mirror of
https://codeberg.org/ashley/poke.git
synced 2024-11-26 04:18:55 +01:00
test if this works (DO NOT PULL)
This commit is contained in:
parent
4bc351de27
commit
eaacf84ea9
1 changed files with 61 additions and 465 deletions
|
@ -378,6 +378,9 @@ a[data-onclick="jump_to_time"] {
|
||||||
<link href="/css/watch-util.css?v=9893448" rel=stylesheet>
|
<link href="/css/watch-util.css?v=9893448" rel=stylesheet>
|
||||||
<link href="/css/watch-navbar.css?v=9893448" rel=stylesheet>
|
<link href="/css/watch-navbar.css?v=9893448" rel=stylesheet>
|
||||||
<link href="/css/poketube.css?v=948934774844" rel=stylesheet>
|
<link href="/css/poketube.css?v=948934774844" rel=stylesheet>
|
||||||
|
<link href="https://vjs.zencdn.net/7.15.4/video-js.css" rel="stylesheet" />
|
||||||
|
<script src="https://vjs.zencdn.net/7.15.4/video.min.js"></script>
|
||||||
|
|
||||||
<!-- css files end -->
|
<!-- css files end -->
|
||||||
|
|
||||||
<% if (k.Video.Channel.Name == "7clouds") { %>
|
<% if (k.Video.Channel.Name == "7clouds") { %>
|
||||||
|
@ -395,6 +398,9 @@ a[data-onclick="jump_to_time"] {
|
||||||
|
|
||||||
<link href="<%- proxyurl %>/https://cdn.jsdelivr.net/npm/ionicons@4.5.0-0/dist/css/ionicons.min.css" rel=stylesheet>
|
<link href="<%- proxyurl %>/https://cdn.jsdelivr.net/npm/ionicons@4.5.0-0/dist/css/ionicons.min.css" rel=stylesheet>
|
||||||
|
|
||||||
|
<link href="https://vjs.zencdn.net/7.15.4/video-js.css" rel="stylesheet" />
|
||||||
|
<script src="https://vjs.zencdn.net/7.15.4/video.min.js"></script>
|
||||||
|
|
||||||
|
|
||||||
<noscript>
|
<noscript>
|
||||||
<style>
|
<style>
|
||||||
|
@ -597,97 +603,7 @@ background-color: #0000;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
#controls {
|
|
||||||
display: flex;
|
|
||||||
visibility: hidden;
|
|
||||||
position: absolute;
|
|
||||||
bottom: 0;
|
|
||||||
margin-bottom: 70px !important;
|
|
||||||
margin: 0 20px;
|
|
||||||
width: 100%;
|
|
||||||
align-items:flex-end;
|
|
||||||
}
|
|
||||||
video:hover~#controls, #controls:hover {
|
|
||||||
visibility: visible;
|
|
||||||
}
|
|
||||||
.control-button {
|
|
||||||
width: 40px;
|
|
||||||
border-radius: 5px;
|
|
||||||
margin-bottom: 6px;
|
|
||||||
padding: 3px
|
|
||||||
}
|
|
||||||
.video-player-container {
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
.control-button svg {
|
|
||||||
fill: #c59cd0;
|
|
||||||
width: 40px;
|
|
||||||
margin-bottom: -6px;
|
|
||||||
}
|
|
||||||
#seekbar {
|
|
||||||
display: flex;
|
|
||||||
margin-left: 20px;
|
|
||||||
margin-right: 20px;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
input[id*="-slider"] {
|
|
||||||
flex-grow: 1;
|
|
||||||
-webkit-appearance: none;
|
|
||||||
appearance: none;
|
|
||||||
background: #ffffff;
|
|
||||||
border: 1px solid #000000;
|
|
||||||
margin-bottom: 23px;
|
|
||||||
cursor: pointer;
|
|
||||||
width: 0.5rem;
|
|
||||||
height: 5px !important;
|
|
||||||
display: block;
|
|
||||||
border-radius: 50px;
|
|
||||||
}
|
|
||||||
input[type=range]::-webkit-slider-thumb {
|
|
||||||
-webkit-appearance: none;
|
|
||||||
border: 1px solid #000000;
|
|
||||||
height: 21px;
|
|
||||||
width: 21px;
|
|
||||||
border-radius: 20px;
|
|
||||||
background: var(--div-gradient);
|
|
||||||
cursor: pointer;
|
|
||||||
box-shadow: 1px 1px 1px #000000, 0px 0px 1px #0d0d0d;
|
|
||||||
}
|
|
||||||
input[type=range]::-moz-range-thumb {
|
|
||||||
border: 1px solid #000000;
|
|
||||||
height: 21px;
|
|
||||||
width: 21px;
|
|
||||||
border-radius: 20px;
|
|
||||||
background: var(--div-gradient);
|
|
||||||
cursor: pointer;
|
|
||||||
box-shadow: 1px 1px 1px #000000, 0px 0px 1px #0d0d0d;
|
|
||||||
}
|
|
||||||
#timestamps {
|
|
||||||
margin-right: 40px;
|
|
||||||
text-shadow: 1px 1px 2px black;
|
|
||||||
}
|
|
||||||
html:fullscreen video {
|
|
||||||
display: block !important;
|
|
||||||
position: fixed !important;
|
|
||||||
top: 0 !important;
|
|
||||||
left: 0 !important;
|
|
||||||
width: 100vw !important;
|
|
||||||
height: 100vh !important;
|
|
||||||
z-index: 999999 !important;
|
|
||||||
}
|
|
||||||
html:fullscreen *:not(html, video, body, ptd-app-ejs, .app, .watch-page, .primary, .video-player-container, #popupMenu, #popupMenu *) {
|
|
||||||
visibility: hidden !important;
|
|
||||||
}
|
|
||||||
.error-card {
|
|
||||||
background-color: #823434aa;
|
|
||||||
margin: 30px;
|
|
||||||
padding: 5px 20px;
|
|
||||||
border: 2px solid red;
|
|
||||||
border-radius: 10px;
|
|
||||||
}
|
|
||||||
#buffer-failed-warning {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.rainbow-gradient {
|
.rainbow-gradient {
|
||||||
background: linear-gradient(to right, red, orange, yellow, green, blue, indigo, violet);
|
background: linear-gradient(to right, red, orange, yellow, green, blue, indigo, violet);
|
||||||
|
@ -696,360 +612,63 @@ background-color: #0000;
|
||||||
}
|
}
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
<noscript>
|
|
||||||
<style>
|
|
||||||
#controls {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</noscript>
|
|
||||||
<script>
|
<script>
|
||||||
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 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);
|
|
||||||
var minutes = Math.floor((seconds - (hours * 3600)) / 60);
|
|
||||||
var secs = Math.floor(seconds - (hours * 3600) - (minutes * 60));
|
|
||||||
if (hours === 0) {
|
|
||||||
var timeString = minutes.toString().padStart(2, '0') + ':' +
|
|
||||||
secs.toString().padStart(2, '0');
|
|
||||||
} else {
|
|
||||||
var timeString = hours.toString().padStart(2, '0') + ':' +
|
|
||||||
minutes.toString().padStart(2, '0') + ':' +
|
|
||||||
secs.toString().padStart(2, '0');
|
|
||||||
}
|
|
||||||
return timeString;
|
|
||||||
}
|
|
||||||
function cstsRemaining(totalTimeInSeconds, elapsedTimeInSeconds) {
|
|
||||||
var remainingSeconds = totalTimeInSeconds - elapsedTimeInSeconds;
|
|
||||||
var hours = Math.floor(remainingSeconds / 3600);
|
|
||||||
var minutes = Math.floor((remainingSeconds % 3600) / 60);
|
|
||||||
var secs = Math.floor(remainingSeconds % 60);
|
|
||||||
|
|
||||||
var timeString;
|
|
||||||
if (hours === 0) {
|
|
||||||
timeString = minutes.toString().padStart(2, '0') + ':' + secs.toString().padStart(2, '0');
|
|
||||||
} else {
|
|
||||||
timeString = hours.toString().padStart(2, '0') + ':' + minutes.toString().padStart(2, '0') + ':' + secs.toString().padStart(2, '0');
|
|
||||||
}
|
|
||||||
|
|
||||||
return '-' + timeString;
|
|
||||||
}
|
|
||||||
function showErrorCard(e) {
|
|
||||||
try {
|
|
||||||
switch (e.target.error.code) {
|
|
||||||
case e.target.error.MEDIA_ERR_ABORTED:
|
|
||||||
return;
|
|
||||||
break;
|
|
||||||
case e.target.error.MEDIA_ERR_NETWORK:
|
|
||||||
document.querySelector("div p span").innerText = "(Network error)"
|
|
||||||
break;
|
|
||||||
case e.target.error.MEDIA_ERR_DECODE:
|
|
||||||
document.querySelector("div p span").innerText = "(Decode error/lack of browser support)"
|
|
||||||
break;
|
|
||||||
case e.target.error.MEDIA_ERR_SRC_NOT_SUPPORTED:
|
|
||||||
document.querySelector("div p span").innerText = "(Network error or format not supported)"
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
document.querySelector("div p span").innerText = "(Unknown error)"
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch {
|
|
||||||
document.querySelector("div p span").innerText = "(Network error)"
|
|
||||||
}
|
|
||||||
document.getElementById("buffer-failed-warning").style.display = "block";
|
|
||||||
}
|
|
||||||
let canPlayPause = true;
|
|
||||||
let didFirstTimePlay = false;
|
|
||||||
document.addEventListener("DOMContentLoaded", () => {
|
document.addEventListener("DOMContentLoaded", () => {
|
||||||
setInterval(()=>{
|
const video = videojs('video', {
|
||||||
if(!document.getElementById("video").paused) {
|
controls: true,
|
||||||
document.getElementById("play-pause").innerHTML = pauseSVG;
|
autoplay: false,
|
||||||
|
preload: 'auto'
|
||||||
}
|
|
||||||
else {
|
|
||||||
aud.pause()
|
|
||||||
document.getElementById("play-pause").innerHTML = playSVG;
|
|
||||||
}
|
|
||||||
}, 100);
|
|
||||||
//FIXME: saved playback intentionally overwritten
|
|
||||||
localStorage.setItem(`progress-${new URLSearchParams(window.location.search).get('v')}`, 0);
|
|
||||||
// Controls and high-res playback
|
|
||||||
//TODO - a
|
|
||||||
let setTime = false
|
|
||||||
const seekbar = document.getElementById("duration-slider")
|
|
||||||
const video = document.getElementById("video");
|
|
||||||
let shouldUseRemaining = false;
|
|
||||||
const timestamps = document.getElementById("timestamps");
|
|
||||||
video.addEventListener("timeupdate", (event) => {
|
|
||||||
seekbar.value = event.target.currentTime;
|
|
||||||
timestamps.innerText = shouldUseRemaining ? `${cstsRemaining(video.duration, video.currentTime)}/${csts(video.duration)}` : `${csts(video.currentTime)}/${csts(video.duration)}`;
|
|
||||||
});
|
|
||||||
timestamps.addEventListener("mouseover", () => {
|
|
||||||
shouldUseRemaining = true;
|
|
||||||
timestamps.innerText = `${cstsRemaining(video.duration, video.currentTime)}/${csts(video.duration)}`;
|
|
||||||
});
|
|
||||||
timestamps.addEventListener("mouseout", () => {
|
|
||||||
shouldUseRemaining = false;
|
|
||||||
timestamps.innerText = `${csts(video.currentTime)}/${csts(video.duration)}`;
|
|
||||||
});
|
|
||||||
// test
|
|
||||||
|
|
||||||
seekbar.addEventListener("input", (event) => {
|
|
||||||
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)
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Play/Pause
|
const audio = document.getElementById('aud');
|
||||||
|
|
||||||
const playPauseButton = document.getElementById("play-pause");
|
// Sync audio with video
|
||||||
playPauseButton.innerHTML = pauseSVG;
|
const syncAudioWithVideo = () => {
|
||||||
function toggleVideo() {
|
if (Math.abs(video.currentTime() - audio.currentTime) > 0.3) {
|
||||||
if(!canPlayPause) return;
|
audio.currentTime = video.currentTime();
|
||||||
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
|
const syncVolume = () => {
|
||||||
try {
|
audio.volume = video.volume();
|
||||||
playPauseButton.innerHTML = pauseSVG;
|
};
|
||||||
vid.play();
|
|
||||||
aud.play();
|
|
||||||
didFirstTimePlay = true;
|
|
||||||
|
|
||||||
}
|
const syncVolumeWithVideo = () => {
|
||||||
catch {}
|
video.volume(audio.volume);
|
||||||
|
};
|
||||||
|
|
||||||
if(!setTime) {
|
video.on('play', () => {
|
||||||
//FIXME: saved playback intentionally overwritten
|
audio.play();
|
||||||
aud.currentTime = 0
|
});
|
||||||
vid.currentTime = 0
|
|
||||||
seekbar.value = 0
|
video.on('pause', () => {
|
||||||
setTime = true
|
audio.pause();
|
||||||
}
|
});
|
||||||
setTimeout(()=>{
|
|
||||||
video.addEventListener("seeking", (event) => {
|
video.on('timeupdate', () => {
|
||||||
if(!didFirstTimePlay) return;
|
syncAudioWithVideo();
|
||||||
if(qua != "medium") {
|
});
|
||||||
video.pause()
|
|
||||||
canPlayPause = false;
|
video.on('seeking', () => {
|
||||||
aud.pause()
|
audio.currentTime = video.currentTime();
|
||||||
aud.currentTime = event.target.currentTime
|
});
|
||||||
|
|
||||||
|
video.on('seeked', () => {
|
||||||
|
audio.currentTime = video.currentTime();
|
||||||
|
});
|
||||||
|
|
||||||
|
video.on('volumechange', syncVolume);
|
||||||
|
audio.addEventListener('volumechange', syncVolumeWithVideo);
|
||||||
|
|
||||||
|
document.addEventListener('fullscreenchange', () => {
|
||||||
|
if (!document.fullscreenElement) {
|
||||||
|
video.pause();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}, 500)
|
});
|
||||||
}
|
|
||||||
const aud = document.getElementById("aud");
|
|
||||||
const vid = document.getElementById("video");
|
|
||||||
function shouldPlay() {
|
|
||||||
if(vid.readyState === HTMLMediaElement.HAVE_ENOUGH_DATA) {
|
|
||||||
startPlayback();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
aud.addEventListener("canplaythrough", shouldPlay);
|
|
||||||
vid.addEventListener("canplaythrough", shouldPlay);
|
|
||||||
})
|
|
||||||
</script>
|
</script>
|
||||||
<% if(shortsui) { %>
|
|
||||||
<script>
|
|
||||||
// Function to apply styles after DOM has loaded
|
|
||||||
function applyStyles() {
|
|
||||||
const styles = `
|
|
||||||
.player {
|
|
||||||
width: fit-content;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
height: fit-content;
|
|
||||||
}
|
|
||||||
|
|
||||||
.video-player-container {
|
|
||||||
max-width: fit-content;
|
|
||||||
min-width: fit-content;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
aspect-ratio: var(--ptd-watch-width-ratio) / var(--ptd-watch-height-ratio);
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
|
|
||||||
// Create a style element and set its content
|
|
||||||
const styleElement = document.createElement('style');
|
|
||||||
styleElement.innerHTML = styles;
|
|
||||||
|
|
||||||
// Append the style element to the document head
|
|
||||||
document.head.appendChild(styleElement);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Event listener to call applyStyles after DOM has loaded
|
|
||||||
window.onload = applyStyles;
|
|
||||||
</script>
|
|
||||||
<% } %>
|
|
||||||
|
|
||||||
<% if (inv_vid.author.endsWith(' - Topic')) { %>
|
|
||||||
<script>
|
|
||||||
// Function to apply styles after DOM has loaded
|
|
||||||
function applyStyles() {
|
|
||||||
const styles = `
|
|
||||||
.player {
|
|
||||||
width: fit-content;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
height: fit-content;
|
|
||||||
}
|
|
||||||
|
|
||||||
.video-player-container {
|
|
||||||
max-width: fit-content;
|
|
||||||
min-width: fit-content;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
aspect-ratio: var(--ptd-watch-width-ratio) / var(--ptd-watch-height-ratio);
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
|
|
||||||
// Create a style element and set its content
|
|
||||||
const styleElement = document.createElement('style');
|
|
||||||
styleElement.innerHTML = styles;
|
|
||||||
|
|
||||||
// Append the style element to the document head
|
|
||||||
document.head.appendChild(styleElement);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Event listener to call applyStyles after DOM has loaded
|
|
||||||
window.onload = applyStyles;
|
|
||||||
</script>
|
|
||||||
<% } %>
|
|
||||||
<% if(dm) { %>
|
<% if(dm) { %>
|
||||||
|
|
||||||
|
|
||||||
|
@ -1427,15 +1046,7 @@ Offical Discord Server! :3
|
||||||
</div>
|
</div>
|
||||||
<% } %>
|
<% } %>
|
||||||
</noscript>
|
</noscript>
|
||||||
<div id="buffer-failed-warning" class="error-card">
|
|
||||||
<p>
|
|
||||||
Oh no, the video couldn't be loaded :(
|
|
||||||
<br/>
|
|
||||||
You can try refreshing the page!
|
|
||||||
<br/>
|
|
||||||
<span></span>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
<video class="player video-ambient-container" id="video" style="border-radius: 16px; box-sizing: border-box; min-width: 100%; display: block;" autoplay preload onerror="showErrorCard(event)">
|
<video class="player video-ambient-container" id="video" style="border-radius: 16px; box-sizing: border-box; min-width: 100%; display: block;" autoplay preload onerror="showErrorCard(event)">
|
||||||
<% if (isvidious) { %>
|
<% if (isvidious) { %>
|
||||||
<% if (!qua) { %>
|
<% if (!qua) { %>
|
||||||
|
@ -1484,21 +1095,6 @@ Offical Discord Server! :3
|
||||||
<track src="/api/subtitles?v=<%=inv_vid.videoId%>&h=<%= %>" label="<%= video.Subtitles.Subtitle.language.replace("United States","Simplified - USA") %>" kind="subtitles">
|
<track src="/api/subtitles?v=<%=inv_vid.videoId%>&h=<%= %>" label="<%= video.Subtitles.Subtitle.language.replace("United States","Simplified - USA") %>" kind="subtitles">
|
||||||
<% } %>
|
<% } %>
|
||||||
</video>
|
</video>
|
||||||
<div id="controls"> <!-- TODO: CONTROLS -->
|
|
||||||
<button id="play-pause" class="control-button">
|
|
||||||
<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>
|
|
||||||
</button>
|
|
||||||
|
|
||||||
<div id="seekbar">
|
|
||||||
<input type="range" min="0" step="any" value="0" id="duration-slider">
|
|
||||||
</div>
|
|
||||||
<p id="timestamps">...</p>
|
|
||||||
<!--
|
|
||||||
<div>
|
|
||||||
<span>volume</span>
|
|
||||||
<input type="range" min="0" max="1" step="any" value="1" id="volume-slider">
|
|
||||||
</div>
|
|
||||||
-->
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<% if (!a) { %>
|
<% if (!a) { %>
|
||||||
|
|
Loading…
Reference in a new issue