Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package cn.cordys.crm.approval.dto;

import cn.cordys.crm.approval.constants.MultiApproverModeEnum;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.AllArgsConstructor;
import lombok.Builder;
Expand All @@ -26,6 +27,9 @@ public class ApprovalRecordNode {
@Schema(description = "审批任务")
private List<ApprovalTaskNode> taskNodes;

@Schema(description = "多人审批方式", allowableValues = {"ALL: 会签", "ANY: 或签", "SEQUENTIAL: 依次审批"})
private MultiApproverModeEnum multiApproverMode;

@Schema(description = "是否退回节点")
private boolean isReturnNode;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,15 @@
import cn.cordys.common.util.BeanUtils;
import cn.cordys.common.util.CommonBeanFactory;
import cn.cordys.common.util.Translator;
import cn.cordys.crm.approval.constants.ApprovalAction;
import cn.cordys.crm.approval.constants.ApprovalAddSignType;
import cn.cordys.crm.approval.constants.ApprovalStatus;
import cn.cordys.crm.approval.constants.ApprovalTaskType;
import cn.cordys.crm.approval.constants.MultiApproverModeEnum;
import cn.cordys.crm.approval.domain.*;
import cn.cordys.crm.approval.dto.ApprovalCcNode;
import cn.cordys.crm.approval.dto.ApprovalInstanceDetail;
import cn.cordys.crm.approval.dto.ApprovalRecordNode;
import cn.cordys.crm.approval.dto.ApprovalTaskNode;
import cn.cordys.crm.approval.mapper.ExtApprovalInstanceMapper;
import cn.cordys.crm.system.domain.Attachment;
import cn.cordys.crm.system.dto.UserSimple;
import cn.cordys.crm.system.service.AttachmentService;
Expand Down Expand Up @@ -52,6 +51,8 @@ public class ApprovalInstanceService {
private AttachmentService attachmentService;
@Resource
private UserExtendService userExtendService;
@Resource
private BaseMapper<ApprovalNodeApprover> approvalNodeApproverMapper;

/**
* 获取资源最新审批实例详情
Expand Down Expand Up @@ -203,9 +204,30 @@ private List<ApprovalRecordNode> buildApprovalRecordNodeList(List<ApprovalTask>
}
});

Map<String, ApprovalNodeApprover> approverNodeMap = getApproverNodeMapByIds(sortHisNodes);
nodes.forEach(node -> {
ApprovalNodeApprover approverNode = approverNodeMap.get(node.getNodeId());
if (approverNode != null) {
node.setMultiApproverMode(MultiApproverModeEnum.valueOf(approverNode.getMultiApproverMode()));
}

});
return nodes;
}

/**
* 获取所有审批节点集合
* @param nodeIds 节点ID集合
* @return 审批节点集合
*/
private Map<String, ApprovalNodeApprover> getApproverNodeMapByIds(List<String> nodeIds) {
if (CollectionUtils.isEmpty(nodeIds)) {
return Map.of();
}
List<ApprovalNodeApprover> approvalNodeApprovers = approvalNodeApproverMapper.selectByIds(nodeIds);
return approvalNodeApprovers.stream().collect(Collectors.toMap(ApprovalNodeApprover::getId, n -> n));
}

private List<ApprovalTask> flatSignTask(ApprovalTask currentTask, Map<String, List<ApprovalAddSignTask>> addSignTaskMap, Map<String, ApprovalTask> signTaskMap) {
if (!signTaskMap.containsKey(currentTask.getId())) {
// 不存在加签链
Expand Down
Loading