Parcourir la source

feat:

1. 合规性审查通过修改;
tags/24112201
WendyYang il y a 1 mois
Parent
révision
5de51c107d
3 fichiers modifiés avec 27 ajouts et 18 suppressions
  1. +14
    -14
      hz-pm-api/src/main/java/com/hz/pm/api/projectdeclared/manage/DeclaredProjectManage.java
  2. +2
    -0
      hz-pm-api/src/main/java/com/hz/pm/api/projectdeclared/manage/ProjectReviewManage.java
  3. +11
    -4
      hz-pm-api/src/main/java/com/hz/pm/api/projectlib/service/IProjectStatusChangeService.java

+ 14
- 14
hz-pm-api/src/main/java/com/hz/pm/api/projectdeclared/manage/DeclaredProjectManage.java Voir le fichier

@@ -42,6 +42,7 @@ import com.hz.pm.api.projectlib.model.enumeration.status.ProjectStatus;
import com.hz.pm.api.projectlib.model.req.ProjectListReq;
import com.hz.pm.api.projectlib.model.vo.ProjectLibListItemVO;
import com.hz.pm.api.projectlib.service.IProjectService;
import com.hz.pm.api.projectlib.service.IProjectStatusChangeService;
import com.hz.pm.api.staging.enums.MsgTypeEnum;
import com.hz.pm.api.sys.manage.NoticeManage;
import com.hz.pm.api.sys.manage.ProcessModelManage;
@@ -74,6 +75,8 @@ import java.util.concurrent.atomic.AtomicInteger;
import java.util.function.BiConsumer;
import java.util.stream.Collectors;

import static com.hz.pm.api.common.statemachine.event.ProjectStateChangeEvent.COMPLIANCE_REVIEW_PASS;

/**
* <p>
* DeclaredProjectManage
@@ -96,6 +99,7 @@ public class DeclaredProjectManage {
private final NoticeManage noticeManage;
private final UserInfoHelper userInfoHelper;
private final MhUnitCache mhUnitCache;
private final IProjectStatusChangeService projectStatusChangeService;

/**
* 新项目 启动实例
@@ -374,23 +378,19 @@ public class DeclaredProjectManage {
query.ne(Project::getStage, ProjectStatus.STOPPED.getCode())
.ne(Project::getStatus, ProjectStatus.CHANGE_APPLY_PASSED.getCode())
.eq(Project::getNewest, Boolean.TRUE)
.select(Project::getStatus, Project::getId);
.select(Project::getStatus, Project::getProjectCode, Project::getStage);
List<Project> projects = projectService.list(query);
Map<ProjectStatus, Long> countMap = CollUtils.groupCount(projects, w -> {
if (!ProjectStatus.TO_BE_DECLARED.eq(w.getStatus())
&& !ProjectStatus.COMPLIANCE_REVIEW_FAILED.eq(w.getStatus())
&& !ProjectStatus.ON_COMPLIANCE_REVIEW.eq(w.getStatus())
&& !ProjectStatus.CHANGE.eq(w.getStage())) {
return ProjectStatus.COMPLIANCE_REVIEW_PASSED;
}
return ProjectStatus.getNoNull(w.getStatus());
});
Map<ProjectStatus, Long> countMap = CollUtils.groupCount(projects,
w -> ProjectStatus.getNoNull(w.getStatus()));
DeclaredProgressStatisticsVO stat = new DeclaredProgressStatisticsVO();
stat.setTotalCount(projects.size());
stat.setTodoCount(countMap.getOrDefault(ProjectStatus.TO_BE_DECLARED, 0L));
stat.setAuditCount(countMap.getOrDefault(ProjectStatus.ON_COMPLIANCE_REVIEW, 0L));
stat.setFailedCount(countMap.getOrDefault(ProjectStatus.COMPLIANCE_REVIEW_FAILED, 0L));
stat.setPassedCount(countMap.getOrDefault(ProjectStatus.COMPLIANCE_REVIEW_PASSED, 0L));
if (!projects.isEmpty()) {
List<String> projectCodes = CollUtils.fieldList(projects, Project::getProjectCode);
stat.setPassedCount(projectStatusChangeService.count(projectCodes, COMPLIANCE_REVIEW_PASS));
}
return stat;
}

@@ -413,7 +413,7 @@ public class DeclaredProjectManage {
if (status != null) {
if (ProjectStatus.COMPLIANCE_REVIEW_PASSED.eq(status)) {
query.exists(ExistsSqlConst.PROJECT_EXISTS_STATUS_CHANGE +
" and npsc.event = {0}", ProjectStateChangeEvent.COMPLIANCE_REVIEW_PASS);
" and npsc.event = {0}", COMPLIANCE_REVIEW_PASS);
} else {
query.eq(Project::getStatus, status);
}
@@ -429,8 +429,8 @@ public class DeclaredProjectManage {
ProjectLibListItemVO item = BeanUtil.copyProperties(w, ProjectLibListItemVO.class);
item.setDeclaredAmount(w.getDeclareAmount());
if (!ProjectStatus.TO_BE_DECLARED.eq(w.getStatus())
&& ProjectStatus.COMPLIANCE_REVIEW_FAILED.eq(w.getStatus())
&& ProjectStatus.ON_COMPLIANCE_REVIEW.eq(w.getStatus())
&& !ProjectStatus.COMPLIANCE_REVIEW_FAILED.eq(w.getStatus())
&& !ProjectStatus.ON_COMPLIANCE_REVIEW.eq(w.getStatus())
&& !ProjectStatus.CHANGE.eq(w.getStage())) {
item.setStatus(ProjectStatus.COMPLIANCE_REVIEW_PASSED.getCode());
}


+ 2
- 0
hz-pm-api/src/main/java/com/hz/pm/api/projectdeclared/manage/ProjectReviewManage.java Voir le fichier

@@ -287,6 +287,8 @@ public class ProjectReviewManage {
} else if (ProjectStatus.EXPERT_REVIEW_FAILED.eq(status)) {
query.in(Project::getStatus, ProjectStatus.EXPERT_REVIEW_FAILED.getCode(),
ProjectStatus.EXPERT_REVIEW_AFTER_MODIFY.getCode());
} else {
query.eq(Project::getStatus, status);
}
} else {
query.exists(ExistsSqlConst.PROJECT_EXISTS_STATUS_CHANGE +


+ 11
- 4
hz-pm-api/src/main/java/com/hz/pm/api/projectlib/service/IProjectStatusChangeService.java Voir le fichier

@@ -1,7 +1,9 @@
package com.hz.pm.api.projectlib.service;

import cn.hutool.core.map.MapUtil;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.IService;
import com.hz.pm.api.common.model.constant.BizConst;
@@ -10,10 +12,7 @@ import com.hz.pm.api.common.util.BizUtils;
import com.hz.pm.api.projectlib.model.entity.ProjectStatusChange;
import com.ningdatech.basic.util.CollUtils;

import java.util.Collection;
import java.util.Comparator;
import java.util.List;
import java.util.Map;
import java.util.*;

/**
* <p>
@@ -89,4 +88,12 @@ public interface IProjectStatusChangeService extends IService<ProjectStatusChang
Comparator.comparing(ProjectStatusChange::getCreateOn).reversed());
}

default long count(Collection<String> projectCodes, ProjectStateChangeEvent event) {
QueryWrapper<ProjectStatusChange> query = Wrappers.query();
query.select("count(distinct project_code) cnt")
.in("project_code", projectCodes)
.eq("event", event);
return MapUtil.getLong(getMap(query), "cnt");
}

}

Chargement…
Annuler
Enregistrer