From a7ac91bc5ae3c2ce0badca1ae9fc7ed57af95758 Mon Sep 17 00:00:00 2001 From: riku <risaku@163.com> Date: 星期二, 22 十月 2024 15:15:28 +0800 Subject: [PATCH] 1. 添加子任务编辑功能(暂存) --- src/views/fysp/task/components/CompSubTaskList.vue | 104 +++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 90 insertions(+), 14 deletions(-) diff --git a/src/views/fysp/task/components/CompSubTaskList.vue b/src/views/fysp/task/components/CompSubTaskList.vue index 70f3f85..b678652 100644 --- a/src/views/fysp/task/components/CompSubTaskList.vue +++ b/src/views/fysp/task/components/CompSubTaskList.vue @@ -1,40 +1,116 @@ <template> <el-row justify="space-between"> <el-text>鍗曟棩璁″垝</el-text> - <el-button type="success" size="small" @click="add">鏂板</el-button> + <el-button + v-show="create && modelValue && modelValue.length > 0" + type="success" + size="small" + @click="add" + >浠诲姟璋冩暣</el-button + > </el-row> <el-divider /> <div> - <el-scrollbar :height="height"> - <ItemSubTask v-for="s in data" :key="s.guid" :item="s"> - <template #default="{ item }"> - <el-button type="danger" size="small" @click="remove(item)" - >绉婚櫎</el-button + <el-scrollbar v-loading="loading" :height="height"> + <el-space + v-if="modelValue && modelValue.length > 0" + fill + :fill-ratio="100" + direction="vertical" + style="width: 100%" + > + <ItemSubTask v-for="s in modelValue" :key="s.guid" :item="s"> + <template #default="{ item }"> + <el-space direction="vertical"> + <el-button plain type="primary" size="small" @click="edit(item)" + >缂栬緫</el-button + > + <el-button + :disabled="item.status != '鏈墽琛�'" + type="default" + size="small" + @click="remove(item)" + >绉婚櫎</el-button + > + </el-space> + </template> + </ItemSubTask> + </el-space> + <div v-else> + <el-empty description="鏃犱换鍔¤褰�" /> + <el-row justify="center"> + <el-button type="success" size="small" @click="add" + >娣诲姞浠诲姟</el-button > - </template> - </ItemSubTask> + </el-row> + </div> </el-scrollbar> </div> + <el-dialog + v-model="dialogVisible" + width="600" + title="涓�閿垱寤烘�讳换鍔�" + destroy-on-close + :close-on-click-modal="false" + :close-on-press-escape="false" + :show-close="false" + > + <CompSubTaskEdit + v-model="activeItem" + @submit="dialogVisible = false" + @cancel="dialogVisible = false" + ></CompSubTaskEdit> + </el-dialog> </template> <script setup> -import { ref, watch, onMounted } from 'vue'; +import { ref, computed, watch, onMounted, onUnmounted } from 'vue'; +import { ElMessageBox, ElNotification, ElMessage } from 'element-plus'; +import CompSubTaskEdit from './CompSubTaskEdit.vue'; const props = defineProps({ - data: Array, + modelValue: Array, height: { type: String, default: '70vh' - } + }, + // 鏄惁鏄剧ず娣诲姞浠诲姟鎸夐挳 + create: Boolean, + loading: Boolean }); -const curSubTaskList = ref([]); -const emit = defineEmits(['add', 'remove']); +const dialogVisible = ref(false) +const activeItem = ref(null) +const data = computed(() => props.modelValue); + +const emit = defineEmits(['edit', 'add', 'remove', 'update:modelValue']); function remove(item) { - emit('remove', item); + if (item.status == '鏈墽琛�') { + ElMessageBox.confirm('鏄惁绉婚櫎鐩戠浠诲姟', `绉婚櫎纭`, { + confirmButtonText: '纭', + cancelButtonText: '鍙栨秷', + type: 'warning' + }).then(() => { + const index = data.value.indexOf(item); + data.value.splice(index, 1); + + emit('update:modelValue', data.value); + emit('remove', item); + }); + } +} + +function edit(item) { + activeItem.value = item + dialogVisible.value = true + emit('edit'); } function add() { emit('add'); } + +onUnmounted(()=>{ + dialogVisible.value = false +}) </script> -- Gitblit v1.9.3