| <script lang="ts"> |
| import { tooltip } from '$lib/actions/tooltip'; |
| import type { Placement } from '@floating-ui/dom'; |
| |
| |
| interface Props { |
| class?: string; |
| placement: Placement; |
| trigger?: import('svelte').Snippet; |
| children?: import('svelte').Snippet<[any]>; |
| } |
| |
| let { |
| class: className = '', |
| placement, |
| trigger, |
| children |
| }: Props = $props(); |
| |
| let tooltipRef = $state<HTMLDivElement | null>(null); |
| |
| const closeTooltip = () => tooltipRef?.dispatchEvent(new Event('closeTooltip')); |
| </script> |
| |
| <div class={className} use:tooltip={{ placement, clickable: true }}> |
| {@render trigger?.()} |
| |
| <div class="tooltip" bind:this={tooltipRef}> |
| <div class="z-50"> |
| {@render children?.({ close: closeTooltip, })} |
| </div> |
| </div> |
| </div> |
| |
| <!-- {#each itemGroups as group} |
| <div class="px-1 py-1"> |
| {#each group as { action, icon, className, label }} |
| <button |
| onclick={() => { |
| if (action) { |
| action(() => tooltipRef.dispatchEvent(new Event('closeTooltip'))); |
| } |
| }} |
| class={twMerge( |
| ' grid grid-cols-[20px,1fr] gap-x-1 rounded-md items-center w-full px-2 py-2 text-sm text-color cursor-default', |
| action && 'hoverable cursor-pointer' |
| )} |
| > |
| <span> |
| <Icon name={icon} class="w-[17px] h-[17px] stroke-white" /> |
| </span> |
| <span class={twMerge('text-left', className)}> |
| {label} |
| </span> |
| </button> |
| {/each} |
| </div> |
| {/each} --> |