graph.html 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. <html>
  2. <head>
  3. <script type="text/javascript" src='plotly-2.14.0.min.js?v=$COMMIT_HASH'></script>
  4. <script type="text/javascript" src="common.js?v=$COMMIT_HASH"></script>
  5. <script type="text/javascript" src="readconfigcommon.js?v=$COMMIT_HASH"></script>
  6. <script type="text/javascript" src="readconfigparam.js?v=$COMMIT_HASH"></script>
  7. <style>
  8. body {
  9. font-family: Arial, Helvetica, sans-serif;
  10. }
  11. </style>
  12. <script>
  13. function run() {
  14. datefile = document.getElementById("datafiles").value;
  15. numbername = document.getElementById("numbers").value;
  16. showRrelativeValues = document.getElementById("showRrelativeValues").checked;
  17. //alert("Auslesen: " + datefile + " " + numbername);
  18. _domainname = getDomainname();
  19. fetch(_domainname + '/fileserver/log/data/' + datefile)
  20. .then(response => {
  21. // handle the response
  22. if (response.status == 404) {
  23. firework.launch("No log data available for " + dateString, 'warning', 10000);
  24. }
  25. response.text()
  26. .then( result => {
  27. var lines = result.split("\n");
  28. var traceValue = { x: [], y: [], type: 'scatter', line: {width: 6}, name: 'Value'};
  29. var tracePreValue = { x: [], y: [], type: 'scatter', line: {width: 2}, name: 'Previous Value', visible: 'legendonly'};
  30. var traceChangeRate = { x: [], y: [], type: 'bar', yaxis: 'y2', opacity: 0.2, name: 'Change Rate'};
  31. var traceChangeAbsolute = { x: [], y: [], type: 'bar', yaxis: 'y2', opacity: 0.2, name: 'Change Absolute', visible: 'legendonly'};
  32. var timex = 1;
  33. for (let line of lines) {
  34. {
  35. //console.log(line);
  36. if (line.split(",")[1] == numbername)
  37. {
  38. var value = line.split(",")[3];
  39. var preValue = line.split(",")[4];
  40. var changeRate = line.split(",")[5];
  41. var changeAbsolute = line.split(",")[6];
  42. var time = line.split(",")[0];
  43. //console.log("> "+time+" "+value+"\n");
  44. traceValue.x.push(time);
  45. traceValue.y.push(value);
  46. tracePreValue.y.push(preValue);
  47. traceChangeRate.y.push(changeRate);
  48. traceChangeAbsolute.y.push(changeAbsolute);
  49. }
  50. }
  51. }
  52. //console.log(trace);
  53. // Copy time to all traces
  54. tracePreValue.x = traceValue.x;
  55. traceChangeRate.x = traceValue.x;
  56. traceChangeAbsolute.x = traceValue.x;
  57. //console.log(traceValue.y);
  58. var offsetValue = traceValue.y[0];
  59. var offsetPreValue = tracePreValue.y[0];
  60. if (showRrelativeValues) {
  61. traceValue.y.forEach(function(part, index, arr) {
  62. arr[index] = arr[index] - offsetValue;
  63. });
  64. tracePreValue.y.forEach(function(part, index, arr) {
  65. arr[index] = arr[index] - offsetPreValue;
  66. });
  67. }
  68. // console.log(traceValue.x)
  69. var data = [traceValue, tracePreValue, traceChangeRate, traceChangeAbsolute];
  70. var layout = {
  71. showlegend: true,
  72. colorway: ['green', 'black', 'blue', 'black'],
  73. yaxis: {title: 'Value'},
  74. yaxis2: {
  75. title: 'Change',
  76. overlaying: 'y',
  77. side: 'right'
  78. },
  79. margin: {
  80. l: 50,
  81. r: 50,
  82. b: 50,
  83. t: 50,
  84. pad: 4
  85. },
  86. legend: {
  87. x: 0.2,
  88. y: 0.9,
  89. xanchor: 'right'
  90. }
  91. };
  92. document.getElementById("chart").innerHTML = "";
  93. Plotly.newPlot('chart', data, layout, {displayModeBar: true});
  94. });
  95. }).catch((error) => {
  96. // handle the error
  97. console.log(error);
  98. });
  99. }
  100. </script>
  101. <link href="firework.css?v=$COMMIT_HASH" rel="stylesheet">
  102. <script type="text/javascript" src="jquery-3.6.0.min.js?v=$COMMIT_HASH"></script>
  103. <script type="text/javascript" src="firework.js?v=$COMMIT_HASH"></script>
  104. </head>
  105. <body>
  106. <h3>Data Graph</h3>
  107. <div id='chart'><p>Loading...<br></p></div>
  108. <select id="datafiles" onchange="run();"></select>
  109. <select id="numbers" onchange="run();"></select>
  110. <input type="checkbox" id="showRrelativeValues" onclick = 'run();' unchecked ><label for="showRrelativeValues">Show relative values</label>
  111. <button onclick="run();">Refresh</button>
  112. &nbsp;&nbsp;|&nbsp;&nbsp;
  113. <button onClick="window.location.href = 'data.html?v=$COMMIT_HASH'">Show data</button>
  114. <button onClick="window.location.href = getDomainname() + '/fileserver/log/data/'">Show data files</button>
  115. </div>
  116. <script>
  117. function WriteModelFiles()
  118. {
  119. list_data = getDATAList();
  120. var _indexDig = document.getElementById("datafiles");
  121. while (_indexDig.length)
  122. _indexDig.remove(0);
  123. for (var i = list_data.length - 1; i >= 0; --i)
  124. {
  125. var optionDig = document.createElement("option");
  126. var text = list_data[i];
  127. optionDig.text = text;
  128. optionDig.value = list_data[i];
  129. _indexDig.add(optionDig);
  130. }
  131. }
  132. function WriteNumbers()
  133. {
  134. list_data = getNUMBERSList();
  135. var _indexDig = document.getElementById("numbers");
  136. while (_indexDig.length)
  137. _indexDig.remove(0);
  138. for (var i = 0; i < list_data.length; ++i)
  139. {
  140. var optionDig = document.createElement("option");
  141. var text = list_data[i];
  142. optionDig.text = text;
  143. optionDig.value = list_data[i];
  144. _indexDig.add(optionDig);
  145. }
  146. }
  147. WriteModelFiles();
  148. WriteNumbers();
  149. run();
  150. </script>
  151. </body>
  152. </html>