From 4927226a3ec612577631b506e04ad559eb9f801e Mon Sep 17 00:00:00 2001 From: Emilien Devos <4016501+unixfox@users.noreply.github.com> Date: Mon, 19 Feb 2024 23:59:35 +0100 Subject: [PATCH] initial working version --- assets/css/player.css | 4 +-- assets/js/player.js | 24 ++++++++++++---- src/invidious/routes/api/manifest.cr | 2 +- .../views/components/player_sources.ecr | 5 +--- videojs-dependencies.yml | 28 +++++++++---------- 5 files changed, 37 insertions(+), 26 deletions(-) diff --git a/assets/css/player.css b/assets/css/player.css index 50c7a74875..cdfbdf7fef 100644 --- a/assets/css/player.css +++ b/assets/css/player.css @@ -106,7 +106,7 @@ ul.vjs-menu-content::-webkit-scrollbar { } .vjs-quality-selector, -.video-js .vjs-http-source-selector { +.video-js .vjs-quality-menu-wrapper { order: 4; } @@ -218,7 +218,7 @@ ul.vjs-menu-content::-webkit-scrollbar { } .player-dimensions.vjs-fluid { - padding-top: 82vh; + padding-top: 82vh !important; } video.video-js { diff --git a/assets/js/player.js b/assets/js/player.js index 71c5e7da85..7c0273fab6 100644 --- a/assets/js/player.js +++ b/assets/js/player.js @@ -5,6 +5,7 @@ var video_data = JSON.parse(document.getElementById('video_data').textContent); var options = { preload: 'auto', liveui: true, + fill: false, playbackRates: [0.25, 0.5, 0.75, 1.0, 1.25, 1.5, 1.75, 2.0], controlBar: { children: [ @@ -19,6 +20,7 @@ var options = { 'captionsButton', 'audioTrackButton', 'qualitySelector', + 'QualityMenuButton', 'playbackRateMenuButton', 'fullscreenToggle' ] @@ -157,6 +159,16 @@ player.on('timeupdate', function () { elem_iv_other.href = addCurrentTimeToURL(base_url_iv_other, domain); }); +player.one('playing', function () { + + if (!video_data.params.listen && video_data.params.quality === 'dash') { + var quality_menu_button = document.getElementsByClassName('vjs-quality-menu-button'); + for (var i = 0; i < quality_menu_button.length; i++) { + quality_menu_button[i].className += ' vjs-icon-cog'; + } + } +}); + var shareOptions = { socials: ['fbFeed', 'tw', 'reddit', 'email'], @@ -226,8 +238,9 @@ if (isMobile()) { operations_bar_element.append(share_element); if (!video_data.params.listen && video_data.params.quality === 'dash') { - var http_source_selector = document.getElementsByClassName('vjs-http-source-selector vjs-menu-button')[0]; + var http_source_selector = document.getElementsByClassName('vjs-quality-menu-button vjs-menu-button')[0]; operations_bar_element.append(http_source_selector); + } }); } @@ -386,7 +399,7 @@ if (video_data.params.autoplay) { } if (!video_data.params.listen && video_data.params.quality === 'dash') { - player.httpSourceSelector(); + var qualityMenuOptions = {} if (video_data.params.quality_dash !== 'auto') { player.ready(function () { @@ -409,12 +422,13 @@ if (!video_data.params.listen && video_data.params.quality === 'dash') { break; } } - qualityLevels.forEach(function (level, index) { - level.enabled = (index === targetQualityLevel); - }); + qualityMenuOptions.defaultResolution = (qualityLevels[targetQualityLevel].height + "p"); }); }); } + + console.log(qualityMenuOptions) + player.qualityMenu(qualityMenuOptions); } player.vttThumbnails({ diff --git a/src/invidious/routes/api/manifest.cr b/src/invidious/routes/api/manifest.cr index 662d1002f1..65a6877d20 100644 --- a/src/invidious/routes/api/manifest.cr +++ b/src/invidious/routes/api/manifest.cr @@ -76,7 +76,7 @@ module Invidious::Routes::API::Manifest xml.element("Role", schemeIdUri: "urn:mpeg:dash:role:2011", value: i == 0 ? "main" : "alternate") - xml.element("Representation", id: fmt["itag"], codecs: codecs, bandwidth: bandwidth) do + xml.element("Representation", id: fmt["itag"].as_i + rand(100), codecs: codecs, bandwidth: bandwidth) do xml.element("AudioChannelConfiguration", schemeIdUri: "urn:mpeg:dash:23003:3:audio_channel_configuration:2011", value: "2") xml.element("BaseURL") { xml.text url } diff --git a/src/invidious/views/components/player_sources.ecr b/src/invidious/views/components/player_sources.ecr index 9af3899c4d..ae3c92e450 100644 --- a/src/invidious/views/components/player_sources.ecr +++ b/src/invidious/views/components/player_sources.ecr @@ -1,7 +1,5 @@ - - @@ -9,9 +7,8 @@ - + - diff --git a/videojs-dependencies.yml b/videojs-dependencies.yml index e9ccc9dde5..4a1fa7da5d 100644 --- a/videojs-dependencies.yml +++ b/videojs-dependencies.yml @@ -1,35 +1,35 @@ -# Due to a 'video append of' error (see #3011), we're stuck on 7.12.1. +# find the checksum of latest version using npm view package video.js: - version: 7.12.1 - shasum: 1d12eeb1f52e3679e8e4c987d9b9eb37e2247fa2 + version: 8.10.0 + shasum: 603a49909ef33f839264da8b73513f9daf592b57 videojs-contrib-quality-levels: - version: 2.1.0 - shasum: 046e9e21ed01043f512b83a1916001d552457083 + version: 4.0.0 + shasum: faa8096594cdbfc3ccbefe8572fc20531ba23f3d -videojs-http-source-selector: - version: 1.1.6 - shasum: 073aadbea0106ba6c98d6b611094dbf8554ffa1f +videojs-contrib-quality-menu: + version: 1.0.0 + shasum: f5e8f855358e20854de23d7607634b5aabf4e9ac videojs-markers: version: 1.0.1 shasum: d7f8d804253fd587813271f8db308a22b9f7df34 videojs-mobile-ui: - version: 0.6.1 - shasum: 0e146c4c481cbee0729cb5e162e558b455562cd0 + version: 1.1.1 + shasum: 6b5e75df36cf688906b3662070399b23da9e8e06 videojs-overlay: - version: 2.1.4 - shasum: 5a103b25374dbb753eb87960d8360c2e8f39cc05 + version: 3.1.0 + shasum: d57505d375eca952feeb36e5b33e0a130e3dc9e0 videojs-share: version: 3.2.1 shasum: 0a3024b981387b9d21c058c829760a72c14b8ceb videojs-vr: - version: 1.8.0 - shasum: 7f2f07f760d8a329c615acd316e49da6ee8edd34 + version: 2.0.0 + shasum: 3d86e3fececf7373cfb89b950ed6ab77ca783d2b videojs-vtt-thumbnails: version: 0.0.13