TPssrPumpOverhaulController.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  1. package com.ruoyi.project.pssr.controller;
  2. import com.ruoyi.common.utils.StringUtils;
  3. import com.ruoyi.common.utils.poi.ExcelUtil;
  4. import com.ruoyi.framework.aspectj.lang.annotation.Log;
  5. import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
  6. import com.ruoyi.framework.web.controller.BaseController;
  7. import com.ruoyi.framework.web.domain.AjaxResult;
  8. import com.ruoyi.framework.web.page.TableDataInfo;
  9. import com.ruoyi.project.pssr.domain.TPssrApprove;
  10. import com.ruoyi.project.pssr.domain.TPssrPumpFill;
  11. import com.ruoyi.project.pssr.domain.TPssrPumpOverhaul;
  12. import com.ruoyi.project.pssr.domain.TPssrSubcontent;
  13. import com.ruoyi.project.pssr.service.*;
  14. import org.activiti.engine.HistoryService;
  15. import org.activiti.engine.RuntimeService;
  16. import org.activiti.engine.impl.identity.Authentication;
  17. import org.activiti.engine.runtime.ProcessInstance;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.security.access.prepost.PreAuthorize;
  20. import org.springframework.web.bind.annotation.*;
  21. import java.util.*;
  22. /**
  23. * 机泵检修完成确认清单Controller
  24. *
  25. * @author ssy
  26. * @date 2024-09-18
  27. */
  28. @RestController
  29. @RequestMapping("/pssr/pumpOverhaul")
  30. public class TPssrPumpOverhaulController extends BaseController {
  31. @Autowired
  32. private ITPssrFileService tPssrFileService;
  33. @Autowired
  34. private ITPssrPumpOverhaulService tPssrPumpOverhaulService;
  35. @Autowired
  36. private ITPssrPumpFillService tPssrPumpFillService;
  37. @Autowired
  38. private ITPssrApproveService tPssrApproveService;
  39. @Autowired
  40. private ITPssrSubcontentService tPssrSubcontentService;
  41. @Autowired
  42. private RuntimeService runtimeService;
  43. @Autowired
  44. private HistoryService historyService;
  45. /**
  46. * 查询机泵检修完成确认清单列表
  47. */
  48. @PreAuthorize("@ss.hasPermi('pssr:pumpOverhaul:list')")
  49. @GetMapping("/list")
  50. public TableDataInfo list(TPssrPumpOverhaul tPssrPumpOverhaul) {
  51. startPage();
  52. List<TPssrPumpOverhaul> list = tPssrPumpOverhaulService.selectTPssrPumpOverhaulList(tPssrPumpOverhaul);
  53. list.forEach(item -> {
  54. item.setFileList(tPssrFileService.selectTPssrFileListByItem(item.getSubId(), item.getId(), "jb-o"));
  55. });
  56. return getDataTable(list);
  57. }
  58. /**
  59. * 导出机泵检修完成确认清单列表
  60. */
  61. @PreAuthorize("@ss.hasPermi('pssr:pumpOverhaul:export')")
  62. @Log(title = "机泵检修完成确认清单", businessType = BusinessType.EXPORT)
  63. @GetMapping("/export")
  64. public AjaxResult export(TPssrPumpOverhaul tPssrPumpOverhaul) {
  65. List<TPssrPumpOverhaul> list = tPssrPumpOverhaulService.selectTPssrPumpOverhaulList(tPssrPumpOverhaul);
  66. ExcelUtil<TPssrPumpOverhaul> util = new ExcelUtil<TPssrPumpOverhaul>(TPssrPumpOverhaul.class);
  67. return util.exportExcel(list, "pumpOverhaul");
  68. }
  69. /**
  70. * 获取机泵检修完成确认清单详细信息
  71. */
  72. @PreAuthorize("@ss.hasPermi('pssr:pumpOverhaul:query')")
  73. @GetMapping(value = "/{id}")
  74. public AjaxResult getInfo(@PathVariable("id") Long id) {
  75. TPssrPumpOverhaul item = tPssrPumpOverhaulService.selectTPssrPumpOverhaulById(id);
  76. item.setFileList(tPssrFileService.selectTPssrFileListByItem(item.getSubId(), item.getId(), "jb-o"));
  77. return AjaxResult.success(item);
  78. }
  79. /**
  80. * 新增机泵检修完成确认清单
  81. */
  82. @PreAuthorize("@ss.hasPermi('pssr:pumpOverhaul:add')")
  83. @Log(title = "机泵检修完成确认清单", businessType = BusinessType.INSERT)
  84. @PostMapping
  85. public AjaxResult add(@RequestBody TPssrPumpOverhaul tPssrPumpOverhaul) {
  86. tPssrPumpOverhaul.setApproveStatus(0L);
  87. tPssrPumpOverhaul.setCreatedate(new Date());
  88. tPssrPumpOverhaul.setCreaterCode(String.valueOf(getUserId()));
  89. return toAjax(tPssrPumpOverhaulService.insertTPssrPumpOverhaul(tPssrPumpOverhaul));
  90. }
  91. /**
  92. * 修改机泵检修完成确认清单
  93. */
  94. @PreAuthorize("@ss.hasPermi('pssr:pumpOverhaul:edit')")
  95. @Log(title = "机泵检修完成确认清单", businessType = BusinessType.UPDATE)
  96. @PutMapping
  97. public AjaxResult edit(@RequestBody TPssrPumpOverhaul tPssrPumpOverhaul) {
  98. tPssrFileService.updateFileRelevance(tPssrPumpOverhaul.getFileIds(), "jb-o", tPssrPumpOverhaul.getId(), tPssrPumpOverhaul.getSubId());
  99. return toAjax(tPssrPumpOverhaulService.updateTPssrPumpOverhaul(tPssrPumpOverhaul));
  100. }
  101. /**
  102. * 删除机泵检修完成确认清单
  103. */
  104. @PreAuthorize("@ss.hasPermi('pssr:pumpOverhaul:remove')")
  105. @Log(title = "机泵检修完成确认清单", businessType = BusinessType.DELETE)
  106. @DeleteMapping("/{ids}")
  107. public AjaxResult remove(@PathVariable Long[] ids) {
  108. return toAjax(tPssrPumpOverhaulService.deleteTPssrPumpOverhaulByIds(ids));
  109. }
  110. /**
  111. * 确认人身防护
  112. */
  113. @PreAuthorize("@ss.hasPermi('pssr:pumpOverhaul:edit')")
  114. @Log(title = "人身防护", businessType = BusinessType.UPDATE)
  115. @PutMapping("/confirmPumpOverhaul")
  116. public AjaxResult confirmPumpOverhaul(@RequestBody TPssrPumpOverhaul tPssrPumpOverhaul) {
  117. long queryStatus = 0;
  118. long approveStatus = 0;
  119. Date date = null;
  120. TPssrPumpOverhaul pumpOverhaul = new TPssrPumpOverhaul();
  121. if (tPssrPumpOverhaul.getTaskType() == 4) {
  122. //确认人1确认
  123. queryStatus = 1;
  124. approveStatus = 3;
  125. pumpOverhaul.setConfirmer1(getUserId().toString());
  126. date = new Date();
  127. } else if (tPssrPumpOverhaul.getTaskType() == 5) {
  128. //确认人2确认
  129. queryStatus = 3;
  130. approveStatus = 2;
  131. pumpOverhaul.setConfirmer2(getUserId().toString());
  132. date = new Date();
  133. }
  134. if (tPssrPumpOverhaul.getIds() != null && tPssrPumpOverhaul.getIds().length > 0) {
  135. for (Long id : tPssrPumpOverhaul.getIds()) {
  136. pumpOverhaul = tPssrPumpOverhaulService.selectTPssrPumpOverhaulById(id);
  137. if (pumpOverhaul.getConfirmationDate() == null && tPssrPumpOverhaul.getTaskType() == 5) {
  138. pumpOverhaul.setConfirmationDate(new Date());
  139. }
  140. pumpOverhaul.setApproveStatus(approveStatus);
  141. pumpOverhaul.setUpdatedate(new Date());
  142. pumpOverhaul.setUpdaterCode(String.valueOf(getUserId()));
  143. tPssrPumpOverhaulService.updateTPssrPumpOverhaul(pumpOverhaul);
  144. }
  145. } else {
  146. pumpOverhaul.setSubId(tPssrPumpOverhaul.getSubId());
  147. pumpOverhaul.setApproveStatus(queryStatus);
  148. for (TPssrPumpOverhaul item : tPssrPumpOverhaulService.selectTPssrPumpOverhaulList(pumpOverhaul)) {
  149. if (item.getConfirmationDate() == null && tPssrPumpOverhaul.getTaskType() == 5) {
  150. item.setConfirmationDate(new Date());
  151. }
  152. item.setApproveStatus(approveStatus);
  153. item.setUpdatedate(new Date());
  154. item.setUpdaterCode(String.valueOf(getUserId()));
  155. tPssrPumpOverhaulService.updateTPssrPumpOverhaul(item);
  156. }
  157. }
  158. //查询当前待审批的确认人
  159. TPssrPumpFill entity = new TPssrPumpFill();
  160. entity.setSubId(tPssrPumpOverhaul.getSubId());
  161. entity.setApproveStatus(queryStatus);
  162. TPssrPumpFill queryData = tPssrPumpFillService.selectAllConfirmedPersonBySubId(entity);
  163. if (queryData != null) {
  164. //如果当前用户还有待审批任务
  165. if (tPssrPumpOverhaul.getTaskType() == 4 && StringUtils.isNotEmpty(queryData.getConfirmer1())) {
  166. if (queryData.getConfirmer1().contains(getUserId().toString())) {
  167. return AjaxResult.success();
  168. }
  169. }
  170. if (tPssrPumpOverhaul.getTaskType() == 5 && StringUtils.isNotEmpty(queryData.getConfirmer2())) {
  171. if (queryData.getConfirmer2().contains(getUserId().toString())) {
  172. return AjaxResult.success();
  173. }
  174. }
  175. }
  176. //无待审批任务结束当前用户流程
  177. // 因为流程关系所以approve一定会有且只有一条数据
  178. TPssrApprove tPssrApprove = tPssrApproveService.selectTPssrApproveBySubId(tPssrPumpOverhaul.getSubId());
  179. TPssrApproveController.handleConfirmApprove(tPssrApprove, getUserId().toString());
  180. return AjaxResult.success();
  181. }
  182. /**
  183. * 驳回人身防护
  184. */
  185. @PutMapping("/turnDownPumpOverhaul")
  186. public AjaxResult turnDownPumpOverhaul(@RequestBody TPssrPumpOverhaul tPssrPumpOverhaul) {
  187. if (tPssrPumpOverhaul.getIds() != null) {
  188. String userId = getUserId().toString();
  189. // 修改已选择数据的状态
  190. for (Long id : tPssrPumpOverhaul.getIds()) {
  191. TPssrPumpOverhaul blind = new TPssrPumpOverhaul();
  192. blind.setId(id);
  193. blind.setApproveStatus(1L);
  194. blind.setUpdatedate(new Date());
  195. blind.setUpdaterCode(getUserId().toString());
  196. tPssrPumpOverhaulService.updateTPssrPumpOverhaul(blind);
  197. }
  198. // 查询当前流程
  199. TPssrApprove approve = tPssrApproveService.selectTPssrApproveBySubId(tPssrPumpOverhaul.getSubId());
  200. try {
  201. runtimeService.deleteProcessInstance(approve.getProcessId(), "pssr2confirm");
  202. historyService.deleteHistoricProcessInstance(approve.getProcessId());
  203. } catch (Exception e) {
  204. logger.info("无运行时流程");
  205. }
  206. // 驳回 查询所有待审批的人员
  207. // 查询确认人
  208. TPssrPumpFill entity = new TPssrPumpFill();
  209. entity.setSubId(tPssrPumpOverhaul.getSubId());
  210. entity.setApproveStatus(1L);
  211. TPssrPumpFill queryData = tPssrPumpFillService.selectAllConfirmedPersonBySubId(entity);
  212. String confirmer1s = null;
  213. String confirmer2s = null;
  214. if (queryData != null) {
  215. confirmer1s = queryData.getConfirmer1();
  216. confirmer2s = queryData.getConfirmer2();
  217. }
  218. logger.info("=======================confirmer1s:{}", confirmer1s);
  219. logger.info("=======================confirmer2s:{}", confirmer2s);
  220. Set<String> confirmerUsers1 = new HashSet<>();
  221. Set<String> confirmerUsers2 = new HashSet<>();
  222. if (StringUtils.isNotEmpty(confirmer1s)) {
  223. confirmerUsers1.addAll(Arrays.asList(confirmer1s.split(",")));
  224. }
  225. if (StringUtils.isNotEmpty(confirmer2s)) {
  226. confirmerUsers2.addAll(Arrays.asList(confirmer2s.split(",")));
  227. }
  228. // 开始申请流程
  229. long businessKey = approve.getApproveId();
  230. //开始工作流、监听
  231. Authentication.setAuthenticatedUserId(userId);//设置当前申请人
  232. Map<String, Object> variables = new HashMap<>();
  233. variables.put("applyUser", userId);
  234. variables.put("confirmUsers1", new ArrayList<>(confirmerUsers1));
  235. variables.put("confirmUsers2", new ArrayList<>(confirmerUsers2));
  236. variables.put("chargePerson", approve.getSubCharge());
  237. //采用key来启动流程定义并设置流程变量,返回流程实例
  238. ProcessInstance pi = runtimeService.startProcessInstanceByKey("pssr2confirm", String.valueOf(businessKey), variables);
  239. // 修改审批表和sub表
  240. approve.setProcessId(pi.getProcessInstanceId());
  241. approve.setApproveStatus(1L);
  242. approve.setUpdatedate(new Date());
  243. approve.setUpdaterCode(getUserId().toString());
  244. tPssrApproveService.updateTPssrApprove(approve);
  245. TPssrSubcontent subcontent = new TPssrSubcontent();
  246. subcontent.setId(approve.getSubId());
  247. subcontent.setApproveStatus(1L);
  248. subcontent.setUpdatedate(new Date());
  249. subcontent.setUpdaterCode(getUserId().toString());
  250. tPssrSubcontentService.updateTPssrSubcontent(subcontent);
  251. return AjaxResult.success();
  252. }
  253. return AjaxResult.error();
  254. }
  255. }