feat: 【工作流】--减签和加签共用处理父任务逻辑

This commit is contained in:
kehaiyou 2023-09-30 14:56:16 +08:00
parent 80d532b0f1
commit cd678e997a

View File

@ -15,7 +15,6 @@ import cn.iocoder.yudao.module.bpm.controller.admin.task.vo.task.*;
import cn.iocoder.yudao.module.bpm.convert.task.BpmTaskConvert;
import cn.iocoder.yudao.module.bpm.dal.dataobject.task.BpmTaskExtDO;
import cn.iocoder.yudao.module.bpm.dal.mysql.task.BpmTaskExtMapper;
import cn.iocoder.yudao.module.bpm.enums.ErrorCodeConstants;
import cn.iocoder.yudao.module.bpm.enums.task.*;
import cn.iocoder.yudao.module.bpm.service.definition.BpmModelService;
import cn.iocoder.yudao.module.bpm.service.message.BpmMessageService;
@ -229,7 +228,7 @@ public class BpmTaskServiceImpl implements BpmTaskService {
new BpmTaskExtDO().setTaskId(task.getId()).setResult(BpmProcessInstanceResultEnum.APPROVE.getResult())
.setReason(reqVO.getReason()));
//处理加签任务
this.approveTask0(task);
this.handleParentTask(task);
}
/**
@ -258,7 +257,7 @@ public class BpmTaskServiceImpl implements BpmTaskService {
*
* @param task 当前任务
*/
private void approveTask0(Task task) {
private void handleParentTask(Task task) {
String parentTaskId = task.getParentTaskId();
if (StrUtil.isNotBlank(parentTaskId)) {
//1. 判断当前任务的父任务是否还有子任务
@ -274,10 +273,9 @@ public class BpmTaskServiceImpl implements BpmTaskService {
//3.2 更新任务拓展表为处理中
taskExtMapper.updateByTaskId(
new BpmTaskExtDO().setTaskId(parentTask.getId()).setResult(BpmProcessInstanceResultEnum.PROCESS.getResult()));
}
}else if (BpmTaskAddSignTypeEnum.AFTER.getType().equals(scopeType)) {
//4. 处理向后加签
if (BpmTaskAddSignTypeEnum.AFTER.getType().equals(scopeType)) {
handleAfterSign(parentTask, parentTaskId);
handleAfterSign(parentTask);
}
//5. 子任务已处理完成清空 scopeType 字段修改 parentTask 信息方便后续可以继续向前后向后加签
// 再查询一次的原因是避免报错Task was updated by another transaction concurrently
@ -296,9 +294,9 @@ public class BpmTaskServiceImpl implements BpmTaskService {
* 处理后加签任务
*
* @param parentTask 当前审批任务的父任务
* @param parentTaskId 当前审批任务的父ID
*/
private void handleAfterSign(Task parentTask, String parentTaskId) {
private void handleAfterSign(Task parentTask) {
String parentTaskId = parentTask.getId();
//4.1 更新 parentTask 的任务拓展表为通过
BpmTaskExtDO currentTaskExt = taskExtMapper.selectByTaskId(parentTask.getId());
BpmTaskExtDO currentTaskUpdateEntity = new BpmTaskExtDO().setTaskId(parentTask.getId())
@ -799,22 +797,11 @@ public class BpmTaskServiceImpl implements BpmTaskService {
//3. 修改扩展表状态为取消
taskExtMapper.updateBatchByTaskIdList(allTaskIdList,new BpmTaskExtDO().setResult(BpmProcessInstanceResultEnum.CANCEL.getResult())
.setReason(StrUtil.format("由于{}操作[减签],任务被取消",user.getNickname())));
//4. 判断当前任务的父任务是否还有子任务
Task parentTask = validateTaskExist(task.getParentTaskId());
Long subTaskCount = getSubTaskCount(task.getParentTaskId());
if(subTaskCount == 0){
if(BpmTaskAddSignTypeEnum.BEFORE.getType().equals(parentTask.getScopeType())){
//4.1 父任务是往前加签的则进入判断,将当前任务的状态设置为进行中并将 owner 设置回 assignee
taskExtMapper.updateByTaskId(new BpmTaskExtDO().setResult(BpmProcessInstanceResultEnum.PROCESS.getResult()).setTaskId(task.getParentTaskId()));
parentTask.setAssignee(parentTask.getOwner());
parentTask.setOwner(null);
}
//4.2 清空 scopeType 字段修改task
clearTaskScopeTypeAndSave(parentTask);
}
//4. 处理当前任务的父任务
this.handleParentTask(task);
//5.记录日志到父任务中
String comment = StrUtil.format("{}操作了【减签】,审批人{}的任务被取消",user.getNickname(),cancelUser.getNickname());
taskService.addComment(parentTask.getId(),parentTask.getProcessInstanceId(),
taskService.addComment(task.getParentTaskId(),task.getProcessInstanceId(),
BpmCommentTypeEnum.SUB_SIGN.getResult().toString(),comment);
}