elk/components/common/dropdown/DropdownItem.vue

87 lines
1.5 KiB
Vue
Raw Normal View History

2022-11-24 16:34:05 +08:00
<script setup lang="ts">
const {
is = 'div',
text,
description,
icon,
checked,
command,
} = defineProps<{
2023-01-22 17:57:30 +08:00
is?: string
text?: string
2022-11-24 17:15:58 +08:00
description?: string
2022-11-24 16:34:05 +08:00
icon?: string
2022-11-24 17:15:58 +08:00
checked?: boolean
command?: boolean
}>()
2022-11-24 16:34:05 +08:00
const emit = defineEmits(['click'])
const type = computed(() => is === 'button' ? 'button' : null)
2023-01-03 19:58:08 +08:00
const { hide } = useDropdownContext() || {}
2022-11-24 16:34:05 +08:00
const el = ref<HTMLDivElement>()
function handleClick(evt: MouseEvent) {
2022-11-26 13:05:44 +08:00
hide?.()
2022-11-24 16:34:05 +08:00
emit('click', evt)
}
useCommand({
scope: 'Actions',
order: -1,
visible: () => command && text,
name: () => text!,
icon: () => icon ?? 'i-ri:question-line',
description: () => description,
onActivate() {
const clickEvent = new MouseEvent('click', {
view: window,
bubbles: true,
cancelable: true,
})
el.value?.dispatchEvent(clickEvent)
},
})
2022-11-24 16:34:05 +08:00
</script>
<template>
2023-01-22 17:57:30 +08:00
<component
v-bind="$attrs"
:is="is"
ref="el"
:type="type"
w-full
flex gap-3 items-center cursor-pointer px4 py3
select-none
hover-bg-active
:aria-label="text"
2022-11-24 17:15:58 +08:00
@click="handleClick"
>
2022-11-24 16:34:05 +08:00
<div v-if="icon" :class="icon" />
2022-11-24 17:15:58 +08:00
<div flex="~ col">
2022-11-26 13:05:44 +08:00
<div text-15px>
<slot>
{{ text }}
</slot>
2022-11-24 17:15:58 +08:00
</div>
<div text-3 text-secondary>
2022-11-24 17:15:58 +08:00
<slot name="description">
<p v-if="description">
{{ description }}
</p>
</slot>
</div>
</div>
<div flex-auto />
<div v-if="checked" i-ri:check-line />
2022-11-26 20:58:10 +08:00
<slot name="actions" />
2023-01-22 17:57:30 +08:00
</component>
2022-11-24 16:34:05 +08:00
</template>