aprsNotifyJS/client.js

68 lines
1.8 KiB
JavaScript
Raw Normal View History

let calls = {};
let messages = [];
const timeoutLength = 20 * 60 * 1000; // 20 Minutes
Notification.requestPermission(permission => {
if (permission === "granted") {
new Notification("Test notification", {body: "whatever"});
}
});
2018-07-10 19:03:21 -04:00
function redrawTable() {
let table = document.querySelector('table.calls');
table.innerHTML =
`<tr><th>Callsign</th>` +
`<th>Last Heard</th>` +
`<th>Time since Last Heard</th>`;
for (let callsign in calls) {
let call = calls[callsign];
let nowDelta = new Date(new Date() - call.lastHeard);
let tr = table.appendChild(document.createElement('tr'));
if (nowDelta.getTime() > timeoutLength) {
tr.classList.add('timedOut');
}
tr.innerHTML =
`<td>${callsign}</td>` +
`<td>${call.lastHeard.toLocaleTimeString('en-GB')}</td>` +
`<td>${nowDelta.toLocaleTimeString('en-GB', {timeZone: "UTC"})}</td>`
;
}
}
function alertNotHeard(callsign) {
new Notification(`${callsign} has not been heard for 20 Minutes!`,
{body: `Last Heard: ${calls[callsign].lastHeard.toLocaleTimeString('en-GB')}`});
}
let aprsStream = new WebSocket("ws://localhost:1234");
aprsStream.onmessage = function(event) {
let message = JSON.parse(event.data);
let callsign = `${message.from.call}-${message.from.ssid || 0}`;
let date = new Date(message.recieved);
console.log(message);
messages.push(message);
if (!(callsign in calls)) {
calls[callsign] = {
lastHeard: date,
};
}
else {
window.clearTimeout(calls[callsign].timeout);
}
calls[callsign].delta = date - calls[callsign].lastHeard;
calls[callsign].timeout = window.setTimeout(
alertNotHeard, timeoutLength, callsign);
2018-07-10 19:03:21 -04:00
redrawTable();
};
2018-07-10 19:03:21 -04:00
window.addEventListener("load", redrawTable);
window.setInterval(redrawTable, 1000);