YouTube Dark Mode Toggle

Adds a bottom-left toggle button for YouTube dark/light text mode

スクリプトをインストールするには、Tampermonkey, GreasemonkeyViolentmonkey のような拡張機能のインストールが必要です。

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

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyUserscripts のような拡張機能のインストールが必要です。

このスクリプトをインストールするには、Tampermonkeyなどの拡張機能をインストールする必要があります。

このスクリプトをインストールするには、ユーザースクリプト管理ツールの拡張機能をインストールする必要があります。

(ユーザースクリプト管理ツールは設定済みなのでインストール!)

このスタイルをインストールするには、Stylusなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus などの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus tなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

(ユーザースタイル管理ツールは設定済みなのでインストール!)

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==UserScript==
// @name         YouTube Dark Mode Toggle
// @namespace    http://tampermonkey.net/
// @version      1.2
// @description  Adds a bottom-left toggle button for YouTube dark/light text mode
// @author       You
// @match        https://www.youtube.com/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    // Wait until YouTube body exists
    function addToggleButton() {
        if (document.body.querySelector('#yt-darkmode-toggle')) return; // already added

        const toggle = document.createElement('button');
        toggle.id = 'yt-darkmode-toggle';
        toggle.innerText = 'Toggle Dark Mode';
        toggle.style.position = 'fixed';
        toggle.style.bottom = '10px';
        toggle.style.left = '10px';
        toggle.style.zIndex = '9999';
        toggle.style.padding = '10px';
        toggle.style.backgroundColor = '#000';
        toggle.style.color = '#fff';
        toggle.style.border = 'none';
        toggle.style.borderRadius = '5px';
        toggle.style.cursor = 'pointer';
        document.body.appendChild(toggle);

        let darkMode = false;

        toggle.addEventListener('click', () => {
            darkMode = !darkMode;

            const textColor = darkMode ? '#fff' : '#000';
            const bgColor = darkMode ? '#111' : '#fff';

            document.body.style.backgroundColor = bgColor;
            document.body.style.color = textColor;

            document.querySelectorAll('*').forEach(el => {
                if (el.tagName !== 'SCRIPT' && el.tagName !== 'STYLE') {
                    el.style.color = textColor;
                }
            });
        });
    }

    // Try adding the button every second until it works
    const interval = setInterval(() => {
        if (document.body) {
            addToggleButton();
            clearInterval(interval);
        }
    }, 1000);

})();