From a8c48babd4bd3e181b0f0bb1130c4c900edcacc2 Mon Sep 17 00:00:00 2001
From: mg <maokecheng@163.com>
Date: 星期三, 12 十月 2022 18:01:03 +0800
Subject: [PATCH] 优化调度,审核流程

---
 ycl-platform/src/main/java/com/ycl/dto/caseHandler/DispatchInfoParam.java                   |    9 ++
 ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java |   56 ++++++++++++++++++
 ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/CheckHandleServiceImpl.java     |   63 ++++++++++++++++++--
 ycl-platform/src/main/java/com/ycl/controller/caseHandler/CheckHandleController.java        |    4 +
 ycl-platform/src/main/java/com/ycl/controller/caseHandler/DispatchHandleController.java     |    2 
 ycl-platform/src/main/java/com/ycl/dto/caseHandler/ChechParam.java                          |    8 ++
 ycl-platform/src/main/java/com/ycl/common/constant/StepName.java                            |   26 ++++++++
 ycl-platform/src/main/java/com/ycl/entity/caseHandler/DisposeRecord.java                    |    2 
 8 files changed, 159 insertions(+), 11 deletions(-)

diff --git a/ycl-platform/src/main/java/com/ycl/common/constant/StepName.java b/ycl-platform/src/main/java/com/ycl/common/constant/StepName.java
new file mode 100644
index 0000000..59e809b
--- /dev/null
+++ b/ycl-platform/src/main/java/com/ycl/common/constant/StepName.java
@@ -0,0 +1,26 @@
+package com.ycl.common.constant;
+
+public enum StepName {
+
+    DISPATCH("01", "璋冨害"),
+    DISPOSE("02", "涓婁紶澶勭疆缁撴灉"),
+    CHECK("03", "鏍告煡"),
+    CLOSING_REGISTER("04", "缁撴");
+
+
+    private String code;
+    private String name;
+
+    StepName(String code, String name) {
+        this.code = code;
+        this.name = name;
+    }
+
+    public String getCode() {
+        return code;
+    }
+
+    public String getName() {
+        return name;
+    }
+}
\ No newline at end of file
diff --git a/ycl-platform/src/main/java/com/ycl/controller/caseHandler/CheckHandleController.java b/ycl-platform/src/main/java/com/ycl/controller/caseHandler/CheckHandleController.java
index 2d9d80e..8dbc0d8 100644
--- a/ycl-platform/src/main/java/com/ycl/controller/caseHandler/CheckHandleController.java
+++ b/ycl-platform/src/main/java/com/ycl/controller/caseHandler/CheckHandleController.java
@@ -1,11 +1,13 @@
 package com.ycl.controller.caseHandler;
 
 import com.ycl.api.CommonResult;
+import com.ycl.bo.AdminUserDetails;
 import com.ycl.dto.caseHandler.ChechParam;
 import com.ycl.service.caseHandler.ICheckHandleService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.security.core.context.SecurityContextHolder;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
 
@@ -30,6 +32,8 @@
     @RequestMapping(value = "/check", method = RequestMethod.POST)
     @ResponseBody
     public CommonResult check(@Validated @RequestBody ChechParam chechParam) {
+        AdminUserDetails user = (AdminUserDetails) SecurityContextHolder.getContext().getAuthentication().getPrincipal();
+        chechParam.setCurrentUser(user.getUserId());
         return CommonResult.success(iCheckHandleService.check(chechParam));
     }
 }
diff --git a/ycl-platform/src/main/java/com/ycl/controller/caseHandler/DispatchHandleController.java b/ycl-platform/src/main/java/com/ycl/controller/caseHandler/DispatchHandleController.java
index d3ffe96..96244c8 100644
--- a/ycl-platform/src/main/java/com/ycl/controller/caseHandler/DispatchHandleController.java
+++ b/ycl-platform/src/main/java/com/ycl/controller/caseHandler/DispatchHandleController.java
@@ -52,6 +52,8 @@
     @RequestMapping(value = "/dispatch", method = RequestMethod.POST)
     @ResponseBody
     public CommonResult<DispatchInfo> dispatch(@Validated @RequestBody DispatchInfoParam dispatchInfoParam) {
+        AdminUserDetails user = (AdminUserDetails) SecurityContextHolder.getContext().getAuthentication().getPrincipal();
+        dispatchInfoParam.setCreateUser(user.getUserId());
         return CommonResult.success(iDispatchHandleService.dispatch(dispatchInfoParam));
     }
 
