2023-01-27 09:32:26 -05:00
|
|
|
<script lang="ts">
|
2023-04-07 18:45:00 +02:00
|
|
|
import CircleIconButton from '$lib/components/elements/buttons/circle-icon-button.svelte';
|
2023-01-27 09:32:26 -05:00
|
|
|
import ControlAppBar from '$lib/components/shared-components/control-app-bar.svelte';
|
|
|
|
|
import CreateSharedLinkModal from '$lib/components/shared-components/create-share-link-modal/create-shared-link-modal.svelte';
|
|
|
|
|
import GalleryViewer from '$lib/components/shared-components/gallery-viewer/gallery-viewer.svelte';
|
|
|
|
|
import { handleError } from '$lib/utils/handle-error';
|
|
|
|
|
import { api, AssetResponseDto, SharedLinkType } from '@api';
|
|
|
|
|
import { onMount } from 'svelte';
|
|
|
|
|
import Close from 'svelte-material-icons/Close.svelte';
|
|
|
|
|
import ShareVariantOutline from 'svelte-material-icons/ShareVariantOutline.svelte';
|
2023-05-08 21:01:39 +02:00
|
|
|
import HeartMinusOutline from 'svelte-material-icons/HeartMinusOutline.svelte';
|
2023-02-27 04:23:43 +01:00
|
|
|
import Error from '../../+error.svelte';
|
2023-04-12 18:37:52 +03:00
|
|
|
import EmptyPlaceholder from '$lib/components/shared-components/empty-placeholder.svelte';
|
2023-03-18 22:31:15 +01:00
|
|
|
import UserPageLayout from '$lib/components/layouts/user-page-layout.svelte';
|
|
|
|
|
import type { PageData } from './$types';
|
2023-01-27 09:32:26 -05:00
|
|
|
|
|
|
|
|
let favorites: AssetResponseDto[] = [];
|
|
|
|
|
let isShowCreateSharedLinkModal = false;
|
|
|
|
|
let selectedAssets: Set<AssetResponseDto> = new Set();
|
|
|
|
|
|
2023-03-18 22:31:15 +01:00
|
|
|
export let data: PageData;
|
|
|
|
|
|
2023-01-27 09:32:26 -05:00
|
|
|
$: isMultiSelectionMode = selectedAssets.size > 0;
|
|
|
|
|
|
|
|
|
|
onMount(async () => {
|
|
|
|
|
try {
|
2023-04-12 18:37:52 +03:00
|
|
|
const { data: assets } = await api.assetApi.getAllAssets(true, undefined);
|
2023-01-27 09:32:26 -05:00
|
|
|
favorites = assets;
|
|
|
|
|
} catch {
|
|
|
|
|
handleError(Error, 'Unable to load favorites');
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const clearMultiSelectAssetAssetHandler = () => {
|
|
|
|
|
selectedAssets = new Set();
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleCreateSharedLink = async () => {
|
|
|
|
|
isShowCreateSharedLinkModal = true;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleCloseSharedLinkModal = () => {
|
|
|
|
|
clearMultiSelectAssetAssetHandler();
|
|
|
|
|
isShowCreateSharedLinkModal = false;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleRemoveFavorite = async () => {
|
|
|
|
|
for (const asset of selectedAssets) {
|
|
|
|
|
try {
|
|
|
|
|
await api.assetApi.updateAsset(asset.id, {
|
|
|
|
|
isFavorite: false
|
|
|
|
|
});
|
|
|
|
|
favorites = favorites.filter((a) => a.id != asset.id);
|
|
|
|
|
} catch {
|
|
|
|
|
handleError(Error, 'Error updating asset favorite state');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
clearMultiSelectAssetAssetHandler();
|
|
|
|
|
};
|
|
|
|
|
</script>
|
|
|
|
|
|
2023-03-18 22:31:15 +01:00
|
|
|
<!-- Multiselection mode app bar -->
|
|
|
|
|
{#if isMultiSelectionMode}
|
|
|
|
|
<ControlAppBar
|
|
|
|
|
on:close-button-click={clearMultiSelectAssetAssetHandler}
|
|
|
|
|
backIcon={Close}
|
|
|
|
|
tailwindClasses={'bg-white shadow-md'}
|
|
|
|
|
>
|
|
|
|
|
<svelte:fragment slot="leading">
|
|
|
|
|
<p class="font-medium text-immich-primary dark:text-immich-dark-primary">
|
|
|
|
|
Selected {selectedAssets.size}
|
|
|
|
|
</p>
|
|
|
|
|
</svelte:fragment>
|
|
|
|
|
<svelte:fragment slot="trailing">
|
|
|
|
|
<CircleIconButton
|
|
|
|
|
title="Share"
|
|
|
|
|
logo={ShareVariantOutline}
|
|
|
|
|
on:click={handleCreateSharedLink}
|
|
|
|
|
/>
|
|
|
|
|
<CircleIconButton
|
|
|
|
|
title="Remove Favorite"
|
2023-05-08 21:01:39 +02:00
|
|
|
logo={HeartMinusOutline}
|
2023-03-18 22:31:15 +01:00
|
|
|
on:click={handleRemoveFavorite}
|
|
|
|
|
/>
|
|
|
|
|
</svelte:fragment>
|
|
|
|
|
</ControlAppBar>
|
|
|
|
|
{/if}
|
|
|
|
|
|
|
|
|
|
<!-- Create shared link modal -->
|
|
|
|
|
{#if isShowCreateSharedLinkModal}
|
|
|
|
|
<CreateSharedLinkModal
|
|
|
|
|
sharedAssets={Array.from(selectedAssets)}
|
|
|
|
|
shareType={SharedLinkType.Individual}
|
|
|
|
|
on:close={handleCloseSharedLinkModal}
|
|
|
|
|
/>
|
|
|
|
|
{/if}
|
|
|
|
|
|
2023-04-12 18:37:52 +03:00
|
|
|
<UserPageLayout user={data.user} hideNavbar={isMultiSelectionMode}>
|
2023-03-18 22:31:15 +01:00
|
|
|
<section>
|
|
|
|
|
<!-- Empty Message -->
|
|
|
|
|
{#if favorites.length === 0}
|
2023-04-12 18:37:52 +03:00
|
|
|
<EmptyPlaceholder
|
|
|
|
|
text="Add favorites to quickly find your best pictures and videos"
|
|
|
|
|
alt="Empty favorites"
|
|
|
|
|
/>
|
2023-03-18 22:31:15 +01:00
|
|
|
{/if}
|
2023-01-27 09:32:26 -05:00
|
|
|
|
2023-04-20 09:09:27 -05:00
|
|
|
<GalleryViewer assets={favorites} bind:selectedAssets viewFrom="favorites-page" />
|
2023-01-27 09:32:26 -05:00
|
|
|
</section>
|
2023-03-18 22:31:15 +01:00
|
|
|
</UserPageLayout>
|