xiejun
2024-11-01 80b6cbfc9c861469146318d0b3dd5f8b8b525b8a
Source/BladeX-Tool/blade-core-tool/src/main/java/org/springblade/core/tool/node/ForestNodeManager.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,85 @@
/*
 *      Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
 *
 *  Redistribution and use in source and binary forms, with or without
 *  modification, are permitted provided that the following conditions are met:
 *
 *  Redistributions of source code must retain the above copyright notice,
 *  this list of conditions and the following disclaimer.
 *  Redistributions in binary form must reproduce the above copyright
 *  notice, this list of conditions and the following disclaimer in the
 *  documentation and/or other materials provided with the distribution.
 *  Neither the name of the dreamlu.net developer nor the names of its
 *  contributors may be used to endorse or promote products derived from
 *  this software without specific prior written permission.
 *  Author: Chill åº„骞 (smallchill@163.com)
 */
package org.springblade.core.tool.node;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Maps;
import org.springblade.core.tool.utils.StringPool;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
/**
 * æ£®æž—管理类
 *
 * @author smallchill
 */
public class ForestNodeManager<T extends INode<T>> {
   /**
    * æ£®æž—的所有节点
    */
   private final ImmutableMap<Long, T> nodeMap;
   /**
    * æ£®æž—的父节点ID
    */
   private final Map<Long, Object> parentIdMap = Maps.newHashMap();
   public ForestNodeManager(List<T> nodes) {
      nodeMap = Maps.uniqueIndex(nodes, INode::getId);
   }
   /**
    * æ ¹æ®èŠ‚ç‚¹ID获取一个节点
    *
    * @param id èŠ‚ç‚¹ID
    * @return å¯¹åº”的节点对象
    */
   public INode<T> getTreeNodeAt(Long id) {
      if (nodeMap.containsKey(id)) {
         return nodeMap.get(id);
      }
      return null;
   }
   /**
    * å¢žåŠ çˆ¶èŠ‚ç‚¹ID
    *
    * @param parentId çˆ¶èŠ‚ç‚¹ID
    */
   public void addParentId(Long parentId) {
      parentIdMap.put(parentId, StringPool.EMPTY);
   }
   /**
    * èŽ·å–æ ‘çš„æ ¹èŠ‚ç‚¹(一个森林对应多颗树)
    *
    * @return æ ‘的根节点集合
    */
   public List<T> getRoot() {
      List<T> roots = new ArrayList<>();
      nodeMap.forEach((key, node) -> {
         if (node.getParentId() == 0 || parentIdMap.containsKey(node.getId())) {
            roots.add(node);
         }
      });
      return roots;
   }
}