mirror of
https://gitee.com/myxzgzs/boyue-ui-admin-vue3
synced 2025-08-09 00:42:42 +08:00
【代码评审】BPM:Simple 设计器 - 路由分支
This commit is contained in:
parent
eca1c83c56
commit
3f9408bfbe
@ -236,6 +236,7 @@ const addNode = (type: number) => {
|
|||||||
emits('update:childNode', data)
|
emits('update:childNode', data)
|
||||||
}
|
}
|
||||||
if (type === NodeType.ROUTE_BRANCH_NODE) {
|
if (type === NodeType.ROUTE_BRANCH_NODE) {
|
||||||
|
// TODO @lesan:高亮那边,需要考虑下。
|
||||||
const data: SimpleFlowNode = {
|
const data: SimpleFlowNode = {
|
||||||
id: 'GateWay_' + generateUUID(),
|
id: 'GateWay_' + generateUUID(),
|
||||||
name: NODE_DEFAULT_NAME.get(NodeType.ROUTE_BRANCH_NODE) as string,
|
name: NODE_DEFAULT_NAME.get(NodeType.ROUTE_BRANCH_NODE) as string,
|
||||||
|
@ -98,7 +98,7 @@ export interface SimpleFlowNode {
|
|||||||
// 审批节点的审批人与发起人相同时,对应的处理类型
|
// 审批节点的审批人与发起人相同时,对应的处理类型
|
||||||
assignStartUserHandlerType?: number
|
assignStartUserHandlerType?: number
|
||||||
// 创建任务监听器
|
// 创建任务监听器
|
||||||
createTaskListener: ListenerHandler
|
createTaskListener?: ListenerHandler
|
||||||
// 条件类型
|
// 条件类型
|
||||||
conditionType?: ConditionType
|
conditionType?: ConditionType
|
||||||
// 条件表达式
|
// 条件表达式
|
||||||
@ -646,7 +646,7 @@ export const DELAY_TYPE = [
|
|||||||
*/
|
*/
|
||||||
export type RouteCondition = {
|
export type RouteCondition = {
|
||||||
nodeId: string
|
nodeId: string
|
||||||
conditionType: number
|
conditionType: number // TODO @lesan:ConditionType
|
||||||
conditionExpression: string
|
conditionExpression: string
|
||||||
conditionGroups: ConditionGroup
|
conditionGroups: ConditionGroup
|
||||||
}
|
}
|
||||||
|
@ -54,6 +54,7 @@
|
|||||||
</el-radio>
|
</el-radio>
|
||||||
</el-radio-group>
|
</el-radio-group>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
<!-- TODO @lesan:1)1、2 使用枚举;2)默认先 条件组关系,再 条件表达式;3)这种可以封装成一个小组件么? -->
|
||||||
<el-form-item
|
<el-form-item
|
||||||
v-if="item.conditionType === 1"
|
v-if="item.conditionType === 1"
|
||||||
label="条件表达式"
|
label="条件表达式"
|
||||||
@ -278,6 +279,7 @@ const getShowText = () => {
|
|||||||
return `${routeGroup.value.length}条路由分支`
|
return `${routeGroup.value.length}条路由分支`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO @lesan:这个需要实现么?
|
||||||
const changeConditionType = () => {}
|
const changeConditionType = () => {}
|
||||||
|
|
||||||
const deleteConditionGroup = (conditions, index) => {
|
const deleteConditionGroup = (conditions, index) => {
|
||||||
|
@ -10,7 +10,9 @@
|
|||||||
>
|
>
|
||||||
<div class="node-title-container">
|
<div class="node-title-container">
|
||||||
<!-- TODO @芋艿 需要更换一下iconfont的图标 -->
|
<!-- TODO @芋艿 需要更换一下iconfont的图标 -->
|
||||||
<div class="node-title-icon copy-task"><span class="iconfont icon-copy"></span></div>
|
<div class="node-title-icon copy-task">
|
||||||
|
<span class="iconfont icon-copy"></span>
|
||||||
|
</div>
|
||||||
<input
|
<input
|
||||||
v-if="!readonly && showInput"
|
v-if="!readonly && showInput"
|
||||||
type="text"
|
type="text"
|
||||||
@ -47,11 +49,7 @@
|
|||||||
:current-node="currentNode"
|
:current-node="currentNode"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<RouteNodeConfig
|
<RouteNodeConfig v-if="!readonly && currentNode" ref="nodeSetting" :flow-node="currentNode" />
|
||||||
v-if="!readonly && currentNode"
|
|
||||||
ref="nodeSetting"
|
|
||||||
:flow-node="currentNode"
|
|
||||||
/>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
@ -59,16 +57,18 @@ import { SimpleFlowNode, NodeType, NODE_DEFAULT_TEXT } from '../consts'
|
|||||||
import NodeHandler from '../NodeHandler.vue'
|
import NodeHandler from '../NodeHandler.vue'
|
||||||
import { useNodeName2, useWatchNode, useTaskStatusClass } from '../node'
|
import { useNodeName2, useWatchNode, useTaskStatusClass } from '../node'
|
||||||
import RouteNodeConfig from '../nodes-config/RouteNodeConfig.vue'
|
import RouteNodeConfig from '../nodes-config/RouteNodeConfig.vue'
|
||||||
|
|
||||||
defineOptions({
|
defineOptions({
|
||||||
name: 'RouteNode'
|
name: 'RouteNode'
|
||||||
})
|
})
|
||||||
|
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
flowNode: {
|
flowNode: {
|
||||||
type: Object as () => SimpleFlowNode,
|
type: Object as () => SimpleFlowNode,
|
||||||
required: true
|
required: true
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
// 定义事件,更新父组件。
|
// 定义事件,更新父组件
|
||||||
const emits = defineEmits<{
|
const emits = defineEmits<{
|
||||||
'update:flowNode': [node: SimpleFlowNode | undefined]
|
'update:flowNode': [node: SimpleFlowNode | undefined]
|
||||||
}>()
|
}>()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user