From 1cad14bca191807e18705c3a5526eda8151be439 Mon Sep 17 00:00:00 2001
From: zhanghua <314079846@qq.com>
Date: 星期一, 14 四月 2025 23:10:22 +0800
Subject: [PATCH] 批量审核和图片保存bug

---
 ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java |  103 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 102 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 dd4d8fe..35c6654 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,31 +1,132 @@
 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.message.DingMessage;
+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.mapper.message.DingMessageMapper;
 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
  * @since 2022-09-28
  */
 @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;
+    @Autowired
+    DingMessageMapper dingMessageMapper;
+
     @Override
+    @Transactional
     public DispatchInfo dispatch(DispatchInfoParam dispatchInfoParam) {
+        //鏂板璋冨害淇℃伅
         DispatchInfo dispatchInfo = new DispatchInfo();
         BeanUtils.copyProperties(dispatchInfoParam, dispatchInfo);
         dispatchInfo.setCreateTime(new Date());
         baseMapper.insert(dispatchInfo);
+        //淇敼妗堜欢鐘舵�佷负璋冨害
+        BaseCase baseCase = new BaseCase();
+        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);
+        //瀛橀拤閽夊伐浣滈�氱煡娑堟伅鍒版暟鎹簱
+        BaseCase baseCaseForCode = baseCaseMapper.selectById(dispatchInfoParam.getBaseCaseId());
+        String baseCaseCode = baseCaseForCode.getCode();
+        Long lawEnforcer = dispatchInfoParam.getLawEnforcer();
+        Long accountId = umsAdminService.getById(lawEnforcer).getAccountId();
+        if (accountId != null) {
+            DingMessage dingMessage = DingMessage.builder()
+                    .accountId(accountId)
+                    .baseCaseCode(baseCaseCode)
+                    .createTime(new Date()).build();
+            dingMessageMapper.insert(dingMessage);
+        }
         return dispatchInfo;
     }
 

--
Gitblit v1.8.0