html_confTherm.h 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /* clang-format off */
  2. //static const char html_confbas_script[] PROGMEM = R"=====(
  3. //<script>
  4. // function g(i) { return document.getElementById(i) };
  5. // function sp(i){g(i).type=(g(i).type==='text'?'password':'text');}
  6. // var xhttp, reqTime, reqFin;
  7. // function setCbx(el, da) {
  8. // if(da == '1') {
  9. // el.checked = true;
  10. // el.style.visibility = 'visible';
  11. // }
  12. // else {
  13. // el.checked = false;
  14. // el.style.visibility = 'visible';
  15. // }
  16. // }
  17. // function updCbxVal(el) {
  18. // if (el.checked) el.value = '1';
  19. // else {
  20. // el.checked = true;
  21. // el.value = '0';
  22. // el.style.visibility = 'hidden';
  23. // }
  24. // }
  25. static const char html_confTherm_script[] PROGMEM = R"=====(
  26. function transmit(f) {
  27. if (!xhttp) {
  28. reqTime = 0;
  29. reqFin = false;
  30. updCbxVal(g('autoSaveTemp'));
  31. updCbxVal(g('autoSaveMode'));
  32. updCbxVal(g('saveToMqttRet'));
  33. updCbxVal(g('PIRenDispPs0'));
  34. updCbxVal(g('togTHdisp'));
  35. xhttp = new XMLHttpRequest();
  36. xhttp.timeout = 1000;
  37. xhttp.overrideMimeType('application/json');
  38. xhttp.open('POST', 'confDataTherm');
  39. xhttp.send(f ? (new FormData(f)) : '');
  40. xhttp.onreadystatechange = function () {
  41. if (xhttp.readyState === XMLHttpRequest.DONE && xhttp.status === 200) {
  42. var data = JSON.parse(xhttp.responseText);
  43. g('tempMin').value = data.tempMin;
  44. g('tempMax').value = data.tempMax;
  45. setCbx(g('autoSaveTemp'), data.autoSaveTemp);
  46. setCbx(g('autoSaveMode'), data.autoSaveMode);
  47. setCbx(g('saveToMqttRet'), data.saveToMqttRet);
  48. setCbx(g('PIRenDispPs0'), data.PIRenDispPs0);
  49. setCbx(g('togTHdisp'), data.togTHdisp);
  50. g('tempDec').value = data.tempDec;
  51. g('hyst').value = data.hyst;
  52. g('minOffTime').value = data.minOffTime;
  53. g('offMsg').value = data.offMsg;
  54. g('iTempLab').value = data.iTempLab;
  55. g('oTempLab').value = data.oTempLab;
  56. g('modeName1').value = data.modeName1;
  57. g('modeName0').value = data.modeName0;
  58. g('psetName0').value = data.psetName0;
  59. g('psetName1').value = data.psetName1;
  60. g('psetName2').value = data.psetName2;
  61. g('pauseTout').value = data.pauseTout;
  62. xhttp = null;
  63. reqFin = true;
  64. }
  65. else {
  66. if(!reqFin && reqTime > 10) {
  67. xhttp = null;
  68. reqFin = true;
  69. }
  70. }
  71. }
  72. }
  73. return false;
  74. }
  75. //transmit();
  76. function saveConf() {
  77. updCbxVal(g('autoSaveTemp'));
  78. updCbxVal(g('autoSaveMode'));
  79. updCbxVal(g('saveToMqttRet'));
  80. updCbxVal(g('PIRenDispPs0'));
  81. updCbxVal(g('togTHdisp'));
  82. g('frmConf').submit();
  83. }
  84. function init() {
  85. transmit();
  86. }
  87. )====="; // html_confTherm_script
  88. // setInterval(function () { ++reqTime; }, 1000);
  89. //</script>
  90. //)====="; // html_confTherm_script
  91. static const char html_confTherm_body[] PROGMEM = R"=====(
  92. <b>Configuration - Thermostat</b>
  93. <div class='config'>
  94. <form id='frmConf' action='setConfTherm' method='POST'>
  95. <br>
  96. <fieldset>
  97. <legend>Thermostat</legend>
  98. <p><b>Minimum Set Temperature [°C]</b><br><input type='text' name='tempMin' id='tempMin'></p>
  99. <p><b>Maximum Set Temperature [°C]</b><br><input type='text' name='tempMax' id='tempMax'></p>
  100. </fieldset>
  101. <div></div><br>
  102. <fieldset>
  103. <legend>Auto Save</legend>
  104. <p><b>Temperature *</b>&nbsp;<input type='checkbox' name='autoSaveTemp' id='autoSaveTemp'/></p>
  105. <p><b>Mode/Preset *</b>&nbsp;<input type='checkbox' name='autoSaveMode' id='autoSaveMode'/></p>
  106. <p class='n'>To minimize flash writes, this can also be <br>
  107. achieved by using MQTT with retain flag, when using <br>
  108. an external controller, especially for Mode/Preset, <br>
  109. as these will change frequently in most cases. <br>
  110. WiFiThermostat will receive the last value from retained MQTT <br>
  111. message automatically on startup/reconnect.</p>
  112. <p><b>Preserve States MQTT retained</b>&nbsp;<input type='checkbox' name='saveToMqttRet' id='saveToMqttRet'/></p>
  113. </fieldset>
  114. <div></div><br>
  115. <fieldset>
  116. <legend>Thermostat - Advanced</legend>
  117. <p><b>Hysteresis [°C]</b><br><input type='text' name='hyst' id='hyst'></p><br>
  118. <p><b>Min. Heating Off-Time [s]</b><br><input type='number' name='minOffTime' id='minOffTime'></p>
  119. <p class='n'>Heating stays off for at least [x] seconds before it <br>can start again.</p><br>
  120. <p><b>Set Temp. Decrease Value **</b><br><input type='text' name='tempDec' id='tempDec'></p>
  121. <p class='n'>** the actual set temperatur is decreased by that value.<br>Can be a fraction. Can be used to prevent over-heating <br>when the thermostat is badly placed.<br></p><br>
  122. <p><b>Heating Pause Timeout [s]</b><br><input type='text' name='pauseTout' id='pauseTout'></p>
  123. <p class='n'>Heating Pause can be enabled via MQTT /cmd/setPause=1. <br>
  124. Set Timeout in seconds here.</p><br>
  125. </fieldset>
  126. <div></div><br>
  127. <fieldset>
  128. <legend>Names and Labels</legend>
  129. <p class='n'>Used in some MQTT status/commands, <br>and also for the LCD and Web interface.<br></p><br>
  130. <p><b>Off-Message</b><br><input type='text' name='offMsg' id='offMsg'></p>
  131. <p class='n'>Shown on LCD in OFF mode. <br><b>max. 13 chars!</b></p>
  132. <br>
  133. <p>Labels</p>
  134. <p class='n'>Used on LCD to identify the data displayed. <br><b>MUST be 1 char</b> or empty for default</p>
  135. <p><b>Inside</b><br><input type='text' name='iTempLab' id='iTempLab'/></p>
  136. <p><b>Outside</b><br><input type='text' name='oTempLab' id='oTempLab'/></p>
  137. <br>
  138. <p>Mode</p>
  139. <p class='n'>Used in web interface and for Home Assistant <br>MQTT Climate component support. <br>Should be 'heat' and 'off' normally. <br><b>Case sensitive! Lower case recommended.</b><br>Web interface shows all in capitals.</p>
  140. <p><b>On</b><br><input type='text' name='modeName1' id='modeName1'></p>
  141. <p><b>Off</b><br><input type='text' name='modeName0' id='modeName0'></p>
  142. <br>
  143. <p>Preset Names</p>
  144. <p class='n'>Used in web interface and for Home Assistant <br>MQTT Climate component support.<br>
  145. Also shown on LCD at preset change, <br>therefore may not exceed <b>13 chars!</b><br><b>Case sensitive!</b> Type exactly as in HA!</p>
  146. <p><b>Normal *</b><br><input type='text' name='psetName0' id='psetName0'></p>
  147. <p class='n'>* always sends/receives "<i>none</i>" as this is hardcoded in <br>Home Assistant MQTT Climate component</p>
  148. <p><b>Reduction 1 **</b><br><input type='text' name='psetName1' id='psetName1'></p>
  149. <p><b>Reduction 2 **</b><br><input type='text' name='psetName2' id='psetName2'></p>
  150. <p class='n'>** sent/received as defined</p>
  151. </fieldset>
  152. <div></div><br>
  153. <fieldset>
  154. <legend>Display</legend>
  155. <p><b>PIR enables LCD backlight <br>only in normal heating mode</b>&nbsp;<input type='checkbox' name='PIRenDispPs0' id='PIRenDispPs0'/></p>
  156. <br>
  157. <p><b>Toggling I/O-Temp/Hum on LCD</b>&nbsp;<input type='checkbox' name='togTHdisp' id='togTHdisp'/></p>
  158. </fieldset>
  159. <br>
  160. </form>
  161. <div></div>
  162. <table style='width:100%'>
  163. <td style='width:50%'><button onclick='location="conf";' class='bgrey'>Cancel</button></td>
  164. <td style='width:50%'><button onclick='return saveConf()' class='bred'>Save</button></td>
  165. </tr></table>
  166. </div>
  167. )====="; // html_confTherm_body