web: make everything ssr-compatible
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
import { derived, readable, type Updater } from 'svelte/store';
|
||||
import { browser } from '$app/environment';
|
||||
import { merge } from 'ts-deepmerge';
|
||||
|
||||
import type {
|
||||
@@ -43,6 +44,9 @@ const migrate = (settings: AllPartialSettingsWithSchema): PartialSettings => {
|
||||
|
||||
|
||||
const loadFromStorage = () => {
|
||||
if (!browser)
|
||||
return {};
|
||||
|
||||
const settings = localStorage.getItem('settings');
|
||||
if (!settings) {
|
||||
const migrated = migrateOldSettings();
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
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';
|
||||
@@ -7,19 +8,25 @@ type Theme = typeof themeOptions[number];
|
||||
|
||||
let set: (_: Theme) => void;
|
||||
|
||||
const browserPreference = () =>
|
||||
window.matchMedia('(prefers-color-scheme: light)')
|
||||
.matches ? 'light' : 'dark';
|
||||
const browserPreference = () => {
|
||||
if (!browser || window.matchMedia('(prefers-color-scheme: light)').matches) {
|
||||
return 'light';
|
||||
}
|
||||
|
||||
return 'dark'
|
||||
}
|
||||
|
||||
const browserPreferenceReadable = readable(
|
||||
browserPreference(),
|
||||
_set => { set = _set }
|
||||
)
|
||||
|
||||
const matchMedia = window.matchMedia('(prefers-color-scheme: dark)');
|
||||
if (browser) {
|
||||
const matchMedia = window.matchMedia('(prefers-color-scheme: dark)');
|
||||
|
||||
if (matchMedia.addEventListener) {
|
||||
matchMedia.addEventListener('change', () => set(browserPreference()));
|
||||
if (matchMedia.addEventListener) {
|
||||
matchMedia.addEventListener('change', () => set(browserPreference()));
|
||||
}
|
||||
}
|
||||
|
||||
export default derived(
|
||||
|
||||
Reference in New Issue
Block a user