2023-01-15 12:23:47 +00:00
|
|
|
import { DEFAULT_FONT_SIZE } from '~/constants'
|
2023-01-12 17:52:52 +00:00
|
|
|
|
|
|
|
export type FontSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl'
|
2023-01-12 18:29:10 +00:00
|
|
|
export type ColorMode = 'light' | 'dark' | 'system'
|
2023-01-12 17:52:52 +00:00
|
|
|
|
|
|
|
export interface FeatureFlags {
|
|
|
|
experimentalVirtualScroller: boolean
|
|
|
|
experimentalGitHubCards: boolean
|
|
|
|
experimentalUserPicker: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface WellnessSettings {
|
|
|
|
hideBoostCount: boolean
|
|
|
|
hideFavoriteCount: boolean
|
|
|
|
hideFollowerCount: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface UserSettings {
|
|
|
|
featureFlags: Partial<FeatureFlags>
|
|
|
|
wellnessSettings: Partial<WellnessSettings>
|
|
|
|
colorMode?: ColorMode
|
|
|
|
fontSize: FontSize
|
|
|
|
language: string
|
2023-01-14 12:58:32 +00:00
|
|
|
zenMode: boolean
|
2023-01-12 17:52:52 +00:00
|
|
|
}
|
|
|
|
|
2023-01-15 12:23:47 +00:00
|
|
|
export function getDefaultLanguage(languages: string[]) {
|
|
|
|
if (process.server)
|
|
|
|
return 'en-US'
|
|
|
|
return matchLanguages(languages, navigator.languages) || 'en-US'
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getDefaultUserSettings(locales: string[]): UserSettings {
|
2023-01-12 17:52:52 +00:00
|
|
|
return {
|
2023-01-15 12:23:47 +00:00
|
|
|
language: getDefaultLanguage(locales),
|
2023-01-12 17:52:52 +00:00
|
|
|
fontSize: DEFAULT_FONT_SIZE,
|
2023-01-14 12:58:32 +00:00
|
|
|
zenMode: false,
|
2023-01-12 17:52:52 +00:00
|
|
|
featureFlags: {},
|
|
|
|
wellnessSettings: {},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export const DEFAULT_WELLNESS_SETTINGS: WellnessSettings = {
|
|
|
|
hideBoostCount: false,
|
|
|
|
hideFavoriteCount: false,
|
|
|
|
hideFollowerCount: false,
|
|
|
|
}
|
|
|
|
|
|
|
|
export const DEFAULT_FEATURE_FLAGS: FeatureFlags = {
|
|
|
|
experimentalVirtualScroller: true,
|
|
|
|
experimentalGitHubCards: true,
|
|
|
|
experimentalUserPicker: true,
|
|
|
|
}
|