userpage.js 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. //===== Java script for user pages
  2. var loadCounter = 0;
  3. var refreshRate = 0;
  4. var refreshTimer;
  5. var hiddenInputs = [];
  6. function notifyResponse( data )
  7. {
  8. Object.keys(data).forEach(function(v) {
  9. var elems = document.getElementsByName(v);
  10. var ndx;
  11. for(ndx = 0; ndx < elems.length; ndx++ )
  12. {
  13. var el = elems[ndx];
  14. if(el.tagName == "INPUT")
  15. {
  16. if( el.type == "radio" )
  17. {
  18. el.checked = data[v] == el.value;
  19. }
  20. else if( el.type == "checkbox" )
  21. {
  22. if( data[v] == "on" )
  23. el.checked = true;
  24. else if( data[v] == "off" )
  25. el.checked = false;
  26. else if( data[v] == true )
  27. el.checked = true;
  28. else
  29. el.checked = false;
  30. }
  31. else
  32. {
  33. el.value = data[v];
  34. }
  35. }
  36. if(el.tagName == "SELECT")
  37. {
  38. el.value = data[v];
  39. }
  40. }
  41. var elem = document.getElementById(v);
  42. if( elem != null )
  43. {
  44. if(elem.tagName == "P" || elem.tagName == "DIV" || elem.tagName == "SPAN" || elem.tagName == "TR" || elem.tagName == "TH" || elem.tagName == "TD" ||
  45. elem.tagName == "TEXTAREA" )
  46. {
  47. elem.innerHTML = data[v];
  48. }
  49. if(elem.tagName == "UL" || elem.tagName == "OL")
  50. {
  51. var list = data[v];
  52. var html = "";
  53. for (var i=0; i<list.length; i++) {
  54. html = html.concat("<li>" + list[i] + "</li>");
  55. }
  56. elem.innerHTML = html;
  57. }
  58. if(elem.tagName == "TABLE")
  59. {
  60. var list = data[v];
  61. var html = "";
  62. if( list.length > 0 )
  63. {
  64. var ths = list[0];
  65. html = html.concat("<tr>");
  66. for (var i=0; i<ths.length; i++) {
  67. html = html.concat("<th>" + ths[i] + "</th>");
  68. }
  69. html = html.concat("</tr>");
  70. }
  71. for (var i=1; i<list.length; i++) {
  72. var tds = list[i];
  73. html = html.concat("<tr>");
  74. for (var j=0; j<tds.length; j++) {
  75. html = html.concat("<td>" + tds[j] + "</td>");
  76. }
  77. html = html.concat("</tr>");
  78. }
  79. elem.innerHTML = html;
  80. }
  81. }
  82. });
  83. if( refreshRate != 0 )
  84. {
  85. clearTimeout(refreshTimer);
  86. refreshTimer = setTimeout( function () {
  87. ajaxJson("GET", window.location.pathname + ".json?reason=refresh", notifyResponse );
  88. }, refreshRate );
  89. }
  90. }
  91. function notifyButtonPressed( btnId )
  92. {
  93. ajaxJson("POST", window.location.pathname + ".json?reason=button\&id=" + btnId, notifyResponse);
  94. }
  95. function refreshFormData()
  96. {
  97. setTimeout( function () {
  98. ajaxJson("GET", window.location.pathname + ".json?reason=refresh", function (resp) {
  99. notifyResponse(resp);
  100. if( loadCounter > 0 )
  101. {
  102. loadCounter--;
  103. refreshFormData();
  104. }
  105. } );
  106. } , 250);
  107. }
  108. function recalculateHiddenInputs()
  109. {
  110. for(var i=0; i < hiddenInputs.length; i++)
  111. {
  112. var hinput = hiddenInputs[i];
  113. var name = hinput.name;
  114. var elems = document.getElementsByName(name);
  115. for(var j=0; j < elems.length; j++ )
  116. {
  117. var chk = elems[j];
  118. var inptp = chk.type;
  119. if( inptp == "checkbox" ) {
  120. if( chk.checked )
  121. {
  122. hinput.disabled = true;
  123. hinput.value = "on";
  124. }
  125. else
  126. {
  127. hinput.disabled = false;
  128. hinput.value = "off";
  129. }
  130. }
  131. }
  132. }
  133. }
  134. document.addEventListener("DOMContentLoaded", function(){
  135. // collect buttons
  136. var btns = document.getElementsByTagName("button");
  137. var ndx;
  138. for (ndx = 0; ndx < btns.length; ndx++) {
  139. var btn = btns[ndx];
  140. var id = btn.getAttribute("id");
  141. var onclk = btn.getAttribute("onclick");
  142. var type = btn.getAttribute("type");
  143. if( id != null && onclk == null && type == "button" )
  144. {
  145. var fn;
  146. eval( "fn = function() { notifyButtonPressed(\"" + id + "\") }" );
  147. btn.onclick = fn;
  148. }
  149. }
  150. // collect forms
  151. var frms = document.getElementsByTagName("form");
  152. for (ndx = 0; ndx < frms.length; ndx++) {
  153. var frm = frms[ndx];
  154. var method = frm.method;
  155. var action = frm.action;
  156. frm.method = "POST";
  157. frm.action = window.location.pathname + ".json?reason=submit";
  158. loadCounter = 4;
  159. frm.onsubmit = function () {
  160. recalculateHiddenInputs();
  161. refreshFormData();
  162. return true;
  163. };
  164. }
  165. // collect metas
  166. var metas = document.getElementsByTagName("meta");
  167. for (ndx = 0; ndx < metas.length; ndx++) {
  168. var meta = metas[ndx];
  169. if( meta.getAttribute("name") == "refresh-rate" )
  170. {
  171. refreshRate = meta.getAttribute("content");
  172. }
  173. }
  174. // collect checkboxes
  175. var inputs = document.getElementsByTagName("input");
  176. for (ndx = 0; ndx < inputs.length; ndx++) {
  177. var inp = inputs[ndx];
  178. if( inp.getAttribute("type") == "checkbox" )
  179. {
  180. var name = inp.getAttribute("name");
  181. var hasHidden = false;
  182. if( name != null )
  183. {
  184. var inpelems = document.getElementsByName(name);
  185. for(var i=0; i < inpelems.length; i++ )
  186. {
  187. var inptp = inpelems[i].type;
  188. if( inptp == "hidden" )
  189. hasHidden = true;
  190. }
  191. }
  192. if( !hasHidden )
  193. {
  194. var parent = inp.parentElement;
  195. var input = document.createElement("input");
  196. input.type = "hidden";
  197. input.name = inp.name;
  198. parent.appendChild(input);
  199. hiddenInputs.push(input);
  200. }
  201. }
  202. }
  203. // load variables at first time
  204. var loadVariables = function() {
  205. ajaxJson("GET", window.location.pathname + ".json?reason=load", notifyResponse,
  206. function () { setTimeout(loadVariables, 1000); }
  207. );
  208. };
  209. loadVariables();
  210. });