PurchasingApprovalServiceImpl.java 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. package com.migao.service.impl;
  2. import com.baomidou.mybatisplus.core.conditions.Wrapper;
  3. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  4. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  7. import com.migao.config.constant.ExamineStatus;
  8. import com.migao.config.constant.FinancesStatus;
  9. import com.migao.config.constant.ProjectStatus;
  10. import com.migao.config.constant.PurchasingStage;
  11. import com.migao.config.response.PageBean;
  12. import com.migao.config.response.ResponseBean;
  13. import com.migao.config.response.ResponseBuilder;
  14. import com.migao.entity.po.Project;
  15. import com.migao.entity.po.ProjectDemand;
  16. import com.migao.entity.po.ProjectFile;
  17. import com.migao.entity.po.PurchasingApproval;
  18. import com.migao.entity.vo.req.ProjectPageQueryReq;
  19. import com.migao.entity.vo.req.PurchasingApprovalPageQueryReq;
  20. import com.migao.entity.vo.res.ProjectQueryRes;
  21. import com.migao.entity.vo.res.PurchasingApprovalQueryRes;
  22. import com.migao.mapper.ProjectDemandMapper;
  23. import com.migao.mapper.ProjectFileMapper;
  24. import com.migao.mapper.ProjectMapper;
  25. import com.migao.mapper.PurchasingApprovalMapper;
  26. import com.migao.service.ProjectService;
  27. import com.migao.service.PurchasingApprovalService;
  28. import com.migao.util.EntityUtils;
  29. import lombok.extern.slf4j.Slf4j;
  30. import org.apache.commons.lang3.StringUtils;
  31. import org.springframework.stereotype.Service;
  32. import org.springframework.transaction.annotation.Transactional;
  33. import javax.annotation.Resource;
  34. import java.util.ArrayList;
  35. import java.util.List;
  36. /**
  37. * @author dingsong
  38. */
  39. @Slf4j
  40. @Service
  41. @Transactional(rollbackFor = {Exception.class})
  42. public class PurchasingApprovalServiceImpl extends ServiceImpl<PurchasingApprovalMapper, PurchasingApproval> implements PurchasingApprovalService {
  43. @Resource
  44. private ProjectMapper projectMapper;
  45. @Resource
  46. private PurchasingApprovalMapper purchasingApprovalMapper;
  47. @Resource
  48. private ProjectDemandMapper projectDemandMapper;
  49. @Resource
  50. private ProjectFileMapper projectFileMapper;
  51. @Override
  52. public ResponseBean<PageBean<ProjectQueryRes>> pageQuery(PurchasingApprovalPageQueryReq purchasingApprovalPageQueryReq) {
  53. Integer page = purchasingApprovalPageQueryReq.getPage();
  54. page = page == null ? 1 : page <= 0 ? 1 : page;
  55. Integer size = purchasingApprovalPageQueryReq.getSize();
  56. size = size == null ? 10 : size <= 0 ? 10 : size;
  57. LambdaQueryWrapper<Project> queryWrapper = new LambdaQueryWrapper<>();
  58. if (purchasingApprovalPageQueryReq.getCreateTime() != null) {
  59. }
  60. if (StringUtils.isNotBlank(purchasingApprovalPageQueryReq.getName())) {
  61. queryWrapper.eq(Project::getCreateTime, purchasingApprovalPageQueryReq.getCreateTime());
  62. }
  63. if (StringUtils.isNotBlank(purchasingApprovalPageQueryReq.getOrderStatus())) {
  64. queryWrapper.eq(Project::getOrderStatus, purchasingApprovalPageQueryReq.getOrderStatus());
  65. }
  66. queryWrapper.ne(Project::getParentId, 0);
  67. //查询子项目并且采购状态是待提报
  68. queryWrapper.eq(Project::getPurchaseStatus, ProjectStatus.TO_BE_REPORTED);
  69. Page<Project> all = projectMapper.selectPage(new Page<>(page, size), queryWrapper);
  70. return ResponseBuilder.ok(
  71. all,
  72. element -> {
  73. ProjectQueryRes projectQueryRes = ProjectQueryRes
  74. .builder()
  75. .id(element.getId())
  76. .capital(String.valueOf(element.getCapital()))
  77. .content(element.getContent())
  78. .cost(String.valueOf(element.getCost()))
  79. .createTime(element.getCreateTime())
  80. .level(element.getLevel())
  81. .name(element.getName())
  82. .progress(element.getProgress())
  83. .projectClassify(element.getProjectClassify())
  84. .specialtyClassify(element.getSpecialtyClassify())
  85. .total(String.valueOf(element.getTotal()))
  86. .totalInvestment(String.valueOf(element.getTotalInvestment()))
  87. .twoClassify(element.getTwoClassify())
  88. .unit(element.getUnit())
  89. .orderStatus(String.valueOf(element.getOrderStatus()))
  90. .reserveStatus(String.valueOf(element.getReserveStatus()))
  91. .build();
  92. return projectQueryRes;
  93. }
  94. );
  95. }
  96. @Override
  97. public ResponseBean<?> submit(Integer projectId, List<Integer> demandIdList) {
  98. Project project = projectMapper.selectById(projectId);
  99. if (project == null) {
  100. return ResponseBuilder.fail("项目不存在");
  101. }
  102. //绑定项目和需求
  103. for (Integer id : demandIdList) {
  104. ProjectDemand projectDemand = new ProjectDemand();
  105. projectDemand.setProjectrId(projectId);
  106. projectDemand.setDemandId(id);
  107. projectDemandMapper.insert(projectDemand);
  108. }
  109. //更新项目状态
  110. project.setPurchaseStatus(ProjectStatus.TO_APPROVAL.getName());
  111. projectMapper.updateById(project);
  112. //新增采购记录
  113. PurchasingApproval purchasingApproval=new PurchasingApproval();
  114. purchasingApproval.setDeleted(0);
  115. purchasingApproval.setProjectId(projectId);
  116. purchasingApproval.setStatus(ProjectStatus.TO_BE_REPORTED.getName());
  117. purchasingApproval.setStage(PurchasingStage.SUBMIT.getName());
  118. purchasingApprovalMapper.insert(purchasingApproval);
  119. return ResponseBuilder.ok();
  120. }
  121. @Override
  122. public ResponseBean<?> approve(Integer id,ExamineStatus status) {
  123. Project project = projectMapper.selectById(id);
  124. if (project == null) {
  125. ResponseBuilder.fail("项目不存在");
  126. }
  127. if (status.equals(FinancesStatus.PASS)) {
  128. project.setPurchaseStatus(ProjectStatus.APPROVE.getName());
  129. projectMapper.updateById(project);
  130. //新增采购记录
  131. PurchasingApproval purchasingApproval=new PurchasingApproval();
  132. purchasingApproval.setDeleted(0);
  133. purchasingApproval.setProjectId(id);
  134. purchasingApproval.setStatus(ProjectStatus.TO_APPROVAL.getName());
  135. purchasingApproval.setStage(PurchasingStage.EXAMINE.getName());
  136. purchasingApprovalMapper.insert(purchasingApproval);
  137. }else {
  138. project.setPurchaseStatus(ProjectStatus.TO_BE_REPORTED.getName());
  139. projectMapper.updateById(project);
  140. }
  141. return ResponseBuilder.ok();
  142. }
  143. @Override
  144. public ResponseBean<?> transmit(Integer projectId, String email, String company) {
  145. Project project = projectMapper.selectById(projectId);
  146. if (project == null) {
  147. ResponseBuilder.fail("项目不存在");
  148. }
  149. project.setPurchaseStatus(ProjectStatus.HAS_ORDERED.getName());
  150. projectMapper.updateById(project);
  151. PurchasingApproval purchasingApproval = PurchasingApproval.builder()
  152. .deleted(0)
  153. .projectId(projectId)
  154. .email(email)
  155. .company(company)
  156. .status(ProjectStatus.HAS_ORDERED.getName())
  157. .build();
  158. purchasingApprovalMapper.insert(purchasingApproval);
  159. return ResponseBuilder.ok();
  160. }
  161. @Override
  162. public ResponseBean<?> contractEntry(Integer projectId, Integer fileId) {
  163. ProjectFile projectFile= ProjectFile.builder()
  164. .projectId(projectId)
  165. .fileId(fileId)
  166. .build();
  167. projectFileMapper.insert(projectFile);
  168. //新增采购记录
  169. PurchasingApproval purchasingApproval=new PurchasingApproval();
  170. purchasingApproval.setDeleted(0);
  171. purchasingApproval.setProjectId(projectId);
  172. purchasingApproval.setStatus(ProjectStatus.CONTRACT_ENTRY.getName());
  173. purchasingApproval.setStage(ProjectStatus.CONTRACT_ENTRY.getName());
  174. purchasingApprovalMapper.insert(purchasingApproval);
  175. return ResponseBuilder.ok();
  176. }
  177. @Override
  178. public ResponseBean<List<PurchasingApprovalQueryRes>> findById(Integer id) {
  179. LambdaQueryWrapper<PurchasingApproval> queryWrapper=new LambdaQueryWrapper<>();
  180. queryWrapper.eq(PurchasingApproval::getProjectId,id);
  181. List<PurchasingApproval> all = purchasingApprovalMapper.selectList(queryWrapper);
  182. List<PurchasingApprovalQueryRes> list=new ArrayList<>();
  183. for (PurchasingApproval approval : all) {
  184. PurchasingApprovalQueryRes res = EntityUtils.copyProperties(approval, PurchasingApprovalQueryRes.class);
  185. list.add(res);
  186. }
  187. return ResponseBuilder.ok(list);
  188. }
  189. }