2022-11-24 16:34:05 +08:00
|
|
|
<script setup lang="ts">
|
2024-10-21 05:00:51 -04:00
|
|
|
const {
|
|
|
|
is = 'div',
|
|
|
|
text,
|
|
|
|
description,
|
|
|
|
icon,
|
|
|
|
checked,
|
|
|
|
command,
|
|
|
|
} = defineProps<{
|
2023-01-22 17:57:30 +08:00
|
|
|
is?: string
|
2022-11-29 16:15:05 +08:00
|
|
|
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
|
2022-11-29 16:15:05 +08:00
|
|
|
command?: boolean
|
2024-10-21 05:00:51 -04:00
|
|
|
}>()
|
|
|
|
|
2022-11-24 16:34:05 +08:00
|
|
|
const emit = defineEmits(['click'])
|
|
|
|
|
2024-10-21 05:00:51 -04:00
|
|
|
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
|
|
|
|
2022-11-29 16:15:05 +08:00
|
|
|
const el = ref<HTMLDivElement>()
|
|
|
|
|
2023-03-30 19:01:24 +00:00
|
|
|
function handleClick(evt: MouseEvent) {
|
2022-11-26 13:05:44 +08:00
|
|
|
hide?.()
|
2022-11-24 16:34:05 +08:00
|
|
|
emit('click', evt)
|
|
|
|
}
|
2022-11-29 16:15:05 +08:00
|
|
|
|
|
|
|
useCommand({
|
|
|
|
scope: 'Actions',
|
|
|
|
|
|
|
|
order: -1,
|
2024-10-21 05:00:51 -04:00
|
|
|
visible: () => command && text,
|
2022-11-29 16:15:05 +08:00
|
|
|
|
2024-10-21 05:00:51 -04:00
|
|
|
name: () => text!,
|
|
|
|
icon: () => icon ?? 'i-ri:question-line',
|
|
|
|
description: () => description,
|
2022-11-29 16:15:05 +08:00
|
|
|
|
|
|
|
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"
|
2024-10-21 05:00:51 -04:00
|
|
|
:type="type"
|
2023-01-31 11:43:12 +08:00
|
|
|
w-full
|
2022-11-29 16:15:05 +08:00
|
|
|
flex gap-3 items-center cursor-pointer px4 py3
|
2023-01-17 04:17:47 +08:00
|
|
|
select-none
|
2022-11-29 16:15:05 +08:00
|
|
|
hover-bg-active
|
2022-11-30 21:00:54 +08:00
|
|
|
: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>
|
2022-11-29 16:15:05 +08:00
|
|
|
<slot>
|
|
|
|
{{ text }}
|
|
|
|
</slot>
|
2022-11-24 17:15:58 +08:00
|
|
|
</div>
|
2022-11-26 21:41:18 +01:00
|
|
|
<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>
|