{"version":3,"sources":["../node_modules/@material-ui/core/esm/styles/useTheme.js","../node_modules/@material-ui/core/esm/utils/useControlled.js","../node_modules/@material-ui/core/esm/Paper/Paper.js","../node_modules/@material-ui/core/esm/transitions/utils.js","../node_modules/@material-ui/core/esm/utils/debounce.js","../node_modules/@material-ui/core/esm/Grow/Grow.js","../node_modules/@material-ui/core/esm/Backdrop/Backdrop.js","../node_modules/@material-ui/core/esm/Fade/Fade.js","../node_modules/react-transition-group/esm/config.js","../node_modules/react-transition-group/esm/Transition.js","../node_modules/react-transition-group/esm/utils/reflow.js","../node_modules/@material-ui/core/esm/Tooltip/Tooltip.js","../node_modules/@material-ui/core/esm/Divider/Divider.js","../node_modules/@material-ui/core/esm/Slide/Slide.js","../node_modules/@material-ui/core/esm/Drawer/Drawer.js"],"names":["useTheme","useThemeWithoutDefault","defaultTheme","useControlled","_ref","controlled","defaultProp","default","isControlled","name","state","React","undefined","current","_React$useState","valueState","setValue","newValue","Paper","props","ref","classes","className","_props$component","component","Component","_props$square","square","_props$elevation","elevation","_props$variant","variant","other","_objectWithoutProperties","_extends","clsx","root","outlined","concat","rounded","withStyles","theme","elevations","shadows","forEach","shadow","index","boxShadow","backgroundColor","palette","background","paper","color","text","primary","transition","transitions","create","borderRadius","shape","border","divider","reflow","node","scrollTop","getTransitionProps","options","timeout","_props$style","style","duration","transitionDuration","mode","delay","transitionDelay","debounce","func","wait","arguments","length","debounced","_len","args","Array","_key","that","this","clearTimeout","setTimeout","apply","clear","getScale","value","Math","pow","styles","entering","opacity","transform","entered","Grow","children","_props$disableStrictM","disableStrictModeCompat","inProp","in","onEnter","onEntered","onEntering","onExit","onExited","onExiting","_props$timeout","_props$TransitionComp","TransitionComponent","Transition","timer","autoTimeout","enableStrictModeCompat","unstable_strictMode","nodeRef","foreignRef","useForkRef","handleRef","normalizedTransitionCallback","callback","nodeOrAppearing","maybeAppearing","_ref2","_slicedToArray","isAppearing","handleEntering","handleEnter","_getTransitionProps","getAutoHeightDuration","clientHeight","join","handleEntered","handleExiting","handleExit","_getTransitionProps2","handleExited","appear","addEndListener","nodeOrNext","maybeNext","next","childProps","visibility","muiSupportAuto","Backdrop","_props$invisible","invisible","open","Fade","zIndex","position","display","alignItems","justifyContent","right","bottom","top","left","WebkitTapHighlightColor","defaultTimeout","enter","enteringScreen","exit","leavingScreen","transitionProps","webkitTransition","UNMOUNTED","EXITED","ENTERING","ENTERED","EXITING","_React$Component","context","_this","call","initialStatus","isMounting","appearStatus","unmountOnExit","mountOnEnter","status","nextCallback","_inheritsLoose","getDerivedStateFromProps","prevState","_proto","prototype","componentDidMount","updateStatus","componentDidUpdate","prevProps","nextStatus","componentWillUnmount","cancelNextCallback","getTimeouts","mounting","ReactDOM","findDOMNode","forceReflow","performEnter","performExit","setState","_this2","appearing","maybeNode","timeouts","enterTimeout","config","safeSetState","onTransitionEnd","_this3","cancel","nextState","setNextCallback","_this4","active","event","handler","doesNotHaveTimeoutOrListener","_ref3","maybeNextCallback","render","_this$props","_objectWithoutPropertiesLoose","createElement","TransitionGroupContext","Provider","cloneElement","Children","only","noop","contextType","propTypes","defaultProps","round","hystersisOpen","hystersisTimer","Tooltip","_props$arrow","arrow","_props$disableFocusLi","disableFocusListener","_props$disableHoverLi","disableHoverListener","_props$disableTouchLi","disableTouchListener","_props$enterDelay","enterDelay","_props$enterNextDelay","enterNextDelay","_props$enterTouchDela","enterTouchDelay","idProp","id","_props$interactive","interactive","_props$leaveDelay","leaveDelay","_props$leaveTouchDela","leaveTouchDelay","onClose","onOpen","openProp","_props$placement","placement","_props$PopperComponen","PopperComponent","Popper","PopperProps","title","TransitionProps","childNode","setChildNode","_React$useState2","arrowRef","setArrowRef","ignoreNonTouchEvents","closeTimer","enterTimer","leaveTimer","touchTimer","_useControlled","_useControlled2","openState","setOpenState","useId","handleOpen","forward","childrenProps","type","onMouseOver","removeAttribute","persist","_useIsFocusVisible","useIsFocusVisible","isFocusVisible","onBlurVisible","focusVisibleRef","_React$useState3","childIsFocusVisible","setChildIsFocusVisible","handleFocus","currentTarget","onFocus","handleClose","shortest","handleLeave","onBlur","onMouseLeave","detectTouchStart","onTouchStart","handleUseRef","handleFocusRef","handleOwnRef","instance","setRef","shouldShowNativeTitle","interactiveWrapperListeners","onTouchEnd","mergedPopperProps","deepmerge","popperOptions","modifiers","enabled","Boolean","element","popper","popperInteractive","popperArrow","anchorEl","placementInner","TransitionPropsInner","shorter","tooltip","capitalize","split","touch","tooltipArrow","pointerEvents","marginTop","marginLeft","marginRight","transformOrigin","marginBottom","height","width","alpha","grey","common","white","fontFamily","typography","padding","fontSize","pxToRem","lineHeight","maxWidth","wordWrap","fontWeight","fontWeightMedium","margin","overflow","boxSizing","content","fontWeightRegular","tooltipPlacementLeft","_defineProperty","breakpoints","up","tooltipPlacementRight","tooltipPlacementTop","tooltipPlacementBottom","flip","Divider","_props$absolute","absolute","_props$flexItem","flexItem","_props$light","light","_props$orientation","orientation","_props$role","role","vertical","flexShrink","inset","middle","spacing","alignSelf","setTranslateValue","direction","rect","getBoundingClientRect","fakeTransform","computedStyle","window","getComputedStyle","getPropertyValue","offsetX","offsetY","transformValues","parseInt","innerWidth","innerHeight","getTranslateValue","webkitTransform","Slide","_props$direction","childrenRef","handleRefIntermediary","easing","easeOut","sharp","updatePosition","handleResize","addEventListener","removeEventListener","oppositeDirection","defaultTransitionDuration","Drawer","_props$anchor","anchor","anchorProp","BackdropProps","_props$ModalProps","ModalProps","BackdropPropsProp","_props$open","_props$PaperProps","PaperProps","SlideProps","_props$transitionDura","mounted","indexOf","isHorizontal","getAnchor","drawer","docked","slidingDrawer","Modal","BackdropComponent","modal","flex","overflowY","flexDirection","WebkitOverflowScrolling","outline","paperAnchorLeft","paperAnchorRight","paperAnchorTop","maxHeight","paperAnchorBottom","paperAnchorDockedLeft","borderRight","paperAnchorDockedTop","borderBottom","paperAnchorDockedRight","borderLeft","paperAnchorDockedBottom","borderTop"],"mappings":"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","file":"static/js/46.1697ea3e.chunk.js","sourcesContent":["import { useTheme as useThemeWithoutDefault } from '@material-ui/styles';\nimport React from 'react';\nimport defaultTheme from './defaultTheme';\nexport default function useTheme() {\n var theme = useThemeWithoutDefault() || defaultTheme;\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useDebugValue(theme);\n }\n\n return theme;\n}","/* eslint-disable react-hooks/rules-of-hooks, react-hooks/exhaustive-deps */\nimport * as React from 'react';\nexport default function useControlled(_ref) {\n var controlled = _ref.controlled,\n defaultProp = _ref.default,\n name = _ref.name,\n _ref$state = _ref.state,\n state = _ref$state === void 0 ? 'value' : _ref$state;\n\n var _React$useRef = React.useRef(controlled !== undefined),\n isControlled = _React$useRef.current;\n\n var _React$useState = React.useState(defaultProp),\n valueState = _React$useState[0],\n setValue = _React$useState[1];\n\n var value = isControlled ? controlled : valueState;\n\n if (process.env.NODE_ENV !== 'production') {\n React.useEffect(function () {\n if (isControlled !== (controlled !== undefined)) {\n console.error([\"Material-UI: A component is changing the \".concat(isControlled ? '' : 'un', \"controlled \").concat(state, \" state of \").concat(name, \" to be \").concat(isControlled ? 'un' : '', \"controlled.\"), 'Elements should not switch from uncontrolled to controlled (or vice versa).', \"Decide between using a controlled or uncontrolled \".concat(name, \" \") + 'element for the lifetime of the component.', \"The nature of the state is determined during the first render, it's considered controlled if the value is not `undefined`.\", 'More info: https://fb.me/react-controlled-components'].join('\\n'));\n }\n }, [controlled]);\n\n var _React$useRef2 = React.useRef(defaultProp),\n defaultValue = _React$useRef2.current;\n\n React.useEffect(function () {\n if (!isControlled && defaultValue !== defaultProp) {\n console.error([\"Material-UI: A component is changing the default \".concat(state, \" state of an uncontrolled \").concat(name, \" after being initialized. \") + \"To suppress this warning opt to use a controlled \".concat(name, \".\")].join('\\n'));\n }\n }, [JSON.stringify(defaultProp)]);\n }\n\n var setValueIfUncontrolled = React.useCallback(function (newValue) {\n if (!isControlled) {\n setValue(newValue);\n }\n }, []);\n return [value, setValueIfUncontrolled];\n}","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { chainPropTypes } from '@material-ui/utils';\nimport withStyles from '../styles/withStyles';\nexport var styles = function styles(theme) {\n var elevations = {};\n theme.shadows.forEach(function (shadow, index) {\n elevations[\"elevation\".concat(index)] = {\n boxShadow: shadow\n };\n });\n return _extends({\n /* Styles applied to the root element. */\n root: {\n backgroundColor: theme.palette.background.paper,\n color: theme.palette.text.primary,\n transition: theme.transitions.create('box-shadow')\n },\n\n /* Styles applied to the root element if `square={false}`. */\n rounded: {\n borderRadius: theme.shape.borderRadius\n },\n\n /* Styles applied to the root element if `variant=\"outlined\"`. */\n outlined: {\n border: \"1px solid \".concat(theme.palette.divider)\n }\n }, elevations);\n};\nvar Paper = /*#__PURE__*/React.forwardRef(function Paper(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$square = props.square,\n square = _props$square === void 0 ? false : _props$square,\n _props$elevation = props.elevation,\n elevation = _props$elevation === void 0 ? 1 : _props$elevation,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'elevation' : _props$variant,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"component\", \"square\", \"elevation\", \"variant\"]);\n\n return /*#__PURE__*/React.createElement(Component, _extends({\n className: clsx(classes.root, className, variant === 'outlined' ? classes.outlined : classes[\"elevation\".concat(elevation)], !square && classes.rounded),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Paper.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * Shadow depth, corresponds to `dp` in the spec.\n * It accepts values between 0 and 24 inclusive.\n */\n elevation: chainPropTypes(PropTypes.number, function (props) {\n var classes = props.classes,\n elevation = props.elevation; // in case `withStyles` fails to inject we don't need this warning\n\n if (classes === undefined) {\n return null;\n }\n\n if (elevation != null && classes[\"elevation\".concat(elevation)] === undefined) {\n return new Error(\"Material-UI: This elevation `\".concat(elevation, \"` is not implemented.\"));\n }\n\n return null;\n }),\n\n /**\n * If `true`, rounded corners are disabled.\n */\n square: PropTypes.bool,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['elevation', 'outlined'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiPaper'\n})(Paper);","export var reflow = function reflow(node) {\n return node.scrollTop;\n};\nexport function getTransitionProps(props, options) {\n var timeout = props.timeout,\n _props$style = props.style,\n style = _props$style === void 0 ? {} : _props$style;\n return {\n duration: style.transitionDuration || typeof timeout === 'number' ? timeout : timeout[options.mode] || 0,\n delay: style.transitionDelay\n };\n}","// Corresponds to 10 frames at 60 Hz.\n// A few bytes payload overhead when lodash/debounce is ~3 kB and debounce ~300 B.\nexport default function debounce(func) {\n var wait = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 166;\n var timeout;\n\n function debounced() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n // eslint-disable-next-line consistent-this\n var that = this;\n\n var later = function later() {\n func.apply(that, args);\n };\n\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n }\n\n debounced.clear = function () {\n clearTimeout(timeout);\n };\n\n return debounced;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _slicedToArray from \"@babel/runtime/helpers/esm/slicedToArray\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { Transition } from 'react-transition-group';\nimport useTheme from '../styles/useTheme';\nimport { reflow, getTransitionProps } from '../transitions/utils';\nimport useForkRef from '../utils/useForkRef';\n\nfunction getScale(value) {\n return \"scale(\".concat(value, \", \").concat(Math.pow(value, 2), \")\");\n}\n\nvar styles = {\n entering: {\n opacity: 1,\n transform: getScale(1)\n },\n entered: {\n opacity: 1,\n transform: 'none'\n }\n};\n/**\n * The Grow transition is used by the [Tooltip](/components/tooltips/) and\n * [Popover](/components/popover/) components.\n * It uses [react-transition-group](https://github.com/reactjs/react-transition-group) internally.\n */\n\nvar Grow = /*#__PURE__*/React.forwardRef(function Grow(props, ref) {\n var children = props.children,\n _props$disableStrictM = props.disableStrictModeCompat,\n disableStrictModeCompat = _props$disableStrictM === void 0 ? false : _props$disableStrictM,\n inProp = props.in,\n onEnter = props.onEnter,\n onEntered = props.onEntered,\n onEntering = props.onEntering,\n onExit = props.onExit,\n onExited = props.onExited,\n onExiting = props.onExiting,\n style = props.style,\n _props$timeout = props.timeout,\n timeout = _props$timeout === void 0 ? 'auto' : _props$timeout,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Transition : _props$TransitionComp,\n other = _objectWithoutProperties(props, [\"children\", \"disableStrictModeCompat\", \"in\", \"onEnter\", \"onEntered\", \"onEntering\", \"onExit\", \"onExited\", \"onExiting\", \"style\", \"timeout\", \"TransitionComponent\"]);\n\n var timer = React.useRef();\n var autoTimeout = React.useRef();\n var theme = useTheme();\n var enableStrictModeCompat = theme.unstable_strictMode && !disableStrictModeCompat;\n var nodeRef = React.useRef(null);\n var foreignRef = useForkRef(children.ref, ref);\n var handleRef = useForkRef(enableStrictModeCompat ? nodeRef : undefined, foreignRef);\n\n var normalizedTransitionCallback = function normalizedTransitionCallback(callback) {\n return function (nodeOrAppearing, maybeAppearing) {\n if (callback) {\n var _ref = enableStrictModeCompat ? [nodeRef.current, nodeOrAppearing] : [nodeOrAppearing, maybeAppearing],\n _ref2 = _slicedToArray(_ref, 2),\n node = _ref2[0],\n isAppearing = _ref2[1]; // onEnterXxx and onExitXxx callbacks have a different arguments.length value.\n\n\n if (isAppearing === undefined) {\n callback(node);\n } else {\n callback(node, isAppearing);\n }\n }\n };\n };\n\n var handleEntering = normalizedTransitionCallback(onEntering);\n var handleEnter = normalizedTransitionCallback(function (node, isAppearing) {\n reflow(node); // So the animation always start from the start.\n\n var _getTransitionProps = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'enter'\n }),\n transitionDuration = _getTransitionProps.duration,\n delay = _getTransitionProps.delay;\n\n var duration;\n\n if (timeout === 'auto') {\n duration = theme.transitions.getAutoHeightDuration(node.clientHeight);\n autoTimeout.current = duration;\n } else {\n duration = transitionDuration;\n }\n\n node.style.transition = [theme.transitions.create('opacity', {\n duration: duration,\n delay: delay\n }), theme.transitions.create('transform', {\n duration: duration * 0.666,\n delay: delay\n })].join(',');\n\n if (onEnter) {\n onEnter(node, isAppearing);\n }\n });\n var handleEntered = normalizedTransitionCallback(onEntered);\n var handleExiting = normalizedTransitionCallback(onExiting);\n var handleExit = normalizedTransitionCallback(function (node) {\n var _getTransitionProps2 = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'exit'\n }),\n transitionDuration = _getTransitionProps2.duration,\n delay = _getTransitionProps2.delay;\n\n var duration;\n\n if (timeout === 'auto') {\n duration = theme.transitions.getAutoHeightDuration(node.clientHeight);\n autoTimeout.current = duration;\n } else {\n duration = transitionDuration;\n }\n\n node.style.transition = [theme.transitions.create('opacity', {\n duration: duration,\n delay: delay\n }), theme.transitions.create('transform', {\n duration: duration * 0.666,\n delay: delay || duration * 0.333\n })].join(',');\n node.style.opacity = '0';\n node.style.transform = getScale(0.75);\n\n if (onExit) {\n onExit(node);\n }\n });\n var handleExited = normalizedTransitionCallback(onExited);\n\n var addEndListener = function addEndListener(nodeOrNext, maybeNext) {\n var next = enableStrictModeCompat ? nodeOrNext : maybeNext;\n\n if (timeout === 'auto') {\n timer.current = setTimeout(next, autoTimeout.current || 0);\n }\n };\n\n React.useEffect(function () {\n return function () {\n clearTimeout(timer.current);\n };\n }, []);\n return /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n appear: true,\n in: inProp,\n nodeRef: enableStrictModeCompat ? nodeRef : undefined,\n onEnter: handleEnter,\n onEntered: handleEntered,\n onEntering: handleEntering,\n onExit: handleExit,\n onExited: handleExited,\n onExiting: handleExiting,\n addEndListener: addEndListener,\n timeout: timeout === 'auto' ? null : timeout\n }, other), function (state, childProps) {\n return /*#__PURE__*/React.cloneElement(children, _extends({\n style: _extends({\n opacity: 0,\n transform: getScale(0.75),\n visibility: state === 'exited' && !inProp ? 'hidden' : undefined\n }, styles[state], style, children.props.style),\n ref: handleRef\n }, childProps));\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Grow.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * A single child content element.\n */\n children: PropTypes.element,\n\n /**\n * Enable this prop if you encounter 'Function components cannot be given refs',\n * use `unstable_createStrictModeTheme`,\n * and can't forward the ref in the child component.\n */\n disableStrictModeCompat: PropTypes.bool,\n\n /**\n * If `true`, show the component; triggers the enter or exit animation.\n */\n in: PropTypes.bool,\n\n /**\n * @ignore\n */\n onEnter: PropTypes.func,\n\n /**\n * @ignore\n */\n onEntered: PropTypes.func,\n\n /**\n * @ignore\n */\n onEntering: PropTypes.func,\n\n /**\n * @ignore\n */\n onExit: PropTypes.func,\n\n /**\n * @ignore\n */\n onExited: PropTypes.func,\n\n /**\n * @ignore\n */\n onExiting: PropTypes.func,\n\n /**\n * @ignore\n */\n style: PropTypes.object,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n *\n * Set to 'auto' to automatically calculate transition time based on height.\n */\n timeout: PropTypes.oneOfType([PropTypes.oneOf(['auto']), PropTypes.number, PropTypes.shape({\n appear: PropTypes.number,\n enter: PropTypes.number,\n exit: PropTypes.number\n })])\n} : void 0;\nGrow.muiSupportAuto = true;\nexport default Grow;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport Fade from '../Fade';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n // Improve scrollable dialog support.\n zIndex: -1,\n position: 'fixed',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n right: 0,\n bottom: 0,\n top: 0,\n left: 0,\n backgroundColor: 'rgba(0, 0, 0, 0.5)',\n WebkitTapHighlightColor: 'transparent'\n },\n\n /* Styles applied to the root element if `invisible={true}`. */\n invisible: {\n backgroundColor: 'transparent'\n }\n};\nvar Backdrop = /*#__PURE__*/React.forwardRef(function Backdrop(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n _props$invisible = props.invisible,\n invisible = _props$invisible === void 0 ? false : _props$invisible,\n open = props.open,\n transitionDuration = props.transitionDuration,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Fade : _props$TransitionComp,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"invisible\", \"open\", \"transitionDuration\", \"TransitionComponent\"]);\n\n return /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n in: open,\n timeout: transitionDuration\n }, other), /*#__PURE__*/React.createElement(\"div\", {\n className: clsx(classes.root, className, invisible && classes.invisible),\n \"aria-hidden\": true,\n ref: ref\n }, children));\n});\nprocess.env.NODE_ENV !== \"production\" ? Backdrop.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the backdrop is invisible.\n * It can be used when rendering a popover or a custom select component.\n */\n invisible: PropTypes.bool,\n\n /**\n * If `true`, the backdrop is open.\n */\n open: PropTypes.bool.isRequired,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n */\n transitionDuration: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n appear: PropTypes.number,\n enter: PropTypes.number,\n exit: PropTypes.number\n })])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiBackdrop'\n})(Backdrop);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _slicedToArray from \"@babel/runtime/helpers/esm/slicedToArray\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { Transition } from 'react-transition-group';\nimport { duration } from '../styles/transitions';\nimport useTheme from '../styles/useTheme';\nimport { reflow, getTransitionProps } from '../transitions/utils';\nimport useForkRef from '../utils/useForkRef';\nvar styles = {\n entering: {\n opacity: 1\n },\n entered: {\n opacity: 1\n }\n};\nvar defaultTimeout = {\n enter: duration.enteringScreen,\n exit: duration.leavingScreen\n};\n/**\n * The Fade transition is used by the [Modal](/components/modal/) component.\n * It uses [react-transition-group](https://github.com/reactjs/react-transition-group) internally.\n */\n\nvar Fade = /*#__PURE__*/React.forwardRef(function Fade(props, ref) {\n var children = props.children,\n _props$disableStrictM = props.disableStrictModeCompat,\n disableStrictModeCompat = _props$disableStrictM === void 0 ? false : _props$disableStrictM,\n inProp = props.in,\n onEnter = props.onEnter,\n onEntered = props.onEntered,\n onEntering = props.onEntering,\n onExit = props.onExit,\n onExited = props.onExited,\n onExiting = props.onExiting,\n style = props.style,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Transition : _props$TransitionComp,\n _props$timeout = props.timeout,\n timeout = _props$timeout === void 0 ? defaultTimeout : _props$timeout,\n other = _objectWithoutProperties(props, [\"children\", \"disableStrictModeCompat\", \"in\", \"onEnter\", \"onEntered\", \"onEntering\", \"onExit\", \"onExited\", \"onExiting\", \"style\", \"TransitionComponent\", \"timeout\"]);\n\n var theme = useTheme();\n var enableStrictModeCompat = theme.unstable_strictMode && !disableStrictModeCompat;\n var nodeRef = React.useRef(null);\n var foreignRef = useForkRef(children.ref, ref);\n var handleRef = useForkRef(enableStrictModeCompat ? nodeRef : undefined, foreignRef);\n\n var normalizedTransitionCallback = function normalizedTransitionCallback(callback) {\n return function (nodeOrAppearing, maybeAppearing) {\n if (callback) {\n var _ref = enableStrictModeCompat ? [nodeRef.current, nodeOrAppearing] : [nodeOrAppearing, maybeAppearing],\n _ref2 = _slicedToArray(_ref, 2),\n node = _ref2[0],\n isAppearing = _ref2[1]; // onEnterXxx and onExitXxx callbacks have a different arguments.length value.\n\n\n if (isAppearing === undefined) {\n callback(node);\n } else {\n callback(node, isAppearing);\n }\n }\n };\n };\n\n var handleEntering = normalizedTransitionCallback(onEntering);\n var handleEnter = normalizedTransitionCallback(function (node, isAppearing) {\n reflow(node); // So the animation always start from the start.\n\n var transitionProps = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'enter'\n });\n node.style.webkitTransition = theme.transitions.create('opacity', transitionProps);\n node.style.transition = theme.transitions.create('opacity', transitionProps);\n\n if (onEnter) {\n onEnter(node, isAppearing);\n }\n });\n var handleEntered = normalizedTransitionCallback(onEntered);\n var handleExiting = normalizedTransitionCallback(onExiting);\n var handleExit = normalizedTransitionCallback(function (node) {\n var transitionProps = getTransitionProps({\n style: style,\n timeout: timeout\n }, {\n mode: 'exit'\n });\n node.style.webkitTransition = theme.transitions.create('opacity', transitionProps);\n node.style.transition = theme.transitions.create('opacity', transitionProps);\n\n if (onExit) {\n onExit(node);\n }\n });\n var handleExited = normalizedTransitionCallback(onExited);\n return /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n appear: true,\n in: inProp,\n nodeRef: enableStrictModeCompat ? nodeRef : undefined,\n onEnter: handleEnter,\n onEntered: handleEntered,\n onEntering: handleEntering,\n onExit: handleExit,\n onExited: handleExited,\n onExiting: handleExiting,\n timeout: timeout\n }, other), function (state, childProps) {\n return /*#__PURE__*/React.cloneElement(children, _extends({\n style: _extends({\n opacity: 0,\n visibility: state === 'exited' && !inProp ? 'hidden' : undefined\n }, styles[state], style, children.props.style),\n ref: handleRef\n }, childProps));\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Fade.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * A single child content element.\n */\n children: PropTypes.element,\n\n /**\n * Enable this prop if you encounter 'Function components cannot be given refs',\n * use `unstable_createStrictModeTheme`,\n * and can't forward the ref in the child component.\n */\n disableStrictModeCompat: PropTypes.bool,\n\n /**\n * If `true`, the component will transition in.\n */\n in: PropTypes.bool,\n\n /**\n * @ignore\n */\n onEnter: PropTypes.func,\n\n /**\n * @ignore\n */\n onEntered: PropTypes.func,\n\n /**\n * @ignore\n */\n onEntering: PropTypes.func,\n\n /**\n * @ignore\n */\n onExit: PropTypes.func,\n\n /**\n * @ignore\n */\n onExited: PropTypes.func,\n\n /**\n * @ignore\n */\n onExiting: PropTypes.func,\n\n /**\n * @ignore\n */\n style: PropTypes.object,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n */\n timeout: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n appear: PropTypes.number,\n enter: PropTypes.number,\n exit: PropTypes.number\n })])\n} : void 0;\nexport default Fade;","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';\nimport { forceReflow } from './utils/reflow';\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 if (this.props.unmountOnExit || this.props.mountOnEnter) {\n var node = this.props.nodeRef ? this.props.nodeRef.current : ReactDOM.findDOMNode(this); // https://github.com/reactjs/react-transition-group/pull/749\n // With unmountOnExit or mountOnEnter, the enter animation should happen at the transition between `exited` and `entering`.\n // To make the animation happen, we have to separate each rendering and avoid being processed as batched.\n\n if (node) forceReflow(node);\n }\n\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;","export var forceReflow = function forceReflow(node) {\n return node.scrollTop;\n};","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _slicedToArray from \"@babel/runtime/helpers/esm/slicedToArray\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { deepmerge, elementAcceptingRef } from '@material-ui/utils';\nimport { alpha } from '../styles/colorManipulator';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nimport Grow from '../Grow';\nimport Popper from '../Popper';\nimport useForkRef from '../utils/useForkRef';\nimport useId from '../utils/unstable_useId';\nimport setRef from '../utils/setRef';\nimport useIsFocusVisible from '../utils/useIsFocusVisible';\nimport useControlled from '../utils/useControlled';\nimport useTheme from '../styles/useTheme';\n\nfunction round(value) {\n return Math.round(value * 1e5) / 1e5;\n}\n\nfunction arrowGenerator() {\n return {\n '&[x-placement*=\"bottom\"] $arrow': {\n top: 0,\n left: 0,\n marginTop: '-0.71em',\n marginLeft: 4,\n marginRight: 4,\n '&::before': {\n transformOrigin: '0 100%'\n }\n },\n '&[x-placement*=\"top\"] $arrow': {\n bottom: 0,\n left: 0,\n marginBottom: '-0.71em',\n marginLeft: 4,\n marginRight: 4,\n '&::before': {\n transformOrigin: '100% 0'\n }\n },\n '&[x-placement*=\"right\"] $arrow': {\n left: 0,\n marginLeft: '-0.71em',\n height: '1em',\n width: '0.71em',\n marginTop: 4,\n marginBottom: 4,\n '&::before': {\n transformOrigin: '100% 100%'\n }\n },\n '&[x-placement*=\"left\"] $arrow': {\n right: 0,\n marginRight: '-0.71em',\n height: '1em',\n width: '0.71em',\n marginTop: 4,\n marginBottom: 4,\n '&::before': {\n transformOrigin: '0 0'\n }\n }\n };\n}\n\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the Popper component. */\n popper: {\n zIndex: theme.zIndex.tooltip,\n pointerEvents: 'none' // disable jss-rtl plugin\n\n },\n\n /* Styles applied to the Popper component if `interactive={true}`. */\n popperInteractive: {\n pointerEvents: 'auto'\n },\n\n /* Styles applied to the Popper component if `arrow={true}`. */\n popperArrow: arrowGenerator(),\n\n /* Styles applied to the tooltip (label wrapper) element. */\n tooltip: {\n backgroundColor: alpha(theme.palette.grey[700], 0.9),\n borderRadius: theme.shape.borderRadius,\n color: theme.palette.common.white,\n fontFamily: theme.typography.fontFamily,\n padding: '4px 8px',\n fontSize: theme.typography.pxToRem(10),\n lineHeight: \"\".concat(round(14 / 10), \"em\"),\n maxWidth: 300,\n wordWrap: 'break-word',\n fontWeight: theme.typography.fontWeightMedium\n },\n\n /* Styles applied to the tooltip (label wrapper) element if `arrow={true}`. */\n tooltipArrow: {\n position: 'relative',\n margin: '0'\n },\n\n /* Styles applied to the arrow element. */\n arrow: {\n overflow: 'hidden',\n position: 'absolute',\n width: '1em',\n height: '0.71em'\n /* = width / sqrt(2) = (length of the hypotenuse) */\n ,\n boxSizing: 'border-box',\n color: alpha(theme.palette.grey[700], 0.9),\n '&::before': {\n content: '\"\"',\n margin: 'auto',\n display: 'block',\n width: '100%',\n height: '100%',\n backgroundColor: 'currentColor',\n transform: 'rotate(45deg)'\n }\n },\n\n /* Styles applied to the tooltip (label wrapper) element if the tooltip is opened by touch. */\n touch: {\n padding: '8px 16px',\n fontSize: theme.typography.pxToRem(14),\n lineHeight: \"\".concat(round(16 / 14), \"em\"),\n fontWeight: theme.typography.fontWeightRegular\n },\n\n /* Styles applied to the tooltip (label wrapper) element if `placement` contains \"left\". */\n tooltipPlacementLeft: _defineProperty({\n transformOrigin: 'right center',\n margin: '0 24px '\n }, theme.breakpoints.up('sm'), {\n margin: '0 14px'\n }),\n\n /* Styles applied to the tooltip (label wrapper) element if `placement` contains \"right\". */\n tooltipPlacementRight: _defineProperty({\n transformOrigin: 'left center',\n margin: '0 24px'\n }, theme.breakpoints.up('sm'), {\n margin: '0 14px'\n }),\n\n /* Styles applied to the tooltip (label wrapper) element if `placement` contains \"top\". */\n tooltipPlacementTop: _defineProperty({\n transformOrigin: 'center bottom',\n margin: '24px 0'\n }, theme.breakpoints.up('sm'), {\n margin: '14px 0'\n }),\n\n /* Styles applied to the tooltip (label wrapper) element if `placement` contains \"bottom\". */\n tooltipPlacementBottom: _defineProperty({\n transformOrigin: 'center top',\n margin: '24px 0'\n }, theme.breakpoints.up('sm'), {\n margin: '14px 0'\n })\n };\n};\nvar hystersisOpen = false;\nvar hystersisTimer = null;\nexport function testReset() {\n hystersisOpen = false;\n clearTimeout(hystersisTimer);\n}\nvar Tooltip = /*#__PURE__*/React.forwardRef(function Tooltip(props, ref) {\n var _props$arrow = props.arrow,\n arrow = _props$arrow === void 0 ? false : _props$arrow,\n children = props.children,\n classes = props.classes,\n _props$disableFocusLi = props.disableFocusListener,\n disableFocusListener = _props$disableFocusLi === void 0 ? false : _props$disableFocusLi,\n _props$disableHoverLi = props.disableHoverListener,\n disableHoverListener = _props$disableHoverLi === void 0 ? false : _props$disableHoverLi,\n _props$disableTouchLi = props.disableTouchListener,\n disableTouchListener = _props$disableTouchLi === void 0 ? false : _props$disableTouchLi,\n _props$enterDelay = props.enterDelay,\n enterDelay = _props$enterDelay === void 0 ? 100 : _props$enterDelay,\n _props$enterNextDelay = props.enterNextDelay,\n enterNextDelay = _props$enterNextDelay === void 0 ? 0 : _props$enterNextDelay,\n _props$enterTouchDela = props.enterTouchDelay,\n enterTouchDelay = _props$enterTouchDela === void 0 ? 700 : _props$enterTouchDela,\n idProp = props.id,\n _props$interactive = props.interactive,\n interactive = _props$interactive === void 0 ? false : _props$interactive,\n _props$leaveDelay = props.leaveDelay,\n leaveDelay = _props$leaveDelay === void 0 ? 0 : _props$leaveDelay,\n _props$leaveTouchDela = props.leaveTouchDelay,\n leaveTouchDelay = _props$leaveTouchDela === void 0 ? 1500 : _props$leaveTouchDela,\n onClose = props.onClose,\n onOpen = props.onOpen,\n openProp = props.open,\n _props$placement = props.placement,\n placement = _props$placement === void 0 ? 'bottom' : _props$placement,\n _props$PopperComponen = props.PopperComponent,\n PopperComponent = _props$PopperComponen === void 0 ? Popper : _props$PopperComponen,\n PopperProps = props.PopperProps,\n title = props.title,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Grow : _props$TransitionComp,\n TransitionProps = props.TransitionProps,\n other = _objectWithoutProperties(props, [\"arrow\", \"children\", \"classes\", \"disableFocusListener\", \"disableHoverListener\", \"disableTouchListener\", \"enterDelay\", \"enterNextDelay\", \"enterTouchDelay\", \"id\", \"interactive\", \"leaveDelay\", \"leaveTouchDelay\", \"onClose\", \"onOpen\", \"open\", \"placement\", \"PopperComponent\", \"PopperProps\", \"title\", \"TransitionComponent\", \"TransitionProps\"]);\n\n var theme = useTheme();\n\n var _React$useState = React.useState(),\n childNode = _React$useState[0],\n setChildNode = _React$useState[1];\n\n var _React$useState2 = React.useState(null),\n arrowRef = _React$useState2[0],\n setArrowRef = _React$useState2[1];\n\n var ignoreNonTouchEvents = React.useRef(false);\n var closeTimer = React.useRef();\n var enterTimer = React.useRef();\n var leaveTimer = React.useRef();\n var touchTimer = React.useRef();\n\n var _useControlled = useControlled({\n controlled: openProp,\n default: false,\n name: 'Tooltip',\n state: 'open'\n }),\n _useControlled2 = _slicedToArray(_useControlled, 2),\n openState = _useControlled2[0],\n setOpenState = _useControlled2[1];\n\n var open = openState;\n\n if (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n var _React$useRef = React.useRef(openProp !== undefined),\n isControlled = _React$useRef.current; // eslint-disable-next-line react-hooks/rules-of-hooks\n\n\n React.useEffect(function () {\n if (childNode && childNode.disabled && !isControlled && title !== '' && childNode.tagName.toLowerCase() === 'button') {\n console.error(['Material-UI: You are providing a disabled `button` child to the Tooltip component.', 'A disabled element does not fire events.', \"Tooltip needs to listen to the child element's events to display the title.\", '', 'Add a simple wrapper element, such as a `span`.'].join('\\n'));\n }\n }, [title, childNode, isControlled]);\n }\n\n var id = useId(idProp);\n React.useEffect(function () {\n return function () {\n clearTimeout(closeTimer.current);\n clearTimeout(enterTimer.current);\n clearTimeout(leaveTimer.current);\n clearTimeout(touchTimer.current);\n };\n }, []);\n\n var handleOpen = function handleOpen(event) {\n clearTimeout(hystersisTimer);\n hystersisOpen = true; // The mouseover event will trigger for every nested element in the tooltip.\n // We can skip rerendering when the tooltip is already open.\n // We are using the mouseover event instead of the mouseenter event to fix a hide/show issue.\n\n setOpenState(true);\n\n if (onOpen) {\n onOpen(event);\n }\n };\n\n var handleEnter = function handleEnter() {\n var forward = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n return function (event) {\n var childrenProps = children.props;\n\n if (event.type === 'mouseover' && childrenProps.onMouseOver && forward) {\n childrenProps.onMouseOver(event);\n }\n\n if (ignoreNonTouchEvents.current && event.type !== 'touchstart') {\n return;\n } // Remove the title ahead of time.\n // We don't want to wait for the next render commit.\n // We would risk displaying two tooltips at the same time (native + this one).\n\n\n if (childNode) {\n childNode.removeAttribute('title');\n }\n\n clearTimeout(enterTimer.current);\n clearTimeout(leaveTimer.current);\n\n if (enterDelay || hystersisOpen && enterNextDelay) {\n event.persist();\n enterTimer.current = setTimeout(function () {\n handleOpen(event);\n }, hystersisOpen ? enterNextDelay : enterDelay);\n } else {\n handleOpen(event);\n }\n };\n };\n\n var _useIsFocusVisible = useIsFocusVisible(),\n isFocusVisible = _useIsFocusVisible.isFocusVisible,\n onBlurVisible = _useIsFocusVisible.onBlurVisible,\n focusVisibleRef = _useIsFocusVisible.ref;\n\n var _React$useState3 = React.useState(false),\n childIsFocusVisible = _React$useState3[0],\n setChildIsFocusVisible = _React$useState3[1];\n\n var handleBlur = function handleBlur() {\n if (childIsFocusVisible) {\n setChildIsFocusVisible(false);\n onBlurVisible();\n }\n };\n\n var handleFocus = function handleFocus() {\n var forward = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n return function (event) {\n // Workaround for https://github.com/facebook/react/issues/7769\n // The autoFocus of React might trigger the event before the componentDidMount.\n // We need to account for this eventuality.\n if (!childNode) {\n setChildNode(event.currentTarget);\n }\n\n if (isFocusVisible(event)) {\n setChildIsFocusVisible(true);\n handleEnter()(event);\n }\n\n var childrenProps = children.props;\n\n if (childrenProps.onFocus && forward) {\n childrenProps.onFocus(event);\n }\n };\n };\n\n var handleClose = function handleClose(event) {\n clearTimeout(hystersisTimer);\n hystersisTimer = setTimeout(function () {\n hystersisOpen = false;\n }, 800 + leaveDelay);\n setOpenState(false);\n\n if (onClose) {\n onClose(event);\n }\n\n clearTimeout(closeTimer.current);\n closeTimer.current = setTimeout(function () {\n ignoreNonTouchEvents.current = false;\n }, theme.transitions.duration.shortest);\n };\n\n var handleLeave = function handleLeave() {\n var forward = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n return function (event) {\n var childrenProps = children.props;\n\n if (event.type === 'blur') {\n if (childrenProps.onBlur && forward) {\n childrenProps.onBlur(event);\n }\n\n handleBlur();\n }\n\n if (event.type === 'mouseleave' && childrenProps.onMouseLeave && event.currentTarget === childNode) {\n childrenProps.onMouseLeave(event);\n }\n\n clearTimeout(enterTimer.current);\n clearTimeout(leaveTimer.current);\n event.persist();\n leaveTimer.current = setTimeout(function () {\n handleClose(event);\n }, leaveDelay);\n };\n };\n\n var detectTouchStart = function detectTouchStart(event) {\n ignoreNonTouchEvents.current = true;\n var childrenProps = children.props;\n\n if (childrenProps.onTouchStart) {\n childrenProps.onTouchStart(event);\n }\n };\n\n var handleTouchStart = function handleTouchStart(event) {\n detectTouchStart(event);\n clearTimeout(leaveTimer.current);\n clearTimeout(closeTimer.current);\n clearTimeout(touchTimer.current);\n event.persist();\n touchTimer.current = setTimeout(function () {\n handleEnter()(event);\n }, enterTouchDelay);\n };\n\n var handleTouchEnd = function handleTouchEnd(event) {\n if (children.props.onTouchEnd) {\n children.props.onTouchEnd(event);\n }\n\n clearTimeout(touchTimer.current);\n clearTimeout(leaveTimer.current);\n event.persist();\n leaveTimer.current = setTimeout(function () {\n handleClose(event);\n }, leaveTouchDelay);\n };\n\n var handleUseRef = useForkRef(setChildNode, ref);\n var handleFocusRef = useForkRef(focusVisibleRef, handleUseRef); // can be removed once we drop support for non ref forwarding class components\n\n var handleOwnRef = React.useCallback(function (instance) {\n // #StrictMode ready\n setRef(handleFocusRef, ReactDOM.findDOMNode(instance));\n }, [handleFocusRef]);\n var handleRef = useForkRef(children.ref, handleOwnRef); // There is no point in displaying an empty tooltip.\n\n if (title === '') {\n open = false;\n } // For accessibility and SEO concerns, we render the title to the DOM node when\n // the tooltip is hidden. However, we have made a tradeoff when\n // `disableHoverListener` is set. This title logic is disabled.\n // It's allowing us to keep the implementation size minimal.\n // We are open to change the tradeoff.\n\n\n var shouldShowNativeTitle = !open && !disableHoverListener;\n\n var childrenProps = _extends({\n 'aria-describedby': open ? id : null,\n title: shouldShowNativeTitle && typeof title === 'string' ? title : null\n }, other, children.props, {\n className: clsx(other.className, children.props.className),\n onTouchStart: detectTouchStart,\n ref: handleRef\n });\n\n var interactiveWrapperListeners = {};\n\n if (!disableTouchListener) {\n childrenProps.onTouchStart = handleTouchStart;\n childrenProps.onTouchEnd = handleTouchEnd;\n }\n\n if (!disableHoverListener) {\n childrenProps.onMouseOver = handleEnter();\n childrenProps.onMouseLeave = handleLeave();\n\n if (interactive) {\n interactiveWrapperListeners.onMouseOver = handleEnter(false);\n interactiveWrapperListeners.onMouseLeave = handleLeave(false);\n }\n }\n\n if (!disableFocusListener) {\n childrenProps.onFocus = handleFocus();\n childrenProps.onBlur = handleLeave();\n\n if (interactive) {\n interactiveWrapperListeners.onFocus = handleFocus(false);\n interactiveWrapperListeners.onBlur = handleLeave(false);\n }\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (children.props.title) {\n console.error(['Material-UI: You have provided a `title` prop to the child of .', \"Remove this title prop `\".concat(children.props.title, \"` or the Tooltip component.\")].join('\\n'));\n }\n }\n\n var mergedPopperProps = React.useMemo(function () {\n return deepmerge({\n popperOptions: {\n modifiers: {\n arrow: {\n enabled: Boolean(arrowRef),\n element: arrowRef\n }\n }\n }\n }, PopperProps);\n }, [arrowRef, PopperProps]);\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.cloneElement(children, childrenProps), /*#__PURE__*/React.createElement(PopperComponent, _extends({\n className: clsx(classes.popper, interactive && classes.popperInteractive, arrow && classes.popperArrow),\n placement: placement,\n anchorEl: childNode,\n open: childNode ? open : false,\n id: childrenProps['aria-describedby'],\n transition: true\n }, interactiveWrapperListeners, mergedPopperProps), function (_ref) {\n var placementInner = _ref.placement,\n TransitionPropsInner = _ref.TransitionProps;\n return /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n timeout: theme.transitions.duration.shorter\n }, TransitionPropsInner, TransitionProps), /*#__PURE__*/React.createElement(\"div\", {\n className: clsx(classes.tooltip, classes[\"tooltipPlacement\".concat(capitalize(placementInner.split('-')[0]))], ignoreNonTouchEvents.current && classes.touch, arrow && classes.tooltipArrow)\n }, title, arrow ? /*#__PURE__*/React.createElement(\"span\", {\n className: classes.arrow,\n ref: setArrowRef\n }) : null));\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? Tooltip.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * If `true`, adds an arrow to the tooltip.\n */\n arrow: PropTypes.bool,\n\n /**\n * Tooltip reference element.\n */\n children: elementAcceptingRef.isRequired,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * Do not respond to focus events.\n */\n disableFocusListener: PropTypes.bool,\n\n /**\n * Do not respond to hover events.\n */\n disableHoverListener: PropTypes.bool,\n\n /**\n * Do not respond to long press touch events.\n */\n disableTouchListener: PropTypes.bool,\n\n /**\n * The number of milliseconds to wait before showing the tooltip.\n * This prop won't impact the enter touch delay (`enterTouchDelay`).\n */\n enterDelay: PropTypes.number,\n\n /**\n * The number of milliseconds to wait before showing the tooltip when one was already recently opened.\n */\n enterNextDelay: PropTypes.number,\n\n /**\n * The number of milliseconds a user must touch the element before showing the tooltip.\n */\n enterTouchDelay: PropTypes.number,\n\n /**\n * This prop is used to help implement the accessibility logic.\n * If you don't provide this prop. It falls back to a randomly generated id.\n */\n id: PropTypes.string,\n\n /**\n * Makes a tooltip interactive, i.e. will not close when the user\n * hovers over the tooltip before the `leaveDelay` is expired.\n */\n interactive: PropTypes.bool,\n\n /**\n * The number of milliseconds to wait before hiding the tooltip.\n * This prop won't impact the leave touch delay (`leaveTouchDelay`).\n */\n leaveDelay: PropTypes.number,\n\n /**\n * The number of milliseconds after the user stops touching an element before hiding the tooltip.\n */\n leaveTouchDelay: PropTypes.number,\n\n /**\n * Callback fired when the component requests to be closed.\n *\n * @param {object} event The event source of the callback.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be open.\n *\n * @param {object} event The event source of the callback.\n */\n onOpen: PropTypes.func,\n\n /**\n * If `true`, the tooltip is shown.\n */\n open: PropTypes.bool,\n\n /**\n * Tooltip placement.\n */\n placement: PropTypes.oneOf(['bottom-end', 'bottom-start', 'bottom', 'left-end', 'left-start', 'left', 'right-end', 'right-start', 'right', 'top-end', 'top-start', 'top']),\n\n /**\n * The component used for the popper.\n */\n PopperComponent: PropTypes.elementType,\n\n /**\n * Props applied to the [`Popper`](/api/popper/) element.\n */\n PopperProps: PropTypes.object,\n\n /**\n * Tooltip title. Zero-length titles string are never displayed.\n */\n title: PropTypes\n /* @typescript-to-proptypes-ignore */\n .node.isRequired,\n\n /**\n * The component used for the transition.\n * [Follow this guide](/components/transitions/#transitioncomponent-prop) to learn more about the requirements for this component.\n */\n TransitionComponent: PropTypes.elementType,\n\n /**\n * Props applied to the [`Transition`](http://reactcommunity.org/react-transition-group/transition#Transition-props) element.\n */\n TransitionProps: PropTypes.object\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTooltip',\n flip: false\n})(Tooltip);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport { alpha } from '../styles/colorManipulator';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n height: 1,\n margin: 0,\n // Reset browser default style.\n border: 'none',\n flexShrink: 0,\n backgroundColor: theme.palette.divider\n },\n\n /* Styles applied to the root element if `absolute={true}`. */\n absolute: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n width: '100%'\n },\n\n /* Styles applied to the root element if `variant=\"inset\"`. */\n inset: {\n marginLeft: 72\n },\n\n /* Styles applied to the root element if `light={true}`. */\n light: {\n backgroundColor: alpha(theme.palette.divider, 0.08)\n },\n\n /* Styles applied to the root element if `variant=\"middle\"`. */\n middle: {\n marginLeft: theme.spacing(2),\n marginRight: theme.spacing(2)\n },\n\n /* Styles applied to the root element if `orientation=\"vertical\"`. */\n vertical: {\n height: '100%',\n width: 1\n },\n\n /* Styles applied to the root element if `flexItem={true}`. */\n flexItem: {\n alignSelf: 'stretch',\n height: 'auto'\n }\n };\n};\nvar Divider = /*#__PURE__*/React.forwardRef(function Divider(props, ref) {\n var _props$absolute = props.absolute,\n absolute = _props$absolute === void 0 ? false : _props$absolute,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'hr' : _props$component,\n _props$flexItem = props.flexItem,\n flexItem = _props$flexItem === void 0 ? false : _props$flexItem,\n _props$light = props.light,\n light = _props$light === void 0 ? false : _props$light,\n _props$orientation = props.orientation,\n orientation = _props$orientation === void 0 ? 'horizontal' : _props$orientation,\n _props$role = props.role,\n role = _props$role === void 0 ? Component !== 'hr' ? 'separator' : undefined : _props$role,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'fullWidth' : _props$variant,\n other = _objectWithoutProperties(props, [\"absolute\", \"classes\", \"className\", \"component\", \"flexItem\", \"light\", \"orientation\", \"role\", \"variant\"]);\n\n return /*#__PURE__*/React.createElement(Component, _extends({\n className: clsx(classes.root, className, variant !== 'fullWidth' && classes[variant], absolute && classes.absolute, flexItem && classes.flexItem, light && classes.light, orientation === 'vertical' && classes.vertical),\n role: role,\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? Divider.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * Absolutely position the element.\n */\n absolute: PropTypes.bool,\n\n /**\n * @ignore\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * If `true`, a vertical divider will have the correct height when used in flex container.\n * (By default, a vertical divider will have a calculated height of `0px` if it is the child of a flex container.)\n */\n flexItem: PropTypes.bool,\n\n /**\n * If `true`, the divider will have a lighter color.\n */\n light: PropTypes.bool,\n\n /**\n * The divider orientation.\n */\n orientation: PropTypes.oneOf(['horizontal', 'vertical']),\n\n /**\n * @ignore\n */\n role: PropTypes.string,\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['fullWidth', 'inset', 'middle'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiDivider'\n})(Divider);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport * as ReactDOM from 'react-dom';\nimport debounce from '../utils/debounce';\nimport { Transition } from 'react-transition-group';\nimport { elementAcceptingRef } from '@material-ui/utils';\nimport useForkRef from '../utils/useForkRef';\nimport useTheme from '../styles/useTheme';\nimport { duration } from '../styles/transitions';\nimport { reflow, getTransitionProps } from '../transitions/utils'; // Translate the node so he can't be seen on the screen.\n// Later, we gonna translate back the node to his original location\n// with `none`.`\n\nfunction getTranslateValue(direction, node) {\n var rect = node.getBoundingClientRect();\n var transform;\n\n if (node.fakeTransform) {\n transform = node.fakeTransform;\n } else {\n var computedStyle = window.getComputedStyle(node);\n transform = computedStyle.getPropertyValue('-webkit-transform') || computedStyle.getPropertyValue('transform');\n }\n\n var offsetX = 0;\n var offsetY = 0;\n\n if (transform && transform !== 'none' && typeof transform === 'string') {\n var transformValues = transform.split('(')[1].split(')')[0].split(',');\n offsetX = parseInt(transformValues[4], 10);\n offsetY = parseInt(transformValues[5], 10);\n }\n\n if (direction === 'left') {\n return \"translateX(\".concat(window.innerWidth, \"px) translateX(\").concat(offsetX - rect.left, \"px)\");\n }\n\n if (direction === 'right') {\n return \"translateX(-\".concat(rect.left + rect.width - offsetX, \"px)\");\n }\n\n if (direction === 'up') {\n return \"translateY(\".concat(window.innerHeight, \"px) translateY(\").concat(offsetY - rect.top, \"px)\");\n } // direction === 'down'\n\n\n return \"translateY(-\".concat(rect.top + rect.height - offsetY, \"px)\");\n}\n\nexport function setTranslateValue(direction, node) {\n var transform = getTranslateValue(direction, node);\n\n if (transform) {\n node.style.webkitTransform = transform;\n node.style.transform = transform;\n }\n}\nvar defaultTimeout = {\n enter: duration.enteringScreen,\n exit: duration.leavingScreen\n};\n/**\n * The Slide transition is used by the [Drawer](/components/drawers/) component.\n * It uses [react-transition-group](https://github.com/reactjs/react-transition-group) internally.\n */\n\nvar Slide = /*#__PURE__*/React.forwardRef(function Slide(props, ref) {\n var children = props.children,\n _props$direction = props.direction,\n direction = _props$direction === void 0 ? 'down' : _props$direction,\n inProp = props.in,\n onEnter = props.onEnter,\n onEntered = props.onEntered,\n onEntering = props.onEntering,\n onExit = props.onExit,\n onExited = props.onExited,\n onExiting = props.onExiting,\n style = props.style,\n _props$timeout = props.timeout,\n timeout = _props$timeout === void 0 ? defaultTimeout : _props$timeout,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Transition : _props$TransitionComp,\n other = _objectWithoutProperties(props, [\"children\", \"direction\", \"in\", \"onEnter\", \"onEntered\", \"onEntering\", \"onExit\", \"onExited\", \"onExiting\", \"style\", \"timeout\", \"TransitionComponent\"]);\n\n var theme = useTheme();\n var childrenRef = React.useRef(null);\n /**\n * used in cloneElement(children, { ref: handleRef })\n */\n\n var handleOwnRef = React.useCallback(function (instance) {\n // #StrictMode ready\n childrenRef.current = ReactDOM.findDOMNode(instance);\n }, []);\n var handleRefIntermediary = useForkRef(children.ref, handleOwnRef);\n var handleRef = useForkRef(handleRefIntermediary, ref);\n\n var normalizedTransitionCallback = function normalizedTransitionCallback(callback) {\n return function (isAppearing) {\n if (callback) {\n // onEnterXxx and onExitXxx callbacks have a different arguments.length value.\n if (isAppearing === undefined) {\n callback(childrenRef.current);\n } else {\n callback(childrenRef.current, isAppearing);\n }\n }\n };\n };\n\n var handleEnter = normalizedTransitionCallback(function (node, isAppearing) {\n setTranslateValue(direction, node);\n reflow(node);\n\n if (onEnter) {\n onEnter(node, isAppearing);\n }\n });\n var handleEntering = normalizedTransitionCallback(function (node, isAppearing) {\n var transitionProps = getTransitionProps({\n timeout: timeout,\n style: style\n }, {\n mode: 'enter'\n });\n node.style.webkitTransition = theme.transitions.create('-webkit-transform', _extends({}, transitionProps, {\n easing: theme.transitions.easing.easeOut\n }));\n node.style.transition = theme.transitions.create('transform', _extends({}, transitionProps, {\n easing: theme.transitions.easing.easeOut\n }));\n node.style.webkitTransform = 'none';\n node.style.transform = 'none';\n\n if (onEntering) {\n onEntering(node, isAppearing);\n }\n });\n var handleEntered = normalizedTransitionCallback(onEntered);\n var handleExiting = normalizedTransitionCallback(onExiting);\n var handleExit = normalizedTransitionCallback(function (node) {\n var transitionProps = getTransitionProps({\n timeout: timeout,\n style: style\n }, {\n mode: 'exit'\n });\n node.style.webkitTransition = theme.transitions.create('-webkit-transform', _extends({}, transitionProps, {\n easing: theme.transitions.easing.sharp\n }));\n node.style.transition = theme.transitions.create('transform', _extends({}, transitionProps, {\n easing: theme.transitions.easing.sharp\n }));\n setTranslateValue(direction, node);\n\n if (onExit) {\n onExit(node);\n }\n });\n var handleExited = normalizedTransitionCallback(function (node) {\n // No need for transitions when the component is hidden\n node.style.webkitTransition = '';\n node.style.transition = '';\n\n if (onExited) {\n onExited(node);\n }\n });\n var updatePosition = React.useCallback(function () {\n if (childrenRef.current) {\n setTranslateValue(direction, childrenRef.current);\n }\n }, [direction]);\n React.useEffect(function () {\n // Skip configuration where the position is screen size invariant.\n if (inProp || direction === 'down' || direction === 'right') {\n return undefined;\n }\n\n var handleResize = debounce(function () {\n if (childrenRef.current) {\n setTranslateValue(direction, childrenRef.current);\n }\n });\n window.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n window.removeEventListener('resize', handleResize);\n };\n }, [direction, inProp]);\n React.useEffect(function () {\n if (!inProp) {\n // We need to update the position of the drawer when the direction change and\n // when it's hidden.\n updatePosition();\n }\n }, [inProp, updatePosition]);\n return /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n nodeRef: childrenRef,\n onEnter: handleEnter,\n onEntered: handleEntered,\n onEntering: handleEntering,\n onExit: handleExit,\n onExited: handleExited,\n onExiting: handleExiting,\n appear: true,\n in: inProp,\n timeout: timeout\n }, other), function (state, childProps) {\n return /*#__PURE__*/React.cloneElement(children, _extends({\n ref: handleRef,\n style: _extends({\n visibility: state === 'exited' && !inProp ? 'hidden' : undefined\n }, style, children.props.style)\n }, childProps));\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Slide.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * A single child content element.\n */\n children: elementAcceptingRef,\n\n /**\n * Direction the child node will enter from.\n */\n direction: PropTypes.oneOf(['down', 'left', 'right', 'up']),\n\n /**\n * If `true`, show the component; triggers the enter or exit animation.\n */\n in: PropTypes.bool,\n\n /**\n * @ignore\n */\n onEnter: PropTypes.func,\n\n /**\n * @ignore\n */\n onEntered: PropTypes.func,\n\n /**\n * @ignore\n */\n onEntering: PropTypes.func,\n\n /**\n * @ignore\n */\n onExit: PropTypes.func,\n\n /**\n * @ignore\n */\n onExited: PropTypes.func,\n\n /**\n * @ignore\n */\n onExiting: PropTypes.func,\n\n /**\n * @ignore\n */\n style: PropTypes.object,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n */\n timeout: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n appear: PropTypes.number,\n enter: PropTypes.number,\n exit: PropTypes.number\n })])\n} : void 0;\nexport default Slide;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport Modal from '../Modal';\nimport Backdrop from '../Backdrop';\nimport withStyles from '../styles/withStyles';\nimport Slide from '../Slide';\nimport Paper from '../Paper';\nimport capitalize from '../utils/capitalize';\nimport { duration } from '../styles/transitions';\nimport useTheme from '../styles/useTheme';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {},\n\n /* Styles applied to the root element if `variant=\"permanent or persistent\"`. */\n docked: {\n flex: '0 0 auto'\n },\n\n /* Styles applied to the `Paper` component. */\n paper: {\n overflowY: 'auto',\n display: 'flex',\n flexDirection: 'column',\n height: '100%',\n flex: '1 0 auto',\n zIndex: theme.zIndex.drawer,\n WebkitOverflowScrolling: 'touch',\n // Add iOS momentum scrolling.\n // temporary style\n position: 'fixed',\n top: 0,\n // We disable the focus ring for mouse, touch and keyboard users.\n // At some point, it would be better to keep it for keyboard users.\n // :focus-ring CSS pseudo-class will help.\n outline: 0\n },\n\n /* Styles applied to the `Paper` component if `anchor=\"left\"`. */\n paperAnchorLeft: {\n left: 0,\n right: 'auto'\n },\n\n /* Styles applied to the `Paper` component if `anchor=\"right\"`. */\n paperAnchorRight: {\n left: 'auto',\n right: 0\n },\n\n /* Styles applied to the `Paper` component if `anchor=\"top\"`. */\n paperAnchorTop: {\n top: 0,\n left: 0,\n bottom: 'auto',\n right: 0,\n height: 'auto',\n maxHeight: '100%'\n },\n\n /* Styles applied to the `Paper` component if `anchor=\"bottom\"`. */\n paperAnchorBottom: {\n top: 'auto',\n left: 0,\n bottom: 0,\n right: 0,\n height: 'auto',\n maxHeight: '100%'\n },\n\n /* Styles applied to the `Paper` component if `anchor=\"left\"` and `variant` is not \"temporary\". */\n paperAnchorDockedLeft: {\n borderRight: \"1px solid \".concat(theme.palette.divider)\n },\n\n /* Styles applied to the `Paper` component if `anchor=\"top\"` and `variant` is not \"temporary\". */\n paperAnchorDockedTop: {\n borderBottom: \"1px solid \".concat(theme.palette.divider)\n },\n\n /* Styles applied to the `Paper` component if `anchor=\"right\"` and `variant` is not \"temporary\". */\n paperAnchorDockedRight: {\n borderLeft: \"1px solid \".concat(theme.palette.divider)\n },\n\n /* Styles applied to the `Paper` component if `anchor=\"bottom\"` and `variant` is not \"temporary\". */\n paperAnchorDockedBottom: {\n borderTop: \"1px solid \".concat(theme.palette.divider)\n },\n\n /* Styles applied to the `Modal` component. */\n modal: {}\n };\n};\nvar oppositeDirection = {\n left: 'right',\n right: 'left',\n top: 'down',\n bottom: 'up'\n};\nexport function isHorizontal(anchor) {\n return ['left', 'right'].indexOf(anchor) !== -1;\n}\nexport function getAnchor(theme, anchor) {\n return theme.direction === 'rtl' && isHorizontal(anchor) ? oppositeDirection[anchor] : anchor;\n}\nvar defaultTransitionDuration = {\n enter: duration.enteringScreen,\n exit: duration.leavingScreen\n};\n/**\n * The props of the [Modal](/api/modal/) component are available\n * when `variant=\"temporary\"` is set.\n */\n\nvar Drawer = /*#__PURE__*/React.forwardRef(function Drawer(props, ref) {\n var _props$anchor = props.anchor,\n anchorProp = _props$anchor === void 0 ? 'left' : _props$anchor,\n BackdropProps = props.BackdropProps,\n children = props.children,\n classes = props.classes,\n className = props.className,\n _props$elevation = props.elevation,\n elevation = _props$elevation === void 0 ? 16 : _props$elevation,\n _props$ModalProps = props.ModalProps;\n _props$ModalProps = _props$ModalProps === void 0 ? {} : _props$ModalProps;\n\n var BackdropPropsProp = _props$ModalProps.BackdropProps,\n ModalProps = _objectWithoutProperties(_props$ModalProps, [\"BackdropProps\"]),\n onClose = props.onClose,\n _props$open = props.open,\n open = _props$open === void 0 ? false : _props$open,\n _props$PaperProps = props.PaperProps,\n PaperProps = _props$PaperProps === void 0 ? {} : _props$PaperProps,\n SlideProps = props.SlideProps,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Slide : _props$TransitionComp,\n _props$transitionDura = props.transitionDuration,\n transitionDuration = _props$transitionDura === void 0 ? defaultTransitionDuration : _props$transitionDura,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'temporary' : _props$variant,\n other = _objectWithoutProperties(props, [\"anchor\", \"BackdropProps\", \"children\", \"classes\", \"className\", \"elevation\", \"ModalProps\", \"onClose\", \"open\", \"PaperProps\", \"SlideProps\", \"TransitionComponent\", \"transitionDuration\", \"variant\"]);\n\n var theme = useTheme(); // Let's assume that the Drawer will always be rendered on user space.\n // We use this state is order to skip the appear transition during the\n // initial mount of the component.\n\n var mounted = React.useRef(false);\n React.useEffect(function () {\n mounted.current = true;\n }, []);\n var anchor = getAnchor(theme, anchorProp);\n var drawer = /*#__PURE__*/React.createElement(Paper, _extends({\n elevation: variant === 'temporary' ? elevation : 0,\n square: true\n }, PaperProps, {\n className: clsx(classes.paper, classes[\"paperAnchor\".concat(capitalize(anchor))], PaperProps.className, variant !== 'temporary' && classes[\"paperAnchorDocked\".concat(capitalize(anchor))])\n }), children);\n\n if (variant === 'permanent') {\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n className: clsx(classes.root, classes.docked, className),\n ref: ref\n }, other), drawer);\n }\n\n var slidingDrawer = /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n in: open,\n direction: oppositeDirection[anchor],\n timeout: transitionDuration,\n appear: mounted.current\n }, SlideProps), drawer);\n\n if (variant === 'persistent') {\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n className: clsx(classes.root, classes.docked, className),\n ref: ref\n }, other), slidingDrawer);\n } // variant === temporary\n\n\n return /*#__PURE__*/React.createElement(Modal, _extends({\n BackdropProps: _extends({}, BackdropProps, BackdropPropsProp, {\n transitionDuration: transitionDuration\n }),\n BackdropComponent: Backdrop,\n className: clsx(classes.root, classes.modal, className),\n open: open,\n onClose: onClose,\n ref: ref\n }, other, ModalProps), slidingDrawer);\n});\nprocess.env.NODE_ENV !== \"production\" ? Drawer.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * Side from which the drawer will appear.\n */\n anchor: PropTypes.oneOf(['bottom', 'left', 'right', 'top']),\n\n /**\n * @ignore\n */\n BackdropProps: PropTypes.object,\n\n /**\n * The contents of the drawer.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The elevation of the drawer.\n */\n elevation: PropTypes.number,\n\n /**\n * Props applied to the [`Modal`](/api/modal/) element.\n */\n ModalProps: PropTypes.object,\n\n /**\n * Callback fired when the component requests to be closed.\n *\n * @param {object} event The event source of the callback.\n */\n onClose: PropTypes.func,\n\n /**\n * If `true`, the drawer is open.\n */\n open: PropTypes.bool,\n\n /**\n * Props applied to the [`Paper`](/api/paper/) element.\n */\n PaperProps: PropTypes.object,\n\n /**\n * Props applied to the [`Slide`](/api/slide/) element.\n */\n SlideProps: PropTypes.object,\n\n /**\n * The duration for the transition, in milliseconds.\n * You may specify a single timeout for all transitions, or individually with an object.\n */\n transitionDuration: PropTypes.oneOfType([PropTypes.number, PropTypes.shape({\n appear: PropTypes.number,\n enter: PropTypes.number,\n exit: PropTypes.number\n })]),\n\n /**\n * The variant to use.\n */\n variant: PropTypes.oneOf(['permanent', 'persistent', 'temporary'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiDrawer',\n flip: false\n})(Drawer);"],"sourceRoot":""}