| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- 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;
- }
|