仿钉钉设计器- 审批节点配置结构调整
parent
58fc91b810
commit
ea1e51a655
|
@ -42,7 +42,14 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { SimpleFlowNode, NodeType, NODE_DEFAULT_NAME, ApproveMethodType, RejectHandlerType, CandidateStrategy } from './consts'
|
import {
|
||||||
|
SimpleFlowNode,
|
||||||
|
NodeType,
|
||||||
|
NODE_DEFAULT_NAME,
|
||||||
|
ApproveMethodType,
|
||||||
|
RejectHandlerType,
|
||||||
|
CandidateStrategy
|
||||||
|
} from './consts'
|
||||||
import { generateUUID } from '@/utils'
|
import { generateUUID } from '@/utils'
|
||||||
defineOptions({
|
defineOptions({
|
||||||
name: 'NodeHandler'
|
name: 'NodeHandler'
|
||||||
|
@ -63,37 +70,47 @@ const props = defineProps({
|
||||||
|
|
||||||
const emits = defineEmits(['update:childNode'])
|
const emits = defineEmits(['update:childNode'])
|
||||||
|
|
||||||
|
|
||||||
const addNode = (type: number) => {
|
const addNode = (type: number) => {
|
||||||
popoverShow.value = false
|
popoverShow.value = false
|
||||||
if (type === NodeType.USER_TASK_NODE) {
|
if (type === NodeType.USER_TASK_NODE) {
|
||||||
const id = 'Activity_'+ generateUUID();
|
const id = 'Activity_' + generateUUID()
|
||||||
const data: SimpleFlowNode = {
|
const data: SimpleFlowNode = {
|
||||||
id: id,
|
id: id,
|
||||||
name: NODE_DEFAULT_NAME.get(NodeType.USER_TASK_NODE) as string,
|
name: NODE_DEFAULT_NAME.get(NodeType.USER_TASK_NODE) as string,
|
||||||
showText: '',
|
showText: '',
|
||||||
type: NodeType.USER_TASK_NODE,
|
type: NodeType.USER_TASK_NODE,
|
||||||
// 审批节点配置
|
approveMethod: ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE,
|
||||||
attributes: {
|
candidateStrategy: CandidateStrategy.USER,
|
||||||
approveMethod: ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE,
|
candidateParam: undefined,
|
||||||
candidateStrategy: CandidateStrategy.USER,
|
fieldsPermission: undefined,
|
||||||
candidateParam: undefined,
|
// 超时处理
|
||||||
fieldsPermission: undefined,
|
timeoutHandler: {
|
||||||
// 超时处理
|
enable: false
|
||||||
timeoutHandler: {
|
},
|
||||||
enable: false
|
rejectHandler: {
|
||||||
},
|
type: RejectHandlerType.FINISH_PROCESS
|
||||||
rejectHandler: {
|
|
||||||
type: RejectHandlerType.FINISH_PROCESS
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
childNode: props.childNode
|
childNode: props.childNode
|
||||||
|
// 审批节点配置
|
||||||
|
// attributes: {
|
||||||
|
// approveMethod: ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE,
|
||||||
|
// candidateStrategy: CandidateStrategy.USER,
|
||||||
|
// candidateParam: undefined,
|
||||||
|
// fieldsPermission: undefined,
|
||||||
|
// // 超时处理
|
||||||
|
// timeoutHandler: {
|
||||||
|
// enable: false
|
||||||
|
// },
|
||||||
|
// rejectHandler: {
|
||||||
|
// type: RejectHandlerType.FINISH_PROCESS
|
||||||
|
// }
|
||||||
|
// },
|
||||||
}
|
}
|
||||||
emits('update:childNode', data);
|
emits('update:childNode', data)
|
||||||
}
|
}
|
||||||
if (type === NodeType.COPY_TASK_NODE) {
|
if (type === NodeType.COPY_TASK_NODE) {
|
||||||
const data: SimpleFlowNode = {
|
const data: SimpleFlowNode = {
|
||||||
id: 'Activity_'+ generateUUID(),
|
id: 'Activity_' + generateUUID(),
|
||||||
name: NODE_DEFAULT_NAME.get(NodeType.COPY_TASK_NODE) as string,
|
name: NODE_DEFAULT_NAME.get(NodeType.COPY_TASK_NODE) as string,
|
||||||
showText: '',
|
showText: '',
|
||||||
type: NodeType.COPY_TASK_NODE,
|
type: NodeType.COPY_TASK_NODE,
|
||||||
|
@ -108,14 +125,14 @@ const addNode = (type: number) => {
|
||||||
emits('update:childNode', data)
|
emits('update:childNode', data)
|
||||||
}
|
}
|
||||||
if (type === NodeType.EXCLUSIVE_NODE) {
|
if (type === NodeType.EXCLUSIVE_NODE) {
|
||||||
const data : SimpleFlowNode = {
|
const data: SimpleFlowNode = {
|
||||||
name: '条件分支',
|
name: '条件分支',
|
||||||
type: NodeType.EXCLUSIVE_NODE,
|
type: NodeType.EXCLUSIVE_NODE,
|
||||||
id: 'GateWay_' + generateUUID(),
|
id: 'GateWay_' + generateUUID(),
|
||||||
childNode: props.childNode,
|
childNode: props.childNode,
|
||||||
conditionNodes: [
|
conditionNodes: [
|
||||||
{
|
{
|
||||||
id: 'Flow_'+ generateUUID(),
|
id: 'Flow_' + generateUUID(),
|
||||||
name: '条件1',
|
name: '条件1',
|
||||||
showText: '',
|
showText: '',
|
||||||
type: NodeType.CONDITION_NODE,
|
type: NodeType.CONDITION_NODE,
|
||||||
|
@ -126,7 +143,7 @@ const addNode = (type: number) => {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'Flow_'+ generateUUID(),
|
id: 'Flow_' + generateUUID(),
|
||||||
name: '其它情况',
|
name: '其它情况',
|
||||||
showText: '其它情况进入此流程',
|
showText: '其它情况进入此流程',
|
||||||
type: NodeType.CONDITION_NODE,
|
type: NodeType.CONDITION_NODE,
|
||||||
|
@ -141,25 +158,25 @@ const addNode = (type: number) => {
|
||||||
emits('update:childNode', data)
|
emits('update:childNode', data)
|
||||||
}
|
}
|
||||||
if (type === NodeType.PARALLEL_NODE_FORK) {
|
if (type === NodeType.PARALLEL_NODE_FORK) {
|
||||||
const data : SimpleFlowNode = {
|
const data: SimpleFlowNode = {
|
||||||
name: '并行分支',
|
name: '并行分支',
|
||||||
type: NodeType.PARALLEL_NODE_FORK,
|
type: NodeType.PARALLEL_NODE_FORK,
|
||||||
id: 'GateWay_' + generateUUID(),
|
id: 'GateWay_' + generateUUID(),
|
||||||
childNode: props.childNode,
|
childNode: props.childNode,
|
||||||
conditionNodes: [
|
conditionNodes: [
|
||||||
{
|
{
|
||||||
id: 'Flow_'+ generateUUID(),
|
id: 'Flow_' + generateUUID(),
|
||||||
name: '并行1',
|
name: '并行1',
|
||||||
showText: '无需配置条件同时执行',
|
showText: '无需配置条件同时执行',
|
||||||
type: NodeType.CONDITION_NODE,
|
type: NodeType.CONDITION_NODE,
|
||||||
childNode: undefined,
|
childNode: undefined
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 'Flow_'+ generateUUID(),
|
id: 'Flow_' + generateUUID(),
|
||||||
name: '并行2',
|
name: '并行2',
|
||||||
showText: '无需配置条件同时执行',
|
showText: '无需配置条件同时执行',
|
||||||
type: NodeType.CONDITION_NODE,
|
type: NodeType.CONDITION_NODE,
|
||||||
childNode: undefined,
|
childNode: undefined
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ export enum NodeType {
|
||||||
* 抄送人节点
|
* 抄送人节点
|
||||||
*/
|
*/
|
||||||
COPY_TASK_NODE = 2,
|
COPY_TASK_NODE = 2,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 条件节点
|
* 条件节点
|
||||||
*/
|
*/
|
||||||
|
@ -71,44 +71,40 @@ export enum RejectHandlerType {
|
||||||
* 驳回到指定节点
|
* 驳回到指定节点
|
||||||
*/
|
*/
|
||||||
RETURN_USER_TASK = 2
|
RETURN_USER_TASK = 2
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 条件配置类型 ( 用于条件节点配置 )
|
// 条件配置类型 ( 用于条件节点配置 )
|
||||||
export enum ConditionConfigType {
|
export enum ConditionConfigType {
|
||||||
|
/**
|
||||||
/**
|
|
||||||
* 条件表达式
|
* 条件表达式
|
||||||
*/
|
*/
|
||||||
EXPRESSION = 1,
|
EXPRESSION = 1,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 条件规则
|
* 条件规则
|
||||||
*/
|
*/
|
||||||
RULE = 2
|
RULE = 2
|
||||||
}
|
}
|
||||||
// 多人审批方式类型 ( 用于审批节点 )
|
// 多人审批方式类型 ( 用于审批节点 )
|
||||||
export enum ApproveMethodType {
|
export enum ApproveMethodType {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 随机挑选一人审批
|
* 随机挑选一人审批
|
||||||
*/
|
*/
|
||||||
RRANDOM_SELECT_ONE_APPROVE = 1,
|
RRANDOM_SELECT_ONE_APPROVE = 1,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 多人会签(按通过比例)
|
* 多人会签(按通过比例)
|
||||||
*/
|
*/
|
||||||
APPROVE_BY_RATIO = 2,
|
APPROVE_BY_RATIO = 2,
|
||||||
|
|
||||||
/**
|
|
||||||
* 多人或签(通过只需一人,拒绝只需一人)
|
|
||||||
*/
|
|
||||||
ANY_APPROVE = 3,
|
|
||||||
/**
|
|
||||||
* 多人依次审批
|
|
||||||
*/
|
|
||||||
SEQUENTIAL_APPROVE = 4
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 多人或签(通过只需一人,拒绝只需一人)
|
||||||
|
*/
|
||||||
|
ANY_APPROVE = 3,
|
||||||
|
/**
|
||||||
|
* 多人依次审批
|
||||||
|
*/
|
||||||
|
SEQUENTIAL_APPROVE = 4
|
||||||
}
|
}
|
||||||
|
|
||||||
// 候选人策略 ( 用于审批节点。抄送节点 )
|
// 候选人策略 ( 用于审批节点。抄送节点 )
|
||||||
|
@ -137,37 +133,67 @@ export enum CandidateStrategy {
|
||||||
* 发起人自选
|
* 发起人自选
|
||||||
*/
|
*/
|
||||||
START_USER_SELECT = 35,
|
START_USER_SELECT = 35,
|
||||||
/**
|
/**
|
||||||
* 发起人自己
|
* 发起人自己
|
||||||
*/
|
*/
|
||||||
START_USER = 36,
|
START_USER = 36,
|
||||||
/**
|
/**
|
||||||
* 指定用户组
|
* 指定用户组
|
||||||
*/
|
*/
|
||||||
USER_GROUP = 40,
|
USER_GROUP = 40,
|
||||||
/**
|
/**
|
||||||
* 流程表达式
|
* 流程表达式
|
||||||
*/
|
*/
|
||||||
EXPRESSION = 60
|
EXPRESSION = 60
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export type RejectHandler = {
|
||||||
|
type: RejectHandlerType
|
||||||
|
|
||||||
|
returnNodeId?: string
|
||||||
|
}
|
||||||
|
|
||||||
|
export type TimeoutHandler = {
|
||||||
|
//是否开启超时处理
|
||||||
|
enable: boolean
|
||||||
|
// 超时执行的动作
|
||||||
|
action?: number
|
||||||
|
// 超时时间设置
|
||||||
|
timeDuration?: string
|
||||||
|
// 执行动作是自动提醒, 最大提醒次数
|
||||||
|
maxRemindCount?: number
|
||||||
|
}
|
||||||
|
|
||||||
export type SimpleFlowNode = {
|
export type SimpleFlowNode = {
|
||||||
id: string,
|
id: string
|
||||||
type: NodeType,
|
type: NodeType
|
||||||
name: string,
|
name: string
|
||||||
showText?: string,
|
showText?: string
|
||||||
attributes?: any,
|
attributes?: any
|
||||||
// 孩子节点
|
// 孩子节点
|
||||||
childNode?: SimpleFlowNode,
|
childNode?: SimpleFlowNode
|
||||||
// 条件节点
|
// 条件节点
|
||||||
conditionNodes?: SimpleFlowNode[]
|
conditionNodes?: SimpleFlowNode[]
|
||||||
|
// 候选人策略
|
||||||
|
candidateStrategy?: number
|
||||||
|
// 候选人参数
|
||||||
|
candidateParam?: string
|
||||||
|
// 多人审批方式
|
||||||
|
approveMethod?: ApproveMethodType
|
||||||
|
//通过比例
|
||||||
|
approveRatio: number
|
||||||
|
// 表单权限
|
||||||
|
fieldsPermission?: any[]
|
||||||
|
// 审批任务超时处理
|
||||||
|
timeoutHandler?: TimeoutHandler
|
||||||
|
// 审批任务拒绝处理
|
||||||
|
rejectHandler?: RejectHandler
|
||||||
}
|
}
|
||||||
|
|
||||||
// 条件组
|
// 条件组
|
||||||
export type ConditionGroup = {
|
export type ConditionGroup = {
|
||||||
// 条件组的逻辑关系是否为且
|
// 条件组的逻辑关系是否为且
|
||||||
and : boolean,
|
and: boolean
|
||||||
// 条件数组
|
// 条件数组
|
||||||
conditions: Condition[]
|
conditions: Condition[]
|
||||||
}
|
}
|
||||||
|
@ -175,84 +201,83 @@ export type ConditionGroup = {
|
||||||
// 条件
|
// 条件
|
||||||
export type Condition = {
|
export type Condition = {
|
||||||
// 条件规则的逻辑关系是否为且
|
// 条件规则的逻辑关系是否为且
|
||||||
and : boolean,
|
and: boolean
|
||||||
rules: ConditionRule[]
|
rules: ConditionRule[]
|
||||||
}
|
}
|
||||||
|
|
||||||
// 条件规则
|
// 条件规则
|
||||||
export type ConditionRule = {
|
export type ConditionRule = {
|
||||||
type : number,
|
type: number
|
||||||
opName: string,
|
opName: string
|
||||||
opCode: string,
|
opCode: string
|
||||||
leftSide: string,
|
leftSide: string
|
||||||
rightSide: string
|
rightSide: string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const NODE_DEFAULT_TEXT = new Map<number, string>()
|
||||||
export const NODE_DEFAULT_TEXT = new Map<number,string>()
|
|
||||||
NODE_DEFAULT_TEXT.set(NodeType.USER_TASK_NODE, '请配置审批人')
|
NODE_DEFAULT_TEXT.set(NodeType.USER_TASK_NODE, '请配置审批人')
|
||||||
NODE_DEFAULT_TEXT.set(NodeType.COPY_TASK_NODE, '请配置抄送人')
|
NODE_DEFAULT_TEXT.set(NodeType.COPY_TASK_NODE, '请配置抄送人')
|
||||||
NODE_DEFAULT_TEXT.set(NodeType.CONDITION_NODE, '请设置条件')
|
NODE_DEFAULT_TEXT.set(NodeType.CONDITION_NODE, '请设置条件')
|
||||||
|
|
||||||
export const NODE_DEFAULT_NAME = new Map<number,string>()
|
export const NODE_DEFAULT_NAME = new Map<number, string>()
|
||||||
NODE_DEFAULT_NAME.set(NodeType.USER_TASK_NODE, '审批人')
|
NODE_DEFAULT_NAME.set(NodeType.USER_TASK_NODE, '审批人')
|
||||||
NODE_DEFAULT_NAME.set(NodeType.COPY_TASK_NODE, '抄送人')
|
NODE_DEFAULT_NAME.set(NodeType.COPY_TASK_NODE, '抄送人')
|
||||||
NODE_DEFAULT_NAME.set(NodeType.CONDITION_NODE, '条件')
|
NODE_DEFAULT_NAME.set(NodeType.CONDITION_NODE, '条件')
|
||||||
|
|
||||||
export const APPROVE_METHODS: DictDataVO [] = [
|
export const APPROVE_METHODS: DictDataVO[] = [
|
||||||
{ label: '随机挑选一人审批', value: ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE },
|
{ label: '随机挑选一人审批', value: ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE },
|
||||||
{ label: '多人会签(按通过比例%)', value: ApproveMethodType.APPROVE_BY_RATIO },
|
{ label: '多人会签(按通过比例%)', value: ApproveMethodType.APPROVE_BY_RATIO },
|
||||||
{ label: '多人或签(一人通过或拒绝)', value: ApproveMethodType.ANY_APPROVE },
|
{ label: '多人或签(一人通过或拒绝)', value: ApproveMethodType.ANY_APPROVE },
|
||||||
{ label: '依次审批(按顺序依次审批)', value: ApproveMethodType.SEQUENTIAL_APPROVE }
|
{ label: '依次审批(按顺序依次审批)', value: ApproveMethodType.SEQUENTIAL_APPROVE }
|
||||||
]
|
]
|
||||||
|
|
||||||
export const CONDITION_CONFIG_TYPES: DictDataVO [] = [
|
export const CONDITION_CONFIG_TYPES: DictDataVO[] = [
|
||||||
{ label: '条件表达式', value: 1 },
|
{ label: '条件表达式', value: 1 },
|
||||||
{ label: '条件规则', value: 2 }
|
{ label: '条件规则', value: 2 }
|
||||||
]
|
]
|
||||||
|
|
||||||
// 时间单位类型
|
// 时间单位类型
|
||||||
export const TIME_UNIT_TYPES: DictDataVO [] = [
|
export const TIME_UNIT_TYPES: DictDataVO[] = [
|
||||||
{ label: '分钟', value: TimeUnitType.MINUTE },
|
{ label: '分钟', value: TimeUnitType.MINUTE },
|
||||||
{ label: '小时', value: TimeUnitType.HOUR },
|
{ label: '小时', value: TimeUnitType.HOUR },
|
||||||
{ label: '天', value: TimeUnitType.DAY },
|
{ label: '天', value: TimeUnitType.DAY }
|
||||||
]
|
]
|
||||||
// 超时处理执行动作类型
|
// 超时处理执行动作类型
|
||||||
export const TIMEOUT_HANDLER_ACTION_TYPES: DictDataVO [] = [
|
export const TIMEOUT_HANDLER_ACTION_TYPES: DictDataVO[] = [
|
||||||
{ label: '自动提醒', value: 1 },
|
{ label: '自动提醒', value: 1 },
|
||||||
{ label: '自动同意', value: 2 },
|
{ label: '自动同意', value: 2 },
|
||||||
{ label: '自动拒绝', value: 3 },
|
{ label: '自动拒绝', value: 3 }
|
||||||
]
|
]
|
||||||
export const REJECT_HANDLER_TYPES: DictDataVO [] = [
|
export const REJECT_HANDLER_TYPES: DictDataVO[] = [
|
||||||
{ label: '终止流程', value: RejectHandlerType.FINISH_PROCESS },
|
{ label: '终止流程', value: RejectHandlerType.FINISH_PROCESS },
|
||||||
{ label: '驳回到指定节点', value: RejectHandlerType.RETURN_USER_TASK }
|
{ label: '驳回到指定节点', value: RejectHandlerType.RETURN_USER_TASK }
|
||||||
// { label: '结束任务', value: RejectHandlerType.FINISH_TASK }
|
// { label: '结束任务', value: RejectHandlerType.FINISH_TASK }
|
||||||
]
|
]
|
||||||
|
|
||||||
// 比较运算符
|
// 比较运算符
|
||||||
export const COMPARISON_OPERATORS : DictDataVO = [
|
export const COMPARISON_OPERATORS: DictDataVO = [
|
||||||
{
|
{
|
||||||
value: '==',
|
value: '==',
|
||||||
label: '等于',
|
label: '等于'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
value: '!=',
|
value: '!=',
|
||||||
label: '不等于',
|
label: '不等于'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
value: '>',
|
value: '>',
|
||||||
label: '大于',
|
label: '大于'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
value: '>=',
|
value: '>=',
|
||||||
label: '大于等于',
|
label: '大于等于'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
value: '<',
|
value: '<',
|
||||||
label: '小于',
|
label: '小于'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
value: '<=',
|
value: '<=',
|
||||||
label: '小于等于',
|
label: '小于等于'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
<el-form label-position="top">
|
<el-form label-position="top">
|
||||||
<el-form-item label="审批人设置" prop="candidateStrategy">
|
<el-form-item label="审批人设置" prop="candidateStrategy">
|
||||||
<el-radio-group
|
<el-radio-group
|
||||||
v-model="currentNode.attributes.candidateStrategy"
|
v-model="currentNode.candidateStrategy"
|
||||||
@change="changeCandidateStrategy"
|
@change="changeCandidateStrategy"
|
||||||
>
|
>
|
||||||
<el-radio
|
<el-radio
|
||||||
|
@ -47,7 +47,7 @@
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item
|
<el-form-item
|
||||||
v-if="currentNode.attributes.candidateStrategy == CandidateStrategy.ROLE"
|
v-if="currentNode.candidateStrategy == CandidateStrategy.ROLE"
|
||||||
label="指定角色"
|
label="指定角色"
|
||||||
prop="candidateParam"
|
prop="candidateParam"
|
||||||
>
|
>
|
||||||
|
@ -62,8 +62,8 @@
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item
|
<el-form-item
|
||||||
v-if="
|
v-if="
|
||||||
currentNode.attributes.candidateStrategy == CandidateStrategy.DEPT_MEMBER ||
|
currentNode.candidateStrategy == CandidateStrategy.DEPT_MEMBER ||
|
||||||
currentNode.attributes.candidateStrategy == CandidateStrategy.DEPT_LEADER
|
currentNode.candidateStrategy == CandidateStrategy.DEPT_LEADER
|
||||||
"
|
"
|
||||||
label="指定部门"
|
label="指定部门"
|
||||||
prop="candidateParam"
|
prop="candidateParam"
|
||||||
|
@ -82,7 +82,7 @@
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item
|
<el-form-item
|
||||||
v-if="currentNode.attributes.candidateStrategy == CandidateStrategy.POST"
|
v-if="currentNode.candidateStrategy == CandidateStrategy.POST"
|
||||||
label="指定岗位"
|
label="指定岗位"
|
||||||
prop="candidateParam"
|
prop="candidateParam"
|
||||||
span="24"
|
span="24"
|
||||||
|
@ -97,7 +97,7 @@
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item
|
<el-form-item
|
||||||
v-if="currentNode.attributes.candidateStrategy == CandidateStrategy.USER"
|
v-if="currentNode.candidateStrategy == CandidateStrategy.USER"
|
||||||
label="指定用户"
|
label="指定用户"
|
||||||
prop="candidateParam"
|
prop="candidateParam"
|
||||||
span="24"
|
span="24"
|
||||||
|
@ -118,7 +118,7 @@
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item
|
<el-form-item
|
||||||
v-if="currentNode.attributes.candidateStrategy === CandidateStrategy.USER_GROUP"
|
v-if="currentNode.candidateStrategy === CandidateStrategy.USER_GROUP"
|
||||||
label="指定用户组"
|
label="指定用户组"
|
||||||
prop="candidateParam"
|
prop="candidateParam"
|
||||||
>
|
>
|
||||||
|
@ -132,7 +132,7 @@
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item
|
<el-form-item
|
||||||
v-if="currentNode.attributes.candidateStrategy === CandidateStrategy.EXPRESSION"
|
v-if="currentNode.candidateStrategy === CandidateStrategy.EXPRESSION"
|
||||||
label="流程表达式"
|
label="流程表达式"
|
||||||
prop="candidateParam"
|
prop="candidateParam"
|
||||||
>
|
>
|
||||||
|
@ -144,10 +144,7 @@
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="多人审批方式" prop="approveMethod">
|
<el-form-item label="多人审批方式" prop="approveMethod">
|
||||||
<el-radio-group
|
<el-radio-group v-model="currentNode.approveMethod" @change="approveMethodChanged">
|
||||||
v-model="currentNode.attributes.approveMethod"
|
|
||||||
@change="approveMethodChanged"
|
|
||||||
>
|
|
||||||
<div class="flex-col">
|
<div class="flex-col">
|
||||||
<div
|
<div
|
||||||
v-for="(item, index) in APPROVE_METHODS"
|
v-for="(item, index) in APPROVE_METHODS"
|
||||||
|
@ -165,14 +162,14 @@
|
||||||
{{ item.label }}
|
{{ item.label }}
|
||||||
</el-radio>
|
</el-radio>
|
||||||
<el-input-number
|
<el-input-number
|
||||||
v-model="currentNode.attributes.approveRatio"
|
v-model="currentNode.approveRatio"
|
||||||
:min="10"
|
:min="10"
|
||||||
:max="100"
|
:max="100"
|
||||||
:step="10"
|
:step="10"
|
||||||
size="small"
|
size="small"
|
||||||
v-if="
|
v-if="
|
||||||
item.value === ApproveMethodType.APPROVE_BY_RATIO &&
|
item.value === ApproveMethodType.APPROVE_BY_RATIO &&
|
||||||
currentNode.attributes.approveMethod === ApproveMethodType.APPROVE_BY_RATIO
|
currentNode.approveMethod === ApproveMethodType.APPROVE_BY_RATIO
|
||||||
"
|
"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
@ -181,7 +178,7 @@
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-divider content-position="left">审批人拒绝时</el-divider>
|
<el-divider content-position="left">审批人拒绝时</el-divider>
|
||||||
<el-form-item prop="rejectHandler">
|
<el-form-item prop="rejectHandler">
|
||||||
<el-radio-group v-model="currentNode.attributes.rejectHandler.type">
|
<el-radio-group v-model="currentNode.rejectHandler!.type">
|
||||||
<div class="flex-col">
|
<div class="flex-col">
|
||||||
<div v-for="(item, index) in REJECT_HANDLER_TYPES" :key="index">
|
<div v-for="(item, index) in REJECT_HANDLER_TYPES" :key="index">
|
||||||
<el-radio :key="item.value" :value="item.value" :label="item.label" />
|
<el-radio :key="item.value" :value="item.value" :label="item.label" />
|
||||||
|
@ -191,12 +188,12 @@
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item
|
<el-form-item
|
||||||
v-if="currentNode.attributes.rejectHandler.type == RejectHandlerType.RETURN_USER_TASK"
|
v-if="currentNode.rejectHandler!.type == RejectHandlerType.RETURN_USER_TASK"
|
||||||
label="驳回节点"
|
label="驳回节点"
|
||||||
prop="rejectHandlerNode"
|
prop="rejectHandlerNode"
|
||||||
>
|
>
|
||||||
<el-select
|
<el-select
|
||||||
v-model="currentNode.attributes.rejectHandler.returnNodeId"
|
v-model="currentNode.rejectHandler!.returnNodeId"
|
||||||
clearable
|
clearable
|
||||||
style="width: 100%"
|
style="width: 100%"
|
||||||
>
|
>
|
||||||
|
@ -211,7 +208,7 @@
|
||||||
<el-divider content-position="left">审批人超时未处理时</el-divider>
|
<el-divider content-position="left">审批人超时未处理时</el-divider>
|
||||||
<el-form-item label="启用开关" prop="timeoutHandlerEnable">
|
<el-form-item label="启用开关" prop="timeoutHandlerEnable">
|
||||||
<el-switch
|
<el-switch
|
||||||
v-model="currentNode.attributes.timeoutHandler.enable"
|
v-model="currentNode.timeoutHandler!.enable"
|
||||||
active-text="开启"
|
active-text="开启"
|
||||||
inactive-text="关闭"
|
inactive-text="关闭"
|
||||||
@change="timeoutHandlerChange"
|
@change="timeoutHandlerChange"
|
||||||
|
@ -220,9 +217,9 @@
|
||||||
<el-form-item
|
<el-form-item
|
||||||
label="执行动作"
|
label="执行动作"
|
||||||
prop="timeoutHandlerAction"
|
prop="timeoutHandlerAction"
|
||||||
v-if="currentNode.attributes.timeoutHandler.enable"
|
v-if="currentNode.timeoutHandler?.enable"
|
||||||
>
|
>
|
||||||
<el-radio-group v-model="currentNode.attributes.timeoutHandler.action">
|
<el-radio-group v-model="currentNode.timeoutHandler!.action">
|
||||||
<el-radio-button
|
<el-radio-button
|
||||||
v-for="item in TIMEOUT_HANDLER_ACTION_TYPES"
|
v-for="item in TIMEOUT_HANDLER_ACTION_TYPES"
|
||||||
:key="item.value"
|
:key="item.value"
|
||||||
|
@ -234,7 +231,7 @@
|
||||||
<el-form-item
|
<el-form-item
|
||||||
label="超时时间设置"
|
label="超时时间设置"
|
||||||
prop="timeoutHandlerTimeDuration"
|
prop="timeoutHandlerTimeDuration"
|
||||||
v-if="currentNode.attributes.timeoutHandler.enable"
|
v-if="currentNode.timeoutHandler?.enable"
|
||||||
>
|
>
|
||||||
<span class="mr-2">当超过</span>
|
<span class="mr-2">当超过</span>
|
||||||
<el-input-number
|
<el-input-number
|
||||||
|
@ -262,13 +259,10 @@
|
||||||
<el-form-item
|
<el-form-item
|
||||||
label="最大提醒次数"
|
label="最大提醒次数"
|
||||||
prop="timeoutHandlerMaxRemindCount"
|
prop="timeoutHandlerMaxRemindCount"
|
||||||
v-if="
|
v-if="currentNode.timeoutHandler?.enable && currentNode.timeoutHandler?.action === 1"
|
||||||
currentNode.attributes.timeoutHandler.enable &&
|
|
||||||
currentNode.attributes.timeoutHandler.action === 1
|
|
||||||
"
|
|
||||||
>
|
>
|
||||||
<el-input-number
|
<el-input-number
|
||||||
v-model="currentNode.attributes.timeoutHandler.maxRemindCount"
|
v-model="currentNode.timeoutHandler!.maxRemindCount"
|
||||||
:min="1"
|
:min="1"
|
||||||
:max="10"
|
:max="10"
|
||||||
/>
|
/>
|
||||||
|
@ -289,7 +283,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
class="field-setting-item"
|
class="field-setting-item"
|
||||||
v-for="(item, index) in currentNode.attributes.fieldsPermission"
|
v-for="(item, index) in currentNode.fieldsPermission"
|
||||||
:key="index"
|
:key="index"
|
||||||
>
|
>
|
||||||
<div class="field-setting-item-label"> {{ item.title }} </div>
|
<div class="field-setting-item-label"> {{ item.title }} </div>
|
||||||
|
@ -371,9 +365,9 @@ const closeDrawer = () => {
|
||||||
settingVisible.value = false
|
settingVisible.value = false
|
||||||
}
|
}
|
||||||
const saveConfig = () => {
|
const saveConfig = () => {
|
||||||
currentNode.value.attributes.candidateParam = candidateParamArray.value?.join(',')
|
currentNode.value.candidateParam = candidateParamArray.value?.join(',')
|
||||||
if (currentNode.value.attributes.timeoutHandler.enable) {
|
if (currentNode.value.timeoutHandler?.enable) {
|
||||||
currentNode.value.attributes.timeoutHandler.timeDuration = isoTimeDuration.value
|
currentNode.value.timeoutHandler.timeDuration = isoTimeDuration.value
|
||||||
}
|
}
|
||||||
currentNode.value.showText = getShowText()
|
currentNode.value.showText = getShowText()
|
||||||
settingVisible.value = false
|
settingVisible.value = false
|
||||||
|
@ -381,7 +375,7 @@ const saveConfig = () => {
|
||||||
const getShowText = (): string => {
|
const getShowText = (): string => {
|
||||||
let showText = ''
|
let showText = ''
|
||||||
// 指定成员
|
// 指定成员
|
||||||
if (currentNode.value.attributes.candidateStrategy === CandidateStrategy.USER) {
|
if (currentNode.value.candidateStrategy === CandidateStrategy.USER) {
|
||||||
if (candidateParamArray.value?.length > 0) {
|
if (candidateParamArray.value?.length > 0) {
|
||||||
const candidateNames: string[] = []
|
const candidateNames: string[] = []
|
||||||
userOptions?.value.forEach((item) => {
|
userOptions?.value.forEach((item) => {
|
||||||
|
@ -393,7 +387,7 @@ const getShowText = (): string => {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 指定角色
|
// 指定角色
|
||||||
if (currentNode.value.attributes.candidateStrategy === CandidateStrategy.ROLE) {
|
if (currentNode.value.candidateStrategy === CandidateStrategy.ROLE) {
|
||||||
if (candidateParamArray.value?.length > 0) {
|
if (candidateParamArray.value?.length > 0) {
|
||||||
const candidateNames: string[] = []
|
const candidateNames: string[] = []
|
||||||
roleOptions?.value.forEach((item) => {
|
roleOptions?.value.forEach((item) => {
|
||||||
|
@ -406,8 +400,8 @@ const getShowText = (): string => {
|
||||||
}
|
}
|
||||||
// 指定部门
|
// 指定部门
|
||||||
if (
|
if (
|
||||||
currentNode.value.attributes.candidateStrategy === CandidateStrategy.DEPT_MEMBER ||
|
currentNode.value.candidateStrategy === CandidateStrategy.DEPT_MEMBER ||
|
||||||
currentNode.value.attributes.candidateStrategy === CandidateStrategy.DEPT_LEADER
|
currentNode.value.candidateStrategy === CandidateStrategy.DEPT_LEADER
|
||||||
) {
|
) {
|
||||||
if (candidateParamArray.value?.length > 0) {
|
if (candidateParamArray.value?.length > 0) {
|
||||||
const candidateNames: string[] = []
|
const candidateNames: string[] = []
|
||||||
|
@ -416,7 +410,7 @@ const getShowText = (): string => {
|
||||||
candidateNames.push(item.name)
|
candidateNames.push(item.name)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
if (currentNode.value.attributes.candidateStrategy === CandidateStrategy.DEPT_MEMBER) {
|
if (currentNode.value.candidateStrategy === CandidateStrategy.DEPT_MEMBER) {
|
||||||
showText = `部门成员:${candidateNames.join(',')}`
|
showText = `部门成员:${candidateNames.join(',')}`
|
||||||
} else {
|
} else {
|
||||||
showText = `部门的负责人:${candidateNames.join(',')}`
|
showText = `部门的负责人:${candidateNames.join(',')}`
|
||||||
|
@ -425,7 +419,7 @@ const getShowText = (): string => {
|
||||||
}
|
}
|
||||||
|
|
||||||
// 指定岗位
|
// 指定岗位
|
||||||
if (currentNode.value.attributes.candidateStrategy === CandidateStrategy.POST) {
|
if (currentNode.value.candidateStrategy === CandidateStrategy.POST) {
|
||||||
if (candidateParamArray.value?.length > 0) {
|
if (candidateParamArray.value?.length > 0) {
|
||||||
const candidateNames: string[] = []
|
const candidateNames: string[] = []
|
||||||
postOptions?.value.forEach((item) => {
|
postOptions?.value.forEach((item) => {
|
||||||
|
@ -437,7 +431,7 @@ const getShowText = (): string => {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 指定用户组
|
// 指定用户组
|
||||||
if (currentNode.value.attributes.candidateStrategy === CandidateStrategy.USER_GROUP) {
|
if (currentNode.value.candidateStrategy === CandidateStrategy.USER_GROUP) {
|
||||||
if (candidateParamArray.value?.length > 0) {
|
if (candidateParamArray.value?.length > 0) {
|
||||||
const candidateNames: string[] = []
|
const candidateNames: string[] = []
|
||||||
userGroupOptions?.value.forEach((item) => {
|
userGroupOptions?.value.forEach((item) => {
|
||||||
|
@ -450,16 +444,16 @@ const getShowText = (): string => {
|
||||||
}
|
}
|
||||||
|
|
||||||
// 发起人自选
|
// 发起人自选
|
||||||
if (currentNode.value.attributes.candidateStrategy === CandidateStrategy.START_USER_SELECT) {
|
if (currentNode.value.candidateStrategy === CandidateStrategy.START_USER_SELECT) {
|
||||||
showText = `发起人自选`
|
showText = `发起人自选`
|
||||||
}
|
}
|
||||||
// 发起人自己
|
// 发起人自己
|
||||||
if (currentNode.value.attributes.candidateStrategy === CandidateStrategy.START_USER) {
|
if (currentNode.value.candidateStrategy === CandidateStrategy.START_USER) {
|
||||||
showText = `发起人自己`
|
showText = `发起人自己`
|
||||||
}
|
}
|
||||||
|
|
||||||
// 流程表达式
|
// 流程表达式
|
||||||
if (currentNode.value.attributes.candidateStrategy === CandidateStrategy.EXPRESSION) {
|
if (currentNode.value.candidateStrategy === CandidateStrategy.EXPRESSION) {
|
||||||
if (candidateParamArray.value?.length > 0) {
|
if (candidateParamArray.value?.length > 0) {
|
||||||
showText = `流程表达式:${candidateParamArray.value[0]}`
|
showText = `流程表达式:${candidateParamArray.value[0]}`
|
||||||
}
|
}
|
||||||
|
@ -472,22 +466,23 @@ const open = () => {
|
||||||
// 修改当前编辑的节点, 由父组件传过来
|
// 修改当前编辑的节点, 由父组件传过来
|
||||||
const setCurrentNode = (node: SimpleFlowNode) => {
|
const setCurrentNode = (node: SimpleFlowNode) => {
|
||||||
currentNode.value = node
|
currentNode.value = node
|
||||||
currentNode.value.attributes.fieldsPermission =
|
currentNode.value.fieldsPermission =
|
||||||
node.attributes.fieldsPermission || getDefaultFieldsPermission(formFields?.value)
|
node.fieldsPermission || getDefaultFieldsPermission(formFields?.value)
|
||||||
const strCandidateParam = node.attributes?.candidateParam
|
const strCandidateParam = node?.candidateParam
|
||||||
if (strCandidateParam) {
|
if (strCandidateParam) {
|
||||||
candidateParamArray.value = strCandidateParam.split(',').map((item) => +item)
|
candidateParamArray.value = strCandidateParam.split(',').map((item) => +item)
|
||||||
}
|
}
|
||||||
if (currentNode.value.attributes?.candidateStrategy === CandidateStrategy.START_USER) {
|
if (
|
||||||
|
(candidateParamArray.value.length <= 1 &&
|
||||||
|
currentNode.value.candidateStrategy === CandidateStrategy.USER) ||
|
||||||
|
currentNode.value.candidateStrategy === CandidateStrategy.START_USER
|
||||||
|
) {
|
||||||
notAllowedMultiApprovers.value = true
|
notAllowedMultiApprovers.value = true
|
||||||
} else {
|
} else {
|
||||||
notAllowedMultiApprovers.value = false
|
notAllowedMultiApprovers.value = false
|
||||||
}
|
}
|
||||||
if (
|
if (currentNode.value.timeoutHandler?.enable && currentNode.value.timeoutHandler?.timeDuration) {
|
||||||
currentNode.value.attributes?.timeoutHandler?.enable &&
|
const strTimeDuration = currentNode.value.timeoutHandler.timeDuration
|
||||||
currentNode.value.attributes?.timeoutHandler?.timeDuration
|
|
||||||
) {
|
|
||||||
const strTimeDuration = currentNode.value.attributes.timeoutHandler.timeDuration
|
|
||||||
let parseTime = strTimeDuration.slice(2, strTimeDuration.length - 1)
|
let parseTime = strTimeDuration.slice(2, strTimeDuration.length - 1)
|
||||||
let parseTimeUnit = strTimeDuration.slice(strTimeDuration.length - 1)
|
let parseTimeUnit = strTimeDuration.slice(strTimeDuration.length - 1)
|
||||||
timeDuration.value = parseInt(parseTime)
|
timeDuration.value = parseInt(parseTime)
|
||||||
|
@ -503,10 +498,10 @@ defineExpose({ open, setCurrentNode }) // 暴露方法给父组件
|
||||||
|
|
||||||
const changeCandidateStrategy = () => {
|
const changeCandidateStrategy = () => {
|
||||||
candidateParamArray.value = []
|
candidateParamArray.value = []
|
||||||
currentNode.value.attributes.approveMethod = ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE
|
currentNode.value.approveMethod = ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE
|
||||||
if (
|
if (
|
||||||
currentNode.value.attributes.candidateStrategy === CandidateStrategy.START_USER ||
|
currentNode.value.candidateStrategy === CandidateStrategy.START_USER ||
|
||||||
currentNode.value.attributes.candidateStrategy === CandidateStrategy.USER
|
currentNode.value.candidateStrategy === CandidateStrategy.USER
|
||||||
) {
|
) {
|
||||||
notAllowedMultiApprovers.value = true
|
notAllowedMultiApprovers.value = true
|
||||||
} else {
|
} else {
|
||||||
|
@ -517,10 +512,10 @@ const changeCandidateStrategy = () => {
|
||||||
const changedCandidateUsers = () => {
|
const changedCandidateUsers = () => {
|
||||||
if (
|
if (
|
||||||
candidateParamArray.value?.length <= 1 &&
|
candidateParamArray.value?.length <= 1 &&
|
||||||
currentNode.value.attributes?.candidateStrategy === CandidateStrategy.USER
|
currentNode.value.candidateStrategy === CandidateStrategy.USER
|
||||||
) {
|
) {
|
||||||
currentNode.value.attributes.approveMethod = ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE
|
currentNode.value.approveMethod = ApproveMethodType.RRANDOM_SELECT_ONE_APPROVE
|
||||||
currentNode.value.attributes.rejectHandler.type = RejectHandlerType.FINISH_PROCESS
|
currentNode.value.rejectHandler!.type = RejectHandlerType.FINISH_PROCESS
|
||||||
notAllowedMultiApprovers.value = true
|
notAllowedMultiApprovers.value = true
|
||||||
} else {
|
} else {
|
||||||
notAllowedMultiApprovers.value = false
|
notAllowedMultiApprovers.value = false
|
||||||
|
@ -539,10 +534,10 @@ const blurEvent = () => {
|
||||||
currentNode.value.name || (NODE_DEFAULT_NAME.get(NodeType.USER_TASK_NODE) as string)
|
currentNode.value.name || (NODE_DEFAULT_NAME.get(NodeType.USER_TASK_NODE) as string)
|
||||||
}
|
}
|
||||||
const approveMethodChanged = () => {
|
const approveMethodChanged = () => {
|
||||||
currentNode.value.attributes.rejectHandler.type = RejectHandlerType.FINISH_PROCESS
|
currentNode.value.rejectHandler!.type = RejectHandlerType.FINISH_PROCESS
|
||||||
const approveMethod = currentNode.value.attributes?.approveMethod
|
const approveMethod = currentNode.value?.approveMethod
|
||||||
if (approveMethod === ApproveMethodType.APPROVE_BY_RATIO) {
|
if (approveMethod === ApproveMethodType.APPROVE_BY_RATIO) {
|
||||||
currentNode.value.attributes.approveRatio = 100
|
currentNode.value.approveRatio = 100
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 默认 6小时
|
// 默认 6小时
|
||||||
|
@ -565,11 +560,11 @@ const isoTimeDuration = computed(() => {
|
||||||
|
|
||||||
// 超时开关改变
|
// 超时开关改变
|
||||||
const timeoutHandlerChange = () => {
|
const timeoutHandlerChange = () => {
|
||||||
if (currentNode.value.attributes.timeoutHandler.enable) {
|
if (currentNode.value.timeoutHandler?.enable) {
|
||||||
timeUnit.value = 2
|
timeUnit.value = 2
|
||||||
timeDuration.value = 6
|
timeDuration.value = 6
|
||||||
currentNode.value.attributes.timeoutHandler.action = 1
|
currentNode.value.timeoutHandler.action = 1
|
||||||
currentNode.value.attributes.timeoutHandler.maxRemindCount = 1
|
currentNode.value.timeoutHandler.maxRemindCount = 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue