UNPKG

@activecollab/components

Version:

ActiveCollab Components

35 lines 1.17 kB
import _extends from "@babel/runtime/helpers/esm/extends"; import React, { cloneElement, useMemo } from "react"; import { Transition } from "react-transition-group"; export const ResizeTransition = _ref => { let _ref$in = _ref.in, inProp = _ref$in === void 0 ? false : _ref$in, onEnter = _ref.onEnter, onExited = _ref.onExited, children = _ref.children, style = _ref.style, _ref$timeout = _ref.timeout, timeout = _ref$timeout === void 0 ? 200 : _ref$timeout; const defaultStyle = useMemo(() => { return { transitionProperty: "width, height", transitionDuration: timeout + "ms", transitionTimingFunction: "ease" }; }, [timeout]); return /*#__PURE__*/React.createElement(Transition, { appear: true, in: inProp, timeout: timeout, onEnter: onEnter, onExited: onExited }, state => { return /*#__PURE__*/cloneElement(children, { style: _extends({ visibility: state === "exited" && !inProp ? "hidden" : undefined }, defaultStyle, style, children.props.style) }); }); }; ResizeTransition.displayName = "ResizeTransition"; //# sourceMappingURL=ResizeTransition.js.map