esphome-ratgdo/components/ratgdo/light/ratgdo_light_output.cpp

60 lines
1.7 KiB
C++

#include "ratgdo_light_output.h"
#include "../ratgdo_state.h"
#include "esphome/core/log.h"
namespace esphome {
namespace ratgdo {
using namespace esphome::light;
static const char* const TAG = "ratgdo.light";
void RATGDOLightOutput::dump_config()
{
ESP_LOGCONFIG("", "RATGDO Light");
}
void RATGDOLightOutput::on_light_state(esphome::ratgdo::LightState state)
{
ESP_LOGD(TAG, "on_light_state: %d", state);
if (this->light_state_) {
set_state(state);
}
}
void RATGDOLightOutput::set_state(esphome::ratgdo::LightState state)
{
bool is_on = state == LightState::LIGHT_STATE_ON;
this->light_state_->current_values.set_state(is_on);
this->light_state_->remote_values.set_state(is_on);
this->light_state_->publish_state();
}
void RATGDOLightOutput::setup_state(light::LightState* light_state)
{
esphome::ratgdo::LightState state = this->parent_->getLightState();
ESP_LOGD(TAG, "setup_state: getLightState: %d", state);
this->light_state_ = light_state;
this->set_state(state);
}
LightTraits RATGDOLightOutput::get_traits()
{
auto traits = LightTraits();
traits.set_supported_color_modes({ light::ColorMode::ON_OFF });
return traits;
}
void RATGDOLightOutput::write_state(light::LightState* state)
{
bool binary;
state->current_values_as_binary(&binary);
if (binary) {
ESP_LOGD(TAG, "output call lightOn");
this->parent_->lightOn();
} else {
ESP_LOGD(TAG, "output call lightOff");
this->parent_->lightOff();
}
}
} // namespace ratgdo
} // namespace esphome