You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					648 lines
				
				20 KiB
			
		
		
			
		
	
	
					648 lines
				
				20 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								"use strict";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								exports.__esModule = true;
							 | 
						||
| 
								 | 
							
								exports.default = exports.EXITING = exports.ENTERED = exports.ENTERING = exports.EXITED = exports.UNMOUNTED = void 0;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _propTypes = _interopRequireDefault(require("prop-types"));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _react = _interopRequireDefault(require("react"));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _reactDom = _interopRequireDefault(require("react-dom"));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _config = _interopRequireDefault(require("./config"));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _PropTypes = require("./utils/PropTypes");
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _TransitionGroupContext = _interopRequireDefault(require("./TransitionGroupContext"));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _reflow = require("./utils/reflow");
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var UNMOUNTED = 'unmounted';
							 | 
						||
| 
								 | 
							
								exports.UNMOUNTED = UNMOUNTED;
							 | 
						||
| 
								 | 
							
								var EXITED = 'exited';
							 | 
						||
| 
								 | 
							
								exports.EXITED = EXITED;
							 | 
						||
| 
								 | 
							
								var ENTERING = 'entering';
							 | 
						||
| 
								 | 
							
								exports.ENTERING = ENTERING;
							 | 
						||
| 
								 | 
							
								var ENTERED = 'entered';
							 | 
						||
| 
								 | 
							
								exports.ENTERED = ENTERED;
							 | 
						||
| 
								 | 
							
								var EXITING = 'exiting';
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * The Transition component lets you describe a transition from one component
							 | 
						||
| 
								 | 
							
								 * state to another _over time_ with a simple declarative API. Most commonly
							 | 
						||
| 
								 | 
							
								 * it's used to animate the mounting and unmounting of a component, but can also
							 | 
						||
| 
								 | 
							
								 * be used to describe in-place transition states as well.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * ---
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * **Note**: `Transition` is a platform-agnostic base component. If you're using
							 | 
						||
| 
								 | 
							
								 * transitions in CSS, you'll probably want to use
							 | 
						||
| 
								 | 
							
								 * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)
							 | 
						||
| 
								 | 
							
								 * instead. It inherits all the features of `Transition`, but contains
							 | 
						||
| 
								 | 
							
								 * additional features necessary to play nice with CSS transitions (hence the
							 | 
						||
| 
								 | 
							
								 * name of the component).
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * ---
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * By default the `Transition` component does not alter the behavior of the
							 | 
						||
| 
								 | 
							
								 * component it renders, it only tracks "enter" and "exit" states for the
							 | 
						||
| 
								 | 
							
								 * components. It's up to you to give meaning and effect to those states. For
							 | 
						||
| 
								 | 
							
								 * example we can add styles to a component when it enters or exits:
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * ```jsx
							 | 
						||
| 
								 | 
							
								 * import { Transition } from 'react-transition-group';
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * const duration = 300;
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * const defaultStyle = {
							 | 
						||
| 
								 | 
							
								 *   transition: `opacity ${duration}ms ease-in-out`,
							 | 
						||
| 
								 | 
							
								 *   opacity: 0,
							 | 
						||
| 
								 | 
							
								 * }
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * const transitionStyles = {
							 | 
						||
| 
								 | 
							
								 *   entering: { opacity: 1 },
							 | 
						||
| 
								 | 
							
								 *   entered:  { opacity: 1 },
							 | 
						||
| 
								 | 
							
								 *   exiting:  { opacity: 0 },
							 | 
						||
| 
								 | 
							
								 *   exited:  { opacity: 0 },
							 | 
						||
| 
								 | 
							
								 * };
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * const Fade = ({ in: inProp }) => (
							 | 
						||
| 
								 | 
							
								 *   <Transition in={inProp} timeout={duration}>
							 | 
						||
| 
								 | 
							
								 *     {state => (
							 | 
						||
| 
								 | 
							
								 *       <div style={{
							 | 
						||
| 
								 | 
							
								 *         ...defaultStyle,
							 | 
						||
| 
								 | 
							
								 *         ...transitionStyles[state]
							 | 
						||
| 
								 | 
							
								 *       }}>
							 | 
						||
| 
								 | 
							
								 *         I'm a fade Transition!
							 | 
						||
| 
								 | 
							
								 *       </div>
							 | 
						||
| 
								 | 
							
								 *     )}
							 | 
						||
| 
								 | 
							
								 *   </Transition>
							 | 
						||
| 
								 | 
							
								 * );
							 | 
						||
| 
								 | 
							
								 * ```
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * There are 4 main states a Transition can be in:
							 | 
						||
