shadcn-vue/apps/www/src/lib/registry/default/ui/dropdown-menu/DropdownMenuItem.vue
2023-08-29 22:35:58 +02:00

38 lines
1.1 KiB
Vue

<script setup lang="ts">
import { computed, useAttrs } from 'vue'
import { type DropdownMenuItemEmits, DropdownMenuItem as DropdownMenuItemPrimitive, type DropdownMenuItemProps } from 'radix-vue'
import { cn, useEmitAsProps } from '@/utils'
defineOptions({
name: 'DropdownMenuItem',
inheritAttrs: false,
})
const props = defineProps<DropdownMenuItemProps & {
inset?: boolean
}>()
const emits = defineEmits<DropdownMenuItemEmits>()
const emitsAsProps = useEmitAsProps(emits)
const allAttrs = useAttrs()
const attrs = computed(() => {
const { class: className, ...rest } = allAttrs
return {
className,
rest,
}
})
</script>
<template>
<DropdownMenuItemPrimitive
:class="cn(
'relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50',
inset && 'pl-8',
attrs.className ?? '',
)"
v-bind="{ ...attrs.rest, ...props, ...emitsAsProps }"
>
<slot />
</DropdownMenuItemPrimitive>
</template>