feat: youtube ad skip
This commit is contained in:
@@ -65,23 +65,44 @@ class YouTubeCaptionProvider {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get #videoEl() {
|
||||||
|
return document.querySelector(VIDEO_SELECT);
|
||||||
|
}
|
||||||
|
|
||||||
#moAds(adContainer) {
|
#moAds(adContainer) {
|
||||||
const adSlector = ".ytp-ad-player-overlay-layout";
|
const adLayout = ".ytp-ad-player-overlay-layout";
|
||||||
|
const skipBtn =
|
||||||
|
".ytp-skip-ad-button, .ytp-ad-skip-button, .ytp-ad-skip-button-modern";
|
||||||
const observer = new MutationObserver((mutations) => {
|
const observer = new MutationObserver((mutations) => {
|
||||||
for (const mutation of mutations) {
|
for (const mutation of mutations) {
|
||||||
if (mutation.type === "childList") {
|
if (mutation.type === "childList") {
|
||||||
|
const videoEl = this.#videoEl;
|
||||||
mutation.addedNodes.forEach((node) => {
|
mutation.addedNodes.forEach((node) => {
|
||||||
if (node.nodeType === 1 && node.matches(adSlector)) {
|
if (node.nodeType !== Node.ELEMENT_NODE) return;
|
||||||
|
|
||||||
|
if (node.matches(adLayout)) {
|
||||||
logger.debug("Youtube Provider: AD start playing!", node);
|
logger.debug("Youtube Provider: AD start playing!", node);
|
||||||
// todo: 顺带把广告快速跳过
|
// todo: 顺带把广告快速跳过
|
||||||
|
if (videoEl) {
|
||||||
|
videoEl.playbackRate = 16;
|
||||||
|
videoEl.currentTime = videoEl.duration;
|
||||||
|
}
|
||||||
if (this.#managerInstance) {
|
if (this.#managerInstance) {
|
||||||
this.#managerInstance.setIsAdPlaying(true);
|
this.#managerInstance.setIsAdPlaying(true);
|
||||||
}
|
}
|
||||||
|
} else if (node.matches(skipBtn)) {
|
||||||
|
logger.debug("Youtube Provider: AD skip button!", node);
|
||||||
|
node.click();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
mutation.removedNodes.forEach((node) => {
|
mutation.removedNodes.forEach((node) => {
|
||||||
if (node.nodeType === 1 && node.matches(adSlector)) {
|
if (node.nodeType !== Node.ELEMENT_NODE) return;
|
||||||
|
|
||||||
|
if (node.matches(adLayout)) {
|
||||||
logger.debug("Youtube Provider: Ad ends!");
|
logger.debug("Youtube Provider: Ad ends!");
|
||||||
|
if (videoEl) {
|
||||||
|
videoEl.playbackRate = 1;
|
||||||
|
}
|
||||||
if (this.#managerInstance) {
|
if (this.#managerInstance) {
|
||||||
this.#managerInstance.setIsAdPlaying(false);
|
this.#managerInstance.setIsAdPlaying(false);
|
||||||
}
|
}
|
||||||
@@ -467,7 +488,7 @@ class YouTubeCaptionProvider {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const videoEl = document.querySelector(VIDEO_SELECT);
|
const videoEl = this.#videoEl;
|
||||||
if (!videoEl) {
|
if (!videoEl) {
|
||||||
logger.warn("Youtube Provider: No video element found");
|
logger.warn("Youtube Provider: No video element found");
|
||||||
return;
|
return;
|
||||||
@@ -878,7 +899,7 @@ class YouTubeCaptionProvider {
|
|||||||
textAlign: "center",
|
textAlign: "center",
|
||||||
});
|
});
|
||||||
|
|
||||||
const videoEl = document.querySelector(VIDEO_SELECT);
|
const videoEl = this.#videoEl;
|
||||||
const videoContainer = videoEl?.parentElement?.parentElement;
|
const videoContainer = videoEl?.parentElement?.parentElement;
|
||||||
if (videoContainer) {
|
if (videoContainer) {
|
||||||
videoContainer.appendChild(notificationEl);
|
videoContainer.appendChild(notificationEl);
|
||||||
|
|||||||
Reference in New Issue
Block a user