// ==UserScript== // @name Block Youtube Users // @author Schegge // @namespace https://github.com/Schegge // @description Prevent from seeing videos by certain users (from recommended, search, related channels...) // @version 2.1.9 // @match *://www.youtube.com/* // @exclude *://www.youtube.com/embed/* // @require https://ajax.googleapis.com/ajax/libs/jquery/2.2.4/jquery.min.js // @grant GM_getValue // @grant GM_setValue // @icon  // @downloadURL none // ==/UserScript== /*** DESCRIPTION → the program is case-insensitive → you can choose the symbol to split the usernames (default is a comma) ('*' not allowed) (max 1 character) → put a * in front of a word for wildcard (only in the blacklist!), it will find the word no matter its position in the username (example: *vevo) → it also hides videos from the playlists/mixes, but it doesn't prevent them from playing if the playlist is in autoplay (download another script that disables autoplay!) → ☆ force a new search (in case of problems?) → you can suspend temporarily the block (to reactivate it just click on the star/save or refresh the page) please report any bugs ***/ (function($) { // get black/whitelist saved var sBL, sWL, sep, ytblacklist, ytwhitelist; function getValues() { sBL = GM_getValue('savedblocks', 'it is case-insensitive, split the usernames with a comma (default), put a * in front of a word for wildcard, it will find the word no matter its position in the username'); sWL = GM_getValue('savedwhites', 'write here whitelisted usernames, if for example you blacklist *vevo, but you want to see IndilaVEVO'); sep = GM_getValue('sep', ','); ytblacklist = sBL.split(sep); ytwhitelist = sWL.split(sep); } getValues(); // where the usernames are var uClasses = ['.g-hovercard', '.yt-uix-tile-link', '.branded-page-module-title-text', '.video-uploader-byline']; // elements for user input var margintop = $('#yt-masthead-container').height() + parseInt($('#yt-masthead-container').css('padding-top')) + parseInt($('#yt-masthead-container').css('padding-bottom')); $('head').append(''); $('
B
').insertAfter('#upload-btn'); $('body').append(''); // check if a username is whitelisted function ifWhite(u) { var whitelisted = false; for(var z = 0; z < ytwhitelist.length; z++) { var w = ytwhitelist[z].trim().toLowerCase(); if (w.length && u == w) { whitelisted = true; } } return whitelisted; } // check if a username is blacklisted function ifMatch(u) { var match = false; if (!ifWhite(u)) { // if the username isn't whitelisted for (var j = 0; j < ytblacklist.length; j++) { var b = ytblacklist[j].trim().toLowerCase(); if (b.charAt(0) == '*') { // wildcards var part = b.split('*'), item = part[1]; if (item.length && u.indexOf(item) !== -1) { match = true; } } else { // exact match if (b.length && u == b) { match = true; } } } } return match; } // delete blacklisted function suspend(t) { if ($(t).parents('.li-is-black').length) { // SEARCH, RECOMMENDED, etc... $(t).parents('.li-is-black').removeClass('li-is-black').show(); } else if ($(this).parents('.tr-is-black').length) { // PLAYLIST (not the dark one) $(t).parents('.tr-is-black').removeClass('tr-is-black').show(); } } // do the thing function findMatch(s) { $(s).each(function() { var username = $(this).text().trim().toLowerCase(); if (username) { if (ifMatch(username)) { // if the username is blacklisted if ($(this).parents('tr.pl-video').length && !$(this).parents('.tr-is-black').length) { // PLAYLIST (not the dark one) $(this).closest('tr').addClass('tr-is-black').hide(); } else if (!$(this).parents('.li-is-black').length) { // SEARCH, RECOMMENDED, etc... $(this).closest('li').addClass('li-is-black').hide(); } } else { // if a previous black/whitelist word is deleted/added suspend(this); } } }); } // the final search function function search() { var url = window.location.href; // playlist?list=WL = Watch Later | != feed/t... = History, Subscriptions if (!/.*youtube\.com\/(playlist\?list=WL|feed\/[^t]\w+)/.test(url)) { for (var i = 0; i < uClasses.length; i++) { findMatch(uClasses[i]); } } } // search when youtube is first opened search(); // open and close options $('#yt-blacklist').on('click', function() { $('#yt-blacklist-options').slideToggle(); }); // save blacklist changes and research $saved = $('saved and searched again'); $error = $('ERROR! * NOT ALLOWED AS SEPARATOR'); $('#saveblacklist').on('click', function() { if ($('#sep-symbol').val() == '*') { $(this).before($error); setTimeout(function() { $error.remove(); }, 4000); } else { GM_setValue('savedblocks', $('#blacklist-words').val()); GM_setValue('savedwhites', $('#whitelist-words').val()); GM_setValue('sep', $('#sep-symbol').val()); getValues(); search(); $(this).before($saved); setTimeout(function() { $saved.remove(); }, 2000); } }); // research and suspend $('#yt-blacklist-research').on('click', search); $('#yt-blacklist-suspend').on('click', function() { for (var i = 0; i < uClasses.length; i++) { $(uClasses[i]).each(function() { suspend(this); }); } }); // research after every change in #content var target = document.querySelector('#content'); var config = { attributes: false, childList: true, characterData: false, subtree: true }; var observer = new MutationObserver(function(mutations) { search(); }); try { observer.observe(target, config); } catch (e) {} })(jQuery);