1 | "use strict";
|
2 |
|
3 | var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
|
4 |
|
5 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
6 |
|
7 | Object.defineProperty(exports, "__esModule", {
|
8 | value: true
|
9 | });
|
10 | exports.default = void 0;
|
11 |
|
12 | var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
13 |
|
14 | var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
15 |
|
16 | var React = _interopRequireWildcard(require("react"));
|
17 |
|
18 | var _PortalWrapper = _interopRequireDefault(require("rc-util/lib/PortalWrapper"));
|
19 |
|
20 | var _Dialog = _interopRequireDefault(require("./Dialog"));
|
21 |
|
22 |
|
23 |
|
24 |
|
25 |
|
26 |
|
27 |
|
28 |
|
29 |
|
30 |
|
31 | var DialogWrap = function DialogWrap(props) {
|
32 | var visible = props.visible,
|
33 | getContainer = props.getContainer,
|
34 | forceRender = props.forceRender,
|
35 | _props$destroyOnClose = props.destroyOnClose,
|
36 | destroyOnClose = _props$destroyOnClose === void 0 ? false : _props$destroyOnClose,
|
37 | _afterClose = props.afterClose;
|
38 |
|
39 | var _React$useState = React.useState(visible),
|
40 | _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
|
41 | animatedVisible = _React$useState2[0],
|
42 | setAnimatedVisible = _React$useState2[1];
|
43 |
|
44 | React.useEffect(function () {
|
45 | if (visible) {
|
46 | setAnimatedVisible(true);
|
47 | }
|
48 | }, [visible]);
|
49 |
|
50 | if (getContainer === false) {
|
51 | return React.createElement(_Dialog.default, (0, _extends2.default)({}, props, {
|
52 | getOpenCount: function getOpenCount() {
|
53 | return 2;
|
54 | }
|
55 |
|
56 | }));
|
57 | }
|
58 |
|
59 |
|
60 | if (!forceRender && destroyOnClose && !animatedVisible) {
|
61 | return null;
|
62 | }
|
63 |
|
64 | return React.createElement(_PortalWrapper.default, {
|
65 | visible: visible,
|
66 | forceRender: forceRender,
|
67 | getContainer: getContainer
|
68 | }, function (childProps) {
|
69 | return React.createElement(_Dialog.default, (0, _extends2.default)({}, props, {
|
70 | destroyOnClose: destroyOnClose,
|
71 | afterClose: function afterClose() {
|
72 | _afterClose === null || _afterClose === void 0 ? void 0 : _afterClose();
|
73 | setAnimatedVisible(false);
|
74 | }
|
75 | }, childProps));
|
76 | });
|
77 | };
|
78 |
|
79 | DialogWrap.displayName = 'Dialog';
|
80 | var _default = DialogWrap;
|
81 | exports.default = _default; |
\ | No newline at end of file |