mirror of
https://github.com/esphome/esphome.git
synced 2025-10-01 17:42:22 +01:00
feat: integrate RealTimeClock into DynamicLampComponent for enhanced time management
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
import esphome.codegen as cg
|
||||
from esphome.components import output
|
||||
from esphome.components.time import RealTimeClock
|
||||
import esphome.config_validation as cv
|
||||
from esphome.const import CONF_ID
|
||||
|
||||
@@ -10,17 +11,22 @@ dynamic_lamp_ns = cg.esphome_ns.namespace('dynamic_lamp')
|
||||
DynamicLampComponent = dynamic_lamp_ns.class_('DynamicLampComponent', cg.Component)
|
||||
CONF_DYNAMIC_LAMP_ID = "dynamic_lamp_id"
|
||||
|
||||
CONF_RTC = 'rtc'
|
||||
CONF_SAVE_MODE = 'save_mode'
|
||||
CONF_AVAILABLE_OUTPUTS = 'available_outputs'
|
||||
CONFIG_SCHEMA = cv.Schema({
|
||||
cv.GenerateID(CONF_ID): cv.declare_id(DynamicLampComponent),
|
||||
cv.Required(CONF_RTC): cv.use_id(RealTimeClock),
|
||||
cv.Required(CONF_AVAILABLE_OUTPUTS): [cv.use_id(output.FloatOutput)],
|
||||
cv.Optional(CONF_SAVE_MODE, default=0): cv.int_range(0, 1),
|
||||
}).extend(cv.COMPONENT_SCHEMA)
|
||||
|
||||
|
||||
async def to_code(config):
|
||||
var = cg.new_Pvariable(config[CONF_ID])
|
||||
var = cg.new_Pvariable(
|
||||
config[CONF_ID],
|
||||
await cg.get_variable(config[CONF_RTC]),
|
||||
)
|
||||
await cg.register_component(var, config)
|
||||
for outputPointer in config.get(CONF_AVAILABLE_OUTPUTS, []):
|
||||
idstr_ = str(outputPointer)
|
||||
|
@@ -244,7 +244,7 @@ bool DynamicLampComponent::add_timer(std::string lamp_name, bool timer_active, u
|
||||
new_timer.friday = friday;
|
||||
new_timer.saturday = saturday;
|
||||
new_timer.sunday = sunday;
|
||||
ESPTime now = this->time_->now();
|
||||
ESPTime now = this->rtc_->now();
|
||||
time_t begin_date = now.to_time_t();
|
||||
time_t end_date = now.increment_days(1).to_time_t();
|
||||
new_timer.begin_date = begin_date;
|
||||
|
@@ -80,14 +80,15 @@ struct DynamicLampTimer {
|
||||
bool saturday : 1;
|
||||
bool sunday : 1;
|
||||
unsigned char :0;
|
||||
ESPTime begin_date : 64;
|
||||
ESPTime end_date : 64;
|
||||
time_t begin_date : 64;
|
||||
time_t end_date : 64;
|
||||
};
|
||||
|
||||
class DynamicLamp;
|
||||
|
||||
class DynamicLampComponent : public Component {
|
||||
public:
|
||||
explicit DynamicLampComponent(time::RealTimeClock *rtc) : rtc_(rtc) {}
|
||||
void setup() override;
|
||||
void loop() override;
|
||||
void dump_config() override;
|
||||
@@ -107,6 +108,7 @@ class DynamicLampComponent : public Component {
|
||||
|
||||
protected:
|
||||
friend class DynamicLamp;
|
||||
time::RealTimeClock *rtc_;
|
||||
void restore_lamp_values_(uint8_t lamp_number);
|
||||
void set_lamp_values_(uint8_t lamp_number, bool active, uint16_t selected_outputs, uint8_t mode, uint8_t mode_value);
|
||||
bool write_state_(uint8_t lamp_number, float state);
|
||||
@@ -115,6 +117,7 @@ class DynamicLampComponent : public Component {
|
||||
LinkedOutput available_outputs_[16];
|
||||
uint8_t save_mode_;
|
||||
uint8_t lamp_count_ = 0;
|
||||
|
||||
};
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user