// ==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.2 // @match *://www.youtube.com/* // @exclude *://www.youtube.com/embed/* // @require https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/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) → you can enable/disable to blacklist channels by clicking on '[x]' before the usernames → you can suspend temporarily the block (to reactivate it just click on save or ☆ or refresh the page) → it also hides videos from the playlists/mixes, but it doesn't prevent them from playing if the playlist is in autoplay please report any bugs (tested on chrome 55 and firefox 50) ***/ (function($) { // get black/whitelist saved var sBL, sWL, sep, add, 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', ','); add = GM_getValue('enableadd', ''); ytblacklist = sBL.split(sep); ytwhitelist = sWL.split(sep); } getValues(); // where the usernames are // related channels playlist/mixes var uClasses = ['#content .g-hovercard', '.branded-page-related-channels-list .yt-uix-tile-link', '.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(''); if (add) $('#yt-blacklist-enableadd').text('disable click add'); // 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; } // do the thing function findMatch(s) { $(s).each(function() { var username = $(this).text().trim().toLowerCase(); if (!username) return 'continue'; // if the username is blacklisted if (ifMatch(username)) { if ($(this).closest("tr").hasClass("tr.pl-video")) { // PLAYLIST PAGE if (!$(this).closest("tr").hasClass("tr-is-black")) { $(this).closest("tr").addClass("tr-is-black"); } } else { // SEARCH, RECOMMENDED, etc... if (!$(this).closest("li").hasClass("li-is-black")) { $(this).closest("li").addClass("li-is-black"); } } } else { // button to add names to blacklist if (add && !$(this).siblings('.yt-blacklist-add').length && !$(this).hasClass('comment-author-text')) { $('[x]').insertBefore($(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'); $error = $('ERROR! * NOT ALLOWED AS SEPARATOR'); $('#saveblacklist').on('click', function() { if ($('#sep-symbol').val() == '*') { $(this).before($error); setTimeout(function() { $error.remove(); }, 4000); } else { // save new values GM_setValue('savedblocks', $('#blacklist-words').val()); GM_setValue('savedwhites', $('#whitelist-words').val()); GM_setValue('sep', $('#sep-symbol').val()); // add notification $(this).before($saved); setTimeout(function() { $saved.remove(); }, 2000); // clear everything $(".li-is-black").removeClass("li-is-black"); $(".tr-is-black").removeClass("tr-is-black"); // research getValues(); search(); } }); // research and suspend $('#yt-blacklist-research').on('click', search); $('#yt-blacklist-suspend').on('click', function() { $(".li-is-black").removeClass("li-is-black"); $(".tr-is-black").removeClass("tr-is-black"); }); // enable/disable click add $('#yt-blacklist-enableadd').on('click', function() { if (add) { add = ''; $('.yt-blacklist-add').remove(); $(this).text('enable click add'); } else { add = 'yes'; $(this).text('disable click add'); } GM_setValue('enableadd', add); search(); }); // add usernames to blacklist $('body').on('click', '.yt-blacklist-add', function(e) { e.preventDefault(); e.stopPropagation(); var q = sBL ? sep + ' ' : ''; $('#blacklist-words').val($('#blacklist-words').val() + q + $(this).attr('data')); GM_setValue('savedblocks', $('#blacklist-words').val()); getValues(); search(); }); // 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);