tdesign-vue-next
Version:
TDesign Component for vue-next
104 lines (100 loc) • 3.8 kB
JavaScript
/**
* tdesign v1.15.2
* (c) 2025 tdesign
* @license MIT
*/
import { defineComponent, toRefs, createVNode, provide, reactive, mergeProps } from 'vue';
import { _ as _typeof } from '../_chunks/dep-15464fee.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-465c43e8.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-0bd8597f.mjs';
import '../_chunks/dep-612a2c2b.mjs';
import './breadcrumb-item-props.mjs';
import '../tooltip/index.mjs';
import '../tooltip/tooltip.mjs';
import '../_chunks/dep-614f307d.mjs';
import '../_chunks/dep-32b59907.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-d58b61b6.mjs';
import '../_chunks/dep-779bddf7.mjs';
import '../popup/container.mjs';
import '../_chunks/dep-d0add92f.mjs';
import './style/css.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-d913bc66.mjs';
import '../_chunks/dep-1690abc9.mjs';
import '../_chunks/dep-62c11543.mjs';
import '../_chunks/dep-27c2b283.mjs';
import '../_chunks/dep-67238d91.mjs';
import '../tooltip/utils/index.mjs';
import '../_chunks/dep-6686ef20.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