From cea2ecb470537a52e6a17d09703a9f770b220cdf Mon Sep 17 00:00:00 2001
From: luohairen <3399054449@qq.com>
Date: 星期四, 05 十二月 2024 17:08:28 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 flowable/src/main/java/com/ycl/domain/vo/FormDetailVO.java                 |   43 ++++++
 business/src/main/java/com/ycl/domain/vo/CustomerTaskVO.java               |    7 +
 flowable/src/main/java/com/ycl/common/constant/ProcessConstants.java       |   13 +
 business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java |   71 ++++++++-
 flowable/src/main/java/com/ycl/service/common/TaskCommonService.java       |  117 ++++++++++++++++
 common/src/main/java/com/ycl/common/enums/business/HandlerTypeEnum.java    |   29 ++++
 flowable/src/main/java/com/ycl/service/impl/FlowTaskServiceImpl.java       |  120 ++++++++++++----
 business/src/main/java/com/ycl/controller/ProjectProcessController.java    |    7 +
 business/src/main/java/com/ycl/service/ProjectProcessService.java          |    9 +
 9 files changed, 375 insertions(+), 41 deletions(-)

diff --git a/business/src/main/java/com/ycl/controller/ProjectProcessController.java b/business/src/main/java/com/ycl/controller/ProjectProcessController.java
index d4924dc..1018841 100644
--- a/business/src/main/java/com/ycl/controller/ProjectProcessController.java
+++ b/business/src/main/java/com/ycl/controller/ProjectProcessController.java
@@ -74,6 +74,13 @@
         return projectProcessService.taskList(query);
     }
 
+    @GetMapping("/detail/task/is/auditing")
+    @ApiOperation(value = "鑾峰彇浠诲姟鏄惁鏄鎵硅妭鐐�", notes = "鑾峰彇浠诲姟鏄惁鏄鎵硅妭鐐�")
+//    @PreAuthorize("@ss.hasPermi('projectProcess:detail')")
+    public Result taskIsAuditing(String processDefId, String taskId) {
+        return projectProcessService.taskIsAuditing(processDefId, taskId);
+    }
+
 
     @GetMapping("/to_do_task")
     @ApiOperation(value = "鍒嗛〉", notes = "鍒嗛〉")
diff --git a/business/src/main/java/com/ycl/domain/vo/CustomerTaskVO.java b/business/src/main/java/com/ycl/domain/vo/CustomerTaskVO.java
index 86eebff..06a3d89 100644
--- a/business/src/main/java/com/ycl/domain/vo/CustomerTaskVO.java
+++ b/business/src/main/java/com/ycl/domain/vo/CustomerTaskVO.java
@@ -1,5 +1,6 @@
 package com.ycl.domain.vo;
 
+import com.ycl.common.enums.business.HandlerTypeEnum;
 import com.ycl.common.enums.business.TaskStatusEnum;
 import lombok.Data;
 
@@ -108,4 +109,10 @@
      * 浠诲姟鍒涘缓鏃堕棿
      */
     private Date createTime;
+
+    /**
+     * 澶勭悊浜虹被鍨�
+     *
+     */
+    private HandlerTypeEnum handlerType;
 }
diff --git a/business/src/main/java/com/ycl/service/ProjectProcessService.java b/business/src/main/java/com/ycl/service/ProjectProcessService.java
index 0506181..ea82840 100644
--- a/business/src/main/java/com/ycl/service/ProjectProcessService.java
+++ b/business/src/main/java/com/ycl/service/ProjectProcessService.java
@@ -69,4 +69,13 @@
     void getAllTodoTask(String taskName, int pageSize, int pageNum, Result result);
 
     Result detailByProcessInsId(TaskQuery query);
+
+    /**
+     * 鏌ヨ鏄惁鏄鎵逛换鍔�
+     *
+     * @param processDefinitionId 娴佺▼瀹氫箟id
+     * @param processDefinitionId 浠诲姟id
+     * @return
+     */
+    Result taskIsAuditing(String processDefinitionId, String taskId);
 }
diff --git a/business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java b/business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java
index 3279664..50f95df 100644
--- a/business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java
+++ b/business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java
@@ -12,6 +12,7 @@
 import com.ycl.common.core.domain.entity.SysRole;
 import com.ycl.common.core.domain.entity.SysUser;
 import com.ycl.common.enums.FlowComment;
+import com.ycl.common.enums.business.HandlerTypeEnum;
 import com.ycl.common.enums.business.TaskStatusEnum;
 import com.ycl.common.utils.SecurityUtils;
 import com.ycl.constant.TaskTypeConstant;
