html_main_thermostat.h 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /* clang-format off */
  2. #ifdef FIRMWARE_VARIANT_THERMOSTAT
  3. static const char html_main_script[] PROGMEM = R"=====(
  4. <script>
  5. function g(i) { return document.getElementById(i) };
  6. var xhttp, updateTime, reqTime, reqFin;
  7. function sendBtn(btn, conf) {
  8. var frmn='BtnFrm'+btn;
  9. var form = g(frmn);
  10. if(conf !== undefined) {
  11. if(confirm(conf)) return transmit(form);
  12. else return false;
  13. }
  14. else return transmit(form);
  15. }
  16. function transmit(f) {
  17. if (!xhttp) {
  18. reqTime = 0;
  19. reqFin = false;
  20. xhttp = new XMLHttpRequest();
  21. xhttp.timeout = 1000;
  22. xhttp.overrideMimeType("application/json");
  23. xhttp.open('POST', 'api');
  24. xhttp.send(f ? (new FormData(f)) : '');
  25. xhttp.onreadystatechange = function () {
  26. if (xhttp.readyState === XMLHttpRequest.DONE && xhttp.status === 200) {
  27. var data = JSON.parse(xhttp.responseText);
  28. if(data.setTemp !== undefined) g('setTemp').innerHTML = data.setTemp.toFixed(1) + '&deg;';
  29. if(data.currSetTemp !== undefined) g('currSetTemp').innerHTML = data.currSetTemp.toFixed(1) + '&deg;';
  30. if(data.actSetTemp !== undefined) g('actSetTemp').innerHTML = data.actSetTemp.toFixed(1) + '&deg;';
  31. if(data.psetName !== undefined) g('pset').innerHTML = data.psetName.toUpperCase();
  32. if(data.psetName0 !== undefined) g('btnPs0').innerHTML = data.psetName0;
  33. if(data.psetName1 !== undefined) g('btnPs1').innerHTML = data.psetName1;
  34. if(data.psetName2 !== undefined) g('btnPs2').innerHTML = data.psetName2;
  35. if(data.temp !== undefined && data.hum !== undefined) g('currTempHum').innerHTML = data.temp.toFixed(1) + '&deg;&nbsp;&nbsp;&nbsp;' + data.hum.toFixed(0) + '%';
  36. else if(data.temp !== undefined) g('currTempHum').innerHTML = data.temp.toFixed(1) + '&deg;';
  37. if(data.outTemp !== undefined && data.outHum !== undefined) g('outTempHum').innerHTML = data.outTemp.toFixed(1) + '&deg;&nbsp;&nbsp;&nbsp;' + data.outHum.toFixed(0) + '%';
  38. else if(data.outTemp !== undefined) g('outTempHum').innerHTML = data.outTemp.toFixed(1) + '&deg;';
  39. if(data.modeName !== undefined) g('mode').innerHTML = data.modeName.toUpperCase();
  40. if(data.mode == '1') { g('btnModeOn').setAttribute('class', ''); g('btnModeOff').setAttribute('class', 'bgrey');}
  41. else { g('btnModeOn').setAttribute('class', 'bgrey'); g('btnModeOff').setAttribute('class', '');}
  42. if(data.pset == '0') { g('btnPs0').setAttribute('class', ''); g('btnPs1').setAttribute('class', 'bgrey'); g('btnPs2').setAttribute('class', 'bgrey');}
  43. else if(data.pset == '1') {g('btnPs0').setAttribute('class', 'bgrey'); g('btnPs1').setAttribute('class', ''); g('btnPs2').setAttribute('class', 'bgrey');}
  44. else if(data.pset == '2') {g('btnPs0').setAttribute('class', 'bgrey'); g('btnPs1').setAttribute('class', 'bgrey'); g('btnPs2').setAttribute('class', ''); }
  45. if(parseInt(data.heatingPause) >= 1 && data.mode == '1') { g('heating').innerHTML = 'PAUSED'; g('heating').style = 'color:red;'; }
  46. else if(data.heating == '1' && data.mode == '1') { g('heating').innerHTML = 'ACTIVE'; g('heating').style = 'color:orange;'; }
  47. else if(data.heating == '2' && data.mode == '1') { g('heating').innerHTML = 'LOCKED'; g('heating').style = 'color:red;'; }
  48. else if(data.heating == '0' && data.mode == '1') { g('heating').innerHTML = 'IDLE'; g('heating').style = 'color:#1fa3ec;'; }
  49. else if(data.mode == '0') { g('heating').innerHTML = 'OFF'; g('heating').style = 'color:black;'; }
  50. if(data.heatingLockTime !== undefined) g('heatingLockTime').innerHTML = data.heatingLockTime + 's';
  51. if(data.heatingPause !== undefined) g('heatingPause').innerHTML = data.heatingPause + 's';
  52. var APname;
  53. if(data.WiFiNum == 1) APname='Default';
  54. else if(data.WiFiNum == 1) APname='Fallback';
  55. if(data.ssid !== undefined && data.WiFiNum !== undefined && data.WiFiNum > 0) g('ssid').innerHTML = data.ssid + ' (' + APname + '-AP)';
  56. else if(data.ssid !== undefined) g('ssid').innerHTML = data.ssid;
  57. if(data.mqttstate !== undefined) {
  58. if(data.mqttstate == "CONNECTED") { g('mqttstate').innerHTML = data.mqttstate + ' to <i>' + data.mqtthost + '</i>'; }
  59. else g('mqttstate').innerHTML = data.mqttstate;
  60. }
  61. if(data.uptime !== undefined) g('uptime').innerHTML = data.uptime;
  62. if(data.date !== undefined) g('date').innerHTML = data.date;
  63. else g('date').innerHTML = '-';
  64. if(data.time !== undefined) g('time').innerHTML = data.time;
  65. else g('time').innerHTML = '-';
  66. if(data.mqttreconn !== undefined) g('mqttreconn').innerHTML = data.mqttreconn;
  67. xhttp = null;
  68. updateTime = 0;
  69. reqFin = true;
  70. }
  71. else {
  72. if(!reqFin && reqTime > 10) {
  73. xhttp = null;
  74. reqFin = true;
  75. }
  76. }
  77. }
  78. }
  79. return false;
  80. }
  81. function init() {
  82. transmit();
  83. }
  84. setInterval(transmit, 2500);
  85. </script>
  86. )====="; // html_main_script
  87. static const char html_main_body_app[] PROGMEM = R"=====(
  88. <p><b>Temperature</b></p>
  89. <div id='setTemp' style='text-align:center;font-weight:bold;font-size:40px'></div>
  90. <div></div>
  91. <table style='width:100%'><tr>
  92. <td style='width:50%'><form id='BtnFrmMinus'><input type='hidden' name='BtnMinus' value='1'><button onclick='return sendBtn("Minus")'>-</button></form></td>
  93. <td style='width:50%'><form id='BtnFrmPlus'><input type='hidden' name='BtnPlus' value='1'><button onclick='return sendBtn("Plus")'>+</button></form></td>
  94. </tr></table>
  95. <table style='width:100%'>
  96. <tr><td style='width:50%'>Current Temp/Hum </td><td><b><span id='currTempHum'></span></td></tr>
  97. <tr><td>Outside Temp/Hum </td><td><b><span id='outTempHum'></span></td></tr>
  98. <tr><td>Current set Temp </td><td><b><span id='currSetTemp'></span></b></td></tr>
  99. <tr><td>Actual set Temp </td><td><b><span id='actSetTemp'></span></b></td></tr>
  100. <tr><td>Heating State </td><td><b><span id='heating'></span></b></td></tr>
  101. <tr><td>Heating Lock Time</td><td><b><span id='heatingLockTime'></span></b></td></tr>
  102. <tr><td>Heating Pause Time</td><td><b><span id='heatingPause'></span></b></td></tr>
  103. </table>
  104. <div></div>
  105. <div></div>
  106. <p><b>Preset</b></p>
  107. <div id='pset' style='text-align:center;font-weight:bold;font-size:20px'></div>
  108. <div></div>
  109. <form id='BtnFrmPset0'><input type='hidden' name='BtnPset0' value='1'><button id='btnPs0' onclick='return sendBtn("Pset0")'>NORMAL</button></form>
  110. <form id='BtnFrmPset1'><input type='hidden' name='BtnPset1' value='1'><button id='btnPs1' onclick='return sendBtn("Pset1")'>REDUCTION 1</button></form>
  111. <form id='BtnFrmPset2'><input type='hidden' name='BtnPset2' value='1'><button id='btnPs2' onclick='return sendBtn("Pset2")'>REDUCTION 2</button></form>
  112. <div></div>
  113. <div></div>
  114. <div></div>
  115. <form action='ThermRedTemps' method='GET'><button>Set Reduction Temps</button></form>
  116. <div></div>
  117. <p><b>Mode</b></p>
  118. <div id='mode' style='text-align:center;font-weight:bold;font-size:20px'></div>
  119. <div></div>
  120. <table style='width:100%'><tr>
  121. <td style='width:50%'><form id='BtnFrmOn'><input type='hidden' name='BtnOn' value='1'><button id='btnModeOn' onclick='return sendBtn("On")'>HEAT</button></form></td>
  122. <td style='width:50%'><form id='BtnFrmOff'><input type='hidden' name='BtnOff' value='1'><button id='btnModeOff' onclick='return sendBtn("Off")'>OFF</button></form></td>
  123. </tr></table>
  124. )====="; // html_main_body_app
  125. #endif