ProvisionalPlanController.java 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. package com.ozs.web.controller.plan;
  2. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  3. import com.ozs.common.annotation.Log;
  4. import com.ozs.common.constant.ModularConstans;
  5. import com.ozs.common.core.controller.BaseController;
  6. import com.ozs.common.core.domain.AjaxResult;
  7. import com.ozs.common.core.domain.model.LoginUser;
  8. import com.ozs.common.enums.BusinessType;
  9. import com.ozs.common.enums.SysFileRefEnum;
  10. import com.ozs.common.exception.ServiceException;
  11. import com.ozs.common.utils.PageUtils;
  12. import com.ozs.common.utils.StringUtils;
  13. import com.ozs.common.utils.file.FileUtils;
  14. import com.ozs.common.utils.poi.ExcelUtil;
  15. import com.ozs.framework.web.service.TokenService;
  16. import com.ozs.plan.doman.ProvisionalPlan;
  17. import com.ozs.plan.doman.vo.requestVo.ProvisionalPlanVo;
  18. import com.ozs.plan.doman.vo.responseVo.ProvisionalPlanResVo;
  19. import com.ozs.plan.service.ProvisionalPlanService;
  20. import com.ozs.plan.service.impl.ProvisionalPlanServiceImpl;
  21. import com.ozs.system.domain.SysFileRef;
  22. import com.ozs.system.service.SysFileRefService;
  23. import io.swagger.annotations.Api;
  24. import io.swagger.annotations.ApiOperation;
  25. import lombok.extern.slf4j.Slf4j;
  26. import org.springframework.beans.factory.annotation.Autowired;
  27. import org.springframework.http.MediaType;
  28. import org.springframework.security.access.prepost.PreAuthorize;
  29. import org.springframework.util.ObjectUtils;
  30. import org.springframework.web.bind.annotation.GetMapping;
  31. import org.springframework.web.bind.annotation.PostMapping;
  32. import org.springframework.web.bind.annotation.RequestBody;
  33. import org.springframework.web.bind.annotation.RequestMapping;
  34. import org.springframework.web.bind.annotation.RestController;
  35. import org.springframework.web.multipart.MultipartFile;
  36. import javax.servlet.http.HttpServletRequest;
  37. import javax.servlet.http.HttpServletResponse;
  38. import java.io.InputStream;
  39. import java.util.ArrayList;
  40. import java.util.Date;
  41. import java.util.List;
  42. /**
  43. * 临时计划
  44. *
  45. * @author sunhh
  46. */
  47. @Api(tags = "临时计划")
  48. @Slf4j
  49. @RestController
  50. @RequestMapping("/plan/provisionalPlan")
  51. public class ProvisionalPlanController extends BaseController {
  52. @Autowired
  53. private ProvisionalPlanService provisionalPlanService;
  54. @Autowired
  55. private ProvisionalPlanServiceImpl provisionalPlanServiceImpl;
  56. @Autowired
  57. private TokenService tokenService;
  58. @Autowired
  59. private SysFileRefService sysFileRefService;
  60. @ApiOperation(value = "新增临时计划")
  61. @PostMapping("/insertProvisionalPlan")
  62. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:insertProvisionalPlan')")
  63. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.INSERT)
  64. public AjaxResult insertProvisionalPlan(@RequestBody ProvisionalPlan provisionalPlan, HttpServletRequest request) {
  65. //获取采购单位
  66. LoginUser loginUser = tokenService.getLoginUser(request);
  67. provisionalPlan.setPurchaseDeptId(String.valueOf(loginUser.getDeptId()));
  68. provisionalPlan.setCreated(String.valueOf(loginUser.getUserId()));
  69. provisionalPlan.setCreateTime(new Date());
  70. //默认未超额
  71. if (ObjectUtils.isEmpty(provisionalPlan.getIsExcess())) {
  72. provisionalPlan.setIsExcess("0");
  73. }
  74. // planType计划类型(0:季度计划,1:临时计划)
  75. provisionalPlan.setPlanType("1");
  76. // 项目状态(0:计划待提交,1:计划待审核,2:计划已退回,3:计划已审核)
  77. provisionalPlan.setProjectStatus("0");
  78. // 计算是否超限额计划 *** 改为前端录入
  79. // provisionalPlan.setIsExcess(iSysDeptService.isExcessOrNo(provisionalPlan.getProjectType(), provisionalPlan.getEvaluation(), Long.valueOf(provisionalPlan.getPurchaseDeptId())));
  80. boolean save = provisionalPlanService.save(provisionalPlan);
  81. log.info("provisionalPlan的主键id:{}", provisionalPlan.getPlanPracticalId());
  82. List<SysFileRef> sysFileRefs = provisionalPlan.getSysFileRefs();
  83. if (!ObjectUtils.isEmpty(sysFileRefs)) {
  84. if (save) {
  85. for (SysFileRef ref : sysFileRefs) {
  86. ref.setRedId(provisionalPlan.getPlanPracticalId());
  87. ref.setType(SysFileRefEnum.PLAN_TEMPORARY.getType());
  88. ref.setCreated(provisionalPlan.getCreated());
  89. ref.setCreateTime(new Date());
  90. ref.setUpdated(provisionalPlan.getCreated());
  91. ref.setUpdateTime(new Date());
  92. sysFileRefService.save(ref);
  93. }
  94. }
  95. }
  96. return toAjax(save);
  97. }
  98. @ApiOperation(value = "删除临时计划", notes = "必传 plan_practical_id")
  99. @PostMapping("/deleteProvisionalPlan")
  100. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:deleteProvisionalPlan')")
  101. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.DELETE)
  102. public AjaxResult deleteProvisionalPlan(@RequestBody ProvisionalPlan provisionalPlan) {
  103. if (StringUtils.isNull(provisionalPlan) || StringUtils.isNull(provisionalPlan.getPlanPracticalId())) {
  104. return error("临时计划id不能为空");
  105. }
  106. return toAjax(provisionalPlanService.deleteProvisionalPlanById(provisionalPlan.getPlanPracticalId()));
  107. }
  108. @ApiOperation(value = "修改临时计划", notes = "必传 plan_year_id 及修改数据")
  109. @PostMapping("/updateProvisionalPlan")
  110. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:updateProvisionalPlan')")
  111. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  112. public AjaxResult updateProvisionalPlan(@RequestBody ProvisionalPlanVo provisionalPlan) {
  113. if (StringUtils.isNull(provisionalPlan) || StringUtils.isNull(provisionalPlan.getPlanPracticalId())) {
  114. return error("临时计划id和修改数据不能为空");
  115. }
  116. log.info(":{}", provisionalPlan);
  117. // 计算是否超限额计划 *** 改为前端录入
  118. // provisionalPlan.setIsExcess(iSysDeptService.isExcessOrNo(provisionalPlan.getProjectType(), provisionalPlan.getEvaluation(), getDeptId()));
  119. return toAjax(provisionalPlanService.updateProvisionalPlanById(provisionalPlan));
  120. }
  121. @ApiOperation(value = "查询临时计划")
  122. @PostMapping("/selectProvisionalPlan")
  123. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectProvisionalPlan')")
  124. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
  125. public AjaxResult selectProvisionalPlan(@RequestBody ProvisionalPlanVo vo, HttpServletRequest request) {
  126. if (StringUtils.isNull(vo)
  127. || StringUtils.isNull(vo.getPageNum())
  128. || StringUtils.isNull(vo.getPageSize())) {
  129. throw new ServiceException("分页参数不能为空!");
  130. }
  131. LoginUser loginUser = tokenService.getLoginUser(request);
  132. return provisionalPlanService.selectProvisionalPlan(vo, request, loginUser);
  133. }
  134. @ApiOperation(value = "查询临时计划-审核单位")
  135. @PostMapping("/selectProvisionalPlanAudit")
  136. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectProvisionalPlanAudit')")
  137. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
  138. public AjaxResult selectProvisionalPlanAudit(@RequestBody ProvisionalPlanVo vo, HttpServletRequest request) {
  139. List<ProvisionalPlanResVo> provisionalPlanList = new ArrayList<>();
  140. if (StringUtils.isNull(vo)
  141. || StringUtils.isNull(vo.getPageNum())
  142. || StringUtils.isNull(vo.getPageSize())) {
  143. throw new ServiceException("分页参数不能为空!");
  144. }
  145. try {
  146. LoginUser loginUser = tokenService.getLoginUser(request);
  147. vo.setCreated(String.valueOf(loginUser.getUserId()));
  148. vo.setPurchaseDeptId(loginUser.getDeptId());
  149. List<ProvisionalPlan> provisionalPlans = provisionalPlanService.queryPage(vo);
  150. if (!ObjectUtils.isEmpty(provisionalPlans) && !ObjectUtils.isEmpty(provisionalPlans.size())) {
  151. provisionalPlanList = provisionalPlanServiceImpl.changeTo(provisionalPlans);
  152. }
  153. } catch (Exception e) {
  154. e.printStackTrace();
  155. }
  156. Page pages = PageUtils.getPages(vo.getPageNum().intValue(), vo.getPageSize().intValue(), provisionalPlanList);
  157. return AjaxResult.success(pages);
  158. }
  159. @ApiOperation(value = "查询临时计划详情")
  160. @PostMapping("/selectById")
  161. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectById')")
  162. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
  163. public AjaxResult selectById(@RequestBody ProvisionalPlanVo provisionalPlanVo) {
  164. if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
  165. throw new ServiceException("id不能为空!");
  166. }
  167. return provisionalPlanService.seletById(provisionalPlanVo.getPlanPracticalId());
  168. }
  169. @ApiOperation(value = "导入临时计划")
  170. @PostMapping("/importProvisionalPlan")
  171. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:importProvisionalPlan')")
  172. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.INSERT)
  173. public AjaxResult importProvisionalPlan(MultipartFile file, boolean updateSupport) throws Exception {
  174. ExcelUtil<ProvisionalPlan> util = new ExcelUtil<>(ProvisionalPlan.class);
  175. List<ProvisionalPlan> provisionalPlans = util.importExcel(file.getInputStream());
  176. if (StringUtils.isNull(provisionalPlans) || provisionalPlans.size() == 0) {
  177. throw new ServiceException("导入临时计划数据不能为空!");
  178. }
  179. //获取采购单位-
  180. LoginUser loginUser = getLoginUser();
  181. String message = provisionalPlanService.importProvisionalPlan(provisionalPlans, updateSupport, loginUser);
  182. return success(message);
  183. }
  184. @ApiOperation(value = "导出临时计划")
  185. @PostMapping("/exportProvisionalPlan")
  186. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:exportProvisionalPlan')")
  187. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.EXPORT)
  188. public void exportProvisionalPlan(HttpServletResponse response, @RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) throws Exception {
  189. LoginUser loginUser = tokenService.getLoginUser(request);
  190. List<ProvisionalPlanResVo> list = provisionalPlanService.selectProvisionalPlanExport(provisionalPlanVo, loginUser);
  191. ExcelUtil<ProvisionalPlanResVo> util = new ExcelUtil<>(ProvisionalPlanResVo.class);
  192. util.exportExcel(response, list, "临时计划数据");
  193. }
  194. @ApiOperation(value = "提交临时计划")
  195. @PostMapping("/commitProvisionalPlan")
  196. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:commitProvisionalPlan')")
  197. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  198. public AjaxResult commitProvisionalPlan(@RequestBody ProvisionalPlanVo provisionalPlanVo) {
  199. if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
  200. return error("提交的临时计划ID不能为空!");
  201. }
  202. return toAjax(provisionalPlanService.commitProvisionalPlan(provisionalPlanVo));
  203. }
  204. @ApiOperation(value = "审核通过")
  205. @PostMapping("/auditPass")
  206. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:auditPass')")
  207. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  208. public AjaxResult auditPass(@RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) {
  209. if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
  210. return error("审核数据ID不能为空!");
  211. }
  212. LoginUser loginUser = tokenService.getLoginUser(request);
  213. provisionalPlanVo.setUpdated(String.valueOf(loginUser.getUserId()));
  214. return provisionalPlanService.auditPass(provisionalPlanVo);
  215. }
  216. @ApiOperation(value = "审核不通过")
  217. @PostMapping("/auditNoPass")
  218. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:auditNoPass')")
  219. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  220. public AjaxResult auditNoPass(@RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) {
  221. if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
  222. return error("审核数据ID不能为空!");
  223. }
  224. LoginUser loginUser = tokenService.getLoginUser(request);
  225. provisionalPlanVo.setUpdated(String.valueOf(loginUser.getUserId()));
  226. return provisionalPlanService.auditNoPass(provisionalPlanVo);
  227. }
  228. @ApiOperation("模板下载")
  229. @GetMapping("/downloaExcel")
  230. public void downloadZip(HttpServletResponse response) {
  231. try {
  232. InputStream resourceAsStream = this.getClass().getResourceAsStream("/template/provisionalPlan.xlsx");
  233. response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);
  234. FileUtils.setAttachmentResponseHeader(response, "临时计划导入模板.xlsx");
  235. FileUtils.writeBytesByInput(resourceAsStream, response.getOutputStream());
  236. } catch (Exception e) {
  237. log.error("下载文件失败", e);
  238. }
  239. }
  240. }