From 32c4af34f1ca02483fbb7e44716a20b40560a138 Mon Sep 17 00:00:00 2001 From: reaw55 <58457329+reaw55@users.noreply.github.com> Date: Sat, 22 Jun 2024 06:22:53 +0700 Subject: [PATCH] adjust lock check --- src/ise_display.cpp | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/src/ise_display.cpp b/src/ise_display.cpp index bfd7ed2..db31649 100644 --- a/src/ise_display.cpp +++ b/src/ise_display.cpp @@ -535,6 +535,13 @@ void ISEDisplay::updatePMinside(u_int16_t pm25_inside) void ISEDisplay::setPMstate(bool is_pm_on, uint8_t pm_fan_speed) { + //check pm_lock if true do nothing + this->pm_lock_state = strcmp(pm_lock->getValue(), "on") == 0; + if (this->pm_lock_state == true) + { + ESP_LOGI("ISEDisplay", "PM lock is on, do nothing"); + return; + } ESP_LOGI("ISEDisplay", "Setting PM state: %d, fan speed: %d", is_pm_on, pm_fan_speed); char buffer[4]; itoa(pm_fan_speed, buffer, DEC); @@ -562,6 +569,13 @@ void ISEDisplay::setACstate(uint8_t ac_fan_speed, uint8_t ac_mode, uint8_t ac_te this->ac_fan_speed = ac_fan_speed; this->ac_mode = ac_mode; this->ac_temperature = ac_temperature; + //check ac_lock if true do nothing + this->ac_lock_state = strcmp(ac_lock->getValue(), "on") == 0; + if (this->ac_lock_state == true) + { + ESP_LOGI("ISEDisplay", "AC lock is on, do nothing"); + return; + } // check ac_temp is within bound of daikin if (this->ac_temperature < DAIKIN_MIN_TEMP) {