UNPKG

tdesign-vue-next

Version:
103 lines (99 loc) 3.77 kB
/** * 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