MonthlyReconciliationController.java 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. package com.ozs.web.controller.plan;
  2. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  3. import com.baomidou.mybatisplus.core.metadata.IPage;
  4. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  5. import com.ozs.base.domain.BaseNoticeType;
  6. import com.ozs.base.vo.BasePolicyPageReqVo;
  7. import com.ozs.common.annotation.Log;
  8. import com.ozs.common.constant.Constants;
  9. import com.ozs.common.constant.ModularConstans;
  10. import com.ozs.common.core.controller.BaseController;
  11. import com.ozs.common.core.domain.AjaxResult;
  12. import com.ozs.common.core.domain.entity.SysDept;
  13. import com.ozs.common.core.domain.entity.SysDictData;
  14. import com.ozs.common.core.domain.entity.SysRole;
  15. import com.ozs.common.enums.BusinessType;
  16. import com.ozs.common.enums.SysFileRefEnum;
  17. import com.ozs.plan.doman.MonthlyReconciliation;
  18. import com.ozs.plan.doman.vo.requestVo.MonthlyReconciliationPageReqVo;
  19. import com.ozs.plan.service.MonthlyReconciliationService;
  20. import com.ozs.system.domain.SysFileInfo;
  21. import com.ozs.system.domain.SysFileRef;
  22. import com.ozs.system.domain.vo.responseVo.SysDeptResponseVo;
  23. import com.ozs.system.service.ISysDeptService;
  24. import com.ozs.system.service.ISysDictTypeService;
  25. import com.ozs.system.service.SysFileRefService;
  26. import com.ozs.system.service.SysFileService;
  27. import io.swagger.annotations.Api;
  28. import io.swagger.annotations.ApiOperation;
  29. import org.apache.commons.lang3.StringUtils;
  30. import org.springframework.beans.factory.annotation.Autowired;
  31. import org.springframework.security.access.prepost.PreAuthorize;
  32. import org.springframework.util.ObjectUtils;
  33. import org.springframework.web.bind.annotation.*;
  34. import javax.validation.constraints.NotEmpty;
  35. import java.util.Arrays;
  36. import java.util.List;
  37. import java.util.Map;
  38. import java.util.stream.Collectors;
  39. @RestController
  40. @RequestMapping("/monthly/reconciliation")
  41. @Api(tags = ModularConstans.monthly)
  42. public class MonthlyReconciliationController extends BaseController {
  43. @Autowired
  44. private MonthlyReconciliationService monthlyReconciliationService;
  45. @Autowired
  46. private SysFileRefService sysFileRefService;
  47. @Autowired
  48. private SysFileService sysFileService;
  49. @Autowired
  50. private ISysDeptService iSysDeptService;
  51. @Autowired
  52. private ISysDictTypeService dictTypeService;
  53. @ApiOperation(value = "分页查询月度对表")
  54. @PostMapping("/page")
  55. @PreAuthorize("@ss.hasPermi('base:monthly:list')")
  56. @Log(title = ModularConstans.monthly, businessType = BusinessType.QUERY)
  57. public AjaxResult page(@NotEmpty(message = "数据为空")
  58. @RequestBody MonthlyReconciliationPageReqVo vo) {
  59. LambdaQueryWrapper<MonthlyReconciliation> lw = new LambdaQueryWrapper<>();
  60. if (!StringUtils.isBlank(vo.getProjectName())) {
  61. lw.like(MonthlyReconciliation::getProjectName, vo.getProjectName());
  62. }
  63. if (!ObjectUtils.isEmpty(vo.getProjectStatus())) {
  64. lw.eq(MonthlyReconciliation::getProjectStatus, vo.getProjectStatus());
  65. }
  66. if (!StringUtils.isBlank(vo.getPurchaseServices())) {
  67. lw.eq(MonthlyReconciliation::getPurchaseServices, vo.getPurchaseServices());
  68. }
  69. if (!ObjectUtils.isEmpty(vo.getStartTime())) {
  70. lw.ge(MonthlyReconciliation::getPlanDemandSubTime, vo.getStartTime());
  71. }
  72. if (!ObjectUtils.isEmpty(vo.getStartTime())) {
  73. lw.le(MonthlyReconciliation::getPlanDemandSubTime, vo.getEntTime());
  74. }
  75. if (!StringUtils.isBlank(vo.getWarnStatus())) {
  76. lw.eq(MonthlyReconciliation::getWarnStatus, vo.getWarnStatus());
  77. }
  78. // 添加数据权限
  79. List<String> roleKeys = getLoginUser().getUser().getRoles().stream().map(SysRole::getRoleKey).collect(Collectors.toList());
  80. if (roleKeys.contains(Constants.DEMAND_UNIT)) {
  81. // 需求单位
  82. /*(purchase_dept_id = 当前用户deptID) */
  83. lw.eq(MonthlyReconciliation::getPurchaseDeptId, getDeptId());
  84. } else if (roleKeys.contains(Constants.PURCHASING_MANAGEMENT)
  85. || roleKeys.contains(Constants.PURCHASE_SERVICES)) {
  86. // 采购管理部门 或 采购办
  87. SysDept sysDept = new SysDept();
  88. sysDept.setParentId(getDeptId());
  89. sysDept.setStatus("0");
  90. List<Long> childDeptIds = iSysDeptService.selectDeptList(sysDept)
  91. .stream()
  92. .map(SysDept::getDeptId)
  93. .collect(Collectors.toList());
  94. if(ObjectUtils.isEmpty(childDeptIds)){
  95. lw.and((wrapper) -> {
  96. wrapper.eq(MonthlyReconciliation::getIsExcess, 0);
  97. wrapper.eq(MonthlyReconciliation::getPurchaseDeptId, getDeptId());
  98. });
  99. }else {
  100. lw.and((wrapper) -> {
  101. wrapper.eq(MonthlyReconciliation::getIsExcess, 0);
  102. wrapper.eq(MonthlyReconciliation::getPurchaseDeptId, getDeptId());
  103. })
  104. .or((wrapper) -> {
  105. wrapper.eq(MonthlyReconciliation::getIsExcess, 1);
  106. wrapper.in(MonthlyReconciliation::getPurchaseDeptId, childDeptIds);
  107. });
  108. }
  109. }
  110. // 分页查询
  111. IPage<MonthlyReconciliation> page = monthlyReconciliationService.page(new Page<>(vo.getPageNum(), vo.getPageSize()), lw);
  112. if (!ObjectUtils.isEmpty(page.getRecords()) && page.getRecords().size() > 0) {
  113. page.setRecords(page.getRecords().stream().map(dto -> {
  114. // 采购单位名称
  115. Map<String, Object> stringObjectMap = iSysDeptService.selectDeptById(dto.getPurchaseDeptId());
  116. if (!ObjectUtils.isEmpty(stringObjectMap)) {
  117. SysDeptResponseVo sysDept = (SysDeptResponseVo) stringObjectMap.get("sysDept");
  118. dto.setPurchaseDeptName(sysDept.getDeptName());
  119. }
  120. // todo 采购服务站名称 要修改为单位管理里面的
  121. // List<SysDictData> data = dictTypeService.selectDictDataByType(Constants.PURCHASE_SERVICES);
  122. // if (!ObjectUtils.isEmpty(data)) {
  123. // List<SysDictData> collect = data.stream()
  124. // .filter(d -> d.getDictValue().equals(dto.getPurchaseServices())).collect(Collectors.toList());
  125. // if (!ObjectUtils.isEmpty(collect)) {
  126. // dto.setPurchaseServicesName(collect.get(0).getDictLabel());
  127. // }
  128. // }
  129. // 项目状态
  130. List<SysDictData> projectStatus = dictTypeService.selectDictDataByType(Constants.SYS_PROJECT_STATUS);
  131. if (!ObjectUtils.isEmpty(projectStatus)) {
  132. List<SysDictData> collect = projectStatus.stream()
  133. .filter(d -> d.getDictValue().equals(dto.getProjectStatus())).collect(Collectors.toList());
  134. if (!ObjectUtils.isEmpty(collect)) {
  135. dto.setProjectStatusStr(collect.get(0).getDictLabel());
  136. }
  137. }
  138. // 报警状态
  139. List<SysDictData> warnStatus = dictTypeService.selectDictDataByType(Constants.PROJECT_WARN_STATUS);
  140. if (!ObjectUtils.isEmpty(warnStatus)) {
  141. List<SysDictData> collect = warnStatus.stream()
  142. .filter(d -> d.getDictValue().equals(dto.getWarnStatus())).collect(Collectors.toList());
  143. if (!ObjectUtils.isEmpty(collect)) {
  144. dto.setWarnStatusStr(collect.get(0).getDictLabel());
  145. }
  146. }
  147. return dto;
  148. }).collect(Collectors.toList()));
  149. }
  150. return success(page);
  151. }
  152. @ApiOperation(value = "查看月度对表详情")
  153. @PostMapping("/getInfo")
  154. @PreAuthorize("@ss.hasPermi('base:monthly:query')")
  155. @Log(title = ModularConstans.monthly, businessType = BusinessType.QUERY)
  156. public AjaxResult getInfo(@NotEmpty(message = "主键id不能为空")
  157. @RequestParam(value = "id", required = true)
  158. Long id) {
  159. MonthlyReconciliation vo = monthlyReconciliationService.getById(id);
  160. if (!ObjectUtils.isEmpty(vo)) {
  161. LambdaQueryWrapper<SysFileRef> lw = new LambdaQueryWrapper();
  162. lw.eq(SysFileRef::getType, SysFileRefEnum.PLAN_TEMPORARY.getType());
  163. lw.eq(SysFileRef::getRedId, vo.getPlanId());
  164. List<SysFileRef> list = sysFileRefService.list(lw);
  165. if (!ObjectUtils.isEmpty(list)) {
  166. LambdaQueryWrapper<SysFileInfo> l = new LambdaQueryWrapper();
  167. l.in(SysFileInfo::getFileId, list.stream().map(SysFileRef::getFileId).collect(Collectors.toList()));
  168. vo.setFileList(sysFileService.list(l));
  169. }
  170. Map<String, Object> stringObjectMap = iSysDeptService.selectDeptById(vo.getPurchaseDeptId());
  171. if (!ObjectUtils.isEmpty(stringObjectMap)) {
  172. SysDeptResponseVo sysDept = (SysDeptResponseVo) stringObjectMap.get("sysDept");
  173. vo.setPurchaseDeptName(sysDept.getDeptName());
  174. }
  175. // 采购服务站名称
  176. List<SysDictData> data = dictTypeService.selectDictDataByType("purchase_services");
  177. if (!ObjectUtils.isEmpty(data)) {
  178. List<SysDictData> collect = data.stream()
  179. .filter(d -> d.getDictValue().equals(vo.getPurchaseServices())).collect(Collectors.toList());
  180. if (!ObjectUtils.isEmpty(collect)) {
  181. vo.setPurchaseServicesName(collect.get(0).getDictLabel());
  182. }
  183. }
  184. }
  185. return success(vo);
  186. }
  187. @ApiOperation(value = "根据项目名称模糊查询项目信息")
  188. @PostMapping("/listProjectInfoLikeName")
  189. @Log(title = ModularConstans.monthly, businessType = BusinessType.QUERY)
  190. public AjaxResult listProjectInfoLikeName(@NotEmpty(message = "数据为空")
  191. @RequestBody BasePolicyPageReqVo vo) {
  192. LambdaQueryWrapper<MonthlyReconciliation> lw = new LambdaQueryWrapper<>();
  193. if (!StringUtils.isBlank(vo.getName())) {
  194. lw.like(MonthlyReconciliation::getProjectName, vo.getName());
  195. }
  196. return success(monthlyReconciliationService.list(lw));
  197. }
  198. }