| 
								 | 
							
								 *  - `'entering'`
							 | 
						||
| 
								 | 
							
								 *  - `'entered'`
							 | 
						||
| 
								 | 
							
								 *  - `'exiting'`
							 | 
						||
| 
								 | 
							
								 *  - `'exited'`
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Transition state is toggled via the `in` prop. When `true` the component
							 | 
						||
| 
								 | 
							
								 * begins the "Enter" stage. During this stage, the component will shift from
							 | 
						||
| 
								 | 
							
								 * its current transition state, to `'entering'` for the duration of the
							 | 
						||
| 
								 | 
							
								 * transition and then to the `'entered'` stage once it's complete. Let's take
							 | 
						||
| 
								 | 
							
								 * the following example (we'll use the
							 | 
						||
| 
								 | 
							
								 * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * ```jsx
							 | 
						||
| 
								 | 
							
								 * function App() {
							 | 
						||
| 
								 | 
							
								 *   const [inProp, setInProp] = useState(false);
							 | 
						||
| 
								 | 
							
								 *   return (
							 | 
						||
| 
								 | 
							
								 *     <div>
							 | 
						||
| 
								 | 
							
								 *       <Transition in={inProp} timeout={500}>
							 | 
						||
| 
								 | 
							
								 *         {state => (
							 | 
						||
| 
								 | 
							
								 *           // ...
							 | 
						||
| 
								 | 
							
								 *         )}
							 | 
						||
| 
								 | 
							
								 *       </Transition>
							 | 
						||
| 
								 | 
							
								 *       <button onClick={() => setInProp(true)}>
							 | 
						||
| 
								 | 
							
								 *         Click to Enter
							 | 
						||
| 
								 | 
							
								 *       </button>
							 | 
						||
| 
								 | 
							
								 *     </div>
							 | 
						||
| 
								 | 
							
								 *   );
							 | 
						||
| 
								 | 
							
								 * }
							 | 
						||
| 
								 | 
							
								 * ```
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * When the button is clicked the component will shift to the `'entering'` state
							 | 
						||
| 
								 | 
							
								 * and stay there for 500ms (the value of `timeout`) before it finally switches
							 | 
						||
| 
								 | 
							
								 * to `'entered'`.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * When `in` is `false` the same thing happens except the state moves from
							 | 
						||
| 
								 | 
							
								 * `'exiting'` to `'exited'`.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								exports.EXITING = EXITING;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var Transition = /*#__PURE__*/function (_React$Component) {
							 | 
						||
| 
								 | 
							
								  _inheritsLoose(Transition, _React$Component);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  function Transition(props, context) {
							 | 
						||
| 
								 | 
							
								    var _this;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    _this = _React$Component.call(this, props, context) || this;
							 | 
						||
| 
								 | 
							
								    var parentGroup = context; // In the context of a TransitionGroup all enters are really appears
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;
							 | 
						||
| 
								 | 
							
								    var initialStatus;
							 | 
						||
| 
								 | 
							
								    _this.appearStatus = null;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (props.in) {
							 | 
						||
| 
								 | 
							
								      if (appear) {
							 | 
						||
| 
								 | 
							
								        initialStatus = EXITED;
							 | 
						||
| 
								 | 
							
								        _this.appearStatus = ENTERING;
							 | 
						||
| 
								 | 
							
								      } else {
							 | 
						||
| 
								 | 
							
								        initialStatus = ENTERED;
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    } else {
							 | 
						||
| 
								 | 
							
								      if (props.unmountOnExit || props.mountOnEnter) {
							 | 
						||
| 
								 | 
							
								        initialStatus = UNMOUNTED;
							 | 
						||
| 
								 | 
							
								      } else {
							 | 
						||
| 
								 | 
							
								        initialStatus = EXITED;
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    _this.state = {
							 | 
						||
| 
								 | 
							
								      status: initialStatus
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								    _this.nextCallback = null;
							 | 
						||
| 
								 | 
							
								    return _this;
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {
							 | 
						||
| 
								 | 
							
								    var nextIn = _ref.in;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (nextIn && prevState.status === UNMOUNTED) {
							 | 
						||
| 
								 | 
							
								      return {
							 | 
						||
| 
								 | 
							
								        status: EXITED
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return null;
							 | 
						||
| 
								 | 
							
								  } // getSnapshotBeforeUpdate(prevProps) {
							 | 
						||
| 
								 | 
							
								  //   let nextStatus = null
							 | 
						||
| 
								 | 
							
								  //   if (prevProps !== this.props) {
							 | 
						||
| 
								 | 
							
								  //     const { status } = this.state
							 | 
						||
| 
								 | 
							
								  //     if (this.props.in) {
							 | 
						||
| 
								 | 
							
								  //       if (status !== ENTERING && status !== ENTERED) {
							 | 
						||
| 
								 | 
							
								  //         nextStatus = ENTERING
							 | 
						||
| 
								 | 
							
								  //       }
							 | 
						||
| 
								 | 
							
								  //     } else {
							 | 
						||
| 
								 | 
							
								  //       if (status === ENTERING || status === ENTERED) {
							 | 
						||
| 
								 | 
							
								  //         nextStatus = EXITING
							 | 
						||
| 
								 | 
							
								  //       }
							 | 
						||
| 
								 | 
							
								  //     }
							 | 
						||
| 
								 | 
							
								  //   }
							 | 
						||
| 
								 | 
							
								  //   return { nextStatus }
							 | 
						||
| 
								 | 
							
								  // }
							 | 
						||
| 
								 | 
							
								  ;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var _proto = Transition.prototype;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.componentDidMount = function componentDidMount() {
							 | 
						||
| 
								 | 
							
								    this.updateStatus(true, this.appearStatus);
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.componentDidUpdate = function componentDidUpdate(prevProps) {
							 | 
						||
| 
								 | 
							
								    var nextStatus = null;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (prevProps !== this.props) {
							 | 
						||
| 
								 | 
							
								      var status = this.state.status;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      if (this.props.in) {
							 | 
						||
| 
								 | 
							
								        if (status !== ENTERING && status !== ENTERED) {
							 | 
						||
| 
								 | 
							
								          nextStatus = ENTERING;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      } else {
							 | 
						||
| 
								 | 
							
								        if (status === ENTERING || status === ENTERED) {
							 | 
						||
| 
								 | 
							
								          nextStatus = EXITING;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    this.updateStatus(false, nextStatus);
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.componentWillUnmount = function componentWillUnmount() {
							 | 
						||
| 
								 | 
							
								    this.cancelNextCallback();
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.getTimeouts = function getTimeouts() {
							 | 
						||
| 
								 | 
							
								    var timeout = this.props.timeout;
							 | 
						||
| 
								 | 
							
								    var exit, enter, appear;
							 | 
						||
| 
								 | 
							
								    exit = enter = appear = timeout;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (timeout != null && typeof timeout !== 'number') {
							 | 
						||
| 
								 | 
							
								      exit = timeout.exit;
							 | 
						||
| 
								 | 
							
								      enter = timeout.enter; // TODO: remove fallback for next major
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      appear = timeout.appear !== undefined ? timeout.appear : enter;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return {
							 | 
						||
| 
								 | 
							
								      exit: exit,
							 | 
						||
| 
								 | 
							
								      enter: enter,
							 | 
						||
| 
								 | 
							
								      appear: appear
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.updateStatus = function updateStatus(mounting, nextStatus) {
							 | 
						||
| 
								 | 
							
								    if (mounting === void 0) {
							 | 
						||
| 
								 | 
							
								      mounting = false;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (nextStatus !== null) {
							 | 
						||
| 
								 | 
							
								      // nextStatus will always be ENTERING or EXITING.
							 | 
						||
| 
								 | 
							
								      this.cancelNextCallback();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      if (nextStatus === ENTERING) {
							 | 
						||
| 
								 | 
							
								        if (this.props.unmountOnExit || this.props.mountOnEnter) {
							 | 
						||
| 
								 | 
							
								          var node = this.props.nodeRef ? this.props.nodeRef.current : _reactDom.default.findDOMNode(this); // https://github.com/reactjs/react-transition-group/pull/749
							 | 
						||
| 
								 | 
							
								          // With unmountOnExit or mountOnEnter, the enter animation should happen at the transition between `exited` and `entering`.
							 | 
						||
| 
								 | 
							
								          // To make the animation happen,  we have to separate each rendering and avoid being processed as batched.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								          if (node) (0, _reflow.forceReflow)(node);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        this.performEnter(mounting);
							 | 
						||
| 
								 | 
							
								      } else {
							 | 
						||
| 
								 | 
							
								        this.performExit();
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    } else if (this.props.unmountOnExit && this.state.status === EXITED) {
							 | 
						||
| 
								 | 
							
								      this.setState({
							 | 
						||
| 
								 | 
							
								        status: UNMOUNTED
							 | 
						||
| 
								 | 
							
								      });
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.performEnter = function performEnter(mounting) {
							 | 
						||
| 
								 | 
							
								    var _this2 = this;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    var enter = this.props.enter;
							 | 
						||
| 
								 | 
							
								    var appearing = this.context ? this.context.isMounting : mounting;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    var _ref2 = this.props.nodeRef ? [appearing] : [_reactDom.default.findDOMNode(this), appearing],
							 | 
						||
| 
								 | 
							
								        maybeNode = _ref2[0],
							 | 
						||
| 
								 | 
							
								        maybeAppearing = _ref2[1];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    var timeouts = this.getTimeouts();
							 | 
						||
| 
								 | 
							
								    var enterTimeout = appearing ? timeouts.appear : timeouts.enter; // no enter animation skip right to ENTERED
							 | 
						||
| 
								 | 
							
								    // if we are mounting and running this it means appear _must_ be set
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (!mounting && !enter || _config.default.disabled) {
							 | 
						||
| 
								 | 
							
								      this.safeSetState({
							 | 
						||
| 
								 | 
							
								        status: ENTERED
							 | 
						||
| 
								 | 
							
								      }, function () {
							 | 
						||
| 
								 | 
							
								        _this2.props.onEntered(maybeNode);
							 | 
						||
| 
								 | 
							
								      });
							 | 
						||
| 
								 | 
							
								      return;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    this.props.onEnter(maybeNode, maybeAppearing);
							 | 
						||
| 
								 | 
							
								    this.safeSetState({
							 | 
						||
| 
								 | 
							
								      status: ENTERING
							 | 
						||
| 
								 | 
							
								    }, function () {
							 | 
						||
| 
								 | 
							
								      _this2.props.onEntering(maybeNode, maybeAppearing);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      _this2.onTransitionEnd(enterTimeout, function () {
							 | 
						||
| 
								 | 
							
								        _this2.safeSetState({
							 | 
						||
| 
								 | 
							
								          status: ENTERED
							 | 
						||
| 
								 | 
							
								        }, function () {
							 | 
						||
| 
								 | 
							
								          _this2.props.onEntered(maybeNode, maybeAppearing);
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								      });
							 | 
						||
| 
								 | 
							
								    });
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.performExit = function performExit() {
							 | 
						||
| 
								 | 
							
								    var _this3 = this;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    var exit = this.props.exit;
							 | 
						||
| 
								 | 
							
								    var timeouts = this.getTimeouts();
							 | 
						||
| 
								 | 
							
								    var maybeNode = this.props.nodeRef ? undefined : _reactDom.default.findDOMNode(this); // no exit animation skip right to EXITED
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (!exit || _config.default.disabled) {
							 | 
						||
| 
								 | 
							
								      this.safeSetState({
							 | 
						||
| 
								 | 
							
								        status: EXITED
							 | 
						||
| 
								 | 
							
								      }, function () {
							 | 
						||
| 
								 | 
							
								        _this3.props.onExited(maybeNode);
							 | 
						||
| 
								 | 
							
								      });
							 | 
						||
| 
								 | 
							
								      return;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    this.props.onExit(maybeNode);
							 | 
						||
| 
								 | 
							
								    this.safeSetState({
							 | 
						||
| 
								 | 
							
								      status: EXITING
							 | 
						||
| 
								 | 
							
								    }, function () {
							 | 
						||
| 
								 | 
							
								      _this3.props.onExiting(maybeNode);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      _this3.onTransitionEnd(timeouts.exit, function () {
							 | 
						||
| 
								 | 
							
								        _this3.safeSetState({
							 | 
						||
| 
								 | 
							
								          status: EXITED
							 | 
						||
| 
								 | 
							
								        }, function () {
							 | 
						||
| 
								 | 
							
								          _this3.props.onExited(maybeNode);
							 | 
						||
| 
								 | 
							
								        });
							 | 
						||
| 
								 | 
							
								      });
							 | 
						||
| 
								 | 
							
								    });
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.cancelNextCallback = function cancelNextCallback() {
							 | 
						||
| 
								 | 
							
								    if (this.nextCallback !== null) {
							 | 
						||
| 
								 | 
							
								      this.nextCallback.cancel();
							 | 
						||
| 
								 | 
							
								      this.nextCallback = null;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.safeSetState = function safeSetState(nextState, callback) {
							 | 
						||
| 
								 | 
							
								    // This shouldn't be necessary, but there are weird race conditions with
							 | 
						||
| 
								 | 
							
								    // setState callbacks and unmounting in testing, so always make sure that
							 | 
						||
| 
								 | 
							
								    // we can cancel any pending setState callbacks after we unmount.
							 | 
						||
| 
								 | 
							
								    callback = this.setNextCallback(callback);
							 | 
						||
| 
								 | 
							
								    this.setState(nextState, callback);
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.setNextCallback = function setNextCallback(callback) {
							 | 
						||
| 
								 | 
							
								    var _this4 = this;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    var active = true;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    this.nextCallback = function (event) {
							 | 
						||
| 
								 | 
							
								      if (active) {
							 | 
						||
| 
								 | 
							
								        active = false;
							 | 
						||
| 
								 | 
							
								        _this4.nextCallback = null;
							 | 
						||
| 
								 | 
							
								        callback(event);
							 | 
						||
| 
								 | 
							
								      }
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    this.nextCallback.cancel = function () {
							 | 
						||
| 
								 | 
							
								      active = false;
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return this.nextCallback;
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.onTransitionEnd = function onTransitionEnd(timeout, handler) {
							 | 
						||
| 
								 | 
							
								    this.setNextCallback(handler);
							 | 
						||
| 
								 | 
							
								    var node = this.props.nodeRef ? this.props.nodeRef.current : _reactDom.default.findDOMNode(this);
							 | 
						||
| 
								 | 
							
								    var doesNotHaveTimeoutOrListener = timeout == null && !this.props.addEndListener;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (!node || doesNotHaveTimeoutOrListener) {
							 | 
						||
| 
								 | 
							
								      setTimeout(this.nextCallback, 0);
							 | 
						||
| 
								 | 
							
								      return;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (this.props.addEndListener) {
							 | 
						||
| 
								 | 
							
								      var _ref3 = this.props.nodeRef ? [this.nextCallback] : [node, this.nextCallback],
							 | 
						||
| 
								 | 
							
								          maybeNode = _ref3[0],
							 | 
						||
| 
								 | 
							
								          maybeNextCallback = _ref3[1];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      this.props.addEndListener(maybeNode, maybeNextCallback);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (timeout != null) {
							 | 
						||
| 
								 | 
							
								      setTimeout(this.nextCallback, timeout);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  _proto.render = function render() {
							 | 
						||
| 
								 | 
							
								    var status = this.state.status;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (status === UNMOUNTED) {
							 | 
						||
| 
								 | 
							
								      return null;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    var _this$props = this.props,
							 | 
						||
| 
								 | 
							
								        children = _this$props.children,
							 | 
						||
| 
								 | 
							
								        _in = _this$props.in,
							 | 
						||
| 
								 | 
							
								        _mountOnEnter = _this$props.mountOnEnter,
							 | 
						||
| 
								 | 
							
								        _unmountOnExit = _this$props.unmountOnExit,
							 | 
						||
| 
								 | 
							
								        _appear = _this$props.appear,
							 | 
						||
| 
								 | 
							
								        _enter = _this$props.enter,
							 | 
						||
| 
								 | 
							
								        _exit = _this$props.exit,
							 | 
						||
| 
								 | 
							
								        _timeout = _this$props.timeout,
							 | 
						||
| 
								 | 
							
								        _addEndListener = _this$props.addEndListener,
							 | 
						||
| 
								 | 
							
								        _onEnter = _this$props.onEnter,
							 | 
						||
| 
								 | 
							
								        _onEntering = _this$props.onEntering,
							 | 
						||
| 
								 | 
							
								        _onEntered = _this$props.onEntered,
							 | 
						||
| 
								 | 
							
								        _onExit = _this$props.onExit,
							 | 
						||
| 
								 | 
							
								        _onExiting = _this$props.onExiting,
							 | 
						||
| 
								 | 
							
								        _onExited = _this$props.onExited,
							 | 
						||
| 
								 | 
							
								        _nodeRef = _this$props.nodeRef,
							 | 
						||
| 
								 | 
							
								        childProps = _objectWithoutPropertiesLoose(_this$props, ["children", "in", "mountOnEnter", "unmountOnExit", "appear", "enter", "exit", "timeout", "addEndListener", "onEnter", "onEntering", "onEntered", "onExit", "onExiting", "onExited", "nodeRef"]);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return (
							 | 
						||
| 
								 | 
							
								      /*#__PURE__*/
							 | 
						||
| 
								 | 
							
								      // allows for nested Transitions
							 | 
						||
| 
								 | 
							
								      _react.default.createElement(_TransitionGroupContext.default.Provider, {
							 | 
						||
| 
								 | 
							
								        value: null
							 | 
						||
| 
								 | 
							
								      }, typeof children === 'function' ? children(status, childProps) : _react.default.cloneElement(_react.default.Children.only(children), childProps))
							 | 
						||
| 
								 | 
							
								    );
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  return Transition;
							 | 
						||
| 
								 | 
							
								}(_react.default.Component);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Transition.contextType = _TransitionGroupContext.default;
							 | 
						||
| 
								 | 
							
								Transition.propTypes = process.env.NODE_ENV !== "production" ? {
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * A React reference to DOM element that need to transition:
							 | 
						||
| 
								 | 
							
								   * https://stackoverflow.com/a/51127130/4671932
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   *   - When `nodeRef` prop is used, `node` is not passed to callback functions
							 | 
						||
| 
								 | 
							
								   *      (e.g. `onEnter`) because user already has direct access to the node.
							 | 
						||
| 
								 | 
							
								   *   - When changing `key` prop of `Transition` in a `TransitionGroup` a new
							 | 
						||
| 
								 | 
							
								   *     `nodeRef` need to be provided to `Transition` with changed `key` prop
							 | 
						||
| 
								 | 
							
								   *     (see
							 | 
						||
| 
								 | 
							
								   *     [test/CSSTransition-test.js](https://github.com/reactjs/react-transition-group/blob/13435f897b3ab71f6e19d724f145596f5910581c/test/CSSTransition-test.js#L362-L437)).
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  nodeRef: _propTypes.default.shape({
							 | 
						||
| 
								 | 
							
								    current: typeof Element === 'undefined' ? _propTypes.default.any : function (propValue, key, componentName, location, propFullName, secret) {
							 | 
						||
| 
								 | 
							
								      var value = propValue[key];
							 | 
						||
| 
								 | 
							
								      return _propTypes.default.instanceOf(value && 'ownerDocument' in value ? value.ownerDocument.defaultView.Element : Element)(propValue, key, componentName, location, propFullName, secret);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }),
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * A `function` child can be used instead of a React element. This function is
							 | 
						||
| 
								 | 
							
								   * called with the current transition status (`'entering'`, `'entered'`,
							 | 
						||
| 
								 | 
							
								   * `'exiting'`, `'exited'`), which can be used to apply context
							 | 
						||
| 
								 | 
							
								   * specific props to a component.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * ```jsx
							 | 
						||
| 
								 | 
							
								   * <Transition in={this.state.in} timeout={150}>
							 | 
						||
| 
								 | 
							
								   *   {state => (
							 | 
						||
| 
								 | 
							
								   *     <MyComponent className={`fade fade-${state}`} />
							 | 
						||
| 
								 | 
							
								   *   )}
							 | 
						||
| 
								 | 
							
								   * </Transition>
							 | 
						||
| 
								 | 
							
								   * ```
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  children: _propTypes.default.oneOfType([_propTypes.default.func.isRequired, _propTypes.default.element.isRequired]).isRequired,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Show the component; triggers the enter or exit states
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  in: _propTypes.default.bool,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * By default the child component is mounted immediately along with
							 | 
						||
| 
								 | 
							
								   * the parent `Transition` component. If you want to "lazy mount" the component on the
							 | 
						||
| 
								 | 
							
								   * first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay
							 | 
						||
| 
								 | 
							
								   * mounted, even on "exited", unless you also specify `unmountOnExit`.
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  mountOnEnter: _propTypes.default.bool,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * By default the child component stays mounted after it reaches the `'exited'` state.
							 | 
						||
| 
								 | 
							
								   * Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  unmountOnExit: _propTypes.default.bool,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * By default the child component does not perform the enter transition when
							 | 
						||
| 
								 | 
							
								   * it first mounts, regardless of the value of `in`. If you want this
							 | 
						||
| 
								 | 
							
								   * behavior, set both `appear` and `in` to `true`.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * > **Note**: there are no special appear states like `appearing`/`appeared`, this prop
							 | 
						||
| 
								 | 
							
								   * > only adds an additional enter transition. However, in the
							 | 
						||
| 
								 | 
							
								   * > `<CSSTransition>` component that first enter transition does result in
							 | 
						||
| 
								 | 
							
								   * > additional `.appear-*` classes, that way you can choose to style it
							 | 
						||
| 
								 | 
							
								   * > differently.
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  appear: _propTypes.default.bool,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Enable or disable enter transitions.
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  enter: _propTypes.default.bool,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Enable or disable exit transitions.
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  exit: _propTypes.default.bool,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * The duration of the transition, in milliseconds.
							 | 
						||
| 
								 | 
							
								   * Required unless `addEndListener` is provided.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * You may specify a single timeout for all transitions:
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * ```jsx
							 | 
						||
| 
								 | 
							
								   * timeout={500}
							 | 
						||
| 
								 | 
							
								   * ```
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * or individually:
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * ```jsx
							 | 
						||
| 
								 | 
							
								   * timeout={{
							 | 
						||
| 
								 | 
							
								   *  appear: 500,
							 | 
						||
| 
								 | 
							
								   *  enter: 300,
							 | 
						||
| 
								 | 
							
								   *  exit: 500,
							 | 
						||
| 
								 | 
							
								   * }}
							 | 
						||
| 
								 | 
							
								   * ```
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * - `appear` defaults to the value of `enter`
							 | 
						||
| 
								 | 
							
								   * - `enter` defaults to `0`
							 | 
						||
| 
								 | 
							
								   * - `exit` defaults to `0`
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @type {number | { enter?: number, exit?: number, appear?: number }}
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  timeout: function timeout(props) {
							 | 
						||
| 
								 | 
							
								    var pt = _PropTypes.timeoutsShape;
							 | 
						||
| 
								 | 
							
								    if (!props.addEndListener) pt = pt.isRequired;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
							 | 
						||
| 
								 | 
							
								      args[_key - 1] = arguments[_key];
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return pt.apply(void 0, [props].concat(args));
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Add a custom transition end trigger. Called with the transitioning
							 | 
						||
| 
								 | 
							
								   * DOM node and a `done` callback. Allows for more fine grained transition end
							 | 
						||
| 
								 | 
							
								   * logic. Timeouts are still used as a fallback if provided.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * **Note**: when `nodeRef` prop is passed, `node` is not passed.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * ```jsx
							 | 
						||
| 
								 | 
							
								   * addEndListener={(node, done) => {
							 | 
						||
| 
								 | 
							
								   *   // use the css transitionend event to mark the finish of a transition
							 | 
						||
| 
								 | 
							
								   *   node.addEventListener('transitionend', done, false);
							 | 
						||
| 
								 | 
							
								   * }}
							 | 
						||
| 
								 | 
							
								   * ```
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  addEndListener: _propTypes.default.func,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Callback fired before the "entering" status is applied. An extra parameter
							 | 
						||
| 
								 | 
							
								   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * **Note**: when `nodeRef` prop is passed, `node` is not passed.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @type Function(node: HtmlElement, isAppearing: bool) -> void
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  onEnter: _propTypes.default.func,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Callback fired after the "entering" status is applied. An extra parameter
							 | 
						||
| 
								 | 
							
								   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * **Note**: when `nodeRef` prop is passed, `node` is not passed.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @type Function(node: HtmlElement, isAppearing: bool)
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  onEntering: _propTypes.default.func,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Callback fired after the "entered" status is applied. An extra parameter
							 | 
						||
| 
								 | 
							
								   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * **Note**: when `nodeRef` prop is passed, `node` is not passed.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @type Function(node: HtmlElement, isAppearing: bool) -> void
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  onEntered: _propTypes.default.func,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Callback fired before the "exiting" status is applied.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * **Note**: when `nodeRef` prop is passed, `node` is not passed.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @type Function(node: HtmlElement) -> void
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  onExit: _propTypes.default.func,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Callback fired after the "exiting" status is applied.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * **Note**: when `nodeRef` prop is passed, `node` is not passed.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @type Function(node: HtmlElement) -> void
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  onExiting: _propTypes.default.func,
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  /**
							 | 
						||
| 
								 | 
							
								   * Callback fired after the "exited" status is applied.
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * **Note**: when `nodeRef` prop is passed, `node` is not passed
							 | 
						||
| 
								 | 
							
								   *
							 | 
						||
| 
								 | 
							
								   * @type Function(node: HtmlElement) -> void
							 | 
						||
| 
								 | 
							
								   */
							 | 
						||
| 
								 | 
							
								  onExited: _propTypes.default.func
							 | 
						||
| 
								 | 
							
								} : {}; // Name the function so it is clearer in the documentation
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function noop() {}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Transition.defaultProps = {
							 | 
						||
| 
								 | 
							
								  in: false,
							 | 
						||
| 
								 | 
							
								  mountOnEnter: false,
							 | 
						||
| 
								 | 
							
								  unmountOnExit: false,
							 | 
						||
| 
								 | 
							
								  appear: false,
							 | 
						||
| 
								 | 
							
								  enter: true,
							 | 
						||
| 
								 | 
							
								  exit: true,
							 | 
						||
| 
								 | 
							
								  onEnter: noop,
							 | 
						||
| 
								 | 
							
								  onEntering: noop,
							 | 
						||
| 
								 | 
							
								  onEntered: noop,
							 | 
						||
| 
								 | 
							
								  onExit: noop,
							 | 
						||
| 
								 | 
							
								  onExiting: noop,
							 | 
						||
| 
								 | 
							
								  onExited: noop
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								Transition.UNMOUNTED = UNMOUNTED;
							 | 
						||
| 
								 | 
							
								Transition.EXITED = EXITED;
							 | 
						||
| 
								 | 
							
								Transition.ENTERING = ENTERING;
							 | 
						||
| 
								 | 
							
								Transition.ENTERED = ENTERED;
							 | 
						||
| 
								 | 
							
								Transition.EXITING = EXITING;
							 | 
						||
| 
								 | 
							
								var _default = Transition;
							 | 
						||
| 
								 | 
							
								exports.default = _default;
							 |