DialogWrap.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. var _typeof = require("@babel/runtime/helpers/typeof");
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.default = void 0;
  8. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  9. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  10. var _portal = _interopRequireDefault(require("@rc-component/portal"));
  11. var React = _interopRequireWildcard(require("react"));
  12. var _context = require("./context");
  13. var _Dialog = _interopRequireDefault(require("./Dialog"));
  14. function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
  15. function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
  16. // fix issue #10656
  17. /*
  18. * getContainer remarks
  19. * Custom container should not be return, because in the Portal component, it will remove the
  20. * return container element here, if the custom container is the only child of it's component,
  21. * like issue #10656, It will has a conflict with removeChild method in react-dom.
  22. * So here should add a child (div element) to custom container.
  23. * */
  24. var DialogWrap = function DialogWrap(props) {
  25. var visible = props.visible,
  26. getContainer = props.getContainer,
  27. forceRender = props.forceRender,
  28. _props$destroyOnClose = props.destroyOnClose,
  29. destroyOnClose = _props$destroyOnClose === void 0 ? false : _props$destroyOnClose,
  30. _afterClose = props.afterClose,
  31. panelRef = props.panelRef;
  32. var _React$useState = React.useState(visible),
  33. _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
  34. animatedVisible = _React$useState2[0],
  35. setAnimatedVisible = _React$useState2[1];
  36. var refContext = React.useMemo(function () {
  37. return {
  38. panel: panelRef
  39. };
  40. }, [panelRef]);
  41. React.useEffect(function () {
  42. if (visible) {
  43. setAnimatedVisible(true);
  44. }
  45. }, [visible]);
  46. // Destroy on close will remove wrapped div
  47. if (!forceRender && destroyOnClose && !animatedVisible) {
  48. return null;
  49. }
  50. return /*#__PURE__*/React.createElement(_context.RefContext.Provider, {
  51. value: refContext
  52. }, /*#__PURE__*/React.createElement(_portal.default, {
  53. open: visible || forceRender || animatedVisible,
  54. autoDestroy: false,
  55. getContainer: getContainer,
  56. autoLock: visible || animatedVisible
  57. }, /*#__PURE__*/React.createElement(_Dialog.default, (0, _extends2.default)({}, props, {
  58. destroyOnClose: destroyOnClose,
  59. afterClose: function afterClose() {
  60. _afterClose === null || _afterClose === void 0 || _afterClose();
  61. setAnimatedVisible(false);
  62. }
  63. }))));
  64. };
  65. DialogWrap.displayName = 'Dialog';
  66. var _default = exports.default = DialogWrap;