mirror of
https://github.com/immich-app/immich.git
synced 2025-03-01 15:11:21 +01:00
101 lines
3.7 KiB
Svelte
101 lines
3.7 KiB
Svelte
<script lang="ts">
|
|
import { goto } from '$app/navigation';
|
|
import empty2Url from '$lib/assets/empty-2.svg';
|
|
import AlbumCard from '$lib/components/album-page/album-card.svelte';
|
|
import LinkButton from '$lib/components/elements/buttons/link-button.svelte';
|
|
import Icon from '$lib/components/elements/icon.svelte';
|
|
import UserPageLayout from '$lib/components/layouts/user-page-layout.svelte';
|
|
import EmptyPlaceholder from '$lib/components/shared-components/empty-placeholder.svelte';
|
|
import UserAvatar from '$lib/components/shared-components/user-avatar.svelte';
|
|
import { AppRoute } from '$lib/constants';
|
|
import { createAlbum } from '@immich/sdk';
|
|
import { mdiLink, mdiPlusBoxOutline } from '@mdi/js';
|
|
import { flip } from 'svelte/animate';
|
|
import { handleError } from '../../../lib/utils/handle-error';
|
|
import type { PageData } from './$types';
|
|
|
|
export let data: PageData;
|
|
|
|
const createSharedAlbum = async () => {
|
|
try {
|
|
const newAlbum = await createAlbum({ createAlbumDto: { albumName: '' } });
|
|
await goto(`${AppRoute.ALBUMS}/${newAlbum.id}`);
|
|
} catch (error) {
|
|
handleError(error, 'Unable to create album');
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<UserPageLayout title={data.meta.title}>
|
|
<div class="flex" slot="buttons">
|
|
<LinkButton on:click={createSharedAlbum}>
|
|
<div class="flex flex-wrap place-items-center justify-center gap-x-1 text-sm">
|
|
<Icon path={mdiPlusBoxOutline} size="18" class="shrink-0" />
|
|
<span class="leading-none max-sm:text-xs">Create shared album</span>
|
|
</div>
|
|
</LinkButton>
|
|
|
|
<LinkButton on:click={() => goto(AppRoute.SHARED_LINKS)}>
|
|
<div class="flex flex-wrap place-items-center justify-center gap-x-1 text-sm">
|
|
<Icon path={mdiLink} size="18" class="shrink-0" />
|
|
<span class="leading-none max-sm:text-xs">Shared links</span>
|
|
</div>
|
|
</LinkButton>
|
|
</div>
|
|
|
|
<div class="flex flex-col">
|
|
{#if data.partners.length > 0}
|
|
<div class="mb-6 mt-2">
|
|
<div>
|
|
<p class="mb-4 font-medium dark:text-immich-dark-fg">Partners</p>
|
|
</div>
|
|
|
|
<div class="flex flex-row flex-wrap gap-4">
|
|
{#each data.partners as partner (partner.id)}
|
|
<a
|
|
href="{AppRoute.PARTNERS}/{partner.id}"
|
|
class="flex gap-4 rounded-lg px-5 py-4 transition-all hover:bg-gray-200 dark:hover:bg-gray-700"
|
|
>
|
|
<UserAvatar user={partner} size="lg" />
|
|
<div class="text-left">
|
|
<p class="text-immich-fg dark:text-immich-dark-fg">
|
|
{partner.name}
|
|
</p>
|
|
<p class="text-sm text-immich-fg/75 dark:text-immich-dark-fg/75">
|
|
{partner.email}
|
|
</p>
|
|
</div>
|
|
</a>
|
|
{/each}
|
|
</div>
|
|
</div>
|
|
|
|
<hr class="mb-4 dark:border-immich-dark-gray" />
|
|
{/if}
|
|
|
|
<div class="mb-6 mt-2">
|
|
<div>
|
|
<p class="mb-4 font-medium dark:text-immich-dark-fg">Albums</p>
|
|
</div>
|
|
|
|
<div>
|
|
<!-- Share Album List -->
|
|
<div class="grid grid-cols-[repeat(auto-fill,minmax(14rem,1fr))] mt-4 gap-y-4">
|
|
{#each data.sharedAlbums as album, index (album.id)}
|
|
<a data-sveltekit-preload-data="hover" href={`albums/${album.id}`} animate:flip={{ duration: 200 }}>
|
|
<AlbumCard preload={index < 20} {album} isSharingView />
|
|
</a>
|
|
{/each}
|
|
</div>
|
|
|
|
<!-- Empty List -->
|
|
{#if data.sharedAlbums.length === 0}
|
|
<EmptyPlaceholder
|
|
text="Create a shared album to share photos and videos with people in your network"
|
|
src={empty2Url}
|
|
/>
|
|
{/if}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</UserPageLayout>
|