mirror of
https://github.com/immich-app/immich
synced 2025-11-14 17:36:12 +00:00
* chore(web): another missing translations * unused removed * more keys * lint fix * test fixed * dynamic translation fix * fixes * people search translation * params fixed * keep filter setting fix * lint fix * $t fixes * Update web/src/lib/i18n/en.json Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com> * another missing * activity translation * link sharing translations * expiration dropdown fix - didn't work localized * notification title * device logout * search results * reset to default * unsaved change * select from computer * selected * select-2 * select-3 * unmerge * pluralize, force icu message * Update web/src/lib/components/asset-viewer/asset-viewer.svelte Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com> * review fixes * remove user * plural fixes * ffmpeg settings * fixes * error title * plural fixes * onboarding * change password * more more * console log fix * another * api key desc * map marker * format fix * key fix * asset-utils * utils * misc --------- Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com>
102 lines
3.7 KiB
Svelte
102 lines
3.7 KiB
Svelte
<script lang="ts">
|
|
import Icon from '$lib/components/elements/icon.svelte';
|
|
import { updateAlbumInfo, type AlbumResponseDto, type UserResponseDto, AssetOrder } from '@immich/sdk';
|
|
import { mdiArrowDownThin, mdiArrowUpThin, mdiPlus } from '@mdi/js';
|
|
import { createEventDispatcher } from 'svelte';
|
|
import FullScreenModal from '$lib/components/shared-components/full-screen-modal.svelte';
|
|
import UserAvatar from '$lib/components/shared-components/user-avatar.svelte';
|
|
import SettingSwitch from '$lib/components/shared-components/settings/setting-switch.svelte';
|
|
import SettingDropdown from '../shared-components/settings/setting-dropdown.svelte';
|
|
import type { RenderedOption } from '../elements/dropdown.svelte';
|
|
import { handleError } from '$lib/utils/handle-error';
|
|
import { findKey } from 'lodash-es';
|
|
import { t } from 'svelte-i18n';
|
|
|
|
export let album: AlbumResponseDto;
|
|
export let order: AssetOrder | undefined;
|
|
export let user: UserResponseDto;
|
|
export let onChangeOrder: (order: AssetOrder) => void;
|
|
|
|
const options: Record<AssetOrder, RenderedOption> = {
|
|
[AssetOrder.Asc]: { icon: mdiArrowUpThin, title: $t('oldest_first') },
|
|
[AssetOrder.Desc]: { icon: mdiArrowDownThin, title: $t('newest_first') },
|
|
};
|
|
|
|
$: selectedOption = order ? options[order] : options[AssetOrder.Desc];
|
|
|
|
const dispatch = createEventDispatcher<{
|
|
close: void;
|
|
toggleEnableActivity: void;
|
|
showSelectSharedUser: void;
|
|
}>();
|
|
|
|
const handleToggle = async (returnedOption: RenderedOption) => {
|
|
if (selectedOption === returnedOption) {
|
|
return;
|
|
}
|
|
let order = AssetOrder.Desc;
|
|
order = findKey(options, (option) => option === returnedOption) as AssetOrder;
|
|
|
|
try {
|
|
await updateAlbumInfo({
|
|
id: album.id,
|
|
updateAlbumDto: {
|
|
order,
|
|
},
|
|
});
|
|
onChangeOrder(order);
|
|
} catch (error) {
|
|
handleError(error, $t('errors.unable_to_save_album'));
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<FullScreenModal title={$t('options')} onClose={() => dispatch('close')}>
|
|
<div class="items-center justify-center">
|
|
<div class="py-2">
|
|
<h2 class="text-gray text-sm mb-2">{$t('settings').toUpperCase()}</h2>
|
|
<div class="grid p-2 gap-y-2">
|
|
{#if order}
|
|
<SettingDropdown
|
|
title={$t('display_order')}
|
|
options={Object.values(options)}
|
|
selectedOption={options[order]}
|
|
onToggle={handleToggle}
|
|
/>
|
|
{/if}
|
|
<SettingSwitch
|
|
title={$t('comments_and_likes')}
|
|
subtitle={$t('let_others_respond')}
|
|
checked={album.isActivityEnabled}
|
|
on:toggle={() => dispatch('toggleEnableActivity')}
|
|
/>
|
|
</div>
|
|
</div>
|
|
<div class="py-2">
|
|
<div class="text-gray text-sm mb-3">{$t('people').toUpperCase()}</div>
|
|
<div class="p-2">
|
|
<button type="button" class="flex items-center gap-2" on:click={() => dispatch('showSelectSharedUser')}>
|
|
<div class="rounded-full w-10 h-10 border border-gray-500 flex items-center justify-center">
|
|
<div><Icon path={mdiPlus} size="25" /></div>
|
|
</div>
|
|
<div>{$t('invite_people')}</div>
|
|
</button>
|
|
<div class="flex items-center gap-2 py-2 mt-2">
|
|
<div>
|
|
<UserAvatar {user} size="md" />
|
|
</div>
|
|
<div class="w-full">{user.name}</div>
|
|
<div>{$t('owner')}</div>
|
|
</div>
|
|
{#each album.albumUsers as { user } (user.id)}
|
|
<div class="flex items-center gap-2 py-2">
|
|
<div>
|
|
<UserAvatar {user} size="md" />
|
|
</div>
|
|
<div class="w-full">{user.name}</div>
|
|
</div>
|
|
{/each}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</FullScreenModal>
|