Youtube watched hider

Hide already watched (progress bar at 100%) video on user's, channel's and subscriptions' pages

当前为 2018-08-21 提交的版本,查看 最新版本

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         Youtube watched hider
// @namespace    http://joshuaarus.fr
// @version      0.6
// @description  Hide already watched (progress bar at 100%) video on user's, channel's and subscriptions' pages
// @author       Arus Joshua
// @match        https://www.youtube.com/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // CONSTANTS

    var IMG_GRAY = "";
    var IMG_WHITE = "";
    var IMG_RED = "";

    var IMG_TO_UPDATE = null;
    var COOKIE_NAME = "";
    var HIDE = false;
    var CURRENT_URL = null;
    var CURRENT_PAGE = null;
    var PAGES = [
        {
            regex: /https:\/\/www\.youtube\.com\/(?:user|channel)\/([^\/]*)(\/.*)?/g,
            displayStyle: "inline-block",
            querySelector: "ytd-grid-video-renderer"
        },
        {
            regex: /https:\/\/www\.youtube\.com\/feed\/history/g,
            displayStyle: "flex",
            cookieName: "history",
            querySelector: "ytd-video-renderer"
        },
        {
            regex: /https:\/\/www\.youtube\.com\/feed\/trending/g,
            displayStyle: "block",
            cookieName: "trending",
            querySelector: "ytd-video-renderer"
        },
        {
            regex: /https:\/\/www\.youtube\.com\/feed\/subscriptions/g,
            displayStyle: "inline-block",
            cookieName: "subscriptions",
            querySelector: "ytd-grid-video-renderer"
        },
        {
            regex: /https:\/\/www\.youtube\.com\/?$/g,
            displayStyle: "inline-block",
            cookieName: "home",
            querySelector: "ytd-grid-video-renderer"
        },
        {
            regex: /https:\/\/www\.youtube\.com\/playlist\?list=(.*)/g,
            displayStyle: "flex",
            querySelector: "ytd-playlist-video-renderer"
        },
        {
            regex: /https:\/\/www\.youtube\.com\/results\?search_query=(.*)/g,
            displayStyle: "bloc",
            querySelector: "ytd-video-renderer"
        },
        {
            regex: /https:\/\/www\.youtube\.com\/watch\?.*/g,
            displayStyle: "inline-block",
            cookieName: "watch",
            querySelector: "ytd-compact-video-renderer"
        }
    ];



    // FUNCTIONS

    var setCookie = function(cvalue) {
        var d = new Date();
        d.setTime(d.getTime() + (60 * 24 * 60 * 60 * 1000));
        var expires = "expires="+d.toUTCString();
        document.cookie = COOKIE_NAME + "=" + cvalue + ";" + expires + ";path=/";
    }

    var getCookie = function() {
        var name = COOKIE_NAME + "=";
        var decodedCookie = decodeURIComponent(document.cookie);
        var ca = decodedCookie.split(';');
        for(var i = 0; i <ca.length; i++) {
            var c = ca[i];
            while (c.charAt(0) == ' ') {
                c = c.substring(1);
            }
            if (c.indexOf(name) === 0) {
                return c.substring(name.length, c.length);
            }
        }
        return "";
    }

    var isTheaterMode = function(){
        var masthead = document.querySelector("ytd-masthead");
        var res = masthead.hasAttribute("dark");
        return res;
    }

    var getButtonIcon = function() {
        return HIDE ? IMG_RED : (isTheaterMode() ? IMG_WHITE : IMG_GRAY);
    }

    var displayOrHide = function() {
        if (CURRENT_PAGE === null) {
            return;
        }

        document.querySelectorAll(CURRENT_PAGE.querySelector).forEach(function(element){
            var progressBar = element.getElementsByClassName("ytd-thumbnail-overlay-resume-playback-renderer");
            if (progressBar.length > 0)
            {
                var avancement = progressBar[0].style.width;
                if (HIDE && avancement == "100%")
                {
                    element.style.display = "none";
                } else {
                    element.style.display = CURRENT_PAGE.displayStyle;
                }
            }
        });
    };

    var addButton = function() {
        var img = document.createElement('img');
        img.id = "youtubeWatchedHiderImg";
        img.src = getButtonIcon();
        img.width = "20";
        img.height = "20";
        IMG_TO_UPDATE = img;

        var ytIcon = document.createElement("yt-icon");
        ytIcon.classList.add("guide-icon");
        ytIcon.classList.add("style-scope");
        ytIcon.classList.add("ytd-guide-entry-renderer");

        var ytIconButton = document.createElement("yt-icon-button");
        ytIconButton.classList.add("style-scope");
        ytIconButton.classList.add("ytd-topbar-menu-button-renderer");
        ytIconButton.classList.add("style-default");

        var aImg = document.createElement("a");
        aImg.href = "";
        aImg.onclick = function() {
            HIDE = !HIDE;
            setCookie(HIDE ? "true" : "false");
            displayOrHide();
            img.src = getButtonIcon();
            return false;
        }

        var divHide = document.createElement("ytd-topbar-menu-button-renderer");
        divHide.id = "youtubeWatchedHiderDiv";
        divHide.classList.add("style-scope");
        divHide.classList.add("ytd-masthead");
        divHide.classList.add("style-default");

        var buttonBar = document.getElementById("buttons");

        buttonBar.insertBefore(divHide, buttonBar.firstChild);
        divHide.querySelector("div").appendChild(aImg);
        aImg.appendChild(ytIconButton);
        ytIconButton.querySelector("button").appendChild(ytIcon);
        ytIcon.appendChild(img);
    };

    var init = function() {
        CURRENT_URL = window.location.href;
        CURRENT_PAGE = null;
        PAGES.some(function(page) {
            if (CURRENT_URL.match(page.regex)) {
                CURRENT_PAGE = page;
                return true;
            }
        });

        if (CURRENT_PAGE === null) {
            return;
        }

        COOKIE_NAME = "youtubeWatchedHiderCookie_" + (CURRENT_PAGE.cookieName !== undefined ? CURRENT_PAGE.cookieName : CURRENT_PAGE.regex.exec(CURRENT_URL)[1]);
        HIDE = getCookie() == "true";

        addButton();
    }


    // FUNCTION TO HANDLE THE CHANGE IN THEATER MODE IN WATCH PAGE

    setTimeout(function(){
        // Select the node that will be observed for mutations
        var targetNode = document.querySelector("ytd-masthead");
        // Options for the observer (which mutations to observe)
        var config = { attributes: true };

        // Callback function to execute when mutations are observed
        var callback = function(mutationsList) {
            IMG_TO_UPDATE.src = getButtonIcon();
        };

        // Create an observer instance linked to the callback function
        var observer = new MutationObserver(callback);

        // Start observing the target node for configured mutations
        observer.observe(targetNode, config);
    }, 1000);


	// AUTOMATIC UPDATE OF THE PAGE

    setInterval(function(){
        if (document.getElementById("youtubeWatchedHiderImg") == null) {
            init();
        }
        displayOrHide();
    }, 1000);

})();