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