Skip to content

Commit

Permalink
add RC30 ww parameters, #117
Browse files Browse the repository at this point in the history
  • Loading branch information
MichaelDvP committed Oct 1, 2021
1 parent 4f24035 commit eea32ad
Show file tree
Hide file tree
Showing 5 changed files with 69 additions and 41 deletions.
6 changes: 4 additions & 2 deletions interface/src/project/EMSESPtypes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,8 @@ export enum DeviceValueUOM {
KB,
SECONDS,
DBM,
MV
MV,
OCLOCK
}

export const DeviceValueUOM_s = [
Expand All @@ -111,5 +112,6 @@ export const DeviceValueUOM_s = [
'KB',
'seconds',
'dBm',
'mV'
'mV',
"o'clock"
];
96 changes: 60 additions & 36 deletions src/devices/thermostat.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1340,17 +1340,17 @@ bool Thermostat::set_wwmode(const char * value, const int8_t id) {

if ((model() == EMS_DEVICE_FLAG_RC300) || (model() == EMS_DEVICE_FLAG_RC100)) {
if (!Helpers::value2enum(value, set, FL_(enum_wwMode))) {
LOG_WARNING(F("Set warm water mode: Invalid mode"));
LOG_WARNING(F("Set ww mode: Invalid mode"));
return false;
}
LOG_INFO(F("Setting warm water mode to %s"), value);
LOG_INFO(F("Setting ww mode to %s"), value);
write_command(0x02F5, 2, set, 0x02F5);
} else {
if (!Helpers::value2enum(value, set, FL_(enum_wwMode2))) {
LOG_WARNING(F("Set warm water mode: Invalid mode"));
LOG_WARNING(F("Set ww mode: Invalid mode"));
return false;
}
LOG_INFO(F("Setting warm water mode to %s"), value);
LOG_INFO(F("Setting ww mode to %s"), value);
write_command(EMS_TYPE_wwSettings, 2, set, EMS_TYPE_wwSettings);
}
return true;
Expand All @@ -1360,10 +1360,10 @@ bool Thermostat::set_wwmode(const char * value, const int8_t id) {
bool Thermostat::set_wwtemp(const char * value, const int8_t id) {
int t = 0;
if (!Helpers::value2number(value, t)) {
LOG_WARNING(F("Set warm water high temperature: Invalid value"));
LOG_WARNING(F("Set ww high temperature: Invalid value"));
return false;
}
LOG_INFO(F("Setting warm water high temperature to %d C"), t);
LOG_INFO(F("Setting ww high temperature to %d C"), t);
write_command(0x031B, 0, t, 0x031B);
return true;
}
Expand All @@ -1372,10 +1372,10 @@ bool Thermostat::set_wwtemp(const char * value, const int8_t id) {
bool Thermostat::set_wwtemplow(const char * value, const int8_t id) {
int t = 0;
if (!Helpers::value2number(value, t)) {
LOG_WARNING(F("Set warm water low temperature: Invalid value"));
LOG_WARNING(F("Set ww low temperature: Invalid value"));
return false;
}
LOG_INFO(F("Setting warm water low temperature to %d C"), t);
LOG_INFO(F("Setting ww low temperature to %d C"), t);
write_command(0x031B, 1, t, 0x031B);
return true;
}
Expand All @@ -1384,10 +1384,10 @@ bool Thermostat::set_wwtemplow(const char * value, const int8_t id) {
bool Thermostat::set_wwcharge(const char * value, const int8_t id) {
bool b = false;
if (!Helpers::value2bool(value, b)) {
LOG_WARNING(F("Set warm water charge: Invalid value"));
LOG_WARNING(F("Set ww charge: Invalid value"));
return false;
}
LOG_INFO(F("Setting warm water charge to %s"), b ? F_(on) : F_(off));
LOG_INFO(F("Setting ww charge to %s"), b ? F_(on) : F_(off));
write_command(0x02F5, 11, b ? 0xFF : 0x00, 0x02F5);
return true;
}
Expand All @@ -1396,11 +1396,11 @@ bool Thermostat::set_wwcharge(const char * value, const int8_t id) {
bool Thermostat::set_wwchargeduration(const char * value, const int8_t id) {
int t = 0xFF;
if (!Helpers::value2number(value, t)) {
LOG_WARNING(F("Set warm water charge duration: Invalid value"));
LOG_WARNING(F("Set ww charge duration: Invalid value"));
return false;
}
t = (t + 8) / 15;
LOG_INFO(F("Setting warm water charge duration to %d min"), t * 15);
LOG_INFO(F("Setting ww charge duration to %d min"), t * 15);
write_command(0x2F5, 10, t, 0x02F5);
return true;
}
Expand Down Expand Up @@ -1431,102 +1431,102 @@ bool Thermostat::set_wwcircmode(const char * value, const int8_t id) {

if ((model() == EMS_DEVICE_FLAG_RC300) || (model() == EMS_DEVICE_FLAG_RC100)) {
if (!Helpers::value2enum(value, set, FL_(enum_wwCircMode))) {
LOG_WARNING(F("Set warm water circulation mode: Invalid mode"));
LOG_WARNING(F("Set ww circulation mode: Invalid mode"));
return false;
}
LOG_INFO(F("Setting warm water circulation mode to %s"), value);
LOG_INFO(F("Setting ww circulation mode to %s"), value);
write_command(0x02F5, 3, set, 0x02F5);
return true;
}
if (!Helpers::value2enum(value, set, FL_(enum_wwCircMode2))) {
LOG_WARNING(F("Set warm water circulation mode: Invalid mode"));
if (!Helpers::value2enum(value, set, FL_(enum_wwMode2))) {
LOG_WARNING(F("Set ww circulation mode: Invalid mode"));
return false;
}
LOG_INFO(F("Setting warm water circulation mode to %s"), value);
LOG_INFO(F("Setting ww circulation mode to %s"), value);
write_command(EMS_TYPE_wwSettings, 3, set, EMS_TYPE_wwSettings);
return true;
}

bool Thermostat::set_wwDisinfect(const char * value, const int8_t id) {
bool b = false;
if (!Helpers::value2bool(value, b)) {
LOG_WARNING(F("Set warm water disinfect: Invalid value"));
LOG_WARNING(F("Set ww disinfect: Invalid value"));
return false;
}
LOG_INFO(F("Setting warm water disinfect to %s"), b ? F_(on) : F_(off));
LOG_INFO(F("Setting ww disinfect to %s"), b ? F_(on) : F_(off));
write_command(0x37, 4, b ? 0xFF : 0x00, 0x37);
return true;
}
bool Thermostat::set_wwDisinfectDay(const char * value, const int8_t id) {
uint8_t set = 0xFF;
if (!Helpers::value2enum(value, set, FL_(enum_dayOfWeek))) {
LOG_WARNING(F("Set warm water disinfection day: Invalid day"));
LOG_WARNING(F("Set ww disinfection day: Invalid day"));
return false;
}
LOG_INFO(F("Setting warm water disinfection day to %s"), value);
LOG_INFO(F("Setting ww disinfection day to %s"), value);
write_command(0x37, 5, set, 0x37);
return true;
}

bool Thermostat::set_wwDisinfectHour(const char * value, const int8_t id) {
int set;
if (!Helpers::value2number(value, set)) {
LOG_WARNING(F("Set warm water disinfection hour: Invalid"));
LOG_WARNING(F("Set ww disinfection hour: Invalid"));
return false;
}
if (set < 0 || set > 23) {
LOG_WARNING(F("Set warm water disinfection hour: Invalid"));
LOG_WARNING(F("Set ww disinfection hour: Invalid"));
return false;
}
LOG_INFO(F("Setting warm water disinfection hour to %s"), value);
LOG_INFO(F("Setting ww disinfection hour to %s"), value);
write_command(0x37, 6, set, 0x37);
return true;
}

bool Thermostat::set_wwMaxTemp(const char * value, const int8_t id) {
int t = 0;
if (!Helpers::value2number(value, t)) {
LOG_WARNING(F("Set warm water max temperature: Invalid value"));
LOG_WARNING(F("Set ww max temperature: Invalid value"));
return false;
}
if (t < 0 || t > 90) {
LOG_WARNING(F("Set warm water max temperature: Invalid value"));
LOG_WARNING(F("Set ww max temperature: Invalid value"));
return false;
}
LOG_INFO(F("Setting warm water max temperature to %d C"), t);
LOG_INFO(F("Setting ww max temperature to %d C"), t);
write_command(0x37, 8, t, 0x37);
return true;
}

bool Thermostat::set_wwOneTimeKey(const char * value, const int8_t id) {
bool b = false;
if (!Helpers::value2bool(value, b)) {
LOG_WARNING(F("Set warm water loading one time key: Invalid value"));
LOG_WARNING(F("Set ww loading one time key: Invalid value"));
return false;
}
LOG_INFO(F("Setting warm water loading one time key to %s"), value);
LOG_INFO(F("Setting ww loading one time key to %s"), value);
write_command(0x37, 9, b ? 0xFF : 0x00, 0x37);
return true;
}

bool Thermostat::set_wwProgMode(const char * value, const int8_t id) {
uint8_t set = 0xFF;
if (!Helpers::value2enum(value, set, FL_(enum_wwProgMode))) {
LOG_WARNING(F("Set warm water program mode: Invalid mode"));
LOG_WARNING(F("Set ww program mode: Invalid mode"));
return false;
}
LOG_INFO(F("Setting warm water program mode to %s"), value);
LOG_INFO(F("Setting ww program mode to %s"), value);
write_command(0x37, 0, set ? 0xFF : 0x00, 0x37);
return true;
}

bool Thermostat::set_wwCircProg(const char * value, const int8_t id) {
uint8_t set = 0xFF;
if (!Helpers::value2enum(value, set, FL_(enum_wwProgMode))) {
LOG_WARNING(F("Set warm water circulation program mode: Invalid mode"));
LOG_WARNING(F("Set ww circulation program mode: Invalid mode"));
return false;
}
LOG_INFO(F("Setting warm water circulation program mode to %s"), value);
LOG_INFO(F("Setting ww circulation program mode to %s"), value);
write_command(0x37, 1, set ? 0xFF : 0x00, 0x37);
return true;
}
Expand Down Expand Up @@ -2490,7 +2490,31 @@ void Thermostat::register_device_values() {
MAKE_CF_CB(set_building));
register_device_value(TAG_DEVICE_DATA_WW, &wwMode_, DeviceValueType::ENUM, FL_(enum_wwMode2), FL_(wwMode), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwmode));
register_device_value(
TAG_DEVICE_DATA_WW, &wwCircMode_, DeviceValueType::ENUM, FL_(enum_wwCircMode2), FL_(wwCircMode), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwcircmode));
TAG_DEVICE_DATA_WW, &wwCircMode_, DeviceValueType::ENUM, FL_(enum_wwMode2), FL_(wwCircMode), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwcircmode));
register_device_value(
TAG_DEVICE_DATA_WW, &wwProgMode_, DeviceValueType::ENUM, FL_(enum_wwProgMode), FL_(wwProgMode), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwProgMode));
register_device_value(
TAG_DEVICE_DATA_WW, &wwCircProg_, DeviceValueType::ENUM, FL_(enum_wwProgMode), FL_(wwCircProg), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwCircProg));
register_device_value(TAG_DEVICE_DATA_WW, &wwDisinfect_, DeviceValueType::BOOL, nullptr, FL_(wwDisinfect), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwDisinfect));
register_device_value(TAG_DEVICE_DATA_WW,
&wwDisinfectDay_,
DeviceValueType::ENUM,
FL_(enum_dayOfWeek),
FL_(wwDisinfectDay),
DeviceValueUOM::NONE,
MAKE_CF_CB(set_wwDisinfectDay));
register_device_value(TAG_DEVICE_DATA_WW,
&wwDisinfectHour_,
DeviceValueType::UINT,
nullptr,
FL_(wwDisinfectHour),
DeviceValueUOM::OCLOCK,
MAKE_CF_CB(set_wwDisinfectHour),
0,
23);
register_device_value(TAG_DEVICE_DATA_WW, &wwMaxTemp_, DeviceValueType::UINT, nullptr, FL_(wwMaxTemp), DeviceValueUOM::DEGREES, MAKE_CF_CB(set_wwMaxTemp));
register_device_value(
TAG_DEVICE_DATA_WW, &wwOneTimeKey_, DeviceValueType::BOOL, nullptr, FL_(wwOneTimeKey), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwOneTimeKey));
break;
case EMS_DEVICE_FLAG_RC35:
register_device_value(TAG_THERMOSTAT_DATA, &dateTime_, DeviceValueType::STRING, nullptr, FL_(dateTime), DeviceValueUOM::NONE, MAKE_CF_CB(set_datetime));
Expand Down Expand Up @@ -2521,7 +2545,7 @@ void Thermostat::register_device_values() {
MAKE_CF_CB(set_building));
register_device_value(TAG_DEVICE_DATA_WW, &wwMode_, DeviceValueType::ENUM, FL_(enum_wwMode2), FL_(wwMode), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwmode));
register_device_value(
TAG_DEVICE_DATA_WW, &wwCircMode_, DeviceValueType::ENUM, FL_(enum_wwCircMode2), FL_(wwCircMode), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwcircmode));
TAG_DEVICE_DATA_WW, &wwCircMode_, DeviceValueType::ENUM, FL_(enum_wwMode2), FL_(wwCircMode), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwcircmode));
register_device_value(
TAG_DEVICE_DATA_WW, &wwProgMode_, DeviceValueType::ENUM, FL_(enum_wwProgMode), FL_(wwProgMode), DeviceValueUOM::NONE, MAKE_CF_CB(set_wwProgMode));
register_device_value(
Expand All @@ -2539,7 +2563,7 @@ void Thermostat::register_device_values() {
DeviceValueType::UINT,
nullptr,
FL_(wwDisinfectHour),
DeviceValueUOM::NONE,
DeviceValueUOM::OCLOCK,
MAKE_CF_CB(set_wwDisinfectHour),
0,
23);
Expand Down
3 changes: 2 additions & 1 deletion src/emsdevice.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,8 @@ static const __FlashStringHelper * DeviceValueUOM_s[] __attribute__((__aligned__
F_(kb),
F_(seconds),
F_(dbm),
F_(mv)
F_(mv),
F_(oclock)

};

Expand Down
3 changes: 2 additions & 1 deletion src/emsdevice.h
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,8 @@ enum DeviceValueUOM : uint8_t {
KB, // 12
SECONDS, // 13
DBM, // 14
MV // 15
MV, // 15
OCLOCK // 16

};

Expand Down
2 changes: 1 addition & 1 deletion src/locale_EN.h
Original file line number Diff line number Diff line change
Expand Up @@ -184,6 +184,7 @@ MAKE_PSTR(kb, "KB")
MAKE_PSTR(seconds, "seconds")
MAKE_PSTR(dbm, "dBm")
MAKE_PSTR(mv, "mV")
MAKE_PSTR(oclock, "o'clock")

// TAG mapping - maps to DeviceValueTAG_s in emsdevice.cpp
// use empty string if want to suppress showing tags
Expand Down Expand Up @@ -327,7 +328,6 @@ MAKE_PSTR_LIST(enum_ibaBuildingType, F_(light), F_(medium), F_(heavy))
MAKE_PSTR_LIST(enum_wwMode, F_(off), F_(low), F_(high), F_(auto), F_(own_prog))
MAKE_PSTR_LIST(enum_wwCircMode, F_(off), F_(on), F_(auto), F_(own_prog))
MAKE_PSTR_LIST(enum_wwMode2, F_(off), F_(on), F_(auto))
MAKE_PSTR_LIST(enum_wwCircMode2, F_(off), F_(on), F_(auto))
MAKE_PSTR_LIST(enum_heatingtype, F_(off), F_(radiator), F_(convector), F_(floor))
MAKE_PSTR_LIST(enum_summermode, F_(summer), F_(auto), F_(winter))

Expand Down

0 comments on commit eea32ad

Please sign in to comment.