From 5e440a7dc434c43eb828fa62cf9c12b0078b8565 Mon Sep 17 00:00:00 2001 From: 疯狂的狮子Li <15040126243@163.com> Date: 星期一, 20 一月 2025 11:36:18 +0800 Subject: [PATCH] !173 发布 5.3.0-BETA 公测版本 Merge pull request !173 from 疯狂的狮子Li/dev --- src/views/workflow/leave/index.vue | 117 ++++++++++++++++++++++++++++------------------------------ 1 files changed, 56 insertions(+), 61 deletions(-) diff --git a/src/views/workflow/leave/index.vue b/src/views/workflow/leave/index.vue index 4f7c8e1..2c8da0e 100644 --- a/src/views/workflow/leave/index.vue +++ b/src/views/workflow/leave/index.vue @@ -2,7 +2,7 @@ <div class="p-2"> <transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave"> <div v-show="showSearch" class="search"> - <el-form ref="queryFormRef" :model="queryParams" :inline="true" label-width="68px"> + <el-form ref="queryFormRef" :model="queryParams" :inline="true"> <el-form-item label="璇峰亣澶╂暟" prop="startLeaveDays"> <el-input v-model="queryParams.startLeaveDays" placeholder="璇疯緭鍏ヨ鍋囧ぉ鏁�" clearable @keyup.enter="handleQuery" /> </el-form-item> @@ -22,16 +22,16 @@ <template #header> <el-row :gutter="10" class="mb8"> <el-col :span="1.5"> - <el-button v-hasPermi="['demo:leave:add']" type="primary" plain icon="Plus" @click="handleAdd">鏂板</el-button> + <el-button v-hasPermi="['workflow:leave:add']" type="primary" plain icon="Plus" @click="handleAdd">鏂板</el-button> </el-col> <el-col :span="1.5"> - <el-button v-hasPermi="['demo:leave:export']" type="warning" plain icon="Download" @click="handleExport">瀵煎嚭</el-button> + <el-button v-hasPermi="['workflow:leave:export']" type="warning" plain icon="Download" @click="handleExport">瀵煎嚭</el-button> </el-col> - <right-toolbar v-model:showSearch="showSearch" @query-table="getList"></right-toolbar> + <right-toolbar v-model:show-search="showSearch" @query-table="getList"></right-toolbar> </el-row> </template> - <el-table v-loading="loading" :data="leaveList" @selection-change="handleSelectionChange"> + <el-table v-loading="loading" border :data="leaveList" @selection-change="handleSelectionChange"> <el-table-column type="selection" width="55" align="center" /> <el-table-column v-if="false" label="涓婚敭" align="center" prop="id" /> <el-table-column label="璇峰亣绫诲瀷" align="center"> @@ -41,51 +41,43 @@ </el-table-column> <el-table-column label="寮�濮嬫椂闂�" align="center" prop="startDate"> <template #default="scope"> - <span>{{ parseTime(scope.row.startDate, '{y}-{m}-{d}') }}</span> + <span>{{ proxy.parseTime(scope.row.startDate, '{y}-{m}-{d}') }}</span> </template> </el-table-column> <el-table-column label="缁撴潫鏃堕棿" align="center" prop="endDate"> <template #default="scope"> - <span>{{ parseTime(scope.row.endDate, '{y}-{m}-{d}') }}</span> + <span>{{ proxy.parseTime(scope.row.endDate, '{y}-{m}-{d}') }}</span> </template> </el-table-column> <el-table-column label="璇峰亣澶╂暟" align="center" prop="leaveDays" /> <el-table-column label="璇峰亣鍘熷洜" align="center" prop="remark" /> - <el-table-column align="center" prop="businessStatusName" label="娴佺▼鐘舵��" min-width="70"> + <el-table-column align="center" label="娴佺▼鐘舵��" min-width="70"> <template #default="scope"> - <el-tag type="success">{{ scope.row.processInstanceVo.businessStatusName }}</el-tag> + <dict-tag :options="wf_business_status" :value="scope.row.status"></dict-tag> </template> </el-table-column> - <el-table-column label="鎿嶄綔" align="center" class-name="small-padding fixed-width"> + <el-table-column label="鎿嶄綔" align="center" width="162"> <template #default="scope"> - <el-tooltip - v-if=" - scope.row.processInstanceVo.businessStatus === 'draft' || - scope.row.processInstanceVo.businessStatus === 'cancel' || - scope.row.processInstanceVo.businessStatus === 'back' - " - content="淇敼" - placement="top" - > - <el-button v-hasPermi="['demo:leave:edit']" link type="primary" icon="Edit" @click="handleUpdate(scope.row)"></el-button> - </el-tooltip> - <el-tooltip - v-if=" - scope.row.processInstanceVo.businessStatus === 'draft' || - scope.row.processInstanceVo.businessStatus === 'cancel' || - scope.row.processInstanceVo.businessStatus === 'back' - " - content="鍒犻櫎" - placement="top" - > - <el-button v-hasPermi="['demo:leave:remove']" link type="primary" icon="Delete" @click="handleDelete(scope.row)"></el-button> - </el-tooltip> - <el-tooltip placement="top" content="鏌ョ湅" > - <el-button link type="primary" icon="View" @click="handleView(scope.row)"></el-button> - </el-tooltip> - <el-tooltip v-if="scope.row.processInstanceVo.businessStatus === 'waiting'" content="鎾ら攢" placement="top"> - <el-button link type="primary" icon="Notification" @click="handleCancelProcessApply(scope.row.processInstanceVo.id)"></el-button> - </el-tooltip> + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5" v-if="scope.row.status === 'draft' || scope.row.status === 'cancel' || scope.row.status === 'back'"> + <el-button v-hasPermi="['workflow:leave:edit']" size="small" type="primary" icon="Edit" @click="handleUpdate(scope.row)" + >淇敼</el-button + > + </el-col> + <el-col :span="1.5" v-if="scope.row.status === 'draft' || scope.row.status === 'cancel' || scope.row.status === 'back'"> + <el-button v-hasPermi="['workflow:leave:remove']" size="small" type="primary" icon="Delete" @click="handleDelete(scope.row)" + >鍒犻櫎</el-button + > + </el-col> + </el-row> + <el-row :gutter="10" class="mb8"> + <el-col :span="1.5"> + <el-button type="primary" size="small" icon="View" @click="handleView(scope.row)">鏌ョ湅</el-button> + </el-col> + <el-col :span="1.5" v-if="scope.row.status === 'waiting'"> + <el-button size="small" type="primary" icon="Notification" @click="handleCancelProcessApply(scope.row.id)">鎾ら攢</el-button> + </el-col> + </el-row> </template> </el-table-column> </el-table> @@ -97,11 +89,11 @@ <script setup name="Leave" lang="ts"> import { delLeave, listLeave } from '@/api/workflow/leave'; -import { cancelProcessApply } from '@/api/workflow/processInstance'; +import { cancelProcessApply } from '@/api/workflow/instance'; import { LeaveForm, LeaveQuery, LeaveVO } from '@/api/workflow/leave/types'; const { proxy } = getCurrentInstance() as ComponentInternalInstance; - +const { wf_business_status } = toRefs<any>(proxy?.useDict('wf_business_status')); const leaveList = ref<LeaveVO[]>([]); const loading = ref(true); const showSearch = ref(true); @@ -131,7 +123,7 @@ const queryFormRef = ref<ElFormInstance>(); const data = reactive<PageData<LeaveForm, LeaveQuery>>({ - form: { }, + form: {}, queryParams: { pageNum: 1, pageSize: 10, @@ -174,37 +166,36 @@ /** 鏂板鎸夐挳鎿嶄綔 */ const handleAdd = () => { proxy.$tab.closePage(proxy.$route); - proxy.$router.push(`/demo/leaveEdit/index/add/add`); proxy.$router.push({ - path: `/demo/leaveEdit/index`, - query: { - type: 'add' - } - }) + path: `/workflow/leaveEdit/index`, + query: { + type: 'add' + } + }); }; /** 淇敼鎸夐挳鎿嶄綔 */ const handleUpdate = (row?: LeaveVO) => { proxy.$tab.closePage(proxy.$route); proxy.$router.push({ - path: `/demo/leaveEdit/index`, - query: { - id: row.id, - type: 'update' - } - }) + path: `/workflow/leaveEdit/index`, + query: { + id: row.id, + type: 'update' + } + }); }; /** 鏌ョ湅鎸夐挳鎿嶄綔 */ const handleView = (row?: LeaveVO) => { proxy.$tab.closePage(proxy.$route); proxy.$router.push({ - path: `/demo/leaveEdit/index`, - query: { - id: row.id, - type: 'view' - } - }) + path: `/workflow/leaveEdit/index`, + query: { + id: row.id, + type: 'view' + } + }); }; /** 鍒犻櫎鎸夐挳鎿嶄綔 */ @@ -219,7 +210,7 @@ /** 瀵煎嚭鎸夐挳鎿嶄綔 */ const handleExport = () => { proxy?.download( - 'demo/leave/export', + 'workflow/leave/export', { ...queryParams.value }, @@ -231,7 +222,11 @@ const handleCancelProcessApply = async (id: string) => { await proxy?.$modal.confirm('鏄惁纭鎾ら攢褰撳墠鍗曟嵁锛�'); loading.value = true; - await cancelProcessApply(id).finally(() => (loading.value = false)); + let data = { + businessId: id, + message: '鐢宠浜烘挙閿�娴佺▼锛�' + }; + await cancelProcessApply(data).finally(() => (loading.value = false)); await getList(); proxy?.$modal.msgSuccess('鎾ら攢鎴愬姛'); }; -- Gitblit v1.9.3