mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
57 lines
1.4 KiB
57 lines
1.4 KiB
<script setup lang="ts"> |
|
import {useRolesWrapper} from "~/composables/useRoles"; |
|
|
|
const { isUIAllowed } = useRolesWrapper() |
|
|
|
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> |
|
<LazySmartsheetColumnEditOrAddProvider |
|
v-if="open" |
|
:column="groupingFieldColumn" |
|
@submit="handleSubmit" |
|
@cancel="open = false" |
|
@click.stop |
|
@keydown.stop |
|
/> |
|
</template> |
|
</a-dropdown> |
|
</template>
|
|
|