Files
gpx.studio/website/src/lib/components/ui/context-menu/context-menu-content.svelte

26 lines
1.1 KiB
Svelte
Raw Normal View History

2024-04-29 17:03:23 +02:00
<script lang="ts">
import { ContextMenu as ContextMenuPrimitive } from "bits-ui";
2025-06-08 16:32:41 +02:00
import { cn } from "$lib/utils.js";
2024-04-29 17:03:23 +02:00
2025-06-08 16:32:41 +02:00
let {
ref = $bindable(null),
portalProps,
class: className,
...restProps
}: ContextMenuPrimitive.ContentProps & {
portalProps?: ContextMenuPrimitive.PortalProps;
} = $props();
2024-04-29 17:03:23 +02:00
</script>
2025-06-08 16:32:41 +02:00
<ContextMenuPrimitive.Portal {...portalProps}>
<ContextMenuPrimitive.Content
bind:ref
2025-06-21 21:07:36 +02:00
data-slot="context-menu-content"
2025-06-08 16:32:41 +02:00
class={cn(
2025-06-21 21:07:36 +02:00
"bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 max-h-(--bits-context-menu-content-available-height) origin-(--bits-context-menu-content-transform-origin) z-50 min-w-[8rem] overflow-y-auto overflow-x-hidden rounded-md border p-1 shadow-md",
2025-06-08 16:32:41 +02:00
className
)}
{...restProps}
/>
</ContextMenuPrimitive.Portal>