TPssrBlindController.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. package com.ruoyi.project.pssr.controller;
  2. import com.ruoyi.common.utils.poi.ExcelUtil;
  3. import com.ruoyi.framework.aspectj.lang.annotation.Log;
  4. import com.ruoyi.framework.aspectj.lang.enums.BusinessType;
  5. import com.ruoyi.framework.web.controller.BaseController;
  6. import com.ruoyi.framework.web.domain.AjaxResult;
  7. import com.ruoyi.framework.web.page.TableDataInfo;
  8. import com.ruoyi.project.pssr.domain.TPssrApprove;
  9. import com.ruoyi.project.pssr.domain.TPssrBlind;
  10. import com.ruoyi.project.pssr.domain.TPssrSubcontent;
  11. import com.ruoyi.project.pssr.service.ITPssrApproveService;
  12. import com.ruoyi.project.pssr.service.ITPssrBlindService;
  13. import com.ruoyi.project.pssr.service.ITPssrSubcontentService;
  14. import org.activiti.engine.ProcessEngine;
  15. import org.activiti.engine.ProcessEngines;
  16. import org.activiti.engine.TaskService;
  17. import org.activiti.engine.task.Task;
  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.Date;
  22. import java.util.HashMap;
  23. import java.util.List;
  24. import java.util.Map;
  25. /**
  26. * 盲板Controller
  27. *
  28. * @author ssy
  29. * @date 2024-09-18
  30. */
  31. @RestController
  32. @RequestMapping("/pssr/blind")
  33. public class TPssrBlindController extends BaseController {
  34. @Autowired
  35. private ITPssrBlindService tPssrBlindService;
  36. @Autowired
  37. private ITPssrApproveService tPssrApproveService;
  38. @Autowired
  39. private ITPssrSubcontentService tPssrSubcontentService;
  40. /**
  41. * 查询盲板列表
  42. */
  43. @PreAuthorize("@ss.hasPermi('pssr:blind:list')")
  44. @GetMapping("/list")
  45. public TableDataInfo list(TPssrBlind tPssrBlind) {
  46. startPage();
  47. List<TPssrBlind> list = tPssrBlindService.selectTPssrBlindList(tPssrBlind);
  48. return getDataTable(list);
  49. }
  50. /**
  51. * 导出盲板列表
  52. */
  53. @PreAuthorize("@ss.hasPermi('pssr:blind:export')")
  54. @Log(title = "盲板", businessType = BusinessType.EXPORT)
  55. @GetMapping("/export")
  56. public AjaxResult export(TPssrBlind tPssrBlind) {
  57. List<TPssrBlind> list = tPssrBlindService.selectTPssrBlindList(tPssrBlind);
  58. ExcelUtil<TPssrBlind> util = new ExcelUtil<TPssrBlind>(TPssrBlind.class);
  59. return util.exportExcel(list, "blind");
  60. }
  61. /**
  62. * 获取盲板详细信息
  63. */
  64. @PreAuthorize("@ss.hasPermi('pssr:blind:query')")
  65. @GetMapping(value = "/{id}")
  66. public AjaxResult getInfo(@PathVariable("id") Long id) {
  67. return AjaxResult.success(tPssrBlindService.selectTPssrBlindById(id));
  68. }
  69. /**
  70. * 新增盲板
  71. */
  72. @PreAuthorize("@ss.hasPermi('pssr:blind:add')")
  73. @Log(title = "盲板", businessType = BusinessType.INSERT)
  74. @PostMapping
  75. public AjaxResult add(@RequestBody TPssrBlind tPssrBlind) {
  76. tPssrBlind.setApproveStatus(0L);
  77. return toAjax(tPssrBlindService.insertTPssrBlind(tPssrBlind));
  78. }
  79. /**
  80. * 修改盲板
  81. */
  82. @PreAuthorize("@ss.hasPermi('pssr:blind:edit')")
  83. @Log(title = "盲板", businessType = BusinessType.UPDATE)
  84. @PutMapping
  85. public AjaxResult edit(@RequestBody TPssrBlind tPssrBlind) {
  86. return toAjax(tPssrBlindService.updateTPssrBlind(tPssrBlind));
  87. }
  88. /**
  89. * 删除盲板
  90. */
  91. @PreAuthorize("@ss.hasPermi('pssr:blind:remove')")
  92. @Log(title = "盲板", businessType = BusinessType.DELETE)
  93. @DeleteMapping("/{ids}")
  94. public AjaxResult remove(@PathVariable Long[] ids) {
  95. return toAjax(tPssrBlindService.deleteTPssrBlindByIds(ids));
  96. }
  97. /**
  98. * 确认盲板
  99. */
  100. @PreAuthorize("@ss.hasPermi('pssr:blind:edit')")
  101. @Log(title = "盲板", businessType = BusinessType.UPDATE)
  102. @PutMapping("/confirmBlind")
  103. public AjaxResult confirmBlind(@RequestBody TPssrBlind tPssrBlind) {
  104. // 修改盲板状态
  105. if (tPssrBlind.getIds() != null && tPssrBlind.getIds().length > 0) {
  106. for (Long id : tPssrBlind.getIds()) {
  107. TPssrBlind item = tPssrBlindService.selectTPssrBlindById(id);
  108. item.setTaskType(tPssrBlind.getTaskType());
  109. setEntity(item);
  110. tPssrBlindService.updateTPssrBlind(item);
  111. }
  112. } else {
  113. TPssrBlind blind = new TPssrBlind();
  114. blind.setSubId(tPssrBlind.getSubId());
  115. blind.setCurrentUser(getUserId().toString());
  116. if (tPssrBlind.getTaskType() == 0) {
  117. blind.setApproveStatus(1L);
  118. } else if (tPssrBlind.getTaskType() == 1) {
  119. blind.setApproveStatus(3L);
  120. }
  121. for (TPssrBlind item : tPssrBlindService.selectTPssrBlindList(blind)) {
  122. item.setTaskType(tPssrBlind.getTaskType());
  123. setEntity(item);
  124. tPssrBlindService.updateTPssrBlind(item);
  125. }
  126. }
  127. //查询当前待审批的确认人
  128. TPssrBlind entity = new TPssrBlind();
  129. entity.setSubId(tPssrBlind.getSubId());
  130. if (tPssrBlind.getTaskType() == 0) {
  131. entity.setApproveStatus(1L);
  132. } else if (tPssrBlind.getTaskType() == 1) {
  133. entity.setApproveStatus(3L);
  134. }
  135. long status = 1;
  136. boolean flag = false;
  137. for (TPssrBlind item : tPssrBlindService.selectTPssrBlindList(entity)) {
  138. item.setTaskType(tPssrBlind.getTaskType());
  139. for (String s : setEntity(item).split(",")) {
  140. int current = Integer.parseInt(s);
  141. if (current == -1)
  142. continue;
  143. if (tPssrBlind.getTaskType() == 0) {
  144. if (item.getInstallStatus().split(",")[current].equals("0")) {
  145. return AjaxResult.success();
  146. }
  147. } else if (tPssrBlind.getTaskType() == 1) {
  148. if (item.getRemoveStatus().split(",")[current].equals("0")) {
  149. return AjaxResult.success();
  150. }
  151. }
  152. }
  153. if (item.getInstallStatus().equals("1,1,1,1,1")) {
  154. item.setApproveStatus(3L);//已确认安装
  155. status = 3L;
  156. flag = true;
  157. tPssrBlindService.updateTPssrBlind(item);
  158. }
  159. if (item.getRemoveStatus().equals("1,1,1,1,1")) {
  160. item.setApproveStatus(2L);//已确认拆除
  161. status = 4L;
  162. flag = true;
  163. tPssrBlindService.updateTPssrBlind(item);
  164. }
  165. }
  166. if (flag) {
  167. TPssrSubcontent tPssrSubcontent = new TPssrSubcontent();
  168. tPssrSubcontent.setId(tPssrBlind.getSubId());
  169. tPssrSubcontent.setApproveStatus(status);
  170. tPssrSubcontentService.updateTPssrSubcontent(tPssrSubcontent);
  171. }
  172. //无待审批任务结束当前用户流程
  173. TPssrApprove approve = new TPssrApprove();
  174. approve.setSubId(tPssrBlind.getSubId());
  175. // 因为流程关系所以approve一定会有且只有一条数据
  176. TPssrApprove tPssrApprove = tPssrApproveService.selectTPssrApproveList(approve).get(0);
  177. TPssrApproveController.handleConfirmApprove(tPssrApprove, getUserId().toString());
  178. return AjaxResult.success();
  179. }
  180. private String setEntity(TPssrBlind tPssrBlind) {
  181. //安装人员
  182. String inProcess = tPssrBlind.getInProcess();
  183. String inCoordinator = tPssrBlind.getInCoordinator();
  184. String inContractor = tPssrBlind.getInContractor();
  185. String inConfirm1 = tPssrBlind.getInConfirm1();
  186. String inConfirm2 = tPssrBlind.getInConfirm2();
  187. //拆除人员
  188. String reProcess = tPssrBlind.getReProcess();
  189. String reCoordinator = tPssrBlind.getReCoordinator();
  190. String reContractor = tPssrBlind.getReContractor();
  191. String reConfirm1 = tPssrBlind.getReConfirm1();
  192. String reConfirm2 = tPssrBlind.getReConfirm2();
  193. //获取当前人员操作下标
  194. String currents = "-1,";
  195. if (inProcess.equals(getUserId().toString()) || reProcess.equals(getUserId().toString())) {
  196. currents += "0,";
  197. }
  198. if (inCoordinator.equals(getUserId().toString()) || reCoordinator.equals(getUserId().toString())) {
  199. currents += "1,";
  200. }
  201. if (inContractor.equals(getUserId().toString()) || reContractor.equals(getUserId().toString())) {
  202. currents += "2,";
  203. }
  204. if (inConfirm1.equals(getUserId().toString()) || reConfirm1.equals(getUserId().toString())) {
  205. currents += "3,";
  206. }
  207. if (inConfirm2.equals(getUserId().toString()) || reConfirm2.equals(getUserId().toString())) {
  208. currents += "4,";
  209. }
  210. for (String val : currents.split(",")) {
  211. int current = Integer.parseInt(val);
  212. //修改状态
  213. if (current != -1) {
  214. if (tPssrBlind.getTaskType() == 0) {
  215. if (tPssrBlind.getInstallDate() == null) {
  216. tPssrBlind.setInstallDate(new Date());
  217. }
  218. String[] is = tPssrBlind.getInstallStatus().split(",");
  219. is[current] = "1";
  220. tPssrBlind.setInstallStatus(String.join(",", is));
  221. if (tPssrBlind.getInstallDate() == null) {
  222. tPssrBlind.setInstallDate(new Date());
  223. }
  224. } else if (tPssrBlind.getTaskType() == 1) {
  225. if (tPssrBlind.getRemovedDate() == null) {
  226. tPssrBlind.setRemovedDate(new Date());
  227. }
  228. String[] rs = tPssrBlind.getRemoveStatus().split(",");
  229. rs[current] = "1";
  230. tPssrBlind.setRemoveStatus(String.join(",", rs));
  231. if (tPssrBlind.getRemovedDate() == null) {
  232. tPssrBlind.setRemovedDate(new Date());
  233. }
  234. }
  235. }
  236. }
  237. return currents;
  238. }
  239. @PutMapping("/turnDownBlind")
  240. public AjaxResult turnDownBlind(TPssrBlind tPssrBlind) {
  241. if (tPssrBlind.getIds() != null) {
  242. String userId = getUserId().toString();
  243. // 修改已选择数据的状态
  244. for (Long id : tPssrBlind.getIds()) {
  245. TPssrBlind blind = new TPssrBlind();
  246. blind.setId(id);
  247. blind.setApproveStatus(1L);
  248. blind.setUpdatedate(new Date());
  249. blind.setUpdaterCode(getUserId().toString());
  250. tPssrBlindService.updateTPssrBlind(blind);
  251. }
  252. // 查询当前流程
  253. TPssrApprove approve = tPssrApproveService.selectTPssrApproveBySubId(tPssrBlind.getSubId());
  254. ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
  255. TaskService taskService = processEngine.getTaskService();
  256. Task task = processEngine.getTaskService()//获取任务service
  257. .createTaskQuery()//创建查询对象
  258. .taskAssignee(userId)
  259. .processInstanceId(approve.getProcessId()).singleResult();
  260. String taskId = task.getId();
  261. //处理流程节点
  262. Map<String, Object> param = new HashMap<>();
  263. param.put("condition", 1);
  264. //认领任务
  265. processEngine.getTaskService().claim(taskId, userId);
  266. taskService.addComment(taskId, approve.getProcessId(), "驳回至拆除" + tPssrBlind.getRemarks());
  267. taskService.complete(taskId, param);
  268. // 修改审批表和sub表
  269. approve.setApproveStatus(1L);
  270. approve.setUpdatedate(new Date());
  271. approve.setUpdaterCode(getUserId().toString());
  272. tPssrApproveService.updateTPssrApprove(approve);
  273. TPssrSubcontent subcontent = new TPssrSubcontent();
  274. subcontent.setId(approve.getSubId());
  275. subcontent.setApproveStatus(1L);
  276. subcontent.setUpdatedate(new Date());
  277. subcontent.setUpdaterCode(getUserId().toString());
  278. tPssrSubcontentService.updateTPssrSubcontent(subcontent);
  279. return AjaxResult.success();
  280. }
  281. return AjaxResult.error();
  282. }
  283. }