index.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. "use strict";
  2. "use client";
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. exports.default = void 0;
  9. var _react = _interopRequireWildcard(require("react"));
  10. var React = _react;
  11. var _classnames = _interopRequireDefault(require("classnames"));
  12. var _useMergedState = _interopRequireDefault(require("rc-util/lib/hooks/useMergedState"));
  13. var _KeyCode = _interopRequireDefault(require("rc-util/lib/KeyCode"));
  14. var _getRenderPropValue = require("../_util/getRenderPropValue");
  15. var _motion = require("../_util/motion");
  16. var _reactNode = require("../_util/reactNode");
  17. var _context = require("../config-provider/context");
  18. var _tooltip = _interopRequireDefault(require("../tooltip"));
  19. var _PurePanel = _interopRequireWildcard(require("./PurePanel"));
  20. var _style = _interopRequireDefault(require("./style"));
  21. var __rest = void 0 && (void 0).__rest || function (s, e) {
  22. var t = {};
  23. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  24. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  25. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  26. }
  27. return t;
  28. };
  29. // CSSINJS
  30. const InternalPopover = /*#__PURE__*/React.forwardRef((props, ref) => {
  31. var _a, _b;
  32. const {
  33. prefixCls: customizePrefixCls,
  34. title,
  35. content,
  36. overlayClassName,
  37. placement = 'top',
  38. trigger = 'hover',
  39. children,
  40. mouseEnterDelay = 0.1,
  41. mouseLeaveDelay = 0.1,
  42. onOpenChange,
  43. overlayStyle = {},
  44. styles,
  45. classNames: popoverClassNames
  46. } = props,
  47. otherProps = __rest(props, ["prefixCls", "title", "content", "overlayClassName", "placement", "trigger", "children", "mouseEnterDelay", "mouseLeaveDelay", "onOpenChange", "overlayStyle", "styles", "classNames"]);
  48. const {
  49. getPrefixCls,
  50. className: contextClassName,
  51. style: contextStyle,
  52. classNames: contextClassNames,
  53. styles: contextStyles
  54. } = (0, _context.useComponentConfig)('popover');
  55. const prefixCls = getPrefixCls('popover', customizePrefixCls);
  56. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls);
  57. const rootPrefixCls = getPrefixCls();
  58. const rootClassNames = (0, _classnames.default)(overlayClassName, hashId, cssVarCls, contextClassName, contextClassNames.root, popoverClassNames === null || popoverClassNames === void 0 ? void 0 : popoverClassNames.root);
  59. const bodyClassNames = (0, _classnames.default)(contextClassNames.body, popoverClassNames === null || popoverClassNames === void 0 ? void 0 : popoverClassNames.body);
  60. const [open, setOpen] = (0, _useMergedState.default)(false, {
  61. value: (_a = props.open) !== null && _a !== void 0 ? _a : props.visible,
  62. defaultValue: (_b = props.defaultOpen) !== null && _b !== void 0 ? _b : props.defaultVisible
  63. });
  64. const settingOpen = (value, e) => {
  65. setOpen(value, true);
  66. onOpenChange === null || onOpenChange === void 0 ? void 0 : onOpenChange(value, e);
  67. };
  68. const onKeyDown = e => {
  69. if (e.keyCode === _KeyCode.default.ESC) {
  70. settingOpen(false, e);
  71. }
  72. };
  73. const onInternalOpenChange = value => {
  74. settingOpen(value);
  75. };
  76. const titleNode = (0, _getRenderPropValue.getRenderPropValue)(title);
  77. const contentNode = (0, _getRenderPropValue.getRenderPropValue)(content);
  78. return wrapCSSVar(/*#__PURE__*/React.createElement(_tooltip.default, Object.assign({
  79. placement: placement,
  80. trigger: trigger,
  81. mouseEnterDelay: mouseEnterDelay,
  82. mouseLeaveDelay: mouseLeaveDelay
  83. }, otherProps, {
  84. prefixCls: prefixCls,
  85. classNames: {
  86. root: rootClassNames,
  87. body: bodyClassNames
  88. },
  89. styles: {
  90. root: Object.assign(Object.assign(Object.assign(Object.assign({}, contextStyles.root), contextStyle), overlayStyle), styles === null || styles === void 0 ? void 0 : styles.root),
  91. body: Object.assign(Object.assign({}, contextStyles.body), styles === null || styles === void 0 ? void 0 : styles.body)
  92. },
  93. ref: ref,
  94. open: open,
  95. onOpenChange: onInternalOpenChange,
  96. overlay: titleNode || contentNode ? (/*#__PURE__*/React.createElement(_PurePanel.Overlay, {
  97. prefixCls: prefixCls,
  98. title: titleNode,
  99. content: contentNode
  100. })) : null,
  101. transitionName: (0, _motion.getTransitionName)(rootPrefixCls, 'zoom-big', otherProps.transitionName),
  102. "data-popover-inject": true
  103. }), (0, _reactNode.cloneElement)(children, {
  104. onKeyDown: e => {
  105. var _a, _b;
  106. if (/*#__PURE__*/(0, _react.isValidElement)(children)) {
  107. (_b = children === null || children === void 0 ? void 0 : (_a = children.props).onKeyDown) === null || _b === void 0 ? void 0 : _b.call(_a, e);
  108. }
  109. onKeyDown(e);
  110. }
  111. })));
  112. });
  113. const Popover = InternalPopover;
  114. Popover._InternalPanelDoNotUseOrYouWillBeFired = _PurePanel.default;
  115. if (process.env.NODE_ENV !== 'production') {
  116. Popover.displayName = 'Popover';
  117. }
  118. var _default = exports.default = Popover;