From a4cd4c2d98392cd1036f36b96c262878743a7e63 Mon Sep 17 00:00:00 2001
From: zhanghua <314079846@qq.com>
Date: 星期四, 05 九月 2024 19:52:22 +0800
Subject: [PATCH] Merge branch 'master' of http://42.193.1.25:9521/r/sccg_server
---
ycl-platform/src/main/java/com/ycl/service/caseHandler/impl/IDispatchHandleServiceImpl.java | 101 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 100 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..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,31 +1,130 @@
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();
+ DingMessage dingMessage = DingMessage.builder()
+ .accountId(accountId)
+ .baseCaseCode(baseCaseCode)
+ .createTime(new Date()).build();
+ dingMessageMapper.insert(dingMessage);
+
return dispatchInfo;
}
--
Gitblit v1.8.0