2023-11-14 04:10:35 +01:00
|
|
|
<script lang="ts">
|
2024-02-14 06:38:57 -08:00
|
|
|
import { UserAvatarColor, type UserResponseDto } from '@immich/sdk';
|
2023-11-14 04:10:35 +01:00
|
|
|
import { createEventDispatcher } from 'svelte';
|
|
|
|
|
import FullScreenModal from '../full-screen-modal.svelte';
|
|
|
|
|
import UserAvatar from '../user-avatar.svelte';
|
2024-06-04 21:53:00 +02:00
|
|
|
import { t } from 'svelte-i18n';
|
2023-11-14 04:10:35 +01:00
|
|
|
|
|
|
|
|
export let user: UserResponseDto;
|
|
|
|
|
|
2023-12-14 17:55:15 +01:00
|
|
|
const dispatch = createEventDispatcher<{
|
|
|
|
|
close: void;
|
|
|
|
|
choose: UserAvatarColor;
|
|
|
|
|
}>();
|
2023-11-14 04:10:35 +01:00
|
|
|
const colors: UserAvatarColor[] = Object.values(UserAvatarColor);
|
|
|
|
|
</script>
|
|
|
|
|
|
2024-06-04 21:53:00 +02:00
|
|
|
<FullScreenModal title={$t('select_avatar_color')} width="auto" onClose={() => dispatch('close')}>
|
2024-04-08 21:02:09 +00:00
|
|
|
<div class="flex items-center justify-center mt-4">
|
|
|
|
|
<div class="grid grid-cols-2 md:grid-cols-5 gap-4">
|
|
|
|
|
{#each colors as color}
|
2024-05-27 09:06:15 +02:00
|
|
|
<button type="button" on:click={() => dispatch('choose', color)}>
|
2024-04-08 21:02:09 +00:00
|
|
|
<UserAvatar label={color} {user} {color} size="xl" showProfileImage={false} />
|
|
|
|
|
</button>
|
|
|
|
|
{/each}
|
2023-11-14 04:10:35 +01:00
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</FullScreenModal>
|