From ec9a95eb994018cc1ba28a80946165f795001dea Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期五, 29 十一月 2024 16:49:24 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- business/src/main/java/com/ycl/service/impl/ProjectInfoServiceImpl.java | 239 ++++++++++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 200 insertions(+), 39 deletions(-) diff --git a/business/src/main/java/com/ycl/service/impl/ProjectInfoServiceImpl.java b/business/src/main/java/com/ycl/service/impl/ProjectInfoServiceImpl.java index 05a25e8..b865b20 100644 --- a/business/src/main/java/com/ycl/service/impl/ProjectInfoServiceImpl.java +++ b/business/src/main/java/com/ycl/service/impl/ProjectInfoServiceImpl.java @@ -1,28 +1,42 @@ package com.ycl.service.impl; +import cn.hutool.core.collection.CollUtil; +import com.alibaba.excel.EasyExcel; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ycl.common.base.Result; import com.ycl.common.enums.business.FileTypeEnum; +import com.ycl.common.enums.business.ImportanceTypeEnum; +import com.ycl.common.enums.business.ProjectCategoryEnum; +import com.ycl.common.exception.base.BaseException; +import com.ycl.common.utils.CopyUtils; +import com.ycl.common.utils.DateUtils; import com.ycl.common.utils.SecurityUtils; -import com.ycl.domain.entity.File; -import com.ycl.domain.entity.ProjectInfo; +import com.ycl.common.utils.StringUtils; +import com.ycl.common.utils.bean.BeanUtils; +import com.ycl.common.utils.excel.OutputExcelUtils; +import com.ycl.domain.entity.*; +import com.ycl.domain.excel.ProjectExcelTemplate; import com.ycl.domain.form.DocumentInfoForm; import com.ycl.domain.form.ProjectInfoForm; +import com.ycl.domain.query.ProjectExportQuery; import com.ycl.domain.query.ProjectInfoQuery; import com.ycl.domain.vo.*; import com.ycl.framework.utils.PageUtil; -import com.ycl.mapper.FileMapper; -import com.ycl.mapper.ProjectInfoMapper; +import com.ycl.mapper.*; import com.ycl.service.FileService; import com.ycl.service.ProjectInfoService; import lombok.RequiredArgsConstructor; -import org.springframework.beans.BeanUtils; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.Assert; +import javax.servlet.ServletOutputStream; +import javax.servlet.http.HttpServletResponse; +import java.math.BigDecimal; +import java.math.RoundingMode; +import java.text.SimpleDateFormat; import java.util.*; import java.util.stream.Collectors; @@ -37,8 +51,13 @@ public class ProjectInfoServiceImpl extends ServiceImpl<ProjectInfoMapper, ProjectInfo> implements ProjectInfoService { private final ProjectInfoMapper projectInfoMapper; + private final ProjectInvestmentFundingMapper investmentFundingMapper; + private final ProjectInvestmentInfoMapper investmentInfoMapper; + private final ProjectInvestmentPolicyComplianceMapper policyMapper; + private final ProjectUnitRegistrationInfoMapper unitRegistrationInfoMapper; private final FileService fileService; private final FileMapper fileMapper; + /** * 娣诲姞 * @@ -56,7 +75,7 @@ baseMapper.insert(entity); //娣诲姞鏂囦欢 List<File> fileList = form.getFileList(); - fileList.forEach(item->{ + fileList.forEach(item -> { item.setBusId(entity.getId()); item.setType(FileTypeEnum.PROJECT_INFO); }); @@ -76,20 +95,21 @@ ProjectInfo entity = baseMapper.selectById(form.getId()); // 涓虹┖鎶汭llegalArgumentException锛屽仛鍏ㄥ眬寮傚父澶勭悊 Assert.notNull(entity, "璁板綍涓嶅瓨鍦�"); - ProjectInfoForm.getEntityByForm(form,entity); + ProjectInfoForm.getEntityByForm(form, entity); Long userId = SecurityUtils.getUserId(); entity.setUpdateBy(userId); //鏇存柊椤圭洰淇℃伅 baseMapper.updateById(entity); List<File> fileList = form.getFileList(); - fileList.forEach(item->{ + fileList.forEach(item -> { + item.setId(null); item.setBusId(entity.getId()); item.setType(FileTypeEnum.PROJECT_INFO); }); //鍒犻櫎鍘熸湁鏂囦欢 QueryWrapper<File> fileQueryWrapper = new QueryWrapper<>(); - fileQueryWrapper.eq("type",FileTypeEnum.PROJECT_INFO.getType()); - fileQueryWrapper.eq("bus_id",entity.getId()); + fileQueryWrapper.eq("type", FileTypeEnum.PROJECT_INFO.getType()); + fileQueryWrapper.eq("bus_id", entity.getId()); fileMapper.delete(fileQueryWrapper); //鏇挎崲鎴愮幇鏈� fileService.saveBatch(fileList); @@ -103,7 +123,6 @@ * @return */ @Override - //TODO:寰呭畬鍠� public Result remove(List<String> ids) { baseMapper.deleteBatchIds(ids); return Result.ok("鍒犻櫎鎴愬姛"); @@ -116,8 +135,18 @@ * @return */ @Override - //TODO:寰呭畬鍠� - public Result removeById(String id) { + @Transactional(rollbackFor = Exception.class) + public Result removeById(Long id) { + investmentFundingMapper.delete(new QueryWrapper<ProjectInvestmentFunding>().eq("project_id", id)); + investmentInfoMapper.delete(new QueryWrapper<ProjectInvestmentInfo>().eq("project_id", id)); + policyMapper.delete(new QueryWrapper<ProjectInvestmentPolicyCompliance>().eq("project_id", id)); + unitRegistrationInfoMapper.delete(new QueryWrapper<ProjectUnitRegistrationInfo>().eq("project_id", id)); + + List<String> types = new ArrayList<>(); + types.add(FileTypeEnum.PROJECT_INFO.getType()); + types.add(FileTypeEnum.INVEST_POLICY.getType()); + types.add(FileTypeEnum.DOCUMENT_INFO.getType()); + fileMapper.delete(new QueryWrapper<File>().eq("bus_id", id).in("type", types)); baseMapper.deleteById(id); return Result.ok("鍒犻櫎鎴愬姛"); } @@ -130,17 +159,59 @@ */ @Override public Result page(ProjectInfoQuery query) { - IPage<ProjectInfo> page = PageUtil.getPage(query, ProjectInfo.class); + if (query.getProjectStartTime() != null) { + query.setProjectStartTime(DateUtils.getDayStart(query.getProjectStartTime())); + } + if (query.getProjectEndTime() != null) { + query.setProjectEndTime(DateUtils.getDayEnd(query.getProjectEndTime())); + } + String projectCategory = query.getProjectCategory(); + //瀹炴柦闃舵鏈変袱涓�兼斁鍦╯ql澶勭悊 + if (ProjectCategoryEnum.RESERVE.getType().equals(projectCategory)) { + query.setProjectStatus(ProjectCategoryEnum.RESERVE.getStatus()); + query.setReserveOrPrevious(ProjectCategoryEnum.RESERVE.getCode()); + } else if (ProjectCategoryEnum.PREVIOUS.getType().equals(projectCategory)) { + query.setProjectStatus(ProjectCategoryEnum.PREVIOUS.getStatus()); + query.setReserveOrPrevious(ProjectCategoryEnum.PREVIOUS.getCode()); + } else if (ProjectCategoryEnum.FINISH.getType().equals(projectCategory)) { + query.setProjectStatus(ProjectCategoryEnum.FINISH.getStatus()); + } else if (ProjectCategoryEnum.EXCEPTION.getType().equals(projectCategory)) { + //TODO + //鍏堟煡鍑哄紓甯告祦绋嬫垨鑰呭紓甯歌繘搴︽垨鑰呭紓甯歌鍒掔殑projectId鍜屽紓甯哥绫� + //閫氳繃projectId鏌ュ嚭椤圭洰鏁版嵁 + //琛ュ厖鐩稿簲鐨勫紓甯告暟鎹紙寮傚父绉嶇被銆佸紓甯告祦绋嬭妭鐐圭瓑锛� + List<ProjectVO> list = new ArrayList<>(); + return Result.ok().data(list).total(0); + } + + IPage<ProjectInfoVO> page = PageUtil.getPage(query, ProjectInfoVO.class); baseMapper.getPage(page, query); - List<ProjectInfo> records = page.getRecords(); - List<ProjectInfoVO> list = records.stream() - .map(entity -> { - ProjectInfoVO vo = ProjectInfoVO.getVoByEntity(entity, null); - vo.setProjectColorCode("green"); - return vo; - }) - .collect(Collectors.toList()); + List<ProjectInfoVO> records = page.getRecords(); + List<ProjectVO> list = new ArrayList<>(); + records.forEach(vo -> { + ProjectInfoVO.transform(vo); + vo.setProjectColorCode("green"); + ProjectVO projectVO = new ProjectVO(); + copyToProjectVO(vo, projectVO); + //缈昏瘧椤圭洰闃舵 + String phase = ProjectCategoryEnum.getPhaseByProjectStatus(projectVO.getProjectStatus(), projectVO.getProcessId() != null); + projectVO.setProjectPhase(phase); + list.add(projectVO); + }); return Result.ok().data(list).total(page.getTotal()); + } + + private void copyToProjectVO(ProjectInfoVO vo, ProjectVO projectVO) { + //蹇界暐null鍊肩殑澶嶅埗 + CopyUtils.copyNoNullProperties(vo, projectVO); + if (vo.getProjectInvestmentInfo() != null) + CopyUtils.copyNoNullProperties(vo.getProjectInvestmentInfo(), projectVO); + if (vo.getProjectUnitRegistrationInfo() != null) + CopyUtils.copyNoNullProperties(vo.getProjectUnitRegistrationInfo(), projectVO); + if (vo.getProjectInvestmentPolicyCompliance() != null) + CopyUtils.copyNoNullProperties(vo.getProjectInvestmentPolicyCompliance(), projectVO); + if (vo.getProjectInvestmentFunding() != null) + CopyUtils.copyNoNullProperties(vo.getProjectInvestmentFunding(), projectVO); } /** @@ -155,8 +226,8 @@ Assert.notNull(entity, "璁板綍涓嶅瓨鍦�"); ProjectInfoVO vo = ProjectInfoVO.getVoByEntity(entity, null); QueryWrapper<File> fileQueryWrapper = new QueryWrapper<>(); - fileQueryWrapper.eq("type",FileTypeEnum.PROJECT_INFO.getType()); - fileQueryWrapper.eq("bus_id",vo.getId()); + fileQueryWrapper.eq("type", FileTypeEnum.PROJECT_INFO.getType()); + fileQueryWrapper.eq("bus_id", vo.getId()); List<File> files = fileMapper.selectList(fileQueryWrapper); vo.setFileList(files); return Result.ok().data(vo); @@ -186,17 +257,80 @@ // {"type":"鐪侀噸鐐归」鐩�","count":0,"amount":"0.00","text":"鐪�"}]}} IndexCountVO indexCountVO = new IndexCountVO(); List<IndexProPhaseCountVO> proPhaseCountVO = new ArrayList<>(); - proPhaseCountVO.add(new IndexProPhaseCountVO("鍌ㄥ瑙勫垝闃舵", 0, "0.00", "鍌�")); - proPhaseCountVO.add(new IndexProPhaseCountVO("椤圭洰鍓嶆湡闃舵", 0, "0.00", "鏂�")); - proPhaseCountVO.add(new IndexProPhaseCountVO("瀹炴柦闃舵", 0, "0.00", "寤�")); - proPhaseCountVO.add(new IndexProPhaseCountVO("绔e伐鎶曠敤闃舵", 0, "0.00", "绔�")); - List<IndexImpTypeCountVO> impTypeCountVO = new ArrayList<>(); - impTypeCountVO.add(new IndexImpTypeCountVO("涓�鑸」鐩�", 0, "0.00", "鏅�")); - impTypeCountVO.add(new IndexImpTypeCountVO("鍘块噸鐐归」鐩�", 0, "0.00", "鍘�")); - impTypeCountVO.add(new IndexImpTypeCountVO("甯傞噸鐐归」鐩�", 0, "0.00", "甯�")); - impTypeCountVO.add(new IndexImpTypeCountVO("鐪侀噸鐐归」鐩�", 0, "0.00", "鐪�")); - indexCountVO.setImpTypeCountVO(impTypeCountVO); + List<ProjectVO> projectVOS = baseMapper.homeCount(); + List<ProjectVO> reserve = new ArrayList<>(); + List<ProjectVO> previous = new ArrayList<>(); + List<ProjectVO> implement = new ArrayList<>(); + List<ProjectVO> finish = new ArrayList<>(); + List<ProjectVO> normal = new ArrayList<>(); + List<ProjectVO> province = new ArrayList<>(); + List<ProjectVO> city = new ArrayList<>(); + List<ProjectVO> county = new ArrayList<>(); + projectVOS.forEach(item -> { + if (ProjectCategoryEnum.RESERVE.getDesc().equals(ProjectCategoryEnum.getPhaseByProjectStatus(item.getProjectStatus(), item.getProcessId() != null))) { + reserve.add(item); + } else if (ProjectCategoryEnum.PREVIOUS.getDesc().equals(ProjectCategoryEnum.getPhaseByProjectStatus(item.getProjectStatus(), item.getProcessId() != null))) { + previous.add(item); + } else if (ProjectCategoryEnum.IMPLEMENT.getDesc().equals(ProjectCategoryEnum.getPhaseByProjectStatus(item.getProjectStatus(), item.getProcessId() != null))) { + implement.add(item); + } else if (ProjectCategoryEnum.FINISH.getDesc().equals(ProjectCategoryEnum.getPhaseByProjectStatus(item.getProjectStatus(), item.getProcessId() != null))) { + finish.add(item); + } + + if (ImportanceTypeEnum.PROVINCIAL_KEY.getType().equals(item.getImportanceType())) { + province.add(item); + } else if (ImportanceTypeEnum.SUINING_KEY.getType().equals(item.getImportanceType())) { + city.add(item); + } else if (ImportanceTypeEnum.SHEHONG_KEY.getType().equals(item.getImportanceType())) { + county.add(item); + } else if (ImportanceTypeEnum.NORMAL.getType().equals(item.getImportanceType())) { + normal.add(item); + } + }); + //鍗曚綅鍏堥粯璁や负鍏� + proPhaseCountVO.add(new IndexProPhaseCountVO("鍌ㄥ瑙勫垝闃舵", reserve.size(), reserve.stream(). + filter(item -> !StringUtils.isEmpty(item.getTotalInvestment())) + .map(item -> new BigDecimal(item.getTotalInvestment()).setScale(2, RoundingMode.HALF_UP)) + .reduce(BigDecimal.ZERO, BigDecimal::add).divide(new BigDecimal("100000000"), 2, RoundingMode.HALF_UP).toString(), "鍌�")); + + proPhaseCountVO.add(new IndexProPhaseCountVO("椤圭洰鍓嶆湡闃舵", previous.size(), previous.stream(). + filter(item -> !StringUtils.isEmpty(item.getTotalInvestment())) + .map(item -> new BigDecimal(item.getTotalInvestment()).setScale(2, RoundingMode.HALF_UP)) + .reduce(BigDecimal.ZERO, BigDecimal::add).divide(new BigDecimal("100000000"), 2, RoundingMode.HALF_UP).toString(), "鏂�")); + + proPhaseCountVO.add(new IndexProPhaseCountVO("瀹炴柦闃舵", implement.size(), implement.stream(). + filter(item -> !StringUtils.isEmpty(item.getTotalInvestment())) + .map(item -> new BigDecimal(item.getTotalInvestment()).setScale(2, RoundingMode.HALF_UP)) + .reduce(BigDecimal.ZERO, BigDecimal::add).divide(new BigDecimal("100000000"), 2, RoundingMode.HALF_UP).toString(), "寤�")); + + proPhaseCountVO.add(new IndexProPhaseCountVO("绔e伐鎶曠敤闃舵", finish.size(), finish.stream(). + filter(item -> !StringUtils.isEmpty(item.getTotalInvestment())) + .map(item -> new BigDecimal(item.getTotalInvestment()).setScale(2, RoundingMode.HALF_UP)) + .reduce(BigDecimal.ZERO, BigDecimal::add).divide(new BigDecimal("100000000"), 2, RoundingMode.HALF_UP).toString(), "绔�")); + indexCountVO.setProPhaseCountVO(proPhaseCountVO); + + List<IndexImpTypeCountVO> impTypeCountVO = new ArrayList<>(); + impTypeCountVO.add(new IndexImpTypeCountVO("涓�鑸」鐩�", province.size(), province.stream(). + filter(item -> !StringUtils.isEmpty(item.getTotalInvestment())) + .map(item -> new BigDecimal(item.getTotalInvestment()).setScale(2, RoundingMode.HALF_UP)) + .reduce(BigDecimal.ZERO, BigDecimal::add).divide(new BigDecimal("100000000"), 2, RoundingMode.HALF_UP).toString(), "鏅�")); + + impTypeCountVO.add(new IndexImpTypeCountVO("鍘块噸鐐归」鐩�", city.size(), city.stream(). + filter(item -> !StringUtils.isEmpty(item.getTotalInvestment())) + .map(item -> new BigDecimal(item.getTotalInvestment()).setScale(2, RoundingMode.HALF_UP)) + .reduce(BigDecimal.ZERO, BigDecimal::add).divide(new BigDecimal("100000000"), 2, RoundingMode.HALF_UP).toString(), "鍘�")); + + impTypeCountVO.add(new IndexImpTypeCountVO("甯傞噸鐐归」鐩�", county.size(), county.stream(). + filter(item -> !StringUtils.isEmpty(item.getTotalInvestment())) + .map(item -> new BigDecimal(item.getTotalInvestment()).setScale(2, RoundingMode.HALF_UP)) + .reduce(BigDecimal.ZERO, BigDecimal::add).divide(new BigDecimal("100000000"), 2, RoundingMode.HALF_UP).toString(), "甯�")); + + impTypeCountVO.add(new IndexImpTypeCountVO("鐪侀噸鐐归」鐩�", normal.size(), normal.stream(). + filter(item -> !StringUtils.isEmpty(item.getTotalInvestment())) + .map(item -> new BigDecimal(item.getTotalInvestment()).setScale(2, RoundingMode.HALF_UP)) + .reduce(BigDecimal.ZERO, BigDecimal::add).divide(new BigDecimal("100000000"), 2, RoundingMode.HALF_UP).toString(), "鐪�")); + indexCountVO.setImpTypeCountVO(impTypeCountVO); return indexCountVO; @@ -213,8 +347,8 @@ public Result docDetail(Integer id) { DocumentInfoForm documentInfoForm = new DocumentInfoForm(); QueryWrapper<File> fileQueryWrapper = new QueryWrapper<>(); - fileQueryWrapper.eq("type",FileTypeEnum.DOCUMENT_INFO.getType()); - fileQueryWrapper.eq("bus_id",id); + fileQueryWrapper.eq("type", FileTypeEnum.DOCUMENT_INFO.getType()); + fileQueryWrapper.eq("bus_id", id); List<File> files = fileMapper.selectList(fileQueryWrapper); documentInfoForm.setFileList(files); return Result.ok().data(documentInfoForm); @@ -223,14 +357,15 @@ @Override public Result addDoc(DocumentInfoForm form) { List<File> fileList = form.getFileList(); - fileList.forEach(item->{ + fileList.forEach(item -> { + item.setId(null); item.setBusId(form.getProjectId()); item.setType(FileTypeEnum.DOCUMENT_INFO); }); //鍒犻櫎鍘熸湁鏂囦欢 QueryWrapper<File> fileQueryWrapper = new QueryWrapper<>(); - fileQueryWrapper.eq("type",FileTypeEnum.DOCUMENT_INFO.getType()); - fileQueryWrapper.eq("bus_id",form.getProjectId()); + fileQueryWrapper.eq("type", FileTypeEnum.DOCUMENT_INFO.getType()); + fileQueryWrapper.eq("bus_id", form.getProjectId()); fileMapper.delete(fileQueryWrapper); //鏇挎崲鎴愮幇鏈� fileService.saveBatch(fileList); @@ -251,4 +386,30 @@ return Result.ok().data(false); } } + + @Override + public void export(HttpServletResponse response, ProjectExportQuery query) { + List<ProjectVO> data = baseMapper.selectProjectDetailByIds(query.getDataIdList()); + List<ProjectExcelTemplate> excelList = new ArrayList<>(); + //瀛楀吀浣滅炕璇� + data.forEach(item->{ + ProjectExcelTemplate excel = new ProjectExcelTemplate(); + BeanUtils.copyProperties(item,excel); + //椤圭洰闃舵 + excel.setProjectPhase(ProjectCategoryEnum.getPhaseByProjectStatus(item.getProjectStatus(),item.getProcessId()!=null)); + excelList.add(excel); + }); + //琛ュ厖鏂囦欢鐨勫瓧娈� + Set<Integer> indexes = OutputExcelUtils.getSelectFields(query.getFieldList(), ProjectExcelTemplate.class); + //涓嶉渶瑕侀檮浠� + if(!query.getRequireFile()) { + try (ServletOutputStream outputStream = response.getOutputStream()) { + EasyExcel.write(outputStream, ProjectExcelTemplate.class).includeColumnIndexes(indexes).sheet("椤圭洰鍒楄〃").doWrite(excelList); + } catch (Exception e) { + log.error(e.getMessage(), e); + throw new BaseException("瀵煎嚭澶辫触锛�" + e.getMessage()); + } + } + //TODO锛氶渶瑕侀檮浠� + } } -- Gitblit v1.8.0