// ==UserScript== // @name YouTube: Hide Watched Videos // @namespace http://www.globexdesigns.com/ // @version 0.5 // @description Hides watched videos from your YouTube subscriptions page. // @author Evgueni Naverniouk // @grant GM_addStyle // @include http://*.youtube.com/* // @include http://youtube.com/* // @include https://*.youtube.com/* // @include https://youtube.com/* // @downloadURL none // ==/UserScript== // To submit bugs or submit revisions please see visit the repository at: // https://github.com/globexdesigns/youtube-hide-watched // You can open new issues at: // https://github.com/globexdesigns/youtube-hide-watched/issues (function (undefined) { GM_addStyle("\ .GR-WATCHED {\ display: none;\ }\ .GR-LABEL {\ color:#666;\ cursor:pointer;\ }\ .GR-LABEL input {\ vertical-align: -2px;\ }\ "); // =========================================================== var findWatchedElements = function () { return document.getElementsByClassName('watched'); }; // =========================================================== var findParentByClass = function(el, cls) { while ((el = el.parentElement) && !el.classList.contains(cls)); return el; }; // =========================================================== var findToolbar = function () { var toolbar = document.getElementsByClassName('appbar-nav-menu'); if (!toolbar || !toolbar.length) return; return toolbar[0]; }; // =========================================================== var isCheckboxAlreadyThere = function () { var checkbox = document.getElementsByClassName('GR-LABEL'); return checkbox && checkbox.length; }; // =========================================================== var addClassToWatchedRows = function () { var items = findWatchedElements() || []; for (var i = 0, l = items.length; i < l; i++) { var item = items[i]; // "Subscription" section needs us to hide the "feed-item-container", // but in the "Trending" section, that class will hide everything. // So there, we need to hide the "expanded-shelf-content-item-wrapper" var row; if (window.location.href.indexOf('/feed/subscriptions') > 0) { row = findParentByClass(item, 'feed-item-container'); } else { row = findParentByClass(item, 'expanded-shelf-content-item-wrapper'); } var gridItem = findParentByClass(item, 'yt-shelf-grid-item'); // If we're in grid view, we will hide the "grid" item, // otherwise we'll hide the item row var itemToHide = gridItem ? gridItem : row; if (localStorage.GRWATCHED === 'true') { itemToHide.classList.add('GR-WATCHED'); } else { itemToHide.classList.remove('GR-WATCHED'); } }; }; // =========================================================== var addCheckboxButton = function () { if (isCheckboxAlreadyThere()) return; // Find toolbar var toolbar = findToolbar(); if (!toolbar) return; // Add label var label = document.createElement('label'); label.classList.add('GR-LABEL'); // Add checkbox var checkbox = document.createElement('input'); checkbox.type = 'checkbox'; checkbox.checked = localStorage.GRWATCHED === 'true' ? 'checked' : null; checkbox.addEventListener('change', function (event) { localStorage.GRWATCHED = event.target.checked; addClassToWatchedRows(); }); label.appendChild(checkbox); // Add label text var textnode = document.createTextNode("Hide Watched"); label.appendChild(textnode); // Create