@@ -1,64 +0,0 @@ | |||
package com.ningdatech.generator.config; | |||
import com.baomidou.mybatisplus.generator.FastAutoGenerator; | |||
import com.baomidou.mybatisplus.generator.config.OutputFile; | |||
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine; | |||
import java.util.Collections; | |||
/** | |||
* @description: 自动生成code代码 | |||
* @author: liuxinxin | |||
* @date: 2023/01/03 09:20 | |||
*/ | |||
public class GeneratorCodeConfig { | |||
private static final String PATH_LXX = "/Users/liuxinxin/IdeaProjects/project-management/pmapi/src/main/java"; | |||
private static final String PATH_YYD = ""; | |||
private static final String PATH_LS = ""; | |||
private static final String PATH_ZPF = ""; | |||
private static final String PATH_CMM = ""; | |||
private static final String URL = "jdbc:mysql://47.98.125.47:3306/nd_project_management?" + | |||
"useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&" + | |||
"useSSL=false&serverTimezone=Asia/Shanghai"; | |||
private static final String USER_NAME = "root"; | |||
private static final String PASSWORD = "NingdaKeji123!"; | |||
private static void generate(String author, String packageName, String path, String... tableNames) { | |||
FastAutoGenerator.create(URL, USER_NAME, PASSWORD) | |||
.globalConfig(builder -> { | |||
// 设置作者 | |||
builder.author(author) | |||
// 开启 swagger 模式 | |||
.enableSwagger() | |||
// 覆盖已生成文件 | |||
.fileOverride() | |||
// 指定输出目录 | |||
.outputDir(path); | |||
}) | |||
.packageConfig(builder -> { | |||
// 设置父包名 | |||
builder.parent("com.ningdatech") | |||
// 设置父包模块名 | |||
.moduleName("pmapi." + packageName) | |||
// 设置mapperXml生成路径 | |||
.pathInfo(Collections.singletonMap(OutputFile.mapperXml, | |||
//设置自己的生成路径 | |||
path + "/com/ningdatech/pmapi/" + packageName + "/mapper")); | |||
}) | |||
.strategyConfig(builder -> { | |||
builder.addTablePrefix("nd"); | |||
// 设置需要生成的表名 | |||
builder.addInclude(tableNames); | |||
}) | |||
// 使用Freemarker引擎模板,默认的是Velocity引擎模板 | |||
.templateEngine(new FreemarkerTemplateEngine()) | |||
.execute(); | |||
} | |||
public static void main(String[] args) { | |||
generate("Liuxinxin", "user", PATH_LXX, "nd_role_info", "nd_user_role"); | |||
} | |||
} |
@@ -56,7 +56,7 @@ public class GeneratorCodeKingbaseConfig { | |||
} | |||
public static void main(String[] args) { | |||
generate("Lierbao", "user", PATH_LXX, "nd_user_auth"); | |||
generate("WendyYang", "projectlib", PATH_YYD, "nd_project_application"); | |||
} | |||
} |
@@ -187,10 +187,6 @@ | |||
<groupId>org.slf4j</groupId> | |||
<artifactId>slf4j-log4j12</artifactId> | |||
</exclusion> | |||
<!-- <exclusion>--> | |||
<!-- <groupId>org.springframework.boot</groupId>--> | |||
<!-- <artifactId>spring-boot-starter-security</artifactId>--> | |||
<!-- </exclusion>--> | |||
</exclusions> | |||
</dependency> | |||
<dependency> | |||
@@ -203,10 +199,6 @@ | |||
</exclusion> | |||
</exclusions> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-flowable-starter</artifactId> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
@@ -235,12 +227,10 @@ | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-cache-starter</artifactId> | |||
<version>1.0.0</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-basic</artifactId> | |||
<version>1.0.0</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.kingbase.dialect</groupId> | |||
@@ -251,17 +241,14 @@ | |||
<dependency> | |||
<groupId>com.alibaba</groupId> | |||
<artifactId>easyexcel-core</artifactId> | |||
<version>3.1.2</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-file-starter</artifactId> | |||
<version>1.0.0</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-zwdd-starter</artifactId> | |||
<version>1.0.0</version> | |||
<artifactId>nd-flowable-starter</artifactId> | |||
</dependency> | |||
<!--浙政钉--> | |||
<dependency> | |||
@@ -1,11 +1,11 @@ | |||
package com.ningdatech.pmapi.declared.controller; | |||
import com.ningdatech.basic.model.PageVo; | |||
import com.ningdatech.pmapi.declared.entity.dto.DeclaredProjectParamDto; | |||
import com.ningdatech.pmapi.declared.entity.dto.DeclaredProjectDto; | |||
import com.ningdatech.pmapi.declared.entity.dto.DeclaredProjectListParamDto; | |||
import com.ningdatech.pmapi.declared.manage.DeclaredProjectManage; | |||
import com.wflow.bean.vo.NdDeclaredProjectVo; | |||
import com.ningdatech.pmapi.projectlib.model.vo.ProjectLibListItemVO; | |||
import com.wflow.workflow.bean.vo.ProcessStartParamsVo; | |||
import com.wflow.workflow.service.ProcessInstanceService; | |||
import io.swagger.annotations.Api; | |||
import io.swagger.annotations.ApiOperation; | |||
import lombok.RequiredArgsConstructor; | |||
@@ -26,28 +26,24 @@ import org.springframework.web.bind.annotation.*; | |||
@Api(value = "DeclaredProject", tags = "申报管理-申报项目") | |||
@RequiredArgsConstructor | |||
public class DeclaredProjectController { | |||
private final ProcessInstanceService processService; | |||
private final DeclaredProjectManage declaredProjectManage; | |||
@ApiOperation(value = "申报项目已申报列表", notes = "申报项目已申报列表") | |||
@GetMapping("/list") | |||
public PageVo<NdDeclaredProjectVo> list(@Validated @ModelAttribute DeclaredProjectParamDto params) {; | |||
public PageVo<ProjectLibListItemVO> list(@Validated @ModelAttribute DeclaredProjectListParamDto params) {; | |||
return declaredProjectManage.page(params); | |||
} | |||
@ApiOperation(value = "申报项目草稿箱", notes = "申报项目草稿箱") | |||
@GetMapping("/draft") | |||
public PageVo<NdDeclaredProjectVo> draft(@Validated @ModelAttribute ProcessStartParamsVo params) { | |||
public PageVo<ProjectLibListItemVO> draft(@Validated @ModelAttribute ProcessStartParamsVo params) { | |||
return PageVo.empty(); | |||
} | |||
@ApiOperation(value = "申报项目", notes = "申报项目") | |||
@PostMapping("/start/{defId}") | |||
public String startTheProcess(@PathVariable String defId, | |||
@RequestBody ProcessStartParamsVo params) { | |||
String instanceId = processService.startProcess(defId, params); | |||
@PostMapping("/start") | |||
public String startTheProcess(@Validated @RequestBody DeclaredProjectDto dto) { | |||
String instanceId = declaredProjectManage.startTheProcess(dto); | |||
return "启动流程实例 " + instanceId + " 成功"; | |||
} | |||
} |
@@ -0,0 +1,33 @@ | |||
package com.ningdatech.pmapi.declared.entity.dto; | |||
import com.ningdatech.pmapi.projectlib.model.entity.Project; | |||
import lombok.AllArgsConstructor; | |||
import lombok.Builder; | |||
import lombok.Data; | |||
import lombok.NoArgsConstructor; | |||
import javax.validation.constraints.NotBlank; | |||
import javax.validation.constraints.NotNull; | |||
import java.io.Serializable; | |||
import java.util.Map; | |||
/** | |||
* @Classname DeclaredProjectDto | |||
* @Description 申报项目 | |||
* @Date 2023/2/1 14:52 | |||
* @Author PoffyZhang | |||
*/ | |||
@Data | |||
@Builder | |||
@NoArgsConstructor | |||
@AllArgsConstructor | |||
public class DeclaredProjectDto implements Serializable { | |||
@NotNull | |||
private Project projectInfo; | |||
private Map<String,Object> formData; | |||
@NotBlank | |||
private String regionCode; | |||
} |
@@ -16,7 +16,7 @@ import lombok.NoArgsConstructor; | |||
@Builder | |||
@NoArgsConstructor | |||
@AllArgsConstructor | |||
public class DeclaredProjectParamDto extends PagePo { | |||
public class DeclaredProjectListParamDto extends PagePo { | |||
private String projectName; | |||
@@ -1,20 +1,32 @@ | |||
package com.ningdatech.pmapi.declared.manage; | |||
import com.alibaba.fastjson.JSON; | |||
import com.alibaba.fastjson.TypeReference; | |||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | |||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; | |||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | |||
import com.ningdatech.basic.model.PageVo; | |||
import com.ningdatech.pmapi.declared.entity.dto.DeclaredProjectParamDto; | |||
import com.wflow.bean.entity.NdDeclaredProject; | |||
import com.wflow.bean.vo.NdDeclaredProjectVo; | |||
import com.wflow.service.NdDeclaredProjectService; | |||
import com.ningdatech.pmapi.declared.entity.dto.DeclaredProjectDto; | |||
import com.ningdatech.pmapi.declared.entity.dto.DeclaredProjectListParamDto; | |||
import com.ningdatech.pmapi.projectlib.enums.ProjectStatusEnum; | |||
import com.ningdatech.pmapi.projectlib.model.entity.Project; | |||
import com.ningdatech.pmapi.projectlib.model.vo.ProjectLibListItemVO; | |||
import com.ningdatech.pmapi.projectlib.service.INdProjectService; | |||
import com.wflow.bean.entity.WflowModels; | |||
import com.wflow.exception.BusinessException; | |||
import com.wflow.workflow.bean.vo.ProcessStartParamsVo; | |||
import com.wflow.workflow.service.ProcessInstanceService; | |||
import com.wflow.workflow.service.ProcessModelService; | |||
import lombok.RequiredArgsConstructor; | |||
import lombok.extern.slf4j.Slf4j; | |||
import org.apache.commons.lang3.StringUtils; | |||
import org.springframework.beans.BeanUtils; | |||
import org.springframework.stereotype.Component; | |||
import java.time.LocalDateTime; | |||
import java.util.Collections; | |||
import java.util.List; | |||
import java.util.Map; | |||
import java.util.Objects; | |||
import java.util.stream.Collectors; | |||
@@ -29,28 +41,77 @@ import java.util.stream.Collectors; | |||
@RequiredArgsConstructor | |||
public class DeclaredProjectManage { | |||
private final NdDeclaredProjectService declaredProjectService; | |||
public PageVo<NdDeclaredProjectVo> page(DeclaredProjectParamDto params) { | |||
Page<NdDeclaredProject> page = params.page(); | |||
LambdaQueryWrapper<NdDeclaredProject> wrapper = Wrappers.lambdaQuery(NdDeclaredProject.class) | |||
.ge(Objects.nonNull(params.getStartTime()), NdDeclaredProject::getCreateOn, params.getStartTime()) | |||
.le(Objects.nonNull(params.getEndTime()), NdDeclaredProject::getCreateOn, params.getEndTime()) | |||
.eq(Objects.nonNull(params.getProjectType()), NdDeclaredProject::getProjectType, params.getProjectType()) | |||
.eq(Objects.nonNull(params.getProjectYear()), NdDeclaredProject::getProjectYear, params.getProjectYear()) | |||
.eq(Objects.nonNull(params.getProjectStatusFirst()), NdDeclaredProject::getProjectStatusFirst, params.getProjectStatusFirst()) | |||
.eq(Objects.nonNull(params.getProjectStatusSecond()), NdDeclaredProject::getProjectStatusSecond, params.getProjectStatusSecond()) | |||
.like(StringUtils.isNotBlank(params.getProjectName()), NdDeclaredProject::getProjectName, params.getProjectName()) | |||
.orderByDesc(NdDeclaredProject::getUpdateOn); | |||
declaredProjectService.page(page,wrapper); | |||
private final INdProjectService ndProjectService; | |||
private final ProcessInstanceService processService; | |||
private final ProcessModelService processModelService; | |||
public PageVo<ProjectLibListItemVO> page(DeclaredProjectListParamDto params) { | |||
Page<Project> page = params.page(); | |||
LambdaQueryWrapper<Project> wrapper = Wrappers.lambdaQuery(Project.class) | |||
.ge(Objects.nonNull(params.getStartTime()), Project::getCreateOn, params.getStartTime()) | |||
.le(Objects.nonNull(params.getEndTime()), Project::getCreateOn, params.getEndTime()) | |||
.eq(Objects.nonNull(params.getProjectType()), Project::getProjectType, params.getProjectType()) | |||
.eq(Objects.nonNull(params.getProjectYear()), Project::getProjectYear, params.getProjectYear()) | |||
.eq(Objects.nonNull(params.getProjectStatusFirst()), Project::getProjectStatusFirst, params.getProjectStatusFirst()) | |||
.eq(Objects.nonNull(params.getProjectStatusSecond()), Project::getProjectStatusSecond, params.getProjectStatusSecond()) | |||
.like(StringUtils.isNotBlank(params.getProjectName()), Project::getProjectName, params.getProjectName()) | |||
.orderByDesc(Project::getUpdateOn); | |||
ndProjectService.page(page,wrapper); | |||
if(0L == page.getTotal()){ | |||
return PageVo.empty(); | |||
} | |||
List<NdDeclaredProjectVo> res = page.getRecords().stream().map(record -> { | |||
NdDeclaredProjectVo vo = new NdDeclaredProjectVo(); | |||
List<ProjectLibListItemVO> res = page.getRecords().stream().map(record -> { | |||
ProjectLibListItemVO vo = new ProjectLibListItemVO(); | |||
BeanUtils.copyProperties(record, vo); | |||
return vo; | |||
}).collect(Collectors.toList()); | |||
return PageVo.of(res,page.getTotal()); | |||
} | |||
/** | |||
* 启动实例 | |||
* @param dto | |||
* @return | |||
*/ | |||
public String startTheProcess(DeclaredProjectDto dto) { | |||
String regionCode = dto.getRegionCode(); | |||
WflowModels model = processModelService.getOne(Wrappers.lambdaQuery(WflowModels.class) | |||
.eq(WflowModels::getRegionCode, regionCode) | |||
.eq(WflowModels::getFormName, "单位内部审批流程") | |||
.last("limit 1")); | |||
if(Objects.isNull(model)){ | |||
throw new BusinessException(String.format("此 【%s】区域找不到流程配置",regionCode)); | |||
} | |||
ProcessStartParamsVo params = new ProcessStartParamsVo(); | |||
params.setDeptId("6179678"); | |||
params.setProcessUsers(Collections.emptyMap()); | |||
dto.getFormData().putAll( | |||
JSON.parseObject(JSON.toJSONString(dto.getProjectInfo()), new TypeReference<Map<String, Object>>() { | |||
})); | |||
params.setFormData(dto.getFormData()); | |||
String instanceId = processService.startProcess(model.getProcessDefId(), params); | |||
//流程启动之后 入库项目 重要业务信息 用于列表查询 展示 | |||
try{ | |||
Project project = new Project(); | |||
BeanUtils.copyProperties(dto.getProjectInfo(),project); | |||
project.setCreateOn(LocalDateTime.now()); | |||
project.setUpdateOn(LocalDateTime.now()); | |||
project.setAreaCode(regionCode); | |||
project.setProjectStatusFirst(ProjectStatusEnum.NOT_APPROVED.getCode()); | |||
project.setProjectStatusSecond(ProjectStatusEnum.UNDER_INTERNAL_AUDIT.getCode()); | |||
project.setInstCode(instanceId); | |||
ndProjectService.save(project); | |||
}catch (Exception e){ | |||
log.error("项目信息入库错误 ",e); | |||
throw new BusinessException("项目信息入库错误 请注意格式"); | |||
} | |||
return instanceId; | |||
} | |||
} |
@@ -0,0 +1,54 @@ | |||
package com.ningdatech.pmapi.projectlib.enums; | |||
import lombok.AllArgsConstructor; | |||
import lombok.Getter; | |||
import lombok.NoArgsConstructor; | |||
import org.apache.commons.lang3.StringUtils; | |||
import java.util.Objects; | |||
@Getter | |||
@AllArgsConstructor | |||
@NoArgsConstructor | |||
public enum ProjectStatusEnum { | |||
/** | |||
* 项目状态 | |||
*/ | |||
NOT_APPROVED (10000,"未立项"), | |||
UNDER_INTERNAL_AUDIT (10001,"单位内部审核中"), | |||
UNDER_INTERNAL_AUDIT_NOT_PASS (10002,"单位内部审核不通过"), | |||
PENDING_PREQUALIFICATION (10003,"待预审"), | |||
JOINT_REVIEW_BY_PROVINCIAL_DEPARTMENTS (10004,"省级部门联审中"), | |||
THE_JOINT_REVIEW_OF_PROVINCIAL_DEPARTMENTS_FAILED (10005,"省级部门联审不通过"), | |||
PRE_APPLYING (10006,"预审中"), | |||
PREQUALIFICATION_FAILED (10007,"预审不通过"), | |||
DEPARTMENT_JOINT_REVIEW (10008,"部门联审中"), | |||
DEPARTMENT_JOINT_REVIEW_FAILED (10009,"部门联审不通过"), | |||
IN_THE_ANNUAL_PLAN (10010,"年度计划中"), | |||
BE_SUSPENDED (10011,"被暂缓"), | |||
SCHEME_UNDER_REVIEW (10012,"方案评审中"), | |||
SCHEME_REVIEW_FAILED (10013,"方案评审不通过"), | |||
TO_BE_APPROVED (10014,"待立项批复"), | |||
PROJECT_APPROVED (20000,"已立项"), | |||
TO_BE_PURCHASED (20001,"待采购"), | |||
UNDER_CONSTRUCTION (20002,"建设中"), | |||
TO_BE_FINALLY_INSPECTED (20003,"待终验"), | |||
FINAL_ACCEPTANCE_IS_UNDER_REVIEW (20004,"终验审核中"), | |||
FINAL_ACCEPTANCE_REVIEW_FAILED (20005,"终验审核不通过"), | |||
ARCHIVED (30000,"已归档"); | |||
private Integer code; | |||
private String desc; | |||
public static String getDescByCode(Integer code) { | |||
if(Objects.isNull(code)){ | |||
return StringUtils.EMPTY; | |||
} | |||
for (ProjectStatusEnum t : ProjectStatusEnum.values()) { | |||
if (code.equals(t.getCode())) { | |||
return t.desc; | |||
} | |||
} | |||
return StringUtils.EMPTY; | |||
} | |||
} |
@@ -0,0 +1,34 @@ | |||
package com.ningdatech.pmapi.projectlib.enums; | |||
import lombok.AllArgsConstructor; | |||
import lombok.Getter; | |||
import lombok.NoArgsConstructor; | |||
import org.apache.commons.lang3.StringUtils; | |||
import java.util.Objects; | |||
@Getter | |||
@AllArgsConstructor | |||
@NoArgsConstructor | |||
public enum ProjectTypeEnum { | |||
/** | |||
* 项目类型 | |||
*/ | |||
BUILD (1,"建设"), | |||
DEV_OPS (2,"运维"); | |||
private Integer code; | |||
private String desc; | |||
public static String getDescByCode(Integer code) { | |||
if(Objects.isNull(code)){ | |||
return StringUtils.EMPTY; | |||
} | |||
for (ProjectTypeEnum t : ProjectTypeEnum.values()) { | |||
if (code.equals(t.getCode())) { | |||
return t.desc; | |||
} | |||
} | |||
return StringUtils.EMPTY; | |||
} | |||
} |
@@ -5,15 +5,14 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; | |||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | |||
import com.ningdatech.basic.model.PageVo; | |||
import com.ningdatech.basic.util.CollUtils; | |||
import com.ningdatech.pmapi.projectlib.model.entity.Project; | |||
import com.ningdatech.pmapi.projectlib.model.req.ProjectLibListReq; | |||
import com.ningdatech.pmapi.projectlib.model.vo.ProjectLibListItemVO; | |||
import com.wflow.bean.entity.NdDeclaredProject; | |||
import com.wflow.service.NdDeclaredProjectService; | |||
import com.ningdatech.pmapi.projectlib.service.IProjectService; | |||
import lombok.RequiredArgsConstructor; | |||
import org.springframework.stereotype.Component; | |||
import java.util.List; | |||
import java.util.stream.Collectors; | |||
import static com.ningdatech.pmapi.common.utils.BizUtils.notBlank; | |||
import static com.ningdatech.pmapi.common.utils.BizUtils.notNull; | |||
@@ -30,36 +29,36 @@ import static com.ningdatech.pmapi.common.utils.BizUtils.notNull; | |||
@RequiredArgsConstructor | |||
public class ProjectLibManage { | |||
private final NdDeclaredProjectService declaredProjectService; | |||
private final IProjectService projectService; | |||
private LambdaQueryWrapper<NdDeclaredProject> projectLibQuery(ProjectLibListReq req) { | |||
LambdaQueryWrapper<NdDeclaredProject> query = Wrappers.lambdaQuery(NdDeclaredProject.class); | |||
notBlank(req.getProjectName(), w -> query.like(NdDeclaredProject::getProjectName, w)); | |||
notNull(req.getProjectType(), w -> query.eq(NdDeclaredProject::getProjectType, w)); | |||
notNull(req.getProjectYear(), w -> query.eq(NdDeclaredProject::getProjectYear, w)); | |||
private LambdaQueryWrapper<Project> projectLibQuery(ProjectLibListReq req) { | |||
LambdaQueryWrapper<Project> query = Wrappers.lambdaQuery(Project.class); | |||
notBlank(req.getProjectName(), w -> query.like(Project::getProjectName, w)); | |||
notNull(req.getProjectType(), w -> query.eq(Project::getProjectType, w)); | |||
notNull(req.getProjectYear(), w -> query.eq(Project::getProjectYear, w)); | |||
// 申报金额 批复金额 | |||
notNull(req.getApprovedAmountMin(), w -> query.ge(NdDeclaredProject::getApprovedAmount, w)); | |||
notNull(req.getApprovedAmountMax(), w -> query.le(NdDeclaredProject::getApprovedAmount, w)); | |||
notNull(req.getApproveAmountMin(), w -> query.ge(Project::getApprovalAmount, w)); | |||
notNull(req.getApproveAmountMax(), w -> query.le(Project::getApprovalAmount, w)); | |||
notNull(req.getDeclaredAmountMax(), w -> query.le(NdDeclaredProject::getDeclaredAmount, w)); | |||
notNull(req.getDeclaredAmountMin(), w -> query.ge(NdDeclaredProject::getDeclaredAmount, w)); | |||
notNull(req.getDeclareAmountMax(), w -> query.le(Project::getDeclareAmount, w)); | |||
notNull(req.getDeclareAmountMin(), w -> query.ge(Project::getDeclareAmount, w)); | |||
// 状态查询 | |||
notNull(req.getStatus1st(), w -> query.ge(NdDeclaredProject::getProjectStatusFirst, w)); | |||
notNull(req.getStatus2nd(), w -> query.ge(NdDeclaredProject::getProjectStatusSecond, w)); | |||
notNull(req.getStatus1st(), w -> query.ge(Project::getStage, w)); | |||
notNull(req.getStatus2nd(), w -> query.ge(Project::getStatus, w)); | |||
notNull(req.getCreateOnMin(), w -> query.ge(NdDeclaredProject::getCreateOn, w)); | |||
notNull(req.getCreateOnMax(), w -> query.le(NdDeclaredProject::getCreateOn, w)); | |||
notNull(req.getCreateOnMin(), w -> query.ge(Project::getCreateOn, w)); | |||
notNull(req.getCreateOnMax(), w -> query.le(Project::getCreateOn, w)); | |||
notBlank(req.getApplyOrg(), w -> query.like(NdDeclaredProject::getOrgName, w)); | |||
notBlank(req.getBuildUnit(), w -> query.like(Project::getBuildUnitName, w)); | |||
query.orderByDesc(NdDeclaredProject::getUpdateOn, NdDeclaredProject::getCreateOn); | |||
query.orderByDesc(Project::getUpdateOn, Project::getCreateOn); | |||
// TODO 区域编码处理 | |||
return query; | |||
} | |||
public PageVo<ProjectLibListItemVO> projectLibList(ProjectLibListReq req) { | |||
LambdaQueryWrapper<NdDeclaredProject> query = projectLibQuery(req); | |||
Page<NdDeclaredProject> page = declaredProjectService.page(req.page(), query); | |||
LambdaQueryWrapper<Project> query = projectLibQuery(req); | |||
Page<Project> page = projectService.page(req.page(), query); | |||
long total; | |||
if ((total = page.getTotal()) == 0) { | |||
return PageVo.empty(); | |||
@@ -69,13 +68,13 @@ public class ProjectLibManage { | |||
item.setId(w.getId()); | |||
item.setProjectName(w.getProjectName()); | |||
item.setCreateOn(w.getCreateOn()); | |||
item.setDeclaredAmount(w.getDeclaredAmount()); | |||
item.setStatus1st(w.getProjectStatusFirst()); | |||
item.setStatus2nd(w.getProjectStatusSecond()); | |||
item.setDeclaredAmount(w.getDeclareAmount()); | |||
item.setStatus1st(w.getStage()); | |||
item.setStatus2nd(w.getStatus()); | |||
item.setProjectType(w.getProjectType()); | |||
item.setProjectYear(w.getProjectYear()); | |||
item.setApplyOrg(w.getOrgName()); | |||
item.setBizArea(w.getBizArea()); | |||
item.setBuildUnit(w.getBuildUnitName()); | |||
item.setBizDomain(w.getBizDomain()); | |||
return item; | |||
}); | |||
return PageVo.of(records, total); | |||
@@ -0,0 +1,16 @@ | |||
package com.ningdatech.pmapi.projectlib.mapper; | |||
import com.ningdatech.pmapi.projectlib.model.entity.ProjectApplication; | |||
import com.baomidou.mybatisplus.core.mapper.BaseMapper; | |||
/** | |||
* <p> | |||
* Mapper 接口 | |||
* </p> | |||
* | |||
* @author WendyYang | |||
* @since 2023-02-05 | |||
*/ | |||
public interface ProjectApplicationMapper extends BaseMapper<ProjectApplication> { | |||
} |
@@ -0,0 +1,5 @@ | |||
<?xml version="1.0" encoding="UTF-8"?> | |||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | |||
<mapper namespace="com.ningdatech.pmapi.projectlib.mapper.ProjectApplicationMapper"> | |||
</mapper> |
@@ -0,0 +1,16 @@ | |||
package com.ningdatech.pmapi.projectlib.mapper; | |||
import com.ningdatech.pmapi.projectlib.model.entity.Project; | |||
import com.baomidou.mybatisplus.core.mapper.BaseMapper; | |||
/** | |||
* <p> | |||
* Mapper 接口 | |||
* </p> | |||
* | |||
* @author WendyYang | |||
* @since 2023-02-03 | |||
*/ | |||
public interface ProjectMapper extends BaseMapper<Project> { | |||
} |
@@ -0,0 +1,5 @@ | |||
<?xml version="1.0" encoding="UTF-8"?> | |||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | |||
<mapper namespace="com.ningdatech.pmapi.projectlib.mapper.ProjectMapper"> | |||
</mapper> |
@@ -0,0 +1,294 @@ | |||
package com.ningdatech.pmapi.projectlib.model.dto; | |||
import io.swagger.annotations.ApiModel; | |||
import io.swagger.annotations.ApiModelProperty; | |||
import lombok.Data; | |||
import java.io.Serializable; | |||
import java.math.BigDecimal; | |||
import java.time.LocalDateTime; | |||
/** | |||
* <p> | |||
* | |||
* </p> | |||
* | |||
* @author zpf | |||
* @since 2023-02-03 | |||
*/ | |||
@Data | |||
@ApiModel(value = "NdProjectDto", description = "") | |||
public class ProjectDto implements Serializable { | |||
private static final long serialVersionUID = 1L; | |||
@ApiModelProperty("主键") | |||
private Long id; | |||
@ApiModelProperty("所属地区编号") | |||
private String areaCode; | |||
@ApiModelProperty("所属地区名称") | |||
private String area; | |||
@ApiModelProperty("项目阶段") | |||
private Integer stage; | |||
@ApiModelProperty("项目状态") | |||
private Integer status; | |||
@ApiModelProperty("项目名称") | |||
private String projectName; | |||
@ApiModelProperty("是否临时增补 0:否 1:是") | |||
private Integer isTemporaryAugment; | |||
@ApiModelProperty("项目负责人") | |||
private String responsibleMan; | |||
@ApiModelProperty("负责人手机号码") | |||
private String responsibleManMobile; | |||
@ApiModelProperty("项目联系人") | |||
private String contactName; | |||
@ApiModelProperty("项目联系人手机号码") | |||
private String contactPhone; | |||
@ApiModelProperty("建设单位名称") | |||
private String buildUnitName; | |||
@ApiModelProperty("建设单位统一社会信用代码") | |||
private String buildUnitCode; | |||
@ApiModelProperty("建设单位浙政钉ID") | |||
private String buildUnitZheJiangGovernmentDingId; | |||
@ApiModelProperty("项目类型 1:建设 2:运维") | |||
private Integer projectType; | |||
@ApiModelProperty("是否首次新建 0:否 1:是") | |||
private Integer isFirst; | |||
@ApiModelProperty("项目预算年度") | |||
private Integer projectYear; | |||
@ApiModelProperty("项目建设起始时间") | |||
private String beginTime; | |||
@ApiModelProperty("项目建设终止时间") | |||
private String endTime; | |||
@ApiModelProperty("四大体系 1:业务应用 2:应用支撑 3:数据资源 4:基础设施") | |||
private Integer fourSystems; | |||
@ApiModelProperty("是否数字化改革项目 0:否 1:是") | |||
private Integer isDigitalReform; | |||
@ApiModelProperty("综合业务领域") | |||
private String bizDomain; | |||
@ApiModelProperty("建设层级 1:国家级 2:省级 3:省本级 4:市级 5:市本级 6:区县 7乡镇") | |||
private Integer buildLevel; | |||
@ApiModelProperty("立项依据") | |||
private String buildBasis; | |||
@ApiModelProperty("发改编码") | |||
private String developCode; | |||
@ApiModelProperty("财政编码") | |||
private String financialCode; | |||
@ApiModelProperty("是否上云 0:否 1:是") | |||
private Integer isCloud; | |||
private String cloudType; | |||
@ApiModelProperty("等保级别 1:一级 2:二级 3:三级 4:四级 5:五级") | |||
private Integer protectionLevel; | |||
@ApiModelProperty("是否密评 0:否 1:是") | |||
private Integer isSecretComments; | |||
@ApiModelProperty("项目简介") | |||
private String projectIntroduction; | |||
@ApiModelProperty("资金申报情况-申报金额(万元)") | |||
private BigDecimal declareAmount; | |||
@ApiModelProperty("资金申报情况-自有金额(万元)") | |||
private BigDecimal declareHaveAmount; | |||
@ApiModelProperty("资金申报情况-政府投资-本级财政资金(万元)") | |||
private BigDecimal declareGovernmentOwnFinanceAmount; | |||
@ApiModelProperty("资金申报情况-政府投资-上级补助资金(万元)") | |||
private BigDecimal declareGovernmentSuperiorFinanceAmount; | |||
@ApiModelProperty("银行贷款(万元)") | |||
private BigDecimal declareBankLendingAmount; | |||
@ApiModelProperty("其它资金(万元)") | |||
private BigDecimal declareOtherAmount; | |||
@ApiModelProperty("资金分配情况-软件开发(万元)") | |||
private BigDecimal softwareDevelopmentAmount; | |||
@ApiModelProperty("资金分配情况-云资源、硬件购置(万元)") | |||
private BigDecimal cloudHardwarePurchaseAmount; | |||
@ApiModelProperty("资金分配情况-第三方服务(万元)") | |||
private BigDecimal thirdPartyAmount; | |||
@ApiModelProperty("年度支付计划-年度支付计划(万元)") | |||
private BigDecimal annualPlanAmount; | |||
@ApiModelProperty("年度支付计划-自有金额(万元)") | |||
private BigDecimal annualPlanHaveAmount; | |||
@ApiModelProperty("年度支付计划-政府投资-本级财政资金(万元)") | |||
private BigDecimal annualPlanGovernmentOwnFinanceAmount; | |||
@ApiModelProperty("年度支付计划-政府投资-上级补助资金(万元)") | |||
private BigDecimal annualPlanGovernmentSuperiorFinanceAmount; | |||
@ApiModelProperty("年度支付计划-银行贷款(万元)") | |||
private BigDecimal annualPlanBankLendingAmount; | |||
@ApiModelProperty("年度支付计划-其它资金(万元)") | |||
private BigDecimal annualPlanOtherAmount; | |||
@ApiModelProperty("立项批复资金(万元)") | |||
private BigDecimal approvalAmount; | |||
private LocalDateTime annualPlanAddTime; | |||
@ApiModelProperty("核心业务-核心业务模块") | |||
private String coreBusiness; | |||
@ApiModelProperty("安全投入-投入项") | |||
private String safetyInputTitle; | |||
@ApiModelProperty("安全投入-内容描述") | |||
private String safetyInputDescribe; | |||
@ApiModelProperty("安全投入-金额(万元)") | |||
private BigDecimal safetyInputAmount; | |||
@ApiModelProperty("附件-初步方案") | |||
private String preliminaryPlanFile; | |||
@ApiModelProperty("附件-佐证材料") | |||
private String supportingMaterialsFile; | |||
@ApiModelProperty("附件-项目总投资测算明细") | |||
private String calculationTotalInvestmentFile; | |||
@ApiModelProperty("附件-申报单位主要职责(单位三定方案)") | |||
private String mainResponsibilitiesApplicantFile; | |||
@ApiModelProperty("备注") | |||
private String projectRemarks; | |||
@ApiModelProperty("是否包含应用 0:否 1:是") | |||
private Integer includeApplication; | |||
@ApiModelProperty("工程形象进度-第一季度") | |||
private String engineeringSpeedOne; | |||
@ApiModelProperty("工程形象进度-第二季度") | |||
private String engineeringSpeedTwo; | |||
@ApiModelProperty("工程形象进度-第三季度") | |||
private String engineeringSpeedThree; | |||
@ApiModelProperty("工程形象进度-第四季度") | |||
private String engineeringSpeedFour; | |||
@ApiModelProperty("核心业务-是否开启核心业务模块 false:关闭 true:开启") | |||
private Boolean isOpenCoreBusiness; | |||
@ApiModelProperty("安全投入-是否开启安全投入模块 false:关闭 true:开启") | |||
private Boolean isOpenSafetyInput; | |||
@ApiModelProperty("工程形象进度-是否开启 false:关闭 true:开启") | |||
private Boolean isEngineeringSpeed; | |||
@ApiModelProperty("附件-是否开启 false:关闭 true:开启") | |||
private Boolean isAccessories; | |||
@ApiModelProperty("备注-是否开启 false:关闭 true:开启") | |||
private Boolean isRemarks; | |||
@ApiModelProperty("年度支付计划-是否开启 false:关闭 true:开启") | |||
private Boolean isAnnualPlanAmount; | |||
@ApiModelProperty("一地创新全省共享项目-是否开启 false:关闭 true:开启") | |||
private Boolean isInnovateWholeProvinceShare; | |||
private LocalDateTime createOn; | |||
private LocalDateTime updateOn; | |||
@ApiModelProperty("流程实例编号") | |||
private String instCode; | |||
@ApiModelProperty("安全投入-模块信息") | |||
private String safetyInputModular; | |||
@ApiModelProperty("项目申报pdf") | |||
private String projectPdf; | |||
@ApiModelProperty("立项申报pdf") | |||
private String declarationPdf; | |||
@ApiModelProperty("建设周期(月)") | |||
private String buildCycle; | |||
@ApiModelProperty("建设方案文件") | |||
private String constructionPlanFile; | |||
@ApiModelProperty("立项批复文件") | |||
private String approvedFile; | |||
@ApiModelProperty("批复金额") | |||
private BigDecimal approvedTotalInvestmentIncrease; | |||
@ApiModelProperty("上级主管部门") | |||
private String higherSuperUnit; | |||
@ApiModelProperty("上级主管部门Code") | |||
private String higherSuperUnitCode; | |||
@ApiModelProperty("主管部门名称") | |||
private String superUnit; | |||
@ApiModelProperty("主管部门Code") | |||
private String superUnitCode; | |||
@ApiModelProperty("前端所需验证字段") | |||
private Integer allApplicationsDone; | |||
@ApiModelProperty("流程实例id") | |||
private String processInsId; | |||
@ApiModelProperty("流程实例 formId") | |||
private String formId; | |||
@ApiModelProperty("项目一级状态 10000 20000 30000") | |||
private Integer projectStatusFirst; | |||
@ApiModelProperty("项目二级状态") | |||
private Integer projectStatusSecond; | |||
@ApiModelProperty("单位名称") | |||
private String orgName; | |||
@ApiModelProperty("单位code") | |||
private String orgCode; | |||
private Long createBy; | |||
private Long updateBy; | |||
} |
@@ -0,0 +1,298 @@ | |||
package com.ningdatech.pmapi.projectlib.model.entity; | |||
import cn.hutool.core.io.FileUtil; | |||
import cn.hutool.core.util.StrUtil; | |||
import com.baomidou.mybatisplus.annotation.IdType; | |||
import com.baomidou.mybatisplus.annotation.TableId; | |||
import com.baomidou.mybatisplus.annotation.TableName; | |||
import io.swagger.annotations.ApiModel; | |||
import io.swagger.annotations.ApiModelProperty; | |||
import lombok.Data; | |||
import java.io.Serializable; | |||
import java.math.BigDecimal; | |||
import java.nio.charset.StandardCharsets; | |||
import java.time.LocalDateTime; | |||
import java.util.List; | |||
import java.util.regex.Matcher; | |||
import java.util.regex.Pattern; | |||
/** | |||
* <p> | |||
* | |||
* </p> | |||
* | |||
* @author WendyYang | |||
* @since 2023-02-03 | |||
*/ | |||
@Data | |||
@TableName("nd_project") | |||
@ApiModel(value = "NdProject对象", description = "") | |||
public class Project implements Serializable { | |||
private static final long serialVersionUID = 1L; | |||
@ApiModelProperty("主键") | |||
@TableId(type = IdType.AUTO) | |||
private Long id; | |||
@ApiModelProperty("所属地区编号") | |||
private String areaCode; | |||
@ApiModelProperty("所属地区名称") | |||
private String area; | |||
@ApiModelProperty("项目阶段") | |||
private Integer stage; | |||
@ApiModelProperty("项目状态") | |||
private Integer status; | |||
@ApiModelProperty("项目名称") | |||
private String projectName; | |||
@ApiModelProperty("是否临时增补 0:否 1:是") | |||
private Integer isTemporaryAugment; | |||
@ApiModelProperty("项目负责人") | |||
private String responsibleMan; | |||
@ApiModelProperty("负责人手机号码") | |||
private String responsibleManMobile; | |||
@ApiModelProperty("项目联系人") | |||
private String contactName; | |||
@ApiModelProperty("项目联系人手机号码") | |||
private String contactPhone; | |||
@ApiModelProperty("建设单位名称") | |||
private String buildUnitName; | |||
@ApiModelProperty("建设单位统一社会信用代码") | |||
private String buildUnitCode; | |||
@ApiModelProperty("建设单位浙政钉ID") | |||
private String buildUnitZheJiangGovernmentDingId; | |||
@ApiModelProperty("项目类型 1:建设 2:运维") | |||
private Integer projectType; | |||
@ApiModelProperty("是否首次新建 0:否 1:是") | |||
private Integer isFirst; | |||
@ApiModelProperty("项目预算年度") | |||
private Integer projectYear; | |||
@ApiModelProperty("项目建设起始时间") | |||
private String beginTime; | |||
@ApiModelProperty("项目建设终止时间") | |||
private String endTime; | |||
@ApiModelProperty("四大体系 1:业务应用 2:应用支撑 3:数据资源 4:基础设施") | |||
private Integer fourSystems; | |||
@ApiModelProperty("是否数字化改革项目 0:否 1:是") | |||
private Integer isDigitalReform; | |||
@ApiModelProperty("综合业务领域") | |||
private String bizDomain; | |||
@ApiModelProperty("建设层级 1:国家级 2:省级 3:省本级 4:市级 5:市本级 6:区县 7乡镇") | |||
private Integer buildLevel; | |||
@ApiModelProperty("立项依据") | |||
private String buildBasis; | |||
@ApiModelProperty("发改编码") | |||
private String developCode; | |||
@ApiModelProperty("财政编码") | |||
private String financialCode; | |||
@ApiModelProperty("是否上云 0:否 1:是") | |||
private Integer isCloud; | |||
private String cloudType; | |||
@ApiModelProperty("等保级别 1:一级 2:二级 3:三级 4:四级 5:五级") | |||
private Integer protectionLevel; | |||
@ApiModelProperty("是否密评 0:否 1:是") | |||
private Integer isSecretComments; | |||
@ApiModelProperty("项目简介") | |||
private String projectIntroduction; | |||
@ApiModelProperty("资金申报情况-申报金额(万元)") | |||
private BigDecimal declareAmount; | |||
@ApiModelProperty("资金申报情况-自有金额(万元)") | |||
private BigDecimal declareHaveAmount; | |||
@ApiModelProperty("资金申报情况-政府投资-本级财政资金(万元)") | |||
private BigDecimal declareGovernmentOwnFinanceAmount; | |||
@ApiModelProperty("资金申报情况-政府投资-上级补助资金(万元)") | |||
private BigDecimal declareGovernmentSuperiorFinanceAmount; | |||
@ApiModelProperty("银行贷款(万元)") | |||
private BigDecimal declareBankLendingAmount; | |||
@ApiModelProperty("其它资金(万元)") | |||
private BigDecimal declareOtherAmount; | |||
@ApiModelProperty("资金分配情况-软件开发(万元)") | |||
private BigDecimal softwareDevelopmentAmount; | |||
@ApiModelProperty("资金分配情况-云资源、硬件购置(万元)") | |||
private BigDecimal cloudHardwarePurchaseAmount; | |||
@ApiModelProperty("资金分配情况-第三方服务(万元)") | |||
private BigDecimal thirdPartyAmount; | |||
@ApiModelProperty("年度支付计划-年度支付计划(万元)") | |||
private BigDecimal annualPlanAmount; | |||
@ApiModelProperty("年度支付计划-自有金额(万元)") | |||
private BigDecimal annualPlanHaveAmount; | |||
@ApiModelProperty("年度支付计划-政府投资-本级财政资金(万元)") | |||
private BigDecimal annualPlanGovernmentOwnFinanceAmount; | |||
@ApiModelProperty("年度支付计划-政府投资-上级补助资金(万元)") | |||
private BigDecimal annualPlanGovernmentSuperiorFinanceAmount; | |||
@ApiModelProperty("年度支付计划-银行贷款(万元)") | |||
private BigDecimal annualPlanBankLendingAmount; | |||
@ApiModelProperty("年度支付计划-其它资金(万元)") | |||
private BigDecimal annualPlanOtherAmount; | |||
@ApiModelProperty("立项批复资金(万元)") | |||
private BigDecimal approvalAmount; | |||
private LocalDateTime annualPlanAddTime; | |||
@ApiModelProperty("核心业务-核心业务模块") | |||
private String coreBusiness; | |||
@ApiModelProperty("安全投入-投入项") | |||
private String safetyInputTitle; | |||
@ApiModelProperty("安全投入-内容描述") | |||
private String safetyInputDescribe; | |||
@ApiModelProperty("安全投入-金额(万元)") | |||
private BigDecimal safetyInputAmount; | |||
@ApiModelProperty("附件-初步方案") | |||
private String preliminaryPlanFile; | |||
@ApiModelProperty("附件-佐证材料") | |||
private String supportingMaterialsFile; | |||
@ApiModelProperty("附件-项目总投资测算明细") | |||
private String calculationTotalInvestmentFile; | |||
@ApiModelProperty("附件-申报单位主要职责(单位三定方案)") | |||
private String mainResponsibilitiesApplicantFile; | |||
@ApiModelProperty("备注") | |||
private String projectRemarks; | |||
@ApiModelProperty("是否包含应用 0:否 1:是") | |||
private Integer includeApplication; | |||
@ApiModelProperty("工程形象进度-第一季度") | |||
private String engineeringSpeedOne; | |||
@ApiModelProperty("工程形象进度-第二季度") | |||
private String engineeringSpeedTwo; | |||
@ApiModelProperty("工程形象进度-第三季度") | |||
private String engineeringSpeedThree; | |||
@ApiModelProperty("工程形象进度-第四季度") | |||
private String engineeringSpeedFour; | |||
@ApiModelProperty("核心业务-是否开启核心业务模块 false:关闭 true:开启") | |||
private Boolean isOpenCoreBusiness; | |||
@ApiModelProperty("安全投入-是否开启安全投入模块 false:关闭 true:开启") | |||
private Boolean isOpenSafetyInput; | |||
@ApiModelProperty("工程形象进度-是否开启 false:关闭 true:开启") | |||
private Boolean isEngineeringSpeed; | |||
@ApiModelProperty("附件-是否开启 false:关闭 true:开启") | |||
private Boolean isAccessories; | |||
@ApiModelProperty("备注-是否开启 false:关闭 true:开启") | |||
private Boolean isRemarks; | |||
@ApiModelProperty("年度支付计划-是否开启 false:关闭 true:开启") | |||
private Boolean isAnnualPlanAmount; | |||
@ApiModelProperty("一地创新全省共享项目-是否开启 false:关闭 true:开启") | |||
private Boolean isInnovateWholeProvinceShare; | |||
private LocalDateTime createOn; | |||
private LocalDateTime updateOn; | |||
@ApiModelProperty("流程实例编号") | |||
private String instCode; | |||
@ApiModelProperty("安全投入-模块信息") | |||
private String safetyInputModular; | |||
@ApiModelProperty("项目申报pdf") | |||
private String projectPdf; | |||
@ApiModelProperty("立项申报pdf") | |||
private String declarationPdf; | |||
@ApiModelProperty("建设周期(月)") | |||
private String buildCycle; | |||
@ApiModelProperty("建设方案文件") | |||
private String constructionPlanFile; | |||
@ApiModelProperty("立项批复文件") | |||
private String approvedFile; | |||
@ApiModelProperty("批复金额") | |||
private BigDecimal approvedTotalInvestmentIncrease; | |||
@ApiModelProperty("上级主管部门") | |||
private String higherSuperUnit; | |||
@ApiModelProperty("上级主管部门Code") | |||
private String higherSuperUnitCode; | |||
@ApiModelProperty("主管部门名称") | |||
private String superUnit; | |||
@ApiModelProperty("主管部门Code") | |||
private String superUnitCode; | |||
@ApiModelProperty("前端所需验证字段") | |||
private Integer allApplicationsDone; | |||
@ApiModelProperty("项目一级状态 10000 20000 30000") | |||
private Integer projectStatusFirst; | |||
@ApiModelProperty("项目二级状态") | |||
private Integer projectStatusSecond; | |||
@ApiModelProperty("单位名称") | |||
private String orgName; | |||
@ApiModelProperty("单位code") | |||
private String orgCode; | |||
private Long createBy; | |||
private Long updateBy; | |||
} |
@@ -0,0 +1,171 @@ | |||
package com.ningdatech.pmapi.projectlib.model.entity; | |||
import com.baomidou.mybatisplus.annotation.IdType; | |||
import com.baomidou.mybatisplus.annotation.TableId; | |||
import com.baomidou.mybatisplus.annotation.TableName; | |||
import java.io.Serializable; | |||
import java.time.LocalDateTime; | |||
import io.swagger.annotations.ApiModel; | |||
import io.swagger.annotations.ApiModelProperty; | |||
/** | |||
* <p> | |||
* 项目应用表 | |||
* </p> | |||
* | |||
* @author WendyYang | |||
* @since 2023-02-05 | |||
*/ | |||
@TableName("nd_project_application") | |||
@ApiModel(value = "NdProjectApplication对象", description = "") | |||
public class ProjectApplication implements Serializable { | |||
private static final long serialVersionUID = 1L; | |||
@ApiModelProperty("应用ID") | |||
@TableId(type = IdType.AUTO) | |||
private Long id; | |||
@ApiModelProperty("项目ID") | |||
private String projectId; | |||
@ApiModelProperty("是否初次建设 0否 1是") | |||
private Integer isFirst; | |||
@ApiModelProperty("应用名称") | |||
private String applicationName; | |||
@ApiModelProperty("创建时间") | |||
private LocalDateTime createOn; | |||
@ApiModelProperty("更新时间") | |||
private LocalDateTime updateOn; | |||
@ApiModelProperty("删除时间") | |||
private LocalDateTime deleteOn; | |||
@ApiModelProperty("关联IRS现有应用") | |||
private String relatedExistsApplication; | |||
@ApiModelProperty("关联IRS现有应用-IRS应用编码") | |||
private String relatedExistsApplicationCode; | |||
@ApiModelProperty("应用类型") | |||
private String applicationType; | |||
@ApiModelProperty("建设层级 1:国家 2:省级 3:市级 4:县(市、区)") | |||
private Integer buildLevel; | |||
@ApiModelProperty("是否统建应用 0:否 1:是") | |||
private Integer isUniteBuild; | |||
@ApiModelProperty("统建类型 1:全省统建 2:全市统建") | |||
private Integer unionBuildKind; | |||
@ApiModelProperty("是否数改系统 0:否 1:是") | |||
private Integer isDigitalModification; | |||
@ApiModelProperty("数改系统") | |||
private String digitalModification; | |||
@ApiModelProperty("业务领域") | |||
private String bizDomain; | |||
@ApiModelProperty("发布端") | |||
private String publishSide; | |||
@ApiModelProperty("是否一本账场景应用名称 0:否 1:是") | |||
private Integer isAccountAppName; | |||
@ApiModelProperty("一本账应用名称") | |||
private String accountAppName; | |||
@ApiModelProperty("领域大脑一本账") | |||
private String domainBrainAccount; | |||
@ApiModelProperty("是否业务协同 0:否 1:是") | |||
private Integer isBizCooperate; | |||
@ApiModelProperty("业务协同描述") | |||
private String bizCooperateInfo; | |||
@ApiModelProperty("使用范围") | |||
private String usesRangeRemark; | |||
@ApiModelProperty("应用简介") | |||
private String applicationSummary; | |||
@ApiModelProperty("应用备注") | |||
private String applicationRemark; | |||
@ApiModelProperty("应用总投资测算明细-文件") | |||
private String applicationEstimateFile; | |||
@ApiModelProperty("等保级别 1:一级 2:二级 3:三级 4:四级 5:五级") | |||
private Integer secrecyGrade; | |||
@ApiModelProperty("密码测评级别 1:一级 2:二级 3:三级 4:四级 5:五级") | |||
private Integer passwordGrade; | |||
@ApiModelProperty("是否符合国家信息技术应用创新相关规范 0:否 1:是") | |||
private Integer nationalItSpec; | |||
@ApiModelProperty("是否使用政务云资源 0否 1是") | |||
private Integer useGovCloud; | |||
@ApiModelProperty("云资源类型") | |||
private String cloudsType; | |||
@ApiModelProperty("云资源基础规格") | |||
private String cloudsFoundationSpecifications; | |||
@ApiModelProperty("云资源台数") | |||
private Integer cloudsNumber; | |||
@ApiModelProperty("云资源用户描述") | |||
private String cloudsDescription; | |||
@ApiModelProperty("网络环境 1:政务内网 2:政务外网 3:互联网 4:业务专网 5:单机") | |||
private Integer netEnv; | |||
@ApiModelProperty("是否使用公共数据 0否 1是") | |||
private Integer useCommonData; | |||
@ApiModelProperty("数据名称") | |||
private String dataName; | |||
@ApiModelProperty("是否使用公共组件 0否 1是") | |||
private Integer useCommonComponent; | |||
@ApiModelProperty("使用的公共组件名称") | |||
private String commonComponents; | |||
@ApiModelProperty("是否产生公共组件 0否 1是") | |||
private Integer produceCommonComponent; | |||
@ApiModelProperty("预计产生组件名称") | |||
private String produceCommonComponents; | |||
@ApiModelProperty("试点任务名称") | |||
private String pilotTasksName; | |||
@ApiModelProperty("试点任务编号") | |||
private String pilotTasksCode; | |||
@ApiModelProperty("所属重大应用名称") | |||
private String importantTaskName; | |||
@ApiModelProperty("所属重大应用编号") | |||
private String importantTaskCode; | |||
@ApiModelProperty("所属子场景应用名称") | |||
private String subSceneApplicationName; | |||
@ApiModelProperty("试点文件") | |||
private String experimentsFile; | |||
private Long createBy; | |||
private Long updateBy; | |||
} |
@@ -29,7 +29,7 @@ public class ProjectLibListReq extends PagePo { | |||
private String projectName; | |||
@ApiModelProperty("申报单位") | |||
private String applyOrg; | |||
private String buildUnit; | |||
@ApiModelProperty("项目类型") | |||
private Integer projectType; | |||
@@ -44,16 +44,16 @@ public class ProjectLibListReq extends PagePo { | |||
private Integer status2nd; | |||
@ApiModelProperty("申报金额") | |||
private BigDecimal declaredAmountMin; | |||
private BigDecimal declareAmountMin; | |||
@ApiModelProperty("申报金额") | |||
private BigDecimal declaredAmountMax; | |||
private BigDecimal declareAmountMax; | |||
@ApiModelProperty("批复金额") | |||
private BigDecimal approvedAmountMin; | |||
private BigDecimal approveAmountMin; | |||
@ApiModelProperty("批复金额") | |||
private BigDecimal approvedAmountMax; | |||
private BigDecimal approveAmountMax; | |||
@ApiModelProperty("创建时间") | |||
private LocalDateTime createOnMin; | |||
@@ -44,10 +44,10 @@ public class ProjectLibListItemVO { | |||
private Integer projectYear; | |||
@ApiModelProperty("申报单位") | |||
private String applyOrg; | |||
private String buildUnit; | |||
@ApiModelProperty("业务领域") | |||
private String bizArea; | |||
private String bizDomain; | |||
@ApiModelProperty("创建时间") | |||
private LocalDateTime createOn; | |||
@@ -0,0 +1,16 @@ | |||
package com.ningdatech.pmapi.projectlib.service; | |||
import com.ningdatech.pmapi.projectlib.model.entity.ProjectApplication; | |||
import com.baomidou.mybatisplus.extension.service.IService; | |||
/** | |||
* <p> | |||
* 服务类 | |||
* </p> | |||
* | |||
* @author WendyYang | |||
* @since 2023-02-05 | |||
*/ | |||
public interface IProjectApplicationService extends IService<ProjectApplication> { | |||
} |
@@ -0,0 +1,16 @@ | |||
package com.ningdatech.pmapi.projectlib.service; | |||
import com.ningdatech.pmapi.projectlib.model.entity.Project; | |||
import com.baomidou.mybatisplus.extension.service.IService; | |||
/** | |||
* <p> | |||
* 服务类 | |||
* </p> | |||
* | |||
* @author WendyYang | |||
* @since 2023-02-03 | |||
*/ | |||
public interface IProjectService extends IService<Project> { | |||
} |
@@ -0,0 +1,20 @@ | |||
package com.ningdatech.pmapi.projectlib.service.impl; | |||
import com.ningdatech.pmapi.projectlib.model.entity.ProjectApplication; | |||
import com.ningdatech.pmapi.projectlib.mapper.ProjectApplicationMapper; | |||
import com.ningdatech.pmapi.projectlib.service.IProjectApplicationService; | |||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | |||
import org.springframework.stereotype.Service; | |||
/** | |||
* <p> | |||
* 服务实现类 | |||
* </p> | |||
* | |||
* @author WendyYang | |||
* @since 2023-02-05 | |||
*/ | |||
@Service | |||
public class ProjectApplicationServiceImpl extends ServiceImpl<ProjectApplicationMapper, ProjectApplication> implements IProjectApplicationService { | |||
} |
@@ -0,0 +1,20 @@ | |||
package com.ningdatech.pmapi.projectlib.service.impl; | |||
import com.ningdatech.pmapi.projectlib.model.entity.Project; | |||
import com.ningdatech.pmapi.projectlib.mapper.ProjectMapper; | |||
import com.ningdatech.pmapi.projectlib.service.IProjectService; | |||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | |||
import org.springframework.stereotype.Service; | |||
/** | |||
* <p> | |||
* 服务实现类 | |||
* </p> | |||
* | |||
* @author WendyYang | |||
* @since 2023-02-03 | |||
*/ | |||
@Service | |||
public class ProjectServiceImpl extends ServiceImpl<ProjectMapper, Project> implements IProjectService { | |||
} |
@@ -50,16 +50,17 @@ public class SysProcdefController { | |||
return processModelService.saveProcess(modelHistory); | |||
} | |||
@ApiOperation(value = "系统流程配置启用(停用)", notes = "系统流程配置启用(停用)") | |||
@PutMapping("/{formId}/active/{state}") | |||
public Object enOrDisModel(@PathVariable String formId, | |||
public String enOrDisModel(@PathVariable String formId, | |||
@PathVariable Boolean state) { | |||
modelGroupService.enOrDisModel(formId, !state); | |||
return R.ok(Boolean.TRUE.equals(state) ? "启用流程成功":"停用流程成功"); | |||
return Boolean.TRUE.equals(state) ? "启用流程成功":"停用流程成功"; | |||
} | |||
@ApiOperation(value = "系统流程配置发布", notes = "系统流程配置发布") | |||
@PostMapping("/deploy/{formId}") | |||
public String save(@Validated @PathVariable String formId) { | |||
public String deploy(@Validated @PathVariable String formId) { | |||
return processModelService.deployProcess(formId); | |||
} | |||
} |
@@ -0,0 +1,23 @@ | |||
package com.ningdatech.pmapi.sys.processDef; | |||
import lombok.Data; | |||
import java.io.Serializable; | |||
import java.util.List; | |||
@Data | |||
public class Node<T> implements Serializable { | |||
private static final long serialVersionUID = -45475579271153023L; | |||
private String id; | |||
private String parentId; | |||
private String name; | |||
private T props; | |||
private Node<?> children; | |||
private List<Node<?>> branchs; | |||
} |
@@ -0,0 +1,79 @@ | |||
package com.ningdatech.pmapi.sys.processDef; | |||
import com.alibaba.fastjson.JSON; | |||
import org.junit.Test; | |||
import java.io.Serializable; | |||
import java.util.List; | |||
/** | |||
* @Classname ProcessTest | |||
* @Description | |||
* @Date 2023/2/4 9:54 | |||
* @Author PoffyZhang | |||
*/ | |||
public class ProcessDefTest { | |||
@Test | |||
public void test() { | |||
String processStr = "{\"id\":\"node_039152532706\",\"name\":\"审批单位\",\"type\":\"ORG\",\"props\":{\"regionCode\":\"\",\"orgCode\":\"GO_3bc86256687a4884ae410af00682b762\",\"type\":\"DEFAULT\",\"processDefId\":\"\",\"subNode\":[]},\"children\":{},\"parentId\":\"root\"}"; | |||
Node node = JSON.parseObject(processStr, Node.class); | |||
OrgProps props = JSON.parseObject(node.getProps().toString(), OrgProps.class); | |||
System.out.println(props.getOrgCode()); | |||
} | |||
public static class OrgProps { | |||
private String regionCode; | |||
private String orgCode; | |||
private String type; | |||
private String processDefId; | |||
private List<Node> subNode; | |||
public String getRegionCode() { | |||
return regionCode; | |||
} | |||
public void setRegionCode(String regionCode) { | |||
this.regionCode = regionCode; | |||
} | |||
public String getOrgCode() { | |||
return orgCode; | |||
} | |||
public void setOrgCode(String orgCode) { | |||
this.orgCode = orgCode; | |||
} | |||
public String getType() { | |||
return type; | |||
} | |||
public void setType(String type) { | |||
this.type = type; | |||
} | |||
public String getProcessDefId() { | |||
return processDefId; | |||
} | |||
public void setProcessDefId(String processDefId) { | |||
this.processDefId = processDefId; | |||
} | |||
public List<Node> getSubNode() { | |||
return subNode; | |||
} | |||
public void setSubNode(List<Node> subNode) { | |||
this.subNode = subNode; | |||
} | |||
} | |||
} |
@@ -123,6 +123,32 @@ | |||
<artifactId>kingbase8-8.2.0</artifactId> | |||
<version>1.0</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.alibaba</groupId> | |||
<artifactId>easyexcel-core</artifactId> | |||
<version>3.1.2</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-file-starter</artifactId> | |||
<version>1.0.0</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-zwdd-starter</artifactId> | |||
<version>1.0.0</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-cache-starter</artifactId> | |||
<version>1.0.0</version> | |||
</dependency> | |||
<dependency> | |||
<groupId>com.ningdatech</groupId> | |||
<artifactId>nd-log-starter</artifactId> | |||
<version>1.0.0</version> | |||
</dependency> | |||
</dependencies> | |||
</dependencyManagement> | |||