From 49aed349c28d41705101f3611795e77c0fc4639a Mon Sep 17 00:00:00 2001
From: huangh <hshgjzd5@163.com>
Date: Thu, 19 Sep 2024 16:16:47 +0800
Subject: [PATCH] 草稿箱分页条件查询

---
 dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseAssistApplyService.java |  126 +++++++++++++++++++++++++++++-------------
 1 files changed, 87 insertions(+), 39 deletions(-)

diff --git a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseAssistApplyService.java b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseAssistApplyService.java
index 3649d2a..ff24fc4 100644
--- a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseAssistApplyService.java
+++ b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseAssistApplyService.java
@@ -189,7 +189,7 @@
     }
 
     /**
-     * 审核联合处置申请
+     * 审核联合处置审核
      * @param caseAssistApply 实体对象
      */
     public void reviewCaseAssistApply(CaseAssistApply caseAssistApply, String userId){
@@ -197,31 +197,74 @@
             // 获取当前登录用户
             CtUserDTO loginUser = custClient.clientGetUserAll(userId);
             Date now = DateUtils.getNowDate();
-            caseAssistApply.setApplyStatus(AuditBaseConsts.AUDIT_STATUS_1);
-            caseAssistApply.setAuditUserId(loginUser.getId());
-            caseAssistApply.setAuditUserName(loginUser.getTrueName());
-            caseAssistApply.setAuditTime(now);
-            caseAssistApply.setUpdateTime(now);
-            mapper.updateCaseAssistApply(caseAssistApply);
+            CaseAssistApply caseAssistApplyPO = mapper.selectById(caseAssistApply.getId());
+            caseAssistApplyPO.setAuditResult(caseAssistApply.getAuditResult());
+            caseAssistApplyPO.setAuditResultName(caseAssistApply.getAuditResultName());
+            caseAssistApplyPO.setAuditContent(caseAssistApply.getAuditContent());
+            caseAssistApplyPO.setApplyStatus(AuditBaseConsts.AUDIT_STATUS_1);
+            caseAssistApplyPO.setAuditUserId(loginUser.getId());
+            caseAssistApplyPO.setAuditUserName(loginUser.getTrueName());
+            caseAssistApplyPO.setAuditTime(now);
+            caseAssistApplyPO.setUpdateTime(now);
+            mapper.updateCaseAssistApply(caseAssistApplyPO);
             // 审核通过,就启动联合处置工作流
-            if (AuditBaseConstsEnum.AUDIT_RESULT_1.getIndex().equals(caseAssistApply.getAuditResult())) {
-                String[] unitIds = caseAssistApply.getApplyAssistUnitId().split(BaseConsts.COMMA);
+            if (AuditBaseConstsEnum.AUDIT_RESULT_1.getIndex().equals(caseAssistApplyPO.getAuditResult())) {
+                String[] unitIds = caseAssistApplyPO.getApplyAssistUnitId().split(BaseConsts.COMMA);
                 for (String unitId: unitIds) {
                     // 启动联合处置工作流
-                    FlowNode firstFlowNode = flowInfoService.startFlow(FlowableConsts.FLOWABLE_ID_LHCZ, caseAssistApply.getCaseId());
+                    FlowNode dfpFlowNode = flowInfoService.startFlow(FlowableConsts.FLOWABLE_ID_LHCZ, caseAssistApplyPO.getCaseId());
+                    // 新建并完成配合部门待分派任务
+                    CaseTask dfpCaseTask = new CaseTask();
+                    dfpCaseTask.setId(utilsClient.getNewTimeId());
+                    dfpCaseTask.setCaseId(caseAssistApplyPO.getCaseId());
+                    dfpCaseTask.setFlowableId(dfpFlowNode.getFlowableId());
+                    dfpCaseTask.setProcessInstanceId(dfpFlowNode.getProcessInstanceId());
+                    dfpCaseTask.setProcessTaskId(dfpFlowNode.getProcessTaskId());
+                    dfpCaseTask.setTaskType(CaseTaskConsts.TASK_TYPE_1);
+                    dfpCaseTask.setNodeType(dfpFlowNode.getNodeType());
+                    dfpCaseTask.setNodeId(dfpFlowNode.getNodeId());
+                    dfpCaseTask.setNodeName(dfpFlowNode.getNodeName());
+                    dfpCaseTask.setFlowId(dfpFlowNode.getFlowId());
+                    dfpCaseTask.setNodeShowName(dfpFlowNode.getNodeShowName());
+                    dfpCaseTask.setCaseTaskType(CaseTaskConsts.CASE_TASK_TYPE_2);
+                    // 通过调度的,任务候选执行者类型是上一步骤选择
+                    dfpCaseTask.setCandeType(CaseTaskConsts.CANDE_TYPE_1);
+                    dfpCaseTask.setCandeUnitId(loginUser.getUnitId());
+                    dfpCaseTask.setCandeUnitName(loginUser.getUnitName());
+                    // 不需要签收
+                    dfpCaseTask.setSignStatus(CaseTaskConsts.SIGN_STATUS_0);
+                    dfpCaseTask.setStatus(CaseTaskConsts.TASK_STATUS_2);
+                    dfpCaseTask.setHandleUnitId(loginUser.getUnitId());
+                    dfpCaseTask.setHandleUnitName(loginUser.getUnitName());
+                    dfpCaseTask.setHandleUserId(loginUser.getId());
+                    dfpCaseTask.setHandleUserName(loginUser.getTrueName());
+                    dfpCaseTask.setHandleContent(caseAssistApplyPO.getAuditContent());
+                    dfpCaseTask.setHandleIllust("交办至:"+caseAssistApplyPO.getApplyAssistUnitName());
+                    // 任务处理时限
+                    if (dfpFlowNode.getExpire() != 0) {
+                        dfpCaseTask.setExpireTime(DateUtils.addDay(now, dfpFlowNode.getExpire()));
+                    }
+                    dfpCaseTask.setDeleteStatus(BaseConsts.DELETE_STATUS_0);
+                    dfpCaseTask.setCustId(caseAssistApplyPO.getCustId());
+                    dfpCaseTask.setCreateTime(now);
+                    dfpCaseTask.setUpdateTime(now);
+                    caseTaskService.save(dfpCaseTask);
+                    // 完成待分派任务
+                    FlowNode dslFlowNode = flowInfoService.completeTask(dfpCaseTask.getFlowableId(), dfpCaseTask.getProcessTaskId(),
+                            FlowableConsts.OPERATION_forward, loginUser.getId());
                     // 创建配合部门待受理任务
                     CaseTask dslCaseTask = new CaseTask();
                     dslCaseTask.setId(utilsClient.getNewTimeId());
-                    dslCaseTask.setCaseId(caseAssistApply.getCaseId());
-                    dslCaseTask.setFlowableId(firstFlowNode.getFlowableId());
-                    dslCaseTask.setProcessInstanceId(firstFlowNode.getProcessInstanceId());
-                    dslCaseTask.setProcessTaskId(firstFlowNode.getProcessTaskId());
+                    dslCaseTask.setCaseId(caseAssistApplyPO.getCaseId());
+                    dslCaseTask.setFlowableId(dslFlowNode.getFlowableId());
+                    dslCaseTask.setProcessInstanceId(dslFlowNode.getProcessInstanceId());
+                    dslCaseTask.setProcessTaskId(dslFlowNode.getProcessTaskId());
                     dslCaseTask.setTaskType(CaseTaskConsts.TASK_TYPE_1);
-                    dslCaseTask.setNodeType(firstFlowNode.getNodeType());
-                    dslCaseTask.setNodeId(firstFlowNode.getNodeId());
-                    dslCaseTask.setNodeName(firstFlowNode.getNodeName());
-                    dslCaseTask.setFlowId(firstFlowNode.getFlowId());
-                    dslCaseTask.setNodeShowName(firstFlowNode.getNodeShowName());
+                    dslCaseTask.setNodeType(dslFlowNode.getNodeType());
+                    dslCaseTask.setNodeId(dslFlowNode.getNodeId());
+                    dslCaseTask.setNodeName(dslFlowNode.getNodeName());
+                    dslCaseTask.setFlowId(dslFlowNode.getFlowId());
+                    dslCaseTask.setNodeShowName(dslFlowNode.getNodeShowName());
                     dslCaseTask.setCaseTaskType(CaseTaskConsts.CASE_TASK_TYPE_2);
                     // 通过调度的,任务候选执行者类型是上一步骤选择
                     dslCaseTask.setCandeType(CaseTaskConsts.CANDE_TYPE_1);
@@ -232,21 +275,21 @@
                     dslCaseTask.setSignStatus(CaseTaskConsts.SIGN_STATUS_1);
                     dslCaseTask.setStatus(CaseTaskConsts.TASK_STATUS_1);
                     // 任务处理时限
-                    if (firstFlowNode.getExpire() != 0) {
-                        dslCaseTask.setExpireTime(DateUtils.addDay(now, firstFlowNode.getExpire()));
+                    if (dslFlowNode.getExpire() != 0) {
+                        dslCaseTask.setExpireTime(DateUtils.addDay(now, dslFlowNode.getExpire()));
                     }
                     dslCaseTask.setDeleteStatus(BaseConsts.DELETE_STATUS_0);
-                    dslCaseTask.setCustId(caseAssistApply.getCustId());
+                    dslCaseTask.setCustId(caseAssistApplyPO.getCustId());
                     dslCaseTask.setCreateTime(now);
                     dslCaseTask.setUpdateTime(now);
                     caseTaskService.save(dslCaseTask);
-                    // 更新纠纷扩展信息
-                    CaseInfoUnfold caseInfoUnfoldPO = new CaseInfoUnfold();
-                    caseInfoUnfoldPO.setId(dslCaseTask.getCaseId());
-                    caseInfoUnfoldPO.setAssistUnitId(caseAssistApply.getApplyAssistUnitId());
-                    caseInfoUnfoldPO.setAssistUnitName(caseAssistApply.getApplyAssistUnitName());
-                    caseInfoUnfoldService.updateCaseInfoUnfold(caseInfoUnfoldPO);
                 }
+                // 更新纠纷扩展信息
+                CaseInfoUnfold caseInfoUnfoldPO = new CaseInfoUnfold();
+                caseInfoUnfoldPO.setId(caseAssistApplyPO.getCaseId());
+                caseInfoUnfoldPO.setAssistUnitId(caseAssistApplyPO.getApplyAssistUnitId());
+                caseInfoUnfoldPO.setAssistUnitName(caseAssistApplyPO.getApplyAssistUnitName());
+                caseInfoUnfoldService.updateCaseInfoUnfold(caseInfoUnfoldPO);
             }
         }catch (Exception e){
             log.error("[CaseAssistApplyService.reviewCaseAssistApply]调用失败,异常信息:"+e, e);
@@ -260,18 +303,23 @@
      * @return long
      */
     public CaseAssistApply caseAssistApplyByCaseId(String caseId){
-        QueryWrapper<CaseAssistApply> caseAssistApplyQueryWrapper = new QueryWrapper<>();
-        caseAssistApplyQueryWrapper.eq("case_id", caseId).eq("apply_status", 0)
-                .orderByDesc("create_time");
-        CaseAssistApply caseAssistApply = mapper.selectOne(caseAssistApplyQueryWrapper);
-        Map<String, Object> terms = new HashMap<>();
-        terms.put("mainId", caseId);
-        terms.put("ownerIds", "'" + caseAssistApply.getId() + "'");
-        List<FileIdInfoBaseDTO> fileIdInfoBaseDTOList = sysClient.listIdInfoByOwnerIdList(terms);
-        if(CollectionUtils.isNotEmpty(fileIdInfoBaseDTOList)){
-            caseAssistApply.setFileInfoBaseDTOList(fileIdInfoBaseDTOList.get(0).getFileList());
+        try {
+            QueryWrapper<CaseAssistApply> caseAssistApplyQueryWrapper = new QueryWrapper<>();
+            caseAssistApplyQueryWrapper.eq("case_id", caseId).eq("apply_status", 0)
+                    .orderByDesc("create_time");
+            CaseAssistApply caseAssistApply = mapper.selectOne(caseAssistApplyQueryWrapper);
+            Map<String, Object> terms = new HashMap<>();
+            terms.put("mainId", caseId);
+            terms.put("ownerIds", "'" + caseAssistApply.getId() + "'");
+            List<FileIdInfoBaseDTO> fileIdInfoBaseDTOList = sysClient.listIdInfoByOwnerIdList(terms);
+            if (CollectionUtils.isNotEmpty(fileIdInfoBaseDTOList)) {
+                caseAssistApply.setFileInfoBaseDTOList(fileIdInfoBaseDTOList.get(0).getFileList());
+            }
+            return caseAssistApply;
+        }catch(Exception e ){
+            log.error("[CaseAssistApplyService.caseAssistApplyByCaseId]调用失败,异常信息:"+e, e);
+            throw new ServiceException("CaseAssistApplyService.caseAssistApplyByCaseId", e);
         }
-        return caseAssistApply;
     }
 
     /**

--
Gitblit v1.8.0