UNPKG

tdesign-vue-next

Version:
141 lines (137 loc) 4.76 kB
/** * tdesign v1.15.2 * (c) 2025 tdesign * @license MIT */ import { ref, createVNode, watch } from 'vue'; import '../utils/adapt.mjs'; import TreeItem from '../tree-item.mjs'; import useTreeEvents from './useTreeEvents.mjs'; import { p as privateKey } from '../../_chunks/dep-517a8ba2.mjs'; import '../../_chunks/dep-465c43e8.mjs'; import 'lodash-es'; import '../../_chunks/dep-d0add92f.mjs'; import '../../_chunks/dep-32b59907.mjs'; import '../../_chunks/dep-15464fee.mjs'; import '../../_chunks/dep-d58b61b6.mjs'; import '../../_chunks/dep-779bddf7.mjs'; import '../../config-provider/hooks/useConfig.mjs'; import '../../config-provider/utils/context.mjs'; import '../../_chunks/dep-afae046d.mjs'; import '../../_chunks/dep-8a6c1499.mjs'; import '../../_chunks/dep-5c28ada1.mjs'; import '../../_chunks/dep-614f307d.mjs'; import '../../_chunks/dep-d913bc66.mjs'; import '../../_chunks/dep-1690abc9.mjs'; import '../../_chunks/dep-62c11543.mjs'; import '../../_chunks/dep-27c2b283.mjs'; import '../../_chunks/dep-612a2c2b.mjs'; import '../../_chunks/dep-0bd8597f.mjs'; import '../../_chunks/dep-67238d91.mjs'; import 'tdesign-icons-vue-next'; import '../../checkbox/index.mjs'; import '../../checkbox/checkbox.mjs'; import '../../checkbox/props.mjs'; import '../../checkbox/consts/index.mjs'; import '../../checkbox/hooks/useCheckboxLazyLoad.mjs'; import '../../checkbox/hooks/useKeyboardEvent.mjs'; import '../../checkbox/group.mjs'; import '../../checkbox/checkbox-group-props.mjs'; import './style/css.mjs'; import '../../loading/index.mjs'; import '../../loading/directive.mjs'; import '../../loading/plugin.mjs'; import '../../loading/loading.mjs'; import '../../loading/icon/gradient.mjs'; import '../../_chunks/dep-6b6765a0.mjs'; import '../../_chunks/dep-3ea2b330.mjs'; import '../../loading/props.mjs'; import '../../_chunks/dep-40c5ec80.mjs'; import '../../_chunks/dep-6686ef20.mjs'; import './useItemState.mjs'; import './useTreeItem.mjs'; import './useItemEvents.mjs'; import './useRenderIcon.mjs'; import '../utils/index.mjs'; import './useRenderLabel.mjs'; import './useRenderLine.mjs'; import './useRenderOperations.mjs'; import './useDraggable.mjs'; import './useTreeAction.mjs'; function useTreeNodes(state) { var store = state.store, scope = state.scope, allNodes = state.allNodes, nodes = state.nodes, virtualConfig = state.virtualConfig; var _useTreeEvents = useTreeEvents(state), handleClick = _useTreeEvents.handleClick, handleChange = _useTreeEvents.handleChange; var nodesEmpty = ref(false); var cacheMap = /* @__PURE__ */new Map(); var refresh = function refresh() { allNodes.value = store.getNodes(); }; var refreshVisibleNodes = function refreshVisibleNodes() { var isVirtual = virtualConfig === null || virtualConfig === void 0 ? void 0 : virtualConfig.isVirtualScroll.value; if (isVirtual) return; var list = []; var hasVisibleNode = false; allNodes.value.forEach(function (node) { if (node.visible) { hasVisibleNode = true; cacheMap.set(node.value, node.value); } if (cacheMap.has(node.value)) { list.push(node); } }); cacheMap.forEach(function (value) { if (!store.getNode(value)) { cacheMap["delete"](value); } }); nodes.value = list; nodesEmpty.value = !hasVisibleNode; }; var refreshVirtualNodes = function refreshVirtualNodes() { var isVirtual = virtualConfig === null || virtualConfig === void 0 ? void 0 : virtualConfig.isVirtualScroll.value; if (!isVirtual) return; var list = virtualConfig.visibleData.value; nodes.value = list; nodesEmpty.value = list.length <= 0; }; var renderItem = function renderItem(h, node, index, stateId) { var rowIndex = node.VIRTUAL_SCROLL_INDEX || index; var nodeUniqueId = node[privateKey]; var treeItem = createVNode(TreeItem, { "key": nodeUniqueId, "rowIndex": rowIndex, "stateId": stateId, "itemKey": nodeUniqueId, "treeScope": scope, "onClick": handleClick, "onChange": handleChange }, null); return treeItem; }; var renderTreeNodes = function renderTreeNodes(h) { var stateId = "render-".concat(new Date().getTime()); var treeNodeViews = nodes.value.map(function (node, index) { return renderItem(h, node, index, stateId); }); return treeNodeViews; }; watch(allNodes, refreshVisibleNodes); watch(virtualConfig.visibleData, refreshVirtualNodes); refresh(); refreshVisibleNodes(); refreshVirtualNodes(); store.emitter.on("update", refresh); return { nodesEmpty: nodesEmpty, renderTreeNodes: renderTreeNodes }; } export { useTreeNodes as default }; //# sourceMappingURL=useTreeNodes.mjs.map