html_confLog.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /* clang-format off */
  2. static const char html_conflog_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 selectElement(el, val) {
  8. el.value = val;
  9. }
  10. function setCbx(el, da) {
  11. if(da == '1') {
  12. el.checked = true;
  13. el.style.visibility = 'visible';
  14. }
  15. else {
  16. el.checked = false;
  17. el.style.visibility = 'visible';
  18. }
  19. }
  20. function updCbxVal(el) {
  21. if (el.checked) el.value = '1';
  22. else {
  23. el.checked = true;
  24. el.value = '0';
  25. el.style.visibility = 'hidden';
  26. }
  27. }
  28. function transmit(f) {
  29. if (!xhttp) {
  30. reqTime = 0;
  31. reqFin = false;
  32. updCbxVal(g('logWebRequests'));
  33. xhttp = new XMLHttpRequest();
  34. xhttp.timeout = 1000;
  35. xhttp.overrideMimeType('application/json');
  36. xhttp.open('POST', 'confDataLog');
  37. xhttp.send(f ? (new FormData(f)) : '');
  38. xhttp.onreadystatechange = function () {
  39. if (xhttp.readyState === XMLHttpRequest.DONE && xhttp.status === 200) {
  40. var data = JSON.parse(xhttp.responseText);
  41. selectElement(g('logLevSer'), data.logLevSer);
  42. selectElement(g('logLevWeb'), data.logLevWeb);
  43. selectElement(g('logLevMqtt'), data.logLevMqtt);
  44. setCbx(g('logWebRequests'), data.logWebRequests);
  45. xhttp = null;
  46. reqFin = true;
  47. }
  48. else {
  49. if(!reqFin && reqTime > 10) {
  50. xhttp = null;
  51. reqFin = true;
  52. }
  53. }
  54. }
  55. }
  56. return false;
  57. }
  58. function saveConf() {
  59. updCbxVal(g('logWebRequests'));
  60. g('frmConf').submit();
  61. }
  62. function init() {
  63. transmit();
  64. }
  65. setInterval(function () { ++reqTime; }, 1000);
  66. </script>
  67. )====="; // html_confweb_script
  68. static const char html_conflog_body[] PROGMEM = R"=====(
  69. <p><b>Configuration - Logging</b></p>
  70. <div class='config'>
  71. <form id='frmConf' action='setConfLog' method='POST'>
  72. <fieldset>
  73. <legend>Log Levels</legend>
  74. <p><b>Serial</b><br>
  75. <select name='logLevSer' id='logLevSer'>
  76. <option value="0">Off</option>
  77. <option value="1">Error</option>
  78. <option value="2">Warn</option>
  79. <option value="3">Info</option>
  80. <option value="4">Debug</option>
  81. <option value="5">Verbose</option>
  82. </select></p>
  83. <p><b>Web-Console</b><br>
  84. <select name='logLevWeb' id='logLevWeb'>
  85. <option value="0">Off</option>
  86. <option value="1">Error</option>
  87. <option value="2">Warn</option>
  88. <option value="3">Info</option>
  89. <option value="4">Debug</option>
  90. <option value="5">Verbose</option>
  91. </select></p>
  92. <p><b>MQTT</b><br>
  93. <select name='logLevMqtt' id='logLevMqtt'>
  94. <option value="0">Off</option>
  95. <option value="1">Error</option>
  96. <option value="2">Warn</option>
  97. <option value="3">Info</option>
  98. <option value="4">Debug</option>
  99. <option value="5">Verbose</option>
  100. </select></p>
  101. <br>
  102. <p><b>Log Web Requests</b>&nbsp;<input type='checkbox' name='logWebRequests' id='logWebRequests'></p>
  103. </fieldset>
  104. </form>
  105. <div></div>
  106. <table style='width:100%'>
  107. <td style='width:50%'><button onclick='location="conf";' class='bgrey'>Cancel</button></td>
  108. <td style='width:50%'><button onclick='return saveConf()' class='bred'>Save</button></td>
  109. </tr></table>
  110. <div></div>
  111. </div>
  112. )====="; // html_confweb_body