@@ -52,6 +53,7 @@
 import org.springframework.beans.BeanUtils;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.Assert;
+import org.springframework.util.CollectionUtils;
 
 import java.util.*;
 import java.util.stream.Collectors;
@@ -286,6 +288,7 @@
             for (IdentityLink identityLink : identityLinksForTask) {
                 // 缁戝畾鐨勬槸鐢ㄦ埛锛屾煡鍑虹敤鎴峰鍚嶃�侀儴闂�
                 if (StringUtils.isNotBlank(identityLink.getUserId())) {
+                    taskVO.setHandlerType(HandlerTypeEnum.USER);
                     SysUser sysUser = sysUserService.selectUserById(Long.parseLong(identityLink.getUserId()));
                     if (Objects.nonNull(sysUser)) {
                         taskVO.setHandlerId(sysUser.getUserId());
@@ -295,14 +298,30 @@
                         }
                         taskVO.setHandlerName(sysUser.getNickName());
                     }
-                    // 缁戝畾鐨勬槸瑙掕壊锛屾煡鍑鸿鑹插悕绉�
+                    // 缁戝畾鐨勬槸瑙掕壊鎴栬�呴儴闂�
                 } else if (StringUtils.isNotBlank(identityLink.getGroupId())) {
-                    SysRole role = sysRoleService.selectRoleById(Long.parseLong(identityLink.getGroupId()));
-                    if (Objects.nonNull(role)) {
-                        taskVO.setHandlerUnitId(Long.parseLong(identityLink.getGroupId()));
-                        taskVO.setHandlerUnitName("鐢辨嫢鏈夎鑹诧細銆�" + role.getRoleName() + "銆戠殑浜哄鐞�");
-                        taskVO.setHandlerName("鏆傛湭澶勭悊");
-                        taskVO.setHandlerId(null);
+                    if (identityLink.getGroupId().startsWith("dept")) {   // 閮ㄩ棬鐨刬d鏄姞浜嗗墠缂�鐨勫锛歞ept:1
+                        taskVO.setHandlerType(HandlerTypeEnum.DEPT);
+                        String[] split = identityLink.getGroupId().split(":");
+                        if (split.length > 1) {
+                            // 閮ㄩ棬
+                            SysDept dept = sysDeptService.selectDeptById(Long.parseLong(split[1]));
+                            if (Objects.nonNull(dept)) {
+                                taskVO.setHandlerUnitId(dept.getDeptId());
+                                taskVO.setHandlerUnitName(dept.getDeptName());
+                                taskVO.setHandlerName("鏆傛湭澶勭悊");
+                                taskVO.setHandlerId(null);
+                            }
+                        }
+                    } else {
+                        taskVO.setHandlerType(HandlerTypeEnum.ROLE);
+                        SysRole role = sysRoleService.selectRoleById(Long.parseLong(identityLink.getGroupId()));
+                        if (Objects.nonNull(role)) {
+                            taskVO.setHandlerUnitId(Long.parseLong(identityLink.getGroupId()));
+                            taskVO.setHandlerUnitName("鐢辨嫢鏈夎鑹诧細銆�" + role.getRoleName() + "銆戠殑浜哄鐞�");
+                            taskVO.setHandlerName("鏆傛湭澶勭悊");
+                            taskVO.setHandlerId(null);
+                        }
                     }
                 }
             }
@@ -318,6 +337,30 @@
                 .eq(ProjectProcess::getProcessDefId, query.getProcessDefId())
                 .list();
         return Result.ok().data(list);
