BreadcrumbSeparator.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
  2. import { createVNode as _createVNode } from "vue";
  3. var __rest = this && this.__rest || function (s, e) {
  4. var t = {};
  5. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  6. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  7. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  8. }
  9. return t;
  10. };
  11. import { defineComponent } from 'vue';
  12. import { flattenChildren } from '../_util/props-util';
  13. import useConfigInject from '../config-provider/hooks/useConfigInject';
  14. export const breadcrumbSeparatorProps = () => ({
  15. prefixCls: String
  16. });
  17. export default defineComponent({
  18. compatConfig: {
  19. MODE: 3
  20. },
  21. name: 'ABreadcrumbSeparator',
  22. __ANT_BREADCRUMB_SEPARATOR: true,
  23. inheritAttrs: false,
  24. props: breadcrumbSeparatorProps(),
  25. setup(props, _ref) {
  26. let {
  27. slots,
  28. attrs
  29. } = _ref;
  30. const {
  31. prefixCls
  32. } = useConfigInject('breadcrumb', props);
  33. return () => {
  34. var _a;
  35. const {
  36. separator,
  37. class: className
  38. } = attrs,
  39. restAttrs = __rest(attrs, ["separator", "class"]);
  40. const children = flattenChildren((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots));
  41. return _createVNode("span", _objectSpread({
  42. "class": [`${prefixCls.value}-separator`, className]
  43. }, restAttrs), [children.length > 0 ? children : '/']);
  44. };
  45. }
  46. });