avatar-selector.svelte 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. <script lang="ts">
  2. import { mdiClose } from '@mdi/js';
  3. import { createEventDispatcher } from 'svelte';
  4. import { UserDtoAvatarColorEnum, UserResponseDto } from '@api';
  5. import CircleIconButton from '$lib/components/elements/buttons/circle-icon-button.svelte';
  6. import FullScreenModal from '../full-screen-modal.svelte';
  7. import UserAvatar from '../user-avatar.svelte';
  8. export let user: UserResponseDto;
  9. const dispatch = createEventDispatcher();
  10. const colors: Array<UserDtoAvatarColorEnum> = Object.values(UserDtoAvatarColorEnum);
  11. </script>
  12. <FullScreenModal on:clickOutside={() => dispatch('close')} on:escape={() => dispatch('close')}>
  13. <div class="flex h-full w-full place-content-center place-items-center overflow-hidden">
  14. <div
  15. class=" rounded-3xl border bg-immich-bg shadow-sm dark:border-immich-dark-gray dark:bg-immich-dark-gray dark:text-immich-dark-fg"
  16. >
  17. <div class="flex px-2 pt-2 items-center">
  18. <h1 class="px-4 w-full self-center font-medium text-immich-primary dark:text-immich-dark-primary">
  19. Select avatar color
  20. </h1>
  21. <div>
  22. <CircleIconButton icon={mdiClose} on:click={() => dispatch('close')} />
  23. </div>
  24. </div>
  25. <div class="flex items-center justify-center p-4">
  26. <div class="grid grid-cols-2 md:grid-cols-5 gap-4">
  27. {#each colors as color}
  28. <div>
  29. <button on:click={() => dispatch('choose', color)}>
  30. <UserAvatar {user} {color} size="xl" showProfileImage={false} />
  31. </button>
  32. </div>
  33. {/each}
  34. </div>
  35. </div>
  36. </div>
  37. </div>
  38. </FullScreenModal>