<template>
|
<!-- 发起人节点 -->
|
<StartUserNode
|
v-if="currentNode && currentNode.type === NodeType.START_USER_NODE"
|
:flow-node="currentNode"
|
/>
|
<!-- 审批节点 -->
|
<UserTaskNode
|
v-if="currentNode && currentNode.type === NodeType.USER_TASK_NODE"
|
:flow-node="currentNode"
|
@update:flow-node="handleModelValueUpdate"
|
@find:parent-node="findFromParentNode"
|
/>
|
<!-- 抄送节点 -->
|
<CopyTaskNode
|
v-if="currentNode && currentNode.type === NodeType.COPY_TASK_NODE"
|
:flow-node="currentNode"
|
@update:flow-node="handleModelValueUpdate"
|
/>
|
<!-- 条件节点 -->
|
<ExclusiveNode
|
v-if="currentNode && currentNode.type === NodeType.CONDITION_BRANCH_NODE"
|
:flow-node="currentNode"
|
@update:model-value="handleModelValueUpdate"
|
@find:parent-node="findFromParentNode"
|
/>
|
<!-- 并行节点 -->
|
<ParallelNode
|
v-if="currentNode && currentNode.type === NodeType.PARALLEL_BRANCH_NODE"
|
:flow-node="currentNode"
|
@update:model-value="handleModelValueUpdate"
|
@find:parent-node="findFromParentNode"
|
/>
|
<!-- 包容分支节点 -->
|
<InclusiveNode
|
v-if="currentNode && currentNode.type === NodeType.INCLUSIVE_BRANCH_NODE"
|
:flow-node="currentNode"
|
@update:model-value="handleModelValueUpdate"
|
@find:parent-node="findFromParentNode"
|
/>
|
<!-- 延迟器节点 -->
|
<DelayTimerNode
|
v-if="currentNode && currentNode.type === NodeType.DELAY_TIMER_NODE"
|
:flow-node="currentNode"
|
@update:flow-node="handleModelValueUpdate"
|
/>
|
<!-- 递归显示孩子节点 -->
|
<ProcessNodeTree
|
v-if="currentNode && currentNode.childNode"
|
v-model:flow-node="currentNode.childNode"
|
:parent-node="currentNode"
|
@find:recursive-find-parent-node="recursiveFindParentNode"
|
/>
|
|
<!-- 结束节点 -->
|
<EndEventNode
|
v-if="currentNode && currentNode.type === NodeType.END_EVENT_NODE"
|
:flow-node="currentNode"
|
/>
|
</template>
|
<script setup lang="ts">
|
import StartUserNode from './nodes/StartUserNode.vue'
|
import EndEventNode from './nodes/EndEventNode.vue'
|
import UserTaskNode from './nodes/UserTaskNode.vue'
|
import CopyTaskNode from './nodes/CopyTaskNode.vue'
|
import ExclusiveNode from './nodes/ExclusiveNode.vue'
|
import ParallelNode from './nodes/ParallelNode.vue'
|
import InclusiveNode from './nodes/InclusiveNode.vue'
|
import DelayTimerNode from './nodes/DelayTimerNode.vue'
|
import { SimpleFlowNode, NodeType } from './consts'
|
import { useWatchNode } from './node'
|
defineOptions({
|
name: 'ProcessNodeTree'
|
})
|
const props = defineProps({
|
parentNode: {
|
type: Object as () => SimpleFlowNode,
|
default: () => null
|
},
|
flowNode: {
|
type: Object as () => SimpleFlowNode,
|
default: () => null
|
}
|
})
|
const emits = defineEmits<{
|
'update:flowNode': [node: SimpleFlowNode | undefined]
|
'find:recursiveFindParentNode': [
|
nodeList: SimpleFlowNode[],
|
curentNode: SimpleFlowNode,
|
nodeType: number
|
]
|
}>()
|
|
const currentNode = useWatchNode(props)
|
|
// 用于删除节点
|
const handleModelValueUpdate = (updateValue) => {
|
emits('update:flowNode', updateValue)
|
}
|
|
const findFromParentNode = (nodeList: SimpleFlowNode[], nodeType: number) => {
|
emits('find:recursiveFindParentNode', nodeList, props.parentNode, nodeType)
|
}
|
|
// 递归从父节点中查询匹配的节点
|
const recursiveFindParentNode = (
|
nodeList: SimpleFlowNode[],
|
findNode: SimpleFlowNode,
|
nodeType: number
|
) => {
|
if (!findNode) {
|
return
|
}
|
if (findNode.type === NodeType.START_USER_NODE) {
|
nodeList.push(findNode)
|
return
|
}
|
|
if (findNode.type === nodeType) {
|
nodeList.push(findNode)
|
}
|
emits('find:recursiveFindParentNode', nodeList, props.parentNode, nodeType)
|
}
|
</script>
|
<style lang="scss" scoped></style>
|