Spaces:
Paused
Paused
File size: 1,159 Bytes
43a06dc |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
import { readable, derived, type Readable } from 'svelte/store';
import { browser } from '$app/environment';
import settings from '$lib/state/settings';
import { themeOptions } from '$lib/types/settings';
type Theme = typeof themeOptions[number];
let set: (_: Theme) => void;
const browserPreference = () => {
if (!browser || window.matchMedia('(prefers-color-scheme: light)').matches) {
return 'light';
}
return 'dark'
}
const browserPreferenceReadable = readable(
browserPreference(),
_set => { set = _set }
)
if (browser) {
const matchMedia = window.matchMedia('(prefers-color-scheme: dark)');
if (matchMedia.addEventListener) {
matchMedia.addEventListener('change', () => set(browserPreference()));
}
}
export default derived(
[settings, browserPreferenceReadable],
([$settings, $browserPref]) => {
if ($settings.appearance.theme !== 'auto') {
return $settings.appearance.theme;
}
return $browserPref;
},
browserPreference()
) as Readable<Exclude<Theme, "auto">>
export const statusBarColors = {
"dark": "#000000",
"light": "#ffffff"
}
|