+    }
+
+    @Override
+    public Result taskIsAuditing(String processDefinitionId, String taskId) {
+        BpmnModel bpmnModel = repositoryService.getBpmnModel(processDefinitionId);
+        Collection<Process> processes = bpmnModel.getProcesses();
+        for (Process process : processes) {
+            Collection<FlowElement> flowElements = process.getFlowElements();
+            for (FlowElement flowElement : flowElements) {
+                if (flowElement instanceof UserTask) {
+                    UserTask userTask = (UserTask) flowElement;
+                    List<ExtensionElement> extensionElements = userTask.getExtensionElements().get("flowable:properties");
+                    if (! CollectionUtils.isEmpty(extensionElements)) {
+                        for (ExtensionElement extensionElement : extensionElements) {
+                            String fieldName = extensionElement.getAttributeValue(taskId,"name");
+                            String fieldValue = extensionElement.getAttributeValue(taskId,"value");
+                            System.out.println("Field Name: " + fieldName + ", Field Value: " + fieldValue);
+                        }
+                    }
+                }
+
+            }
+        }
+        return null;
     }
 
     /**
@@ -373,6 +416,7 @@
             for (IdentityLink identityLink : identityLinksForTask) {
                 // 缁戝畾鐨勬槸鐢ㄦ埛锛屾煡鍑虹敤鎴峰鍚嶃�侀儴闂�
                 if (StringUtils.isNotBlank(identityLink.getUserId())) {
+                    taskVO.setHandlerType(HandlerTypeEnum.USER);
                     SysUser sysUser = sysUserService.selectUserById(Long.parseLong(identityLink.getUserId()));
                     if (Objects.nonNull(sysUser)) {
                         taskVO.setHandlerId(sysUser.getUserId());
@@ -385,6 +429,7 @@
                     // 缁戝畾鐨勬槸瑙掕壊鎴栬�呴儴闂�
                 } else if (StringUtils.isNotBlank(identityLink.getGroupId())) {
                     if (identityLink.getGroupId().startsWith("dept")) {   // 閮ㄩ棬鐨刬d鏄姞浜嗗墠缂�鐨勫锛歞ept:1
+                        taskVO.setHandlerType(HandlerTypeEnum.DEPT);
                         String[] split = identityLink.getGroupId().split(":");
                         if (split.length > 1) {
                             // 閮ㄩ棬
@@ -397,6 +442,7 @@
                             }
                         }
                     } else {
+                        taskVO.setHandlerType(HandlerTypeEnum.ROLE);
                         SysRole role = sysRoleService.selectRoleById(Long.parseLong(identityLink.getGroupId()));
                         if (Objects.nonNull(role)) {
                             taskVO.setHandlerUnitId(Long.parseLong(identityLink.getGroupId()));
@@ -426,7 +472,6 @@
         int startNum = pageSize * (pageNum - 1);
         int endNum = startNum + pageSize;
         List<UserTask> allUserTaskElement = this.getAllUserTaskElement(processDefinitionId);
-        result.total(allUserTaskElement.size());
         if (startNum >= allUserTaskElement.size()) {
             // 濡傛灉璧峰绱㈠紩瓒呭嚭浜嗗垪琛ㄧ殑澶у皬锛岃繑鍥炰竴涓┖鍒楄〃
             return new ArrayList<>();
@@ -435,6 +480,7 @@
             // 妯℃嫙妯$硦鏌ヨ
             allUserTaskElement = allUserTaskElement.stream().filter(taskEl -> taskEl.getName().contains(taskName)).collect(Collectors.toList());
         }
+        result.total(allUserTaskElement.size());
         int end = Math.min(endNum, allUserTaskElement.size());
         List<UserTask> userTasks = allUserTaskElement.subList(startNum, end);
         // 鏌ュ嚭娴佺▼
@@ -458,6 +504,7 @@
                 if (Objects.isNull(historicTask)) {
                     // 鏈紑濮嬬殑浠诲姟锛屽叾鍏宠仈鐨勭敤鎴风粍杩欎簺閮藉彲浠ヤ粠UserTask涓嬁鍒帮紝鍥犱负鏈韩鏈紑濮嬬殑浠诲姟鏄病鏈塼ask鐨勶紝鎵�浠ヨ繖閲岀洿鎺ユ煡
                     if (StringUtils.isNotBlank(userTask.getAssignee())) {
+                        vo.setHandlerType(HandlerTypeEnum.USER);
                         SysUser sysUser = sysUserService.selectUserById(Long.parseLong(userTask.getAssignee()));
                         if (Objects.nonNull(sysUser)) {
                             vo.setHandlerId(sysUser.getUserId());
@@ -468,6 +515,7 @@
                     } else if (CollectionUtil.isNotEmpty(userTask.getCandidateGroups())) {
                         String groupId = userTask.getCandidateGroups().get(0);
                         if (groupId.startsWith("dept")) {   // 閮ㄩ棬鐨刬d鏄姞浜嗗墠缂�鐨勫锛歞ept:1
+                            vo.setHandlerType(HandlerTypeEnum.DEPT);
                             String[] split = groupId.split(":");
                             if (split.length > 1) {
                                 // 閮ㄩ棬
@@ -480,6 +528,7 @@
                                 }
                             }
                         } else {
+                            vo.setHandlerType(HandlerTypeEnum.ROLE);
                             SysRole role = sysRoleService.selectRoleById(Long.parseLong(groupId));
                             if (Objects.nonNull(role)) {
                                 vo.setHandlerUnitId(Long.parseLong(groupId));
@@ -533,7 +582,7 @@
         int startNum = pageSize * (pageNum - 1);
         int endNum = startNum + pageSize;
         List<UserTask> allUserTaskElement = this.getAllUserTaskElement(processDefinitionId);
-        result.total(allUserTaskElement.size());
+
         if (startNum >= allUserTaskElement.size()) {
             // 濡傛灉璧峰绱㈠紩瓒呭嚭浜嗗垪琛ㄧ殑澶у皬锛岃繑鍥炰竴涓┖鍒楄〃
             return new ArrayList<>();
@@ -542,6 +591,7 @@
             // 妯℃嫙妯$硦鏌ヨ
             allUserTaskElement = allUserTaskElement.stream().filter(taskEl -> taskEl.getName().contains(taskName)).collect(Collectors.toList());
         }
+        result.total(allUserTaskElement.size());
         int end = Math.min(endNum, allUserTaskElement.size());
         List<UserTask> userTasks = allUserTaskElement.subList(startNum, end);
         // 鏌ュ嚭娴佺▼
@@ -565,6 +615,7 @@
                 if (Objects.isNull(historicTask)) {
                     // 鏈紑濮嬬殑浠诲姟锛屽叾鍏宠仈鐨勭敤鎴风粍杩欎簺閮藉彲浠ヤ粠UserTask涓嬁鍒帮紝鍥犱负鏈韩鏈紑濮嬬殑浠诲姟鏄病鏈塼ask鐨勶紝鎵�浠ヨ繖閲岀洿鎺ユ煡
                     if (StringUtils.isNotBlank(userTask.getAssignee())) {
+                        vo.setHandlerType(HandlerTypeEnum.USER);
                         SysUser sysUser = sysUserService.selectUserById(Long.parseLong(userTask.getAssignee()));
                         if (Objects.nonNull(sysUser)) {
                             vo.setHandlerId(sysUser.getUserId());
@@ -575,6 +626,7 @@
                     } else if (CollectionUtil.isNotEmpty(userTask.getCandidateGroups())) {
                         String groupId = userTask.getCandidateGroups().get(0);
                         if (groupId.startsWith("dept")) {   // 閮ㄩ棬鐨刬d鏄姞浜嗗墠缂�鐨勫锛歞ept:1
+                            vo.setHandlerType(HandlerTypeEnum.DEPT);
                             String[] split = groupId.split(":");
                             if (split.length > 1) {
                                 // 閮ㄩ棬
@@ -587,6 +639,7 @@
                                 }
                             }
                         } else {
+                            vo.setHandlerType(HandlerTypeEnum.ROLE);
                             SysRole role = sysRoleService.selectRoleById(Long.parseLong(groupId));
                             if (Objects.nonNull(role)) {
                                 vo.setHandlerUnitId(Long.parseLong(groupId));
diff --git a/common/src/main/java/com/ycl/common/enums/business/HandlerTypeEnum.java b/common/src/main/java/com/ycl/common/enums/business/HandlerTypeEnum.java
new file mode 100644
index 0000000..37ca447
--- /dev/null
+++ b/common/src/main/java/com/ycl/common/enums/business/HandlerTypeEnum.java
@@ -0,0 +1,29 @@
+package com.ycl.common.enums.business;
+
+import com.fasterxml.jackson.annotation.JsonValue;
+import lombok.Getter;
+
+/**
+ * 浠诲姟澶勭悊浜虹被鍨�
+ *
+ * @author锛歺p
+ * @date锛�2024/11/29 11:13
+ */
+@Getter
+public enum HandlerTypeEnum {
+
+    USER("USER", "鐢ㄦ埛"),
+    DEPT("DEPT", "閮ㄩ棬"),
+    ROLE("ROLE", "瑙掕壊")
+    ;
+
+    @JsonValue
+    private final String value;
+
+    private final String desc;
+
+    HandlerTypeEnum(String value, String desc) {
+        this.value = value;
+        this.desc = desc;
+    }
+}
diff --git a/flowable/src/main/java/com/ycl/common/constant/ProcessConstants.java b/flowable/src/main/java/com/ycl/common/constant/ProcessConstants.java
index 161e31f..173a8d6 100644
--- a/flowable/src/main/java/com/ycl/common/constant/ProcessConstants.java
+++ b/flowable/src/main/java/com/ycl/common/constant/ProcessConstants.java
@@ -76,5 +76,18 @@
      */
     public static final String FLOWABLE_SKIP_EXPRESSION_ENABLED = "_FLOWABLE_SKIP_EXPRESSION_ENABLED";
 
