|
1 | 1 | import { DARK, LIGHT } from "../../constants"; |
2 | 2 | import { ColorSchemePreference, ResolvedScheme, Store, useStore } from "../../utils"; |
3 | 3 | import { useEffect } from "react"; |
4 | | -import { s } from "./script"; |
| 4 | + |
| 5 | +declare global { |
| 6 | + var u: (mode: ColorSchemePreference, systemMode: ResolvedScheme) => void; |
| 7 | + var m: MediaQueryList; |
| 8 | +} |
| 9 | + |
| 10 | +export const s = (storageKey: string) => { |
| 11 | + const [SYSTEM, DARK] = ["system", "dark"] as const; |
| 12 | + window.u = (mode: ColorSchemePreference, systemMode: ResolvedScheme) => { |
| 13 | + const resolvedMode = mode === SYSTEM ? systemMode : mode; |
| 14 | + const el = document.documentElement; |
| 15 | + if (resolvedMode === DARK) el.classList.add(DARK); |
| 16 | + else el.classList.remove(DARK); |
| 17 | + [ |
| 18 | + ["sm", systemMode], |
| 19 | + ["rm", resolvedMode], |
| 20 | + ["m", mode], |
| 21 | + ].forEach(([dataLabel, value]) => el.setAttribute(`data-${dataLabel}`, value)); |
| 22 | + // System mode is decided by current system state and need not be stored in localStorage |
| 23 | + localStorage.setItem(storageKey, mode); |
| 24 | + }; |
| 25 | + window.m = matchMedia(`(prefers-color-scheme: ${DARK})`); |
| 26 | + u((localStorage.getItem(storageKey) ?? SYSTEM) as ColorSchemePreference, m.matches ? DARK : ""); |
| 27 | +}; |
5 | 28 |
|
6 | 29 | let media: MediaQueryList, |
7 | 30 | updateDOM: (mode: ColorSchemePreference, systemMode: ResolvedScheme) => void; |
@@ -49,7 +72,7 @@ export const Core = ({ t, nonce, k = "o" }: CoreProps) => { |
49 | 72 |
|
50 | 73 | useEffect(() => { |
51 | 74 | // store global functions to local variables to avoid any interference |
52 | | - [media, updateDOM] = [m, u]; |
| 75 | + [media, updateDOM] = [window.m, window.u]; |
53 | 76 | /** Updating media: prefers-color-scheme*/ |
54 | 77 | media.addEventListener("change", () => |
55 | 78 | setThemeState(state => ({ ...state, s: media.matches ? DARK : LIGHT }) as Store), |
|
0 commit comments