diff --git a/ycl-platform/src/main/java/com/ycl/dto/caseHandler/ChechParam.java b/ycl-platform/src/main/java/com/ycl/dto/caseHandler/ChechParam.java
index ceddd69..0ebaa9a 100644
--- a/ycl-platform/src/main/java/com/ycl/dto/caseHandler/ChechParam.java
+++ b/ycl-platform/src/main/java/com/ycl/dto/caseHandler/ChechParam.java
@@ -18,7 +18,7 @@
     /**
      * 妗堜欢id
      */
-    @ApiModelProperty(value = "妗堜欢id")
+    @ApiModelProperty(value = "妗堜欢id", required = true)
     private Long baseCaseId;
     /**
      * 褰撳墠澶勭悊浜�
@@ -35,4 +35,10 @@
      */
     @ApiModelProperty(value = "瀹℃牳鎰忚")
     private String checkOpinion;
+    /**
+     * 瀹℃牳缁撴灉
+     */
+    @ApiModelProperty(value = "瀹℃牳缁撴灉")
+    private String result;
+
 }
diff --git a/ycl-platform/src/main/java/com/ycl/dto/caseHandler/DispatchInfoParam.java b/ycl-platform/src/main/java/com/ycl/dto/caseHandler/DispatchInfoParam.java
index 59c9241..fa0b0fe 100644
--- a/ycl-platform/src/main/java/com/ycl/dto/caseHandler/DispatchInfoParam.java
+++ b/ycl-platform/src/main/java/com/ycl/dto/caseHandler/DispatchInfoParam.java
@@ -18,8 +18,9 @@
     /**
      * 妗堜欢id
      */
-    @ApiModelProperty(value = "妗堜欢id")
+    @ApiModelProperty(value = "妗堜欢id", required = true)
     private Long baseCaseId;
+
     /**
      * 鎵ф硶浜哄憳
      */
@@ -61,4 +62,10 @@
     @ApiModelProperty(value = "娲鹃仯鎰忚")
     private String dispatchOpinion;
 
+    /**
+     * 褰撳墠鐧诲綍浜�
+     */
+    @ApiModelProperty(value = "娲鹃仯鎰忚")
+    private Long createUser;
+
 }
diff --git a/ycl-platform/src/main/java/com/ycl/entity/caseHandler/DisposeRecord.java b/ycl-platform/src/main/java/com/ycl/entity/caseHandler/DisposeRecord.java
index 8b67f66..5a9644c 100644
--- a/ycl-platform/src/main/java/com/ycl/entity/caseHandler/DisposeRecord.java
+++ b/ycl-platform/src/main/java/com/ycl/entity/caseHandler/DisposeRecord.java
@@ -85,7 +85,7 @@
      */
     @TableField("handler_id")
     @ApiModelProperty(value = "瀹為檯澶勭悊浜�")
