YouTube - Hide Watched

YouTube - Hide Watched.

目前為 2022-09-17 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         YouTube - Hide Watched
// @description  YouTube - Hide Watched.
// @version      0.1
// @author       to
// @namespace    https://github.com/to
// @license      MIT
// 
// @match        https://www.youtube.com/feed/subscriptions
// @icon         https://www.google.com/s2/favicons?sz=64&domain=youtube.com
// 
// @run-at       document-idle
// ==/UserScript==

const THRESHOLD = 90;

new MutationObserver(throttleAndDebounce(() => {
	for (let progress of document.querySelectorAll('#progress')) {
		if (parseInt(progress.style.width) > THRESHOLD) {
			let video = progress.closest('ytd-grid-video-renderer');
			video.classList.add('tm-watched')
			video.style.display = 'none';
		}
	}
}, 1000)).observe(document.body, {
	childList: true,
	subtree: true,
});


function throttleAndDebounce(fn, interval) {
	let timer;
	let lastTime = Date.now() - interval;
	return function () {
		if ((Date.now() - lastTime) > interval) {
			lastTime = Date.now();
			fn();
		} else {
			clearTimeout(timer);
			timer = setTimeout(() => {
				fn();
			}, interval);
		}
	}
}