Exercism Dark Mode

Enables dark theme in exercism.org

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Exercism Dark Mode
// @version      1.0.0
// @description  Enables dark theme in exercism.org
// @author       7heMech
// @license      MIT
// @icon         https://www.google.com/s2/favicons?sz=64&domain=exercism.org
// @match        https://exercism.org/*
// @run-at       document-start
// @grant        none
// @namespace https://greasyfork.org/users/1193487
// ==/UserScript==

(function() {
    'use strict';

    const body = document.body;

    toggleDarkTheme();

    function callback(mutationList, observer) {
        mutationList.forEach(function(mutation) {
            if (mutation.type !== 'attributes' || mutation.attributeName !== 'class') return;
            toggleDarkTheme();
        })
    }

    const observer = new MutationObserver(callback);
    observer.observe(body, { attributes: true });

    function toggleDarkTheme() {
        if (!body.classList.contains('theme-light')) return;
        body.classList.remove('theme-light');
        body.classList.add('theme-dark');
    }
})();