mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-10-31 18:28:43 +08:00 
			
		
		
		
	Merge remote-tracking branch 'yudao/develop' into develop
# Conflicts: # yudao-module-crm/yudao-module-crm-biz/src/main/java/cn/iocoder/yudao/module/crm/service/contract/CrmContractServiceImpl.java
This commit is contained in:
		| @@ -58,7 +58,7 @@ public class CrmContractRespVO { | ||||
|  | ||||
|     @Schema(description = "工作流编号", example = "1043") | ||||
|     @ExcelProperty("工作流编号") | ||||
|     private Long processInstanceId; | ||||
|     private String processInstanceId; | ||||
|  | ||||
|     @Schema(description = "审批状态", requiredMode = Schema.RequiredMode.REQUIRED, example = "0") | ||||
|     @ExcelProperty("审批状态") | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| package cn.iocoder.yudao.module.crm.service.contract; | ||||
|  | ||||
| import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||
| import cn.iocoder.yudao.module.bpm.api.listener.dto.BpmResultListenerRespDTO; | ||||
| import cn.iocoder.yudao.module.crm.controller.admin.contract.vo.CrmContractPageReqVO; | ||||
| import cn.iocoder.yudao.module.crm.controller.admin.contract.vo.CrmContractSaveReqVO; | ||||
| import cn.iocoder.yudao.module.crm.controller.admin.contract.vo.CrmContractTransferReqVO; | ||||
| @@ -72,9 +71,10 @@ public interface CrmContractService { | ||||
|     /** | ||||
|      * 更新合同流程审批结果 | ||||
|      * | ||||
|      * @param event 审批结果 | ||||
|      * @param id 合同编号 | ||||
|      * @param bpmResult BPM 审批结果 | ||||
|      */ | ||||
|     void updateContractAuditStatus(BpmResultListenerRespDTO event); | ||||
|     void updateContractAuditStatus(Long id, Integer bpmResult); | ||||
|  | ||||
|     /** | ||||
|      * 获得合同 | ||||
|   | ||||
| @@ -8,9 +8,9 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult; | ||||
| import cn.iocoder.yudao.framework.common.util.number.MoneyUtils; | ||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||
| import cn.iocoder.yudao.framework.common.util.object.ObjectUtils; | ||||
| import cn.iocoder.yudao.module.bpm.api.listener.dto.BpmResultListenerRespDTO; | ||||
| import cn.iocoder.yudao.module.bpm.api.task.BpmProcessInstanceApi; | ||||
| import cn.iocoder.yudao.module.bpm.api.task.dto.BpmProcessInstanceCreateReqDTO; | ||||
| import cn.iocoder.yudao.module.bpm.enums.task.BpmProcessInstanceResultEnum; | ||||
| import cn.iocoder.yudao.module.crm.controller.admin.contract.vo.CrmContractPageReqVO; | ||||
| import cn.iocoder.yudao.module.crm.controller.admin.contract.vo.CrmContractSaveReqVO; | ||||
| import cn.iocoder.yudao.module.crm.controller.admin.contract.vo.CrmContractTransferReqVO; | ||||
| @@ -34,6 +34,7 @@ import com.mzt.logapi.context.LogRecordContext; | ||||
| import com.mzt.logapi.service.impl.DiffParseFunction; | ||||
| import com.mzt.logapi.starter.annotation.LogRecord; | ||||
| import jakarta.annotation.Resource; | ||||
| import lombok.extern.slf4j.Slf4j; | ||||
| import org.springframework.stereotype.Service; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
| import org.springframework.validation.annotation.Validated; | ||||
| @@ -47,8 +48,6 @@ import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionU | ||||
| import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.*; | ||||
| import static cn.iocoder.yudao.module.crm.enums.ErrorCodeConstants.*; | ||||
| import static cn.iocoder.yudao.module.crm.enums.LogRecordConstants.*; | ||||
| import static cn.iocoder.yudao.module.crm.util.CrmAuditStatusUtils.convertAuditStatus; | ||||
| import static cn.iocoder.yudao.module.crm.util.CrmAuditStatusUtils.isEndResult; | ||||
|  | ||||
| /** | ||||
|  * CRM 合同 Service 实现类 | ||||
| @@ -57,6 +56,7 @@ import static cn.iocoder.yudao.module.crm.util.CrmAuditStatusUtils.isEndResult; | ||||
|  */ | ||||
| @Service | ||||
| @Validated | ||||
| @Slf4j | ||||
| public class CrmContractServiceImpl implements CrmContractService { | ||||
|  | ||||
|     /** | ||||
| @@ -130,7 +130,7 @@ public class CrmContractServiceImpl implements CrmContractService { | ||||
|         // 1.2 只有草稿、审批中,可以编辑; | ||||
|         if (!ObjectUtils.equalsAny(contract.getAuditStatus(), CrmAuditStatusEnum.DRAFT.getStatus(), | ||||
|                 CrmAuditStatusEnum.PROCESS.getStatus())) { | ||||
|             throw exception(CONTRACT_UPDATE_FAIL_EDITING_PROHIBITED); | ||||
|             throw exception(CONTRACT_UPDATE_FAIL_NOT_DRAFT); | ||||
|         } | ||||
|         // 1.3 校验产品项的有效性 | ||||
|         List<CrmContractProductDO> contractProducts = validateContractProducts(updateReqVO.getProducts()); | ||||
| @@ -292,15 +292,22 @@ public class CrmContractServiceImpl implements CrmContractService { | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void updateContractAuditStatus(BpmResultListenerRespDTO event) { | ||||
|         // 判断下状态是否符合预期 | ||||
|         if (!isEndResult(event.getResult())) { | ||||
|             return; | ||||
|     public void updateContractAuditStatus(Long id, Integer bpmResult) { | ||||
|         // 1.1 校验合同是否存在 | ||||
|         CrmContractDO contract = validateContractExists(id); | ||||
|         // 1.2 只有审批中,可以更新审批结果 | ||||
|         if (ObjUtil.notEqual(contract.getAuditStatus(), CrmAuditStatusEnum.PROCESS.getStatus())) { | ||||
|             log.error("[updateContractAuditStatus][contract({}) 不处于审批中,无法更新审批结果({})]", | ||||
|                     contract.getId(), bpmResult); | ||||
|             throw exception(CONTRACT_UPDATE_AUDIT_STATUS_FAIL_NOT_PROCESS); | ||||
|         } | ||||
|         convertAuditStatus(event); | ||||
|         // 更新合同状态 | ||||
|         contractMapper.updateById(new CrmContractDO().setId(Long.parseLong(event.getBusinessKey())) | ||||
|                 .setAuditStatus(event.getResult())); | ||||
|  | ||||
|         // 2. 更新合同审批结果 | ||||
|         Integer auditStatus = BpmProcessInstanceResultEnum.APPROVE.getResult().equals(bpmResult) ? CrmAuditStatusEnum.APPROVE.getStatus() | ||||
|                 : BpmProcessInstanceResultEnum.REJECT.getResult().equals(bpmResult) ? CrmAuditStatusEnum.REJECT.getStatus() | ||||
|                 : BpmProcessInstanceResultEnum.CANCEL.getResult(); | ||||
|         Assert.notNull(auditStatus, "BPM 审批结果({}) 转换失败", bpmResult); | ||||
|         contractMapper.updateById(new CrmContractDO().setId(id).setAuditStatus(auditStatus)); | ||||
|     } | ||||
|  | ||||
|     //======================= 查询相关 ======================= | ||||
|   | ||||
| @@ -1,20 +1,19 @@ | ||||
| package cn.iocoder.yudao.module.crm.service.contract.listener; | ||||
|  | ||||
| import cn.iocoder.yudao.module.bpm.api.listener.BpmResultListenerApi; | ||||
| import cn.iocoder.yudao.module.bpm.api.listener.dto.BpmResultListenerRespDTO; | ||||
| import cn.iocoder.yudao.module.bpm.event.BpmProcessInstanceResultEvent; | ||||
| import cn.iocoder.yudao.module.bpm.event.BpmProcessInstanceResultEventListener; | ||||
| import cn.iocoder.yudao.module.crm.service.contract.CrmContractService; | ||||
| import cn.iocoder.yudao.module.crm.service.contract.CrmContractServiceImpl; | ||||
| import jakarta.annotation.Resource; | ||||
| import org.springframework.stereotype.Component; | ||||
|  | ||||
| // TODO @芋艿:后续改成支持 RPC | ||||
| /** | ||||
|  * 合同审批的结果的监听器实现类 | ||||
|  * | ||||
|  * @author HUIHUI | ||||
|  */ | ||||
| @Component | ||||
| public class CrmContractResultListener implements BpmResultListenerApi { | ||||
| public class CrmContractResultListener extends BpmProcessInstanceResultEventListener { | ||||
|  | ||||
|     @Resource | ||||
|     private CrmContractService contractService; | ||||
| @@ -25,8 +24,8 @@ public class CrmContractResultListener implements BpmResultListenerApi { | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void onEvent(BpmResultListenerRespDTO event) { | ||||
|         contractService.updateContractAuditStatus(event); | ||||
|     protected void onEvent(BpmProcessInstanceResultEvent event) { | ||||
|         contractService.updateContractAuditStatus(Long.parseLong(event.getBusinessKey()), event.getResult()); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 puhui999
					puhui999