ProvisionalPlanController.java 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313
  1. package com.ozs.web.controller.plan;
  2. import com.alibaba.excel.EasyExcel;
  3. import com.alibaba.excel.ExcelWriter;
  4. import com.alibaba.excel.write.metadata.WriteSheet;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import com.ozs.common.annotation.Log;
  7. import com.ozs.common.constant.ModularConstans;
  8. import com.ozs.common.core.controller.BaseController;
  9. import com.ozs.common.core.domain.AjaxResult;
  10. import com.ozs.common.core.domain.model.LoginUser;
  11. import com.ozs.common.enums.BusinessType;
  12. import com.ozs.common.enums.SysFileRefEnum;
  13. import com.ozs.common.exception.ServiceException;
  14. import com.ozs.common.exception.base.BaseException;
  15. import com.ozs.common.utils.PageUtils;
  16. import com.ozs.common.utils.StringUtils;
  17. import com.ozs.common.utils.file.FileUtils;
  18. import com.ozs.common.utils.poi.ExcelUtil;
  19. import com.ozs.framework.web.service.TokenService;
  20. import com.ozs.plan.doman.ProvisionalPlan;
  21. import com.ozs.plan.doman.vo.requestVo.PlanYearsStandardVo;
  22. import com.ozs.plan.doman.vo.requestVo.ProvisionalPlanVo;
  23. import com.ozs.plan.doman.vo.responseVo.ProvisionalPlanResVo;
  24. import com.ozs.plan.service.ProvisionalPlanService;
  25. import com.ozs.plan.service.impl.ProvisionalPlanServiceImpl;
  26. import com.ozs.system.domain.SysFileRef;
  27. import com.ozs.system.service.SysFileRefService;
  28. import io.swagger.annotations.Api;
  29. import io.swagger.annotations.ApiOperation;
  30. import lombok.extern.slf4j.Slf4j;
  31. import org.springframework.beans.factory.annotation.Autowired;
  32. import org.springframework.http.MediaType;
  33. import org.springframework.security.access.prepost.PreAuthorize;
  34. import org.springframework.util.ObjectUtils;
  35. import org.springframework.web.bind.annotation.GetMapping;
  36. import org.springframework.web.bind.annotation.PostMapping;
  37. import org.springframework.web.bind.annotation.RequestBody;
  38. import org.springframework.web.bind.annotation.RequestMapping;
  39. import org.springframework.web.bind.annotation.RestController;
  40. import org.springframework.web.multipart.MultipartFile;
  41. import javax.servlet.http.HttpServletRequest;
  42. import javax.servlet.http.HttpServletResponse;
  43. import java.io.InputStream;
  44. import java.io.OutputStream;
  45. import java.math.BigDecimal;
  46. import java.net.URLEncoder;
  47. import java.util.ArrayList;
  48. import java.util.Date;
  49. import java.util.List;
  50. /**
  51. * 临时计划
  52. *
  53. * @author sunhh
  54. */
  55. @Api(tags = "临时计划")
  56. @Slf4j
  57. @RestController
  58. @RequestMapping("/plan/provisionalPlan")
  59. public class ProvisionalPlanController extends BaseController {
  60. @Autowired
  61. private ProvisionalPlanService provisionalPlanService;
  62. @Autowired
  63. private ProvisionalPlanServiceImpl provisionalPlanServiceImpl;
  64. @Autowired
  65. private TokenService tokenService;
  66. @Autowired
  67. private SysFileRefService sysFileRefService;
  68. @ApiOperation(value = "新增临时计划")
  69. @PostMapping("/insertProvisionalPlan")
  70. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:insertProvisionalPlan')")
  71. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.INSERT)
  72. public AjaxResult insertProvisionalPlan(@RequestBody ProvisionalPlan provisionalPlan, HttpServletRequest request) {
  73. //年度中已存在的不能再使用(临时审核通过后会进行同步到年度计划)
  74. if (provisionalPlanService.countYearProjectName(provisionalPlan.getProjectName()) > 0) {
  75. return AjaxResult.error("该项目名称已经使用。");
  76. }
  77. if (provisionalPlanService.countProjectName(provisionalPlan.getProjectName()) > 0) {
  78. return AjaxResult.error("该项目名称已经使用。");
  79. }
  80. //获取采购单位
  81. LoginUser loginUser = tokenService.getLoginUser(request);
  82. provisionalPlan.setPurchaseDeptId(String.valueOf(loginUser.getDeptId()));
  83. provisionalPlan.setCreated(String.valueOf(loginUser.getUserId()));
  84. provisionalPlan.setCreateTime(new Date());
  85. //默认未超额
  86. if (ObjectUtils.isEmpty(provisionalPlan.getIsExcess())) {
  87. provisionalPlan.setIsExcess("0");
  88. }
  89. // planType计划类型(0:季度计划,1:临时计划)
  90. provisionalPlan.setPlanType("1");
  91. // 项目状态(0:计划待提交,1:计划待审核,2:计划已退回,3:计划已审核)
  92. provisionalPlan.setProjectStatus("0");
  93. // 发函状态(0:未发函或已处理,1:确认发函)
  94. provisionalPlan.setSendLetter("0");
  95. // 计算是否超限额计划 *** 改为前端录入
  96. boolean save = provisionalPlanService.save(provisionalPlan);
  97. List<SysFileRef> sysFileRefs = provisionalPlan.getSysFileRefs();
  98. if (!ObjectUtils.isEmpty(sysFileRefs)) {
  99. if (save) {
  100. for (SysFileRef ref : sysFileRefs) {
  101. ref.setRedId(provisionalPlan.getPlanPracticalId());
  102. ref.setType(SysFileRefEnum.PLAN_TEMPORARY.getType());
  103. ref.setCreated(provisionalPlan.getCreated());
  104. ref.setCreateTime(new Date());
  105. ref.setUpdated(provisionalPlan.getCreated());
  106. ref.setUpdateTime(new Date());
  107. sysFileRefService.save(ref);
  108. }
  109. }
  110. }
  111. return toAjax(save);
  112. }
  113. @ApiOperation(value = "删除临时计划", notes = "必传 plan_practical_id")
  114. @PostMapping("/deleteProvisionalPlan")
  115. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:deleteProvisionalPlan')")
  116. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.DELETE)
  117. public AjaxResult deleteProvisionalPlan(@RequestBody ProvisionalPlan provisionalPlan) {
  118. if (StringUtils.isNull(provisionalPlan) || StringUtils.isNull(provisionalPlan.getPlanPracticalId())) {
  119. return error("临时计划id不能为空");
  120. }
  121. return toAjax(provisionalPlanService.deleteProvisionalPlanById(provisionalPlan.getPlanPracticalId()));
  122. }
  123. @ApiOperation(value = "修改临时计划", notes = "必传 planPracticalId 及修改数据")
  124. @PostMapping("/updateProvisionalPlan")
  125. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:updateProvisionalPlan')")
  126. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  127. public AjaxResult updateProvisionalPlan(@RequestBody ProvisionalPlanVo provisionalPlan) {
  128. //年度中已存在的不能再使用(临时审核通过后会进行同步到年度计划)
  129. if (provisionalPlanService.countYearProjectName(provisionalPlan.getProjectName()) > 0) {
  130. return AjaxResult.error("该项目已同步至年度计划。");
  131. }
  132. if (provisionalPlanService.countProjectNameOth(provisionalPlan) > 0) {
  133. return AjaxResult.error("该项目名称已经使用。");
  134. }
  135. if (StringUtils.isNull(provisionalPlan) || StringUtils.isNull(provisionalPlan.getPlanPracticalId())) {
  136. return error("临时计划id和修改数据不能为空");
  137. }
  138. log.info(":{}", provisionalPlan);
  139. // 计算是否超限额计划 *** 改为前端录入
  140. // provisionalPlan.setIsExcess(iSysDeptService.isExcessOrNo(provisionalPlan.getProjectType(), provisionalPlan.getEvaluation(), getDeptId()));
  141. return toAjax(provisionalPlanService.updateProvisionalPlanById(provisionalPlan));
  142. }
  143. @ApiOperation(value = "查询临时计划")
  144. @PostMapping("/selectProvisionalPlan")
  145. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectProvisionalPlan')")
  146. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
  147. public AjaxResult selectProvisionalPlan(@RequestBody ProvisionalPlanVo vo, HttpServletRequest request) {
  148. if (StringUtils.isNull(vo)
  149. || StringUtils.isNull(vo.getPageNum())
  150. || StringUtils.isNull(vo.getPageSize())) {
  151. throw new ServiceException("分页参数不能为空!");
  152. }
  153. LoginUser loginUser = tokenService.getLoginUser(request);
  154. return provisionalPlanService.selectProvisionalPlan(vo, request, loginUser);
  155. }
  156. @ApiOperation(value = "查询临时计划-审核单位")
  157. @PostMapping("/selectProvisionalPlanAudit")
  158. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectProvisionalPlanAudit')")
  159. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
  160. public AjaxResult selectProvisionalPlanAudit(@RequestBody ProvisionalPlanVo vo, HttpServletRequest request) {
  161. List<ProvisionalPlanResVo> provisionalPlanList = new ArrayList<>();
  162. if (StringUtils.isNull(vo)
  163. || StringUtils.isNull(vo.getPageNum())
  164. || StringUtils.isNull(vo.getPageSize())) {
  165. throw new ServiceException("分页参数不能为空!");
  166. }
  167. Page pages = new Page();
  168. try {
  169. ProvisionalPlanVo standardVo = new ProvisionalPlanVo();
  170. standardVo.setPageNum(null);
  171. standardVo.setPageSize(null);
  172. LoginUser loginUser = tokenService.getLoginUser(request);
  173. standardVo.setCreated(String.valueOf(loginUser.getUserId()));
  174. standardVo.setPurchaseDeptId(loginUser.getDeptId());
  175. List<ProvisionalPlan> provisionalPlans = provisionalPlanService.queryPage(standardVo);
  176. if (!ObjectUtils.isEmpty(provisionalPlans) && !ObjectUtils.isEmpty(provisionalPlans.size())) {
  177. provisionalPlanList = provisionalPlanServiceImpl.changeTo(provisionalPlans);
  178. pages = PageUtils.getPages(vo.getPageNum().intValue(), vo.getPageSize().intValue(), provisionalPlanList);
  179. }
  180. } catch (Exception e) {
  181. e.printStackTrace();
  182. }
  183. return AjaxResult.success(pages);
  184. }
  185. @ApiOperation(value = "查询临时计划详情")
  186. @PostMapping("/selectById")
  187. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectById')")
  188. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
  189. public AjaxResult selectById(@RequestBody ProvisionalPlanVo provisionalPlanVo) {
  190. if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
  191. throw new ServiceException("id不能为空!");
  192. }
  193. return provisionalPlanService.seletById(provisionalPlanVo.getPlanPracticalId());
  194. }
  195. @ApiOperation(value = "导入临时计划")
  196. @PostMapping("/importProvisionalPlan")
  197. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:importProvisionalPlan')")
  198. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.INSERT)
  199. public AjaxResult importProvisionalPlan(MultipartFile file, boolean updateSupport) throws Exception {
  200. ExcelUtil<ProvisionalPlan> util = new ExcelUtil<>(ProvisionalPlan.class);
  201. List<ProvisionalPlan> provisionalPlans = util.importExcel(file.getInputStream(), 3);
  202. if (StringUtils.isNull(provisionalPlans) || provisionalPlans.size() == 0) {
  203. throw new ServiceException("导入临时计划数据不能为空!");
  204. }
  205. //获取采购单位-
  206. LoginUser loginUser = getLoginUser();
  207. String message = provisionalPlanService.importProvisionalPlan(provisionalPlans, updateSupport, loginUser);
  208. return success(message);
  209. }
  210. @ApiOperation(value = "导出临时计划")
  211. @PostMapping("/exportProvisionalPlan")
  212. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:exportProvisionalPlan')")
  213. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.EXPORT)
  214. public void exportProvisionalPlan(HttpServletResponse response, @RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) throws Exception {
  215. LoginUser loginUser = tokenService.getLoginUser(request);
  216. List<ProvisionalPlanResVo> list = provisionalPlanService.selectProvisionalPlanExport(provisionalPlanVo, loginUser);
  217. ExcelUtil<ProvisionalPlanResVo> util = new ExcelUtil<>(ProvisionalPlanResVo.class);
  218. util.exportExcel(response, list, "临时计划数据");
  219. }
  220. @ApiOperation(value = "提交临时计划")
  221. @PostMapping("/commitProvisionalPlan")
  222. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:commitProvisionalPlan')")
  223. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  224. public AjaxResult commitProvisionalPlan(@RequestBody ProvisionalPlanVo provisionalPlanVo) {
  225. if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
  226. return error("提交的临时计划ID不能为空!");
  227. }
  228. return toAjax(provisionalPlanService.commitProvisionalPlan(provisionalPlanVo));
  229. }
  230. @ApiOperation(value = "审核通过")
  231. @PostMapping("/auditPass")
  232. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:auditPass')")
  233. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  234. public AjaxResult auditPass(@RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) {
  235. if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
  236. return error("审核数据ID不能为空!");
  237. }
  238. LoginUser loginUser = tokenService.getLoginUser(request);
  239. provisionalPlanVo.setUpdated(String.valueOf(loginUser.getUserId()));
  240. return provisionalPlanService.auditPass(provisionalPlanVo);
  241. }
  242. @ApiOperation(value = "审核不通过")
  243. @PostMapping("/auditNoPass")
  244. @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:auditNoPass')")
  245. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  246. public AjaxResult auditNoPass(@RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) {
  247. if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
  248. return error("审核数据ID不能为空!");
  249. }
  250. LoginUser loginUser = tokenService.getLoginUser(request);
  251. provisionalPlanVo.setUpdated(String.valueOf(loginUser.getUserId()));
  252. return provisionalPlanService.auditNoPass(provisionalPlanVo);
  253. }
  254. @ApiOperation(value = "填写采购服务站")
  255. @PostMapping("/adPurchaseServices")
  256. //@PreAuthorize("@ss.hasPermi('plan:planYears:adPurchaseServices')")
  257. @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
  258. public AjaxResult adPurchaseServices(@RequestBody ProvisionalPlanVo provisionalPlanVo) {
  259. return provisionalPlanService.adPurchaseServices(provisionalPlanVo);
  260. }
  261. @ApiOperation("模板下载")
  262. @GetMapping("/downloaExcel")
  263. public void downloadZip(HttpServletResponse response) {
  264. List<ProvisionalPlanResVo> list = new ArrayList<ProvisionalPlanResVo>();
  265. list.add(new ProvisionalPlanResVo(1L, "单位1", "环太平洋项目", "物资服务类",
  266. "徒步环太平洋", new BigDecimal(12.23), "单位1,单位2", "科目一",
  267. "2023-02", "2023-03", "2023-04",
  268. "重点采购项目,重大规划任务项目", ""));
  269. list.add(new ProvisionalPlanResVo(2L, "单位2", "环北冰洋项目", "工程类",
  270. "徒步环北冰洋", new BigDecimal(15.88), "单位1", "科目二",
  271. "2023-01", "2023-05", "2023-08",
  272. "重点采购项目", ""));
  273. InputStream resourceAsStream = this.getClass().getResourceAsStream("/template/provisional_plan.xlsx");
  274. OutputStream outputStream = null;
  275. try {
  276. response.setContentType("application/vnd.ms-excel");
  277. response.setCharacterEncoding("utf-8");
  278. // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
  279. String fileName = URLEncoder.encode("临时计划(模板)", "UTF-8").replaceAll("\\+", "%20");
  280. response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
  281. outputStream = response.getOutputStream();
  282. ExcelWriter excelWriter = EasyExcel.write(outputStream)
  283. .withTemplate(resourceAsStream).autoCloseStream(true).build();
  284. WriteSheet writeSheet = EasyExcel.writerSheet().build();
  285. excelWriter.fill(list, writeSheet);
  286. excelWriter.finish();
  287. outputStream.flush();
  288. outputStream.close();
  289. } catch (Exception e) {
  290. log.error(e.getMessage());
  291. throw new BaseException("下载文件失败");
  292. }
  293. }
  294. }