23 lines
642 B
TypeScript
23 lines
642 B
TypeScript
import { onReady } from "./utils";
|
|
|
|
type Theme = "light" | "dark";
|
|
|
|
const colorSchemeQuery = window.matchMedia?.("(prefers-color-scheme: dark)") ?? null;
|
|
|
|
const getPreferredTheme = (): Theme => {
|
|
const prefersDark = colorSchemeQuery?.matches ?? false;
|
|
return prefersDark ? "dark" : "light";
|
|
};
|
|
|
|
const applyTheme = (theme: Theme): void => {
|
|
document.documentElement.setAttribute("data-theme", theme);
|
|
document.documentElement.style.colorScheme = theme;
|
|
};
|
|
|
|
const initTheme = (): void => {
|
|
applyTheme(getPreferredTheme());
|
|
colorSchemeQuery?.addEventListener("change", () => applyTheme(getPreferredTheme()));
|
|
};
|
|
|
|
onReady(initTheme);
|