element-plus
Version:
A Component Library for Vue 3
1 lines • 17.4 kB
Source Map (JSON)
{"version":3,"file":"tree-store.mjs","names":[],"sources":["../../../../../../../packages/components/tree/src/model/tree-store.ts"],"sourcesContent":["import { nextTick } from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { NOOP, hasOwn, isObject, isPropAbsent } from '@element-plus/utils'\nimport Node from './node'\nimport { getNodeKey } from './util'\n\nimport type {\n FilterNodeMethodFunction,\n FilterValue,\n LoadFunction,\n TreeData,\n TreeKey,\n TreeNodeData,\n TreeOptionProps,\n TreeStoreNodesMap,\n TreeStoreOptions,\n} from '../tree.type'\n\nexport default class TreeStore {\n currentNode: Node | null\n currentNodeKey: TreeKey | null\n nodesMap: TreeStoreNodesMap\n root!: Node\n data!: TreeData\n lazy = false\n load?: LoadFunction\n filterNodeMethod?: FilterNodeMethodFunction\n key!: TreeKey\n defaultCheckedKeys?: TreeKey[]\n checkStrictly = false\n defaultExpandedKeys?: TreeKey[]\n autoExpandParent = false\n defaultExpandAll = false\n checkDescendants = false\n props!: TreeOptionProps\n\n constructor(options: TreeStoreOptions) {\n this.currentNode = null\n this.currentNodeKey = null\n\n for (const option in options) {\n if (hasOwn(options, option)) {\n this[option] = options[option]\n }\n }\n\n this.nodesMap = {}\n }\n\n initialize() {\n this.root = new Node({\n data: this.data,\n store: this,\n })\n this.root.initialize()\n\n if (this.lazy && this.load) {\n const loadFn = this.load\n loadFn(\n this.root,\n (data) => {\n this.root.doCreateChildren(data)\n this._initDefaultCheckedNodes()\n },\n NOOP\n )\n } else {\n this._initDefaultCheckedNodes()\n }\n }\n\n filter(value: FilterValue): void {\n const filterNodeMethod = this.filterNodeMethod\n const lazy = this.lazy\n const traverse = async function (node: TreeStore | Node) {\n const childNodes = (node as TreeStore).root\n ? (node as TreeStore).root.childNodes\n : (node as Node).childNodes\n\n for (const [index, child] of childNodes.entries()) {\n child.visible = !!filterNodeMethod?.call(\n child,\n value,\n child.data,\n child\n )\n\n if (index % 80 === 0 && index > 0) {\n await nextTick()\n }\n await traverse(child)\n }\n\n if (!(node as Node).visible && childNodes.length) {\n let allHidden = true\n allHidden = !childNodes.some((child) => child.visible)\n\n if ((node as TreeStore).root) {\n ;(node as TreeStore).root.visible = allHidden === false\n } else {\n ;(node as Node).visible = allHidden === false\n }\n }\n if (!value) return\n\n if ((node as Node).visible && !(node as Node).isLeaf) {\n if (!lazy || (node as Node).loaded) {\n ;(node as Node).expand()\n }\n }\n }\n\n traverse(this)\n }\n\n setData(newVal: TreeData): void {\n const instanceChanged = newVal !== this.root.data\n if (instanceChanged) {\n this.nodesMap = {}\n this.root.setData(newVal)\n this._initDefaultCheckedNodes()\n this.setCurrentNodeKey(this.currentNodeKey)\n } else {\n this.root.updateChildren()\n }\n }\n\n getNode(data: TreeKey | TreeNodeData | Node): Node {\n if (data instanceof Node) return data\n const key = isObject(data) ? getNodeKey(this.key, data) : data\n return this.nodesMap[key] || null\n }\n\n insertBefore(\n data: TreeNodeData,\n refData: TreeKey | TreeNodeData | Node\n ): void {\n const refNode = this.getNode(refData)\n refNode.parent?.insertBefore({ data }, refNode)\n }\n\n insertAfter(\n data: TreeNodeData,\n refData: TreeKey | TreeNodeData | Node\n ): void {\n const refNode = this.getNode(refData)\n refNode.parent?.insertAfter({ data }, refNode)\n }\n\n remove(data: TreeNodeData | Node): void {\n const node = this.getNode(data)\n\n if (node && node.parent) {\n if (node === this.currentNode) {\n this.currentNode = null\n }\n node.parent.removeChild(node)\n }\n }\n\n append(data: TreeNodeData, parentData: TreeNodeData | TreeKey | Node): void {\n const parentNode = !isPropAbsent(parentData)\n ? this.getNode(parentData)\n : this.root\n\n if (parentNode) {\n parentNode.insertChild({ data })\n }\n }\n\n _initDefaultCheckedNodes(): void {\n const defaultCheckedKeys = this.defaultCheckedKeys || []\n const nodesMap = this.nodesMap\n\n defaultCheckedKeys.forEach((checkedKey) => {\n const node = nodesMap[checkedKey]\n\n if (node) {\n node.setChecked(true, !this.checkStrictly)\n }\n })\n }\n\n _initDefaultCheckedNode(node: Node): void {\n const defaultCheckedKeys = this.defaultCheckedKeys || []\n\n if (!isNil(node.key) && defaultCheckedKeys.includes(node.key)) {\n node.setChecked(true, !this.checkStrictly)\n }\n }\n\n setDefaultCheckedKey(newVal: TreeKey[]): void {\n if (newVal !== this.defaultCheckedKeys) {\n this.defaultCheckedKeys = newVal\n this._initDefaultCheckedNodes()\n }\n }\n\n registerNode(node: Node): void {\n const key = this.key\n if (!node || !node.data) return\n\n if (!key) {\n this.nodesMap[node.id] = node\n } else {\n const nodeKey = node.key\n if (!isNil(nodeKey)) this.nodesMap[nodeKey] = node\n }\n }\n\n deregisterNode(node: Node): void {\n const key = this.key\n if (!key || !node || !node.data) return\n\n node.childNodes.forEach((child) => {\n this.deregisterNode(child)\n })\n\n delete this.nodesMap[node.key!]\n }\n\n getCheckedNodes(\n leafOnly = false,\n includeHalfChecked = false\n ): TreeNodeData[] {\n const checkedNodes: TreeNodeData[] = []\n const traverse = function (node: TreeStore | Node) {\n const childNodes = (node as TreeStore).root\n ? (node as TreeStore).root.childNodes\n : (node as Node).childNodes\n\n childNodes.forEach((child) => {\n if (\n (child.checked || (includeHalfChecked && child.indeterminate)) &&\n (!leafOnly || (leafOnly && child.isLeaf))\n ) {\n checkedNodes.push(child.data)\n }\n\n traverse(child)\n })\n }\n\n traverse(this)\n\n return checkedNodes\n }\n\n getCheckedKeys(leafOnly = false): TreeKey[] {\n return this.getCheckedNodes(leafOnly).map((data) => (data || {})[this.key])\n }\n\n getHalfCheckedNodes(): TreeNodeData[] {\n const nodes: TreeNodeData[] = []\n const traverse = function (node: TreeStore | Node) {\n const childNodes = (node as TreeStore).root\n ? (node as TreeStore).root.childNodes\n : (node as Node).childNodes\n\n childNodes.forEach((child) => {\n if (child.indeterminate) {\n nodes.push(child.data)\n }\n\n traverse(child)\n })\n }\n\n traverse(this)\n\n return nodes\n }\n\n getHalfCheckedKeys(): TreeKey[] {\n return this.getHalfCheckedNodes().map((data) => (data || {})[this.key])\n }\n\n _getAllNodes(): Node[] {\n const allNodes: Node[] = []\n const nodesMap = this.nodesMap\n for (const nodeKey in nodesMap) {\n if (hasOwn(nodesMap, nodeKey)) {\n allNodes.push(nodesMap[nodeKey])\n }\n }\n\n return allNodes\n }\n\n updateChildren(key: TreeKey, data: TreeData): void {\n const node = this.nodesMap[key]\n if (!node) return\n const childNodes = node.childNodes\n for (let i = childNodes.length - 1; i >= 0; i--) {\n const child = childNodes[i]\n this.remove(child.data)\n }\n for (let i = 0, j = data.length; i < j; i++) {\n const child = data[i]\n this.append(child, node.data)\n }\n }\n\n _setCheckedKeys(\n key: TreeKey,\n leafOnly = false,\n checkedKeys: { [key: string]: boolean }\n ) {\n const allNodes = this._getAllNodes().sort((a, b) => a.level - b.level)\n const cache: Record<TreeKey, boolean> = Object.create(null)\n const keys = Object.keys(checkedKeys)\n allNodes.forEach((node) => node.setChecked(false, false))\n const cacheCheckedChild = (node: Node) => {\n node.childNodes.forEach((child) => {\n cache[child.data[key]] = true\n if (child.childNodes?.length) {\n cacheCheckedChild(child)\n }\n })\n }\n for (let i = 0, j = allNodes.length; i < j; i++) {\n const node = allNodes[i]\n const nodeKey: string = node.data[key].toString()\n const checked = keys.includes(nodeKey)\n if (!checked) {\n if (node.checked && !cache[nodeKey]) {\n node.setChecked(false, false)\n }\n continue\n }\n\n if (node.childNodes.length) {\n cacheCheckedChild(node)\n }\n\n if (node.isLeaf || this.checkStrictly) {\n node.setChecked(true, false)\n continue\n }\n node.setChecked(true, true)\n\n if (leafOnly) {\n node.setChecked(false, false, true)\n const traverse = function (node: Node): void {\n const childNodes = node.childNodes\n childNodes.forEach((child) => {\n if (!child.isLeaf) {\n child.setChecked(false, false, true)\n }\n traverse(child)\n })\n node.reInitChecked()\n }\n traverse(node)\n }\n }\n }\n\n setCheckedNodes(array: Node[], leafOnly = false): void {\n const key = this.key\n const checkedKeys: Record<TreeKey, boolean> = {}\n array.forEach((item) => {\n checkedKeys[((item || {}) as any)[key]] = true\n })\n\n this._setCheckedKeys(key, leafOnly, checkedKeys)\n }\n\n setCheckedKeys(keys: TreeKey[], leafOnly = false): void {\n this.defaultCheckedKeys = keys\n const key = this.key\n const checkedKeys: Record<TreeKey, boolean> = {}\n keys.forEach((key) => {\n checkedKeys[key] = true\n })\n\n this._setCheckedKeys(key, leafOnly, checkedKeys)\n }\n\n setDefaultExpandedKeys(keys: TreeKey[]) {\n keys = keys || []\n this.defaultExpandedKeys = keys\n keys.forEach((key) => {\n const node = this.getNode(key)\n if (node) node.expand(null, this.autoExpandParent)\n })\n }\n\n setChecked(\n data: TreeKey | TreeNodeData,\n checked: boolean,\n deep: boolean\n ): void {\n const node = this.getNode(data)\n\n if (node) {\n node.setChecked(!!checked, deep)\n }\n }\n\n getCurrentNode() {\n return this.currentNode\n }\n\n setCurrentNode(currentNode: Node): void {\n const prevCurrentNode = this.currentNode\n if (prevCurrentNode) {\n prevCurrentNode.isCurrent = false\n }\n this.currentNode = currentNode\n this.currentNode.isCurrent = true\n }\n\n setUserCurrentNode(node: Node, shouldAutoExpandParent = true): void {\n const key = (node as any)[this.key]\n const currNode = this.nodesMap[key]\n this.setCurrentNode(currNode)\n if (\n shouldAutoExpandParent &&\n this.currentNode &&\n this.currentNode.level > 1\n ) {\n this.currentNode.parent?.expand(null, true)\n }\n }\n\n setCurrentNodeKey(key: TreeKey | null, shouldAutoExpandParent = true): void {\n this.currentNodeKey = key\n if (isPropAbsent(key)) {\n this.currentNode && (this.currentNode.isCurrent = false)\n this.currentNode = null\n return\n }\n const node = this.getNode(key)\n if (node) {\n this.setCurrentNode(node)\n if (\n shouldAutoExpandParent &&\n this.currentNode &&\n this.currentNode.level > 1\n ) {\n this.currentNode.parent?.expand(null, true)\n }\n }\n }\n}\n"],"mappings":"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"}