From 9d5a6551a7eb54b67f3a61ead9437333f3f3c901 Mon Sep 17 00:00:00 2001 From: Particle Date: Sat, 13 Apr 2024 13:59:14 -0400 Subject: [PATCH] Closes #975 Closes #976 --- src/chrome/js/background-inject.js | 56 +++++++++++++++++++++-------- src/firefox/js/background-inject.js | 56 +++++++++++++++++++++-------- 2 files changed, 82 insertions(+), 30 deletions(-) diff --git a/src/chrome/js/background-inject.js b/src/chrome/js/background-inject.js index 079a0cd..e4868a1 100644 --- a/src/chrome/js/background-inject.js +++ b/src/chrome/js/background-inject.js @@ -466,19 +466,44 @@ function mainScript(extensionId, SettingData, defaultSettings) { })(); - const OverrideOnYouTubePlayerReady = (() => { + const OverrideOnPlayerReady = (() => { const listeners = []; + const onPlayerReadyEventKey = crypto.randomUUID(); + let recentApi = null; - window.onYouTubePlayerReady = (function (original) { - return function (api) { - listeners?.forEach(listener => listener?.(api)); - original?.apply(this, arguments); - }; - }(window.onYouTubePlayerReady)); + Object.defineProperty(Object.prototype, "onPlayerReadyEvent_", { + set(data) { + this[onPlayerReadyEventKey] = data; + }, + get() { + + const original = this[onPlayerReadyEventKey]; + + if (original.constructor === Boolean) { + return original + } + + return function (api) { + recentApi = api; + listeners?.forEach(listener => listener?.(api)); + return original?.apply(this, arguments); + } + } + }); + + function addListener(listener) { + + if (recentApi) { + listener(recentApi) + } + + listeners.push(listener) + + } return { - onReadyListener: listener => listeners.push(listener) + onReadyListener: listener => addListener(listener) }; })(); @@ -1020,10 +1045,11 @@ function mainScript(extensionId, SettingData, defaultSettings) { } else { + const masthead = document.getElementById("masthead-container"); const moviePlayerParent = document.getElementById("movie_player")?.parentElement; - if (moviePlayerParent) { - moviePlayerParent.style.width = ""; + if (masthead) { + masthead.style.width = ""; } const chat = document.getElementById("chat-container"); @@ -1075,7 +1101,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { FeatureUpdater.register(SettingData.superTheater.id, update); - OverrideOnYouTubePlayerReady.onReadyListener(created); + OverrideOnPlayerReady.onReadyListener(created); return {}; @@ -1460,7 +1486,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { FeatureUpdater.register(SettingData.videoFocusToggle.id, update); FeatureUpdater.register(SettingData.videoFocus.id, update); - OverrideOnYouTubePlayerReady.onReadyListener(onCreated); + OverrideOnPlayerReady.onReadyListener(onCreated); return { check: check @@ -1801,7 +1827,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { }) - OverrideOnYouTubePlayerReady.onReadyListener(onCreated); + OverrideOnPlayerReady.onReadyListener(onCreated); return {}; @@ -1859,7 +1885,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { } }); - OverrideOnYouTubePlayerReady.onReadyListener(onCreated); + OverrideOnPlayerReady.onReadyListener(onCreated); return {}; @@ -1873,7 +1899,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { } }); - OverrideOnYouTubePlayerReady.onReadyListener(onCreated); + OverrideOnPlayerReady.onReadyListener(onCreated); return {}; diff --git a/src/firefox/js/background-inject.js b/src/firefox/js/background-inject.js index 079a0cd..e4868a1 100644 --- a/src/firefox/js/background-inject.js +++ b/src/firefox/js/background-inject.js @@ -466,19 +466,44 @@ function mainScript(extensionId, SettingData, defaultSettings) { })(); - const OverrideOnYouTubePlayerReady = (() => { + const OverrideOnPlayerReady = (() => { const listeners = []; + const onPlayerReadyEventKey = crypto.randomUUID(); + let recentApi = null; - window.onYouTubePlayerReady = (function (original) { - return function (api) { - listeners?.forEach(listener => listener?.(api)); - original?.apply(this, arguments); - }; - }(window.onYouTubePlayerReady)); + Object.defineProperty(Object.prototype, "onPlayerReadyEvent_", { + set(data) { + this[onPlayerReadyEventKey] = data; + }, + get() { + + const original = this[onPlayerReadyEventKey]; + + if (original.constructor === Boolean) { + return original + } + + return function (api) { + recentApi = api; + listeners?.forEach(listener => listener?.(api)); + return original?.apply(this, arguments); + } + } + }); + + function addListener(listener) { + + if (recentApi) { + listener(recentApi) + } + + listeners.push(listener) + + } return { - onReadyListener: listener => listeners.push(listener) + onReadyListener: listener => addListener(listener) }; })(); @@ -1020,10 +1045,11 @@ function mainScript(extensionId, SettingData, defaultSettings) { } else { + const masthead = document.getElementById("masthead-container"); const moviePlayerParent = document.getElementById("movie_player")?.parentElement; - if (moviePlayerParent) { - moviePlayerParent.style.width = ""; + if (masthead) { + masthead.style.width = ""; } const chat = document.getElementById("chat-container"); @@ -1075,7 +1101,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { FeatureUpdater.register(SettingData.superTheater.id, update); - OverrideOnYouTubePlayerReady.onReadyListener(created); + OverrideOnPlayerReady.onReadyListener(created); return {}; @@ -1460,7 +1486,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { FeatureUpdater.register(SettingData.videoFocusToggle.id, update); FeatureUpdater.register(SettingData.videoFocus.id, update); - OverrideOnYouTubePlayerReady.onReadyListener(onCreated); + OverrideOnPlayerReady.onReadyListener(onCreated); return { check: check @@ -1801,7 +1827,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { }) - OverrideOnYouTubePlayerReady.onReadyListener(onCreated); + OverrideOnPlayerReady.onReadyListener(onCreated); return {}; @@ -1859,7 +1885,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { } }); - OverrideOnYouTubePlayerReady.onReadyListener(onCreated); + OverrideOnPlayerReady.onReadyListener(onCreated); return {}; @@ -1873,7 +1899,7 @@ function mainScript(extensionId, SettingData, defaultSettings) { } }); - OverrideOnYouTubePlayerReady.onReadyListener(onCreated); + OverrideOnPlayerReady.onReadyListener(onCreated); return {};