side-bar-button.svelte 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <script lang="ts">
  2. import type Icon from 'svelte-material-icons/AbTesting.svelte';
  3. import InformationOutline from 'svelte-material-icons/InformationOutline.svelte';
  4. import { fade } from 'svelte/transition';
  5. import { createEventDispatcher } from 'svelte';
  6. export let title: string;
  7. export let logo: typeof Icon;
  8. export let isSelected: boolean;
  9. export let flippedLogo = false;
  10. let showMoreInformation = false;
  11. const dispatch = createEventDispatcher();
  12. const onButtonClicked = () => dispatch('selected');
  13. </script>
  14. <!-- svelte-ignore a11y-no-static-element-interactions -->
  15. <div
  16. on:click={onButtonClicked}
  17. on:keydown={onButtonClicked}
  18. class="flex w-full place-items-center justify-between gap-4 rounded-r-full py-3 transition-[padding] delay-100 duration-100 hover:cursor-pointer hover:bg-immich-gray hover:text-immich-primary dark:text-immich-dark-fg dark:hover:bg-immich-dark-gray dark:hover:text-immich-dark-primary
  19. {isSelected
  20. ? 'bg-immich-primary/10 text-immich-primary hover:bg-immich-primary/25 dark:bg-immich-dark-primary/10 dark:text-immich-dark-primary'
  21. : ''}
  22. pl-5 group-hover:sm:px-5 md:px-5
  23. "
  24. >
  25. <div class="flex w-full place-items-center gap-4 overflow-hidden truncate">
  26. <svelte:component this={logo} size="1.5em" class="shrink-0 {flippedLogo ? '-scale-x-100' : ''}" />
  27. <p class="text-sm font-medium">{title}</p>
  28. </div>
  29. <div
  30. class="h-0 overflow-hidden transition-[height] delay-1000 duration-100 sm:group-hover:h-auto group-hover:sm:overflow-visible md:h-auto md:overflow-visible"
  31. >
  32. {#if $$slots.moreInformation}
  33. <div
  34. class="relative flex cursor-default select-none justify-center"
  35. on:mouseenter={() => (showMoreInformation = true)}
  36. on:mouseleave={() => (showMoreInformation = false)}
  37. >
  38. <div class="p-1 text-gray-600 hover:cursor-help dark:text-gray-400">
  39. <InformationOutline />
  40. </div>
  41. {#if showMoreInformation}
  42. <div class="absolute right-6 top-0">
  43. <div
  44. class="flex place-content-center place-items-center whitespace-nowrap rounded-3xl border bg-immich-bg px-6 py-3 text-xs text-immich-fg shadow-lg dark:border-immich-dark-gray dark:bg-gray-600 dark:text-immich-dark-fg"
  45. class:hidden={!showMoreInformation}
  46. transition:fade={{ duration: 200 }}
  47. >
  48. <slot name="moreInformation" />
  49. </div>
  50. </div>
  51. {/if}
  52. </div>
  53. {/if}
  54. </div>
  55. </div>