Reddit Match System Theme

Change Reddit theme according to your system preferences dynamically

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         Reddit Match System Theme
// @namespace    http://tampermonkey.net/
// @version      1.2
// @description  Change Reddit theme according to your system preferences dynamically
// @author       MattD
// @license      MIT
// @match        https://*.reddit.com/*
// @icon         https://www.redditstatic.com/shreddit/assets/favicon/64x64.png
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    const switchTheme = () => {
        if (window.matchMedia('(prefers-color-scheme: light)').matches && document.documentElement.classList.contains("theme-dark")) {
            document.documentElement.classList.add("theme-light")
            document.documentElement.classList.remove("theme-dark")
            console.log(`Reddit Match System Theme : Switched to light`);
        } else if (window.matchMedia('(prefers-color-scheme: dark)').matches && document.documentElement.classList.contains("theme-light")) {
            document.documentElement.classList.add("theme-dark")
            document.documentElement.classList.remove("theme-light")
            console.log(`Reddit Match System Theme : Switched to dark`);
        }
    }
    const init = () => {
        console.log(`Reddit Match System Theme Init`);
        let timer = null;
        new MutationObserver(() => {
            clearTimeout(timer);
            timer = setTimeout(() => {switchTheme()}, 200);
        }).observe(document.body, {childList: true, subtree: true, attributes: true, characterData: true});
        new MutationObserver(() => {
            switchTheme();
        }).observe(document.querySelector("title"), { childList: true });
        window.matchMedia('(prefers-color-scheme: light)').addEventListener('change', switchTheme);
    };
    document.readyState === "loading" ? document.addEventListener("DOMContentLoaded", init) : init();
})();