PurePanel.js 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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 _classnames = _interopRequireDefault(require("classnames"));
  11. var _rcDialog = require("rc-dialog");
  12. var _PurePanel = require("../_util/PurePanel");
  13. var _configProvider = require("../config-provider");
  14. var _useCSSVarCls = _interopRequireDefault(require("../config-provider/hooks/useCSSVarCls"));
  15. var _ConfirmDialog = require("./ConfirmDialog");
  16. var _shared = require("./shared");
  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 PurePanel = props => {
  27. const {
  28. prefixCls: customizePrefixCls,
  29. className,
  30. closeIcon,
  31. closable,
  32. type,
  33. title,
  34. children,
  35. footer
  36. } = props,
  37. restProps = __rest(props, ["prefixCls", "className", "closeIcon", "closable", "type", "title", "children", "footer"]);
  38. const {
  39. getPrefixCls
  40. } = React.useContext(_configProvider.ConfigContext);
  41. const rootPrefixCls = getPrefixCls();
  42. const prefixCls = customizePrefixCls || getPrefixCls('modal');
  43. const rootCls = (0, _useCSSVarCls.default)(rootPrefixCls);
  44. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls, rootCls);
  45. const confirmPrefixCls = `${prefixCls}-confirm`;
  46. // Choose target props by confirm mark
  47. let additionalProps = {};
  48. if (type) {
  49. additionalProps = {
  50. closable: closable !== null && closable !== void 0 ? closable : false,
  51. title: '',
  52. footer: '',
  53. children: (/*#__PURE__*/React.createElement(_ConfirmDialog.ConfirmContent, Object.assign({}, props, {
  54. prefixCls: prefixCls,
  55. confirmPrefixCls: confirmPrefixCls,
  56. rootPrefixCls: rootPrefixCls,
  57. content: children
  58. })))
  59. };
  60. } else {
  61. additionalProps = {
  62. closable: closable !== null && closable !== void 0 ? closable : true,
  63. title,
  64. footer: footer !== null && /*#__PURE__*/React.createElement(_shared.Footer, Object.assign({}, props)),
  65. children
  66. };
  67. }
  68. return wrapCSSVar(/*#__PURE__*/React.createElement(_rcDialog.Panel, Object.assign({
  69. prefixCls: prefixCls,
  70. className: (0, _classnames.default)(hashId, `${prefixCls}-pure-panel`, type && confirmPrefixCls, type && `${confirmPrefixCls}-${type}`, className, cssVarCls, rootCls)
  71. }, restProps, {
  72. closeIcon: (0, _shared.renderCloseIcon)(prefixCls, closeIcon),
  73. closable: closable
  74. }, additionalProps)));
  75. };
  76. var _default = exports.default = (0, _PurePanel.withPureRenderTheme)(PurePanel);