From 05683f2b2bdbdbe21cf17ad523c21ab338bd1c54 Mon Sep 17 00:00:00 2001
From: wuxw <928255095@qq.com>
Date: 星期二, 19 七月 2022 21:49:55 +0800
Subject: [PATCH] 优化添加设备 功能

---
 service-common/src/main/java/com/java110/common/smo/impl/ContractApplyUserInnerServiceSMOImpl.java |  103 +++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 95 insertions(+), 8 deletions(-)

diff --git a/service-common/src/main/java/com/java110/common/smo/impl/ContractApplyUserInnerServiceSMOImpl.java b/service-common/src/main/java/com/java110/common/smo/impl/ContractApplyUserInnerServiceSMOImpl.java
index 4080f70..58a988f 100644
--- a/service-common/src/main/java/com/java110/common/smo/impl/ContractApplyUserInnerServiceSMOImpl.java
+++ b/service-common/src/main/java/com/java110/common/smo/impl/ContractApplyUserInnerServiceSMOImpl.java
@@ -9,15 +9,16 @@
 import com.java110.intf.common.IContractApplyUserInnerServiceSMO;
 import com.java110.intf.common.IWorkflowInnerServiceSMO;
 import com.java110.intf.store.IContractInnerServiceSMO;
+import com.java110.po.contract.ContractPo;
 import com.java110.utils.util.Assert;
+import com.java110.utils.util.FlowUtil;
 import com.java110.utils.util.StringUtil;
-import org.activiti.engine.HistoryService;
-import org.activiti.engine.ProcessEngine;
-import org.activiti.engine.RuntimeService;
-import org.activiti.engine.TaskService;
+import org.activiti.bpmn.model.*;
+import org.activiti.engine.*;
 import org.activiti.engine.history.HistoricProcessInstance;
 import org.activiti.engine.history.HistoricTaskInstance;
 import org.activiti.engine.history.HistoricTaskInstanceQuery;
+import org.activiti.engine.impl.identity.Authentication;
 import org.activiti.engine.query.Query;
 import org.activiti.engine.runtime.ProcessInstance;
 import org.activiti.engine.task.Task;
@@ -49,7 +50,8 @@
 
     @Autowired
     private IWorkflowInnerServiceSMO workflowInnerServiceSMOImpl;
