|
@@ -1,6 +1,10 @@
|
|
|
<template>
|
|
|
<div v-loading="loading" class="mb-20px">
|
|
|
- <SimpleProcessViewer :flow-node="simpleModel" :tasks="tasks" :process-instance="processInstance"/>
|
|
|
+ <SimpleProcessViewer
|
|
|
+ :flow-node="simpleModel"
|
|
|
+ :tasks="tasks"
|
|
|
+ :process-instance="processInstance"
|
|
|
+ />
|
|
|
</div>
|
|
|
</template>
|
|
|
<script lang="ts" setup>
|
|
@@ -12,72 +16,51 @@ defineOptions({ name: 'BpmProcessInstanceSimpleViewer' })
|
|
|
|
|
|
const props = defineProps({
|
|
|
loading: propTypes.bool.def(false), // 是否加载中
|
|
|
- modelView: propTypes.object
|
|
|
+ modelView: propTypes.object,
|
|
|
+ simpleJson: propTypes.string // Simple 模型结构数据 (json 格式)
|
|
|
})
|
|
|
const simpleModel = ref()
|
|
|
// 用户任务
|
|
|
const tasks = ref([])
|
|
|
// 流程实例
|
|
|
const processInstance = ref()
|
|
|
-// /** 只有 loading 完成时,才去加载流程列表 */
|
|
|
-// watch(
|
|
|
-// () => props.loading,
|
|
|
-// async (value) => {
|
|
|
-// if (value && props.id) {
|
|
|
-// const modelView = await ProcessInstanceApi.getProcessInstanceBpmnModelView(props.id)
|
|
|
-// if (modelView) {
|
|
|
-// tasks.value = modelView.tasks
|
|
|
-// processInstance.value = modelView.processInstance
|
|
|
-// // 已经拒绝的活动节点编号集合,只包括 UserTask
|
|
|
-// const rejectedTaskActivityIds: string[] = modelView.rejectedTaskActivityIds
|
|
|
-// // 进行中的活动节点编号集合, 只包括 UserTask
|
|
|
-// const unfinishedTaskActivityIds: string[] = modelView.unfinishedTaskActivityIds
|
|
|
-// // 已经完成的活动节点编号集合, 包括 UserTask、Gateway 等
|
|
|
-// const finishedActivityIds: string[] = modelView.finishedTaskActivityIds
|
|
|
-// // 已经完成的连线节点编号集合,只包括 SequenceFlow
|
|
|
-// const finishedSequenceFlowActivityIds: string[] = modelView.finishedSequenceFlowActivityIds
|
|
|
-// setSimpleModelNodeTaskStatus(
|
|
|
-// modelView.simpleModel,
|
|
|
-// modelView.processInstance.status,
|
|
|
-// rejectedTaskActivityIds,
|
|
|
-// unfinishedTaskActivityIds,
|
|
|
-// finishedActivityIds,
|
|
|
-// finishedSequenceFlowActivityIds
|
|
|
-// )
|
|
|
-// simpleModel.value = modelView.simpleModel
|
|
|
-// }
|
|
|
-// }
|
|
|
-// }
|
|
|
-// )
|
|
|
+
|
|
|
+/** 监控模型视图 包括任务列表、进行中的活动节点编号等 */
|
|
|
watch(
|
|
|
() => props.modelView,
|
|
|
async (newModelView) => {
|
|
|
if (newModelView) {
|
|
|
- if (newModelView) {
|
|
|
- tasks.value = newModelView.tasks
|
|
|
- processInstance.value = newModelView.processInstance
|
|
|
- // 已经拒绝的活动节点编号集合,只包括 UserTask
|
|
|
- const rejectedTaskActivityIds: string[] = newModelView.rejectedTaskActivityIds
|
|
|
- // 进行中的活动节点编号集合, 只包括 UserTask
|
|
|
- const unfinishedTaskActivityIds: string[] = newModelView.unfinishedTaskActivityIds
|
|
|
- // 已经完成的活动节点编号集合, 包括 UserTask、Gateway 等
|
|
|
- const finishedActivityIds: string[] = newModelView.finishedTaskActivityIds
|
|
|
- // 已经完成的连线节点编号集合,只包括 SequenceFlow
|
|
|
- const finishedSequenceFlowActivityIds: string[] = newModelView.finishedSequenceFlowActivityIds
|
|
|
- setSimpleModelNodeTaskStatus(
|
|
|
- newModelView.simpleModel,
|
|
|
- newModelView.processInstance.status,
|
|
|
- rejectedTaskActivityIds,
|
|
|
- unfinishedTaskActivityIds,
|
|
|
- finishedActivityIds,
|
|
|
- finishedSequenceFlowActivityIds
|
|
|
- )
|
|
|
- simpleModel.value = newModelView.simpleModel
|
|
|
- }
|
|
|
+ tasks.value = newModelView.tasks
|
|
|
+ processInstance.value = newModelView.processInstance
|
|
|
+ // 已经拒绝的活动节点编号集合,只包括 UserTask
|
|
|
+ const rejectedTaskActivityIds: string[] = newModelView.rejectedTaskActivityIds
|
|
|
+ // 进行中的活动节点编号集合, 只包括 UserTask
|
|
|
+ const unfinishedTaskActivityIds: string[] = newModelView.unfinishedTaskActivityIds
|
|
|
+ // 已经完成的活动节点编号集合, 包括 UserTask、Gateway 等
|
|
|
+ const finishedActivityIds: string[] = newModelView.finishedTaskActivityIds
|
|
|
+ // 已经完成的连线节点编号集合,只包括 SequenceFlow
|
|
|
+ const finishedSequenceFlowActivityIds: string[] = newModelView.finishedSequenceFlowActivityIds
|
|
|
+ setSimpleModelNodeTaskStatus(
|
|
|
+ newModelView.simpleModel,
|
|
|
+ newModelView.processInstance.status,
|
|
|
+ rejectedTaskActivityIds,
|
|
|
+ unfinishedTaskActivityIds,
|
|
|
+ finishedActivityIds,
|
|
|
+ finishedSequenceFlowActivityIds
|
|
|
+ )
|
|
|
+ simpleModel.value = newModelView.simpleModel
|
|
|
+ }
|
|
|
+ }
|
|
|
+)
|
|
|
+/** 监控模型结构数据 */
|
|
|
+watch(
|
|
|
+ () => props.simpleJson,
|
|
|
+ async (value) => {
|
|
|
+ if (value) {
|
|
|
+ simpleModel.value = JSON.parse(value)
|
|
|
}
|
|
|
}
|
|
|
)
|
|
|
-
|
|
|
const setSimpleModelNodeTaskStatus = (
|
|
|
simpleModel: SimpleFlowNode | undefined,
|
|
|
processStatus: number,
|