|
|
|
<script setup lang="ts">
|
|
|
|
const { isUIAllowed } = useRoles()
|
|
|
|
|
|
|
|
const { groupingFieldColumn } = useKanbanViewStoreOrThrow()
|
|
|
|
|
|
|
|
const isLocked = inject(IsLockedInj, ref(false))
|
|
|
|
|
|
|
|
const IsPublic = inject(IsPublicInj, ref(false))
|
|
|
|
|
|
|
|
const open = ref(false)
|
|
|
|
|
|
|
|
useMenuCloseOnEsc(open)
|
|
|
|
|
|
|
|
const handleSubmit = async () => {
|
|
|
|
open.value = false
|
|
|
|
}
|
|
|
|
|
|
|
|
provide(IsKanbanInj, ref(true))
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<a-dropdown
|
|
|
|
v-if="!IsPublic && isUIAllowed('fieldEdit')"
|
|
|
|
v-model:visible="open"
|
|
|
|
:trigger="['click']"
|
|
|
|
overlay-class-name="nc-dropdown-kanban-add-edit-stack-menu"
|
|
|
|
>
|
|
|
|
<div class="nc-kanban-btn">
|
|
|
|
<a-button
|
|
|
|
v-e="['c:kanban:edit-or-add-stack']"
|
|
|
|
class="nc-kanban-add-edit-stack-menu-btn nc-toolbar-btn"
|
|
|
|
:disabled="isLocked"
|
|
|
|
>
|
|
|
|
<div class="flex items-center gap-1">
|
|
|
|
<component :is="iconMap.edit" v-if="groupingFieldColumn" />
|
|
|
|
<component :is="iconMap.plus" v-else />
|
|
|
|
<span class="capitalize ml-1 text-sm">
|
|
|
|
{{ groupingFieldColumn ? 'Edit' : 'Add' }}
|
|
|
|
Stack
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
</a-button>
|
|
|
|
</div>
|
|
|
|
<template #overlay>
|
|
|
|
<div class="overflow-auto max-h-[max(80vh,500px)] min-w-[384px]">
|
|
|
|
<LazySmartsheetColumnEditOrAddProvider
|
|
|
|
v-if="open"
|
|
|
|
:column="groupingFieldColumn"
|
|
|
|
@submit="handleSubmit"
|
|
|
|
@cancel="open = false"
|
|
|
|
@click.stop
|
|
|
|
@keydown.stop
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</a-dropdown>
|
|
|
|
</template>
|