-
+    @Autowired
+    private RepositoryService repositoryService;
 
     /**
      * 鍚姩娴佺▼
@@ -60,9 +62,11 @@
         //灏嗕俊鎭姞鍏ap,浠ヤ究浼犲叆娴佺▼涓�
         Map<String, Object> variables = new HashMap<String, Object>();
         variables.put("contractDto", contractDto);
-
+        variables.put("userId", contractDto.getCurrentUserId());
+        variables.put("startUserId", contractDto.getCurrentUserId());
+        variables.put("nextUserId", contractDto.getNextUserId());
         //寮�鍚祦绋�
-        ProcessInstance processInstance = runtimeService.startProcessInstanceByKey(getWorkflowDto(contractDto.getStoreId()), variables);
+        ProcessInstance processInstance = runtimeService.startProcessInstanceByKey(getWorkflowDto(contractDto.getStoreId()), contractDto.getContractId(), variables);
         //灏嗗緱鍒扮殑瀹炰緥娴佺▼id鍊艰祴缁欎箣鍓嶈缃殑鍙橀噺
         String processInstanceId = processInstance.getId();
         // System.out.println("娴佺▼寮�鍚垚鍔�.......瀹炰緥娴佺▼id:" + processInstanceId);
@@ -70,6 +74,7 @@
         contractDto.setProcessInstanceId(processInstanceId);
 
         return contractDto;
+
     }
 
     /**
@@ -115,6 +120,41 @@
             String business_key = pi.getBusinessKey();
             contractIds.add(business_key);
             taskBusinessKeyMap.put(business_key, task.getId());
+
+            //璁$畻鏄惁鏈� 瀹℃牳鎸夐挳
+            BpmnModel bpmnModel = repositoryService.getBpmnModel(task.getProcessDefinitionId());
+            FlowNode flowNode = (FlowNode) bpmnModel.getFlowElement(task.getTaskDefinitionKey());
+            //鑾峰彇褰撳墠鑺傜偣杈撳嚭杩炵嚎
+            List<SequenceFlow> outgoingFlows = flowNode.getOutgoingFlows();
+            //璁$畻鏄惁鏈夌粨鏉熸寜閽�
+            boolean isReturn;
+            for (SequenceFlow outgoingFlow : outgoingFlows) {
+                //鑾峰彇杈撳嚭鑺傜偣鍏冪礌
+                FlowElement targetFlowElement = outgoingFlow.getTargetFlowElement();
+                isReturn = false;
+                //鎺掗櫎闈炵敤鎴蜂换鍔℃帴鐐�
+                if (targetFlowElement instanceof UserTask) {
+                    //鍒ゆ柇杈撳嚭鑺傜偣鐨別l琛ㄨ揪寮�
+                    Map vars = new HashMap();
+                    vars.put("flag", "false"); // 1100
+                    if (FlowUtil.isCondition(outgoingFlow.getConditionExpression(), vars)) {
+                        isReturn = true;
+                    }
+
+                    if (!isReturn) {
+                        String assignee = ((UserTask) targetFlowElement).getAssignee();
+                        if (!StringUtil.isEmpty(assignee)) {
+                            taskBusinessKeyMap.put(business_key + "_hasAudit", "1");
+                        }
+                    }
+                }
+                //濡傛灉涓嬩竴涓负 缁撴潫鑺傜偣
+                if (targetFlowElement instanceof EndEvent) {
+                    //true 鑾峰彇杈撳嚭鑺傜偣鍚嶇О
+                    taskBusinessKeyMap.put(business_key + "_hasEnd", "1");
+                }
+            }
+
         }
 
         if (contractIds == null || contractIds.size() == 0) {
@@ -129,6 +169,8 @@
 
         for (ContractDto tmpContractDto : tmpContractDtos) {
             tmpContractDto.setTaskId(taskBusinessKeyMap.get(tmpContractDto.getContractId()));
+            tmpContractDto.setHasAudit(taskBusinessKeyMap.get(tmpContractDto.getContractId() + "_hasAudit"));
+            tmpContractDto.setHasEnd(taskBusinessKeyMap.get(tmpContractDto.getContractId() + "_hasEnd"));
         }
         return tmpContractDtos;
     }
@@ -172,7 +214,7 @@
         workflowDto.setFlowType(WorkflowDto.FLOW_TYPE_CONTRACT_APPLY);
         workflowDto.setStoreId(storeId);
         List<WorkflowDto> workflowDtos = workflowInnerServiceSMOImpl.queryWorkflows(workflowDto);
-        Assert.listOnlyOne(workflowDtos, "鏈壘鍒� 鎶曡瘔寤鸿娴佺▼鎴栨壘鍒板鏉★紝璇峰湪鐗╀笟璐﹀彿绯荤粺绠$悊涓嬫祦绋嬬鐞嗕腑閰嶇疆娴佺▼");
+        Assert.listOnlyOne(workflowDtos, "鏈壘鍒� 鍚堝悓璧疯崏缁娴佺▼鎴栨壘鍒板鏉★紝璇峰湪鐗╀笟璐﹀彿绯荤粺绠$悊涓嬫祦绋嬬鐞嗕腑閰嶇疆娴佺▼");
 
         WorkflowDto tmpWorkflowDto = workflowDtos.get(0);
         if (StringUtil.isEmpty(tmpWorkflowDto.getProcessDefinitionKey())) {
@@ -259,4 +301,49 @@
         return tmpContractDtos;
     }
 
+
+    public boolean completeTask(@RequestBody ContractDto contractDto) {
+        TaskService taskService = processEngine.getTaskService();
+        Task task = taskService.createTaskQuery().taskId(contractDto.getTaskId()).singleResult();
+        String processInstanceId = task.getProcessInstanceId();
+        Authentication.setAuthenticatedUserId(contractDto.getCurrentUserId());
+        taskService.addComment(contractDto.getTaskId(), processInstanceId, contractDto.getAuditMessage());
+        Map<String, Object> variables = new HashMap<String, Object>();
+        variables.put("auditCode", contractDto.getAuditCode());
+        variables.put("currentUserId", contractDto.getCurrentUserId());
+        variables.put("flag", "1200".equals(contractDto.getAuditCode()) ? "false" : "true");
+        variables.put("startUserId", contractDto.getStartUserId());
+        variables.put("nextUserId", contractDto.getNextUserId());
+        taskService.complete(contractDto.getTaskId(), variables);
+
+        ProcessInstance pi = runtimeService.createProcessInstanceQuery().processInstanceId(processInstanceId).singleResult();
+        if (pi == null) {
+            return true;
+        }
+        return false;
+    }
+
+    //鍒犻櫎浠诲姟
+    public boolean deleteTask(@RequestBody ContractPo contractDto) {
+        TaskService taskService = processEngine.getTaskService();
+
+        TaskQuery query = taskService.createTaskQuery().processInstanceBusinessKey(contractDto.getContractId());
+        query.orderByTaskCreateTime().desc();
+        List<Task> list = query.list();
+
+        if (list == null || list.size() < 1) {
+            return true;
+        }
+
+        for (Task task : list) {
+            String processInstanceId = task.getProcessInstanceId();
+            //3.浣跨敤娴佺▼瀹炰緥锛屾煡璇�
+            runtimeService.deleteProcessInstance(processInstanceId, "鍙栨秷鍚堝悓");
+
+        }
+
+        return true;
+    }
+
+
 }

--
Gitblit v1.8.0