test if this works (DO NOT PULL)

This commit is contained in:
ashley 2024-07-20 14:02:06 +00:00
parent 740a5d82e1
commit 098c13b966

View file

@ -703,274 +703,305 @@ background-color: #0000;
</style> </style>
</noscript> </noscript>
<script> <script>
const qua = new URLSearchParams(new URL(window.location.href).search).get("quality") || ""; const qua = new URLSearchParams(new URL(window.location.href).search).get("quality") || "";
const playSVG = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><title>play-circle-outline</title><path d="M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2M10,16.5L16,12L10,7.5V16.5Z" /></svg>' const playSVG = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><title>play-circle-outline</title><path d="M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10,10 0 0,0 12,2M10,16.5L16,12L10,7.5V16.5Z" /></svg>';
const pauseSVG = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><title>pause-circle-outline</title><path d="M13,16V8H15V16H13M9,16V8H11V16H9M12,2A10,10 0 0,1 22,12A10,10 0 0,1 12,22A10,10 0 0,1 2,12A10,10 0 0,1 12,2M12,4A8,8 0 0,0 4,12A8,8 0 0,0 12,20A8,8 0 0,0 20,12A8,8 0 0,0 12,4Z" /></svg>' const pauseSVG = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><title>pause-circle-outline</title><path d="M13,16V8H15V16H13M9,16V8H11V16H9M12,2A10,10 0 0,1 22,12A10,10 0 0,1 12,22A10,10 0 0,1 2,12A10,10 0 0,1 12,2M12,4A8,8 0 0,0 4,12A8,8 0 0,0 12,20A8,8 0 0,0 20,12A8,8 0 0,0 12,4Z" /></svg>';
function csts(seconds) {
var hours = Math.floor(seconds / 3600); function csts(seconds) {
var minutes = Math.floor((seconds - (hours * 3600)) / 60); var hours = Math.floor(seconds / 3600);
var secs = Math.floor(seconds - (hours * 3600) - (minutes * 60)); var minutes = Math.floor((seconds - (hours * 3600)) / 60);
if (hours === 0) { var secs = Math.floor(seconds - (hours * 3600) - (minutes * 60));
var timeString = minutes.toString().padStart(2, '0') + ':' + if (hours === 0) {
secs.toString().padStart(2, '0'); var timeString = minutes.toString().padStart(2, '0') + ':' + secs.toString().padStart(2, '0');
} else { } else {
var timeString = hours.toString().padStart(2, '0') + ':' + var timeString = hours.toString().padStart(2, '0') + ':' + minutes.toString().padStart(2, '0') + ':' + secs.toString().padStart(2, '0');
minutes.toString().padStart(2, '0') + ':' + }
secs.toString().padStart(2, '0'); return timeString;
}
return timeString;
} }
function cstsRemaining(totalTimeInSeconds, elapsedTimeInSeconds) { function cstsRemaining(totalTimeInSeconds, elapsedTimeInSeconds) {
var remainingSeconds = totalTimeInSeconds - elapsedTimeInSeconds; var remainingSeconds = totalTimeInSeconds - elapsedTimeInSeconds;
var hours = Math.floor(remainingSeconds / 3600); var hours = Math.floor(remainingSeconds / 3600);
var minutes = Math.floor((remainingSeconds % 3600) / 60); var minutes = Math.floor((remainingSeconds % 3600) / 60);
var secs = Math.floor(remainingSeconds % 60); var secs = Math.floor(remainingSeconds % 60);
var timeString; var timeString;
if (hours === 0) { if (hours === 0) {
timeString = minutes.toString().padStart(2, '0') + ':' + secs.toString().padStart(2, '0'); timeString = minutes.toString().padStart(2, '0') + ':' + secs.toString().padStart(2, '0');
} else { } else {
timeString = hours.toString().padStart(2, '0') + ':' + minutes.toString().padStart(2, '0') + ':' + secs.toString().padStart(2, '0'); timeString = hours.toString().padStart(2, '0') + ':' + minutes.toString().padStart(2, '0') + ':' + secs.toString().padStart(2, '0');
} }
return '-' + timeString; return '-' + timeString;
} }
function showErrorCard(e) {
try { function showErrorCard(e) {
switch (e.target.error.code) { try {
switch (e.target.error.code) {
case e.target.error.MEDIA_ERR_ABORTED: case e.target.error.MEDIA_ERR_ABORTED:
return; return;
break;
case e.target.error.MEDIA_ERR_NETWORK: case e.target.error.MEDIA_ERR_NETWORK:
document.querySelector("div p span").innerText = "(Network error)" document.querySelector("div p span").innerText = "(Network error)";
break; break;
case e.target.error.MEDIA_ERR_DECODE: case e.target.error.MEDIA_ERR_DECODE:
document.querySelector("div p span").innerText = "(Decode error/lack of browser support)" document.querySelector("div p span").innerText = "(Decode error/lack of browser support)";
break; break;
case e.target.error.MEDIA_ERR_SRC_NOT_SUPPORTED: case e.target.error.MEDIA_ERR_SRC_NOT_SUPPORTED:
document.querySelector("div p span").innerText = "(Network error or format not supported)" document.querySelector("div p span").innerText = "(Network error or format not supported)";
break; break;
default: default:
document.querySelector("div p span").innerText = "(Unknown error)" document.querySelector("div p span").innerText = "(Unknown error)";
break; break;
}
} }
catch { } catch {
document.querySelector("div p span").innerText = "(Network error)" document.querySelector("div p span").innerText = "(Network error)";
}
document.getElementById("buffer-failed-warning").style.display = "block";
} }
let canPlayPause = true; document.getElementById("buffer-failed-warning").style.display = "block";
let didFirstTimePlay = false; }
document.addEventListener("DOMContentLoaded", () => {
//FIXME: saved playback intentionally overwritten let canPlayPause = true;
localStorage.setItem(`progress-${new URLSearchParams(window.location.search).get('v')}`, 0); let didFirstTimePlay = false;
// Controls and high-res playback
//TODO - a document.addEventListener("DOMContentLoaded", () => {
let setTime = false localStorage.setItem(`progress-${new URLSearchParams(window.location.search).get('v')}`, 0);
const seekbar = document.getElementById("duration-slider")
const video = document.getElementById("video"); let setTime = false;
let shouldUseRemaining = false; const seekbar = document.getElementById("duration-slider");
const timestamps = document.getElementById("timestamps"); const video = document.getElementById("video");
video.addEventListener("timeupdate", (event) => { let shouldUseRemaining = false;
seekbar.value = event.target.currentTime; const timestamps = document.getElementById("timestamps");
timestamps.innerText = shouldUseRemaining ? `${cstsRemaining(video.duration, video.currentTime)}/${csts(video.duration)}` : `${csts(video.currentTime)}/${csts(video.duration)}`;
}); video.addEventListener("timeupdate", (event) => {
timestamps.addEventListener("mouseover", () => { seekbar.value = event.target.currentTime;
shouldUseRemaining = true; timestamps.innerText = shouldUseRemaining ? `${cstsRemaining(video.duration, video.currentTime)}/${csts(video.duration)}` : `${csts(video.currentTime)}/${csts(video.duration)}`;
timestamps.innerText = `${cstsRemaining(video.duration, video.currentTime)}/${csts(video.duration)}`; });
});
timestamps.addEventListener("mouseout", () => { timestamps.addEventListener("mouseover", () => {
shouldUseRemaining = false; shouldUseRemaining = true;
timestamps.innerText = `${csts(video.currentTime)}/${csts(video.duration)}`; timestamps.innerText = `${cstsRemaining(video.duration, video.currentTime)}/${csts(video.duration)}`;
}); });
// test
timestamps.addEventListener("mouseout", () => {
seekbar.addEventListener("input", (event) => { shouldUseRemaining = false;
video.pause() timestamps.innerText = `${csts(video.currentTime)}/${csts(video.duration)}`;
canPlayPause = false; });
if(qua != "medium") {
aud.pause() seekbar.addEventListener("input", (event) => {
aud.currentTime = event.target.value video.pause();
canPlayPause = false;
if (qua != "medium") {
aud.pause();
aud.currentTime = event.target.value;
}
video.currentTime = event.target.value;
canPlayPause = true;
setTimeout(() => {
video.play();
aud.play();
}, 200);
});
const playPauseButton = document.getElementById("play-pause");
playPauseButton.innerHTML = pauseSVG;
function toggleVideo() {
if (!canPlayPause) return;
if (document.getElementById("popupMenu").style.display == "none") {
if (!document.fullscreen) {
if (!video.paused) {
video.pause();
if (qua != "medium") {
aud.pause();
} }
video.currentTime = event.target.value playPauseButton.innerHTML = playSVG;
canPlayPause = true; } else {
setTimeout(()=>{ video.play();
video.play(); if (qua != "medium") {
aud.play(); aud.play();
}, 200)
});
// Play/Pause
const playPauseButton = document.getElementById("play-pause");
playPauseButton.innerHTML = pauseSVG;
function toggleVideo() {
if(!canPlayPause) return;
if(document.getElementById("popupMenu").style.display == "none") {
if(!document.fullscreen) {
if(!video.paused) {
video.pause(); if(qua != "medium") { aud.pause(); } playPauseButton.innerHTML = playSVG;
}
else {
video.play(); if(qua != "medium") { aud.play(); } playPauseButton.innerHTML = pauseSVG;
}
}
} }
else {
document.getElementById("popupMenu").style.display = "none"
}
}
playPauseButton.addEventListener("click", () => {
toggleVideo()
});
video.addEventListener("pause", ()=>{if(qua != "medium") {aud.pause()}});
video.addEventListener("play", ()=>{if(qua != "medium") {aud.play()}})
video.addEventListener("click", toggleVideo);
video.addEventListener("dblclick", () => {
document.documentElement.requestFullscreen();
});
function handleVolumeChange(element) {
switch (element.volume) {
case 1:
element.volume = 0;
document.querySelector("#muteOption #new").innerText = "25%"
document.querySelector("#muteOption #current").innerText = "0%"
break;
case 0:
element.volume = 0.25;
document.querySelector("#muteOption #new").innerText = "50%"
document.querySelector("#muteOption #current").innerText = "25%"
break;
case 0.25:
element.volume = 0.5;
document.querySelector("#muteOption #new").innerText = "75%"
document.querySelector("#muteOption #current").innerText = "50%"
break;
case 0.5:
element.volume = 0.75;
document.querySelector("#muteOption #new").innerText = "100%"
document.querySelector("#muteOption #current").innerText = "75%"
break;
case 0.75:
element.volume = 1;
document.querySelector("#muteOption #new").innerText = "0%"
document.querySelector("#muteOption #current").innerText = "100%"
break;
default:
element.volume = 1;
document.querySelector("#muteOption #new").innerText = "0%"
document.querySelector("#muteOption #current").innerText = "100%"
break;
}
}
document.getElementById("muteOption").addEventListener("click", () => {
if(qua != "medium") {
handleVolumeChange(aud)
}
else {
handleVolumeChange(video)
}
});
document.getElementById("syncOption").addEventListener("click", () => {
aud.pause(); video.pause(); playPauseButton.innerHTML = playSVG;
video.currentTime > aud.currentTime ? aud.currentTime = video.currentTime : video.currentTime = aud.currentTime;
playPauseButton.innerHTML = pauseSVG;
});
setTimeout(()=>{
if(!didFirstTimePlay) {
video.addEventListener("seeked", (event) => {
setTimeout(()=>{
canPlayPause = true;
if(video.currentTime==0||aud.currentTime==0) return;
video.pause(); aud.pause(); playPauseButton.innerHTML = playSVG;
},1)
});
aud.addEventListener("seeked", (event) => {
setTimeout(()=>{
if(video.currentTime==0||aud.currentTime==0) return;
video.pause(); aud.pause(); playPauseButton.innerHTML = playSVG;
},1)
});
didFirstTimePlay = true;
}
},100)
document.addEventListener("fullscreenchange", function() {
if(document.fullscreen) {
video.controlsList = "noplaybackrate nodownload"
window.onscroll = function () { window.scrollTo(0, 0); };
document.documentElement.style.overflow = "hidden"
video.controls = true;
}
if(!document.fullscreen) {
video.controlsList = ""
window.onscroll = null;
document.documentElement.style.overflow = null
video.controls = false;
}
});
video.addEventListener("fullscreenchange", () => {
video.fullscreen = false;
document.exitFullscreen();
});
video.addEventListener("contextmenu", (event) => {
if(document.fullscreen) {
event.preventDefault()
const popupMenu = document.getElementById('popupMenu');
if (popupMenu) {
const xPosition = event.clientX + window.pageXOffset;
const yPosition = event.clientY + window.pageYOffset;
popupMenu.style.left = `${xPosition}px`;
popupMenu.style.top = `${yPosition}px`;
}
popupMenu.style.display = "block"
}
});
function startPlayback() {
// Final prepare
seekbar.max = video.duration
const timestamps = document.getElementById("timestamps");
timestamps.innerText = `${csts(video.currentTime)}/${csts(video.duration)}`;
// Show controls
try {
playPauseButton.innerHTML = pauseSVG; playPauseButton.innerHTML = pauseSVG;
vid.play();
aud.play();
didFirstTimePlay = true;
} }
catch {} }
} else {
if(!setTime) { document.getElementById("popupMenu").style.display = "none";
//FIXME: saved playback intentionally overwritten }
aud.currentTime = 0 }
vid.currentTime = 0
seekbar.value = 0 playPauseButton.addEventListener("click", () => {
setTime = true toggleVideo();
});
video.addEventListener("pause", () => {
if (qua != "medium") {
aud.pause();
}
});
video.addEventListener("play", () => {
if (qua != "medium") {
aud.play();
}
});
video.addEventListener("click", toggleVideo);
video.addEventListener("dblclick", () => {
document.documentElement.requestFullscreen();
});
function handleVolumeChange(element) {
switch (element.volume) {
case 1:
element.volume = 0;
document.querySelector("#muteOption #new").innerText = "25%";
document.querySelector("#muteOption #current").innerText = "0%";
break;
case 0:
element.volume = 0.25;
document.querySelector("#muteOption #new").innerText = "50%";
document.querySelector("#muteOption #current").innerText = "25%";
break;
case 0.25:
element.volume = 0.5;
document.querySelector("#muteOption #new").innerText = "75%";
document.querySelector("#muteOption #current").innerText = "50%";
break;
case 0.5:
element.volume = 0.75;
document.querySelector("#muteOption #new").innerText = "100%";
document.querySelector("#muteOption #current").innerText = "75%";
break;
case 0.75:
element.volume = 1;
document.querySelector("#muteOption #new").innerText = "0%";
document.querySelector("#muteOption #current").innerText = "100%";
break;
default:
element.volume = 1;
document.querySelector("#muteOption #new").innerText = "0%";
document.querySelector("#muteOption #current").innerText = "100%";
break;
}
}
document.getElementById("muteOption").addEventListener("click", () => {
if (qua != "medium") {
handleVolumeChange(aud);
} else {
handleVolumeChange(video);
}
});
document.getElementById("syncOption").addEventListener("click", () => {
aud.pause();
video.pause();
playPauseButton.innerHTML = playSVG;
video.currentTime > aud.currentTime ? aud.currentTime = video.currentTime : video.currentTime = aud.currentTime;
playPauseButton.innerHTML = pauseSVG;
});
setTimeout(() => {
if (!didFirstTimePlay) {
video.addEventListener("seeked", (event) => {
setTimeout(() => {
canPlayPause = true;
if (video.currentTime == 0 || aud.currentTime == 0) return;
video.pause();
aud.pause();
playPauseButton.innerHTML = playSVG;
}, 1);
});
aud.addEventListener("seeked", (event) => {
setTimeout(() => {
if (video.currentTime == 0 || aud.currentTime == 0) return;
video.pause();
aud.pause();
playPauseButton.innerHTML = playSVG;
}, 1);
});
didFirstTimePlay = true;
}
}, 100);
document.addEventListener("fullscreenchange", function() {
if (document.fullscreen) {
video.controlsList = "noplaybackrate nodownload";
window.onscroll = function() { window.scrollTo(0, 0); };
document.documentElement.style.overflow = "hidden";
video.controls = true;
}
if (!document.fullscreen) {
video.controlsList = "";
window.onscroll = null;
document.documentElement.style.overflow = null;
video.controls = false;
}
});
video.addEventListener("fullscreenchange", () => {
video.fullscreen = false;
document.exitFullscreen();
});
video.addEventListener("contextmenu", (event) => {
if (document.fullscreen) {
event.preventDefault();
const popupMenu = document.getElementById('popupMenu');
if (popupMenu) {
const xPosition = event.clientX + window.pageXOffset;
const yPosition = event.clientY + window.pageYOffset;
popupMenu.style.left = `${xPosition}px`;
popupMenu.style.top = `${yPosition}px`;
}
popupMenu.style.display = "block";
}
});
function startPlayback() {
seekbar.max = video.duration;
const timestamps = document.getElementById("timestamps");
timestamps.innerText = `${csts(video.currentTime)}/${csts(video.duration)}`;
try {
playPauseButton.innerHTML = pauseSVG;
vid.play();
aud.play();
didFirstTimePlay = true;
} catch {}
if (!setTime) {
aud.currentTime = 0;
vid.currentTime = 0;
seekbar.value = 0;
setTime = true;
}
setTimeout(() => {
video.addEventListener("seeking", (event) => {
if (!didFirstTimePlay) return;
if (qua != "medium") {
video.pause();
canPlayPause = false;
aud.pause();
aud.currentTime = event.target.currentTime;
} }
setTimeout(()=>{ });
video.addEventListener("seeking", (event) => { }, 500);
if(!didFirstTimePlay) return; }
if(qua != "medium") {
video.pause() const aud = document.getElementById("aud");
canPlayPause = false; const vid = document.getElementById("video");
aud.pause()
aud.currentTime = event.target.currentTime function shouldPlay() {
} if (vid.readyState === HTMLMediaElement.HAVE_ENOUGH_DATA && aud.readyState === HTMLMediaElement.HAVE_ENOUGH_DATA) {
}); startPlayback();
}, 500)
} }
const aud = document.getElementById("aud"); }
const vid = document.getElementById("video");
function shouldPlay() { aud.addEventListener("canplaythrough", shouldPlay);
if(vid.readyState === HTMLMediaElement.HAVE_ENOUGH_DATA && aud.readyState === HTMLMediaElement.HAVE_ENOUGH_DATA) { vid.addEventListener("canplaythrough", shouldPlay);
startPlayback(); });
}
}
aud.addEventListener("canplaythrough", shouldPlay);
vid.addEventListener("canplaythrough", shouldPlay);
})
</script> </script>
<% if(shortsui) { %> <% if(shortsui) { %>
<script> <script>