CostProjectMaterialManagerImpl.java 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. package com.hotent.project.manager.impl;
  2. import cn.hutool.core.util.ObjectUtil;
  3. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  4. import com.baomidou.mybatisplus.core.metadata.IPage;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import com.hotent.baseInfo.model.CostCatalogUnit;
  7. import com.hotent.project.manager.CostProjectApprovalManager;
  8. import com.hotent.project.model.CostProjectApproval;
  9. import com.hotent.project.model.CostProjectDocument;
  10. import com.hotent.project.model.CostProjectMaterial;
  11. import com.hotent.project.dao.CostProjectMaterialDao;
  12. import com.hotent.project.manager.CostProjectMaterialManager;
  13. import com.hotent.base.manager.impl.BaseManagerImpl;
  14. import com.hotent.project.req.CostProjectBasePageReq;
  15. import com.hotent.req.PageReq;
  16. import com.hotent.surveyinfo.manager.CostSurveyFdTemplateManager;
  17. import com.hotent.surveyinfo.model.CostSurveyFdTemplate;
  18. import com.hotent.sys.persistence.manager.DataDictManager;
  19. import com.hotent.sys.persistence.model.DataDict;
  20. import com.hotent.uc.exception.BaseException;
  21. import org.springframework.beans.factory.annotation.Autowired;
  22. import org.springframework.stereotype.Service;
  23. import org.springframework.transaction.annotation.Transactional;
  24. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  25. import java.util.ArrayList;
  26. import java.util.List;
  27. import java.util.Map;
  28. import java.util.function.Function;
  29. import java.util.stream.Collectors;
  30. import javax.annotation.Resource;
  31. import com.hotent.base.util.BeanUtils;
  32. /**
  33. * 报送资料要求 服务实现类
  34. *
  35. * @author 超级管理员
  36. * @company 山西清众科技股份有限公司
  37. * @since 2025-09-26
  38. */
  39. @Service
  40. public class CostProjectMaterialManagerImpl extends BaseManagerImpl<CostProjectMaterialDao, CostProjectMaterial> implements CostProjectMaterialManager {
  41. @Autowired
  42. private CostSurveyFdTemplateManager costSurveyFdTemplateManager;
  43. @Resource
  44. DataDictManager dataDictManager;
  45. @Autowired
  46. private CostProjectApprovalManager costProjectApprovalManager;
  47. @Override
  48. public CostProjectMaterial getDetail(String id) {
  49. CostProjectMaterial costProjectMaterial = this.get(id);
  50. return costProjectMaterial;
  51. }
  52. @Override
  53. @Transactional
  54. public int createOrUpdate(CostProjectMaterial costProjectMaterial) {
  55. //新建或更新
  56. return this.saveOrUpdate(costProjectMaterial)?1:0;
  57. }
  58. @Override
  59. public boolean save(CostProjectMaterial entity){
  60. String projectId = entity.getProjectId();
  61. if(ObjectUtil.isEmpty(projectId)){
  62. throw new BaseException("项目id不能为空");
  63. }
  64. CostProjectApproval costProjectApproval = costProjectApprovalManager.get(projectId);
  65. if (ObjectUtil.isEmpty(costProjectApproval)) {
  66. throw new BaseException("项目不存在");
  67. }
  68. entity.setCatalogId(costProjectApproval.getCatalogId());
  69. return super.save(entity);
  70. }
  71. @Override
  72. public IPage<CostProjectMaterial> pageList(CostProjectBasePageReq req) {
  73. LambdaQueryWrapper<CostProjectMaterial> qw = new LambdaQueryWrapper<>();
  74. qw.eq(CostProjectMaterial::getProjectId, req.getProjectId());
  75. qw.orderByAsc(CostProjectMaterial::getOrderNum);
  76. IPage<CostProjectMaterial> page = new Page<>(req.getPageNum(), req.getPageSize());
  77. IPage<CostProjectMaterial> pageList = this.page(page, qw);
  78. List<String> ids = pageList.getRecords().stream().filter(u -> "3".equals(u.getFormatRequired())).map(CostProjectMaterial::getTemplateId).distinct().collect(Collectors.toList());
  79. Map<String, CostSurveyFdTemplate> fdTemplateMap;
  80. if(!ObjectUtil.isEmpty(ids)) {
  81. List<CostSurveyFdTemplate> costSurveyFdTemplates = this.costSurveyFdTemplateManager.listByIds(ids);
  82. fdTemplateMap = costSurveyFdTemplates.stream().collect(Collectors.toMap(CostSurveyFdTemplate::getSurveyTemplateId, Function.identity()));
  83. } else {
  84. fdTemplateMap = null;
  85. }
  86. List<CostProjectMaterial> records = pageList.getRecords();
  87. List<String> list = records.stream().map(CostProjectMaterial::getInformationType).distinct().collect(Collectors.toList());
  88. QueryWrapper<DataDict> wrapper = new QueryWrapper<>();
  89. wrapper.eq("TYPE_ID_","1976557733440159744");
  90. wrapper.in("KEY_",list);
  91. List<DataDict> costDictDatas= dataDictManager.list(wrapper);
  92. List<String> listRequire = records.stream().map(CostProjectMaterial::getFormatRequired).distinct().collect(Collectors.toList());
  93. QueryWrapper<DataDict> wrapperRequire = new QueryWrapper<>();
  94. wrapperRequire.eq("TYPE_ID_","1976558645202157568");
  95. wrapperRequire.in("KEY_",listRequire);
  96. List<DataDict> listRequireDatas= dataDictManager.list(wrapperRequire);
  97. records.forEach(costCatalogUnit -> {
  98. costDictDatas.stream()
  99. .filter(c -> costCatalogUnit.getInformationType() != null &&
  100. costCatalogUnit.getInformationType().equals(String.valueOf(c.getKey())))
  101. .findAny().ifPresent(costDictData -> costCatalogUnit.setInformationTypeName(costDictData.getName()));
  102. listRequireDatas.stream()
  103. .filter(c -> costCatalogUnit.getFormatRequired() != null &&
  104. costCatalogUnit.getFormatRequired().equals(String.valueOf(c.getKey())))
  105. .findAny().ifPresent(costDictData -> costCatalogUnit.setFormatRequiredName(costDictData.getName()));
  106. if ("3".equals(costCatalogUnit.getFormatRequired())) {
  107. if(fdTemplateMap!=null) {
  108. CostSurveyFdTemplate costSurveyFdTemplate = fdTemplateMap.get(costCatalogUnit.getTemplateId());
  109. costCatalogUnit.setSurveyTemplateName(costSurveyFdTemplate.getSurveyTemplateName());
  110. }else{
  111. costCatalogUnit.setSurveyTemplateName("-");
  112. }
  113. }else{
  114. costCatalogUnit.setSurveyTemplateName("-");
  115. }
  116. });
  117. return pageList;
  118. }
  119. @Override
  120. public List<CostProjectMaterial> getListByProjectId(String projectId) {
  121. LambdaQueryWrapper<CostProjectMaterial> queryWrapper = new LambdaQueryWrapper<>();
  122. queryWrapper.eq(CostProjectMaterial::getProjectId, projectId);
  123. List<CostProjectMaterial> list = this.list(queryWrapper);
  124. if (ObjectUtil.isEmpty(list)) {
  125. return new ArrayList<>();
  126. }
  127. return list;
  128. }
  129. }