|
|
@ -28,9 +28,6 @@
|
|
|
|
</el-form-item>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="设备" prop="machineId">
|
|
|
|
<el-form-item label="设备" prop="machineId">
|
|
|
|
<el-input v-model="queryParams.machineId" placeholder="请输入设备" clearable @keyup.enter="handleQuery" />
|
|
|
|
<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>-->
|
|
|
|
<!-- <el-form-item label="申请时间" prop="applyTime">
|
|
|
|
<!-- <el-form-item label="申请时间" prop="applyTime">
|
|
|
|
<el-date-picker clearable
|
|
|
|
<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" prop="remark" v-if="columns[18].visible"/>
|
|
|
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
|
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
|
|
<template #default="scope">
|
|
|
|
<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-tooltip content="修改" placement="top">
|
|
|
|
<el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['dms:dmsBillsFaultInstance:edit']"></el-button>
|
|
|
|
<el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['dms:dmsBillsFaultInstance:edit']"></el-button>
|
|
|
|
</el-tooltip>
|
|
|
|
</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" />
|
|
|
|
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
|
|
|
|
</el-card>
|
|
|
|
</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-dialog :title="dialog.title" v-model="dialog.visible" width="500px" append-to-body>
|
|
|
|
<el-form ref="dmsBillsFaultInstanceFormRef" :model="form" :rules="rules" label-width="80px">
|
|
|
|
<el-form ref="dmsBillsFaultInstanceFormRef" :model="form" :rules="rules" label-width="80px">
|
|
|
@ -315,9 +324,12 @@
|
|
|
|
</template>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script setup name="DmsBillsFaultInstance" lang="ts">
|
|
|
|
<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 { DmsBillsFaultInstanceVO, DmsBillsFaultInstanceQuery, DmsBillsFaultInstanceForm } from '@/api/dms/dmsBillsFaultInstance/types';
|
|
|
|
import {getDmsBaseMachineInfoList} from "@/api/dms/dmsBaseMachineInfo";
|
|
|
|
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 { 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'));
|
|
|
|
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;
|
|
|
|
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(() => {
|
|
|
|
onMounted(() => {
|
|
|
|
getDeviceList();
|
|
|
|
getDeviceList();
|
|
|
|