From 1220f5ca98b10b735a47c37a81fbfc554b01e2fe Mon Sep 17 00:00:00 2001 From: liriming <1343021927@qq.com> Date: 星期一, 20 一月 2025 14:41:35 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- src/components/SimpleProcessDesignerV2/src/ProcessNodeTree.vue | 125 +++++++++++++++++++++++++++++++++++++++++ 1 files changed, 125 insertions(+), 0 deletions(-) diff --git a/src/components/SimpleProcessDesignerV2/src/ProcessNodeTree.vue b/src/components/SimpleProcessDesignerV2/src/ProcessNodeTree.vue new file mode 100644 index 0000000..419501a --- /dev/null +++ b/src/components/SimpleProcessDesignerV2/src/ProcessNodeTree.vue @@ -0,0 +1,125 @@ +<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> -- Gitblit v1.9.3