#pragma once #include "esphome/core/component.h" #include "esphome/core/log.h" #include "esphome/components/uart/uart.h" #include "esphome/components/climate/climate.h" #ifdef USE_REMOTE_TRANSMITTER #include "esphome/components/remote_base/midea_protocol.h" #include "esphome/components/remote_transmitter/remote_transmitter.h" #endif #include #include namespace esphome { namespace midea { using climate::ClimatePreset; using climate::ClimateTraits; using climate::ClimateMode; using climate::ClimateSwingMode; using climate::ClimateFanMode; template class ApplianceBase : public Component, public uart::UARTDevice, public climate::Climate { static_assert(std::is_base_of::value, "T must derive from dudanov::midea::ApplianceBase class"); public: ApplianceBase() { this->base_.setStream(this); this->base_.addOnStateCallback(std::bind(&ApplianceBase::on_status_change, this)); dudanov::midea::ApplianceBase::setLogger([](int level, const char *tag, int line, String format, va_list args) { esp_log_vprintf_(level, tag, line, format.c_str(), args); }); } bool can_proceed() override { return this->base_.getAutoconfStatus() != dudanov::midea::AutoconfStatus::AUTOCONF_PROGRESS; } float get_setup_priority() const override { return setup_priority::BEFORE_CONNECTION; } void setup() override { this->base_.setup(); } void loop() override { this->base_.loop(); } void set_period(uint32_t ms) { this->base_.setPeriod(ms); } void set_response_timeout(uint32_t ms) { this->base_.setTimeout(ms); } void set_request_attempts(uint32_t attempts) { this->base_.setNumAttempts(attempts); } void set_beeper_feedback(bool state) { this->base_.setBeeper(state); } void set_autoconf(bool value) { this->base_.setAutoconf(value); } void set_supported_modes(std::set modes) { this->supported_modes_ = std::move(modes); } void set_supported_swing_modes(std::set modes) { this->supported_swing_modes_ = std::move(modes); } void set_supported_presets(std::set presets) { this->supported_presets_ = std::move(presets); } void set_custom_presets(std::set presets) { this->supported_custom_presets_ = std::move(presets); } void set_custom_fan_modes(std::set modes) { this->supported_custom_fan_modes_ = std::move(modes); } virtual void on_status_change() = 0; #ifdef USE_REMOTE_TRANSMITTER void set_transmitter(remote_transmitter::RemoteTransmitterComponent *transmitter) { this->transmitter_ = transmitter; } void transmit_ir(remote_base::MideaData &data) { data.finalize(); auto transmit = this->transmitter_->transmit(); remote_base::MideaProtocol().encode(transmit.get_data(), data); transmit.perform(); } #endif protected: T base_; std::set supported_modes_{}; std::set supported_swing_modes_{}; std::set supported_presets_{}; std::set supported_custom_presets_{}; std::set supported_custom_fan_modes_{}; #ifdef USE_REMOTE_TRANSMITTER remote_transmitter::RemoteTransmitterComponent *transmitter_{nullptr}; #endif }; } // namespace midea } // namespace esphome