V2EX Auto Dark Mode

Turn on/off dark mode automatically in v2ex.com based on the color scheme of OS.

目前為 2021-04-01 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         V2EX Auto Dark Mode
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  Turn on/off dark mode automatically in v2ex.com based on the color scheme of OS.
// @author       Jiachen Chen
// @match        *://*.v2ex.com/*
// @match        *://v2ex.com/*
// @icon         https://www.google.com/s2/favicons?domain=v2ex.com
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    const toggleLink = document.querySelector('.light-toggle').getAttribute('href');

    if (window.matchMedia && window.matchMedia('(prefers-color-scheme: light)').matches) {
        if (SITE_NIGHT) {
            window.location.replace(toggleLink);
        }
    }

    window.matchMedia('(prefers-color-scheme: light)').addEventListener('change', e => {
        if (SITE_NIGHT) {
            window.location.replace(toggleLink);
        }
    });

    if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
        if (SITE_NIGHT === 0) {
            window.location.replace(toggleLink);
        }
    }

    window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', e => {
        if (SITE_NIGHT === 0) {
            window.location.replace(toggleLink);
        }
    });
})();