From d0ffecb36c393e1d4505aaf01f19051955d42c84 Mon Sep 17 00:00:00 2001
From: xusd <hugeinfo123>
Date: Fri, 13 Sep 2024 20:04:51 +0800
Subject: [PATCH] 修复bug

---
 dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseTaskService.java |  153 +++++++++++++++++++++++++++++++--------------------
 1 files changed, 93 insertions(+), 60 deletions(-)

diff --git a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseTaskService.java b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseTaskService.java
index 3acafae..de4b459 100644
--- a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseTaskService.java
+++ b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseTaskService.java
@@ -91,7 +91,7 @@
     @Autowired
     private CaseWindupApplyService caseWindupApplyService;
     @Autowired
-    private CaseAssistApplyService assistApplyService;
+    private CaseAssistApplyService caseAssistApplyService;
     @Autowired
     private CaseAppearService caseAppearService;
     @Autowired
@@ -555,10 +555,10 @@
             FrontPageCountDTO frontPageCountDTO = mapper.countTaskList(terms);
             long supervise = superviseService.countCaseSuperviseList(0,loginUser.getUnitId());
             frontPageCountDTO.setSupervise(supervise);
-            long countApplyReview = caseWindupApplyMapper.countApplyReview(loginUser.getUnitId());
-            long countReturnReview = caseReturnMapper.countReturnReview(loginUser.getUnitId());
-            long countAppearReview = caseAppearMapper.countAppearReview(loginUser.getUnitId());
-            long countAssistReview = caseAssistApplyMapper.countAssistReview(loginUser.getUnitId());
+            long countApplyReview = caseWindupApplyService.countApplyReview(loginUser.getUnitId());
+            long countReturnReview = caseReturnService.countReturnReview(loginUser.getUnitId());
+            long countAppearReview = caseAppearService.countAppearReview(loginUser.getUnitId());
+            long countAssistReview = caseAssistApplyService.countAssistReview(loginUser.getUnitId());
             frontPageCountDTO.setWaitReview(countApplyReview+countReturnReview+countAppearReview+countAssistReview);
             return frontPageCountDTO;
         }catch (Exception e) {
@@ -646,7 +646,7 @@
                 for(CaseInfoUnfold unfold: unfoldList){
                     for(FrontPageListDTO frontPageListDTO: frontPageListDTOList){
                         if(frontPageListDTO.getCaseId().equals(unfold.getId())){
-                            frontPageListDTO.setOrganizingUnit(unfold.getMediateUnitId());
+                            frontPageListDTO.setOrganizingUnit(unfold.getMediateUnitName());
                             frontPageListDTO.setCooperatingUnit(unfold.getAssistUnitName());
                         }
                     }
@@ -668,8 +668,8 @@
      */
     public Page<FrontPageListDTO> pageMyTaskBl(PageRequest page, Map<String, Object> terms){
         try {
-            long total = caseWindupApplyMapper.countMySubmitApplyReview(terms);
-            List<FrontPageListDTO> frontPageListDTOList = caseWindupApplyMapper.pageMySubmitApplyReview(page, terms);
+            long total = caseWindupApplyService.countMySubmitApplyReview(terms);
+            List<FrontPageListDTO> frontPageListDTOList = caseWindupApplyService.listMySubmitApplyReview(page, terms);
 
             List<String> caseIdList = new ArrayList<>();
             caseIdList = frontPageListDTOList.stream().map(FrontPageListDTO ::getCaseId).collect(Collectors.toList());
@@ -680,7 +680,7 @@
                 for(CaseInfoUnfold unfold: unfoldList){
                     for(FrontPageListDTO frontPageListDTO: frontPageListDTOList){
                         if(frontPageListDTO.getCaseId().equals(unfold.getId())){
-                            frontPageListDTO.setOrganizingUnit(unfold.getMediateUnitId());
+                            frontPageListDTO.setOrganizingUnit(unfold.getMediateUnitName());
                             frontPageListDTO.setCooperatingUnit(unfold.getAssistUnitName());
                         }
                     }
@@ -704,17 +704,17 @@
             long total = 0;
             List<FrontPageListDTO> frontPageListDTOList = new ArrayList<>();
             if(1 == type){
-                total = caseReturnMapper.countMyTaskReturnReview(terms);
-                frontPageListDTOList = caseReturnMapper.pageMyTaskReturnReview(page,terms);
+                total = caseReturnService.countMyTaskReturnReview(terms);
+                frontPageListDTOList = caseReturnService.pageMyTaskReturnReview(page,terms);
             }else if(2 == type){
-                total = caseAppearMapper.countMyTaskAppearReview(terms);
-                frontPageListDTOList = caseAppearMapper.pageMyTaskAppearReview(page, terms);
+                total = caseAppearService.countMyTaskAppearReview(terms);
+                frontPageListDTOList = caseAppearService.pageMyTaskAppearReview(page, terms);
             }else if(3 == type){
-                total = caseWindupApplyMapper.countMyTaskApplyReview(terms);
-                frontPageListDTOList = caseWindupApplyMapper.pageMyTaskApplyReview(page, terms);
+                total = caseWindupApplyService.countMyTaskApplyReview(terms);
+                frontPageListDTOList = caseWindupApplyService.listMyTaskApplyReview(page, terms);
             }else if(4 == type){
-                total = caseAssistApplyMapper.countMyTaskAssistReview(terms);
-                frontPageListDTOList = caseAssistApplyMapper.pageMyTaskAssistReview(page, terms);
+                total = caseAssistApplyService.countMyTaskAssistReview(terms);
+                frontPageListDTOList = caseAssistApplyService.pageMyTaskAssistReview(page, terms);
             }
             return new PageImpl<FrontPageListDTO>(frontPageListDTOList, page, total);
         }catch (Exception e) {
@@ -896,7 +896,7 @@
      */
     public void webStartFlowZXSL(CaseInfo caseInfo, CtUserDTO loginUser){
         try{
-            // 启动自行手里工作流
+            // 启动自行受理工作流
             FlowNode firstFlowNode = flowInfoService.startFlow(FlowableConsts.FLOWABLE_ID_ZXSL, caseInfo.getId());
             // 进入第1个节点-办理反馈
             CaseTask blfkCaseTask = new CaseTask();
@@ -1114,35 +1114,41 @@
 
     /**
      * web端任务处理-签收
-     * @param signTaskDTO 签收任务表单
+     * @param signTaskDTOList 签收任务表单
      * @param userId 当前登录用户
      */
-    public void webSign(SignTaskDTO signTaskDTO, String userId){
+    public void webSign(List<SignTaskDTO> signTaskDTOList, String userId){
         try{
             Date nowDate = DateUtils.getNowDate();
             // 获取当前登录用户
             CtUserDTO loginUser = custClient.clientGetUserAll(userId);
-            // 更新纠纷任务信息
-            CaseTask caseTaskPO = new CaseTask();
-            caseTaskPO.setId(signTaskDTO.getCaseTaskId());
-            caseTaskPO.setSignStatus(CaseTaskConsts.SIGN_STATUS_2);
-            caseTaskPO.setSignTime(nowDate);
-            caseTaskPO.setSignUserId(loginUser.getId());
-            caseTaskPO.setSignUserName(loginUser.getTrueName());
-            caseTaskPO.setHandleIllust("已签收");
-            caseTaskPO.setUpdateTime(nowDate);
-            mapper.updateCaseTask(caseTaskPO);
-            // 更新纠纷信息
-            CaseInfo caseInfoPO = new CaseInfo();
-            caseInfoPO.setId(signTaskDTO.getCaseId());
-            caseInfoPO.setStatus(CaseStatusBaseConstsEnum.CASE_STATUS_3.getIndex());
-            caseInfoPO.setStatusName(CaseStatusBaseConstsEnum.CASE_STATUS_3.getDes());
-            caseInfoPO.setProcess(CaseProcessBaseConstsEnum.getByStatus(caseInfoPO.getStatus()).getIndex());
-            caseInfoPO.setProcessName(CaseProcessBaseConstsEnum.getByStatus(caseInfoPO.getStatus()).getDes());
-            caseInfoPO.setInfoProcess(CaseInfoProcessBaseConstsEnum.getByProcess(caseInfoPO.getProcess()).getIndex());
-            caseInfoPO.setInfoProcessName(CaseInfoProcessBaseConstsEnum.getByProcess(caseInfoPO.getProcess()).getDes());
-            caseInfoPO.setUpdateTime(nowDate);
-            caseInfoService.updateCaseInfo(caseInfoPO);
+            List<String> taskIdList = new ArrayList<>();
+            List<String> caseIdList = new ArrayList<>();
+            for (SignTaskDTO signTaskDTO: signTaskDTOList){
+                CaseTask qsCaseTask = mapper.selectById(signTaskDTO.getCaseId());
+                // 更新纠纷任务信息
+                CaseTask caseTaskPO = new CaseTask();
+                caseTaskPO.setSignStatus(CaseTaskConsts.SIGN_STATUS_2);
+                caseTaskPO.setSignTime(nowDate);
+                caseTaskPO.setSignUserId(loginUser.getId());
+                caseTaskPO.setSignUserName(loginUser.getTrueName());
+                caseTaskPO.setHandleIllust("已签收");
+                caseTaskPO.setUpdateTime(nowDate);
+                mapper.updateCaseTask(caseTaskPO);
+                // 承办部门签收才更新纠纷信息
+                if (CaseTaskConsts.CASE_TASK_TYPE_1 ==  qsCaseTask.getCaseTaskType()) {
+                    // 更新纠纷信息
+                    CaseInfo caseInfoPO = new CaseInfo();
+                    caseInfoPO.setStatus(CaseStatusBaseConstsEnum.CASE_STATUS_3.getIndex());
+                    caseInfoPO.setStatusName(CaseStatusBaseConstsEnum.CASE_STATUS_3.getDes());
+                    caseInfoPO.setProcess(CaseProcessBaseConstsEnum.getByStatus(caseInfoPO.getStatus()).getIndex());
+                    caseInfoPO.setProcessName(CaseProcessBaseConstsEnum.getByStatus(caseInfoPO.getStatus()).getDes());
+                    caseInfoPO.setInfoProcess(CaseInfoProcessBaseConstsEnum.getByProcess(caseInfoPO.getProcess()).getIndex());
+                    caseInfoPO.setInfoProcessName(CaseInfoProcessBaseConstsEnum.getByProcess(caseInfoPO.getProcess()).getDes());
+                    caseInfoPO.setUpdateTime(nowDate);
+                    caseInfoService.updateCaseInfo(caseInfoPO);
+                }
+            }
         }catch (Exception e){
             log.error("[CaseTaskService.webSign]调用失败,异常信息:"+e, e);
             throw new ServiceException("CaseTaskService.webSign", e);
@@ -1190,7 +1196,7 @@
             blfkCaseTask.setNodeName(newFlowNode.getNodeName());
             blfkCaseTask.setFlowId(newFlowNode.getFlowId());
             blfkCaseTask.setNodeShowName(newFlowNode.getNodeShowName());
-            blfkCaseTask.setCaseTaskType(CaseTaskConsts.CASE_TASK_TYPE_1);
+            blfkCaseTask.setCaseTaskType(dslCaseTask.getCaseTaskType());
             // 受理任务,任务候选执行者类型是上一步骤选择
             blfkCaseTask.setCandeType(CaseTaskConsts.CANDE_TYPE_1);
             blfkCaseTask.setCandeUnitId(loginUser.getUnitId());
@@ -1207,23 +1213,26 @@
             blfkCaseTask.setCreateTime(nowDate);
             blfkCaseTask.setUpdateTime(nowDate);
             mapper.insert(blfkCaseTask);
-            // 更新纠纷信息
-            CaseInfo caseInfoPO = new CaseInfo();
-            caseInfoPO.setId(blfkCaseTask.getCaseId());
-            caseInfoPO.setStatus(CaseStatusBaseConstsEnum.CASE_STATUS_4.getIndex());
-            caseInfoPO.setStatusName(CaseStatusBaseConstsEnum.CASE_STATUS_4.getDes());
-            caseInfoPO.setProcess(CaseProcessBaseConstsEnum.getByStatus(caseInfoPO.getStatus()).getIndex());
-            caseInfoPO.setProcessName(CaseProcessBaseConstsEnum.getByStatus(caseInfoPO.getStatus()).getDes());
-            caseInfoPO.setInfoProcess(CaseInfoProcessBaseConstsEnum.getByProcess(caseInfoPO.getProcess()).getIndex());
-            caseInfoPO.setInfoProcessName(CaseInfoProcessBaseConstsEnum.getByProcess(caseInfoPO.getProcess()).getDes());
-            caseInfoService.updateCaseInfo(caseInfoPO);
-            // 更新纠纷扩展信息
-            CaseInfoUnfold caseInfoUnfoldPO = new CaseInfoUnfold();
-            caseInfoUnfoldPO.setId(blfkCaseTask.getCaseId());
-            caseInfoUnfoldPO.setAcceptTime(nowDate);
-            caseInfoUnfoldPO.setMediateUnitId(blfkCaseTask.getCandeUnitId());
-            caseInfoUnfoldPO.setMediateUnitName(blfkCaseTask.getCandeUnitName());
-            caseInfoUnfoldService.updateCaseInfoUnfold(caseInfoUnfoldPO);
+            // 承办部门签收才更新纠纷信息
+            if (CaseTaskConsts.CASE_TASK_TYPE_1 ==  dslCaseTask.getCaseTaskType()) {
+                // 更新纠纷信息
+                CaseInfo caseInfoPO = new CaseInfo();
+                caseInfoPO.setId(blfkCaseTask.getCaseId());
+                caseInfoPO.setStatus(CaseStatusBaseConstsEnum.CASE_STATUS_4.getIndex());
+                caseInfoPO.setStatusName(CaseStatusBaseConstsEnum.CASE_STATUS_4.getDes());
+                caseInfoPO.setProcess(CaseProcessBaseConstsEnum.getByStatus(caseInfoPO.getStatus()).getIndex());
+                caseInfoPO.setProcessName(CaseProcessBaseConstsEnum.getByStatus(caseInfoPO.getStatus()).getDes());
+                caseInfoPO.setInfoProcess(CaseInfoProcessBaseConstsEnum.getByProcess(caseInfoPO.getProcess()).getIndex());
+                caseInfoPO.setInfoProcessName(CaseInfoProcessBaseConstsEnum.getByProcess(caseInfoPO.getProcess()).getDes());
+                caseInfoService.updateCaseInfo(caseInfoPO);
+                // 更新纠纷扩展信息
+                CaseInfoUnfold caseInfoUnfoldPO = new CaseInfoUnfold();
+                caseInfoUnfoldPO.setId(blfkCaseTask.getCaseId());
+                caseInfoUnfoldPO.setAcceptTime(nowDate);
+                caseInfoUnfoldPO.setMediateUnitId(blfkCaseTask.getCandeUnitId());
+                caseInfoUnfoldPO.setMediateUnitName(blfkCaseTask.getCandeUnitName());
+                caseInfoUnfoldService.updateCaseInfoUnfold(caseInfoUnfoldPO);
+            }
         }catch (Exception e){
             log.error("[CaseTaskService.webAccept]调用失败,异常信息:"+e, e);
             throw new ServiceException("CaseTaskService.webAccept", e);
@@ -1468,6 +1477,27 @@
                 caseInfoUnfoldPO.setUpdateTime(nowDate);
                 caseInfoUnfoldService.updateCaseInfoUnfold(caseInfoUnfoldPO);
             }
+            // 查询配合部门的任务,全部结束流程
+            QueryWrapper<CaseTask> caseTaskQueryWrapper = new QueryWrapper<>();
+            caseTaskQueryWrapper.eq("case_task_type", CaseTaskConsts.CASE_TASK_TYPE_2).eq("case_id", jasqCaseTask.getCaseId());
+            List<CaseTask> assistCaseTaskList = mapper.selectList(caseTaskQueryWrapper);
+            for (CaseTask assistCaseTask: assistCaseTaskList){
+                // 完成配合部门当前办理反馈任务
+                assistCaseTask.setId(caseWindupApply.getCaseTaskId());
+                assistCaseTask.setStatus(CaseTaskConsts.TASK_STATUS_2);
+                assistCaseTask.setHandleUnitId(loginUser.getUnitId());
+                assistCaseTask.setHandleUnitName(loginUser.getUnitName());
+                assistCaseTask.setHandleUserId(loginUser.getId());
+                assistCaseTask.setHandleUserName(loginUser.getTrueName());
+                assistCaseTask.setHandleResult(CaseTaskConsts.HANDLE_RESULT_1);
+                assistCaseTask.setHandleTime(nowDate);
+                assistCaseTask.setUpdateTime(nowDate);
+                mapper.updateCaseTask(assistCaseTask);
+                // 完成当前配合部门办理反馈工作流任务
+                flowInfoService.completeTask(assistCaseTask.getFlowableId(), assistCaseTask.getProcessTaskId(),
+                        FlowableConsts.OPERATION_forward, userId);
+
+            }
         }catch (Exception e){
             log.error("[CaseTaskService.webWindupApply]调用失败,异常信息:"+e, e);
             throw new ServiceException("CaseTaskService.webWindupApply", e);
@@ -1645,7 +1675,7 @@
     }
 
     /**
-     * web端任务处理-上报
+     * web端任务处理-回退申请
      * @param caseReturn 回退申请表单
      * @param userId 当前登录用户
      */
@@ -1660,6 +1690,9 @@
             caseReturn.setReturnUserId(loginUser.getId());
             caseReturn.setReturnUserName(loginUser.getTrueName());
             caseReturn.setReturnTime(nowDate);
+            CtUnitDTO zzzxUnit = custClient.getParentZzzxUnit(loginUser.getUnitId());
+            caseReturn.setAuditUnitId(zzzxUnit.getId());
+            caseReturn.setAuditUnitName(zzzxUnit.getUnitName());
             caseReturn.setReturnStatus(AuditBaseConsts.AUDIT_STATUS_0);
             caseReturn.setDeleteStatus(BaseConsts.DELETE_STATUS_0);
             caseReturn.setCustId(loginUser.getCustId());

--
Gitblit v1.8.0