mirror of
https://github.com/esphome/esphome.git
synced 2025-11-19 00:05:43 +00:00
Color mode implementation (#2012)
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
#include "mqtt_light.h"
|
||||
#include "esphome/components/light/light_json_schema.h"
|
||||
#include "esphome/core/log.h"
|
||||
|
||||
#ifdef USE_LIGHT
|
||||
@@ -14,7 +15,9 @@ std::string MQTTJSONLightComponent::component_type() const { return "light"; }
|
||||
|
||||
void MQTTJSONLightComponent::setup() {
|
||||
this->subscribe_json(this->get_command_topic_(), [this](const std::string &topic, JsonObject &root) {
|
||||
this->state_->make_call().parse_json(root).perform();
|
||||
LightCall call = this->state_->make_call();
|
||||
LightJSONSchema::parse_json(*this->state_, call, root);
|
||||
call.perform();
|
||||
});
|
||||
|
||||
auto f = std::bind(&MQTTJSONLightComponent::publish_state_, this);
|
||||
@@ -24,21 +27,40 @@ void MQTTJSONLightComponent::setup() {
|
||||
MQTTJSONLightComponent::MQTTJSONLightComponent(LightState *state) : MQTTComponent(), state_(state) {}
|
||||
|
||||
bool MQTTJSONLightComponent::publish_state_() {
|
||||
return this->publish_json(this->get_state_topic_(), [this](JsonObject &root) { this->state_->dump_json(root); });
|
||||
return this->publish_json(this->get_state_topic_(),
|
||||
[this](JsonObject &root) { LightJSONSchema::dump_json(*this->state_, root); });
|
||||
}
|
||||
LightState *MQTTJSONLightComponent::get_state() const { return this->state_; }
|
||||
std::string MQTTJSONLightComponent::friendly_name() const { return this->state_->get_name(); }
|
||||
void MQTTJSONLightComponent::send_discovery(JsonObject &root, mqtt::SendDiscoveryConfig &config) {
|
||||
root["schema"] = "json";
|
||||
auto traits = this->state_->get_traits();
|
||||
if (traits.get_supports_brightness())
|
||||
|
||||
root["color_mode"] = true;
|
||||
JsonArray &color_modes = root.createNestedArray("supported_color_modes");
|
||||
if (traits.supports_color_mode(ColorMode::COLOR_TEMPERATURE))
|
||||
color_modes.add("color_temp");
|
||||
if (traits.supports_color_mode(ColorMode::RGB))
|
||||
color_modes.add("rgb");
|
||||
if (traits.supports_color_mode(ColorMode::RGB_WHITE))
|
||||
color_modes.add("rgbw");
|
||||
if (traits.supports_color_mode(ColorMode::RGB_COLD_WARM_WHITE))
|
||||
color_modes.add("rgbww");
|
||||
if (traits.supports_color_mode(ColorMode::BRIGHTNESS))
|
||||
color_modes.add("brightness");
|
||||
if (traits.supports_color_mode(ColorMode::ON_OFF))
|
||||
color_modes.add("onoff");
|
||||
|
||||
// legacy API
|
||||
if (traits.supports_color_capability(ColorCapability::BRIGHTNESS))
|
||||
root["brightness"] = true;
|
||||
if (traits.get_supports_rgb())
|
||||
if (traits.supports_color_capability(ColorCapability::RGB))
|
||||
root["rgb"] = true;
|
||||
if (traits.get_supports_color_temperature())
|
||||
if (traits.supports_color_capability(ColorCapability::COLOR_TEMPERATURE))
|
||||
root["color_temp"] = true;
|
||||
if (traits.get_supports_rgb_white_value())
|
||||
if (traits.supports_color_capability(ColorCapability::WHITE))
|
||||
root["white_value"] = true;
|
||||
|
||||
if (this->state_->supports_effects()) {
|
||||
root["effect"] = true;
|
||||
JsonArray &effect_list = root.createNestedArray("effect_list");
|
||||
|
||||
Reference in New Issue
Block a user