diff --git a/web/src/lib/components/shared-components/side-bar/recent-albums.svelte b/web/src/lib/components/shared-components/side-bar/recent-albums.svelte index d90d7dec01c87..ccd0de62ee78b 100644 --- a/web/src/lib/components/shared-components/side-bar/recent-albums.svelte +++ b/web/src/lib/components/shared-components/side-bar/recent-albums.svelte @@ -2,37 +2,55 @@ import { onMount } from 'svelte'; import { getAssetThumbnailUrl } from '$lib/utils'; import { getAllAlbums, type AlbumResponseDto } from '@immich/sdk'; - import { handleError } from '$lib/utils/handle-error'; - import { t } from 'svelte-i18n'; let albums: AlbumResponseDto[] = $state([]); - onMount(async () => { + let loadingAlbums: boolean = $state(false); + + async function loadAlbums() { try { + loadingAlbums = true; const allAlbums = await getAllAlbums({}); albums = allAlbums.sort((a, b) => (a.updatedAt > b.updatedAt ? -1 : 1)).slice(0, 3); } catch (error) { - handleError(error, $t('failed_to_load_assets')); + console.error('Failed to load albums', error); + } finally { + loadingAlbums = false; } - }); + } + + onMount(loadAlbums); -{#each albums as album} - -
-
-
-
- {album.albumName} +{#if !loadingAlbums} + {#each albums as album} + +
+
+
+
+ {album.albumName} +
+
+ {/each} +{:else} + {#each { length: 3 } as _} +
+
+
+
+
- -{/each} + {/each} +{/if}