DropdownMenuContent.vue 1.4 KB

123456789101112131415161718192021222324252627282930313233343536
  1. <script setup lang="ts">
  2. import type { DropdownMenuContentEmits, DropdownMenuContentProps } from "reka-ui"
  3. import type { HTMLAttributes } from "vue"
  4. import { reactiveOmit } from "@vueuse/core"
  5. import {
  6. DropdownMenuContent,
  7. DropdownMenuPortal,
  8. useForwardPropsEmits,
  9. } from "reka-ui"
  10. import { cn } from '@/Packages/Shadcn/Lib/utils'
  11. const props = withDefaults(
  12. defineProps<DropdownMenuContentProps & { class?: HTMLAttributes["class"] }>(),
  13. {
  14. sideOffset: 4,
  15. },
  16. )
  17. const emits = defineEmits<DropdownMenuContentEmits>()
  18. const delegatedProps = reactiveOmit(props, "class")
  19. const forwarded = useForwardPropsEmits(delegatedProps, emits)
  20. </script>
  21. <template>
  22. <DropdownMenuPortal>
  23. <DropdownMenuContent
  24. data-slot="dropdown-menu-content"
  25. v-bind="forwarded"
  26. :class="cn('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 z-50 max-h-(--reka-dropdown-menu-content-available-height) min-w-[8rem] origin-(--reka-dropdown-menu-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border p-1 shadow-md', props.class)"
  27. >
  28. <slot />
  29. </DropdownMenuContent>
  30. </DropdownMenuPortal>
  31. </template>