1- <!DOCTYPE HTML>
2- < html >
1+ < div id =sensorStatus >
2+ < p > Getting sensor information...</ p >
3+ </ div >
4+ < div class ="container ">
5+ < table id ="sensorDataTable " class ="info " style ="border:none; font-size: 20px; " >
6+ < tbody >
7+ < tr >
38
4- < head >
5- < meta name ="viewport " content ="width=device-width, initial-scale=1 ">
6- < link rel ="stylesheet " href ="https://use.fontawesome.com/releases/v5.7.2/css/all.css "
7- integrity ="sha384-fnmOCqbTlWIlj8LyTjo7mOUStjsKC4pOpQbqyi7RrhN7udi9RwhKkMHpvLbHG9Sr " crossorigin ="anonymous ">
8- < style >
9- html {
10- font-family : Arial;
11- display : inline-block;
12- margin : 0px auto;
13- text-align : center;
14- }
15-
16- h2 {
17- font-size : 3.0rem ;
18- }
19-
20- p {
21- font-size : 3.0rem ;
22- }
23-
24- .units {
25- font-size : 1.2rem ;
26- }
27-
28- .sensor-label {
29- font-size : 1.5rem ;
30- vertical-align : middle;
31- padding-bottom : 15px ;
32- }
33- </ style >
34- </ head >
35-
36- < body >
37- < h2 > Live connected sensor viewer</ h2 >
38- < div id =sensorElement >
39- < p > Getting sensor information...</ p >
40- </ div >
41- </ body >
42-
43- < footer >
44- < p style ="padding-top:15px;text-align:center ">
45- < a href ="/_ac "> < img
46- src =" " border ="0 " title ="AutoConnect menu " alt ="AutoConnect menu " />
47- </ a >
48- </ p >
49-
50- </ footer >
9+ </ tr >
10+ </ tbody >
11+ </ table >
12+ </ div >
5113
5214
5315< script >
54-
5516 loadData ( ) ; //Load the data for first time
5617 setInterval ( loadData , 1000 ) ; //Reload the data every X milliseconds.
57-
5818 //Load the JSON data from API, and then replace the HTML element
5919 function loadData ( ) {
6020 var xhttp = new XMLHttpRequest ( ) ;
6121 xhttp . onreadystatechange = function ( ) {
6222 if ( this . readyState == 4 && this . status == 200 ) {
63-
64- var sensorElement = document . getElementById ( "sensorElement" ) ;
65-
66- sensorElement . textContent = "" ; //Clear all elements in sensorElement div
67-
68-
69- var sensorsData = JSON . parse ( this . response ) . data ; //Parse the response to JSON object
70-
71-
72- if ( Object . keys ( sensorsData ) . length == 0 ) { //object is empty
73- sensorElement . innerHTML = "<p> No sensors connected. </p>"
23+ var sensorStatus = document . getElementById ( "sensorStatus" ) ;
24+ var sensorTable = document . getElementById ( "sensorDataTable" ) ;
25+
26+ var sensorsData = JSON . parse ( this . response ) . data ; //Parse the response to JSON object
27+ if ( Object . keys ( sensorsData ) . length == 0 ) { //object is empty
28+ sensorStatus . style . display = "block" ; //Display the status text div
29+ sensorTable . style . display = "none" //Hide the table
30+ sensorStatus . textContent = "" ; //Clear all elements in sensorElement div
31+ sensorStatus . innerHTML = "<p> No sensors connected. </p>"
7432 return ;
75- }
76-
77- for ( sensorName of Object . keys ( sensorsData ) ) { //iterate through each element and create paragraph for each sensor
78- sensorElement . innerHTML += "<p><span class=\"sensor-label\">" +
79- sensorName + "</span> <span id=\"sensor-value\">" +
80- sensorsData [ sensorName ] + " </span> <sup class=\"units\">" + ' ' + " </sup> </p>" ;
33+ } else {
34+ sensorStatus . style . display = "none" ; //Hide the status text div
35+ sensorTable . style . display = "block" //Show the table
36+ sensorTable . innerHTML = "" //Clear the table
37+
38+ for ( sensorName of Object . keys ( sensorsData ) ) { //iterate through each element and create table row for each sensor
39+ var row = sensorTable . insertRow ( 0 ) ;
40+ var cell1 = row . insertCell ( 0 ) ;
41+ var cell2 = row . insertCell ( 1 ) ;
42+ cell1 . style . fontWeight = "bold"
43+ cell2 . style . paddingLeft = "40px" ;
44+ cell1 . innerHTML = sensorName ;
45+ cell2 . innerHTML = sensorsData [ sensorName ] ;
46+ }
8147
8248 }
83-
49+
8450 }
8551 } ;
86-
87-
8852 xhttp . open ( "GET" , "/getJSON" , true ) ; //request JSON data from URI/getJSON
8953 xhttp . send ( ) ;
9054 }
91-
92- </ script >
93- </ html >
55+ </ script >
0 commit comments