diff options
author | Devaev Maxim <[email protected]> | 2020-06-02 20:59:43 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2020-06-02 20:59:43 +0300 |
commit | cb9597679d8c9189e671e166de45c707c650bb2f (patch) | |
tree | e0f3e00bafe4c1674f8497e6832f292233d94821 /web/share/js | |
parent | fe7c275d1a827f95d40d774e38b928aee493a41b (diff) |
improved info handler
Diffstat (limited to 'web/share/js')
-rw-r--r-- | web/share/js/index/main.js | 25 | ||||
-rw-r--r-- | web/share/js/kvm/session.js | 50 |
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, " ").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; |