tdesign-vue-next
Version:
TDesign Component for vue-next
103 lines (99 loc) • 3.77 kB
JavaScript
/**
* tdesign v1.20.0
* (c) 2026 tdesign
* @license MIT
*/
import { defineComponent, toRefs, createVNode, provide, reactive, mergeProps } from 'vue';
import { _ as _typeof } from '../_chunks/dep-7e80b480.mjs';
import props from './props.mjs';
import _BreadcrumbItem from './breadcrumb-item.mjs';
import { u as usePrefixClass, a as useTNodeJSX, i as useGlobalIcon } from '../_chunks/dep-6e1ec500.mjs';
import './hooks/index.mjs';
import { ChevronRightIcon, EllipsisIcon } from 'tdesign-icons-vue-next';
import { useBreadcrumbOptions } from './hooks/useBreadcrumbOptions.mjs';
import { useEllipsis } from './hooks/useEllipsis.mjs';
import '../_chunks/dep-e25ecc4b.mjs';
import './breadcrumb-item-props.mjs';
import '../tooltip/index.mjs';
import '../tooltip/tooltip.mjs';
import '../_chunks/dep-a1cffe73.mjs';
import '../_chunks/dep-1e8a6a5e.mjs';
import 'lodash-es';
import '../tooltip/props.mjs';
import '../popup/props.mjs';
import '../popup/index.mjs';
import '../popup/popup.mjs';
import '@popperjs/core';
import '../_chunks/dep-98b885ec.mjs';
import '../_chunks/dep-c53b1c81.mjs';
import '../popup/container.mjs';
import '../_chunks/dep-3a6b2289.mjs';
import './style/css.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';
import '../tooltip/utils/index.mjs';
import '../_chunks/dep-0f5e7d6e.mjs';
var _Breadcrumb = defineComponent({
name: "TBreadcrumb",
props: props,
setup: function setup(props2) {
var _toRefs = toRefs(props2),
theme = _toRefs.theme,
maxItemWidth = _toRefs.maxItemWidth;
var COMPONENT_NAME = usePrefixClass("breadcrumb");
var renderTNodeJSX = useTNodeJSX();
var _useGlobalIcon = useGlobalIcon({
ChevronRightIcon: ChevronRightIcon,
EllipsisIcon: EllipsisIcon
}),
ChevronRightIcon$1 = _useGlobalIcon.ChevronRightIcon,
EllipsisIcon$1 = _useGlobalIcon.EllipsisIcon;
var separatorContent = renderTNodeJSX("separator");
var separator = separatorContent || createVNode(ChevronRightIcon$1, null, null);
provide("tBreadcrumb", reactive({
separator: separator,
theme: theme,
maxItemWidth: maxItemWidth
}));
return function () {
var _useBreadcrumbOptions = useBreadcrumbOptions(props2),
breadcrumbOptions = _useBreadcrumbOptions.breadcrumbOptions;
var ellipsisItems = breadcrumbOptions.value.slice(props2.itemsBeforeCollapse, breadcrumbOptions.value.length - props2.itemsAfterCollapse);
var ellipsisSlot = renderTNodeJSX("ellipsis", {
params: {
items: ellipsisItems,
separator: separator
}
});
var ellipsisContent = ellipsisSlot || createVNode(EllipsisIcon$1, null, null);
var _useEllipsis = useEllipsis(props2, breadcrumbOptions, ellipsisContent),
getDisplayItems = _useEllipsis.getDisplayItems;
var items = getDisplayItems.value;
var content = items.map(function (item, index) {
if (_typeof(item) === "object" && "content" in item) {
return createVNode(_BreadcrumbItem, mergeProps({
"key": index
}, item), {
"default": function _default() {
return [item.content];
}
});
}
return item;
});
return createVNode("div", {
"class": COMPONENT_NAME.value
}, [content]);
};
}
});
export { _Breadcrumb as default };
//# sourceMappingURL=breadcrumb.mjs.map