package org.springblade.mdm.flow.excution.append; import lombok.extern.slf4j.Slf4j; import org.flowable.engine.delegate.DelegateExecution; import org.springblade.core.tool.utils.DateUtil; import org.springblade.mdm.flow.entity.FlowProgramFile; import org.springblade.mdm.flow.service.FlowCommonService; import org.springblade.mdm.flow.service.FlowProgramFileService; import org.springblade.mdm.flow.service.FlowProgramProperties; import org.springblade.mdm.program.entity.NcNode; import org.springblade.mdm.program.entity.NcProgramApproved; import org.springblade.mdm.program.service.NcNodeHisService; import org.springblade.mdm.program.service.NcNodeService; import org.springblade.mdm.program.service.NcProgramApprovedService; import org.springblade.mdm.utils.EntityUtil; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; /** * 程序补充流程(临时流程) 审批通过执行的事件 */ @Slf4j @Component("appendFinishListener") public class AppendFinishListener { @Autowired private FlowProgramFileService flowProgramFileService; @Autowired private NcProgramApprovedService approvedService; @Autowired private FlowCommonService flowCommonService; @Autowired private NcNodeService ncNodeService; @Autowired private NcNodeHisService nodeHisService; /** * 在流程结束时自动调用,(配置在审批结束事件的executelistener中了) * @param execution 执行对象 */ public void handle(DelegateExecution execution) { Date time = DateUtil.now(); // 执行业务逻辑 String instId = execution.getProcessInstanceId(); log.info("事件名称{},instid={}" , execution.getEventName(),instId); FlowProgramProperties props = flowCommonService.getProgramProperties(instId); String programName = NcNodeService.genProgramName(props.getDrawingNo(),props.getProcessNo(),props.getProcessEdition()); //临时流程,不处理树,只处理文件 NcNode tempPkgNode = new NcNode(); tempPkgNode.setNodeType(NcNode.TYPE_PROGRAM_PACKAGE); tempPkgNode.setIsLastEdition(1); tempPkgNode.setProcessNo(props.getProcessNo()); tempPkgNode.setMachineCode(props.getMachineCode()); tempPkgNode.setProcessName(props.getProcessName()); tempPkgNode.setProcessEdition(props.getProcessEdition()); tempPkgNode.setDrawingNoEdition(props.getDrawingNoEdition()); tempPkgNode.setName(programName); tempPkgNode.setParentIds("0,4"); tempPkgNode.setIsLocked(0); tempPkgNode.setCraftEdition(props.getCraftEdition()); tempPkgNode.setDrawingNo(props.getDrawingNo()); tempPkgNode.setProcessInstanceId(instId); ncNodeService.save(tempPkgNode); List newFlowFileList = flowProgramFileService.listByProcessInstanceId(props.getProcessInstanceId()); for(FlowProgramFile newFlowFile : newFlowFileList) { NcNode tempProgramNode = new NcNode(); BeanUtils.copyProperties(tempPkgNode,tempProgramNode); EntityUtil.clearBaseProperties(tempProgramNode); tempProgramNode.setNodeType(NcNode.TYPE_PROGRAM_FILE); tempProgramNode.setName(newFlowFile.getName()); tempProgramNode.setParentId(tempPkgNode.getId()); tempProgramNode.setParentIds(tempPkgNode.subNodeParentIds()); tempProgramNode.setProcessInstanceId(props.getProcessInstanceId()); tempProgramNode.setFlowProgramFileId(newFlowFile.getId()); ncNodeService.save(tempProgramNode); } addApproveTable(tempPkgNode,props); nodeHisService.mergeNodeToHisGeTime(time); log.info("程序补充流程已完成in AppendFinishListener"); } /** * 保存审批完成的记录 * @param packageNode * @param props */ void addApproveTable(NcNode packageNode,FlowProgramProperties props){ NcProgramApproved approved = new NcProgramApproved(); approved.setProgramName(packageNode.getName()); approved.setNcNodeId(packageNode.getId());//程序包节点id approved.setTitle(props.getTitle()); approved.setProgrammerId(props.getProgrammerId()); approvedService.save(approved); } }