mirror of
https://github.com/esphome/esphome.git
synced 2025-10-30 06:33:51 +00:00
Cleanup dashboard JS (#491)
* Cleanup dashboard JS * Add vscode * Save start_mark/end_mark * Updates * Updates * Remove need for cv.nameable It's a bit hacky but removes so much bloat from integrations * Add enum helper * Document APIs, and Improvements * Fixes * Fixes * Update PULL_REQUEST_TEMPLATE.md * Updates * Updates * Updates
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
import esphome.codegen as cg
|
||||
import esphome.config_validation as cv
|
||||
from esphome.components import mqtt, sensor
|
||||
from esphome.const import CONF_ID, CONF_NAME, CONF_QOS, CONF_TOPIC
|
||||
from esphome.const import CONF_ID, CONF_QOS, CONF_TOPIC, UNIT_EMPTY, ICON_EMPTY
|
||||
from .. import mqtt_subscribe_ns
|
||||
|
||||
DEPENDENCIES = ['mqtt']
|
||||
@@ -9,19 +9,20 @@ DEPENDENCIES = ['mqtt']
|
||||
CONF_MQTT_PARENT_ID = 'mqtt_parent_id'
|
||||
MQTTSubscribeSensor = mqtt_subscribe_ns.class_('MQTTSubscribeSensor', sensor.Sensor, cg.Component)
|
||||
|
||||
CONFIG_SCHEMA = cv.nameable(sensor.SENSOR_SCHEMA.extend({
|
||||
cv.GenerateID(): cv.declare_variable_id(MQTTSubscribeSensor),
|
||||
cv.GenerateID(CONF_MQTT_PARENT_ID): cv.use_variable_id(mqtt.MQTTClientComponent),
|
||||
CONFIG_SCHEMA = sensor.sensor_schema(UNIT_EMPTY, ICON_EMPTY, 1).extend({
|
||||
cv.GenerateID(): cv.declare_id(MQTTSubscribeSensor),
|
||||
cv.GenerateID(CONF_MQTT_PARENT_ID): cv.use_id(mqtt.MQTTClientComponent),
|
||||
cv.Required(CONF_TOPIC): cv.subscribe_topic,
|
||||
cv.Optional(CONF_QOS, default=0): cv.mqtt_qos,
|
||||
}).extend(cv.COMPONENT_SCHEMA))
|
||||
}).extend(cv.COMPONENT_SCHEMA)
|
||||
|
||||
|
||||
def to_code(config):
|
||||
parent = yield cg.get_variable(config[CONF_MQTT_PARENT_ID])
|
||||
var = cg.new_Pvariable(config[CONF_ID], config[CONF_NAME], parent, config[CONF_TOPIC])
|
||||
var = cg.new_Pvariable(config[CONF_ID])
|
||||
yield cg.register_component(var, config)
|
||||
|
||||
cg.add(var.set_qos(config[CONF_QOS]))
|
||||
|
||||
yield sensor.register_sensor(var, config)
|
||||
|
||||
parent = yield cg.get_variable(config[CONF_MQTT_PARENT_ID])
|
||||
cg.add(var.set_parent(parent))
|
||||
cg.add(var.set_topic(config[CONF_TOPIC]))
|
||||
cg.add(var.set_qos(config[CONF_QOS]))
|
||||
|
||||
@@ -9,9 +9,8 @@ namespace mqtt_subscribe {
|
||||
|
||||
class MQTTSubscribeSensor : public sensor::Sensor, public Component {
|
||||
public:
|
||||
MQTTSubscribeSensor(const std::string &name, mqtt::MQTTClientComponent *parent, const std::string &topic)
|
||||
: Sensor(name), parent_(parent), topic_(topic) {}
|
||||
|
||||
void set_parent(mqtt::MQTTClientComponent *parent) { parent_ = parent; }
|
||||
void set_topic(const std::string &topic) { topic_ = topic; }
|
||||
void setup() override;
|
||||
void dump_config() override;
|
||||
float get_setup_priority() const override;
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
import esphome.codegen as cg
|
||||
import esphome.config_validation as cv
|
||||
from esphome.components import text_sensor, mqtt
|
||||
from esphome.const import CONF_ID, CONF_NAME, CONF_QOS, CONF_TOPIC
|
||||
from esphome.const import CONF_ID, CONF_QOS, CONF_TOPIC
|
||||
from .. import mqtt_subscribe_ns
|
||||
|
||||
DEPENDENCIES = ['mqtt']
|
||||
@@ -10,19 +10,20 @@ CONF_MQTT_PARENT_ID = 'mqtt_parent_id'
|
||||
MQTTSubscribeTextSensor = mqtt_subscribe_ns.class_('MQTTSubscribeTextSensor',
|
||||
text_sensor.TextSensor, cg.Component)
|
||||
|
||||
CONFIG_SCHEMA = cv.nameable(text_sensor.TEXT_SENSOR_SCHEMA.extend({
|
||||
cv.GenerateID(): cv.declare_variable_id(MQTTSubscribeTextSensor),
|
||||
cv.GenerateID(CONF_MQTT_PARENT_ID): cv.use_variable_id(mqtt.MQTTClientComponent),
|
||||
CONFIG_SCHEMA = text_sensor.TEXT_SENSOR_SCHEMA.extend({
|
||||
cv.GenerateID(): cv.declare_id(MQTTSubscribeTextSensor),
|
||||
cv.GenerateID(CONF_MQTT_PARENT_ID): cv.use_id(mqtt.MQTTClientComponent),
|
||||
cv.Required(CONF_TOPIC): cv.subscribe_topic,
|
||||
cv.Optional(CONF_QOS, default=0): cv.mqtt_qos,
|
||||
}).extend(cv.COMPONENT_SCHEMA))
|
||||
}).extend(cv.COMPONENT_SCHEMA)
|
||||
|
||||
|
||||
def to_code(config):
|
||||
parent = yield cg.get_variable(config[CONF_MQTT_PARENT_ID])
|
||||
var = cg.new_Pvariable(config[CONF_ID], config[CONF_NAME], parent, config[CONF_TOPIC])
|
||||
var = cg.new_Pvariable(config[CONF_ID])
|
||||
yield cg.register_component(var, config)
|
||||
|
||||
cg.add(var.set_qos(config[CONF_QOS]))
|
||||
|
||||
yield text_sensor.register_text_sensor(var, config)
|
||||
|
||||
parent = yield cg.get_variable(config[CONF_MQTT_PARENT_ID])
|
||||
cg.add(var.set_parent(parent))
|
||||
cg.add(var.set_topic(config[CONF_TOPIC]))
|
||||
cg.add(var.set_qos(config[CONF_QOS]))
|
||||
|
||||
@@ -9,9 +9,8 @@ namespace mqtt_subscribe {
|
||||
|
||||
class MQTTSubscribeTextSensor : public text_sensor::TextSensor, public Component {
|
||||
public:
|
||||
MQTTSubscribeTextSensor(const std::string &name, mqtt::MQTTClientComponent *parent, const std::string &topic)
|
||||
: TextSensor(name), parent_(parent), topic_(topic) {}
|
||||
|
||||
void set_parent(mqtt::MQTTClientComponent *parent) { parent_ = parent; }
|
||||
void set_topic(const std::string &topic) { topic_ = topic; }
|
||||
void setup() override;
|
||||
void dump_config() override;
|
||||
float get_setup_priority() const override;
|
||||
|
||||
Reference in New Issue
Block a user