+    /**
+     * 琛ㄥ崟淇℃伅key
+     *
+     */
+    public static final String TASK_FORM_KEY = "formJson";
+
+
+    /**
+     * 琛ㄥ崟閰嶅锛屾殏鏃朵笉鐭ラ亾鏄暐
+     *
+     */
+    public static final String WIDGET_LIST = "widgetList";
+
 
 }
diff --git a/flowable/src/main/java/com/ycl/domain/vo/FormDetailVO.java b/flowable/src/main/java/com/ycl/domain/vo/FormDetailVO.java
new file mode 100644
index 0000000..d37ba81
--- /dev/null
+++ b/flowable/src/main/java/com/ycl/domain/vo/FormDetailVO.java
@@ -0,0 +1,43 @@
+package com.ycl.domain.vo;
+
+import com.alibaba.fastjson2.JSONObject;
+import lombok.Data;
+
+import java.util.Map;
+
+/**
+ * 澶勭悊涓嬩竴涓换鍔℃椂锛屽洖鏄惧墠缃换鍔$殑琛ㄥ崟(鍖呭惈鏈妭鐐圭殑琛ㄥ崟)
+ *
+ * @author锛歺p
+ * @date锛�2024/12/5 0:35
+ */
+@Data
+public class FormDetailVO {
+
+
+    /**
+     * 鏄惁褰撳墠鑺傜偣鐨勮〃鍗�
+     *
+     */
+    private Boolean current = false;
+
+    /**
+     * 鍓嶇疆鑺傜偣瀹氫箟id
+     *
+     */
+    private String beforeNodeDefId;
+
+    /**
+     * 鍓嶇疆鑺傜偣鍚嶇О锛堜换鍔″悕绉帮級
+     *
+     */
+    private String beforeNodeName;
+
+    /**
+     * 鍓嶇疆鑺傜偣琛ㄥ崟鏁版嵁
+     *
+     */
+    private Map<String, Object> formJsonObj;
+
+
+}
diff --git a/flowable/src/main/java/com/ycl/service/common/TaskCommonService.java b/flowable/src/main/java/com/ycl/service/common/TaskCommonService.java
new file mode 100644
index 0000000..5335db3
--- /dev/null
+++ b/flowable/src/main/java/com/ycl/service/common/TaskCommonService.java
@@ -0,0 +1,117 @@
+package com.ycl.service.common;
+
+import com.alibaba.fastjson2.JSONObject;
+import com.ycl.common.constant.ProcessConstants;
+import com.ycl.domain.entity.SysForm;
+import com.ycl.domain.vo.FormDetailVO;
+import com.ycl.flow.FindNextNodeUtil;
+import com.ycl.service.ISysFormService;
+import lombok.RequiredArgsConstructor;
+import org.flowable.bpmn.model.*;
+import org.flowable.bpmn.model.Process;
+import org.flowable.engine.RepositoryService;
+import org.flowable.engine.RuntimeService;
+import org.flowable.engine.repository.ProcessDefinition;
+import org.springframework.stereotype.Service;
+import org.springframework.util.CollectionUtils;
+import org.springframework.util.StringUtils;
+
+import java.util.*;
+
+/**
+ * @author锛歺p
+ * @date锛�2024/12/4 23:22
+ */
+@Service
+@RequiredArgsConstructor
+public class TaskCommonService {
+
+    private final RuntimeService runtimeService;
+    private final RepositoryService repositoryService;
+
+    /**
+     * 閫氳繃褰撳墠鑺傜偣瀹氫箟key锛岃幏鍙栧叾涓婁竴涓妭鐐圭殑瀹氫箟id锛屽鏋滃墠闈㈡槸骞惰鐨勪細杩斿洖澶氫釜
+     *
+     * @param processDefId 娴佺▼瀹氫箟id
+     * @param currentNodeDefId
+     * @return
+     */
+    public List<FormDetailVO> getBeforeNodeDefId(String processDefId, String currentNodeDefId, ISysFormService sysFormService) {
+        // 鑾峰彇娴佺▼瀹氫箟
+        ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery()
+                .processDefinitionId(processDefId)
+                .singleResult();
+
+        // 鑾峰彇娴佺▼妯″瀷
+        BpmnModel bpmnModel = repositoryService.getBpmnModel(processDefId);
+        if (bpmnModel == null) {
+            throw new RuntimeException("BpmnModel not found for processDefinitionId: " + processDefId);
+        }
+
+        // 鑾峰彇娴佺▼瀵硅薄
+        Process process = bpmnModel.getProcessById(processDefinition.getKey());
+        if (process == null) {
+            throw new RuntimeException("Process not found for processDefinitionId: " + processDefId);
+        }
+
+        // 閬嶅巻娴佺▼鍏冪礌锛屾壘鍒板搴旂殑浠诲姟鑺傜偣
+        Collection<FlowElement> flowElements = process.getFlowElements();
+        UserTask currentElement = null;
+        for (FlowElement flowElement : flowElements) {
+            if (flowElement instanceof UserTask && flowElement.getId().equals(currentNodeDefId)) {
+                currentElement = (UserTask) flowElement;
+                break;
+            }
+        }
+        if (Objects.isNull(currentElement)) {
+            throw new RuntimeException("鏈壘鍒版敼浠诲姟鐨勬祦绋嬪畾涔夎妭鐐�");
+        }
+
+        // 鑾峰彇褰撳墠鑺傜偣鐨勮緭鍏�
+        List<FormDetailVO> defKeys = new ArrayList<>(2);
+        if (StringUtils.hasText(currentElement.getFormKey())) {
+            FormDetailVO formDetailVO = new FormDetailVO();
+            formDetailVO.setBeforeNodeDefId(currentElement.getId());
+            formDetailVO.setBeforeNodeName(currentElement.getName());
+            formDetailVO.setCurrent(Boolean.TRUE);
+
+            SysForm sysForm = sysFormService.selectSysFormById(Long.parseLong(currentElement.getFormKey()));
+            if (Objects.isNull(sysForm)) {
+                throw new RuntimeException("璇ユ祦绋嬬粦瀹氱殑琛ㄥ崟涓嶅瓨鍦ㄦ垨宸茶鍒犻櫎");
+            }
+            Map<String, Object> data = new HashMap<>(1);
+            data.put(ProcessConstants.TASK_FORM_KEY, JSONObject.parseObject(sysForm.getFormContent()));
+
+            formDetailVO.setFormJsonObj(data);
+            defKeys.add(formDetailVO);
+        }
+        this.before(currentElement, defKeys);
+
+        return defKeys;
+    }
+
+    /**
+     * 閫掑綊鑾峰彇褰撳墠鑺傜偣鐨勫墠涓�涓换鍔¤妭鐐筴ey
+     *
+     * @param currentElement
+     * @param defKeys
+     */
+    private void before(UserTask currentElement, List<FormDetailVO> defKeys) {
+        if (! CollectionUtils.isEmpty(currentElement.getIncomingFlows())) {
+            for (SequenceFlow incomingFlow : currentElement.getIncomingFlows()) {
+                if (! (incomingFlow.getSourceFlowElement() instanceof UserTask)) {
+                    // 涓嶅寘鍚紑濮嬭妭鐐�
+                    if (! (incomingFlow.getSourceFlowElement() instanceof StartEvent)) {
+                        before((UserTask) (incomingFlow.getSourceFlowElement()), defKeys);
+                    }
+                } else {
+                    FormDetailVO formDetailVO = new FormDetailVO();
+                    formDetailVO.setBeforeNodeDefId(incomingFlow.getSourceFlowElement().getId());
+                    formDetailVO.setBeforeNodeName(incomingFlow.getSourceFlowElement().getName());
+                    defKeys.add(formDetailVO);
+                }
+            }
+        }
+    }
+
+}
diff --git a/flowable/src/main/java/com/ycl/service/impl/FlowTaskServiceImpl.java b/flowable/src/main/java/com/ycl/service/impl/FlowTaskServiceImpl.java
index d2d5a45..a7af1d7 100644
--- a/flowable/src/main/java/com/ycl/service/impl/FlowTaskServiceImpl.java
+++ b/flowable/src/main/java/com/ycl/service/impl/FlowTaskServiceImpl.java
@@ -19,6 +19,7 @@
 import com.ycl.domain.entity.SysForm;
 import com.ycl.domain.vo.FlowQueryVo;
 import com.ycl.domain.vo.FlowTaskVo;
