old mode 100644
new mode 100755
| | |
| | | |
| | | import com.java110.common.dao.IWorkflowServiceDao; |
| | | import com.java110.core.base.smo.BaseServiceSMO; |
| | | import com.java110.core.smo.common.IWorkflowInnerServiceSMO; |
| | | import com.java110.core.smo.user.IUserInnerServiceSMO; |
| | | import com.java110.intf.common.IWorkflowInnerServiceSMO; |
| | | import com.java110.intf.user.IUserInnerServiceSMO; |
| | | import com.java110.dto.PageDto; |
| | | import com.java110.dto.user.UserDto; |
| | | import com.java110.dto.workflow.WorkflowAuditInfoDto; |
| | |
| | | import com.java110.utils.util.DateUtil; |
| | | import com.java110.utils.util.StringUtil; |
| | | import org.activiti.bpmn.BpmnAutoLayout; |
| | | import org.activiti.bpmn.model.BpmnModel; |
| | | import org.activiti.bpmn.model.EndEvent; |
| | | import org.activiti.bpmn.model.ExclusiveGateway; |
| | | import org.activiti.bpmn.model.FlowNode; |
| | | import org.activiti.bpmn.model.ParallelGateway; |
| | | import org.activiti.bpmn.model.Process; |
| | | import org.activiti.bpmn.model.SequenceFlow; |
| | | import org.activiti.bpmn.model.StartEvent; |
| | | import org.activiti.bpmn.model.UserTask; |
| | | import org.activiti.engine.HistoryService; |
| | | import org.activiti.engine.ProcessEngine; |
| | | import org.activiti.engine.ProcessEngines; |
| | | import org.activiti.engine.RepositoryService; |
| | | import org.activiti.engine.RuntimeService; |
| | | import org.activiti.engine.TaskService; |
| | | import org.activiti.bpmn.model.*; |
| | | import org.activiti.engine.*; |
| | | import org.activiti.engine.history.HistoricActivityInstance; |
| | | import org.activiti.engine.history.HistoricActivityInstanceQuery; |
| | | import org.activiti.engine.history.HistoricProcessInstance; |
| | |
| | | import java.io.InputStream; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.ArrayList; |
| | | import java.util.Date; |
| | | import java.util.Iterator; |
| | | import java.util.List; |
| | | |
| | |
| | | // 获取流程图图像字符流 |
| | | ProcessDiagramGenerator pec = processEngine.getProcessEngineConfiguration().getProcessDiagramGenerator(); |
| | | //配置字体 |
| | | InputStream imageStream = pec.generateDiagram(bpmnModel, "png", executedActivityIdList, flowIds, "宋体", "微软雅黑", "黑体", null, 2.0); |
| | | InputStream imageStream = pec.generateDiagram(bpmnModel, "png", executedActivityIdList, flowIds, "宋体", "宋体", "宋体", null, 2.0); |
| | | |
| | | |
| | | image = Base64Convert.ioToBase64(imageStream); |
| | |
| | | public String getWorkflowImage(@RequestBody WorkflowDto workflowDto) { |
| | | |
| | | ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine(); |
| | | String image = ""; |
| | | List<String> list = processEngine.getRepositoryService()// |
| | | .getDeploymentResourceNames(workflowDto.getProcessDefinitionKey()); |
| | | String image = ""; |
| | | |
| | | String resourceName = ""; |
| | | if (list != null && list.size() > 0) { |
| | | for (String name : list) { |
| | |
| | | |
| | | InputStream in = processEngine.getRepositoryService() |
| | | .getResourceAsStream(workflowDto.getProcessDefinitionKey(), resourceName); |
| | | |
| | | |
| | | try { |
| | | image = Base64Convert.ioToBase64(in); |
| | | } catch (IOException e) { |
| | |
| | | } |
| | | return image; |
| | | } |
| | | |
| | | |
| | | /** |
| | | * @Date:2017/11/24 |
| | |
| | | //结束节点 |
| | | process.addFlowElement(createEndEvent()); |
| | | |
| | | |
| | | //连线 |
| | | for (int y = 0; y < workflowStepDtos.size(); y++) { |
| | | WorkflowStepDto step = workflowStepDtos.get(y); |
| | |
| | | process.addFlowElement(createSequenceFlow("parallelGateway-fork" + y, "userTask" + y + u, "parallelGateway-fork-userTask" + y + u, "")); |
| | | process.addFlowElement(createSequenceFlow("userTask" + y + u, "parallelGateway-join" + y, "userTask-parallelGateway-join", "")); |
| | | if (u == (userList.size() - 1)) { |
| | | process.addFlowElement(createSequenceFlow("parallelGateway-join" + y, "repulse" + y, "parallelGateway-join-repulse", "${flag=='false'}")); |
| | | if (y == (workflowStepDtos.size() - 1)) { |
| | | process.addFlowElement(createSequenceFlow("parallelGateway-join" + y, "repulse" + y, "parallelGateway-join-repulse", "")); |
| | | } else { |
| | | process.addFlowElement(createSequenceFlow("parallelGateway-join" + y, "repulse" + y, "parallelGateway-join-repulse", "${flag=='false'}")); |
| | | } |
| | | process.addFlowElement(createSequenceFlow("repulse" + y, "task" + getNormal(workflowStepDtos, y), "repulse-task" + y, "${flag=='true'}")); |
| | | } |
| | | } |
| | | //最后一个节点 并行网关-汇聚到结束节点 |
| | | if (y == (workflowStepDtos.size() - 1)) { |
| | | process.addFlowElement(createSequenceFlow("repulse" + y, "endEvent", "parallelGateway-join-endEvent", "${flag=='false'}")); |
| | | } |
| | | |
| | | |
| | | process.addFlowElement(createSequenceFlow("repulse" + y, "endEvent", "parallelGateway-join-endEvent", "${flag=='false'}")); |
| | | |
| | | } else { |
| | | //普通流转 |
| | | //第一个节点 |
| | |
| | | } |
| | | } |
| | | //是否最后一个节点 |
| | | if (y == (workflowStepDtos.size() - 1)) { |
| | | /* if (y == (workflowStepDtos.size() - 1)) { |
| | | //审核节点到结束节点 |
| | | process.addFlowElement(createSequenceFlow("repulse" + y, "endEvent", "task" + y + "endEvent", "${flag=='false'}")); |
| | | process.addFlowElement(createSequenceFlow("task" + y, "repulse" + y, "task-repulse" + y, "${flag=='false'}")); |
| | | } else { |
| | | //审核节点到回退节点 |
| | | process.addFlowElement(createSequenceFlow("task" + y, "repulse" + y, "task-repulse" + y, "${flag=='false'}")); |
| | | }*/ |
| | | process.addFlowElement(createSequenceFlow("repulse" + y, "endEvent", "repulse" + y + "endEvent", "${flag=='false'}")); |
| | | if (y == (workflowStepDtos.size() - 1)) { |
| | | process.addFlowElement(createSequenceFlow("task" + y, "repulse" + y, "task-repulse" + y, "")); |
| | | } else { |
| | | process.addFlowElement(createSequenceFlow("task" + y, "repulse" + y, "task-repulse" + y, "${flag=='false'}")); |
| | | } |
| | | |
| | | process.addFlowElement(createSequenceFlow("repulse" + y, "task" + y, "repulse-task" + y, "${flag=='true'}")); |
| | | } |
| | | } |
| | |
| | | |
| | | /** |
| | | * 查询审核历史 |
| | | * |
| | | * @param workflowAuditInfoDto |
| | | * @return |
| | | */ |
| | |
| | | // 需要转换成HistoricActivityInstance |
| | | HistoricActivityInstance activityInstance = (HistoricActivityInstance) iterator |
| | | .next(); |
| | | if (activityInstance.getEndTime() == null) { |
| | | continue; |
| | | // if (activityInstance.getEndTime() == null) { |
| | | // continue; |
| | | // } |
| | | |
| | | tmpWorkflowAuditInfoDto = new WorkflowAuditInfoDto(); |
| | | tmpWorkflowAuditInfoDto.setAuditName(activityInstance.getActivityName()); |
| | | if (activityInstance.getEndTime() != null) { |
| | | tmpWorkflowAuditInfoDto.setAuditTime(DateUtil.getFormatTimeString(activityInstance.getEndTime(), DateUtil.DATE_FORMATE_STRING_A)); |
| | | tmpWorkflowAuditInfoDto.setStateName("完成"); |
| | | tmpWorkflowAuditInfoDto.setState(WorkflowAuditInfoDto.STATE_FINISH); |
| | | } else { |
| | | tmpWorkflowAuditInfoDto.setStateName("正在处理"); |
| | | tmpWorkflowAuditInfoDto.setState(WorkflowAuditInfoDto.STATE_NO); |
| | | } |
| | | Long time = activityInstance.getDurationInMillis() == null ? new Date().getTime() - activityInstance.getStartTime().getTime() |
| | | : activityInstance.getDurationInMillis(); |
| | | tmpWorkflowAuditInfoDto.setDuration(getCostTime(time)); |
| | | |
| | | //如果还没结束则不放里面 |
| | | List<Comment> comments = taskService.getTaskComments(activityInstance.getTaskId()); |
| | | if (comments == null || comments.size() < 1) { |
| | | continue; |
| | | String msg = ""; |
| | | if (comments != null && comments.size() > 0) { |
| | | for (Comment comment : comments) { |
| | | msg += (comment.getFullMessage() + "/"); |
| | | } |
| | | } |
| | | for (Comment comment : comments) { |
| | | tmpWorkflowAuditInfoDto = new WorkflowAuditInfoDto(); |
| | | tmpWorkflowAuditInfoDto.setAuditName(activityInstance.getActivityName()); |
| | | tmpWorkflowAuditInfoDto.setAuditTime(DateUtil.getFormatTimeString(activityInstance.getEndTime(), DateUtil.DATE_FORMATE_STRING_A)); |
| | | tmpWorkflowAuditInfoDto.setDuration(activityInstance.getDurationInMillis() + ""); |
| | | tmpWorkflowAuditInfoDto.setUserId(comment.getUserId()); |
| | | tmpWorkflowAuditInfoDto.setMessage(comment.getFullMessage()); |
| | | workflowAuditInfoDtos.add(tmpWorkflowAuditInfoDto); |
| | | } |
| | | msg = msg.endsWith("/") ? msg.substring(0, msg.length() - 1) : msg; |
| | | tmpWorkflowAuditInfoDto.setUserId(activityInstance.getAssignee()); |
| | | tmpWorkflowAuditInfoDto.setMessage(msg); |
| | | workflowAuditInfoDtos.add(tmpWorkflowAuditInfoDto); |
| | | } |
| | | return workflowAuditInfoDtos; |
| | | } |
| | |
| | | * @ReturnType:List |
| | | * @CreateDate:2014-6-25下午5:03:13 |
| | | * @UseFor :在 ACT_HI_ACTINST 表中找到对应流程实例的userTask节点 不包括startEvent |
| | | * <p> |
| | | * .finished() |
| | | */ |
| | | private List<HistoricActivityInstance> getHisUserTaskActivityInstanceList( |
| | | String processInstanceId) { |
| | | List<HistoricActivityInstance> hisActivityInstanceList = ((HistoricActivityInstanceQuery) historyService |
| | | .createHistoricActivityInstanceQuery() |
| | | .processInstanceId(processInstanceId).activityType("userTask") |
| | | .finished().orderByHistoricActivityInstanceEndTime().desc()) |
| | | .orderByHistoricActivityInstanceStartTime().asc()) |
| | | .list(); |
| | | return hisActivityInstanceList; |
| | | } |
| | |
| | | public void setUserInnerServiceSMOImpl(IUserInnerServiceSMO userInnerServiceSMOImpl) { |
| | | this.userInnerServiceSMOImpl = userInnerServiceSMOImpl; |
| | | } |
| | | |
| | | public String getCostTime(Long time) { |
| | | if (time == null) { |
| | | return "00:00"; |
| | | } |
| | | long hours = time / (1000 * 60 * 60); |
| | | long minutes = (time - hours * (1000 * 60 * 60)) / (1000 * 60); |
| | | String diffTime = ""; |
| | | if (minutes < 10) { |
| | | diffTime = hours + ":0" + minutes; |
| | | } else { |
| | | diffTime = hours + ":" + minutes; |
| | | } |
| | | return diffTime; |
| | | } |
| | | } |