<!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>