html_confbas.ino 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. static const char html_confbas_script[] PROGMEM = R"=====(
  2. <script>
  3. function g(i) { return document.getElementById(i) };
  4. function sp(i){g(i).type=(g(i).type==='text'?'password':'text');}
  5. var xhttp, reqTime, reqFin;
  6. function setCbx(el, da) {
  7. if(da == '1') {
  8. el.checked = true;
  9. el.style.visibility = 'visible';
  10. }
  11. else {
  12. el.checked = false;
  13. el.style.visibility = 'visible';
  14. }
  15. }
  16. function updCbxVal(el) {
  17. if (el.checked) el.value = '1';
  18. else {
  19. el.checked = true;
  20. el.value = '0';
  21. el.style.visibility = 'hidden';
  22. }
  23. }
  24. function transmit(f) {
  25. if (!xhttp) {
  26. reqTime = 0;
  27. reqFin = false;
  28. updCbxVal(g('autoSaveTemp'));
  29. updCbxVal(g('autoSaveMode'));
  30. updCbxVal(g('PIRenDisp'));
  31. updCbxVal(g('togTHdisp'));
  32. xhttp = new XMLHttpRequest();
  33. xhttp.timeout = 1000;
  34. xhttp.overrideMimeType('application/json');
  35. xhttp.open('POST', 'confdbas');
  36. xhttp.send(f ? (new FormData(f)) : '');
  37. xhttp.onreadystatechange = function () {
  38. if (xhttp.readyState === XMLHttpRequest.DONE && xhttp.status === 200) {
  39. var data = JSON.parse(xhttp.responseText);
  40. g('tempMin').value = data.tempMin;
  41. g('tempMax').value = data.tempMax;
  42. g('measInt').value = data.measInt;
  43. g('dispInt').value = data.dispInt;
  44. g('dispTout').value = data.dispTout;
  45. setCbx(g('autoSaveTemp'), data.autoSaveTemp);
  46. setCbx(g('autoSaveMode'), data.autoSaveMode);
  47. setCbx(g('PIRenDisp'), data.PIRenDisp);
  48. setCbx(g('togTHdisp'), data.togTHdisp);
  49. xhttp = null;
  50. reqFin = true;
  51. }
  52. else {
  53. if(!reqFin && reqTime > 10) {
  54. xhttp = null;
  55. reqFin = true;
  56. }
  57. }
  58. }
  59. }
  60. return false;
  61. }
  62. //transmit();
  63. function saveConf() {
  64. updCbxVal(g('autoSaveTemp'));
  65. updCbxVal(g('autoSaveMode'));
  66. updCbxVal(g('PIRenDisp'));
  67. updCbxVal(g('togTHdisp'));
  68. g('frmConf').submit();
  69. }
  70. function init() {
  71. transmit();
  72. }
  73. setInterval(function () { ++reqTime; }, 1000);
  74. </script>
  75. )====="; // html_confbas_script
  76. static const char html_confbas_body[] PROGMEM = R"=====(
  77. <b>Configuration - Thermostat Basic</b>
  78. <div class='config'>
  79. <form id='frmConf' action='setConfBas' method='POST'>
  80. <br>
  81. <fieldset>
  82. <legend>Thermostat</legend>
  83. <p><b>Minimum Set Temperature [°C]</b><br><input type='text' name='tempMin' id='tempMin'></p>
  84. <p><b>Maximum Set Temperature [°C]</b><br><input type='text' name='tempMax' id='tempMax'></p>
  85. </fieldset>
  86. <div></div><br>
  87. <fieldset>
  88. <legend>Auto Save</legend>
  89. <p><b>Temperature *</b>&nbsp;<input type='checkbox' name='autoSaveTemp' id='autoSaveTemp'/></p>
  90. <p><b>Mode/Preset *</b>&nbsp;<input type='checkbox' name='autoSaveMode' id='autoSaveMode'/></p>
  91. </fieldset>
  92. <div></div><br>
  93. <fieldset>
  94. <legend>Intervals / Timeouts</legend>
  95. <p><b>Measurement Interval [s]</b><br><input type='number' name='measInt' id='measInt'></p>
  96. <p><b>Display Update Interval [s]</b><br><input type='number' name='dispInt' id='dispInt'></p>
  97. <p><b>Display Timeout [s]</b><br><input type='number' name='dispTout' id='dispTout'></p>
  98. </fieldset>
  99. <div></div><br>
  100. <fieldset>
  101. <legend>Misc</legend>
  102. <p><b>PIR enables LCD backlight</b>&nbsp;<input type='checkbox' name='PIRenDisp' id='PIRenDisp'/></p>
  103. <p><b>Toggling I/O-Temp/Hum on LCD</b>&nbsp;<input type='checkbox' name='togTHdisp' id='togTHdisp'/></p>
  104. </fieldset>
  105. <br>
  106. </form>
  107. <div></div>
  108. <table style='width:100%'>
  109. <td style='width:50%'><button onclick='location="conf";' class='bgrey'>Cancel</button></td>
  110. <td style='width:50%'><button onclick='return saveConf()' class='bred'>Save</button></td>
  111. </tr></table>
  112. </div>
  113. )====="; // html_confbas_body