7static const char *
const TAG =
"thermostat.climate";
38 auto use_default_preset =
true;
43 if (restore.has_value()) {
44 use_default_preset =
false;
45 restore->to_call(
this).perform();
50 if (use_default_preset) {
66 for (
auto &timer : this->
timer_) {
67 if (timer.active && (timer.started + timer.time <
millis())) {
192 if (
call.get_preset().has_value()) {
200 if (
call.get_custom_preset().has_value()) {
209 if (
call.get_mode().has_value())
211 if (
call.get_fan_mode().has_value())
213 if (
call.get_swing_mode().has_value())
220 if (
call.get_target_temperature_high().has_value()) {
225 if (
call.get_target_temperature().has_value()) {
302 if ((!ignore_timers) &&
311 switch (this->
mode) {
354 return target_action;
367 switch (this->
mode) {
396 return target_action;
417 bool action_ready =
false;
436 ESP_LOGVV(TAG,
"Switching to IDLE/OFF action");
452 ESP_LOGVV(TAG,
"Switching to COOLING action");
466 ESP_LOGVV(TAG,
"Switching to HEATING action");
478 ESP_LOGVV(TAG,
"Switching to FAN_ONLY action");
487 ESP_LOGVV(TAG,
"Switching to DRYING action");
505 if (trig !=
nullptr) {
509 if (trig_fan !=
nullptr) {
510 ESP_LOGVV(TAG,
"Calling FAN_ONLY action with HEATING/COOLING action");
540 ESP_LOGVV(TAG,
"Updating supplemental action...");
554 ESP_LOGVV(TAG,
"Calling supplemental COOLING action");
561 ESP_LOGVV(TAG,
"Calling supplemental HEATING action");
567 if (trig !=
nullptr) {
588 ESP_LOGVV(TAG,
"Switching to FAN_ON mode");
592 ESP_LOGVV(TAG,
"Switching to FAN_OFF mode");
596 ESP_LOGVV(TAG,
"Switching to FAN_AUTO mode");
600 ESP_LOGVV(TAG,
"Switching to FAN_LOW mode");
604 ESP_LOGVV(TAG,
"Switching to FAN_MEDIUM mode");
608 ESP_LOGVV(TAG,
"Switching to FAN_HIGH mode");
612 ESP_LOGVV(TAG,
"Switching to FAN_MIDDLE mode");
616 ESP_LOGVV(TAG,
"Switching to FAN_FOCUS mode");
620 ESP_LOGVV(TAG,
"Switching to FAN_DIFFUSE mode");
624 ESP_LOGVV(TAG,
"Switching to FAN_QUIET mode");
637 if (trig !=
nullptr) {
682 if (trig !=
nullptr) {
704 switch (swing_mode) {
723 if (trig !=
nullptr) {
769 this->
timer_[timer_index].active =
true;
774 auto ret = this->
timer_[timer_index].active;
775 this->
timer_[timer_index].active =
false;
780 return this->
timer_[timer_index].active;
784 return this->
timer_[timer_index].time;
788 return this->
timer_[timer_index].func;
792 ESP_LOGVV(TAG,
"cooling_max_run_time timer expired");
799 ESP_LOGVV(TAG,
"cooling_off timer expired");
805 ESP_LOGVV(TAG,
"cooling_on timer expired");
811 ESP_LOGVV(TAG,
"fan_mode timer expired");
818 ESP_LOGVV(TAG,
"fanning_off timer expired");
823 ESP_LOGVV(TAG,
"fanning_on timer expired");
828 ESP_LOGVV(TAG,
"heating_max_run_time timer expired");
835 ESP_LOGVV(TAG,
"heating_off timer expired");
841 ESP_LOGVV(TAG,
"heating_on timer expired");
847 ESP_LOGVV(TAG,
"idle_on timer expired");
873 if (trig !=
nullptr) {
962 bool is_default_preset) {
963 ESP_LOGCONFIG(TAG,
" %s Is Default: %s", preset_name, YESNO(is_default_preset));
967 ESP_LOGCONFIG(TAG,
" %s Default Target Temperature Low: %.1f°C", preset_name,
970 ESP_LOGCONFIG(TAG,
" %s Default Target Temperature Low: %.1f°C", preset_name, config.
default_temperature);
975 ESP_LOGCONFIG(TAG,
" %s Default Target Temperature High: %.1f°C", preset_name,
978 ESP_LOGCONFIG(TAG,
" %s Default Target Temperature High: %.1f°C", preset_name, config.
default_temperature);
983 ESP_LOGCONFIG(TAG,
" %s Default Mode: %s", preset_name,
987 ESP_LOGCONFIG(TAG,
" %s Default Fan Mode: %s", preset_name,
991 ESP_LOGCONFIG(TAG,
" %s Default Swing Mode: %s", preset_name,
1002 this->preset.value() !=
preset) {
1006 if (trig !=
nullptr) {
1026 ESP_LOGI(TAG,
"Custom preset %s requested",
custom_preset.c_str());
1032 if (trig !=
nullptr) {
1037 ESP_LOGI(TAG,
"Custom preset %s applied",
custom_preset.c_str());
1039 ESP_LOGI(TAG,
"No changes required to apply custom preset %s",
custom_preset.c_str());
1044 ESP_LOGE(TAG,
"Custom Preset %s is not configured, ignoring.",
custom_preset.c_str());
1049 bool something_changed =
false;
1054 something_changed =
true;
1058 something_changed =
true;
1063 something_changed =
true;
1072 something_changed =
true;
1078 something_changed =
true;
1084 something_changed =
true;
1087 return something_changed;
1101 : cool_action_trigger_(new
Trigger<>()),
1102 supplemental_cool_action_trigger_(new
Trigger<>()),
1103 cool_mode_trigger_(new
Trigger<>()),
1104 dry_action_trigger_(new
Trigger<>()),
1105 dry_mode_trigger_(new
Trigger<>()),
1106 heat_action_trigger_(new
Trigger<>()),
1107 supplemental_heat_action_trigger_(new
Trigger<>()),
1108 heat_mode_trigger_(new
Trigger<>()),
1109 auto_mode_trigger_(new
Trigger<>()),
1110 idle_action_trigger_(new
Trigger<>()),
1111 off_mode_trigger_(new
Trigger<>()),
1112 fan_only_action_trigger_(new
Trigger<>()),
1113 fan_only_mode_trigger_(new
Trigger<>()),
1114 fan_mode_on_trigger_(new
Trigger<>()),
1115 fan_mode_off_trigger_(new
Trigger<>()),
1116 fan_mode_auto_trigger_(new
Trigger<>()),
1117 fan_mode_low_trigger_(new
Trigger<>()),
1118 fan_mode_medium_trigger_(new
Trigger<>()),
1119 fan_mode_high_trigger_(new
Trigger<>()),
1120 fan_mode_middle_trigger_(new
Trigger<>()),
1121 fan_mode_focus_trigger_(new
Trigger<>()),
1122 fan_mode_diffuse_trigger_(new
Trigger<>()),
1123 fan_mode_quiet_trigger_(new
Trigger<>()),
1124 swing_mode_both_trigger_(new
Trigger<>()),
1125 swing_mode_off_trigger_(new
Trigger<>()),
1126 swing_mode_horizontal_trigger_(new
Trigger<>()),
1127 swing_mode_vertical_trigger_(new
Trigger<>()),
1128 temperature_change_trigger_(new
Trigger<>()),
1129 preset_change_trigger_(new
Trigger<>()) {}
1202 bool supports_fan_only_action_uses_fan_mode_timer) {
1296 LOG_CLIMATE(
"",
"Thermostat",
this);
1303 ESP_LOGCONFIG(TAG,
" Cooling Parameters:");
1308 ESP_LOGCONFIG(TAG,
" Maximum Run Time: %" PRIu32
"s",
1311 ESP_LOGCONFIG(TAG,
" Minimum Off Time: %" PRIu32
"s",
1313 ESP_LOGCONFIG(TAG,
" Minimum Run Time: %" PRIu32
"s",
1317 ESP_LOGCONFIG(TAG,
" Heating Parameters:");
1322 ESP_LOGCONFIG(TAG,
" Maximum Run Time: %" PRIu32
"s",
1325 ESP_LOGCONFIG(TAG,
" Minimum Off Time: %" PRIu32
"s",
1327 ESP_LOGCONFIG(TAG,
" Minimum Run Time: %" PRIu32
"s",
1331 ESP_LOGCONFIG(TAG,
" Fanning Minimum Off Time: %" PRIu32
"s",
1333 ESP_LOGCONFIG(TAG,
" Fanning Minimum Run Time: %" PRIu32
"s",
1340 ESP_LOGCONFIG(TAG,
" Minimum Fan Mode Switching Time: %" PRIu32
"s",
1344 ESP_LOGCONFIG(TAG,
" Supports AUTO: %s", YESNO(this->
supports_auto_));
1346 ESP_LOGCONFIG(TAG,
" Supports COOL: %s", YESNO(this->
supports_cool_));
1347 ESP_LOGCONFIG(TAG,
" Supports DRY: %s", YESNO(this->
supports_dry_));
1349 ESP_LOGCONFIG(TAG,
" Supports FAN_ONLY_ACTION_USES_FAN_MODE_TIMER: %s",
1358 ESP_LOGCONFIG(TAG,
" Supports HEAT: %s", YESNO(this->
supports_heat_));
1375 ESP_LOGCONFIG(TAG,
" Supported PRESETS: ");
1379 ESP_LOGCONFIG(TAG,
" Supports %s: %s", preset_name, YESNO(
true));
1383 ESP_LOGCONFIG(TAG,
" Supported CUSTOM PRESETS: ");
1385 const auto *preset_name = it.first.c_str();
1387 ESP_LOGCONFIG(TAG,
" Supports %s: %s", preset_name, YESNO(
true));
1388 this->
dump_preset_config_(preset_name, it.second, it.first == this->default_custom_preset_);
1390 ESP_LOGCONFIG(TAG,
" On boot, restore from: %s",
1397 : default_temperature(default_temperature) {}
1400 float default_temperature_high)
1401 : default_temperature_low(default_temperature_low), default_temperature_high(default_temperature_high) {}
BedjetMode mode
BedJet operating mode.
void stop_action()
Stop any action connected to this trigger.
void trigger(Ts... x)
Inform the parent automation that the event has triggered.
This class is used to encode all control actions on a climate device.
const optional< ClimateSwingMode > & get_swing_mode() const
const optional< std::string > & get_custom_preset() const
const optional< float > & get_target_temperature_low() const
const optional< float > & get_target_temperature() const
const optional< ClimatePreset > & get_preset() const
const optional< float > & get_target_temperature_high() const
const optional< ClimateFanMode > & get_fan_mode() const
const optional< ClimateMode > & get_mode() const
ClimateMode mode
The active mode of the climate device.
optional< ClimateFanMode > fan_mode
The active fan mode of the climate device.
ClimateTraits get_traits()
Get the traits of this climate device with all overrides applied.
float target_temperature
The target temperature of the climate device.
float current_humidity
The current humidity of the climate device, as reported from the integration.
ClimateSwingMode swing_mode
The active swing mode of the climate device.
float target_temperature_low
The minimum target temperature of the climate device, for climate devices with split target temperatu...
optional< std::string > custom_preset
The active custom preset mode of the climate device.
float current_temperature
The current temperature of the climate device, as reported from the integration.
ClimateAction action
The active state of the climate device.
void publish_state()
Publish the state of the climate device, to be called from integrations.
optional< ClimatePreset > preset
The active preset of the climate device.
optional< ClimateDeviceRestoreState > restore_state_()
Restore the state of the climate device, call this from your setup() method.
float target_temperature_high
The maximum target temperature of the climate device, for climate devices with split target temperatu...
This class contains all static data for climate devices.
void add_supported_fan_mode(ClimateFanMode mode)
void set_supports_action(bool supports_action)
void set_supports_current_humidity(bool supports_current_humidity)
void add_supported_custom_preset(const std::string &preset)
void add_supported_preset(ClimatePreset preset)
void set_supports_two_point_target_temperature(bool supports_two_point_target_temperature)
void add_supported_mode(ClimateMode mode)
void set_supports_current_temperature(bool supports_current_temperature)
float get_visual_max_temperature() const
void add_supported_swing_mode(ClimateSwingMode mode)
float get_visual_min_temperature() const
value_type value_or(U const &v) const
value_type const & value() const
Base-class for all sensors.
void add_on_state_callback(std::function< void(float)> &&callback)
Add a callback that will be called every time a filtered value arrives.
float state
This member variable stores the last state that has passed through all filters.
Trigger * swing_mode_off_trigger_
The trigger to call when the controller should switch the swing mode to "off".
bool supports_fan_mode_off_
void set_supports_swing_mode_horizontal(bool supports_swing_mode_horizontal)
Trigger * idle_action_trigger_
The trigger to call when the controller should switch to idle action/off mode.
void switch_to_action_(climate::ClimateAction action, bool publish_state=true)
Switch the climate device to the given climate action.
bool supports_fan_mode_quiet_
void set_supports_fan_mode_on(bool supports_fan_mode_on)
Trigger * get_fan_mode_medium_trigger() const
Trigger * preset_change_trigger_
The triggr to call when the preset mode changes.
Trigger * get_swing_mode_vertical_trigger() const
float cooling_deadband_
Hysteresis values used for computing climate actions.
Trigger * heat_action_trigger_
The trigger to call when the controller should switch to heating action/mode.
thermostat::OnBootRestoreFrom on_boot_restore_from_
If set to DEFAULT_PRESET then the default preset is always used.
float supplemental_heat_delta_
bool supports_swing_mode_vertical_
void control(const climate::ClimateCall &call) override
Override control to change settings of the climate device.
Trigger * off_mode_trigger_
void fan_mode_timer_callback_()
Trigger * dry_mode_trigger_
void set_supports_auto(bool supports_auto)
Trigger * get_fan_mode_off_trigger() const
bool use_startup_delay_
Used to start "off" delay timers at boot.
bool heating_action_ready_()
float cool_deadband()
Get current hysteresis values.
bool climate_action_change_delayed()
Returns true if a climate action/fan mode transition is being delayed.
void set_supports_fan_with_heating(bool supports_fan_with_heating)
bool cooling_max_runtime_exceeded_
Flags indicating if maximum allowable run time was exceeded.
Trigger * get_fan_mode_on_trigger() const
Trigger * get_cool_mode_trigger() const
bool supports_fan_mode_medium_
Trigger * get_fan_mode_diffuse_trigger() const
const uint8_t min_timer_duration_
Minimum allowable duration in seconds for action timers.
Trigger * fan_mode_low_trigger_
The trigger to call when the controller should switch the fan to "low" speed.
void set_heat_overrun(float overrun)
Trigger * get_fan_mode_auto_trigger() const
void set_supports_two_points(bool supports_two_points)
void validate_target_temperature_low()
Trigger * fan_mode_auto_trigger_
The trigger to call when the controller should switch the fan to "auto" mode.
void set_heating_maximum_run_time_in_sec(uint32_t time)
void set_supports_fan_only_cooling(bool supports_fan_only_cooling)
bool supports_fan_mode_on_
Whether the controller supports turning on or off just the fan.
bool supports_swing_mode_off_
Trigger * get_fan_mode_middle_trigger() const
void set_supports_heat(bool supports_heat)
void set_supports_fan_only_action_uses_fan_mode_timer(bool fan_only_action_uses_fan_mode_timer)
float set_point_minimum_differential_
Minimum differential required between set points.
bool supports_fan_with_cooling_
Special flags – enables fan_only action to be called with cooling/heating actions.
void set_supports_fan_mode_diffuse(bool supports_fan_mode_diffuse)
void switch_to_swing_mode_(climate::ClimateSwingMode swing_mode, bool publish_state=true)
Switch the climate device to the given climate swing mode.
Trigger * fan_mode_diffuse_trigger_
The trigger to call when the controller should switch the fan to "diffuse" position.
Trigger * fan_only_action_trigger_
The trigger to call when the controller should switch to fan-only action/mode.
Trigger * cool_action_trigger_
The trigger to call when the controller should switch to cooling action/mode.
Trigger * swing_mode_vertical_trigger_
The trigger to call when the controller should switch the swing mode to "vertical".
std::vector< ThermostatClimateTimer > timer_
Climate action timers.
bool change_preset_internal_(const ThermostatClimateTargetTempConfig &config)
Applies the temperature, mode, fan, and swing modes of the provided config.
bool hysteresis_valid()
Set point and hysteresis validation.
void set_supports_fan_mode_auto(bool supports_fan_mode_auto)
bool supplemental_heating_required_()
Trigger * get_fan_only_mode_trigger() const
Trigger * supplemental_cool_action_trigger_
void switch_to_supplemental_action_(climate::ClimateAction action)
bool supports_fan_mode_high_
bool fanning_action_ready_()
Trigger * dry_action_trigger_
The trigger to call when the controller should switch to dry (dehumidification) mode.
Trigger * get_swing_mode_off_trigger() const
void switch_to_mode_(climate::ClimateMode mode, bool publish_state=true)
Switch the climate device to the given climate mode.
Trigger * get_fan_mode_low_trigger() const
Trigger * swing_mode_both_trigger_
The trigger to call when the controller should switch the swing mode to "both".
void set_supports_swing_mode_vertical(bool supports_swing_mode_vertical)
bool cooling_action_ready_()
void heating_max_run_time_timer_callback_()
Trigger * get_dry_action_trigger() const
void validate_target_temperature_high()
void set_supports_fan_only(bool supports_fan_only)
void heating_off_timer_callback_()
void set_sensor(sensor::Sensor *sensor)
bool supports_fan_only_action_uses_fan_mode_timer_
Special flag – enables fan_modes to share timer with fan_only climate action.
void set_supports_swing_mode_off(bool supports_swing_mode_off)
void switch_to_fan_mode_(climate::ClimateFanMode fan_mode, bool publish_state=true)
Switch the climate device to the given climate fan mode.
void set_heating_minimum_off_time_in_sec(uint32_t time)
void heating_on_timer_callback_()
bool supports_swing_mode_both_
Whether the controller supports various swing modes.
void fanning_off_timer_callback_()
Trigger * get_swing_mode_horizontal_trigger() const
Trigger * get_temperature_change_trigger() const
Trigger * get_fan_mode_focus_trigger() const
void validate_target_temperatures()
climate::ClimateTraits traits() override
Return the traits of this controller.
Trigger * swing_mode_horizontal_trigger_
The trigger to call when the controller should switch the swing mode to "horizontal".
Trigger * fan_only_mode_trigger_
void idle_on_timer_callback_()
Trigger * get_swing_mode_both_trigger() const
Trigger * fan_mode_focus_trigger_
The trigger to call when the controller should switch the fan to "focus" position.
Trigger * get_auto_mode_trigger() const
climate::ClimateFanMode locked_fan_mode()
Returns the fan mode that is locked in (check fan_mode_change_delayed(), first!)
void set_humidity_sensor(sensor::Sensor *humidity_sensor)
bool supports_fan_mode_middle_
bool supports_fan_mode_focus_
float prev_target_temperature_low_
void set_supports_fan_mode_middle(bool supports_fan_mode_middle)
void set_supplemental_heat_delta(float delta)
Trigger * temperature_change_trigger_
The trigger to call when the target temperature(s) change(es).
void set_supports_fan_mode_low(bool supports_fan_mode_low)
Trigger * fan_mode_off_trigger_
The trigger to call when the controller should switch off the fan.
Trigger * get_dry_mode_trigger() const
bool timer_active_(ThermostatClimateTimerIndex timer_index)
float supplemental_cool_delta_
Maximum allowable temperature deltas before engauging supplemental cooling/heating actions.
std::map< std::string, ThermostatClimateTargetTempConfig > custom_preset_config_
The set of custom preset configurations this thermostat supports (eg. "My Custom Preset")
Trigger * prev_mode_trigger_
void set_supports_heat_cool(bool supports_heat_cool)
void set_heating_minimum_run_time_in_sec(uint32_t time)
Trigger * get_heat_action_trigger() const
climate::ClimateSwingMode prev_swing_mode_
Trigger * get_supplemental_cool_action_trigger() const
void set_supports_fan_mode_quiet(bool supports_fan_mode_quiet)
bool supplemental_cooling_required_()
void set_supports_dry(bool supports_dry)
void set_cooling_minimum_off_time_in_sec(uint32_t time)
climate::ClimateAction delayed_climate_action()
Returns the climate action that is being delayed (check climate_action_change_delayed(),...
void set_fanning_minimum_off_time_in_sec(uint32_t time)
sensor::Sensor * sensor_
The sensor used for getting the current temperature.
bool drying_action_ready_()
Trigger * get_fan_mode_high_trigger() const
void set_supports_fan_mode_medium(bool supports_fan_mode_medium)
void set_cool_deadband(float deadband)
Trigger * get_fan_mode_quiet_trigger() const
Trigger * get_off_mode_trigger() const
void set_on_boot_restore_from(thermostat::OnBootRestoreFrom on_boot_restore_from)
uint32_t timer_duration_(ThermostatClimateTimerIndex timer_index)
climate::ClimateMode prev_mode_
void set_supports_swing_mode_both(bool supports_swing_mode_both)
void set_supports_cool(bool supports_cool)
void start_timer_(ThermostatClimateTimerIndex timer_index)
Start/cancel/get status of climate action timer.
Trigger * prev_fan_mode_trigger_
Trigger * fan_mode_high_trigger_
The trigger to call when the controller should switch the fan to "high" speed.
Trigger * get_idle_action_trigger() const
void dump_preset_config_(const char *preset_name, const ThermostatClimateTargetTempConfig &config, bool is_default_preset)
void set_set_point_minimum_differential(float differential)
void set_custom_preset_config(const std::string &name, const ThermostatClimateTargetTempConfig &config)
bool supports_fan_with_heating_
void set_heat_deadband(float deadband)
bool supports_fan_mode_low_
Whether the controller supports various fan speeds and/or positions.
bool supports_fan_only_cooling_
Special flag – enables fan to be switched based on target_temperature_high.
void fanning_on_timer_callback_()
void dump_config() override
Trigger * prev_action_trigger_
A reference to the trigger that was previously active.
bool supports_auto_
Whether the controller supports auto/cooling/drying/fanning/heating.
bool supports_swing_mode_horizontal_
climate::ClimateAction supplemental_action_
Store previously-known states.
Trigger * get_supplemental_heat_action_trigger() const
Trigger * get_heat_mode_trigger() const
Trigger * cool_mode_trigger_
void set_fan_mode_minimum_switching_time_in_sec(uint32_t time)
bool supports_fan_mode_diffuse_
void set_cool_overrun(float overrun)
void set_preset_config(climate::ClimatePreset preset, const ThermostatClimateTargetTempConfig &config)
void trigger_supplemental_action_()
void set_supports_fan_with_cooling(bool supports_fan_with_cooling)
Trigger * fan_mode_medium_trigger_
The trigger to call when the controller should switch the fan to "medium" speed.
Trigger * fan_mode_middle_trigger_
The trigger to call when the controller should switch the fan to "middle" position.
Trigger * get_fan_only_action_trigger() const
float prev_target_temperature_high_
void set_supports_fan_mode_focus(bool supports_fan_mode_focus)
void check_temperature_change_trigger_()
Check if the temperature change trigger should be called.
Trigger * fan_mode_on_trigger_
The trigger to call when the controller should switch on the fan.
void set_supports_fan_mode_off(bool supports_fan_mode_off)
climate::ClimateFanMode prev_fan_mode_
void cooling_on_timer_callback_()
void set_use_startup_delay(bool use_startup_delay)
Trigger * heat_mode_trigger_
void cooling_off_timer_callback_()
void change_custom_preset_(const std::string &custom_preset)
Change to a provided custom preset setting; will reset temperature, mode, fan, and swing modes accord...
bool cancel_timer_(ThermostatClimateTimerIndex timer_index)
climate::ClimateAction compute_supplemental_action_()
float prev_target_temperature_
Store previously-known temperatures.
void set_supplemental_cool_delta(float delta)
climate::ClimatePreset default_preset_
Default standard preset to use on start up.
void set_fanning_minimum_run_time_in_sec(uint32_t time)
sensor::Sensor * humidity_sensor_
The sensor used for getting the current humidity.
bool fan_mode_change_delayed()
void cooling_max_run_time_timer_callback_()
set_timeout() callbacks for various actions (see above)
Trigger * prev_swing_mode_trigger_
bool supports_fan_mode_auto_
Whether the controller supports fan auto mode.
Trigger * get_preset_change_trigger() const
void set_cooling_maximum_run_time_in_sec(uint32_t time)
climate::ClimateAction compute_action_(bool ignore_timers=false)
Re-compute the required action of this climate controller.
std::map< climate::ClimatePreset, ThermostatClimateTargetTempConfig > preset_config_
The set of standard preset configurations this thermostat supports (Eg. AWAY, ECO,...
void validate_target_temperature()
bool supports_two_points_
Whether the controller supports two set points.
std::string default_custom_preset_
Default custom preset to use on start up.
bool setup_complete_
setup_complete_ blocks modifying/resetting the temps immediately after boot
Trigger * get_cool_action_trigger() const
void set_idle_minimum_time_in_sec(uint32_t time)
void set_supports_fan_mode_high(bool supports_fan_mode_high)
bool idle_action_ready_()
Is the action ready to be called? Returns true if so.
void change_preset_(climate::ClimatePreset preset)
Change to a provided preset setting; will reset temperature, mode, fan, and swing modes accordingly.
void set_cooling_minimum_run_time_in_sec(uint32_t time)
void refresh()
Call triggers based on updated climate states (modes/actions)
void set_default_preset(const std::string &custom_preset)
Trigger * fan_mode_quiet_trigger_
The trigger to call when the controller should switch the fan to "quiet" position.
Trigger * supplemental_heat_action_trigger_
std::function< void()> timer_cbf_(ThermostatClimateTimerIndex timer_index)
bool heating_max_runtime_exceeded_
Trigger * auto_mode_trigger_
The trigger to call when the controller should switch to auto mode.
bool cooling_required_()
Check if cooling/fanning/heating actions are required; returns true if so.
ClimateSwingMode swing_mode
const LogString * climate_swing_mode_to_string(ClimateSwingMode swing_mode)
Convert the given ClimateSwingMode to a human-readable string.
const LogString * climate_preset_to_string(ClimatePreset preset)
Convert the given PresetMode to a human-readable string.
ClimatePreset
Enum for all preset modes.
@ CLIMATE_PRESET_NONE
No preset is active.
const LogString * climate_fan_mode_to_string(ClimateFanMode fan_mode)
Convert the given ClimateFanMode to a human-readable string.
ClimateSwingMode
Enum for all modes a climate swing can be in.
@ CLIMATE_SWING_OFF
The swing mode is set to Off.
@ CLIMATE_SWING_HORIZONTAL
The fan mode is set to Horizontal.
@ CLIMATE_SWING_VERTICAL
The fan mode is set to Vertical.
@ CLIMATE_SWING_BOTH
The fan mode is set to Both.
ClimateMode
Enum for all modes a climate device can be in.
@ CLIMATE_MODE_DRY
The climate device is set to dry/humidity mode.
@ CLIMATE_MODE_FAN_ONLY
The climate device only has the fan enabled, no heating or cooling is taking place.
@ CLIMATE_MODE_HEAT
The climate device is set to heat to reach the target temperature.
@ CLIMATE_MODE_COOL
The climate device is set to cool to reach the target temperature.
@ CLIMATE_MODE_HEAT_COOL
The climate device is set to heat/cool to reach the target temperature.
@ CLIMATE_MODE_OFF
The climate device is off.
@ CLIMATE_MODE_AUTO
The climate device is adjusting the temperature dynamically.
const LogString * climate_mode_to_string(ClimateMode mode)
Convert the given ClimateMode to a human-readable string.
ClimateAction
Enum for the current action of the climate device. Values match those of ClimateMode.
@ CLIMATE_ACTION_OFF
The climate device is off (inactive or no power)
@ CLIMATE_ACTION_IDLE
The climate device is idle (monitoring climate but no action needed)
@ CLIMATE_ACTION_DRYING
The climate device is drying.
@ CLIMATE_ACTION_HEATING
The climate device is actively heating.
@ CLIMATE_ACTION_COOLING
The climate device is actively cooling.
@ CLIMATE_ACTION_FAN
The climate device is in fan only mode.
@ CLIMATE_FAN_MEDIUM
The fan mode is set to Medium.
@ CLIMATE_FAN_DIFFUSE
The fan mode is set to Diffuse.
@ CLIMATE_FAN_ON
The fan mode is set to On.
@ CLIMATE_FAN_AUTO
The fan mode is set to Auto.
@ CLIMATE_FAN_FOCUS
The fan mode is set to Focus.
@ CLIMATE_FAN_LOW
The fan mode is set to Low.
@ CLIMATE_FAN_MIDDLE
The fan mode is set to Middle.
@ CLIMATE_FAN_QUIET
The fan mode is set to Quiet.
@ CLIMATE_FAN_OFF
The fan mode is set to Off.
@ CLIMATE_FAN_HIGH
The fan mode is set to High.
ThermostatClimateTimerIndex
@ TIMER_HEATING_MAX_RUN_TIME
@ TIMER_COOLING_MAX_RUN_TIME
Providing packet encoding functions for exchanging data with a remote host.
uint32_t IRAM_ATTR HOT millis()
optional< climate::ClimateSwingMode > swing_mode_
optional< climate::ClimateFanMode > fan_mode_
float default_temperature_low
optional< climate::ClimateMode > mode_
float default_temperature
ThermostatClimateTargetTempConfig()
float default_temperature_high