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

63 lines
1.8 KiB
C++
Raw Normal View History

2023-06-07 13:49:13 -05:00
#include "ratgdo_light_output.h"
2023-06-07 13:27:01 -05:00
#include "../ratgdo_state.h"
#include "esphome/core/log.h"
namespace esphome {
namespace ratgdo {
2023-06-07 13:28:01 -05:00
using namespace esphome::light;
2023-06-07 13:27:01 -05:00
static const char* const TAG = "ratgdo.light";
void RATGDOLightOutput::dump_config()
{
2023-06-07 13:29:05 -05:00
ESP_LOGCONFIG("", "RATGDO Light");
2023-06-07 13:27:01 -05:00
}
2023-06-07 19:31:08 -05:00
void RATGDOLightOutput::on_light_state(esphome::ratgdo::LightState state)
2023-06-07 17:14:35 -05:00
{
2023-06-07 17:15:02 -05:00
ESP_LOGD(TAG, "on_light_state: %d", state);
2023-06-07 17:14:35 -05:00
if (this->light_state_) {
2023-06-09 16:51:34 -05:00
this->has_initial_state_ = true;
2023-06-09 16:45:49 -05:00
set_state(state);
2023-06-07 17:14:35 -05:00
}
}
2023-06-09 16:45:49 -05:00
void RATGDOLightOutput::set_state(esphome::ratgdo::LightState state)
2023-06-09 16:46:28 -05:00
{
2023-06-07 13:27:01 -05:00
2023-06-09 16:47:01 -05:00
bool is_on = state == LightState::LIGHT_STATE_ON;
2023-06-09 16:46:28 -05:00
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();
2023-06-09 16:47:01 -05:00
ESP_LOGD(TAG, "setup_state: getLightState: %d", state);
2023-06-09 16:46:28 -05:00
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;
}
2023-06-09 16:45:53 -05:00
2023-06-09 16:46:28 -05:00
void RATGDOLightOutput::write_state(light::LightState* state)
{
2023-06-09 16:51:34 -05:00
if (!this->has_initial_state_)
return;
2023-06-09 16:46:28 -05:00
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();
}
2023-06-07 13:27:01 -05:00
}
} // namespace ratgdo
} // namespace esphome