PurePanel.js 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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 = exports.RawPurePanel = exports.Overlay = void 0;
  9. var React = _interopRequireWildcard(require("react"));
  10. var _classnames = _interopRequireDefault(require("classnames"));
  11. var _rcTooltip = require("rc-tooltip");
  12. var _getRenderPropValue = require("../_util/getRenderPropValue");
  13. var _configProvider = require("../config-provider");
  14. var _style = _interopRequireDefault(require("./style"));
  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 Overlay = ({
  24. title,
  25. content,
  26. prefixCls
  27. }) => {
  28. if (!title && !content) {
  29. return null;
  30. }
  31. return /*#__PURE__*/React.createElement(React.Fragment, null, title && /*#__PURE__*/React.createElement("div", {
  32. className: `${prefixCls}-title`
  33. }, title), content && /*#__PURE__*/React.createElement("div", {
  34. className: `${prefixCls}-inner-content`
  35. }, content));
  36. };
  37. exports.Overlay = Overlay;
  38. const RawPurePanel = props => {
  39. const {
  40. hashId,
  41. prefixCls,
  42. className,
  43. style,
  44. placement = 'top',
  45. title,
  46. content,
  47. children
  48. } = props;
  49. const titleNode = (0, _getRenderPropValue.getRenderPropValue)(title);
  50. const contentNode = (0, _getRenderPropValue.getRenderPropValue)(content);
  51. const cls = (0, _classnames.default)(hashId, prefixCls, `${prefixCls}-pure`, `${prefixCls}-placement-${placement}`, className);
  52. return /*#__PURE__*/React.createElement("div", {
  53. className: cls,
  54. style: style
  55. }, /*#__PURE__*/React.createElement("div", {
  56. className: `${prefixCls}-arrow`
  57. }), /*#__PURE__*/React.createElement(_rcTooltip.Popup, Object.assign({}, props, {
  58. className: hashId,
  59. prefixCls: prefixCls
  60. }), children || /*#__PURE__*/React.createElement(Overlay, {
  61. prefixCls: prefixCls,
  62. title: titleNode,
  63. content: contentNode
  64. })));
  65. };
  66. exports.RawPurePanel = RawPurePanel;
  67. const PurePanel = props => {
  68. const {
  69. prefixCls: customizePrefixCls,
  70. className
  71. } = props,
  72. restProps = __rest(props, ["prefixCls", "className"]);
  73. const {
  74. getPrefixCls
  75. } = React.useContext(_configProvider.ConfigContext);
  76. const prefixCls = getPrefixCls('popover', customizePrefixCls);
  77. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls);
  78. return wrapCSSVar(/*#__PURE__*/React.createElement(RawPurePanel, Object.assign({}, restProps, {
  79. prefixCls: prefixCls,
  80. hashId: hashId,
  81. className: (0, _classnames.default)(className, cssVarCls)
  82. })));
  83. };
  84. var _default = exports.default = PurePanel;