UNPKG

tdesign-vue-next

Version:
156 lines (152 loc) 5.45 kB
/** * tdesign v1.19.2 * (c) 2026 tdesign * @license MIT */ import { ref, watch, createVNode } from 'vue'; import 'lodash-es'; import '@babel/runtime/helpers/toConsumableArray'; import '@babel/runtime/helpers/typeof'; import '../../_chunks/dep-c68ea098.js'; import '../../config-provider/hooks/useConfig.js'; import '@babel/runtime/helpers/slicedToArray'; import '../../_chunks/dep-91fc762d.js'; import '@babel/runtime/helpers/defineProperty'; import 'tdesign-icons-vue-next'; import '../../checkbox/index.js'; import '../../loading/index.js'; import { p as privateKey } from '../../_chunks/dep-58eae151.js'; import TreeItem from '../tree-item.js'; import useTreeEvents from './useTreeEvents.js'; import '../../_chunks/dep-f0f392fb.js'; import '../../config-provider/utils/context.js'; import '../../_chunks/dep-509ddbe3.js'; import 'dayjs'; import '@babel/runtime/helpers/createClass'; import '@babel/runtime/helpers/classCallCheck'; import '../../checkbox/checkbox.js'; import '../../checkbox/props.js'; import '../../_chunks/dep-7bdccf65.js'; import '../../_chunks/dep-d518fdfb.js'; import '../../_chunks/dep-8d4d971b.js'; import '../../_chunks/dep-98d89c71.js'; import '../../_chunks/dep-e8dd47a9.js'; import '../../_chunks/dep-2ba9b7d0.js'; import '../../_chunks/dep-8be9c790.js'; import '../../_chunks/dep-d67d6f8a.js'; import '../../_chunks/dep-ef7a41ce.js'; import '../../_chunks/dep-e332908e.js'; import '../../checkbox/constants/index.js'; import '../../checkbox/hooks/useCheckboxLazyLoad.js'; import '../../_chunks/dep-6f148007.js'; import '../../checkbox/hooks/useKeyboardEvent.js'; import '../../_chunks/dep-e9e05226.js'; import '../../checkbox/group.js'; import '../../checkbox/checkbox-group-props.js'; import '../../_chunks/dep-b36a4e94.js'; import '../../_chunks/dep-ae3e94b6.js'; import 'tdesign-vue-next/esm/common/style/web/components/checkbox/_index.less'; import '../../loading/directive.js'; import '../../loading/plugin.js'; import '../../_chunks/dep-2a7145b5.js'; import '../../loading/icon/gradient.js'; import '../../_chunks/dep-fbf70ecb.js'; import '@babel/runtime/helpers/objectWithoutProperties'; import '../../loading/props.js'; import 'tdesign-vue-next/esm/common/style/web/components/loading/_index.less'; import '@babel/runtime/helpers/asyncToGenerator'; import '@babel/runtime/regenerator'; import '../../_chunks/dep-06660d60.js'; import '../utils/adapt.js'; import '../../_chunks/dep-c3757953.js'; import '../../_chunks/dep-52eae58a.js'; import '../../_chunks/dep-6ff755da.js'; import '../../_chunks/dep-4e6777ed.js'; import '../../_chunks/dep-d5fc4caa.js'; import './useItemState.js'; import './useTreeItem.js'; import './useItemEvents.js'; import './useRenderIcon.js'; import '../utils/index.js'; import './useRenderLabel.js'; import './useRenderLine.js'; import './useRenderOperations.js'; import './useDraggable.js'; import './useTreeAction.js'; 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.js.map