aboutsummaryrefslogtreecommitdiffstats
path: root/code/frontend/src/components/ui/dropdown-menu/dropdown-menu-sub-content.svelte
diff options
context:
space:
mode:
Diffstat (limited to 'code/frontend/src/components/ui/dropdown-menu/dropdown-menu-sub-content.svelte')
-rw-r--r--code/frontend/src/components/ui/dropdown-menu/dropdown-menu-sub-content.svelte29
1 files changed, 29 insertions, 0 deletions
diff --git a/code/frontend/src/components/ui/dropdown-menu/dropdown-menu-sub-content.svelte b/code/frontend/src/components/ui/dropdown-menu/dropdown-menu-sub-content.svelte
new file mode 100644
index 0000000..7c00a1b
--- /dev/null
+++ b/code/frontend/src/components/ui/dropdown-menu/dropdown-menu-sub-content.svelte
@@ -0,0 +1,29 @@
+<script lang="ts">
+ import { DropdownMenu as DropdownMenuPrimitive } from 'bits-ui'
+ import { cn, flyAndScale } from '$utils/ui'
+
+ type $$Props = DropdownMenuPrimitive.SubContentProps
+
+ let className: $$Props['class'] = undefined
+ export let transition: $$Props['transition'] = flyAndScale
+ export let transitionConfig: $$Props['transitionConfig'] = {
+ x: -10,
+ y: 0
+ }
+ export { className as class }
+</script>
+
+<DropdownMenuPrimitive.SubContent
+ {transition}
+ {transitionConfig}
+ class={cn(
+ 'z-50 min-w-[8rem] rounded-md border bg-popover p-1 text-popover-foreground shadow-lg focus:outline-none',
+ className
+ )}
+ {...$$restProps}
+ on:keydown
+ on:focusout
+ on:pointermove
+>
+ <slot />
+</DropdownMenuPrimitive.SubContent>