index.vue
1.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
<script setup>
import KanbanBoardComp from '@/views/apps/kanban/KanbanBoard.vue'
// 👉 initial kanban data fetch
const {
data: kanban,
execute: refetchKanban,
} = await useApi('/apps/kanban')
const addNewBoard = async newBoardName => {
await $api('/apps/kanban/board/add', {
method: 'POST',
body: { title: newBoardName },
})
refetchKanban()
}
const deleteBoard = async boardId => {
await $api(`/apps/kanban/board/${ boardId }`, { method: 'DELETE' })
refetchKanban()
}
const renameTheBoard = async kanbanBoard => {
await $api('/apps/kanban/board/rename', {
method: 'PUT',
body: kanbanBoard,
})
refetchKanban()
}
const addNewItem = async newItem => {
await $api('/apps/kanban/item/add', {
method: 'POST',
body: newItem,
})
refetchKanban()
}
const editItemFn = async editItem => {
await $api('/apps/kanban/item/update', {
method: 'PUT',
body: editItem,
})
refetchKanban()
}
const deleteItemFn = async deleteItem => {
if (deleteItem.item && deleteItem.item.id) {
await $api(`/apps/kanban/item/${ deleteItem.item.id }`, {
method: 'DELETE',
body: deleteItem,
})
refetchKanban()
}
}
const updateItemState = async kanbanState => {
await $api('/apps/kanban/item/state-update', {
method: 'PUT',
body: kanbanState,
})
}
const updateBoardState = async kanbanBoardIds => {
await $api('/apps/kanban/board/state-update', {
method: 'PUT',
body: kanbanBoardIds,
})
}
</script>
<template>
<KanbanBoardComp
v-if="kanban"
:kanban-data="kanban"
@add-new-board="addNewBoard"
@delete-board="deleteBoard"
@rename-board="renameTheBoard"
@add-new-item="addNewItem"
@edit-item="editItemFn"
@delete-item="deleteItemFn"
@update-items-state="updateItemState"
@update-board-state="updateBoardState"
/>
</template>