flowable多实例并行审核

1.在多实例环节前一个环节配置监听事件,设置所需审核人集合和基数并写入流程变量中
flowable多实例并行审核_第1张图片

public class MultiTaskFlowHandler implements TaskListener {

    /**
     * 设置多部门并行审批环节的处理人
     * @param task
     */
    @Override
    public void notify(DelegateTask task) {
        String procInsId = task.getProcessInstanceId();
        List<String> assigneeList = new ArrayList<>();
        assigneeList.add("123");
        assigneeList.add("456");
        runtimeService.setVariable(procInsId, "assigneeList", assigneeList);
        //${loopCardinality}
        runtimeService.setVariable(procInsId, "loopCardinality", assigneeList.size());
    }
}

2.设置多实例环节
flowable多实例并行审核_第2张图片
流程设计器参数说明

  • 多实例类型:

     Parallel -> 并行多实例,多人同时审核,如把任务分给5个人来处理,这5个人同时会收到任务,并且可以同时处理,不受各自的影响。(直接生成5条act_run_task数据,每个用户都可以审核,5条审核完该节点通过)  
     Sequential -> 串行多实例,任务由一个人完成后,再由另一个人去处理,直至全部完成,每个任务依赖于前一个任务完成。(审核一次生成一条act_run_task数据,下一个用户接着审核)
    
  • 配置信息:

     collection(集合): 传入List参数,一般为用户ID集合
     elementVariable(元素变量):List中单个参数的名称,指定一个别名,以备动态指定。注意设置任务处理人时,一定要与别名一致
     loopCardinality(基数):List循环次数
     isSequential:是否串并行
     completionCondition(完成条件):任务出口条件
     nrOfInstances:实例总数。
     nrOfCompletedInstances:已完成的实例个数。nr是number单词缩写 。
     loopCounter:已经循环的次数。
     nrOfActiveInstances:未完成的实例个数。
    
  • 设置完成条件:

     若全部审批通过才通过则完成条件设置为${nrOfCompletedInstances/nrOfInstances >= 1};
     同理若一半的人完成即可通过则完成条件设置为${nrOfCompletedInstances/nrOfInstances >= 0.5}
    

你可能感兴趣的:(java)