import { DEFAULT_FONT_SIZE } from '~/constants' export type FontSize = `${number}px` // Temporary type for backward compatibility export type OldFontSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl' export type ColorMode = 'light' | 'dark' | 'system' export interface PreferencesSettings { hideAltIndicatorOnPosts: boolean hideBoostCount: boolean hideReplyCount: boolean hideFavoriteCount: boolean hideFollowerCount: boolean hideTranslation: boolean hideUsernameEmojis: boolean hideAccountHoverCard: boolean grayscaleMode: boolean enableAutoplay: boolean enableDataSaving: boolean enablePinchToZoom: boolean experimentalVirtualScroller: boolean experimentalGitHubCards: boolean experimentalUserPicker: boolean } export interface UserSettings { preferences: Partial colorMode?: ColorMode fontSize: FontSize language: string disabledTranslationLanguages: string[] zenMode: boolean themeColors?: ThemeColors } export interface UserHomeFilter { bot: boolean sensitive: boolean repost: boolean mutual: boolean tag: boolean } export interface ThemeColors { '--theme-color-name': string '--c-primary': string '--c-primary-active': string '--c-primary-light': string '--c-primary-fade': string '--c-dark-primary': string '--c-dark-primary-active': string '--c-dark-primary-light': string '--c-dark-primary-fade': string '--rgb-primary': string '--rgb-dark-primary': string } export function getDefaultLanguage(languages: string[]) { if (process.server) return 'en-US' return matchLanguages(languages, navigator.languages) || 'en-US' } export function getDefaultUserSettings(locales: string[]): UserSettings { return { language: getDefaultLanguage(locales), fontSize: DEFAULT_FONT_SIZE, disabledTranslationLanguages: [], zenMode: false, preferences: {}, } } export const DEFAULT__PREFERENCES_SETTINGS: PreferencesSettings = { hideAltIndicatorOnPosts: false, hideBoostCount: false, hideReplyCount: false, hideFavoriteCount: false, hideFollowerCount: false, hideTranslation: false, hideUsernameEmojis: false, hideAccountHoverCard: false, grayscaleMode: false, enableAutoplay: true, enableDataSaving: false, enablePinchToZoom: false, experimentalVirtualScroller: true, experimentalGitHubCards: true, experimentalUserPicker: true, }