记camunda串行会签的使用(同节点多人顺序审批)

背景

由于流程引擎的需求较多,最近出现一个不定长的有序审批需求,之前一直做的都是最基础的流程审批,一下子被难住了,查了好多资料,大概确定方向是camunda的会签,但资料又有些欠缺。

后来在看并行会签的时候发现了这个功能,大致实现的功能是:某一个节点,可以选择多个不同的审批人,按照顺序审批下去,最后一个人审批通过则通过

绘图

绘图工具拿了Camunda Modeler,这边摘取其中一个节点作为示例。

如图,流程从发起申请开始,到达领导审批节点,领导审批节点会存在多个审批人,且需要按照顺序,若有一个人不通过,则流程返回发起申请,否则流程完结。

流程图

 

 串行审批节点

选择如图横着的三条杠,左侧竖着的是并行

 

 

 会签参数

主要参数见右侧

Collection:指集合名称(所有需要审批人的标识列表)

Element Variable:集合内的元素变量(当处于某个审批人时,该变量里存的会是当前审批人的标识)

Completion Condition:向下流转的条件(这边设置了未完成的审批=0或达成拒绝的条件时向下流转)

 

 注意

需要注意的是,右侧的Assignee,Candidate Users,Candidate Groups依然按需填写,按照负责人/归属用户/归属组等条件查询时依然需要。

若采用Assignee的话,填写上一步中的Element Variable字段的内容,即可获取当前审批人。

 

会签自动生成的字段

处于会签节点时,该task会自动生成以下几个字段(可用于上述作为节点完成的判断条件),字段与任务完成时塞入的map同一层级:

nrOfInstances 实例的数目
nrOfCompletedInstances 完成实例的数目
nrOfActiveInstances 未完成实例的数目
loopCounter 循环计数器,办理人在列表中的索引。

 代码

代码逻辑与普通的流程处理无差,只是在流转到串行审批节点时,需要将Collection中的字段传入map中然后执行complete。

// 以下为流转代码
String taskId = request.getTaskId();

// 统一逻辑,获取当前process_id的下一个节点(nextNode)的分支的参数
Map<String,Object> map = taskCommonService.getBranchMap(request.getNextNode(),CommonConstans.PROCESS_ID);

// 获取下一个节点的审批人列表
List<String> approverIds = taskCommonService.getApproverIds(request.getNextNode(),CommonConstans.PROCESS_ID);

// 置入上述Collection中所需列表
map.put("assigneeList", approverIds);

// 完成当前任务
taskSerice.complete(taskId, map);
posted @ 2020-10-12 13:47  糖醋小灰  阅读(8486)  评论(9)    收藏  举报