mirror of
https://gitlab.crans.org/nounous/ghostream.git
synced 2025-01-09 11:42:19 +00:00
107 lines
3.6 KiB
JavaScript
107 lines
3.6 KiB
JavaScript
import { ViewerCounter } from "./modules/viewerCounter.js";
|
|
|
|
/**
|
|
* Initialize viewer page
|
|
*
|
|
* @param {String} stream
|
|
* @param {String} omeApp
|
|
* @param {Number} viewersCounterRefreshPeriod
|
|
* @param {String} posterUrl
|
|
*/
|
|
export function initViewerPage(stream, omeApp, viewersCounterRefreshPeriod, posterUrl) {
|
|
// Create viewer counter
|
|
const viewerCounter = new ViewerCounter(
|
|
document.getElementById("connected-people"),
|
|
stream,
|
|
);
|
|
viewerCounter.regularUpdate(viewersCounterRefreshPeriod);
|
|
viewerCounter.refreshViewersCounter();
|
|
|
|
// Side widget toggler
|
|
const sideWidgetToggle = document.getElementById("sideWidgetToggle");
|
|
const sideWidget = document.getElementById("sideWidget");
|
|
if (sideWidgetToggle !== null && sideWidget !== null) {
|
|
// On click, toggle side widget visibility
|
|
sideWidgetToggle.addEventListener("click", function () {
|
|
if (sideWidget.style.display === "none") {
|
|
sideWidget.style.display = "block";
|
|
sideWidgetToggle.textContent = "»";
|
|
} else {
|
|
sideWidget.style.display = "none";
|
|
sideWidgetToggle.textContent = "«";
|
|
}
|
|
});
|
|
}
|
|
|
|
// Create player
|
|
let player = OvenPlayer.create("viewer", {
|
|
title: stream,
|
|
image: posterUrl,
|
|
autoStart: true,
|
|
mute: true,
|
|
expandFullScreenUI: true,
|
|
sources: [
|
|
{
|
|
"file": "wss://" + window.location.host + "/" + omeApp + "/" + stream,
|
|
"type": "webrtc",
|
|
"label": " WebRTC - Source"
|
|
},
|
|
{
|
|
"type": "hls",
|
|
"file": "https://" + window.location.host + "/" + omeApp + "/" + stream + "_bypass/playlist.m3u8",
|
|
"label": " HLS"
|
|
}
|
|
]
|
|
});
|
|
player.on("stateChanged", function (data) {
|
|
if (data.newstate === "loading") {
|
|
document.getElementById("connectionIndicator").style.fill = '#ffc107'
|
|
}
|
|
if (data.newstate === "playing") {
|
|
document.getElementById("connectionIndicator").style.fill = '#28a745'
|
|
}
|
|
if (data.newstate === "idle") {
|
|
document.getElementById("connectionIndicator").style.fill = '#dc3545'
|
|
}
|
|
})
|
|
player.on("error", function (error) {
|
|
document.getElementById("connectionIndicator").style.fill = '#dc3545'
|
|
if (error.code === 501 || error.code === 406) {
|
|
// Clear messages
|
|
const errorMsg = document.getElementsByClassName("op-message-text")[0]
|
|
errorMsg.textContent = ""
|
|
|
|
const warningIcon = document.getElementsByClassName("op-message-icon")[0]
|
|
warningIcon.textContent = ""
|
|
|
|
// Reload in 30s
|
|
setTimeout(function () {
|
|
player.load()
|
|
}, 30000)
|
|
} else {
|
|
console.log(error);
|
|
}
|
|
});
|
|
|
|
// Register keyboard events
|
|
window.addEventListener("keydown", (event) => {
|
|
switch (event.key) {
|
|
case "f":
|
|
// F key put player in fullscreen
|
|
if (document.fullscreenElement !== null) {
|
|
document.exitFullscreen()
|
|
} else {
|
|
document.getElementsByTagName("video")[0].requestFullscreen()
|
|
}
|
|
break;
|
|
case "m":
|
|
case " ":
|
|
// M and space key mute player
|
|
player.setMute(!player.getMute())
|
|
event.preventDefault()
|
|
player.play()
|
|
break;
|
|
}
|
|
});
|
|
}
|