FloatButtonGroup.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. "use strict";
  2. "use client";
  3. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  4. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. exports.default = void 0;
  9. var _react = _interopRequireDefault(require("react"));
  10. var _CloseOutlined = _interopRequireDefault(require("@ant-design/icons/CloseOutlined"));
  11. var _FileTextOutlined = _interopRequireDefault(require("@ant-design/icons/FileTextOutlined"));
  12. var _classnames = _interopRequireDefault(require("classnames"));
  13. var _rcMotion = _interopRequireDefault(require("rc-motion"));
  14. var _useEvent = _interopRequireDefault(require("rc-util/lib/hooks/useEvent"));
  15. var _useMergedState = _interopRequireDefault(require("rc-util/lib/hooks/useMergedState"));
  16. var _useZIndex = require("../_util/hooks/useZIndex");
  17. var _warning = require("../_util/warning");
  18. var _context = require("../config-provider/context");
  19. var _useCSSVarCls = _interopRequireDefault(require("../config-provider/hooks/useCSSVarCls"));
  20. var _context2 = require("./context");
  21. var _FloatButton = _interopRequireWildcard(require("./FloatButton"));
  22. var _style = _interopRequireDefault(require("./style"));
  23. var __rest = void 0 && (void 0).__rest || function (s, e) {
  24. var t = {};
  25. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  26. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  27. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  28. }
  29. return t;
  30. };
  31. const FloatButtonGroup = props => {
  32. var _a;
  33. const {
  34. prefixCls: customizePrefixCls,
  35. className,
  36. style,
  37. shape = 'circle',
  38. type = 'default',
  39. placement = 'top',
  40. icon = /*#__PURE__*/_react.default.createElement(_FileTextOutlined.default, null),
  41. closeIcon,
  42. description,
  43. trigger,
  44. children,
  45. onOpenChange,
  46. open: customOpen,
  47. onClick: onTriggerButtonClick
  48. } = props,
  49. floatButtonProps = __rest(props, ["prefixCls", "className", "style", "shape", "type", "placement", "icon", "closeIcon", "description", "trigger", "children", "onOpenChange", "open", "onClick"]);
  50. const {
  51. direction,
  52. getPrefixCls,
  53. closeIcon: contextCloseIcon
  54. } = (0, _context.useComponentConfig)('floatButtonGroup');
  55. const mergedCloseIcon = (_a = closeIcon !== null && closeIcon !== void 0 ? closeIcon : contextCloseIcon) !== null && _a !== void 0 ? _a : /*#__PURE__*/_react.default.createElement(_CloseOutlined.default, null);
  56. const prefixCls = getPrefixCls(_FloatButton.floatButtonPrefixCls, customizePrefixCls);
  57. const rootCls = (0, _useCSSVarCls.default)(prefixCls);
  58. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls, rootCls);
  59. const groupPrefixCls = `${prefixCls}-group`;
  60. const isMenuMode = trigger && ['click', 'hover'].includes(trigger);
  61. const isValidPlacement = placement && ['top', 'left', 'right', 'bottom'].includes(placement);
  62. const groupCls = (0, _classnames.default)(groupPrefixCls, hashId, cssVarCls, rootCls, className, {
  63. [`${groupPrefixCls}-rtl`]: direction === 'rtl',
  64. [`${groupPrefixCls}-${shape}`]: shape,
  65. [`${groupPrefixCls}-${shape}-shadow`]: !isMenuMode,
  66. [`${groupPrefixCls}-${placement}`]: isMenuMode && isValidPlacement // 只有菜单模式才支持弹出方向
  67. });
  68. // ============================ zIndex ============================
  69. const [zIndex] = (0, _useZIndex.useZIndex)('FloatButton', style === null || style === void 0 ? void 0 : style.zIndex);
  70. const mergedStyle = Object.assign(Object.assign({}, style), {
  71. zIndex
  72. });
  73. const wrapperCls = (0, _classnames.default)(hashId, `${groupPrefixCls}-wrap`);
  74. const [open, setOpen] = (0, _useMergedState.default)(false, {
  75. value: customOpen
  76. });
  77. const floatButtonGroupRef = _react.default.useRef(null);
  78. // ========================== Open ==========================
  79. const hoverTrigger = trigger === 'hover';
  80. const clickTrigger = trigger === 'click';
  81. const triggerOpen = (0, _useEvent.default)(nextOpen => {
  82. if (open !== nextOpen) {
  83. setOpen(nextOpen);
  84. onOpenChange === null || onOpenChange === void 0 ? void 0 : onOpenChange(nextOpen);
  85. }
  86. });
  87. // ===================== Trigger: Hover =====================
  88. const onMouseEnter = () => {
  89. if (hoverTrigger) {
  90. triggerOpen(true);
  91. }
  92. };
  93. const onMouseLeave = () => {
  94. if (hoverTrigger) {
  95. triggerOpen(false);
  96. }
  97. };
  98. // ===================== Trigger: Click =====================
  99. const onInternalTriggerButtonClick = e => {
  100. if (clickTrigger) {
  101. triggerOpen(!open);
  102. }
  103. onTriggerButtonClick === null || onTriggerButtonClick === void 0 ? void 0 : onTriggerButtonClick(e);
  104. };
  105. _react.default.useEffect(() => {
  106. if (clickTrigger) {
  107. const onDocClick = e => {
  108. var _a;
  109. // Skip if click on the group
  110. if ((_a = floatButtonGroupRef.current) === null || _a === void 0 ? void 0 : _a.contains(e.target)) {
  111. return;
  112. }
  113. triggerOpen(false);
  114. };
  115. document.addEventListener('click', onDocClick, {
  116. capture: true
  117. });
  118. return () => document.removeEventListener('click', onDocClick, {
  119. capture: true
  120. });
  121. }
  122. }, [clickTrigger]);
  123. // ======================== Warning =========================
  124. if (process.env.NODE_ENV !== 'production') {
  125. const warning = (0, _warning.devUseWarning)('FloatButton.Group');
  126. process.env.NODE_ENV !== "production" ? warning(!('open' in props) || !!trigger, 'usage', '`open` need to be used together with `trigger`') : void 0;
  127. }
  128. // ========================= Render =========================
  129. return wrapCSSVar(/*#__PURE__*/_react.default.createElement(_context2.FloatButtonGroupProvider, {
  130. value: shape
  131. }, /*#__PURE__*/_react.default.createElement("div", {
  132. ref: floatButtonGroupRef,
  133. className: groupCls,
  134. style: mergedStyle,
  135. // Hover trigger
  136. onMouseEnter: onMouseEnter,
  137. onMouseLeave: onMouseLeave
  138. }, isMenuMode ? (/*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_rcMotion.default, {
  139. visible: open,
  140. motionName: `${groupPrefixCls}-wrap`
  141. }, ({
  142. className: motionClassName
  143. }) => (/*#__PURE__*/_react.default.createElement("div", {
  144. className: (0, _classnames.default)(motionClassName, wrapperCls)
  145. }, children))), /*#__PURE__*/_react.default.createElement(_FloatButton.default, Object.assign({
  146. type: type,
  147. icon: open ? mergedCloseIcon : icon,
  148. description: description,
  149. "aria-label": props['aria-label'],
  150. className: `${groupPrefixCls}-trigger`,
  151. onClick: onInternalTriggerButtonClick
  152. }, floatButtonProps)))) : children)));
  153. };
  154. var _default = exports.default = FloatButtonGroup;