-    private Integer handlerId;
+    private Long handlerId;
 
     /**
      * 鍒涘缓浜�
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 6a74ac8..62d6428 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,17 +1,23 @@
 package com.ycl.service.caseHandler.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ycl.common.constant.BaseCaseStatus;
+import com.ycl.common.constant.StepName;
 import com.ycl.dto.caseHandler.ChechParam;
 import com.ycl.entity.caseHandler.BaseCase;
 import com.ycl.entity.caseHandler.DisposeRecord;
+import com.ycl.entity.caseHandler.WorkflowConfigStep;
+import com.ycl.exception.ApiException;
 import com.ycl.mapper.caseHandler.BaseCaseMapper;
 import com.ycl.mapper.caseHandler.DisposeRecordMapper;
+import com.ycl.mapper.caseHandler.WorkflowConfigStepMapper;
 import com.ycl.service.caseHandler.ICheckHandleService;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
+import java.time.LocalDateTime;
 
 /**
  * <p>
@@ -28,21 +34,62 @@
     @Resource
     BaseCaseMapper baseCaseMapper;
 
+    @Resource
+    DisposeRecordMapper disposeRecordMapper;
+    @Resource
+    WorkflowConfigStepMapper workflowConfigStepMapper;
+
     @Override
     public Boolean check(ChechParam chechParam) {
-          //鏂板娴佺▼璁板綍淇℃伅
-        DisposeRecord disposeRecord = new DisposeRecord();
-        disposeRecord.setBaseCaseId(chechParam.getBaseCaseId());
-        disposeRecord.setWorkflowConfigStepId(3L);
-        disposeRecord.setState(chechParam.getStatus());
-        disposeRecord.setCreateUser(chechParam.getCurrentUser());
-        disposeRecord.setStepName("鏍告煡");
-        baseMapper.insert(disposeRecord);
          //淇敼妗堜欢鐘舵�佷负瀹℃牳
         BaseCase baseCase = new BaseCase();
         baseCase.setId(chechParam.getBaseCaseId());
         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);
+        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.setHandlerRoleId(stepNext.getRoleId());
+        stepNextRecord.setHandlerId(chechParam.getCurrentUser());
+        //涓婁紶澶勭疆鏈粨鏉�
+        stepNextRecord.setState(0);
+        stepNextRecord.setStartTime(LocalDateTime.now());
+        stepNextRecord.setCreateUser(chechParam.getCurrentUser());
+        stepNextRecord.setCreateTime(LocalDateTime.now());
+
+        disposeRecordMapper.insert(stepNextRecord);
         return true;
     }
 }
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..2895f7e 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,18 +1,26 @@
 package com.ycl.service.caseHandler.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ycl.common.constant.BaseCaseStatus;
+import com.ycl.common.constant.StepName;
 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.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 org.springframework.beans.BeanUtils;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
+import java.time.LocalDateTime;
 import java.util.Date;
 
 /**
@@ -29,6 +37,10 @@
 
     @Resource
     BaseCaseMapper baseCaseMapper;
+    @Resource
+    DisposeRecordMapper disposeRecordMapper;
+    @Resource
+    WorkflowConfigStepMapper workflowConfigStepMapper;
     @Override
     public DispatchInfo dispatch(DispatchInfoParam dispatchInfoParam) {
         //鏂板璋冨害淇℃伅
@@ -41,6 +53,50 @@
         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("鏈煡璇㈠埌璇ユ祦绋嬬幆鑺�");
+        }
+
+        //娣诲姞璋冨害璁板綍
+        DisposeRecord disposeRecord = new DisposeRecord();
+        disposeRecord.setBaseCaseId(baseCase.getId());
+        disposeRecord.setWorkflowConfigStepId(workflowConfigStep.getId());
+        disposeRecord.setStepName(workflowConfigStep.getName());
+        disposeRecord.setHandlerRoleId(workflowConfigStep.getRoleId());
+        disposeRecord.setHandlerId(dispatchInfo.getCreateUser());
+        //璋冨害宸茬粨鏉�
+        disposeRecord.setState(1);
+        disposeRecord.setStartTime(LocalDateTime.now());
+        disposeRecord.setEndTime(LocalDateTime.now());
+        disposeRecord.setCreateUser(dispatchInfo.getCreateUser());
+        disposeRecord.setCreateTime(LocalDateTime.now());
+
+        disposeRecordMapper.insert(disposeRecord);
+
+        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.setHandlerRoleId(stepNext.getRoleId());
+        stepNextRecord.setHandlerId(dispatchInfo.getCreateUser());
+        //涓婁紶澶勭疆鏈粨鏉�
+        stepNextRecord.setState(0);
+        stepNextRecord.setStartTime(LocalDateTime.now());
+        stepNextRecord.setCreateUser(dispatchInfo.getCreateUser());
+        stepNextRecord.setCreateTime(LocalDateTime.now());
+
+        disposeRecordMapper.insert(stepNextRecord);
         return dispatchInfo;
     }
 

--
Gitblit v1.8.0