BreadcrumbItem.js 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = exports.breadcrumbItemProps = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  10. var _propsUtil = require("../_util/props-util");
  11. var _dropdown = _interopRequireDefault(require("../dropdown/dropdown"));
  12. var _DownOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/DownOutlined"));
  13. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  14. var _type = require("../_util/type");
  15. var __rest = void 0 && (void 0).__rest || function (s, e) {
  16. var t = {};
  17. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  18. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  19. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  20. }
  21. return t;
  22. };
  23. const breadcrumbItemProps = () => ({
  24. prefixCls: String,
  25. href: String,
  26. separator: _vueTypes.default.any,
  27. dropdownProps: (0, _type.objectType)(),
  28. overlay: _vueTypes.default.any,
  29. onClick: (0, _type.eventType)()
  30. });
  31. exports.breadcrumbItemProps = breadcrumbItemProps;
  32. var _default = exports.default = (0, _vue.defineComponent)({
  33. compatConfig: {
  34. MODE: 3
  35. },
  36. name: 'ABreadcrumbItem',
  37. inheritAttrs: false,
  38. __ANT_BREADCRUMB_ITEM: true,
  39. props: breadcrumbItemProps(),
  40. // emits: ['click'],
  41. slots: Object,
  42. setup(props, _ref) {
  43. let {
  44. slots,
  45. attrs,
  46. emit
  47. } = _ref;
  48. const {
  49. prefixCls
  50. } = (0, _useConfigInject.default)('breadcrumb', props);
  51. /**
  52. * if overlay is have
  53. * Wrap a Dropdown
  54. */
  55. const renderBreadcrumbNode = (breadcrumbItem, prefixCls) => {
  56. const overlay = (0, _propsUtil.getPropsSlot)(slots, props, 'overlay');
  57. if (overlay) {
  58. return (0, _vue.createVNode)(_dropdown.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props.dropdownProps), {}, {
  59. "overlay": overlay,
  60. "placement": "bottom"
  61. }), {
  62. default: () => [(0, _vue.createVNode)("span", {
  63. "class": `${prefixCls}-overlay-link`
  64. }, [breadcrumbItem, (0, _vue.createVNode)(_DownOutlined.default, null, null)])]
  65. });
  66. }
  67. return breadcrumbItem;
  68. };
  69. const handleClick = e => {
  70. emit('click', e);
  71. };
  72. return () => {
  73. var _a;
  74. const separator = (_a = (0, _propsUtil.getPropsSlot)(slots, props, 'separator')) !== null && _a !== void 0 ? _a : '/';
  75. const children = (0, _propsUtil.getPropsSlot)(slots, props);
  76. const {
  77. class: cls,
  78. style
  79. } = attrs,
  80. restAttrs = __rest(attrs, ["class", "style"]);
  81. let link;
  82. if (props.href !== undefined) {
  83. link = (0, _vue.createVNode)("a", (0, _objectSpread2.default)({
  84. "class": `${prefixCls.value}-link`,
  85. "onClick": handleClick
  86. }, restAttrs), [children]);
  87. } else {
  88. link = (0, _vue.createVNode)("span", (0, _objectSpread2.default)({
  89. "class": `${prefixCls.value}-link`,
  90. "onClick": handleClick
  91. }, restAttrs), [children]);
  92. }
  93. // wrap to dropDown
  94. link = renderBreadcrumbNode(link, prefixCls.value);
  95. if (children !== undefined && children !== null) {
  96. return (0, _vue.createVNode)("li", {
  97. "class": cls,
  98. "style": style
  99. }, [link, separator && (0, _vue.createVNode)("span", {
  100. "class": `${prefixCls.value}-separator`
  101. }, [separator])]);
  102. }
  103. return null;
  104. };
  105. }
  106. });