YouTubeDepopulator

Hides Youtube <li> elements, or sections on the homepage, with an <span.shelf-title-annotation>, or section subtitle, that contains the text "Popular ", "#", or "Trending "

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey, Greasemonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

You will need to install an extension such as Tampermonkey to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्क्रिप्ट व्यवस्थापक एक्स्टेंशन इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्क्रिप्ट व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्टाईल व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

// ==UserScript==
// @name        YouTubeDepopulator
// @namespace   YouTubeDepopulator
// @description Hides Youtube <li> elements, or sections on the homepage, with an <span.shelf-title-annotation>, or section subtitle, that contains the text "Popular ", "#", or "Trending "
// @run-at         document-body
// @include        *://youtube.tld/*
// @include        *://*.youtube.tld/*
// @version     1.5
// @grant       none
// ==/UserScript==

var spanElems = document.querySelectorAll('span.shelf-title-annotation,span.branded-page-module-title-text');

for (var i = 0; i < spanElems.length; i++) {
    if (spanElems[i].innerHTML.contains('Popular ') || spanElems[i].innerHTML.contains('#') || spanElems[i].innerHTML.contains('Breaking ') || spanElems[i].innerHTML.contains('Trending ')) {
    var parentElem = spanElems[i].parentNode;
    while (parentElem.nodeName != 'LI' && parentElem != null){
      parentElem = parentElem.parentNode;
    }
    if(parentElem != null){
      parentElem.remove();
    }
  }
}

!function (send) {
    XMLHttpRequest.prototype.send = function (data) {
        var callback = this.onreadystatechange;
        this.onreadystatechange = function () {
            if (this.readyState == 4) {

                setTimeout(function () {
                    var spanElems = document.querySelectorAll('span.shelf-title-annotation');

                    for (var i = 0; i < spanElems.length; i++) {
                        if (spanElems[i].innerHTML.contains('Popular ') || spanElems[i].innerHTML.contains('#') || spanElems[i].innerHTML.contains('Trending ') 
|| spanElems[i].innerHTML.contains('Breaking ')) {
                            var parentElem = spanElems[i].parentNode;
                            while (parentElem.nodeName != 'LI' && parentElem != null) {
                                parentElem = parentElem.parentNode;
                            }
                            if (parentElem != null) {
                                parentElem.remove();
                            }
                        }
                    }
                }, 1000);

            }

            callback.apply(this, arguments);
        }

        send.call(this, data);
    }
}(XMLHttpRequest.prototype.send);