From ce0651907f18a57dae80065e01589e975530f53e Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期二, 20 五月 2025 18:52:44 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TFeasibilityStudyReportController.java | 263 ++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 211 insertions(+), 52 deletions(-) diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TFeasibilityStudyReportController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TFeasibilityStudyReportController.java index f519cc4..29490ee 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TFeasibilityStudyReportController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TFeasibilityStudyReportController.java @@ -6,27 +6,34 @@ import com.ruoyi.common.annotation.Log; import com.ruoyi.common.basic.PageInfo; import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.enums.BusinessType; -import com.ruoyi.common.enums.FeasibilityStudyReportStatusEnum; import com.ruoyi.common.enums.FeasibilityReportFileEnum; +import com.ruoyi.common.enums.FeasibilityStudyReportStatusEnum; +import com.ruoyi.common.enums.StudyReportTypeEnum; import com.ruoyi.framework.web.service.TokenService; import com.ruoyi.system.dto.AuditStatusDTO; import com.ruoyi.system.dto.TFeasibilityStudyReportDTO; +import com.ruoyi.system.mapper.SysUserMapper; import com.ruoyi.system.model.TFeasibilityReportFile; import com.ruoyi.system.model.TFeasibilityStudyReport; +import com.ruoyi.system.model.TProjectTeam; +import com.ruoyi.system.model.TProjectTeamStaff; import com.ruoyi.system.query.TFeasibilityStudyReportQuery; -import com.ruoyi.system.service.TFeasibilityReportFileService; -import com.ruoyi.system.service.TFeasibilityStudyReportService; +import com.ruoyi.system.service.*; import com.ruoyi.system.vo.TFeasibilityStudyReportVO; +import io.jsonwebtoken.lang.Collections; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.*; import java.time.LocalDateTime; import java.util.List; +import java.util.Map; +import java.util.Objects; +import java.util.stream.Collectors; /** * <p> @@ -38,61 +45,164 @@ */ @Api(tags = "可研、可行、工艺开发工具、验证发布报告管理") @RestController -@RequestMapping("/t-feasibility-study-report") +@RequestMapping("") public class TFeasibilityStudyReportController { private final TFeasibilityStudyReportService feasibilityStudyReportService; private final TFeasibilityReportFileService feasibilityReportFileService; private final TokenService tokenService; + private final TProjectTeamService projectTeamService; + private final TProjectTeamStaffService projectTeamStaffService; + private final ISysUserService sysUserService; + private final SysUserMapper sysUserMapper; @Autowired - public TFeasibilityStudyReportController(TFeasibilityStudyReportService feasibilityStudyReportService, TFeasibilityReportFileService feasibilityReportFileService, TokenService tokenService) { + public TFeasibilityStudyReportController(TFeasibilityStudyReportService feasibilityStudyReportService, TFeasibilityReportFileService feasibilityReportFileService, TokenService tokenService, TProjectTeamService projectTeamService, TProjectTeamStaffService projectTeamStaffService, ISysUserService sysUserService, SysUserMapper sysUserMapper) { this.feasibilityStudyReportService = feasibilityStudyReportService; this.feasibilityReportFileService = feasibilityReportFileService; this.tokenService = tokenService; + this.projectTeamService = projectTeamService; + this.projectTeamStaffService = projectTeamStaffService; + this.sysUserService = sysUserService; + this.sysUserMapper = sysUserMapper; } /** * 获取可研、可行、工艺开发工具、验证发布报告管理列表 */ - @PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:list')") - @ApiOperation(value = "获取可研、可行、工艺开发工具、验证发布报告管理分页列表") + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:list')") + @ApiOperation(value = "获取可研、可行、工艺开发工具、验证发布报告管理分页列表",response = TFeasibilityStudyReportQuery.class) @PostMapping(value = "/api/t-feasibility-study-report/pageList") public R<PageInfo<TFeasibilityStudyReportVO>> pageList(@RequestBody String param) { TFeasibilityStudyReportQuery query = JSON.parseObject(param, TFeasibilityStudyReportQuery.class); + Long userId = tokenService.getLoginUser().getUserId(); + Integer roleType = tokenService.getLoginUser().getUser().getRoleType(); + if(roleType != 1){ + // 查询用户所在项目组 + List<TProjectTeamStaff> projectTeamStaffs = projectTeamStaffService.list(Wrappers.lambdaQuery(TProjectTeamStaff.class) + .eq(TProjectTeamStaff::getUserId, userId)); + if(projectTeamStaffs.size() > 0){ + // 查询项目组id + List<String> teamIds = projectTeamStaffs.stream().map(TProjectTeamStaff::getTeamId).distinct().collect(Collectors.toList()); + query.setTeamIds(teamIds); + } + } return R.ok(feasibilityStudyReportService.pageList(query)); + } + + /** + * 获取可研、可行、工艺开发工具、验证发布报告管理列表 + */ + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:evaluatePageList')") + @ApiOperation(value = "获取专业报告课题评定分页列表-超管、审批人",response = TFeasibilityStudyReportQuery.class) + @PostMapping(value = "/api/t-feasibility-study-report/evaluatePageList") + public R<PageInfo<TFeasibilityStudyReportVO>> evaluatePageList(@RequestBody String param) { + TFeasibilityStudyReportQuery query = JSON.parseObject(param, TFeasibilityStudyReportQuery.class); + Long userId = tokenService.getLoginUser().getUserId(); + Integer roleType = tokenService.getLoginUser().getUser().getRoleType(); + if(roleType != 1){ + // 查询用户所在项目组 + List<TProjectTeamStaff> projectTeamStaffs = projectTeamStaffService.list(Wrappers.lambdaQuery(TProjectTeamStaff.class) + .eq(TProjectTeamStaff::getUserId, userId)); + if(projectTeamStaffs.size() > 0){ + // 查询项目组id + List<String> teamIds = projectTeamStaffs.stream().map(TProjectTeamStaff::getTeamId).distinct().collect(Collectors.toList()); + query.setTeamIds(teamIds); + } + } + return R.ok(feasibilityStudyReportService.evaluatePageList(query)); + } + + @ApiOperation(value = "获取专业报告课题评定数量统计",response = TFeasibilityStudyReportQuery.class) + @PostMapping(value = "/api/t-feasibility-study-report/evaluateCount") + public R<Map<String,Integer>> evaluateCount(@RequestBody String param) { + TFeasibilityStudyReportQuery query = JSON.parseObject(param, TFeasibilityStudyReportQuery.class); + Long userId = tokenService.getLoginUser().getUserId(); + Integer roleType = tokenService.getLoginUser().getUser().getRoleType(); + if(roleType != 1){ + // 查询用户所在项目组 + List<TProjectTeamStaff> projectTeamStaffs = projectTeamStaffService.list(Wrappers.lambdaQuery(TProjectTeamStaff.class) + .eq(TProjectTeamStaff::getUserId, userId)); + if(projectTeamStaffs.size() > 0){ + // 查询项目组id + List<String> teamIds = projectTeamStaffs.stream().map(TProjectTeamStaff::getTeamId).distinct().collect(Collectors.toList()); + query.setTeamIds(teamIds); + } + } + Map<String,Integer> map = feasibilityStudyReportService.evaluateCount(query); + return R.ok(map); } /** * 添加可研、可行、工艺开发工具、验证发布报告管理管理 */ - @PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:add')") + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:add')") @Log(title = "可研、可行、工艺开发工具、验证发布报告管理信息-新增可研、可行、工艺开发工具、验证发布报告管理", businessType = BusinessType.INSERT) @ApiOperation(value = "添加可研、可行、工艺开发工具、验证发布报告管理",response = TFeasibilityStudyReportDTO.class) @PostMapping(value = "/api/t-feasibility-study-report/add") public R<Boolean> add(@RequestBody String param) { TFeasibilityStudyReportDTO dto = JSON.parseObject(param,TFeasibilityStudyReportDTO.class); - // TODO 生成编号 + // 通过当前用户查询项目组 + Long userId = tokenService.getLoginUser().getUserId(); + TProjectTeamStaff projectTeamStaff = projectTeamStaffService.getOne(Wrappers.lambdaQuery(TProjectTeamStaff.class) + .eq(TProjectTeamStaff::getUserId, userId) + .last("LIMIT 1")); + if(Objects.isNull(projectTeamStaff)){ + return R.fail("当前用户未分配项目组,无法创建项目课题方案"); + } + // 查询项目组 + TProjectTeam projectTeam = projectTeamService.getById(projectTeamStaff.getTeamId()); + if(Objects.isNull(projectTeam)){ + return R.fail("项目组不存在"); + } + if(projectTeam.getStatus() == 2){ + return R.fail("项目组已封存,无法创建项目课题方案"); + } + // 生成可研、可行、工艺开发工具、验证发布报告编号 + String reportCode = ""; + switch (dto.getReportType()){ + case 1: + reportCode = projectTeam.getTeamName() + "-" + StudyReportTypeEnum.FEASIBILITY_STUDY_REPORT.getCode(); + break; + case 2: + reportCode = projectTeam.getTeamName() + "-" + StudyReportTypeEnum.FEASIBLE_REPORT.getCode(); + break; + case 3: + reportCode = projectTeam.getTeamName() + "-" + StudyReportTypeEnum.PROCESS_DEVELOPMENT_TOOLS.getCode(); + break; + default: + reportCode = projectTeam.getTeamName() + "-" + StudyReportTypeEnum.VERIFICATION_RELEASE.getCode(); + break; + } + + // 查询上个项目课题方案的序号 + long count = feasibilityStudyReportService.count(Wrappers.lambdaQuery(TFeasibilityStudyReport.class) + .like(TFeasibilityStudyReport::getReportCode, reportCode)); + reportCode = reportCode + "-" + String.format("%03d", count+1); + dto.setReportCode(reportCode); + feasibilityStudyReportService.save(dto); // 添加检测报告文件 List<TFeasibilityReportFile> feasibilityReportFiles = dto.getFeasibilityReportFiles(); - for (TFeasibilityReportFile feasibilityReportFile : feasibilityReportFiles) { - feasibilityReportFile.setReportId(dto.getId()); - switch (FeasibilityReportFileEnum.fromCode(feasibilityReportFile.getReportType())) { - case FEASIBILITY_STUDY_REPORT: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.FEASIBILITY_STUDY_REPORT.getCode()); - break; - case FEASIBLE_REPORT: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.FEASIBLE_REPORT.getCode()); - break; - case PROCESS_DEVELOPMENT_TOOLS: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.PROCESS_DEVELOPMENT_TOOLS.getCode()); - break; - case VERIFICATION_RELEASE: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.VERIFICATION_RELEASE.getCode()); - break; - default: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.PROJECT_PROPOSAL.getCode()); - break; + if(!Collections.isEmpty(feasibilityReportFiles)){ + for (TFeasibilityReportFile feasibilityReportFile : feasibilityReportFiles) { + feasibilityReportFile.setReportId(dto.getId()); + switch (FeasibilityReportFileEnum.fromCode(feasibilityReportFile.getReportType())) { + case FEASIBILITY_STUDY_REPORT: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.FEASIBILITY_STUDY_REPORT.getCode()); + break; + case FEASIBLE_REPORT: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.FEASIBLE_REPORT.getCode()); + break; + case PROCESS_DEVELOPMENT_TOOLS: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.PROCESS_DEVELOPMENT_TOOLS.getCode()); + break; + case VERIFICATION_RELEASE: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.VERIFICATION_RELEASE.getCode()); + break; + default: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.PROJECT_PROPOSAL.getCode()); + break; + } } } feasibilityReportFileService.saveBatch(feasibilityReportFiles); @@ -102,7 +212,7 @@ /** * 修改可研、可行、工艺开发工具、验证发布报告管理 */ - @PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:edit')") + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:edit')") @Log(title = "可研、可行、工艺开发工具、验证发布报告管理信息-修改可研、可行、工艺开发工具、验证发布报告管理", businessType = BusinessType.UPDATE) @ApiOperation(value = "修改可研、可行、工艺开发工具、验证发布报告管理") @PostMapping(value = "/api/t-feasibility-study-report/update") @@ -113,24 +223,26 @@ .eq(TFeasibilityReportFile::getReportId, dto.getId())); // 添加检测报告文件 List<TFeasibilityReportFile> feasibilityReportFiles = dto.getFeasibilityReportFiles(); - for (TFeasibilityReportFile feasibilityReportFile : feasibilityReportFiles) { - feasibilityReportFile.setReportId(dto.getId()); - switch (FeasibilityReportFileEnum.fromCode(feasibilityReportFile.getReportType())) { - case FEASIBILITY_STUDY_REPORT: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.FEASIBILITY_STUDY_REPORT.getCode()); - break; - case FEASIBLE_REPORT: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.FEASIBLE_REPORT.getCode()); - break; - case PROCESS_DEVELOPMENT_TOOLS: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.PROCESS_DEVELOPMENT_TOOLS.getCode()); - break; - case VERIFICATION_RELEASE: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.VERIFICATION_RELEASE.getCode()); - break; - default: - feasibilityReportFile.setReportType(FeasibilityReportFileEnum.PROJECT_PROPOSAL.getCode()); - break; + if(!Collections.isEmpty(feasibilityReportFiles)){ + for (TFeasibilityReportFile feasibilityReportFile : feasibilityReportFiles) { + feasibilityReportFile.setReportId(dto.getId()); + switch (FeasibilityReportFileEnum.fromCode(feasibilityReportFile.getReportType())) { + case FEASIBILITY_STUDY_REPORT: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.FEASIBILITY_STUDY_REPORT.getCode()); + break; + case FEASIBLE_REPORT: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.FEASIBLE_REPORT.getCode()); + break; + case PROCESS_DEVELOPMENT_TOOLS: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.PROCESS_DEVELOPMENT_TOOLS.getCode()); + break; + case VERIFICATION_RELEASE: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.VERIFICATION_RELEASE.getCode()); + break; + default: + feasibilityReportFile.setReportType(FeasibilityReportFileEnum.PROJECT_PROPOSAL.getCode()); + break; + } } } feasibilityReportFileService.saveBatch(feasibilityReportFiles); @@ -140,7 +252,7 @@ /** * 查看可研、可行、工艺开发工具、验证发布报告管理详情 */ - @PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:detail')") + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:detail')") @ApiOperation(value = "查看可研、可行、工艺开发工具、验证发布报告管理详情") @GetMapping(value = "/open/t-feasibility-study-report/getDetailById") public R<TFeasibilityStudyReportVO> getDetailById(@RequestParam String id) { @@ -151,13 +263,22 @@ List<TFeasibilityReportFile> feasibilityReportFiles = feasibilityReportFileService.list(Wrappers.lambdaQuery(TFeasibilityReportFile.class) .eq(TFeasibilityReportFile::getReportId, id)); feasibilityStudyReportVO.setFeasibilityReportFiles(feasibilityReportFiles); + // 查询项目组 + TProjectTeam projectTeam = projectTeamService.getById(feasibilityStudyReport.getTeamId()); + // 查询项目组成员 + List<TProjectTeamStaff> projectTeamStaffs = projectTeamStaffService.list(Wrappers.lambdaQuery(TProjectTeamStaff.class) + .eq(TProjectTeamStaff::getTeamId, projectTeam.getId())); + List<Long> userIds = projectTeamStaffs.stream().map(TProjectTeamStaff::getUserId).collect(Collectors.toList()); + List<SysUser> sysUsers = sysUserMapper.selectUserByIds(userIds); + feasibilityStudyReportVO.setStaffNames(sysUsers.stream().map(SysUser::getNickName).collect(Collectors.joining(","))); + feasibilityStudyReportVO.setProjectTeam(projectTeam); return R.ok(feasibilityStudyReportVO); } /** * 删除可研、可行、工艺开发工具、验证发布报告管理 */ - @PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:delete')") + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:delete')") @Log(title = "可研、可行、工艺开发工具、验证发布报告管理信息-删除可研、可行、工艺开发工具、验证发布报告管理", businessType = BusinessType.DELETE) @ApiOperation(value = "删除可研、可行、工艺开发工具、验证发布报告管理") @DeleteMapping(value = "/open/t-feasibility-study-report/deleteById") @@ -170,7 +291,7 @@ /** * 批量删除可研、可行、工艺开发工具、验证发布报告管理 */ - @PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:delete')") + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:delete')") @Log(title = "可研、可行、工艺开发工具、验证发布报告管理信息-删除可研、可行、工艺开发工具、验证发布报告管理", businessType = BusinessType.DELETE) @ApiOperation(value = "批量删除可研、可行、工艺开发工具、验证发布报告管理") @DeleteMapping(value = "/open/t-feasibility-study-report/deleteByIds") @@ -183,7 +304,7 @@ /** * 撤销可研、可行、工艺开发工具、验证发布报告管理 */ - @PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:revokedReport')") + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:revokedReport')") @Log(title = "可研、可行、工艺开发工具、验证发布报告管理信息-撤销可研、可行、工艺开发工具、验证发布报告管理状态", businessType = BusinessType.UPDATE) @ApiOperation(value = "撤销可研、可行、工艺开发工具、验证发布报告管理状态") @PutMapping(value = "/open/t-feasibility-study-report/revokedReport") @@ -197,7 +318,7 @@ /** * 审核可研、可行、工艺开发工具、验证发布报告管理 */ - @PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:auditReport')") + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:auditReport')") @Log(title = "可研、可行、工艺开发工具、验证发布报告管理信息-审核可研、可行、工艺开发工具、验证发布报告管理状态", businessType = BusinessType.UPDATE) @ApiOperation(value = "审核可研、可行、工艺开发工具、验证发布报告管理状态") @PostMapping(value = "/api/t-feasibility-study-report/auditReport") @@ -212,6 +333,44 @@ feasibilityStudyReportService.updateById(feasibilityStudyReport); return R.ok(); } + + /** + * 课题评定-进行评定 + */ + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:evaluate')") + @Log(title = "课题评定-进行评定", businessType = BusinessType.UPDATE) + @ApiOperation(value = "课题评定") + @PutMapping(value = "/open/t-feasibility-study-report/evaluate") + public R<Boolean> evaluate(@RequestParam(value = "id") String id, + @RequestParam(value = "evaluateScore") String evaluateScore) { + Long userId = tokenService.getLoginUser().getUserId(); + TFeasibilityStudyReport feasibilityStudyReport = feasibilityStudyReportService.getById(id); + feasibilityStudyReport.setStatus(3); + feasibilityStudyReport.setEvaluatePersonId(userId); + feasibilityStudyReport.setEvaluateTime(LocalDateTime.now()); + feasibilityStudyReport.setEvaluateScore(evaluateScore); + feasibilityStudyReportService.updateById(feasibilityStudyReport); + return R.ok(); + } + + /** + * 课题评定-评定详情 + */ + //@PreAuthorize("@ss.hasPermi('system:feasibilityStudyReport:evaluate')") + @Log(title = "课题评定-评定详情", businessType = BusinessType.UPDATE) + @ApiOperation(value = "评定详情") + @GetMapping(value = "/open/t-feasibility-study-report/evaluateDetail") + public R<TFeasibilityStudyReportVO> evaluateDetail(@RequestParam(value = "id") String id) { + TFeasibilityStudyReport feasibilityStudyReport = feasibilityStudyReportService.getById(id); + TFeasibilityStudyReportVO tFeasibilityStudyReportVO = new TFeasibilityStudyReportVO(); + BeanUtils.copyProperties(feasibilityStudyReport, tFeasibilityStudyReportVO); + // 查询评定人员名称 + SysUser sysUser = sysUserService.selectUserById(feasibilityStudyReport.getEvaluatePersonId()); + if(Objects.nonNull(sysUser)){ + tFeasibilityStudyReportVO.setEvaluatePersonName(sysUser.getNickName()); + } + return R.ok(tFeasibilityStudyReportVO); + } } -- Gitblit v1.7.1