From aadd9096f633c3f1a9c1fc895a68d2ada586de85 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期四, 31 三月 2022 10:15:48 +0800
Subject: [PATCH] 优化删除业主为 cmd 模式

---
 service-common/src/main/java/com/java110/common/smo/impl/ContractApplyUserInnerServiceSMOImpl.java |   52 +++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 47 insertions(+), 5 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 095837b..a4b5301 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
@@ -11,11 +11,10 @@
 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;
@@ -51,7 +50,8 @@
 
     @Autowired
     private IWorkflowInnerServiceSMO workflowInnerServiceSMOImpl;
-
+    @Autowired
+    private RepositoryService repositoryService;
 
     /**
      * 鍚姩娴佺▼
@@ -120,6 +120,46 @@
             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) && assignee.indexOf("${") < 0) {
+                            taskBusinessKeyMap.put(business_key+"_hasAudit", task.getId());
+                        }
+                        if ("${startUserId}".equals(assignee)) {
+                            taskBusinessKeyMap.put(business_key+"_hasAudit", task.getId());
+                        }
+                        if ("${nextUserId}".equals(assignee)) {
+                            taskBusinessKeyMap.put(business_key+"_hasAudit", task.getId());
+                        }
+                    }
+                }
+                //濡傛灉涓嬩竴涓负 缁撴潫鑺傜偣
+                if (targetFlowElement instanceof EndEvent) {
+                    //true 鑾峰彇杈撳嚭鑺傜偣鍚嶇О
+                    taskBusinessKeyMap.put(business_key+"_hasEnd", task.getId());
+                }
+            }
+
         }
 
         if (contractIds == null || contractIds.size() == 0) {
@@ -134,6 +174,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;
     }

--
Gitblit v1.8.0