YouTube Dark Mode Toggle Fixed

Adds a working bottom-left dark/light toggle for YouTube

スクリプトをインストールするには、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 Fixed
// @namespace    http://tampermonkey.net/
// @version      1.4
// @description  Adds a working bottom-left dark/light toggle for YouTube
// @author       You
// @match        https://www.youtube.com/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    const DARK_STYLE_ID = 'yt-darkmode-style';

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

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

        let darkMode = false;

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

            if (darkMode) {
                // Add a style element for dark mode
                const style = document.createElement('style');
                style.id = DARK_STYLE_ID;
                style.innerHTML = `
                    ytd-app, ytd-page-manager, #content, #primary, #secondary {
                        background-color: #111 !important;
                        color: #fff !important;
                    }
                    yt-formatted-string, a, h1, h2, h3, h4, h5, h6, span, div {
                        color: #fff !important;
                    }
                    ytd-video-renderer, ytd-rich-item-renderer, ytd-rich-grid-media {
                        background-color: #222 !important;
                    }
                `;
                document.head.appendChild(style);
            } else {
                const style = document.getElementById(DARK_STYLE_ID);
                if (style) style.remove();
            }
        });
    }

    // Use MutationObserver to wait for YouTube SPA navigation
    const observer = new MutationObserver(() => {
        if (document.body) {
            addToggleButton();
            observer.disconnect();
        }
    });

    observer.observe(document.documentElement, { childList: true, subtree: true });

})();