From 97adbaff29c161b155ca155c6723ec0c7d8e040e Mon Sep 17 00:00:00 2001 From: wrfz <77174685+wrfz@users.noreply.github.com> Date: Tue, 10 Sep 2024 19:11:29 +0200 Subject: [PATCH] Fix 1x dhw --- .../daikin_rotex_can/daikin_rotex_can.cpp | 22 +++++++++++++------ 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/components/daikin_rotex_can/daikin_rotex_can.cpp b/components/daikin_rotex_can/daikin_rotex_can.cpp index 7aafe29..734c3fa 100644 --- a/components/daikin_rotex_can/daikin_rotex_can.cpp +++ b/components/daikin_rotex_can/daikin_rotex_can.cpp @@ -162,15 +162,23 @@ void DaikinRotexCanComponent::set_generic_number(std::string const& id, float va ///////////////// Buttons ///////////////// void DaikinRotexCanComponent::dhw_run() { TRequest const* pRequest = m_data_requests.get("target_hot_water_temperature"); + if (pRequest != nullptr) { + number::Number* pNumber = pRequest->get_number(); + if (pNumber != nullptr) { + const float temp = pNumber->state; + const std::string name = pRequest->getName(); - const float temp = pRequest->get_sensor()->get_raw_state(); - const std::string name = pRequest->getName(); + m_data_requests.sendSet(name, 70); - m_data_requests.sendSet(name, 70); - - m_dhw_run_lambdas.push_back([temp, name, this]() { - m_data_requests.sendSet(name, temp); - }); + call_later([name, temp, this](){ + m_data_requests.sendSet(name, temp); + }, 10*1000); + } else { + ESP_LOGE("dhw_rum", "Request doesn't have a Number!"); + } + } else { + ESP_LOGE("dhw_rum", "Request couldn't be found!"); + } } void DaikinRotexCanComponent::run_dhw_lambdas() {