dropdown-button.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  10. var _button = _interopRequireDefault(require("../button"));
  11. var _dropdown = _interopRequireDefault(require("./dropdown"));
  12. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  13. var _propsUtil = require("../_util/props-util");
  14. var _props = require("./props");
  15. var _EllipsisOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/EllipsisOutlined"));
  16. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  17. var _style = _interopRequireDefault(require("./style"));
  18. var __rest = void 0 && (void 0).__rest || function (s, e) {
  19. var t = {};
  20. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  21. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  22. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  23. }
  24. return t;
  25. };
  26. const ButtonGroup = _button.default.Group;
  27. var _default = exports.default = (0, _vue.defineComponent)({
  28. compatConfig: {
  29. MODE: 3
  30. },
  31. name: 'ADropdownButton',
  32. inheritAttrs: false,
  33. __ANT_BUTTON: true,
  34. props: (0, _propsUtil.initDefaultProps)((0, _props.dropdownButtonProps)(), {
  35. trigger: 'hover',
  36. placement: 'bottomRight',
  37. type: 'default'
  38. }),
  39. // emits: ['click', 'visibleChange', 'update:visible'],s
  40. slots: Object,
  41. setup(props, _ref) {
  42. let {
  43. slots,
  44. attrs,
  45. emit
  46. } = _ref;
  47. const handleVisibleChange = val => {
  48. emit('update:visible', val);
  49. emit('visibleChange', val);
  50. emit('update:open', val);
  51. emit('openChange', val);
  52. };
  53. const {
  54. prefixCls,
  55. direction,
  56. getPopupContainer
  57. } = (0, _useConfigInject.default)('dropdown', props);
  58. const buttonPrefixCls = (0, _vue.computed)(() => `${prefixCls.value}-button`);
  59. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  60. return () => {
  61. var _a, _b;
  62. const _c = (0, _extends2.default)((0, _extends2.default)({}, props), attrs),
  63. {
  64. type = 'default',
  65. disabled,
  66. danger,
  67. loading,
  68. htmlType,
  69. class: className = '',
  70. overlay = (_a = slots.overlay) === null || _a === void 0 ? void 0 : _a.call(slots),
  71. trigger,
  72. align,
  73. open,
  74. visible,
  75. onVisibleChange: _onVisibleChange,
  76. placement = direction.value === 'rtl' ? 'bottomLeft' : 'bottomRight',
  77. href,
  78. title,
  79. icon = ((_b = slots.icon) === null || _b === void 0 ? void 0 : _b.call(slots)) || (0, _vue.createVNode)(_EllipsisOutlined.default, null, null),
  80. mouseEnterDelay,
  81. mouseLeaveDelay,
  82. overlayClassName,
  83. overlayStyle,
  84. destroyPopupOnHide,
  85. onClick,
  86. 'onUpdate:open': _updateVisible
  87. } = _c,
  88. restProps = __rest(_c, ["type", "disabled", "danger", "loading", "htmlType", "class", "overlay", "trigger", "align", "open", "visible", "onVisibleChange", "placement", "href", "title", "icon", "mouseEnterDelay", "mouseLeaveDelay", "overlayClassName", "overlayStyle", "destroyPopupOnHide", "onClick", 'onUpdate:open']);
  89. const dropdownProps = {
  90. align,
  91. disabled,
  92. trigger: disabled ? [] : trigger,
  93. placement,
  94. getPopupContainer: getPopupContainer === null || getPopupContainer === void 0 ? void 0 : getPopupContainer.value,
  95. onOpenChange: handleVisibleChange,
  96. mouseEnterDelay,
  97. mouseLeaveDelay,
  98. open: open !== null && open !== void 0 ? open : visible,
  99. overlayClassName,
  100. overlayStyle,
  101. destroyPopupOnHide
  102. };
  103. const leftButton = (0, _vue.createVNode)(_button.default, {
  104. "danger": danger,
  105. "type": type,
  106. "disabled": disabled,
  107. "loading": loading,
  108. "onClick": onClick,
  109. "htmlType": htmlType,
  110. "href": href,
  111. "title": title
  112. }, {
  113. default: slots.default
  114. });
  115. const rightButton = (0, _vue.createVNode)(_button.default, {
  116. "danger": danger,
  117. "type": type,
  118. "icon": icon
  119. }, null);
  120. return wrapSSR((0, _vue.createVNode)(ButtonGroup, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, restProps), {}, {
  121. "class": (0, _classNames.default)(buttonPrefixCls.value, className, hashId.value)
  122. }), {
  123. default: () => [slots.leftButton ? slots.leftButton({
  124. button: leftButton
  125. }) : leftButton, (0, _vue.createVNode)(_dropdown.default, dropdownProps, {
  126. default: () => [slots.rightButton ? slots.rightButton({
  127. button: rightButton
  128. }) : rightButton],
  129. overlay: () => overlay
  130. })]
  131. }));
  132. };
  133. }
  134. });