update 统一工作流FlowParams构造方式为建造者模式,提升代码可读性

dev
AprilWind 8 months ago
parent 1102573da3
commit ac0dbde532

@ -201,12 +201,13 @@ public class FlwCommonServiceImpl implements IFlwCommonService {
} }
for (FlowTask task : list) { for (FlowTask task : list) {
List<RemoteUserVo> userList = flwTaskService.currentTaskAllUser(task.getId()); List<RemoteUserVo> userList = flwTaskService.currentTaskAllUser(task.getId());
FlowParams flowParams = FlowParams.build(); FlowParams flowParams = FlowParams.build()
flowParams.nodeCode(targetNodeCode); .nodeCode(targetNodeCode)
flowParams.message(message); .message(message)
flowParams.skipType(SkipType.PASS.getKey()); .skipType(SkipType.PASS.getKey())
flowParams.flowStatus(flowStatus).hisStatus(flowHisStatus); .flowStatus(flowStatus)
flowParams.ignore(true); .hisStatus(flowHisStatus)
.ignore(true);
//解决会签没权限问题 //解决会签没权限问题
if (CollUtil.isNotEmpty(userList)) { if (CollUtil.isNotEmpty(userList)) {
flowParams.handler(userList.get(0).getUserId().toString()); flowParams.handler(userList.get(0).getUserId().toString());

@ -437,11 +437,11 @@ public class FlwInstanceServiceImpl implements IFlwInstanceService {
} }
List<FlowTask> flowTaskList = flwTaskService.selectByInstId(bo.getId()); List<FlowTask> flowTaskList = flwTaskService.selectByInstId(bo.getId());
for (FlowTask flowTask : flowTaskList) { for (FlowTask flowTask : flowTaskList) {
FlowParams flowParams = new FlowParams(); FlowParams flowParams = FlowParams.build()
flowParams.message(bo.getComment()); .message(bo.getComment())
flowParams.flowStatus(BusinessStatusEnum.INVALID.getStatus()) .flowStatus(BusinessStatusEnum.INVALID.getStatus())
.hisStatus(TaskStatusEnum.INVALID.getStatus()); .hisStatus(TaskStatusEnum.INVALID.getStatus())
flowParams.ignore(true); .ignore(true);
taskService.termination(flowTask.getId(), flowParams); taskService.termination(flowTask.getId(), flowParams);
} }
return true; return true;

@ -120,10 +120,10 @@ public class FlwTaskServiceImpl implements IFlwTaskService {
dto.setTaskId(taskList.get(0).getId()); dto.setTaskId(taskList.get(0).getId());
return dto; return dto;
} }
FlowParams flowParams = new FlowParams(); FlowParams flowParams = FlowParams.build()
flowParams.flowCode(startProcessBo.getFlowCode()); .flowCode(startProcessBo.getFlowCode())
flowParams.variable(startProcessBo.getVariables()); .variable(startProcessBo.getVariables())
flowParams.flowStatus(BusinessStatusEnum.DRAFT.getStatus()); .flowStatus(BusinessStatusEnum.DRAFT.getStatus());
Instance instance; Instance instance;
try { try {
instance = insService.start(businessId, flowParams); instance = insService.start(businessId, flowParams);
@ -173,13 +173,13 @@ public class FlwTaskServiceImpl implements IFlwTaskService {
completeTaskBo.getVariables().putAll(assigneeMap); completeTaskBo.getVariables().putAll(assigneeMap);
} }
// 构建流程参数,包括变量、跳转类型、消息、处理人、权限等信息 // 构建流程参数,包括变量、跳转类型、消息、处理人、权限等信息
FlowParams flowParams = new FlowParams(); FlowParams flowParams = FlowParams.build()
flowParams.variable(completeTaskBo.getVariables()); .variable(completeTaskBo.getVariables())
flowParams.skipType(SkipType.PASS.getKey()); .skipType(SkipType.PASS.getKey())
flowParams.message(completeTaskBo.getMessage()); .message(completeTaskBo.getMessage())
flowParams.flowStatus(BusinessStatusEnum.WAITING.getStatus()).hisStatus(TaskStatusEnum.PASS.getStatus()); .flowStatus(BusinessStatusEnum.WAITING.getStatus())
.hisStatus(TaskStatusEnum.PASS.getStatus())
flowParams.hisTaskExt(completeTaskBo.getFileId()); .hisTaskExt(completeTaskBo.getFileId());
// 执行任务跳转,并根据返回的处理人设置下一步处理人 // 执行任务跳转,并根据返回的处理人设置下一步处理人
Instance instance = taskService.skip(taskId, flowParams); Instance instance = taskService.skip(taskId, flowParams);
this.setHandler(instance, flowTask, flowCopyList); this.setHandler(instance, flowTask, flowCopyList);
@ -313,10 +313,10 @@ public class FlwTaskServiceImpl implements IFlwTaskService {
task.setId(taskId); task.setId(taskId);
task.setNodeName("【抄送】" + task.getNodeName()); task.setNodeName("【抄送】" + task.getNodeName());
Date updateTime = new Date(flowHisTask.getUpdateTime().getTime() - 1000); Date updateTime = new Date(flowHisTask.getUpdateTime().getTime() - 1000);
FlowParams flowParams = FlowParams.build(); FlowParams flowParams = FlowParams.build()
flowParams.skipType(SkipType.NONE.getKey()); .skipType(SkipType.NONE.getKey())
flowParams.hisStatus(TaskStatusEnum.COPY.getStatus()); .hisStatus(TaskStatusEnum.COPY.getStatus())
flowParams.message("【抄送给】" + StreamUtils.join(flowCopyList, FlowCopyBo::getUserName)); .message("【抄送给】" + StreamUtils.join(flowCopyList, FlowCopyBo::getUserName));
HisTask hisTask = hisTaskService.setSkipHisTask(task, flowNode, flowParams); HisTask hisTask = hisTaskService.setSkipHisTask(task, flowNode, flowParams);
hisTask.setCreateTime(updateTime); hisTask.setCreateTime(updateTime);
hisTask.setUpdateTime(updateTime); hisTask.setUpdateTime(updateTime);
@ -459,13 +459,13 @@ public class FlwTaskServiceImpl implements IFlwTaskService {
Long definitionId = task.getDefinitionId(); Long definitionId = task.getDefinitionId();
Definition definition = defService.getById(definitionId); Definition definition = defService.getById(definitionId);
String applyNodeCode = flwCommonService.applyNodeCode(definitionId); String applyNodeCode = flwCommonService.applyNodeCode(definitionId);
FlowParams flowParams = FlowParams.build(); FlowParams flowParams = FlowParams.build()
flowParams.nodeCode(bo.getNodeCode()); .nodeCode(bo.getNodeCode())
flowParams.message(message); .message(message)
flowParams.skipType(SkipType.REJECT.getKey()); .skipType(SkipType.REJECT.getKey())
flowParams.flowStatus(applyNodeCode.equals(bo.getNodeCode()) ? TaskStatusEnum.BACK.getStatus() : TaskStatusEnum.WAITING.getStatus()) .flowStatus(applyNodeCode.equals(bo.getNodeCode()) ? TaskStatusEnum.BACK.getStatus() : TaskStatusEnum.WAITING.getStatus())
.hisStatus(TaskStatusEnum.BACK.getStatus()); .hisStatus(TaskStatusEnum.BACK.getStatus())
flowParams.hisTaskExt(bo.getFileId()); .hisTaskExt(bo.getFileId());
taskService.skip(task.getId(), flowParams); taskService.skip(task.getId(), flowParams);
Instance instance = insService.getById(inst.getId()); Instance instance = insService.getById(inst.getId());
@ -522,9 +522,9 @@ public class FlwTaskServiceImpl implements IFlwTaskService {
if (ObjectUtil.isNotNull(instance)) { if (ObjectUtil.isNotNull(instance)) {
BusinessStatusEnum.checkInvalidStatus(instance.getFlowStatus()); BusinessStatusEnum.checkInvalidStatus(instance.getFlowStatus());
} }
FlowParams flowParams = new FlowParams(); FlowParams flowParams = FlowParams.build()
flowParams.message(bo.getComment()); .message(bo.getComment())
flowParams.flowStatus(BusinessStatusEnum.TERMINATION.getStatus()) .flowStatus(BusinessStatusEnum.TERMINATION.getStatus())
.hisStatus(TaskStatusEnum.TERMINATION.getStatus()); .hisStatus(TaskStatusEnum.TERMINATION.getStatus());
taskService.termination(taskId, flowParams); taskService.termination(taskId, flowParams);
return true; return true;
@ -665,8 +665,8 @@ public class FlwTaskServiceImpl implements IFlwTaskService {
@Override @Override
@Transactional(rollbackFor = Exception.class) @Transactional(rollbackFor = Exception.class)
public boolean taskOperation(TaskOperationBo bo, String taskOperation) { public boolean taskOperation(TaskOperationBo bo, String taskOperation) {
FlowParams flowParams = new FlowParams(); FlowParams flowParams = FlowParams.build()
flowParams.message(bo.getMessage()); .message(bo.getMessage());
if (LoginHelper.isSuperAdmin() || LoginHelper.isTenantAdmin()) { if (LoginHelper.isSuperAdmin() || LoginHelper.isTenantAdmin()) {
flowParams.ignore(true); flowParams.ignore(true);
} }

Loading…
Cancel
Save