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