summaryrefslogtreecommitdiff
path: root/web
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2022-11-29 10:13:53 +0300
committerMaxim Devaev <[email protected]>2022-11-29 10:13:53 +0300
commita68eb4ed2d34682a696f5145868cc744cef9a949 (patch)
tree81b0766aa003a58f971a003d4027363e44d9c12c /web
parent6a339238ffa5907ef99b537918b1861c27740265 (diff)
refactoring
Diffstat (limited to 'web')
-rw-r--r--web/share/js/kvm/stream.js45
-rw-r--r--web/share/js/kvm/stream_janus.js10
2 files changed, 25 insertions, 30 deletions
diff --git a/web/share/js/kvm/stream.js b/web/share/js/kvm/stream.js
index fef59c49..650256f4 100644
--- a/web/share/js/kvm/stream.js
+++ b/web/share/js/kvm/stream.js
@@ -111,23 +111,24 @@ export function Streamer() {
let has_webrtc = JanusStreamer.is_webrtc_available();
let has_h264 = JanusStreamer.is_h264_available();
- let set_enabled = function() {
- tools.hidden.setVisible($("stream-message-no-webrtc"), !has_webrtc);
- tools.hidden.setVisible($("stream-message-no-h264"), !has_h264);
- __janus_enabled = (enabled && has_webrtc && JanusStreamer.is_imported()); // Don't check has_h264 for sure
+ let set_enabled = function(imported) {
+ tools.hidden.setVisible($("stream-message-no-webrtc"), enabled && !has_webrtc);
+ tools.hidden.setVisible($("stream-message-no-h264"), enabled && !has_h264);
+ __janus_enabled = (enabled && has_webrtc && imported); // Don't check has_h264 for sure
tools.feature.setEnabled($("stream-mode"), __janus_enabled);
tools.info(
`Stream: Janus WebRTC state: enabled=${enabled},`
- + ` webrtc=${has_webrtc}, h264=${has_h264}, imported=${JanusStreamer.is_imported()}`
+ + ` webrtc=${has_webrtc}, h264=${has_h264}, imported=${imported}`
);
- tools.radio.clickValue("stream-mode-radio", tools.storage.get("stream.mode", "janus"));
+ let mode = (__janus_enabled ? tools.storage.get("stream.mode", "janus") : "mjpeg");
+ tools.radio.clickValue("stream-mode-radio", mode);
self.setState(__state);
};
if (enabled && has_webrtc) {
JanusStreamer.ensure_janus(set_enabled);
} else {
- set_enabled();
+ set_enabled(false);
}
};
@@ -239,22 +240,20 @@ export function Streamer() {
};
var __clickModeRadio = function() {
- if (JanusStreamer.is_imported()) {
- let mode = tools.radio.getValue("stream-mode-radio");
- tools.storage.set("stream.mode", mode);
- if (mode !== __streamer.getMode()) {
- tools.hidden.setVisible($("stream-image"), (mode !== "janus"));
- tools.hidden.setVisible($("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);
- }
+ let mode = tools.radio.getValue("stream-mode-radio");
+ tools.storage.set("stream.mode", mode);
+ if (mode !== __streamer.getMode()) {
+ tools.hidden.setVisible($("stream-image"), (mode !== "janus"));
+ tools.hidden.setVisible($("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/kvm/stream_janus.js b/web/share/js/kvm/stream_janus.js
index eece0124..ad5b5b54 100644
--- a/web/share/js/kvm/stream_janus.js
+++ b/web/share/js/kvm/stream_janus.js
@@ -333,22 +333,18 @@ JanusStreamer.ensure_janus = function(callback) {
"debug": "all",
"callback": function() {
_Janus = module.Janus;
- callback();
+ callback(true);
},
});
}).catch((err) => {
tools.error("Stream: Can't import Janus module:", err);
- callback();
+ callback(false);
});
} else {
- callback();
+ callback(true);
}
};
-JanusStreamer.is_imported = function() {
- return (_Janus !== null);
-};
-
JanusStreamer.is_webrtc_available = function() {
return !!window.RTCPeerConnection;
};