From 2078aee230bc109d66da296da8b7f24377befa1b Mon Sep 17 00:00:00 2001
From: zhanghua <314079846@qq.com>
Date: 星期五, 20 十二月 2024 11:08:44 +0800
Subject: [PATCH] 1
---
ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java | 89 +++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 87 insertions(+), 2 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 7bb40d9..c32af93 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,43 @@
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.ycl.constant.BaseCaseStatus;
+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
@@ -25,11 +45,23 @@
*/
@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();
@@ -38,8 +70,61 @@
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();
+ DingMessage dingMessage = DingMessage.builder()
+ .accountId(accountId)
+ .baseCaseCode(baseCaseCode)
+ .createTime(new Date()).build();
+ dingMessageMapper.insert(dingMessage);
+
return dispatchInfo;
}
--
Gitblit v1.8.0