您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Adds buttons to hide watched and/or upcoming videos from the subscription page / channel videos tab.
当前为
// ==UserScript== // @name YouTube - Hide videos buttons // @description Adds buttons to hide watched and/or upcoming videos from the subscription page / channel videos tab. // @version 2023.03.07.00.14 // @author MetalTxus // @namespace https://github.com/jesuscc1993 // @icon https://www.youtube.com/favicon.ico // @match *://*.youtube.com/* // @require https://code.jquery.com/jquery-3.2.1.min.js // ==/UserScript== /* globals jQuery */ (() => { 'use strict'; let hideWatchedButton, hideBothButton, hideUpcomingButton, buttonContainer; const shouldRender = () => { return location.href.match(urlPattern) !== null; } const watchedVideosSelector = '[id="progress"]'; const upcomingVideosSelector = '[overlay-style="UPCOMING"]'; const hideBothVideos = () => { hideVideos(`${watchedVideosSelector}, ${upcomingVideosSelector}`, hideBothButton, `Hide both (-{ matchingVideos }/{ totalCount })`); }; const hideWatchedVideos = () => { hideVideos(watchedVideosSelector, hideWatchedButton, `Hide watched (-{ matchingVideos }/{ totalCount })`); }; const hideUpcomingVideos = () => { hideVideos(upcomingVideosSelector, hideUpcomingButton, `Hide upcoming (-{ matchingVideos }/{ totalCount })`); }; const hideVideos = (matchingSelector, button, text) => { const matchingVideos = jQuery(matchingSelector).parents(videosSelector); matchingVideos.css('display', 'none'); const matchingVideosCount = matchingVideos.length; const totalVideoCount = jQuery(videosSelector).length; button.text(text .replace(/\{\s*matchingVideos\s*\}/g, matchingVideosCount) .replace(/\{\s*totalCount\s*\}/g, totalVideoCount)); }; const handleButtonPresence = () => { if (shouldRender()) { const destinationElement = jQuery(destinationElementSelector).first(); if (destinationElement.length && !destinationElement.find(buttonContainer).length) { insertButtons(destinationElement); } } else { buttonContainer.remove(); } }; const insertButtons = (destinationElement) => { hideBothButton.off('click').on('click', hideBothVideos).text('Hide both'); hideWatchedButton.off('click').on('click', hideWatchedVideos).text('Hide watched'); hideUpcomingButton.off('click').on('click', hideUpcomingVideos).text('Hide upcoming'); destinationElement.prepend(buttonContainer); } const initialize = () => { jQuery('head').append(style); buttonContainer = jQuery(`<div class="mt-hide-videos-container"></div>`); hideBothButton = jQuery(buttonTemplate); hideWatchedButton = jQuery(buttonTemplate); hideUpcomingButton = jQuery(buttonTemplate); buttonContainer.append(hideWatchedButton); buttonContainer.append(hideBothButton); buttonContainer.append(hideUpcomingButton); setInterval(handleButtonPresence, 150); } const destinationElementSelector = ` [page-subtype="channels"][role="main"] ytd-rich-grid-renderer, [page-subtype="playlist"][role="main"] ytd-item-section-renderer, [page-subtype="subscriptions"][role="main"] ytd-section-list-renderer, ytd-search[role="main"] ytd-section-list-renderer `; const videosSelector = ` [page-subtype="channels"][role="main"] ytd-rich-item-renderer, [page-subtype="playlist"][role="main"] ytd-playlist-video-renderer, [page-subtype="subscriptions"][role="main"] ytd-grid-video-renderer, ytd-search[role="main"] ytd-video-renderer `; const style = ` <style> .mt-hide-videos-container { display: flex; width: 100%; } .mt-hide-videos-button { border-radius: 8px !important; flex: 1; } [page-subtype="channels"] .mt-hide-videos-container, [page-subtype="subscriptions"] .mt-hide-videos-container { margin-top: 24px; } .ytd-search ytd-section-list-renderer .mt-hide-videos-container { margin: 12px 0; } </style> ` const buttonTemplate = ` <tp-yt-paper-button class="style-scope ytd-subscribe-button-renderer mt-hide-videos-button" /> `; const urlPattern = /youtube.com\/((channel\/|c\/|@)(.*)\/videos|feed\/subscriptions|results|playlist)/; initialize(); })();