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/NodeHandler.vue | 231 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 231 insertions(+), 0 deletions(-) diff --git a/src/components/SimpleProcessDesignerV2/src/NodeHandler.vue b/src/components/SimpleProcessDesignerV2/src/NodeHandler.vue new file mode 100644 index 0000000..4dfd51a --- /dev/null +++ b/src/components/SimpleProcessDesignerV2/src/NodeHandler.vue @@ -0,0 +1,231 @@ +<template> + <div class="node-handler-wrapper"> + <div class="node-handler"> + <el-popover + trigger="hover" + v-model:visible="popoverShow" + placement="right-start" + width="auto" + v-if="!readonly" + > + <div class="handler-item-wrapper"> + <div class="handler-item" @click="addNode(NodeType.USER_TASK_NODE)"> + <div class="approve handler-item-icon"> + <span class="iconfont icon-approve icon-size"></span> + </div> + <div class="handler-item-text">审批人</div> + </div> + <div class="handler-item" @click="addNode(NodeType.COPY_TASK_NODE)"> + <div class="handler-item-icon copy"> + <span class="iconfont icon-size icon-copy"></span> + </div> + <div class="handler-item-text">抄送</div> + </div> + <div class="handler-item" @click="addNode(NodeType.CONDITION_BRANCH_NODE)"> + <div class="handler-item-icon condition"> + <span class="iconfont icon-size icon-exclusive"></span> + </div> + <div class="handler-item-text">条件分支</div> + </div> + <div class="handler-item" @click="addNode(NodeType.PARALLEL_BRANCH_NODE)"> + <div class="handler-item-icon parallel"> + <span class="iconfont icon-size icon-parallel"></span> + </div> + <div class="handler-item-text">并行分支</div> + </div> + <div class="handler-item" @click="addNode(NodeType.INCLUSIVE_BRANCH_NODE)"> + <div class="handler-item-icon inclusive"> + <span class="iconfont icon-size icon-inclusive"></span> + </div> + <div class="handler-item-text">包容分支</div> + </div> + <div class="handler-item" @click="addNode(NodeType.DELAY_TIMER_NODE)"> + <!-- TODO @芋艿 需要更换一下iconfont的图标 --> + <div class="handler-item-icon copy"> + <span class="iconfont icon-size icon-copy"></span> + </div> + <div class="handler-item-text">延迟器</div> + </div> + </div> + <template #reference> + <div class="add-icon"><Icon icon="ep:plus" /></div> + </template> + </el-popover> + </div> + </div> +</template> + +<script setup lang="ts"> +import { + ApproveMethodType, + AssignEmptyHandlerType, + AssignStartUserHandlerType, + NODE_DEFAULT_NAME, + NodeType, + RejectHandlerType, + SimpleFlowNode +} from './consts' +import { generateUUID } from '@/utils' + +defineOptions({ + name: 'NodeHandler' +}) + +const message = useMessage() // 消息弹窗 + +const popoverShow = ref(false) +const props = defineProps({ + childNode: { + type: Object as () => SimpleFlowNode, + default: null + }, + currentNode: { + type: Object as () => SimpleFlowNode, + required: true + } +}) +const emits = defineEmits(['update:childNode']) + +const readonly = inject<Boolean>('readonly') // 是否只读 + +const addNode = (type: number) => { + // 校验:条件分支、包容分支后面,不允许直接添加并行分支 + if ( + type === NodeType.PARALLEL_BRANCH_NODE && + [NodeType.CONDITION_BRANCH_NODE, NodeType.INCLUSIVE_BRANCH_NODE].includes( + props.currentNode?.type + ) + ) { + message.error('条件分支、包容分支后面,不允许直接添加并行分支') + return + } + + popoverShow.value = false + if (type === NodeType.USER_TASK_NODE) { + const id = 'Activity_' + generateUUID() + const data: SimpleFlowNode = { + id: id, + name: NODE_DEFAULT_NAME.get(NodeType.USER_TASK_NODE) as string, + showText: '', + type: NodeType.USER_TASK_NODE, + approveMethod: ApproveMethodType.SEQUENTIAL_APPROVE, + // 超时处理 + rejectHandler: { + type: RejectHandlerType.FINISH_PROCESS + }, + timeoutHandler: { + enable: false + }, + assignEmptyHandler: { + type: AssignEmptyHandlerType.APPROVE + }, + assignStartUserHandlerType: AssignStartUserHandlerType.START_USER_AUDIT, + childNode: props.childNode + } + emits('update:childNode', data) + } + if (type === NodeType.COPY_TASK_NODE) { + const data: SimpleFlowNode = { + id: 'Activity_' + generateUUID(), + name: NODE_DEFAULT_NAME.get(NodeType.COPY_TASK_NODE) as string, + showText: '', + type: NodeType.COPY_TASK_NODE, + childNode: props.childNode + } + emits('update:childNode', data) + } + if (type === NodeType.CONDITION_BRANCH_NODE) { + const data: SimpleFlowNode = { + name: '条件分支', + type: NodeType.CONDITION_BRANCH_NODE, + id: 'GateWay_' + generateUUID(), + childNode: props.childNode, + conditionNodes: [ + { + id: 'Flow_' + generateUUID(), + name: '条件1', + showText: '', + type: NodeType.CONDITION_NODE, + childNode: undefined, + conditionType: 1, + defaultFlow: false + }, + { + id: 'Flow_' + generateUUID(), + name: '其它情况', + showText: '未满足其它条件时,将进入此分支', + type: NodeType.CONDITION_NODE, + childNode: undefined, + conditionType: undefined, + defaultFlow: true + } + ] + } + emits('update:childNode', data) + } + if (type === NodeType.PARALLEL_BRANCH_NODE) { + const data: SimpleFlowNode = { + name: '并行分支', + type: NodeType.PARALLEL_BRANCH_NODE, + id: 'GateWay_' + generateUUID(), + childNode: props.childNode, + conditionNodes: [ + { + id: 'Flow_' + generateUUID(), + name: '并行1', + showText: '无需配置条件同时执行', + type: NodeType.CONDITION_NODE, + childNode: undefined + }, + { + id: 'Flow_' + generateUUID(), + name: '并行2', + showText: '无需配置条件同时执行', + type: NodeType.CONDITION_NODE, + childNode: undefined + } + ] + } + emits('update:childNode', data) + } + if (type === NodeType.INCLUSIVE_BRANCH_NODE) { + const data: SimpleFlowNode = { + name: '包容分支', + type: NodeType.INCLUSIVE_BRANCH_NODE, + id: 'GateWay_' + generateUUID(), + childNode: props.childNode, + conditionNodes: [ + { + id: 'Flow_' + generateUUID(), + name: '包容条件1', + showText: '', + type: NodeType.CONDITION_NODE, + childNode: undefined, + defaultFlow: false + }, + { + id: 'Flow_' + generateUUID(), + name: '其它情况', + showText: '未满足其它条件时,将进入此分支', + type: NodeType.CONDITION_NODE, + childNode: undefined, + defaultFlow: true + } + ] + } + emits('update:childNode', data) + } + if (type === NodeType.DELAY_TIMER_NODE) { + const data: SimpleFlowNode = { + id: 'Activity_' + generateUUID(), + name: NODE_DEFAULT_NAME.get(NodeType.DELAY_TIMER_NODE) as string, + showText: '', + type: NodeType.DELAY_TIMER_NODE, + childNode: props.childNode + } + emits('update:childNode', data) + } +} +</script> + +<style lang="scss" scoped></style> -- Gitblit v1.9.3