YouTube Channel Search Filter

Hide search results from other YouTube channels when searching within a specific channel.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

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

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

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

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

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name         YouTube Channel Search Filter
// @namespace    https://greasyfork.org/en/users/1191564-iamcup
// @version      1.0
// @description  Hide search results from other YouTube channels when searching within a specific channel.
// @author       Tom McGraw
// @match        https://www.youtube.com/*/search?query=*
// @grant        none
// @license MIT
// ==/UserScript==

(function() {
    'use strict';

    // Get the channel name from the URL
    const url = window.location.href;
    const match = url.match(/@([^/]+)\/search/);
    if (!match) return;

    const searchText = match[1];

    // Function to hide elements without the specified text
    function hideElementsWithoutText() {
        const elements = document.querySelectorAll('div#contents ytd-item-section-renderer');

        elements.forEach(element => {
            const text = element.textContent;
            if (!text.includes(searchText)) {
                element.style.display = 'none';
            }
        });
    }

    // Call the function when the page loads and when new content is loaded (e.g., when scrolling)
    window.addEventListener('load', hideElementsWithoutText);
    window.addEventListener('scroll', hideElementsWithoutText);
})();