From 16106b33a62463b60e1fed04cbd697317990fed9 Mon Sep 17 00:00:00 2001 From: CMM <2198256324@qq.com> Date: Tue, 4 Apr 2023 16:45:45 +0800 Subject: [PATCH 1/3] =?UTF-8?q?=E8=A2=AB=E6=92=A4=E5=9B=9E=E9=A1=B9?= =?UTF-8?q?=E7=9B=AE=E8=AF=A6=E6=83=85=E4=BF=AE=E6=94=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java b/pmapi/src/main/java/com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java index 4dadbf6..5cb8e14 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/todocenter/manage/TodoCenterManage.java @@ -440,8 +440,9 @@ public class TodoCenterManage { ProcessProgressVo progressInstanceDetail = processInstanceService.getProgressInstanceDetail(nodeId, instanceId); List progressInfo = progressInstanceDetail.getProgressInfo(); - buildUserUtils.buildUserByProcessInfo(progressInfo); - + if (CollUtil.isNotEmpty(progressInfo)){ + buildUserUtils.buildUserByProcessInfo(progressInfo); + } ProcessProgressDetailVo res = new ProcessProgressDetailVo(); res.setProcessProgressVo(progressInstanceDetail); res.setStatus(progressInstanceDetail.getStatus()); From f7860059980f061cc12838372da694966a2b4e01 Mon Sep 17 00:00:00 2001 From: WendyYang Date: Tue, 4 Apr 2023 16:49:22 +0800 Subject: [PATCH 2/3] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E8=AF=84=E5=AE=A1?= =?UTF-8?q?=E9=99=84=E4=BB=B6=E4=BF=A1=E6=81=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../pmapi/expert/manage/ExpertReviewManage.java | 22 ++++++++++++++++++++-- .../expert/model/vo/ExpertReviewDetailVO.java | 4 ++++ .../entity/dto/MeetingReviewProjectDTO.java | 3 +++ .../pmapi/meeting/manage/MeetingManage.java | 5 +++++ 4 files changed, 32 insertions(+), 2 deletions(-) diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/expert/manage/ExpertReviewManage.java b/pmapi/src/main/java/com/ningdatech/pmapi/expert/manage/ExpertReviewManage.java index ac53807..8071049 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/expert/manage/ExpertReviewManage.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/expert/manage/ExpertReviewManage.java @@ -6,18 +6,22 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.ningdatech.basic.exception.BizException; import com.ningdatech.basic.util.CollUtils; import com.ningdatech.cache.lock.DistributedLock; +import com.ningdatech.file.entity.vo.result.AttachFileVo; +import com.ningdatech.file.service.FileService; import com.ningdatech.pmapi.expert.model.dto.ReviewTemplateOptionDTO; import com.ningdatech.pmapi.expert.model.entity.ExpertReview; import com.ningdatech.pmapi.expert.model.req.ExpertReviewDetailReq; import com.ningdatech.pmapi.expert.model.vo.ExpertReviewDetailVO; import com.ningdatech.pmapi.expert.service.IExpertReviewService; -import com.ningdatech.pmapi.meeting.entity.enumeration.ExpertAttendStatusEnum; import com.ningdatech.pmapi.meeting.service.IMeetingExpertService; import com.ningdatech.pmapi.user.util.LoginUserUtil; import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Component; +import java.util.Collections; +import java.util.HashMap; import java.util.List; +import java.util.Map; import static com.ningdatech.pmapi.meeting.entity.enumeration.ExpertAttendStatusEnum.AGREED; @@ -36,6 +40,7 @@ public class ExpertReviewManage { private final IExpertReviewService expertReviewService; private final DistributedLock distributedLock; private final IMeetingExpertService meetingExpertService; + private final FileService fileService; private static final String EXPERT_REVIEW_KEY = "expert_review:"; @@ -120,7 +125,20 @@ public class ExpertReviewManage { query.eq(ExpertReview::getIsFinal, Boolean.FALSE); query.orderByDesc(ExpertReview::getCreateOn); List reviews = expertReviewService.list(query); - return CollUtils.convert(reviews, this::buildExpertReviewDetail); + if (reviews.isEmpty()) { + return Collections.emptyList(); + } + List attachFileIds = CollUtils.fieldList(reviews, ExpertReview::getAttachFileId); + Map fileMap = new HashMap<>(attachFileIds.size()); + if (attachFileIds.size() > 0) { + List files = fileService.getByIds(attachFileIds); + files.forEach(w -> fileMap.put(w.getFileId(), w)); + } + return CollUtils.convert(reviews, w -> { + ExpertReviewDetailVO reviewDetail = buildExpertReviewDetail(w); + reviewDetail.setAttachFile(fileMap.get(w.getAttachFileId())); + return reviewDetail; + }); } } diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/expert/model/vo/ExpertReviewDetailVO.java b/pmapi/src/main/java/com/ningdatech/pmapi/expert/model/vo/ExpertReviewDetailVO.java index 7af0cd6..be22bc6 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/expert/model/vo/ExpertReviewDetailVO.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/expert/model/vo/ExpertReviewDetailVO.java @@ -1,5 +1,6 @@ package com.ningdatech.pmapi.expert.model.vo; +import com.ningdatech.file.entity.vo.result.AttachFileVo; import com.ningdatech.pmapi.expert.model.dto.ReviewTemplateOptionDTO; import io.swagger.annotations.ApiModelProperty; import lombok.Builder; @@ -40,6 +41,9 @@ public class ExpertReviewDetailVO { @ApiModelProperty("附件ID") private Long attachFileId; + @ApiModelProperty("附件详情") + private AttachFileVo attachFile; + @ApiModelProperty("评审结果:1 通过、2 需复核、3 不通过") private Integer reviewResult; diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/meeting/entity/dto/MeetingReviewProjectDTO.java b/pmapi/src/main/java/com/ningdatech/pmapi/meeting/entity/dto/MeetingReviewProjectDTO.java index 2964d50..d2fa0af 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/meeting/entity/dto/MeetingReviewProjectDTO.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/meeting/entity/dto/MeetingReviewProjectDTO.java @@ -31,4 +31,7 @@ public class MeetingReviewProjectDTO { @ApiModelProperty("申报单位") private String buildOrg; + @ApiModelProperty("评审结果") + private String reviewResult; + } diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/meeting/manage/MeetingManage.java b/pmapi/src/main/java/com/ningdatech/pmapi/meeting/manage/MeetingManage.java index 464634e..a3435b6 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/meeting/manage/MeetingManage.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/meeting/manage/MeetingManage.java @@ -415,6 +415,7 @@ public class MeetingManage { if (meeting.getIsInnerProject()) { List innerProjects = meetingInnerProjectService.listByMeetingId(meetingId); List projects = projectService.listByIds(CollUtils.fieldList(innerProjects, MeetingInnerProject::getProjectId)); + Map reviewMap = expertReviewService.listFinalReviewMap(meetingId); List convert = CollUtils.convert(projects, w -> { MeetingReviewProjectDTO mrp = new MeetingReviewProjectDTO(); mrp.setBuildOrg(w.getBuildOrgName()); @@ -422,6 +423,10 @@ public class MeetingManage { mrp.setProjectType(w.getProjectType().toString()); mrp.setProjectYear(w.getProjectYear()); mrp.setDeclareAmount(w.getDeclareAmount()); + ExpertReview review = reviewMap.get(w.getId()); + if (review != null) { + mrp.setReviewResult(ReviewResultEnum.getByCode(review.getReviewResult()).getValue()); + } return mrp; }); detail.setProjects(convert); From 95c286c7eac09aa7628fef3e5e42a78df3d7f840 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?niohe=C2=B7erbao?= Date: Tue, 4 Apr 2023 16:49:27 +0800 Subject: [PATCH 3/3] =?UTF-8?q?=E4=B8=93=E5=AE=B6=E6=8A=A5=E5=90=8D?= =?UTF-8?q?=E7=94=A8=E6=88=B7=E8=A7=92=E8=89=B2=E8=87=AA=E5=8A=A8=E8=A1=A5?= =?UTF-8?q?=E5=85=85=E4=B8=93=E5=AE=B6=E4=BF=A1=E6=81=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../ningdatech/pmapi/expert/manage/ExpertManage.java | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/pmapi/src/main/java/com/ningdatech/pmapi/expert/manage/ExpertManage.java b/pmapi/src/main/java/com/ningdatech/pmapi/expert/manage/ExpertManage.java index 71dc2e7..ca4795d 100644 --- a/pmapi/src/main/java/com/ningdatech/pmapi/expert/manage/ExpertManage.java +++ b/pmapi/src/main/java/com/ningdatech/pmapi/expert/manage/ExpertManage.java @@ -1,5 +1,6 @@ package com.ningdatech.pmapi.expert.manage; +import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.ningdatech.basic.exception.BizException; import com.ningdatech.file.entity.vo.result.AttachFileVo; import com.ningdatech.file.service.FileService; @@ -23,8 +24,13 @@ import com.ningdatech.pmapi.expert.service.ExpertInfoService; import com.ningdatech.pmapi.expert.service.IExpertUserFullInfoService; import com.ningdatech.pmapi.meta.constant.DictExpertInfoTypeEnum; import com.ningdatech.pmapi.meta.model.ExpertRegionInfo; +import com.ningdatech.pmapi.sys.model.entity.Role; +import com.ningdatech.pmapi.sys.model.entity.UserRole; +import com.ningdatech.pmapi.sys.service.IRoleService; +import com.ningdatech.pmapi.sys.service.IUserRoleService; import com.ningdatech.pmapi.user.constant.UserAvailableEnum; import com.ningdatech.pmapi.user.entity.UserInfo; +import com.ningdatech.pmapi.user.entity.enumeration.RoleEnum; import com.ningdatech.pmapi.user.service.IUserInfoService; import com.ningdatech.pmapi.user.util.LoginUserUtil; import lombok.RequiredArgsConstructor; @@ -55,6 +61,8 @@ public class ExpertManage { private final ExpertUserInfoAssembler expertUserInfoAssembler; private final IUserInfoService iUserInfoService; private final ExpertMetaApplyManage expertMetaApplyManage; + private final IUserRoleService iUserRoleService; + private final IRoleService iRoleService; /** @@ -108,6 +116,18 @@ public class ExpertManage { applyResult.setAuditOpinion("同意"); applyResult.setApplyResult(true); expertMetaApplyManage.metaApplyResult(applyResult); + + // 增加用户专家角色 + Role expertRole = iRoleService.getOne(Wrappers.lambdaQuery(Role.class).eq(Role::getCode, RoleEnum.EXPERT.name())); + UserRole expertUserRole = iUserRoleService.getOne(Wrappers.lambdaQuery(UserRole.class).eq(UserRole::getRoleId, expertRole.getId())); + if (Objects.isNull(expertUserRole)) { + expertUserRole = new UserRole(); + expertUserRole.setUserId(userId); + expertUserRole.setRoleId(expertRole.getId()); + expertUserRole.setCreateBy(-1L); + expertUserRole.setCreateOn(LocalDateTime.now()); + iUserRoleService.save(expertUserRole); + } }