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/CheckHandleServiceImpl.java |   91 +++++++++++++++++++++++++++++++++------------
 1 files changed, 66 insertions(+), 25 deletions(-)

diff --git a/ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/CheckHandleServiceImpl.java b/ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/CheckHandleServiceImpl.java
index 62d6428..b0a9382 100644
--- a/ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/CheckHandleServiceImpl.java
+++ b/ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/CheckHandleServiceImpl.java
@@ -1,10 +1,12 @@
 package com.ycl.service.caseHandler.impl;
 
 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.ycl.common.constant.BaseCaseStatus;
+import com.ycl.common.constant.CheckResult;
 import com.ycl.common.constant.StepName;
-import com.ycl.dto.caseHandler.ChechParam;
+import com.ycl.dto.caseHandler.CheckParam;
 import com.ycl.entity.caseHandler.BaseCase;
 import com.ycl.entity.caseHandler.DisposeRecord;
 import com.ycl.entity.caseHandler.WorkflowConfigStep;
@@ -18,6 +20,7 @@
 
 import javax.annotation.Resource;
 import java.time.LocalDateTime;
+import java.util.List;
 
 /**
  * <p>
@@ -40,37 +43,63 @@
     WorkflowConfigStepMapper workflowConfigStepMapper;
 
     @Override
-    public Boolean check(ChechParam chechParam) {
-         //淇敼妗堜欢鐘舵�佷负瀹℃牳
+    public Boolean check(CheckParam checkParam) {
+
+        QueryWrapper<WorkflowConfigStep> stepQurey = new QueryWrapper<>();
+        stepQurey.eq("name", StepName.CHECK.getName());
+        WorkflowConfigStep workflowConfigStep = workflowConfigStepMapper.selectOne(stepQurey);
+        //淇敼妗堜欢鐘舵�佷负瀹℃牳
         BaseCase baseCase = new BaseCase();
-        baseCase.setId(chechParam.getBaseCaseId());
+        baseCase.setId(checkParam.getBaseCaseId());
+        baseCase.setAuditOpinion(checkParam.getCheckOpinion());
+        //淇敼鏍告煡璁板綍
+        DisposeRecord disposeRecord = new DisposeRecord();
+        //椹冲洖澶勭悊
+        if (CheckResult.REJECT.getName().equals(checkParam.getResult())) {
+            QueryWrapper<WorkflowConfigStep> lastNextqurey = new QueryWrapper<>();
+            lastNextqurey.eq("workflow_config_id", workflowConfigStep.getWorkflowConfigId());
+            lastNextqurey.eq("seq", workflowConfigStep.getSeq());
+            WorkflowConfigStep lastStep = workflowConfigStepMapper.selectOne(lastNextqurey);
+            //鍒犻櫎褰撳墠鏁版嵁
+            UpdateWrapper<DisposeRecord> deleteWrapper = new UpdateWrapper<>();
+            deleteWrapper.eq("base_case_id", checkParam.getBaseCaseId()).eq("workflow_config_step_id", lastStep.getId());
+            disposeRecordMapper.delete(deleteWrapper);
+            //淇敼鐘舵�佷负涓婁竴姝ョ姸鎬�
+            QueryWrapper<WorkflowConfigStep> lastLastNextqurey = new QueryWrapper<>();
+            lastLastNextqurey.eq("workflow_config_id", workflowConfigStep.getWorkflowConfigId());
+            lastLastNextqurey.eq("seq", workflowConfigStep.getSeq() - 1);
+            WorkflowConfigStep lastLastStep = workflowConfigStepMapper.selectOne(lastLastNextqurey);
+
+            UpdateWrapper<DisposeRecord> updateWrapper = new UpdateWrapper<>();
+            updateWrapper.eq("base_case_id", checkParam.getBaseCaseId()).eq("workflow_config_step_id", lastLastStep.getId());
+
+            //澶勭悊鏈紑濮�
+            disposeRecord.setState(0);
+            disposeRecordMapper.update(disposeRecord, updateWrapper);
+            //璋冨害
+            baseCase.setState(BaseCaseStatus.DISPATCH);
+            baseCaseMapper.updateById(baseCase);
+            return true;
+        }
+        //鏍告煡
         baseCase.setState(BaseCaseStatus.CHECK);
-        baseCase.setAuditOpinion(chechParam.getCheckOpinion());
         baseCaseMapper.updateById(baseCase);
 
-
-        QueryWrapper<WorkflowConfigStep> stepqurey = new QueryWrapper<>();
-        stepqurey.eq("name", StepName.CHECK.getName());
-        WorkflowConfigStep workflowConfigStep = workflowConfigStepMapper.selectOne(stepqurey);
 
         if (workflowConfigStep == null) {
             throw new ApiException("鏈煡璇㈠埌璇ユ祦绋嬬幆鑺�");
         }
-        //娣诲姞璋冨害璁板綍
-        DisposeRecord disposeRecord = new DisposeRecord();
-        disposeRecord.setBaseCaseId(baseCase.getId());
-        disposeRecord.setWorkflowConfigStepId(workflowConfigStep.getId());
-        disposeRecord.setStepName(workflowConfigStep.getName());
-        disposeRecord.setHandlerRoleId(workflowConfigStep.getRoleId());
-        disposeRecord.setHandlerId(chechParam.getCurrentUser());
-        disposeRecord.setState(1);
-        disposeRecord.setStartTime(LocalDateTime.now());
-        disposeRecord.setEndTime(LocalDateTime.now());
-        disposeRecord.setResult(chechParam.getResult());
-        disposeRecord.setCreateUser(chechParam.getCurrentUser());
-        disposeRecord.setCreateTime(LocalDateTime.now());
 
-        disposeRecordMapper.insert(disposeRecord);
+        UpdateWrapper<DisposeRecord> updateWrapper = new UpdateWrapper<>();
+        updateWrapper.eq("base_case_id", baseCase.getId()).eq("workflow_config_step_id", workflowConfigStep.getId());
+
+        disposeRecord.setHandlerId(checkParam.getCurrentUser());
+        //鏍告煡宸茬粨鏉�
+        disposeRecord.setState(1);
+        disposeRecord.setResult(checkParam.getResult());
+        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);
@@ -82,14 +111,26 @@
         stepNextRecord.setWorkflowConfigStepId(stepNext.getId());
         stepNextRecord.setStepName(stepNext.getName());
         stepNextRecord.setHandlerRoleId(stepNext.getRoleId());
-        stepNextRecord.setHandlerId(chechParam.getCurrentUser());
         //涓婁紶澶勭疆鏈粨鏉�
         stepNextRecord.setState(0);
         stepNextRecord.setStartTime(LocalDateTime.now());
-        stepNextRecord.setCreateUser(chechParam.getCurrentUser());
+        stepNextRecord.setCreateUser(checkParam.getCurrentUser());
         stepNextRecord.setCreateTime(LocalDateTime.now());
 
         disposeRecordMapper.insert(stepNextRecord);
         return true;
     }
+
+    @Override
+    public Boolean checkBatch(List<Long> ids, Long userId) {
+        ids.forEach(id -> {
+            CheckParam checkParam = new CheckParam();
+            checkParam.setCurrentUser(userId);
+            checkParam.setBaseCaseId(id);
+            checkParam.setResult(CheckResult.PASS.getName());
+            checkParam.setCheckOpinion("鍚屾剰");
+            this.check(checkParam);
+        });
+        return null;
+    }
 }

--
Gitblit v1.8.0