feat(dms): 故障报修工单启动工作流功能

- 新增更新故障报修工单工作流定义 ID 的接口和方法
- 添加启动工作流的按钮和相关逻辑
- 实现工作流启动后自动打开审批组件处理第一个节点
- 增加查看工单进度的功能
- 优化故障报修工单列表界面,移除不必要的搜索条件
master
zch 5 days ago
parent 380d191ad3
commit 252d670ed0

@ -75,3 +75,20 @@ export function getDmsBillsFaultInstanceList (query) {
params: query
});
};
/**
* ID
* @param repairInstanceId ID
* @param wfDefinitionId ID
* @return truefalse
*/
export function updateWfDefinitionIdById (repairInstanceId: string | number, wfDefinitionId: string | number) {
return request({
url: '/dms/dmsBillsFaultInstance/updateWfDefinitionIdById',
method: 'post',
params: {
repairInstanceId,
wfDefinitionId
}
});
}

@ -384,6 +384,21 @@ export const dynamicRoutes: RouteRecordRaw[] = [
]
},
{
path: '/dms/dmsFaultInstanceActivity',
component: Layout,
hidden: true,
permissions: ['dms:dmsBillsFaultInstance:add'],
children: [
{
path: 'index',
component: () => import('@/views/dms/dmsFaultInstanceActivity/index.vue'),
name: 'dmsFaultInstanceActivity',
meta: { title: '维修工单明细', activeMenu: '/dms/dmsBillsFaultInstance', icon: '' }
}
]
},
{
path: '/dms/dmsPlanMaintDetail',
component: Layout,

@ -28,9 +28,6 @@
</el-form-item>
<el-form-item label="设备" prop="machineId">
<el-input v-model="queryParams.machineId" placeholder="请输入设备" clearable @keyup.enter="handleQuery" />
</el-form-item>
<el-form-item label="申请人" prop="applyUser">
<el-input v-model="queryParams.applyUser" placeholder="请输入申请人" clearable @keyup.enter="handleQuery" />
</el-form-item>-->
<!-- <el-form-item label="申请时间" prop="applyTime">
<el-date-picker clearable
@ -171,6 +168,12 @@
<el-table-column label="备注" align="center" prop="remark" v-if="columns[18].visible"/>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template #default="scope">
<!-- 启动工单按钮 -->
<el-tooltip content="启动工单" placement="top" v-if="!scope.row.wfDefinitionId">
<el-button link type="success" icon="View" @click="handleStartWorkflow(scope.row)">
</el-button>
</el-tooltip>
<el-tooltip content="修改" placement="top">
<el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['dms:dmsBillsFaultInstance:edit']"></el-button>
</el-tooltip>
@ -184,6 +187,12 @@
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
</el-card>
<!-- 工作流处理组件 -->
<submitVerify
ref="submitVerifyRef"
:task-variables="taskVariables"
@submit-callback="submitCallback" />
<!-- 添加或修改故障报修工单对话框 -->
<el-dialog :title="dialog.title" v-model="dialog.visible" width="500px" append-to-body>
<el-form ref="dmsBillsFaultInstanceFormRef" :model="form" :rules="rules" label-width="80px">
@ -315,9 +324,12 @@
</template>
<script setup name="DmsBillsFaultInstance" lang="ts">
import { listDmsBillsFaultInstance, getDmsBillsFaultInstance, delDmsBillsFaultInstance, addDmsBillsFaultInstance, updateDmsBillsFaultInstance } from '@/api/dms/dmsBillsFaultInstance';
import { listDmsBillsFaultInstance, getDmsBillsFaultInstance, delDmsBillsFaultInstance, addDmsBillsFaultInstance, updateDmsBillsFaultInstance, updateWfDefinitionIdById } from '@/api/dms/dmsBillsFaultInstance';
import { DmsBillsFaultInstanceVO, DmsBillsFaultInstanceQuery, DmsBillsFaultInstanceForm } from '@/api/dms/dmsBillsFaultInstance/types';
import {getDmsBaseMachineInfoList} from "@/api/dms/dmsBaseMachineInfo";
import { useRouter } from 'vue-router';
import { startWorkFlow } from '@/api/workflow/task'
import SubmitVerify from '@/components/Process/submitVerify.vue'
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
const { repair_confirm, active_flag, fault_source_type, bills_status, instance_type } = toRefs<any>(proxy?.useDict('repair_confirm', 'active_flag', 'fault_source_type', 'bills_status', 'instance_type'));
@ -570,6 +582,87 @@ const getDeviceList = async () => {
deviceList = res.data;
}
//
const handleStartWorkflow = async (row: DmsBillsFaultInstanceVO) => {
try {
const confirmResult = await proxy?.$modal.confirm(
`确认启动故障报修工单"${row.billsFaultCode}"的工作流?`
);
if (confirmResult) {
buttonLoading.value = true;
//
const workflowData = {
businessId: row.repairInstanceId,
flowCode: 'Fault01',
variables: {
repairInstanceId: row.repairInstanceId,
billsFaultCode: row.billsFaultCode,
instanceType: row.instanceType,
faultSourceType: row.faultSourceType,
machineId: row.machineId
}
};
const workflowRes = await startWorkFlow(workflowData);
//
if (!workflowRes || !workflowRes.data || !workflowRes.data.taskId) {
throw new Error('工作流启动失败未获取到有效的taskId');
}
await updateWfDefinitionIdById(row.repairInstanceId, workflowRes.data.taskId);
//
taskVariables.value = {
entity: {
repairInstanceId: row.repairInstanceId,
instanceType: row.instanceType,
faultSourceType: row.faultSourceType,
machineId: row.machineId,
processStepOrder: 1
}
};
proxy?.$modal.msgSuccess('工单工作流启动成功');
//
if (submitVerifyRef.value && workflowRes.data.taskId) {
submitVerifyRef.value.openDialog(workflowRes.data.taskId);
}
}
} catch (error) {
console.error('启动工作流失败:', error);
proxy?.$modal.msgError('启动工作流失败: ' + (error.message || '未知错误'));
} finally {
buttonLoading.value = false;
}
};
//
const router = useRouter();
const handleWorkflowProgress = (row: DmsBillsFaultInstanceVO) => {
//
router.push({
path: '/workflow/process/record',
query: { businessId: row.repairInstanceId }
});
};
const submitVerifyRef = ref<InstanceType<typeof SubmitVerify>>();
const taskVariables = ref<any>({});
// -
const submitCallback = async () => {
try {
//
await getList();
proxy?.$modal.msgSuccess('工单创建节点处理完成,工作流已流转到下一步');
} catch (error) {
console.error('刷新列表失败:', error);
proxy?.$modal.msgError('刷新列表失败');
}
};
onMounted(() => {
getDeviceList();

@ -99,10 +99,10 @@
:rows="3"
placeholder="请输入处理意见" />
</el-form-item>
</el-col>
</el-row>
</el-form>
</el-card>
</el-col>
</el-row>
</el-form>
</el-card>
<!-- 审批组件 -->
<submitVerify

@ -301,7 +301,7 @@ const initializeFormData = () => {
form.lubeLevel = workOrder.value.lubeLevel;
form.lubeGroup = workOrder.value.lubeGroup;
form.lubeSupervisor = workOrder.value.lubeSupervisor;
} else {
} else {
//
form.lubeLevel = workOrder.value.lubeLevel;
form.lubeGroup = workOrder.value.lubeGroup;

File diff suppressed because it is too large Load Diff

@ -105,9 +105,9 @@
type="textarea"
:rows="3"
placeholder="请输入处理意见" />
</el-form-item>
</el-col>
</el-row>
</el-form-item>
</el-col>
</el-row>
</el-form>
</el-card>
@ -248,7 +248,7 @@ const loadWorkOrderInfo = async () => {
if (maint_level.value && workOrder.value.maintStatus !== undefined) {
const statusItem = maint_level.value.find((item: any) => String(item.value) === String(workOrder.value.maintStatus));
workOrderStatusText.value = statusItem ? statusItem.label : '未知状态';
} else {
} else {
workOrderStatusText.value = '未知状态';
}
};

Loading…
Cancel
Save