TelegramPWA/src/util/systemTheme.ts
2023-07-05 13:23:12 +02:00

29 lines
862 B
TypeScript

import type { ThemeKey } from '../types';
let systemThemeCache: ThemeKey = (
window.matchMedia?.('(prefers-color-scheme: dark)').matches
) ? 'dark' : 'light';
let themeChangeCallback: ((newTheme: ThemeKey) => void) | undefined;
export function getSystemTheme() {
return systemThemeCache;
}
function handleSystemThemeChange(e: MediaQueryListEventMap['change']) {
systemThemeCache = e.matches ? 'dark' : 'light';
themeChangeCallback?.(systemThemeCache);
}
export function setSystemThemeChangeCallback(callback: (newTheme: ThemeKey) => void) {
themeChangeCallback = callback;
}
const mql = window.matchMedia('(prefers-color-scheme: dark)');
if (typeof mql.addEventListener === 'function') {
mql.addEventListener('change', handleSystemThemeChange);
} else if (typeof mql.addListener === 'function') {
mql.addListener(handleSystemThemeChange);
}