From 08c96e4b797573fd64b42a52a2f9b9805d59d3e3 Mon Sep 17 00:00:00 2001 From: Junjie <xjj@123> Date: 星期日, 07 四月 2024 14:03:54 +0800 Subject: [PATCH] # --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/utils/Utils.java | 50 +++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 45 insertions(+), 5 deletions(-) diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/utils/Utils.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/utils/Utils.java index 0398a98..0ac4c2a 100644 --- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/utils/Utils.java +++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/utils/Utils.java @@ -2,9 +2,11 @@ import com.zy.asrs.framework.common.Cools; +import com.zy.asrs.wcs.common.constant.Constants; import javax.servlet.http.HttpServletResponse; import java.util.ArrayList; +import java.util.Iterator; import java.util.List; import java.util.Optional; import java.util.function.BiConsumer; @@ -27,7 +29,8 @@ * @param <R> parentId鐨勭被鍨� * @return List<T> */ - public static <T, R> List<T> toTreeData(List<T> data, R parentId, + public static <T, R> List<T> toTreeData(List<T> data, + R parentId, Function<? super T, ? extends R> parentIdMapper, Function<? super T, ? extends R> idMapper, BiConsumer<T, List<T>> consumer) { @@ -37,11 +40,48 @@ if (parentId.equals(dParentId)) { R dId = idMapper.apply(d); List<T> children = toTreeData(data, dId, parentIdMapper, idMapper, consumer); - consumer.accept(d, children); + if(children.size() > 0) { + consumer.accept(d, children); + } result.add(d); } } return result; + } + +// public static <T> List<T> treeRemove(List<T> data, String condition, +// Function<? super T, ? extends String> fetcher, +// Function<T, List<T>> childrenGetter, +// BiConsumer<T, List<T>> childrenSetter) { +// List<T> result = new ArrayList<>(); +// for (T node : data) { +// List<T> children = childrenGetter.apply(node); +// +// if (children != null && !children.isEmpty()) { +// List<T> newChildren = treeRemove(children, condition, fetcher, childrenGetter, childrenSetter); +// childrenSetter.accept(node, newChildren); +// } +// +// if (fetcher.apply(node).contains(condition)) { +// result.add(node); +// } +// } +// return result; +// } + + public static <T> void treeRemove(List<T> list, String condition, Function<? super T, ? extends String> fetcher, Function<T, List<T>> childrenGetter) { + Iterator<T> iterator = list.iterator(); + while (iterator.hasNext()) { + T next = iterator.next(); + List<T> children = childrenGetter.apply(next); + if (children != null && !children.isEmpty()) { + treeRemove(children, condition, fetcher, childrenGetter); + } else { + if (!fetcher.apply(next).contains(condition)) { + iterator.remove(); + } + } + } } /** @@ -257,11 +297,11 @@ public static void cors(HttpServletResponse response){ // 璺ㄥ煙璁剧疆 + response.setHeader("Access-Control-Max-Age", "3600"); response.setHeader("Access-Control-Allow-Origin", "*"); - response.setHeader("Access-Control-Allow-Credentials", "true"); response.setHeader("Access-Control-Allow-Methods", "*"); - response.setHeader("Access-Control-Allow-Headers", "Content-Type,Access-Token,Authorization"); - response.setHeader("Access-Control-Expose-Headers", "*"); + response.setHeader("Access-Control-Allow-Headers", "*"); + response.setHeader("Access-Control-Expose-Headers", Constants.TOKEN_HEADER_NAME); } } -- Gitblit v1.9.1