UNPKG

@aplus-frontend/antdv

Version:

Vue basic component library maintained based on ant-design-vue

58 lines 1.72 kB
import _extends from "@babel/runtime/helpers/esm/extends"; import { shallowRef, watch, toRaw } from 'vue'; import { convertChildrenToData } from '../utils/legacyUtil'; function parseSimpleTreeData(treeData, _ref) { let { id, pId, rootPId } = _ref; const keyNodes = {}; const rootNodeList = []; // Fill in the map const nodeList = treeData.map(node => { const clone = _extends({}, node); const key = clone[id]; keyNodes[key] = clone; clone.key = clone.key || key; return clone; }); // Connect tree nodeList.forEach(node => { const parentKey = node[pId]; const parent = keyNodes[parentKey]; // Fill parent if (parent) { parent.children = parent.children || []; parent.children.push(node); } // Fill root tree node if (parentKey === rootPId || !parent && rootPId === null) { rootNodeList.push(node); } }); return rootNodeList; } /** * Convert `treeData` or `children` into formatted `treeData`. * Will not re-calculate if `treeData` or `children` not change. */ export default function useTreeData(treeData, children, simpleMode) { const mergedTreeData = shallowRef(); watch([simpleMode, treeData, children], () => { const simpleModeValue = simpleMode.value; if (treeData.value) { mergedTreeData.value = simpleMode.value ? parseSimpleTreeData(toRaw(treeData.value), _extends({ id: 'id', pId: 'pId', rootPId: null }, simpleModeValue !== true ? simpleModeValue : {})) : toRaw(treeData.value).slice(); } else { mergedTreeData.value = convertChildrenToData(toRaw(children.value)); } }, { immediate: true, deep: true }); return mergedTreeData; }