mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-26 00:02:34 -04:00 
			
		
		
		
	pr feedback
This commit is contained in:
		
							parent
							
								
									a25df32a65
								
							
						
					
					
						commit
						1b7022bf12
					
				| @ -1,7 +1,6 @@ | |||||||
| import overpass from '$lib/assets/fonts/overpass/Overpass.ttf?url'; | import overpass from '$lib/assets/fonts/overpass/Overpass.ttf?url'; | ||||||
| import overpassMono from '$lib/assets/fonts/overpass/OverpassMono.ttf?url'; | import overpassMono from '$lib/assets/fonts/overpass/OverpassMono.ttf?url'; | ||||||
| import fouc from '$lib/utils/app?raw'; | import fouc from '$lib/utils/app?raw'; | ||||||
| import theme from '$lib/utils/theme?raw'; |  | ||||||
| import type { Handle } from '@sveltejs/kit'; | import type { Handle } from '@sveltejs/kit'; | ||||||
| import { ModuleKind, transpileModule } from 'typescript'; | import { ModuleKind, transpileModule } from 'typescript'; | ||||||
| 
 | 
 | ||||||
| @ -16,9 +15,7 @@ const transpileFile = (content: string) => { | |||||||
| export const handle = (async ({ event, resolve }) => { | export const handle = (async ({ event, resolve }) => { | ||||||
|   return resolve(event, { |   return resolve(event, { | ||||||
|     transformPageChunk: ({ html }) => { |     transformPageChunk: ({ html }) => { | ||||||
|       const themePrepared = theme.replaceAll(/^export\s+/gm, ''); |       const scriptFouc = `<script>${transpileFile(fouc)}</script>`; | ||||||
|       const foucPrepared = fouc.replaceAll(/^import.*$/gm, themePrepared); |  | ||||||
|       const scriptFouc = `<script>${transpileFile(foucPrepared)}</script>`; |  | ||||||
| 
 | 
 | ||||||
|       return html |       return html | ||||||
|         .replace('%app.font%', overpass) |         .replace('%app.font%', overpass) | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ | |||||||
|   import OnboardingCard from './onboarding-card.svelte'; |   import OnboardingCard from './onboarding-card.svelte'; | ||||||
|   import { colorTheme } from '$lib/stores/preferences.store'; |   import { colorTheme } from '$lib/stores/preferences.store'; | ||||||
|   import { moonPath, moonViewBox, sunPath, sunViewBox } from '$lib/assets/svg-paths'; |   import { moonPath, moonViewBox, sunPath, sunViewBox } from '$lib/assets/svg-paths'; | ||||||
|   import { Theme } from '$lib/utils/theme'; |   import { Theme } from '$lib/constants'; | ||||||
|   import { t } from 'svelte-i18n'; |   import { t } from 'svelte-i18n'; | ||||||
| 
 | 
 | ||||||
|   export let onDone: () => void; |   export let onDone: () => void; | ||||||
|  | |||||||
| @ -3,11 +3,11 @@ | |||||||
|   import logoLightUrl from '$lib/assets/immich-logo-inline-light.svg'; |   import logoLightUrl from '$lib/assets/immich-logo-inline-light.svg'; | ||||||
|   import logoNoText from '$lib/assets/immich-logo.svg'; |   import logoNoText from '$lib/assets/immich-logo.svg'; | ||||||
|   import { content as alternativeLogo } from '$lib/assets/immich-logo.json'; |   import { content as alternativeLogo } from '$lib/assets/immich-logo.json'; | ||||||
|   import { Theme } from '$lib/utils/theme'; |  | ||||||
|   import { colorTheme } from '$lib/stores/preferences.store'; |   import { colorTheme } from '$lib/stores/preferences.store'; | ||||||
|   import { DateTime } from 'luxon'; |   import { DateTime } from 'luxon'; | ||||||
|   import type { HTMLImgAttributes } from 'svelte/elements'; |   import type { HTMLImgAttributes } from 'svelte/elements'; | ||||||
|   import { t } from 'svelte-i18n'; |   import { t } from 'svelte-i18n'; | ||||||
|  |   import { Theme } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
|   // eslint-disable-next-line @typescript-eslint/no-unused-vars |   // eslint-disable-next-line @typescript-eslint/no-unused-vars | ||||||
|   interface $$Props extends HTMLImgAttributes { |   interface $$Props extends HTMLImgAttributes { | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ | |||||||
|   import Icon from '$lib/components/elements/icon.svelte'; |   import Icon from '$lib/components/elements/icon.svelte'; | ||||||
|   import { colorTheme, mapSettings } from '$lib/stores/preferences.store'; |   import { colorTheme, mapSettings } from '$lib/stores/preferences.store'; | ||||||
|   import { getAssetThumbnailUrl, handlePromiseError } from '$lib/utils'; |   import { getAssetThumbnailUrl, handlePromiseError } from '$lib/utils'; | ||||||
|   import { Theme } from '$lib/utils/theme'; |   import { Theme } from '$lib/constants'; | ||||||
|   import { getServerConfig, type MapMarkerResponseDto } from '@immich/sdk'; |   import { getServerConfig, type MapMarkerResponseDto } from '@immich/sdk'; | ||||||
|   import mapboxRtlUrl from '@mapbox/mapbox-gl-rtl-text/mapbox-gl-rtl-text.min.js?url'; |   import mapboxRtlUrl from '@mapbox/mapbox-gl-rtl-text/mapbox-gl-rtl-text.min.js?url'; | ||||||
|   import { mdiCog, mdiMap, mdiMapMarker } from '@mdi/js'; |   import { mdiCog, mdiMap, mdiMapMarker } from '@mdi/js'; | ||||||
|  | |||||||
| @ -2,7 +2,7 @@ | |||||||
|   import { moonPath, moonViewBox, sunPath, sunViewBox } from '$lib/assets/svg-paths'; |   import { moonPath, moonViewBox, sunPath, sunViewBox } from '$lib/assets/svg-paths'; | ||||||
|   import CircleIconButton, { type Padding } from '$lib/components/elements/buttons/circle-icon-button.svelte'; |   import CircleIconButton, { type Padding } from '$lib/components/elements/buttons/circle-icon-button.svelte'; | ||||||
|   import { colorTheme, handleToggleTheme } from '$lib/stores/preferences.store'; |   import { colorTheme, handleToggleTheme } from '$lib/stores/preferences.store'; | ||||||
|   import { Theme } from '$lib/utils/theme'; |   import { Theme } from '$lib/constants'; | ||||||
|   import { t } from 'svelte-i18n'; |   import { t } from 'svelte-i18n'; | ||||||
| 
 | 
 | ||||||
|   $: icon = $colorTheme.value === Theme.LIGHT ? moonPath : sunPath; |   $: icon = $colorTheme.value === Theme.LIGHT ? moonPath : sunPath; | ||||||
|  | |||||||
| @ -102,6 +102,12 @@ export const timeBeforeShowLoadingSpinner: number = 100; | |||||||
| 
 | 
 | ||||||
| export const timeDebounceOnSearch: number = 300; | export const timeDebounceOnSearch: number = 300; | ||||||
| 
 | 
 | ||||||
|  | // should be the same values as the ones in the app.ts
 | ||||||
|  | export enum Theme { | ||||||
|  |   LIGHT = 'light', | ||||||
|  |   DARK = 'dark', | ||||||
|  | } | ||||||
|  | 
 | ||||||
| export const fallbackLocale = { | export const fallbackLocale = { | ||||||
|   code: 'en-US', |   code: 'en-US', | ||||||
|   name: 'English (US)', |   name: 'English (US)', | ||||||
|  | |||||||
| @ -1,10 +1,14 @@ | |||||||
| import { browser } from '$app/environment'; | import { browser } from '$app/environment'; | ||||||
| import { defaultLang } from '$lib/constants'; | import { defaultLang, Theme } from '$lib/constants'; | ||||||
| import { getPreferredLocale } from '$lib/utils/i18n'; | import { getPreferredLocale } from '$lib/utils/i18n'; | ||||||
| import { colorThemeKeyName, Theme, type ThemeSetting } from '$lib/utils/theme'; |  | ||||||
| import { persisted } from 'svelte-local-storage-store'; | import { persisted } from 'svelte-local-storage-store'; | ||||||
| import { get } from 'svelte/store'; | import { get } from 'svelte/store'; | ||||||
| 
 | 
 | ||||||
|  | export interface ThemeSetting { | ||||||
|  |   value: Theme; | ||||||
|  |   system: boolean; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| export const handleToggleTheme = () => { | export const handleToggleTheme = () => { | ||||||
|   const theme = get(colorTheme); |   const theme = get(colorTheme); | ||||||
|   theme.value = theme.value === Theme.DARK ? Theme.LIGHT : Theme.DARK; |   theme.value = theme.value === Theme.DARK ? Theme.LIGHT : Theme.DARK; | ||||||
| @ -20,7 +24,8 @@ const initTheme = (): ThemeSetting => { | |||||||
| 
 | 
 | ||||||
| const initialTheme = initTheme(); | const initialTheme = initTheme(); | ||||||
| 
 | 
 | ||||||
| export const colorTheme = persisted<ThemeSetting>(colorThemeKeyName, initialTheme, { | // The 'color-theme' key is also used by app.ts to prevent FOUC on page load.
 | ||||||
|  | export const colorTheme = persisted<ThemeSetting>('color-theme', initialTheme, { | ||||||
|   serializer: { |   serializer: { | ||||||
|     parse: (text: string): ThemeSetting => { |     parse: (text: string): ThemeSetting => { | ||||||
|       const parsedText: ThemeSetting = JSON.parse(text); |       const parsedText: ThemeSetting = JSON.parse(text); | ||||||
|  | |||||||
| @ -1,11 +1,17 @@ | |||||||
| /* | // should be the same values as the one in perferences.store.ts
 | ||||||
|  * we don't want to deal with imports so that import should be | interface ThemeSetting { | ||||||
|  * replaced by the actual content of the file before fouc.ts is transpiled |   value: Theme; | ||||||
|  * |   system: boolean; | ||||||
|  */ | } | ||||||
| import { colorThemeKeyName, Theme, type ThemeSetting } from '$lib/utils/theme'; |  | ||||||
| 
 | 
 | ||||||
| const storedTheme = localStorage.getItem(colorThemeKeyName); | // should be the same values as the ones in constants.ts
 | ||||||
|  | enum Theme { | ||||||
|  |   LIGHT = 'light', | ||||||
|  |   DARK = 'dark', | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // should be the same key as the one in preferences.store.ts
 | ||||||
|  | const storedTheme = localStorage.getItem('color-theme'); | ||||||
| const theme: ThemeSetting = storedTheme ? JSON.parse(storedTheme) : { value: Theme.LIGHT, system: true }; | const theme: ThemeSetting = storedTheme ? JSON.parse(storedTheme) : { value: Theme.LIGHT, system: true }; | ||||||
| const themeValue = theme.system && window.matchMedia('(prefers-color-scheme: dark)').matches ? Theme.DARK : theme.value; | const themeValue = theme.system && window.matchMedia('(prefers-color-scheme: dark)').matches ? Theme.DARK : theme.value; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,11 +0,0 @@ | |||||||
| export interface ThemeSetting { |  | ||||||
|   value: Theme; |  | ||||||
|   system: boolean; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| export enum Theme { |  | ||||||
|   LIGHT = 'light', |  | ||||||
|   DARK = 'dark', |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| export const colorThemeKeyName = 'color-theme'; |  | ||||||
| @ -8,8 +8,8 @@ | |||||||
|   import NotificationList from '$lib/components/shared-components/notification/notification-list.svelte'; |   import NotificationList from '$lib/components/shared-components/notification/notification-list.svelte'; | ||||||
|   import UploadPanel from '$lib/components/shared-components/upload-panel.svelte'; |   import UploadPanel from '$lib/components/shared-components/upload-panel.svelte'; | ||||||
|   import VersionAnnouncementBox from '$lib/components/shared-components/version-announcement-box.svelte'; |   import VersionAnnouncementBox from '$lib/components/shared-components/version-announcement-box.svelte'; | ||||||
|   import { Theme, type ThemeSetting } from '$lib/utils/theme'; |   import { Theme } from '$lib/constants'; | ||||||
|   import { colorTheme, handleToggleTheme } from '$lib/stores/preferences.store'; |   import { colorTheme, handleToggleTheme, type ThemeSetting } from '$lib/stores/preferences.store'; | ||||||
|   import { serverConfig } from '$lib/stores/server-config.store'; |   import { serverConfig } from '$lib/stores/server-config.store'; | ||||||
|   import { user } from '$lib/stores/user.store'; |   import { user } from '$lib/stores/user.store'; | ||||||
|   import { closeWebsocketConnection, openWebsocketConnection } from '$lib/stores/websocket'; |   import { closeWebsocketConnection, openWebsocketConnection } from '$lib/stores/websocket'; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user