73a413e008407d936c503fb0f31def5cd1b4b5a49c5b3f3ffd1b76e0051d924ecce2d0a2e28bbf2a8cdee45f78f35470903fd638fe2db44c3d6a08e2f08381 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. import { defineComponent, getCurrentInstance, inject, ref, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, renderSlot, createBlock, withCtx, resolveDynamicComponent, toDisplayString } from 'vue';
  2. import { ElIcon } from '../../icon/index.mjs';
  3. import { breadcrumbKey } from './constants.mjs';
  4. import { breadcrumbItemProps } from './breadcrumb-item.mjs';
  5. import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
  6. import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
  7. const __default__ = defineComponent({
  8. name: "ElBreadcrumbItem"
  9. });
  10. const _sfc_main = /* @__PURE__ */ defineComponent({
  11. ...__default__,
  12. props: breadcrumbItemProps,
  13. setup(__props) {
  14. const props = __props;
  15. const instance = getCurrentInstance();
  16. const breadcrumbContext = inject(breadcrumbKey, void 0);
  17. const ns = useNamespace("breadcrumb");
  18. const router = instance.appContext.config.globalProperties.$router;
  19. const link = ref();
  20. const onClick = () => {
  21. if (!props.to || !router)
  22. return;
  23. props.replace ? router.replace(props.to) : router.push(props.to);
  24. };
  25. return (_ctx, _cache) => {
  26. var _a, _b;
  27. return openBlock(), createElementBlock("span", {
  28. class: normalizeClass(unref(ns).e("item"))
  29. }, [
  30. createElementVNode("span", {
  31. ref_key: "link",
  32. ref: link,
  33. class: normalizeClass([unref(ns).e("inner"), unref(ns).is("link", !!_ctx.to)]),
  34. role: "link",
  35. onClick
  36. }, [
  37. renderSlot(_ctx.$slots, "default")
  38. ], 2),
  39. ((_a = unref(breadcrumbContext)) == null ? void 0 : _a.separatorIcon) ? (openBlock(), createBlock(unref(ElIcon), {
  40. key: 0,
  41. class: normalizeClass(unref(ns).e("separator"))
  42. }, {
  43. default: withCtx(() => [
  44. (openBlock(), createBlock(resolveDynamicComponent(unref(breadcrumbContext).separatorIcon)))
  45. ]),
  46. _: 1
  47. }, 8, ["class"])) : (openBlock(), createElementBlock("span", {
  48. key: 1,
  49. class: normalizeClass(unref(ns).e("separator")),
  50. role: "presentation"
  51. }, toDisplayString((_b = unref(breadcrumbContext)) == null ? void 0 : _b.separator), 3))
  52. ], 2);
  53. };
  54. }
  55. });
  56. var BreadcrumbItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "breadcrumb-item.vue"]]);
  57. export { BreadcrumbItem as default };
  58. //# sourceMappingURL=breadcrumb-item2.mjs.map