Compare commits

...

4 Commits

Author SHA1 Message Date
Brendan Davis c337481e75
Merge 9f54e2ea30 into a90b6fb65f 2024-06-25 17:50:21 -07:00
JJ a90b6fb65f
Add ID to OTA to allow extension for overrides (#296) 2024-06-26 02:33:24 +02:00
Brendan Davis 9f54e2ea30
Merge branch 'main' into on_door_state_change 2024-01-24 20:32:57 -05:00
brgaulin be16a745a0 feat: add cover.on_state_change trigger
fixes #192
2024-01-22 22:21:33 -05:00
5 changed files with 23 additions and 0 deletions

View File

@ -49,6 +49,7 @@ api:
ota: ota:
- platform: esphome - platform: esphome
id: ratgdo_ota
sensor: sensor:
- platform: ratgdo - platform: ratgdo

View File

@ -29,6 +29,7 @@ ratgdo:
ota: ota:
- platform: esphome - platform: esphome
id: ratgdo_ota
binary_sensor: binary_sensor:
- platform: ratgdo - platform: ratgdo

View File

@ -32,6 +32,7 @@ ratgdo:
ota: ota:
- platform: esphome - platform: esphome
id: ratgdo_ota
lock: lock:
- platform: ratgdo - platform: ratgdo

View File

@ -18,9 +18,13 @@ CoverOpeningTrigger = ratgdo_ns.class_(
CoverClosingTrigger = ratgdo_ns.class_( CoverClosingTrigger = ratgdo_ns.class_(
"CoverClosingTrigger", automation.Trigger.template() "CoverClosingTrigger", automation.Trigger.template()
) )
CoverStateTrigger = ratgdo_ns.class_(
"CoverStateTrigger", automation.Trigger.template()
)
CONF_ON_OPENING = "on_opening" CONF_ON_OPENING = "on_opening"
CONF_ON_CLOSING = "on_closing" CONF_ON_CLOSING = "on_closing"
CONF_ON_STATE_CHANGE = "on_state_change"
CONFIG_SCHEMA = cover.COVER_SCHEMA.extend( CONFIG_SCHEMA = cover.COVER_SCHEMA.extend(
{ {
@ -31,6 +35,9 @@ CONFIG_SCHEMA = cover.COVER_SCHEMA.extend(
cv.Optional(CONF_ON_CLOSING): automation.validate_automation( cv.Optional(CONF_ON_CLOSING): automation.validate_automation(
{cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(CoverClosingTrigger)} {cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(CoverClosingTrigger)}
), ),
cv.Optional(CONF_ON_STATE_CHANGE): automation.validate_automation(
{cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(CoverStateTrigger)}
),
} }
).extend(RATGDO_CLIENT_SCHMEA) ).extend(RATGDO_CLIENT_SCHMEA)
@ -46,5 +53,8 @@ async def to_code(config):
for conf in config.get(CONF_ON_CLOSING, []): for conf in config.get(CONF_ON_CLOSING, []):
trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var) trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var)
await automation.build_automation(trigger, [], conf) await automation.build_automation(trigger, [], conf)
for conf in config.get(CONF_ON_STATE_CHANGE, []):
trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var)
await automation.build_automation(trigger, [], conf)
await register_ratgdo_child(var, config) await register_ratgdo_child(var, config)

View File

@ -31,5 +31,15 @@ namespace ratgdo {
} }
}; };
class CoverStateTrigger : public Trigger<> {
public:
CoverStateTrigger(cover::Cover* a_cover)
{
a_cover->add_on_state_callback([this, a_cover]() {
this->trigger();
});
}
};
} // namespace ratgdo } // namespace ratgdo
} // namespace esphome } // namespace esphome