wupengfei
2025-03-21 1bbd7061dac79cacf5513234a04cac8ba0be5c6f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
import { AreaType } from '@12333/constants';
 
export interface AreaTreeNode extends API.AreaDto {
  children?: AreaTreeNode[];
}
 
export function formatAreaListToTree(
  areaDataList: API.AreaDto[],
  parentId: number,
  maxLayer = AreaType.Area
) {
  const treeNodeList: API.AreaTreeNode[] = [];
  if (areaDataList.length > 0) {
    areaDataList.forEach((areaData) => {
      const areaTreeNode: API.AreaTreeNode = { ...areaData };
      if (areaData.parentId === parentId && areaData.layer <= maxLayer) {
        const children = formatAreaListToTree(areaDataList, areaData.areaCode, maxLayer);
        areaTreeNode.children = children;
        treeNodeList.push(areaTreeNode);
      }
    });
  }
  return treeNodeList;
}
 
export function flattenAreaTree(tree: API.AreaDto[]) {
  let result = [] as API.AreaDto[];
 
  // 递归函数,用于遍历子节点
  function flatten(node: API.AreaDto) {
    result.push(node);
 
    if (node.children && node.children.length > 0) {
      node.children.forEach(flatten);
    }
  }
 
  // 遍历树的根节点
  tree.forEach(flatten);
 
  return result;
}