Reddit Automatic Dark Mode

Switches Reddit cark mode on and off according to System Theme (if exposed by browser).

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

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

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

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

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

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

ستحتاج إلى تثبيت إضافة مثل Stylus لتثبيت هذا النمط.

ستحتاج إلى تثبيت إضافة لإدارة أنماط المستخدم لتتمكن من تثبيت هذا النمط.

ستحتاج إلى تثبيت إضافة لإدارة أنماط المستخدم لتثبيت هذا النمط.

ستحتاج إلى تثبيت إضافة لإدارة أنماط المستخدم لتثبيت هذا النمط.

(لدي بالفعل مثبت أنماط للمستخدم، دعني أقم بتثبيته!)

// ==UserScript==
// @name         Reddit Automatic Dark Mode
// @namespace    https://github.com/r0uv3n/
// @version      2024-03-02
// @description  Switches Reddit cark mode on and off according to System Theme (if exposed by browser).
// @author       Henry Ruben Fischer
// @match        *://*.reddit.com/*
// @icon         https://www.redditstatic.com/shreddit/assets/favicon/64x64.png
// @grant        none
// @license      MIT
// ==/UserScript==

// jshint esversion:11
(function() {
    'use strict';
    const getPreferredTheme = () => window?.matchMedia?.('(prefers-color-scheme:dark)')?.matches ? 'dark' : 'light';
    const darkModeToggle = document.getElementsByName("darkmode-switch-name")[0];
    const getRedditTheme = () => darkModeToggle.attributes["aria-checked"] ? 'dark' : 'light';
    const applyPreferredTheme = () => {
        if (getRedditTheme() != getPreferredTheme()) {
            darkModeToggle.click();
        }
    }
    window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change',applyPreferredTheme);
    // The above event listener is probably not applied on page load, so we do that manually once. Also we need to wait a bit since reddit seems to set the theme manually after a bit.
    setTimeout(applyPreferredTheme, 3000); //Two seconds will elapse and Code will execute.

})();