From e4ee26d6e5da074c5a682bed33d193974297537c Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期五, 13 十二月 2024 17:55:44 +0800 Subject: [PATCH] bug修改、任务驳回功能基础实现 --- flowable/src/main/java/com/ycl/service/impl/FlowTaskServiceImpl.java | 34 ++++++++++++++++++---------------- 1 files changed, 18 insertions(+), 16 deletions(-) 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 67e0bc3..aff08d2 100644 --- a/flowable/src/main/java/com/ycl/service/impl/FlowTaskServiceImpl.java +++ b/flowable/src/main/java/com/ycl/service/impl/FlowTaskServiceImpl.java @@ -1213,28 +1213,30 @@ } } // 杩欓噷鍙渶瑕佹煡鑷韩浠ュ強涓婁竴涓妭鐐�(濡傛灉骞惰鐨勬湁澶氫釜)鐨勮〃鍗曟暟鎹� - List<FormDetailVO> beforeNodes = taskCommonService.getBeforeNodeDefId(processDefId, processDefKey, sysFormService, Boolean.TRUE); + List<FormDetailVO> beforeNodes = taskCommonService.getBeforeNodeDefInfo(processDefId, processDefKey, sysFormService, Boolean.TRUE); List<String> beforeNodeDefIds = beforeNodes.stream().filter(item -> !item.getCurrent() || currentNeedData).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)); - } - } - } - } - // 鎷垮埌鐩爣琛ㄥ崟鍚庯紝鍐嶅鐞嗘瘡涓〃鍗曠殑鏁版嵁 + // 澶勭悊姣忎釜琛ㄥ崟鐨勬暟鎹� for (FormDetailVO formDetailVO : beforeNodes) { if (formDetailVO.getCurrent() && !currentNeedData) { continue; // 璺宠繃褰撳墠鑺傜偣锛屽洜涓哄綋鍓嶈妭鐐瑰湪鑾峰彇鍓嶇疆鑺傜偣鏃跺凡缁忚缃繃浜�(浣嗚〃鍗曟暟鎹病鏈夌粰) } + + Map<String, Object> newP = new HashMap<>(); + if (CollectionUtils.isNotEmpty(beforeNodeDefIds)) { + for (String key : parameters.keySet()) { + // 杩囨护鎷垮埌鐩爣琛ㄥ崟鏁版嵁锛屽皢鐩爣琛ㄥ崟鏁版嵁鏀惧埌鏂癿ap涓� + if (key.startsWith(formDetailVO.getBeforeNodeDefId())) { + if (key.contains(ProcessConstants.TASK_FORM_KEY)) { + newP.put(key, parameters.get(key)); + } + else { + newP.put(key.split("&")[1], parameters.get(key)); + } + } + } + } + Object form = newP.get(formDetailVO.getBeforeNodeDefId() + "&" + ProcessConstants.TASK_FORM_KEY); if (Objects.nonNull(form)) { JSONObject formJson = JSONObject.parseObject(JSON.toJSONString(form)); -- Gitblit v1.8.0