fix: normalize dirty list to tree
This commit is contained in:
parent
fe9c84f263
commit
e5cef8ccc0
|
@ -1,6 +1,7 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import _ from 'lodash';
|
import _ from 'lodash';
|
||||||
import { Tree } from 'antd';
|
import { Tree } from 'antd';
|
||||||
|
import LTT from 'list-to-tree';
|
||||||
import { MenuConfItem, TreeNode } from '@interface';
|
import { MenuConfItem, TreeNode } from '@interface';
|
||||||
|
|
||||||
export function isAbsolutePath(url: string) {
|
export function isAbsolutePath(url: string) {
|
||||||
|
@ -73,20 +74,37 @@ export function findNode(treeData: TreeNode[], node: TreeNode) {
|
||||||
|
|
||||||
export function normalizeTreeData(data: TreeNode[]) {
|
export function normalizeTreeData(data: TreeNode[]) {
|
||||||
const treeData: TreeNode[] = [];
|
const treeData: TreeNode[] = [];
|
||||||
|
let tag = 0;
|
||||||
|
|
||||||
|
function fn(_cache?: TreeNode[]) {
|
||||||
|
const cache: TreeNode[] = [];
|
||||||
_.each(data, (node) => {
|
_.each(data, (node) => {
|
||||||
node = _.cloneDeep(node);
|
node = _.cloneDeep(node);
|
||||||
if (node.pid === 0) {
|
if (node.pid === 0) {
|
||||||
|
if (tag === 0) {
|
||||||
treeData.splice(_.sortedIndexBy(treeData, node, 'name'), 0, node);
|
treeData.splice(_.sortedIndexBy(treeData, node, 'name'), 0, node);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
const findedNode = findNode(treeData, node);
|
const findedNode = findNode(treeData, node); // find parent node
|
||||||
if (!findedNode) return;
|
if (!findedNode) {
|
||||||
|
cache.push(node);
|
||||||
|
return;
|
||||||
|
};
|
||||||
if (_.isArray(findedNode.children)) {
|
if (_.isArray(findedNode.children)) {
|
||||||
|
if (!_.find(findedNode.children, { id: node.id })) {
|
||||||
findedNode.children.splice(_.sortedIndexBy(findedNode.children, node, 'name'), 0, node);
|
findedNode.children.splice(_.sortedIndexBy(findedNode.children, node, 'name'), 0, node);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
findedNode.children = [node];
|
findedNode.children = [node];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
tag += 1;
|
||||||
|
if (cache.length && !_.isEqual(_cache, cache)) {
|
||||||
|
fn(cache);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fn();
|
||||||
return treeData;
|
return treeData;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue