diff options
Diffstat (limited to 'web/share')
-rw-r--r-- | web/share/js/kvm/stream.js | 14 | ||||
-rw-r--r-- | web/share/js/tools.js | 19 |
2 files changed, 27 insertions, 6 deletions
diff --git a/web/share/js/kvm/stream.js b/web/share/js/kvm/stream.js index 1596816c..272df998 100644 --- a/web/share/js/kvm/stream.js +++ b/web/share/js/kvm/stream.js @@ -459,6 +459,7 @@ export function Streamer() { __janus_enabled = (enabled && supported && _Janus !== null); tools.featureSetEnabled($("stream-mode"), __janus_enabled); tools.info(`Stream: Janus WebRTC state: enabled=${enabled}, supported=${supported}, imported=${!!_Janus}`); + tools.radioClickValue("stream-mode-radio", tools.storage.get("stream.mode", "mjpeg")); self.setState(__state); }; if (enabled && supported) { @@ -609,16 +610,17 @@ export function Streamer() { var __clickModeRadio = function() { if (_Janus !== null) { let mode = tools.radioGetValue("stream-mode-radio"); + tools.storage.set("stream.mode", mode); if (mode !== __streamer.getMode()) { setTimeout(() => tools.radioSetValue("stream-mode-radio", mode), 100); - tools.hiddenSetVisible($("stream-image"), (mode === "mjpeg")); - tools.hiddenSetVisible($("stream-video"), (mode !== "mjpeg")); - if (mode === "mjpeg") { - __streamer.stopStream(); - __streamer = new _MjpegStreamer(__setActive, __setInactive, __setInfo); - } else { // janus + tools.hiddenSetVisible($("stream-image"), (mode !== "janus")); + tools.hiddenSetVisible($("stream-video"), (mode === "janus")); + if (mode === "janus") { __streamer.stopStream(); __streamer = new _JanusStreamer(__setActive, __setInactive, __setInfo); + } else { // mjpeg + __streamer.stopStream(); + __streamer = new _MjpegStreamer(__setActive, __setInactive, __setInfo); } if (wm.isWindowVisible($("stream-window"))) { __streamer.ensureStream(__state); diff --git a/web/share/js/tools.js b/web/share/js/tools.js index 02c6e637..6fcacf45 100644 --- a/web/share/js/tools.js +++ b/web/share/js/tools.js @@ -160,6 +160,15 @@ export var tools = new function() { el.checked = (el.value === value); } }; + this.radioClickValue = function(name, value) { + for (let el of $$$(`input[type="radio"][name="${name}"]`)) { + if (el.value === value) { + el.click(); + return; + } + } + }; + this.progressSetValue = function(el, title, percent) { el.setAttribute("data-label", title); @@ -242,6 +251,16 @@ export var tools = new function() { this.info("Browser:", this.browser); this.https = (location.protocol === "https:"); + + this.storage = new function() { + return { + "get": function(key, default_value) { + let value = window.localStorage.getItem(key); + return (value !== null ? value : default_value); + }, + "set": (key, value) => window.localStorage.setItem(key, value), + }; + }; }; export var $ = (id) => document.getElementById(id); |