summaryrefslogtreecommitdiff
path: root/web/share/js
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2020-06-02 20:59:43 +0300
committerDevaev Maxim <[email protected]>2020-06-02 20:59:43 +0300
commitcb9597679d8c9189e671e166de45c707c650bb2f (patch)
treee0f3e00bafe4c1674f8497e6832f292233d94821 /web/share/js
parentfe7c275d1a827f95d40d774e38b928aee493a41b (diff)
improved info handler
Diffstat (limited to 'web/share/js')
-rw-r--r--web/share/js/index/main.js25
-rw-r--r--web/share/js/kvm/session.js50
2 files changed, 60 insertions, 15 deletions
diff --git a/web/share/js/index/main.js b/web/share/js/index/main.js
index ba33b0aa..497a4d73 100644
--- a/web/share/js/index/main.js
+++ b/web/share/js/index/main.js
@@ -56,15 +56,20 @@ function __loadKvmdInfo() {
if (http.status === 200) {
let info = JSON.parse(http.responseText).result;
- let apps = Object.values(info.extras).sort(function(a, b) {
- if (a.place < b.place) {
- return -1;
- } else if (a.place > b.place) {
- return 1;
- } else {
- return 0;
- }
- });
+ let apps = [];
+ if (info.extras === null) {
+ wm.error("Not all applications in the menu can be displayed<br>due an error. See KVMD logs for details.");
+ } else {
+ apps = Object.values(info.extras).sort(function(a, b) {
+ if (a.place < b.place) {
+ return -1;
+ } else if (a.place > b.place) {
+ return 1;
+ } else {
+ return 0;
+ }
+ });
+ }
$("apps-box").innerHTML = "<ul id=\"apps\"></ul>";
@@ -79,7 +84,7 @@ function __loadKvmdInfo() {
$("apps").innerHTML += __makeApp("logout-button", "#", "share/svg/logout.svg", "Logout");
tools.setOnClick($("logout-button"), __logout);
- if (info.meta && info.meta.server && info.meta.server.host) {
+ if (info.meta !== null && info.meta.server && info.meta.server.host) {
$("kvmd-meta-server-host").innerHTML = info.meta.server.host;
document.title = `Pi-KVM Index: ${info.meta.server.host}`;
} else {
diff --git a/web/share/js/kvm/session.js b/web/share/js/kvm/session.js
index 5df1481c..7b68ac88 100644
--- a/web/share/js/kvm/session.js
+++ b/web/share/js/kvm/session.js
@@ -55,8 +55,8 @@ export function Session() {
/************************************************************************/
- var __setKvmdInfo = function(state) {
- if (state.meta) {
+ var __setAboutInfo = function(state) {
+ if (state.meta != null) {
let text = JSON.stringify(state.meta, undefined, 4).replace(/ /g, "&nbsp;").replace(/\n/g, "<br>");
$("about-meta").innerHTML = `
<span class="code-comment">// The Pi-KVM metadata.<br>
@@ -75,8 +75,48 @@ export function Session() {
}
}
- $("about-version-kvmd").innerHTML = state.version.kvmd;
- $("about-version-streamer").innerHTML = `${state.version.streamer} (${state.streamer})`;
+ let sys = state.system;
+ $("about-version").innerHTML = `
+ KVMD: <span class="code-comment">${sys.kvmd.version}</span><br>
+ <hr>
+ Streamer: <span class="code-comment">${sys.streamer.version} (${sys.streamer.app})</span>
+ ${__formatStreamerFeatures(sys.streamer.features)}
+ <hr>
+ ${sys.kernel.system} kernel:
+ ${__formatUname(sys.kernel)}
+ `;
+ };
+
+ var __formatStreamerFeatures = function(features) {
+ let pairs = [];
+ for (let field of Object.keys(features).sort()) {
+ pairs.push([
+ field,
+ (features[field] ? "Yes" : "No"),
+ ]);
+ }
+ return __formatUl(pairs);
+ };
+
+ var __formatUname = function(kernel) {
+ let pairs = [];
+ for (let field of Object.keys(kernel).sort()) {
+ if (field != "system") {
+ pairs.push([
+ field[0].toUpperCase() + field.slice(1),
+ kernel[field],
+ ]);
+ }
+ }
+ return __formatUl(pairs);
+ };
+
+ var __formatUl = function(pairs) {
+ let text = "<ul>";
+ for (let pair of pairs) {
+ text += `<li>${pair[0]}: <span class="code-comment">${pair[1]}</span></li>`;
+ }
+ return text + "</ul>";
};
var __startSession = function() {
@@ -117,7 +157,7 @@ export function Session() {
let data = JSON.parse(event.data);
switch (data.event_type) {
case "pong": __missed_heartbeats = 0; break;
- case "info_state": __setKvmdInfo(data.event); break;
+ case "info_state": __setAboutInfo(data.event); break;
case "wol_state": __wol.setState(data.event); break;
case "hid_state": __hid.setState(data.event); break;
case "atx_state": __atx.setState(data.event); break;