+import com.ycl.domain.vo.FormDetailVO;
 import com.ycl.factory.FlowServiceFactory;
 import com.ycl.flow.CustomProcessDiagramGenerator;
 import com.ycl.flow.FindNextNodeUtil;
@@ -26,6 +27,7 @@
 import com.ycl.service.IFlowTaskService;
 import com.ycl.service.ISysDeployFormService;
 import com.ycl.service.ISysFormService;
+import com.ycl.service.common.TaskCommonService;
 import com.ycl.system.service.ISysRoleService;
 import com.ycl.system.service.ISysUserService;
 import lombok.RequiredArgsConstructor;
@@ -80,6 +82,7 @@
     private final ISysRoleService sysRoleService;
     private final ISysDeployFormService sysInstanceFormService;
     private final ISysFormService sysFormService;
+    private final TaskCommonService taskCommonService;
 
     /**
      * 瀹屾垚瀹℃牳浠诲姟
@@ -119,10 +122,21 @@
         if (Objects.isNull(task)) {
             return AjaxResult.error("浠诲姟涓嶅瓨鍦�");
         }
+        Map<String, Object> newV = new HashMap<>(2);
+        if (! org.springframework.util.CollectionUtils.isEmpty(variables)) {
+            for (String key : variables.keySet()) {
+                newV.put(task.getTaskDefinitionKey() + "&" + key, variables.get(key));
+//                if (ProcessConstants.TASK_FORM_KEY.equals(key)) {
+//                    newV.put(task.getTaskDefinitionKey() + "_" + ProcessConstants.TASK_FORM_KEY, variables.get(key));
+//                } else if (ProcessConstants.WIDGET_LIST.equals(key)){
+//                    newV.put(task.getTaskDefinitionKey() + "_" + ProcessConstants.WIDGET_LIST, variables.get(key));
+//                }
+            }
+        }
         // 鍏堣褰撳墠鐢ㄦ埛璁ら杩欎釜浠诲姟
         taskService.claim(taskId, SecurityUtils.getUserId() + "");
         taskService.addComment(taskId, task.getProcessInstanceId(), FlowComment.SUBMIT.getType(), "瀹屾垚鎻愪氦");
-        taskService.complete(taskId, variables);
+        taskService.complete(taskId, newV);
         return AjaxResult.success("鎻愪氦鎴愬姛");
     }
 
@@ -1135,41 +1149,83 @@
         } else {
             parameters = taskService.getVariables(taskId);
         }
-
-        JSONObject oldVariables = JSONObject.parseObject(JSON.toJSONString(parameters.get("formJson")));
-        if (Objects.isNull(oldVariables)) {
-            // 濡傛灉鏄┖鐨勶紝鐩存帴浣跨敤涓昏〃鍗曪紝鍥犱负杩欎唬琛ㄦ槸娴佺▼涓殑绗竴涓彁浜よ〃鍗曠殑浠诲姟
-            String deploymentId = runtimeService.createProcessInstanceQuery().processInstanceId(task.getProcessInstanceId()).singleResult().getDeploymentId();
-            return this.flowFormData(deploymentId);
+        if (! parameters.keySet().stream().anyMatch(key -> key.contains(ProcessConstants.TASK_FORM_KEY))) {
+            // 濡傛灉鏄┖鐨勶紝浣跨敤formId鍘绘煡
+            if (StringUtils.isNotBlank(task.getFormKey())) {
+                SysForm sysForm = sysFormService.selectSysFormById(Long.parseLong(task.getFormKey()));
+                if (Objects.isNull(sysForm)) {
+                    throw new RuntimeException("璇ユ祦绋嬬粦瀹氱殑琛ㄥ崟涓嶅瓨鍦ㄦ垨宸茶鍒犻櫎");
+                }
+                FormDetailVO formDetailVO = new FormDetailVO();
+                Map<String, Object> data = new HashMap<>(1);
+                data.put(ProcessConstants.TASK_FORM_KEY, JSONObject.parseObject(sysForm.getFormContent()));
+                formDetailVO.setFormJsonObj(data);
+                formDetailVO.setBeforeNodeName(task.getName());
+                formDetailVO.setCurrent(Boolean.TRUE);
+                return AjaxResult.success(Arrays.asList(formDetailVO));
+            } else {
+                return AjaxResult.success(new ArrayList<>(1));
+            }
         }
-        List<JSONObject> oldFields = JSON.parseObject(JSON.toJSONString(oldVariables.get("widgetList")), new TypeReference<List<JSONObject>>() {
-        });
-        // 璁剧疆宸插~鍐欑殑琛ㄥ崟涓虹鐢ㄧ姸鎬�
-        for (JSONObject oldField : oldFields) {
-            JSONObject options = oldField.getJSONObject("options");
-            options.put("disabled", true);
-        }
-        // TODO 鏆傛椂鍙鐞嗙敤鎴蜂换鍔′笂鐨勮〃鍗�
-        if (StringUtils.isNotBlank(task.getFormKey())) {
-            SysForm sysForm = sysFormService.selectSysFormById(Long.parseLong(task.getFormKey()));
-            JSONObject data = JSONObject.parseObject(sysForm.getFormContent());
-            List<JSONObject> newFields = JSON.parseObject(JSON.toJSONString(data.get("widgetList")), new TypeReference<List<JSONObject>>() {
-            });
-            // 琛ㄥ崟鍥炴樉鏃� 鍔犲叆瀛愯〃鍗曚俊鎭埌娴佺▼鍙橀噺涓�
-            for (JSONObject newField : newFields) {
-                String key = newField.getString("id");
-                // 澶勭悊鍥剧墖涓婁紶缁勪欢鍥炴樉闂
-                if ("picture-upload".equals(newField.getString("type"))) {
-                    parameters.put(key, new ArrayList<>());
-                } else {
-                    parameters.put(key, null);
+        // 杩欓噷鍙渶瑕佹煡鑷韩浠ュ強涓婁竴涓妭鐐�(濡傛灉骞惰鐨勬湁澶氫釜)鐨勮〃鍗曟暟鎹�
+        List<FormDetailVO> beforeNodes = taskCommonService.getBeforeNodeDefId(task.getProcessDefinitionId(), task.getTaskDefinitionKey(), sysFormService);
+        List<String> beforeNodeDefIds = beforeNodes.stream().filter(item -> !item.getCurrent()).map(FormDetailVO::getBeforeNodeDefId).collect(Collectors.toList());
+        Map<String, Object> newP = new HashMap<>();
+        if (CollectionUtils.isNotEmpty(beforeNodeDefIds)) {
+            for (String key : parameters.keySet()) {
+                // 杩囨护鐩爣鏁版嵁锛屽皢鐩爣琛ㄥ崟鏁版嵁鏀惧埌鏂癿ap涓�
+                if (beforeNodeDefIds.stream().anyMatch(defId -> key.startsWith(defId))) {
+                    if (key.contains(ProcessConstants.TASK_FORM_KEY)) {
+                        newP.put(key, parameters.get(key));
+                    } else {
+                        newP.put(key.split("&")[1], parameters.get(key));
+                    }
                 }
             }
-            oldFields.addAll(newFields);
         }
-        oldVariables.put("widgetList", oldFields);
-        parameters.put("formJson", oldVariables);
-        return AjaxResult.success(parameters);
+
+        // 鎷垮埌鐩爣琛ㄥ崟鍚庯紝鍐嶅鐞嗘瘡涓〃鍗曠殑鏁版嵁
+        for (FormDetailVO formDetailVO : beforeNodes) {
+            if (formDetailVO.getCurrent()) {
+                continue;  // 璺宠繃褰撳墠鑺傜偣锛屽洜涓哄綋鍓嶈妭鐐瑰湪鑾峰彇鍓嶇疆鑺傜偣鏃跺凡缁忚缃繃浜�
+            }
+            Object form = newP.get(formDetailVO.getBeforeNodeDefId() + "&" + ProcessConstants.TASK_FORM_KEY);
+            if (Objects.nonNull(form)) {
+                JSONObject formJson = JSONObject.parseObject(JSON.toJSONString(form));
+                List<JSONObject> oldFields = JSON.parseObject(JSON.toJSONString(formJson.get(ProcessConstants.WIDGET_LIST)), new TypeReference<List<JSONObject>>() {
+                });
+
+                // 璁剧疆宸插~鍐欑殑琛ㄥ崟涓虹鐢ㄧ姸鎬�
+                for (JSONObject oldField : oldFields) {
+                    JSONObject options = oldField.getJSONObject("options");
+                    options.put("disabled", true);
+                }
+                // TODO 鏆傛椂鍙鐞嗙敤鎴蜂换鍔′笂鐨勮〃鍗�
+//                if (StringUtils.isNotBlank(task.getFormKey())) {
+//                    SysForm sysForm = sysFormService.selectSysFormById(Long.parseLong(task.getFormKey()));
+//                    JSONObject data = JSONObject.parseObject(sysForm.getFormContent());
+//                    List<JSONObject> newFields = JSON.parseObject(JSON.toJSONString(data.get(ProcessConstants.WIDGET_LIST)), new TypeReference<List<JSONObject>>() {
+//                    });
+//                    // 琛ㄥ崟鍥炴樉鏃� 鍔犲叆瀛愯〃鍗曚俊鎭埌娴佺▼鍙橀噺涓�
+//                    for (JSONObject newField : newFields) {
+//                        String key = newField.getString("id");
+//                        // 澶勭悊鍥剧墖涓婁紶缁勪欢鍥炴樉闂
+//                        if ("picture-upload".equals(newField.getString("type"))) {
+//                            parameters.put(key, new ArrayList<>());
+//                        } else {
+//                            parameters.put(key, null);
+//                        }
+//                    }
+//                    oldFields.addAll(newFields);
+//                }
+                formJson.put(ProcessConstants.WIDGET_LIST, oldFields);
+                newP.put(ProcessConstants.TASK_FORM_KEY, formJson);
+                newP.remove(formDetailVO.getBeforeNodeDefId() + "&" + ProcessConstants.TASK_FORM_KEY);
+                formDetailVO.setFormJsonObj(newP);
+            }
+        }
+
+        return AjaxResult.success(beforeNodes);
     }
 
     /**

--
Gitblit v1.8.0