2023-05-16 16:13:20 +02:00
|
|
|
<script lang="ts" context="module">
|
2023-07-01 00:50:47 -04:00
|
|
|
import { createContext } from '$lib/utils/context';
|
2023-05-16 16:13:20 +02:00
|
|
|
|
2023-07-01 00:50:47 -04:00
|
|
|
export type OnAssetDelete = (assetId: string) => void;
|
2023-10-06 07:01:14 +00:00
|
|
|
export type OnRestore = (ids: string[]) => void;
|
2023-08-16 16:04:55 -04:00
|
|
|
export type OnArchive = (ids: string[], isArchived: boolean) => void;
|
|
|
|
|
export type OnFavorite = (ids: string[], favorite: boolean) => void;
|
2023-05-16 16:13:20 +02:00
|
|
|
|
2023-07-01 00:50:47 -04:00
|
|
|
export interface AssetControlContext {
|
|
|
|
|
// Wrap assets in a function, because context isn't reactive.
|
|
|
|
|
getAssets: () => Set<AssetResponseDto>;
|
|
|
|
|
clearSelect: () => void;
|
|
|
|
|
}
|
2023-05-16 16:13:20 +02:00
|
|
|
|
2023-07-01 00:50:47 -04:00
|
|
|
const { get: getAssetControlContext, set: setContext } = createContext<AssetControlContext>();
|
|
|
|
|
export { getAssetControlContext };
|
2023-05-16 16:13:20 +02:00
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<script lang="ts">
|
2023-07-01 00:50:47 -04:00
|
|
|
import { locale } from '$lib/stores/preferences.store';
|
|
|
|
|
import type { AssetResponseDto } from '@api';
|
|
|
|
|
import ControlAppBar from '../shared-components/control-app-bar.svelte';
|
2023-10-25 09:48:25 -04:00
|
|
|
import { mdiClose } from '@mdi/js';
|
2023-05-16 16:13:20 +02:00
|
|
|
|
2023-07-01 00:50:47 -04:00
|
|
|
export let assets: Set<AssetResponseDto>;
|
|
|
|
|
export let clearSelect: () => void;
|
2023-05-16 16:13:20 +02:00
|
|
|
|
2023-07-01 00:50:47 -04:00
|
|
|
setContext({ getAssets: () => assets, clearSelect });
|
2023-05-16 16:13:20 +02:00
|
|
|
</script>
|
|
|
|
|
|
2023-10-25 09:48:25 -04:00
|
|
|
<ControlAppBar on:close-button-click={clearSelect} backIcon={mdiClose} tailwindClasses="bg-white shadow-md">
|
2023-07-01 00:50:47 -04:00
|
|
|
<p class="font-medium text-immich-primary dark:text-immich-dark-primary" slot="leading">
|
|
|
|
|
Selected {assets.size.toLocaleString($locale)}
|
|
|
|
|
</p>
|
|
|
|
|
<slot slot="trailing" />
|
2023-05-16 16:13:20 +02:00
|
|
|
</ControlAppBar>
|