{"version":3,"file":"npm.react-transition-group.js","mappings":"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","sources":["webpack://giveeasy.cloud/./node_modules/react-transition-group/esm/config.js","webpack://giveeasy.cloud/./node_modules/react-transition-group/esm/Transition.js","webpack://giveeasy.cloud/./node_modules/react-transition-group/esm/utils/ChildMapping.js","webpack://giveeasy.cloud/./node_modules/react-transition-group/esm/TransitionGroup.js","webpack://giveeasy.cloud/./node_modules/react-transition-group/esm/TransitionGroupContext.js"],"sourcesContent":["export default {\n disabled: false\n};","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport config from './config';\nimport { timeoutsShape } from './utils/PropTypes';\nimport TransitionGroupContext from './TransitionGroupContext';\nexport var UNMOUNTED = 'unmounted';\nexport var EXITED = 'exited';\nexport var ENTERING = 'entering';\nexport var ENTERED = 'entered';\nexport var EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * ---\n *\n * **Note**: `Transition` is a platform-agnostic base component. If you're using\n * transitions in CSS, you'll probably want to use\n * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)\n * instead. It inherits all the features of `Transition`, but contains\n * additional features necessary to play nice with CSS transitions (hence the\n * name of the component).\n *\n * ---\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the\n * components. It's up to you to give meaning and effect to those states. For\n * example we can add styles to a component when it enters or exits:\n *\n * ```jsx\n * import { Transition } from 'react-transition-group';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n * transition: `opacity ${duration}ms ease-in-out`,\n * opacity: 0,\n * }\n *\n * const transitionStyles = {\n * entering: { opacity: 1 },\n * entered: { opacity: 1 },\n * exiting: { opacity: 0 },\n * exited: { opacity: 0 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n * \n * {state => (\n *
\n * I'm a fade Transition!\n *
\n * )}\n *
\n * );\n * ```\n *\n * There are 4 main states a Transition can be in:\n * - `'entering'`\n * - `'entered'`\n * - `'exiting'`\n * - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component\n * begins the \"Enter\" stage. During this stage, the component will shift from\n * its current transition state, to `'entering'` for the duration of the\n * transition and then to the `'entered'` stage once it's complete. Let's take\n * the following example (we'll use the\n * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):\n *\n * ```jsx\n * function App() {\n * const [inProp, setInProp] = useState(false);\n * return (\n *
\n * \n * {state => (\n * // ...\n * )}\n * \n * \n *
\n * );\n * }\n * ```\n *\n * When the button is clicked the component will shift to the `'entering'` state\n * and stay there for 500ms (the value of `timeout`) before it finally switches\n * to `'entered'`.\n *\n * When `in` is `false` the same thing happens except the state moves from\n * `'exiting'` to `'exited'`.\n */\n\nvar Transition = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Transition, _React$Component);\n\n function Transition(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n var parentGroup = context; // In the context of a TransitionGroup all enters are really appears\n\n var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;\n var initialStatus;\n _this.appearStatus = null;\n\n if (props.in) {\n if (appear) {\n initialStatus = EXITED;\n _this.appearStatus = ENTERING;\n } else {\n initialStatus = ENTERED;\n }\n } else {\n if (props.unmountOnExit || props.mountOnEnter) {\n initialStatus = UNMOUNTED;\n } else {\n initialStatus = EXITED;\n }\n }\n\n _this.state = {\n status: initialStatus\n };\n _this.nextCallback = null;\n return _this;\n }\n\n Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {\n var nextIn = _ref.in;\n\n if (nextIn && prevState.status === UNMOUNTED) {\n return {\n status: EXITED\n };\n }\n\n return null;\n } // getSnapshotBeforeUpdate(prevProps) {\n // let nextStatus = null\n // if (prevProps !== this.props) {\n // const { status } = this.state\n // if (this.props.in) {\n // if (status !== ENTERING && status !== ENTERED) {\n // nextStatus = ENTERING\n // }\n // } else {\n // if (status === ENTERING || status === ENTERED) {\n // nextStatus = EXITING\n // }\n // }\n // }\n // return { nextStatus }\n // }\n ;\n\n var _proto = Transition.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.updateStatus(true, this.appearStatus);\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var nextStatus = null;\n\n if (prevProps !== this.props) {\n var status = this.state.status;\n\n if (this.props.in) {\n if (status !== ENTERING && status !== ENTERED) {\n nextStatus = ENTERING;\n }\n } else {\n if (status === ENTERING || status === ENTERED) {\n nextStatus = EXITING;\n }\n }\n }\n\n this.updateStatus(false, nextStatus);\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.cancelNextCallback();\n };\n\n _proto.getTimeouts = function getTimeouts() {\n var timeout = this.props.timeout;\n var exit, enter, appear;\n exit = enter = appear = timeout;\n\n if (timeout != null && typeof timeout !== 'number') {\n exit = timeout.exit;\n enter = timeout.enter; // TODO: remove fallback for next major\n\n appear = timeout.appear !== undefined ? timeout.appear : enter;\n }\n\n return {\n exit: exit,\n enter: enter,\n appear: appear\n };\n };\n\n _proto.updateStatus = function updateStatus(mounting, nextStatus) {\n if (mounting === void 0) {\n mounting = false;\n }\n\n if (nextStatus !== null) {\n // nextStatus will always be ENTERING or EXITING.\n this.cancelNextCallback();\n\n if (nextStatus === ENTERING) {\n this.performEnter(mounting);\n } else {\n this.performExit();\n }\n } else if (this.props.unmountOnExit && this.state.status === EXITED) {\n this.setState({\n status: UNMOUNTED\n });\n }\n };\n\n _proto.performEnter = function performEnter(mounting) {\n var _this2 = this;\n\n var enter = this.props.enter;\n var appearing = this.context ? this.context.isMounting : mounting;\n\n var _ref2 = this.props.nodeRef ? [appearing] : [ReactDOM.findDOMNode(this), appearing],\n maybeNode = _ref2[0],\n maybeAppearing = _ref2[1];\n\n var timeouts = this.getTimeouts();\n var enterTimeout = appearing ? timeouts.appear : timeouts.enter; // no enter animation skip right to ENTERED\n // if we are mounting and running this it means appear _must_ be set\n\n if (!mounting && !enter || config.disabled) {\n this.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(maybeNode);\n });\n return;\n }\n\n this.props.onEnter(maybeNode, maybeAppearing);\n this.safeSetState({\n status: ENTERING\n }, function () {\n _this2.props.onEntering(maybeNode, maybeAppearing);\n\n _this2.onTransitionEnd(enterTimeout, function () {\n _this2.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(maybeNode, maybeAppearing);\n });\n });\n });\n };\n\n _proto.performExit = function performExit() {\n var _this3 = this;\n\n var exit = this.props.exit;\n var timeouts = this.getTimeouts();\n var maybeNode = this.props.nodeRef ? undefined : ReactDOM.findDOMNode(this); // no exit animation skip right to EXITED\n\n if (!exit || config.disabled) {\n this.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(maybeNode);\n });\n return;\n }\n\n this.props.onExit(maybeNode);\n this.safeSetState({\n status: EXITING\n }, function () {\n _this3.props.onExiting(maybeNode);\n\n _this3.onTransitionEnd(timeouts.exit, function () {\n _this3.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(maybeNode);\n });\n });\n });\n };\n\n _proto.cancelNextCallback = function cancelNextCallback() {\n if (this.nextCallback !== null) {\n this.nextCallback.cancel();\n this.nextCallback = null;\n }\n };\n\n _proto.safeSetState = function safeSetState(nextState, callback) {\n // This shouldn't be necessary, but there are weird race conditions with\n // setState callbacks and unmounting in testing, so always make sure that\n // we can cancel any pending setState callbacks after we unmount.\n callback = this.setNextCallback(callback);\n this.setState(nextState, callback);\n };\n\n _proto.setNextCallback = function setNextCallback(callback) {\n var _this4 = this;\n\n var active = true;\n\n this.nextCallback = function (event) {\n if (active) {\n active = false;\n _this4.nextCallback = null;\n callback(event);\n }\n };\n\n this.nextCallback.cancel = function () {\n active = false;\n };\n\n return this.nextCallback;\n };\n\n _proto.onTransitionEnd = function onTransitionEnd(timeout, handler) {\n this.setNextCallback(handler);\n var node = this.props.nodeRef ? this.props.nodeRef.current : ReactDOM.findDOMNode(this);\n var doesNotHaveTimeoutOrListener = timeout == null && !this.props.addEndListener;\n\n if (!node || doesNotHaveTimeoutOrListener) {\n setTimeout(this.nextCallback, 0);\n return;\n }\n\n if (this.props.addEndListener) {\n var _ref3 = this.props.nodeRef ? [this.nextCallback] : [node, this.nextCallback],\n maybeNode = _ref3[0],\n maybeNextCallback = _ref3[1];\n\n this.props.addEndListener(maybeNode, maybeNextCallback);\n }\n\n if (timeout != null) {\n setTimeout(this.nextCallback, timeout);\n }\n };\n\n _proto.render = function render() {\n var status = this.state.status;\n\n if (status === UNMOUNTED) {\n return null;\n }\n\n var _this$props = this.props,\n children = _this$props.children,\n _in = _this$props.in,\n _mountOnEnter = _this$props.mountOnEnter,\n _unmountOnExit = _this$props.unmountOnExit,\n _appear = _this$props.appear,\n _enter = _this$props.enter,\n _exit = _this$props.exit,\n _timeout = _this$props.timeout,\n _addEndListener = _this$props.addEndListener,\n _onEnter = _this$props.onEnter,\n _onEntering = _this$props.onEntering,\n _onEntered = _this$props.onEntered,\n _onExit = _this$props.onExit,\n _onExiting = _this$props.onExiting,\n _onExited = _this$props.onExited,\n _nodeRef = _this$props.nodeRef,\n childProps = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"in\", \"mountOnEnter\", \"unmountOnExit\", \"appear\", \"enter\", \"exit\", \"timeout\", \"addEndListener\", \"onEnter\", \"onEntering\", \"onEntered\", \"onExit\", \"onExiting\", \"onExited\", \"nodeRef\"]);\n\n return (\n /*#__PURE__*/\n // allows for nested Transitions\n React.createElement(TransitionGroupContext.Provider, {\n value: null\n }, typeof children === 'function' ? children(status, childProps) : React.cloneElement(React.Children.only(children), childProps))\n );\n };\n\n return Transition;\n}(React.Component);\n\nTransition.contextType = TransitionGroupContext;\nTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * A React reference to DOM element that need to transition:\n * https://stackoverflow.com/a/51127130/4671932\n *\n * - When `nodeRef` prop is used, `node` is not passed to callback functions\n * (e.g. `onEnter`) because user already has direct access to the node.\n * - When changing `key` prop of `Transition` in a `TransitionGroup` a new\n * `nodeRef` need to be provided to `Transition` with changed `key` prop\n * (see\n * [test/CSSTransition-test.js](https://github.com/reactjs/react-transition-group/blob/13435f897b3ab71f6e19d724f145596f5910581c/test/CSSTransition-test.js#L362-L437)).\n */\n nodeRef: PropTypes.shape({\n current: typeof Element === 'undefined' ? PropTypes.any : function (propValue, key, componentName, location, propFullName, secret) {\n var value = propValue[key];\n return PropTypes.instanceOf(value && 'ownerDocument' in value ? value.ownerDocument.defaultView.Element : Element)(propValue, key, componentName, location, propFullName, secret);\n }\n }),\n\n /**\n * A `function` child can be used instead of a React element. This function is\n * called with the current transition status (`'entering'`, `'entered'`,\n * `'exiting'`, `'exited'`), which can be used to apply context\n * specific props to a component.\n *\n * ```jsx\n * \n * {state => (\n * \n * )}\n * \n * ```\n */\n children: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]).isRequired,\n\n /**\n * Show the component; triggers the enter or exit states\n */\n in: PropTypes.bool,\n\n /**\n * By default the child component is mounted immediately along with\n * the parent `Transition` component. If you want to \"lazy mount\" the component on the\n * first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay\n * mounted, even on \"exited\", unless you also specify `unmountOnExit`.\n */\n mountOnEnter: PropTypes.bool,\n\n /**\n * By default the child component stays mounted after it reaches the `'exited'` state.\n * Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.\n */\n unmountOnExit: PropTypes.bool,\n\n /**\n * By default the child component does not perform the enter transition when\n * it first mounts, regardless of the value of `in`. If you want this\n * behavior, set both `appear` and `in` to `true`.\n *\n * > **Note**: there are no special appear states like `appearing`/`appeared`, this prop\n * > only adds an additional enter transition. However, in the\n * > `` component that first enter transition does result in\n * > additional `.appear-*` classes, that way you can choose to style it\n * > differently.\n */\n appear: PropTypes.bool,\n\n /**\n * Enable or disable enter transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * Enable or disable exit transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * The duration of the transition, in milliseconds.\n * Required unless `addEndListener` is provided.\n *\n * You may specify a single timeout for all transitions:\n *\n * ```jsx\n * timeout={500}\n * ```\n *\n * or individually:\n *\n * ```jsx\n * timeout={{\n * appear: 500,\n * enter: 300,\n * exit: 500,\n * }}\n * ```\n *\n * - `appear` defaults to the value of `enter`\n * - `enter` defaults to `0`\n * - `exit` defaults to `0`\n *\n * @type {number | { enter?: number, exit?: number, appear?: number }}\n */\n timeout: function timeout(props) {\n var pt = timeoutsShape;\n if (!props.addEndListener) pt = pt.isRequired;\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n return pt.apply(void 0, [props].concat(args));\n },\n\n /**\n * Add a custom transition end trigger. Called with the transitioning\n * DOM node and a `done` callback. Allows for more fine grained transition end\n * logic. Timeouts are still used as a fallback if provided.\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * ```jsx\n * addEndListener={(node, done) => {\n * // use the css transitionend event to mark the finish of a transition\n * node.addEventListener('transitionend', done, false);\n * }}\n * ```\n */\n addEndListener: PropTypes.func,\n\n /**\n * Callback fired before the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired after the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement, isAppearing: bool)\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired after the \"entered\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired before the \"exiting\" status is applied.\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired after the \"exiting\" status is applied.\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExiting: PropTypes.func,\n\n /**\n * Callback fired after the \"exited\" status is applied.\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExited: PropTypes.func\n} : {}; // Name the function so it is clearer in the documentation\n\nfunction noop() {}\n\nTransition.defaultProps = {\n in: false,\n mountOnEnter: false,\n unmountOnExit: false,\n appear: false,\n enter: true,\n exit: true,\n onEnter: noop,\n onEntering: noop,\n onEntered: noop,\n onExit: noop,\n onExiting: noop,\n onExited: noop\n};\nTransition.UNMOUNTED = UNMOUNTED;\nTransition.EXITED = EXITED;\nTransition.ENTERING = ENTERING;\nTransition.ENTERED = ENTERED;\nTransition.EXITING = EXITING;\nexport default Transition;","import { Children, cloneElement, isValidElement } from 'react';\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\n\nexport function getChildMapping(children, mapFn) {\n var mapper = function mapper(child) {\n return mapFn && isValidElement(child) ? mapFn(child) : child;\n };\n\n var result = Object.create(null);\n if (children) Children.map(children, function (c) {\n return c;\n }).forEach(function (child) {\n // run the map function here instead so that the key is the computed one\n result[child.key] = mapper(child);\n });\n return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\nexport function mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n\n function getValueForKey(key) {\n return key in next ? next[key] : prev[key];\n } // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n\n\n var nextKeysPending = Object.create(null);\n var pendingKeys = [];\n\n for (var prevKey in prev) {\n if (prevKey in next) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n\n var i;\n var childMapping = {};\n\n for (var nextKey in next) {\n if (nextKeysPending[nextKey]) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n\n childMapping[nextKey] = getValueForKey(nextKey);\n } // Finally, add the keys which didn't appear before any key in `next`\n\n\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n\n return childMapping;\n}\n\nfunction getProp(child, prop, props) {\n return props[prop] != null ? props[prop] : child.props[prop];\n}\n\nexport function getInitialChildMapping(props, onExited) {\n return getChildMapping(props.children, function (child) {\n return cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n appear: getProp(child, 'appear', props),\n enter: getProp(child, 'enter', props),\n exit: getProp(child, 'exit', props)\n });\n });\n}\nexport function getNextChildMapping(nextProps, prevChildMapping, onExited) {\n var nextChildMapping = getChildMapping(nextProps.children);\n var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n Object.keys(children).forEach(function (key) {\n var child = children[key];\n if (!isValidElement(child)) return;\n var hasPrev = (key in prevChildMapping);\n var hasNext = (key in nextChildMapping);\n var prevChild = prevChildMapping[key];\n var isLeaving = isValidElement(prevChild) && !prevChild.props.in; // item is new (entering)\n\n if (hasNext && (!hasPrev || isLeaving)) {\n // console.log('entering', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n } else if (!hasNext && hasPrev && !isLeaving) {\n // item is old (exiting)\n // console.log('leaving', key)\n children[key] = cloneElement(child, {\n in: false\n });\n } else if (hasNext && hasPrev && isValidElement(prevChild)) {\n // item hasn't changed transition states\n // copy over the last transition props;\n // console.log('unchanged', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: prevChild.props.in,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n }\n });\n return children;\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { getChildMapping, getInitialChildMapping, getNextChildMapping } from './utils/ChildMapping';\n\nvar values = Object.values || function (obj) {\n return Object.keys(obj).map(function (k) {\n return obj[k];\n });\n};\n\nvar defaultProps = {\n component: 'div',\n childFactory: function childFactory(child) {\n return child;\n }\n};\n/**\n * The `` component manages a set of transition components\n * (`` and ``) in a list. Like with the transition\n * components, `` is a state machine for managing the mounting\n * and unmounting of components over time.\n *\n * Consider the example below. As items are removed or added to the TodoList the\n * `in` prop is toggled automatically by the ``.\n *\n * Note that `` does not define any animation behavior!\n * Exactly _how_ a list item animates is up to the individual transition\n * component. This means you can mix and match animations across different list\n * items.\n */\n\nvar TransitionGroup = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(TransitionGroup, _React$Component);\n\n function TransitionGroup(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n\n var handleExited = _this.handleExited.bind(_assertThisInitialized(_this)); // Initial children should all be entering, dependent on appear\n\n\n _this.state = {\n contextValue: {\n isMounting: true\n },\n handleExited: handleExited,\n firstRender: true\n };\n return _this;\n }\n\n var _proto = TransitionGroup.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.mounted = true;\n this.setState({\n contextValue: {\n isMounting: false\n }\n });\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.mounted = false;\n };\n\n TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n var prevChildMapping = _ref.children,\n handleExited = _ref.handleExited,\n firstRender = _ref.firstRender;\n return {\n children: firstRender ? getInitialChildMapping(nextProps, handleExited) : getNextChildMapping(nextProps, prevChildMapping, handleExited),\n firstRender: false\n };\n } // node is `undefined` when user provided `nodeRef` prop\n ;\n\n _proto.handleExited = function handleExited(child, node) {\n var currentChildMapping = getChildMapping(this.props.children);\n if (child.key in currentChildMapping) return;\n\n if (child.props.onExited) {\n child.props.onExited(node);\n }\n\n if (this.mounted) {\n this.setState(function (state) {\n var children = _extends({}, state.children);\n\n delete children[child.key];\n return {\n children: children\n };\n });\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n Component = _this$props.component,\n childFactory = _this$props.childFactory,\n props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n\n var contextValue = this.state.contextValue;\n var children = values(this.state.children).map(childFactory);\n delete props.appear;\n delete props.enter;\n delete props.exit;\n\n if (Component === null) {\n return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, children);\n }\n\n return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, /*#__PURE__*/React.createElement(Component, props, children));\n };\n\n return TransitionGroup;\n}(React.Component);\n\nTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * `` renders a `
` by default. You can change this\n * behavior by providing a `component` prop.\n * If you use React v16+ and would like to avoid a wrapping `
` element\n * you can pass in `component={null}`. This is useful if the wrapping div\n * borks your css styles.\n */\n component: PropTypes.any,\n\n /**\n * A set of `` components, that are toggled `in` and out as they\n * leave. the `` will inject specific transition props, so\n * remember to spread them through if you are wrapping the `` as\n * with our `` example.\n *\n * While this component is meant for multiple `Transition` or `CSSTransition`\n * children, sometimes you may want to have a single transition child with\n * content that you want to be transitioned out and in when you change it\n * (e.g. routes, images etc.) In that case you can change the `key` prop of\n * the transition child as you change its content, this will cause\n * `TransitionGroup` to transition the child out and back in.\n */\n children: PropTypes.node,\n\n /**\n * A convenience prop that enables or disables appear animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n appear: PropTypes.bool,\n\n /**\n * A convenience prop that enables or disables enter animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * A convenience prop that enables or disables exit animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * You may need to apply reactive updates to a child as it is exiting.\n * This is generally done by using `cloneElement` however in the case of an exiting\n * child the element has already been removed and not accessible to the consumer.\n *\n * If you do need to update a child as it leaves you can provide a `childFactory`\n * to wrap every child, even the ones that are leaving.\n *\n * @type Function(child: ReactElement) -> ReactElement\n */\n childFactory: PropTypes.func\n} : {};\nTransitionGroup.defaultProps = defaultProps;\nexport default TransitionGroup;","import React from 'react';\nexport default React.createContext(null);"],"names":["Transition","_React$Component","props","context","_this","call","this","initialStatus","appear","isMounting","enter","appearStatus","in","unmountOnExit","mountOnEnter","state","status","nextCallback","getDerivedStateFromProps","_ref","prevState","_proto","prototype","componentDidMount","updateStatus","componentDidUpdate","prevProps","nextStatus","componentWillUnmount","cancelNextCallback","getTimeouts","exit","timeout","undefined","mounting","performEnter","performExit","setState","_this2","appearing","_ref2","nodeRef","maybeNode","maybeAppearing","timeouts","enterTimeout","config","safeSetState","onEntered","onEnter","onEntering","onTransitionEnd","_this3","onExit","onExiting","onExited","cancel","nextState","callback","setNextCallback","_this4","active","event","handler","node","current","doesNotHaveTimeoutOrListener","addEndListener","_ref3","maybeNextCallback","setTimeout","render","_this$props","children","childProps","TransitionGroupContext","value","noop","contextType","propTypes","defaultProps","UNMOUNTED","EXITED","ENTERING","ENTERED","EXITING","getChildMapping","mapFn","result","Object","create","Children","c","forEach","child","key","mapper","isValidElement","getProp","prop","getNextChildMapping","nextProps","prevChildMapping","nextChildMapping","mergeChildMappings","prev","next","getValueForKey","i","nextKeysPending","pendingKeys","prevKey","length","push","childMapping","nextKey","pendingNextKey","keys","hasPrev","hasNext","prevChild","isLeaving","cloneElement","bind","values","obj","map","k","TransitionGroup","handleExited","contextValue","firstRender","mounted","currentChildMapping","Component","component","childFactory"],"sourceRoot":""}