aboutsummaryrefslogtreecommitdiff
path: root/youtube-noscript-shim.user.js
blob: beee8147e174ad114ddb403168907d2e6b022fe5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// ==UserScript==
// @name        youtube-noscript-shim
// @namespace   systemreboot.net
// @description Use YouTube with NoScript
// @include     https://www.youtube.com/*
// @version     0.1
// @grant       none
// ==/UserScript==

// Copyright (C) 2017 Arun Isaac <arunisaac@systemreboot.net>

// This program is free software: you can redistribute it and/or
// modify it under the terms of the GNU General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.

// This program is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
// General Public License for more details.

// You should have received a copy of the GNU General Public License
// along with this program.  If not, see <http://www.gnu.org/licenses/>.

function toggleClasses (selector, classes) {
    classes.forEach(function (cls) {
	document.querySelector(selector).classList.toggle(cls);
    });
}

function toggleBooleanAttributes (selector, attributes) {
    element = document.querySelector(selector);
    attributes.forEach(function (attribute) {
	element.setAttribute(attribute, element.getAttribute(attribute) == "true" ? "false" : "true");
    });
}

// Load thumbnails
Array.from(document.querySelectorAll("img[data-thumb]")).forEach(function (img) {
    img.setAttribute("src", img.getAttribute("data-thumb"));
});

// Search filters
document.querySelector(".filter-button").addEventListener("click", function () {
    toggleClasses(".filter-button", ["yt-uix-button-toggled"]);
    toggleClasses(".search-header", ["yt-uix-expander-collapsed"]);
    toggleBooleanAttributes(".filter-button", ["aria-pressed"]);
});

// Guide
document.querySelector("#appbar-guide-button").addEventListener("click", function () {
    toggleClasses("html", ["show-guide"]);
    toggleBooleanAttributes("#appbar-guide-button", ["aria-expanded"]);
});