UNPKG

tdesign-vue-next

Version:
69 lines (65 loc) 2.35 kB
/** * tdesign v1.19.2 * (c) 2026 tdesign * @license MIT */ import { defineComponent, ref, onMounted, onUpdated, createVNode } from 'vue'; import 'lodash-es'; import '@babel/runtime/helpers/toConsumableArray'; import '@babel/runtime/helpers/typeof'; import '../../_chunks/dep-c68ea098.js'; import { u as usePrefixClass } from '../../_chunks/dep-e8dd47a9.js'; import '@babel/runtime/helpers/slicedToArray'; import '../../_chunks/dep-91fc762d.js'; import '@babel/runtime/helpers/defineProperty'; import '../../_chunks/dep-f0f392fb.js'; import '../../config-provider/hooks/useConfig.js'; import '../../config-provider/utils/context.js'; import '../../_chunks/dep-509ddbe3.js'; import 'dayjs'; import '@babel/runtime/helpers/createClass'; import '@babel/runtime/helpers/classCallCheck'; var PopupOverflowContent = defineComponent({ name: "PopupOverflowContent", props: { foldIndex: { type: Number, required: true } }, setup: function setup(props, ctx) { var classPrefix = usePrefixClass(); var wrapperRef = ref(); var hideBeforeFoldIndex = function hideBeforeFoldIndex() { if (!wrapperRef.value) return; var menuItemClass = "".concat(classPrefix.value, "-menu__item"); var submenuClass = "".concat(classPrefix.value, "-submenu"); var items = []; var _collect = function collect(parent, depth) { if (depth > 3) return; Array.from(parent.children).forEach(function (el) { if (!(el instanceof HTMLElement)) return; if (el.classList.contains(menuItemClass) || el.classList.contains(submenuClass)) { items.push(el); } else { _collect(el, depth + 1); } }); }; _collect(wrapperRef.value, 0); items.forEach(function (el, index) { el.style.display = index < props.foldIndex ? "none" : ""; }); }; onMounted(hideBeforeFoldIndex); onUpdated(hideBeforeFoldIndex); return function () { var _ctx$slots$default, _ctx$slots; return createVNode("div", { "ref": wrapperRef }, [(_ctx$slots$default = (_ctx$slots = ctx.slots)["default"]) === null || _ctx$slots$default === void 0 ? void 0 : _ctx$slots$default.call(_ctx$slots)]); }; } }); export { PopupOverflowContent as default }; //# sourceMappingURL=popup-overflow-content.js.map