UNPKG

2.06 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
5var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
6
7exports.__esModule = true;
8exports.default = void 0;
9
10var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
12var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
13
14var _classnames = _interopRequireDefault(require("classnames"));
15
16var _react = _interopRequireWildcard(require("react"));
17
18var _Transition = _interopRequireWildcard(require("react-transition-group/Transition"));
19
20var _end = _interopRequireDefault(require("dom-helpers/transition/end"));
21
22var _triggerBrowserReflow = _interopRequireDefault(require("./utils/triggerBrowserReflow"));
23
24var _fadeStyles;
25
26var defaultProps = {
27 in: false,
28 timeout: 300,
29 mountOnEnter: false,
30 unmountOnExit: false,
31 appear: false
32};
33var fadeStyles = (_fadeStyles = {}, _fadeStyles[_Transition.ENTERING] = 'show', _fadeStyles[_Transition.ENTERED] = 'show', _fadeStyles);
34
35var Fade = _react.default.forwardRef(function (_ref, ref) {
36 var className = _ref.className,
37 children = _ref.children,
38 props = (0, _objectWithoutPropertiesLoose2.default)(_ref, ["className", "children"]);
39 var handleEnter = (0, _react.useCallback)(function (node) {
40 (0, _triggerBrowserReflow.default)(node);
41 if (props.onEnter) props.onEnter(node);
42 }, [props]);
43 return _react.default.createElement(_Transition.default, (0, _extends2.default)({
44 ref: ref,
45 addEndListener: _end.default
46 }, props, {
47 onEnter: handleEnter
48 }), function (status, innerProps) {
49 return _react.default.cloneElement(children, (0, _extends2.default)({}, innerProps, {
50 className: (0, _classnames.default)('fade', className, children.props.className, fadeStyles[status])
51 }));
52 });
53});
54
55Fade.defaultProps = defaultProps;
56Fade.displayName = 'Fade';
57var _default = Fade;
58exports.default = _default;
59module.exports = exports["default"];
\No newline at end of file