ESP_VCP/data/index.htm
2018-06-28 09:01:26 +02:00

221 lines
7.9 KiB
HTML

<!DOCTYPE html>
<html><head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>xPablo.cz TRACE</title>
<style>
.ei {
background: url('') no-repeat #FBE3E4 5px 5px; padding: 1em; padding-left: 3.5em; border: 2px solid #FBC2C4; color: #D12F19;
}
html {
display: table;
margin: auto;
}
body {
background-color:#f9f9f9; color:#555555;
font-family:Helvetica Neue, Helvetica, Arial, sans-serif;
font-weight:400; font-size:85%;
}
h3 {
font-weight:500; font-size:1.4em;
}
p {
height:0.9em;
}
label {
display:inline-block; width:10em;
text-align:right; padding-right:0.4em;
}
fieldset {
padding-right:2em; padding-left:2em; display:inline-block;
background-color:#efefef; border:solid 1px #dddddd;
border-radius:0.3em; width:22em;
}
legend {
font-size:1.15em; font-weight:500; background-color:#efefef;
font-weight: bold;
border-width:1px; border-style:solid; border-color:#dddddd;
border-radius:0.3em; padding-left:0.5em; padding-right:0.5em;
}
span.r {
color: red;
}
span.g {
color: green;
}
span.y {
color: yellow;
}
span.b {
color: black;
}
/* Trace elementy */
table.trace {
font-family: Arial;
font-weight: bold;
}
.trace tr {
line-height: 16px;
}
td.tr_err {
border-left: 5px solid red;
padding-left: 5px;
background: #ffcccc;
}
td.tr_inf {
border-left: 5px solid green;
padding-left: 5px;
background: lightgreen;
}
td.tr_warn {
border-left: 5px solid yellow;
padding-left: 5px;
background: lightyellow;
}
td.tr_dbg {
border-left: 5px solid black;
padding-left: 5px;
background: lightgray;
}
td.tr_tm {
text-align: right;
width: 5%;
}
</style>
<meta name='viewport' content='width=device-width, initial-scale=1'>
</head>
<script>
var connection;
var connected = 0;
function ping() {
if (connected) {
if (document.getElementById("live").checked)
connection.send('status');
else
connection.send('ping');
setTimeout(ping, 5000);
}
}
function getTraceTime(stamp) {
var hours = Math.trunc((stamp % 86400000) / 3600000); // 86400 equals secs per day
var minutes = Math.trunc((stamp % 3600000) / 60000); // 3600 equals secs per minute
var seconds = Math.trunc((stamp % 60000) / 1000);
var ms = stamp % 1000;
var t;
t = hours.toLocaleString(undefined, {
minimumIntegerDigits: 2
}) + ':' + minutes.toLocaleString(undefined, {
minimumIntegerDigits: 2
}) + ':' + seconds.toLocaleString(undefined, {
minimumIntegerDigits: 2
}) + '.' + ms.toLocaleString(undefined, {
minimumIntegerDigits: 3
});
return t;
}
function connect() {
connection = new WebSocket('ws://' + window.location.hostname + '/wss', ['arduino']);
connection.onopen = function() {
console.log('WS Connected');
connected = 1;
document.getElementById('errinfo').style = "display:none";
ping(); // ping pro rychlejsi detekci ztraty spojeni
};
connection.onerror = function(error) {
console.log('WS Error ', error);
connected = 0;
};
connection.onmessage = function(e) {
var d = JSON.parse(e.data);
if (d.type == 'trace') {
var h = '<table class="trace" style="width:100%;">';
for (var i = 0; i < d.data.length; i++) {
h += '<tr><td class="tr_tm">';
h += getTraceTime(d.data[i].t);
h += '</td><td class="';
switch (d.data[i].s) {
case 0: // error
h += 'tr_err';
break;
case 1: // warning
h += 'tr_warn';
break;
case 2: // info
h += 'tr_inf';
break;
case 3: // debug
h += 'tr_dbg';
break;
case 4: // debug more
h += 'tr_dbg';
break;
}
h += '">' + d.data[i].d;
h += '</td></tr>'
}
h += '</table>';
document.getElementById('trace').innerHTML = h;
}
if (d.type == 'status') {
// document.getElementById('reset').innerHTML = d.reset;
// document.getElementById('flash').innerHTML = d.flash;
document.getElementById('ram').innerHTML = d.ram;
}
}
connection.onclose = function() {
console.log('WS Reconnecting timer start');
setTimeout(function(){connect()}, 5000);
document.getElementById('errinfo').style = "display:show";
connected = 0;
}
}
</script>
<body onload="connect()">
<h3>Informace</h3>
<fieldset>
Příčina resetu: <span id='reset'>???</span><br>
Velikost flash: <span id='flash'>???</span> bytů<br>
Volná RAM: <span id='ram'>???</span> bytů <input type="checkbox" id="live">Stále aktualizovat<br>
</fieldset>
<br />
<h3>Stopař</h3>
<div class='fixed' id=trace>
<span style='color:black'> NAHRÁVÁM ...</span>
</div>
<br />
<div class="ei" id="errinfo" style="display:none">Obnovuji spojení...</div>
</body>
</html>