mirror of https://github.com/nymea/nymea.git
202 lines
7.2 KiB
JavaScript
202 lines
7.2 KiB
JavaScript
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
* *
|
|
* Copyright (C) 2018 Simon Stürz <simon.stuerz@guh.io> *
|
|
* *
|
|
* This file is part of nymea. *
|
|
* *
|
|
* nymea is free software: you can redistribute it and/or modify *
|
|
* it under the terms of the GNU General Public License as published by *
|
|
* the Free Software Foundation, version 2 of the License. *
|
|
* *
|
|
* nymea is distributed in the hope that it will be useful, *
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
|
* GNU General Public License for more details. *
|
|
* *
|
|
* You should have received a copy of the GNU General Public License *
|
|
* along with nymea. If not, see <http://www.gnu.org/licenses/>. *
|
|
* *
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
|
|
/* ========================================================================*/
|
|
/* Navigation
|
|
/* ========================================================================*/
|
|
|
|
function selectSection(event, section) {
|
|
|
|
console.log("Selected tab " + section)
|
|
|
|
var i, tabcontent, tablinks;
|
|
tabcontent = document.getElementsByClassName("tabcontent");
|
|
for (i = 0; i < tabcontent.length; i++) {
|
|
tabcontent[i].style.display = "none";
|
|
}
|
|
|
|
tablinks = document.getElementsByClassName("tablinks");
|
|
for (i = 0; i < tablinks.length; i++) {
|
|
tablinks[i].className = tablinks[i].className.replace(" active", "");
|
|
}
|
|
|
|
document.getElementById(section).style.display = "block";
|
|
event.currentTarget.className += " active";
|
|
}
|
|
|
|
/* ========================================================================*/
|
|
/* Websocket connection
|
|
/* ========================================================================*/
|
|
|
|
var webSocket = null;
|
|
var webSocketConnected = false;
|
|
|
|
function toggleWebsocketConnection() {
|
|
if (webSocketConnected) {
|
|
disconnectWebsocket()
|
|
} else {
|
|
connectWebsocket()
|
|
}
|
|
}
|
|
|
|
function connectWebsocket() {
|
|
var urlString = "ws://" + window.location.hostname + ":2626"
|
|
console.log("Connecting to: " + urlString);
|
|
|
|
try {
|
|
webSocket = new WebSocket(urlString);
|
|
|
|
webSocket.onopen = function(openEvent) {
|
|
console.log("WebSocket connected: " + JSON.stringify(openEvent, null, 4));
|
|
webSocketConnected = true;
|
|
document.getElementById("toggleLogsButton").innerHTML = "Stop logs";
|
|
};
|
|
|
|
webSocket.onclose = function(closeEvent) {
|
|
console.log("WebSocket disconnected: " + JSON.stringify(closeEvent, null, 4));
|
|
webSocketConnected = false;
|
|
document.getElementById("toggleLogsButton").innerHTML = "Start logs";
|
|
};
|
|
|
|
webSocket.onerror = function(errorEvent) {
|
|
console.log("WebSocket error: " + JSON.stringify(errorEvent, null, 4));
|
|
};
|
|
|
|
webSocket.onmessage = function (messageEvent) {
|
|
var message = messageEvent.data;
|
|
console.log("WebSocket data received: " + message);
|
|
document.getElementById("logsTextArea").value += message;
|
|
document.getElementById("logsTextArea").scrollTop = document.getElementById("logsTextArea").scrollHeight
|
|
};
|
|
|
|
} catch (exception) {
|
|
console.error(exception);
|
|
}
|
|
|
|
}
|
|
|
|
function disconnectWebsocket() {
|
|
console.log("Disconnecting from: " + webSocket.url);
|
|
webSocket.close()
|
|
webSocketConnected = false;
|
|
document.getElementById("toggleLogsButton").innerHTML = "Start logs";
|
|
}
|
|
|
|
|
|
/* ========================================================================*/
|
|
/* File download / show functions
|
|
/* ========================================================================*/
|
|
|
|
function showFile(path) {
|
|
console.log("Show file in tab " + path);
|
|
window.open(path, '_blank');
|
|
}
|
|
|
|
function downloadFile(filePath, fileName) {
|
|
console.log("Download file requested " + filePath + " --> " + fileName);
|
|
var element = document.createElement('a');
|
|
element.setAttribute('href', filePath);
|
|
element.setAttribute('download', fileName);
|
|
element.style.display = 'none';
|
|
document.body.appendChild(element);
|
|
element.click();
|
|
document.body.removeChild(element);
|
|
}
|
|
|
|
/* ========================================================================*/
|
|
/* Network test functions
|
|
/* ========================================================================*/
|
|
|
|
function startPingTest() {
|
|
console.log("Start ping test");
|
|
var textArea = document.getElementById("pingTextArea");
|
|
var button = document.getElementById("pingButton");
|
|
// Clear the text output
|
|
textArea.value = "";
|
|
|
|
// Request ping output
|
|
var request = new XMLHttpRequest();
|
|
request.open("GET", "/debug/ping", true);
|
|
request.send(null);
|
|
button.disabled = true
|
|
request.onreadystatechange = function() {
|
|
if (request.readyState == 4) {
|
|
console.log(request.responseText);
|
|
textArea.value = request.responseText
|
|
button.disabled = false
|
|
}
|
|
};
|
|
}
|
|
|
|
function startDigTest() {
|
|
console.log("Start dig test");
|
|
var textArea = document.getElementById("digTextArea");
|
|
var button = document.getElementById("digButton");
|
|
|
|
// Clear the text output
|
|
textArea.value = "";
|
|
|
|
// Request dig output
|
|
var request = new XMLHttpRequest();
|
|
request.open("GET", "/debug/dig", true);
|
|
request.send(null);
|
|
button.disabled = true
|
|
request.onreadystatechange = function() {
|
|
if (request.readyState == 4) {
|
|
console.log(request.responseText);
|
|
textArea.value = request.responseText
|
|
button.disabled = false
|
|
}
|
|
};
|
|
}
|
|
|
|
function startTracePathTest() {
|
|
console.log("Start trace path test");
|
|
var textArea = document.getElementById("tracePathTextArea");
|
|
var button = document.getElementById("tracePathButton");
|
|
|
|
// Clear the text output
|
|
textArea.value = "";
|
|
|
|
// Request dig output
|
|
var request = new XMLHttpRequest();
|
|
request.open("GET", "/debug/tracepath", true);
|
|
request.send(null);
|
|
button.disabled = true
|
|
request.onreadystatechange = function() {
|
|
if (request.readyState == 4) {
|
|
console.log(request.responseText);
|
|
textArea.value = request.responseText
|
|
button.disabled = false
|
|
}
|
|
};
|
|
}
|
|
|
|
/* ========================================================================*/
|
|
/* Start function calls
|
|
/* ========================================================================*/
|
|
|
|
window.onload = function() {
|
|
console.log("Window loading finished.");
|
|
document.getElementById("informationTabButton").click();
|
|
};
|
|
|