UNPKG

tdesign-vue-next

Version:
101 lines (97 loc) 3.29 kB
/** * tdesign v1.20.0 * (c) 2026 tdesign * @license MIT */ import { defineComponent, ref, computed, onMounted, nextTick, watch, createVNode } from 'vue'; import { _ as _defineProperty } from '../_chunks/dep-e25ecc4b.mjs'; import { _ as _slicedToArray } from '../_chunks/dep-a1cffe73.mjs'; import props from './props.mjs'; import { u as usePrefixClass, l as useResizeObserver } from '../_chunks/dep-6e1ec500.mjs'; import { debounce } from 'lodash-es'; import '../_chunks/dep-7e80b480.mjs'; import '../_chunks/dep-1e8a6a5e.mjs'; import '../_chunks/dep-3a6b2289.mjs'; import '../_chunks/dep-98b885ec.mjs'; import '../_chunks/dep-c53b1c81.mjs'; import '../config-provider/hooks/useConfig.mjs'; import '../config-provider/utils/context.mjs'; import '../_chunks/dep-fc168c9c.mjs'; import '../_chunks/dep-2242b0fd.mjs'; import '../_chunks/dep-b9ecb840.mjs'; import '../_chunks/dep-67ace303.mjs'; import '../_chunks/dep-8768d1f1.mjs'; import '../_chunks/dep-68c88886.mjs'; import '../_chunks/dep-dfce43be.mjs'; import '../_chunks/dep-d9965fa1.mjs'; var TTabNavBar = defineComponent({ props: { navs: { type: Array }, placement: props.placement, value: props.value }, setup: function setup(props) { var COMPONENT_NAME = usePrefixClass("tabs"); var classPrefix = usePrefixClass(); var barRef = ref(); var navBarClass = computed(function () { return ["".concat(COMPONENT_NAME.value, "__bar"), "".concat(classPrefix.value, "-is-").concat(props.placement)]; }); var navBarStyle = ref(null); var getStyle = function getStyle() { var isVertical = ["left", "right"].includes(props.placement.toLowerCase()); var _ref = isVertical ? ["height", "top"] : ["width", "left"], _ref2 = _slicedToArray(_ref, 2), sizePropName = _ref2[0], offsetPropName = _ref2[1]; var offset = 0; var i = 0; for (; i < props.navs.length; i++) { var _props$navs$i; if (props.navs[i].props.value === props.value) { break; } if ((_props$navs$i = props.navs[i]) !== null && _props$navs$i !== void 0 && _props$navs$i.el) { var sizeWithUnit = getComputedStyle(props.navs[i].el)[sizePropName]; var size = parseFloat(sizeWithUnit); offset += size; } } if (!props.navs[i]) return {}; return _defineProperty(_defineProperty({}, offsetPropName, "".concat(offset, "px")), sizePropName, props.navs[i].el ? getComputedStyle(props.navs[i].el)[sizePropName] : "0px"); }; var update = function update() { return navBarStyle.value = getStyle(); }; onMounted(function () { nextTick(function () { update(); }); }); watch([function () { return props.navs; }, function () { return props.value; }, function () { return props.placement; }], function () { nextTick(function () { update(); }); }); useResizeObserver(barRef, debounce(function () { update(); }, 35)); return function () { return createVNode("div", { "class": navBarClass.value, "style": navBarStyle.value, "ref": barRef }, null); }; } }); export { TTabNavBar as default }; //# sourceMappingURL=tab-nav-bar.mjs.map