From e328acd399dae70ccdf413a6dce94272563477b5 Mon Sep 17 00:00:00 2001
From: zhanghua <314079846@qq.com>
Date: 星期一, 18 十二月 2023 15:03:06 +0800
Subject: [PATCH] 格式调整

---
 ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java |   83 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 82 insertions(+), 1 deletions(-)

diff --git a/ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java b/ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java
index d5e4334..ce83cb6 100644
--- a/ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java
+++ b/ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java
@@ -1,23 +1,41 @@
 package com.ycl.service.caseHandler.impl;
 
+import com.alibaba.druid.support.json.JSONUtils;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.google.gson.JsonObject;
 import com.ycl.common.constant.BaseCaseStatus;
+import com.ycl.common.constant.StepName;
+import com.ycl.common.dingding.DingCommon;
+import com.ycl.controller.user.UmsAdminController;
 import com.ycl.dto.caseHandler.DispatchInfoParam;
 import com.ycl.entity.caseHandler.BaseCase;
 import com.ycl.entity.caseHandler.DispatchInfo;
+import com.ycl.entity.caseHandler.DisposeRecord;
+import com.ycl.entity.caseHandler.WorkflowConfigStep;
+import com.ycl.entity.user.UmsAdmin;
+import com.ycl.exception.ApiException;
 import com.ycl.mapper.caseHandler.BaseCaseMapper;
 import com.ycl.mapper.caseHandler.DispatchInfoMapper;
+import com.ycl.mapper.caseHandler.DisposeRecordMapper;
+import com.ycl.mapper.caseHandler.WorkflowConfigStepMapper;
 import com.ycl.service.caseHandler.IDispatchHandleService;
+import com.ycl.service.user.UmsAdminService;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
+import java.time.LocalDateTime;
 import java.util.Date;
 
 /**
  * <p>
- *  璋冨害澶勭悊 鏈嶅姟瀹炵幇绫�
+ * 璋冨害澶勭悊 鏈嶅姟瀹炵幇绫�
  * </p>
  *
  * @author mg
@@ -25,11 +43,21 @@
  */
 @Service
 @Transactional
+@Slf4j
 public class IDispatchHandleServiceImpl extends ServiceImpl<DispatchInfoMapper, DispatchInfo> implements IDispatchHandleService {
 
     @Resource
     BaseCaseMapper baseCaseMapper;
+    @Resource
+    DisposeRecordMapper disposeRecordMapper;
+    @Resource
+    WorkflowConfigStepMapper workflowConfigStepMapper;
+    @Autowired
+    DingCommon dingCommon;
+    @Autowired
+    UmsAdminService umsAdminService;
     @Override
+    @Transactional
     public DispatchInfo dispatch(DispatchInfoParam dispatchInfoParam) {
         //鏂板璋冨害淇℃伅
         DispatchInfo dispatchInfo = new DispatchInfo();
@@ -41,6 +69,59 @@
         baseCase.setId(dispatchInfoParam.getBaseCaseId());
         baseCase.setState(BaseCaseStatus.DISPATCH);
         baseCaseMapper.updateById(baseCase);
+
+        QueryWrapper<WorkflowConfigStep> stepqurey = new QueryWrapper<>();
+        stepqurey.eq("name", StepName.DISPATCH.getName());
+        WorkflowConfigStep workflowConfigStep = workflowConfigStepMapper.selectOne(stepqurey);
+
+        if (workflowConfigStep == null) {
+            throw new ApiException("鏈煡璇㈠埌璇ユ祦绋嬬幆鑺�");
+        }
+
+        UpdateWrapper<DisposeRecord> updateWrapper = new UpdateWrapper<>();
+        updateWrapper.eq("base_case_id", baseCase.getId()).eq("workflow_config_step_id", workflowConfigStep.getId());
+
+        //淇敼璋冨害璁板綍
+        DisposeRecord disposeRecord = new DisposeRecord();
+        disposeRecord.setHandlerId(dispatchInfo.getCreateUser());
+        disposeRecord.setResult(dispatchInfo.getDispatchOpinion());
+        //璋冨害宸茬粨鏉�
+        disposeRecord.setState(1);
+        disposeRecord.setEndTime(LocalDateTime.now());
+        disposeRecordMapper.update(disposeRecord, updateWrapper);
+
+        QueryWrapper<WorkflowConfigStep> stepNextqurey = new QueryWrapper<>();
+        stepNextqurey.eq("workflow_config_id", workflowConfigStep.getWorkflowConfigId());
+        stepNextqurey.eq("seq", workflowConfigStep.getSeq() + 1);
+        WorkflowConfigStep stepNext = workflowConfigStepMapper.selectOne(stepNextqurey);
+
+        //娣诲姞涓嬩竴姝ヨ褰�
+        DisposeRecord stepNextRecord = new DisposeRecord();
+        stepNextRecord.setBaseCaseId(baseCase.getId());
+        stepNextRecord.setWorkflowConfigStepId(stepNext.getId());
+        stepNextRecord.setStepName(stepNext.getName());
+        stepNextRecord.setLimitTime(dispatchInfoParam.getDisposeDate());
+        stepNextRecord.setHandlerId(dispatchInfoParam.getLawEnforcer());
+        stepNextRecord.setHandlerRoleId(stepNext.getRoleId());
+        //涓婁紶澶勭疆鏈粨鏉�
+        stepNextRecord.setState(0);
+        stepNextRecord.setStartTime(LocalDateTime.now());
+        stepNextRecord.setCreateUser(dispatchInfo.getCreateUser());
+        stepNextRecord.setCreateTime(LocalDateTime.now());
+
+        disposeRecordMapper.insert(stepNextRecord);
+        //鍙戦�侀拤閽夊伐浣滈�氱煡娑堟伅
+        log.info("鍙戦�佷竴鏉″伐浣滈�氱煡");
+        BaseCase baseCaseForCode = baseCaseMapper.selectById(dispatchInfoParam.getBaseCaseId());
+        String baseCaseCode = baseCaseForCode.getCode();
+        String text ="鎮ㄦ湁涓�鏉″伐浣滈�氱煡  \n  " +
+                " 閬傛槍浜戞墽娉曪細鏈夊緟澶勭悊鐨勪换鍔�  \n  " +
+                "路鎮ㄦ湁1鏉″緟澶勭悊浜嬩欢銆備簨浠剁紪鍙�:  \n  " +
+                baseCaseCode;
+        Long lawEnforcer = dispatchInfoParam.getLawEnforcer();
+        UmsAdmin user = umsAdminService.getById(lawEnforcer);
+        dingCommon.sendDingMsgStr(user.getAccountId()+"",text);
+
         return dispatchInfo;
     }
 

--
Gitblit v1.8.0