{"version":3,"sources":["../node_modules/@mui/material/Grow/Grow.js","../node_modules/@mui/utils/esm/getScrollbarSize/getScrollbarSize.js","../node_modules/@mui/material/Unstable_TrapFocus/FocusTrap.js","../node_modules/@mui/material/Modal/ModalManager.js","../node_modules/@mui/material/Modal/useModal.js","../node_modules/@mui/material/Modal/modalClasses.js","../node_modules/@mui/material/Modal/Modal.js","../node_modules/@mui/material/Backdrop/backdropClasses.js","../node_modules/@mui/material/Backdrop/Backdrop.js"],"names":["_excluded","getScale","value","styles","entering","opacity","transform","entered","isWebKit154","navigator","test","userAgent","Grow","React","props","ref","addEndListener","appear","children","easing","in","inProp","onEnter","onEntered","onEntering","onExit","onExited","onExiting","style","timeout","TransitionComponent","Transition","other","_objectWithoutPropertiesLoose","timer","useTimeout","autoTimeout","theme","useTheme","nodeRef","handleRef","useForkRef","getReactElementRef","normalizedTransitionCallback","callback","maybeIsAppearing","node","current","undefined","handleEntering","handleEnter","isAppearing","reflow","duration","transitionDuration","delay","transitionTimingFunction","getTransitionProps","mode","transitions","getAutoHeightDuration","clientHeight","transition","create","join","handleEntered","handleExiting","handleExit","handleExited","_jsx","_extends","next","start","state","childProps","visibility","muiSupportAuto","getScrollbarSize","doc","documentWidth","documentElement","clientWidth","Math","abs","window","innerWidth","candidatesSelector","defaultGetTabbable","root","regularTabNodes","orderedTabNodes","Array","from","querySelectorAll","forEach","i","nodeTabIndex","tabindexAttr","parseInt","getAttribute","Number","isNaN","contentEditable","nodeName","tabIndex","getTabIndex","disabled","tagName","type","name","getRadio","selector","ownerDocument","querySelector","roving","isNonTabbableRadio","isNodeMatchingSelectorFocusable","push","documentOrder","sort","a","b","map","concat","defaultIsEnabled","FocusTrap","disableAutoFocus","disableEnforceFocus","disableRestoreFocus","getTabbable","isEnabled","open","ignoreNextEnforceFocus","sentinelStart","sentinelEnd","nodeToRestore","reactFocusEventTarget","activated","rootRef","lastKeydown","contains","activeElement","hasAttribute","setAttribute","focus","loopFocus","nativeEvent","key","shiftKey","contain","rootElement","hasFocus","tabbable","length","_lastKeydown$current","_lastKeydown$current2","isShiftTab","Boolean","focusNext","focusPrevious","addEventListener","interval","setInterval","clearInterval","removeEventListener","handleFocusSentinel","event","relatedTarget","_jsxs","onFocus","target","childrenPropsHandler","ariaHidden","element","show","removeAttribute","getPaddingRight","ownerWindow","getComputedStyle","paddingRight","ariaHiddenSiblings","container","mountElement","currentElement","elementsToExclude","blacklist","call","isNotExcludedElement","indexOf","isNotForbiddenElement","isForbiddenTagName","isInputHidden","isAriaHiddenForbiddenOnElement","findIndexOf","items","idx","some","item","index","handleContainer","containerInfo","restoreStyle","disableScrollLock","body","scrollHeight","isOverflowing","scrollbarSize","property","el","fixedElements","scrollContainer","parentNode","DocumentFragment","parent","parentElement","containerWindow","overflowY","overflow","overflowX","restore","_ref","setProperty","removeProperty","defaultManager","constructor","this","containers","modals","add","modal","modalIndex","modalRef","hiddenSiblings","getHiddenSiblings","mount","containerIndex","remove","ariaHiddenState","arguments","splice","nextTop","isTopModal","useModal","parameters","disableEscapeKeyDown","manager","closeAfterTransition","onTransitionEnter","onTransitionExited","onClose","mountNodeRef","exited","setExited","hasTransition","hasOwnProperty","getHasTransition","ariaHiddenProp","getModal","handleMounted","scrollTop","handleOpen","useEventCallback","resolvedContainer","getContainer","handlePortalRef","handleClose","createHandleKeyDown","otherHandlers","_otherHandlers$onKeyD","onKeyDown","which","stopPropagation","createHandleBackdropClick","_otherHandlers$onClic","onClick","currentTarget","getRootProps","propsEventHandlers","extractEventHandlers","externalEventHandlers","role","getBackdropProps","createChainedFunction","portalRef","getModalUtilityClass","slot","generateUtilityClass","generateUtilityClasses","ModalRoot","styled","overridesResolver","ownerState","hidden","_ref3","position","zIndex","vars","right","bottom","top","left","ModalBackdrop","Backdrop","backdrop","Modal","inProps","_slots$root","_ref2","_slots$backdrop","_slotProps$root","_slotProps$backdrop","useDefaultProps","BackdropComponent","BackdropProps","className","component","components","componentsProps","disablePortal","hideBackdrop","keepMounted","onBackdropClick","slotProps","slots","propsWithDefaults","classes","composeClasses","useUtilityClasses","RootSlot","Root","BackdropSlot","rootSlotProps","backdropSlotProps","rootProps","useSlotProps","elementType","externalSlotProps","externalForwardedProps","getSlotProps","additionalProps","as","clsx","backdropProps","e","Portal","getBackdropUtilityClass","backdropClasses","BackdropRoot","invisible","display","alignItems","justifyContent","backgroundColor","WebkitTapHighlightColor","Fade"],"mappings":"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","file":"static/js/3.2289073f.chunk.js","sourcesContent":["'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"addEndListener\", \"appear\", \"children\", \"easing\", \"in\", \"onEnter\", \"onEntered\", \"onEntering\", \"onExit\", \"onExited\", \"onExiting\", \"style\", \"timeout\", \"TransitionComponent\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport useTimeout from '@mui/utils/useTimeout';\nimport elementAcceptingRef from '@mui/utils/elementAcceptingRef';\nimport getReactElementRef from '@mui/utils/getReactElementRef';\nimport { Transition } from 'react-transition-group';\nimport useTheme from '../styles/useTheme';\nimport { getTransitionProps, reflow } from '../transitions/utils';\nimport useForkRef from '../utils/useForkRef';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction getScale(value) {\n return `scale(${value}, ${value ** 2})`;\n}\nconst styles = {\n entering: {\n opacity: 1,\n transform: getScale(1)\n },\n entered: {\n opacity: 1,\n transform: 'none'\n }\n};\n\n/*\n TODO v6: remove\n Conditionally apply a workaround for the CSS transition bug in Safari 15.4 / WebKit browsers.\n */\nconst isWebKit154 = typeof navigator !== 'undefined' && /^((?!chrome|android).)*(safari|mobile)/i.test(navigator.userAgent) && /(os |version\\/)15(.|_)4/i.test(navigator.userAgent);\n\n/**\n * The Grow transition is used by the [Tooltip](/material-ui/react-tooltip/) and\n * [Popover](/material-ui/react-popover/) components.\n * It uses [react-transition-group](https://github.com/reactjs/react-transition-group) internally.\n */\nconst Grow = /*#__PURE__*/React.forwardRef(function Grow(props, ref) {\n const {\n addEndListener,\n appear = true,\n children,\n easing,\n in: inProp,\n onEnter,\n onEntered,\n onEntering,\n onExit,\n onExited,\n onExiting,\n style,\n timeout = 'auto',\n // eslint-disable-next-line react/prop-types\n TransitionComponent = Transition\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const timer = useTimeout();\n const autoTimeout = React.useRef();\n const theme = useTheme();\n const nodeRef = React.useRef(null);\n const handleRef = useForkRef(nodeRef, getReactElementRef(children), ref);\n const normalizedTransitionCallback = callback => maybeIsAppearing => {\n if (callback) {\n const node = nodeRef.current;\n\n // onEnterXxx and onExitXxx callbacks have a different arguments.length value.\n if (maybeIsAppearing === undefined) {\n callback(node);\n } else {\n callback(node, maybeIsAppearing);\n }\n }\n };\n const handleEntering = normalizedTransitionCallback(onEntering);\n const handleEnter = normalizedTransitionCallback((node, isAppearing) => {\n reflow(node); // So the animation always start from the start.\n\n const {\n duration: transitionDuration,\n delay,\n easing: transitionTimingFunction\n } = getTransitionProps({\n style,\n timeout,\n easing\n }, {\n mode: 'enter'\n });\n let duration;\n if (timeout === 'auto') {\n duration = theme.transitions.getAutoHeightDuration(node.clientHeight);\n autoTimeout.current = duration;\n } else {\n duration = transitionDuration;\n }\n node.style.transition = [theme.transitions.create('opacity', {\n duration,\n delay\n }), theme.transitions.create('transform', {\n duration: isWebKit154 ? duration : duration * 0.666,\n delay,\n easing: transitionTimingFunction\n })].join(',');\n if (onEnter) {\n onEnter(node, isAppearing);\n }\n });\n const handleEntered = normalizedTransitionCallback(onEntered);\n const handleExiting = normalizedTransitionCallback(onExiting);\n const handleExit = normalizedTransitionCallback(node => {\n const {\n duration: transitionDuration,\n delay,\n easing: transitionTimingFunction\n } = getTransitionProps({\n style,\n timeout,\n easing\n }, {\n mode: 'exit'\n });\n let duration;\n if (timeout === 'auto') {\n duration = theme.transitions.getAutoHeightDuration(node.clientHeight);\n autoTimeout.current = duration;\n } else {\n duration = transitionDuration;\n }\n node.style.transition = [theme.transitions.create('opacity', {\n duration,\n delay\n }), theme.transitions.create('transform', {\n duration: isWebKit154 ? duration : duration * 0.666,\n delay: isWebKit154 ? delay : delay || duration * 0.333,\n easing: transitionTimingFunction\n })].join(',');\n node.style.opacity = 0;\n node.style.transform = getScale(0.75);\n if (onExit) {\n onExit(node);\n }\n });\n const handleExited = normalizedTransitionCallback(onExited);\n const handleAddEndListener = next => {\n if (timeout === 'auto') {\n timer.start(autoTimeout.current || 0, next);\n }\n if (addEndListener) {\n // Old call signature before `react-transition-group` implemented `nodeRef`\n addEndListener(nodeRef.current, next);\n }\n };\n return /*#__PURE__*/_jsx(TransitionComponent, _extends({\n appear: appear,\n in: inProp,\n nodeRef: nodeRef,\n onEnter: handleEnter,\n onEntered: handleEntered,\n onEntering: handleEntering,\n onExit: handleExit,\n onExited: handleExited,\n onExiting: handleExiting,\n addEndListener: handleAddEndListener,\n timeout: timeout === 'auto' ? null : timeout\n }, other, {\n children: (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 }));\n});\nprocess.env.NODE_ENV !== \"production\" ? Grow.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * Add a custom transition end trigger. Called with the transitioning DOM\n * node and a done callback. Allows for more fine grained transition end\n * logic. Note: Timeouts are still used as a fallback if provided.\n */\n addEndListener: PropTypes.func,\n /**\n * Perform the enter transition when it first mounts if `in` is also `true`.\n * Set this to `false` to disable this behavior.\n * @default true\n */\n appear: PropTypes.bool,\n /**\n * A single child content element.\n */\n children: elementAcceptingRef.isRequired,\n /**\n * The transition timing function.\n * You may specify a single easing or a object containing enter and exit values.\n */\n easing: PropTypes.oneOfType([PropTypes.shape({\n enter: PropTypes.string,\n exit: PropTypes.string\n }), PropTypes.string]),\n /**\n * If `true`, the component will transition in.\n */\n in: PropTypes.bool,\n /**\n * @ignore\n */\n onEnter: PropTypes.func,\n /**\n * @ignore\n */\n onEntered: PropTypes.func,\n /**\n * @ignore\n */\n onEntering: PropTypes.func,\n /**\n * @ignore\n */\n onExit: PropTypes.func,\n /**\n * @ignore\n */\n onExited: PropTypes.func,\n /**\n * @ignore\n */\n onExiting: PropTypes.func,\n /**\n * @ignore\n */\n style: PropTypes.object,\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 * @default 'auto'\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;","// A change of the browser zoom change the scrollbar size.\n// Credit https://github.com/twbs/bootstrap/blob/488fd8afc535ca3a6ad4dc581f5e89217b6a36ac/js/src/util/scrollbar.js#L14-L18\nexport default function getScrollbarSize(doc) {\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes\n const documentWidth = doc.documentElement.clientWidth;\n return Math.abs(window.innerWidth - documentWidth);\n}","'use client';\n\n/* eslint-disable consistent-return, jsx-a11y/no-noninteractive-tabindex */\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp, elementAcceptingRef, unstable_useForkRef as useForkRef, unstable_ownerDocument as ownerDocument, unstable_getReactElementRef as getReactElementRef } from '@mui/utils';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\n// Inspired by https://github.com/focus-trap/tabbable\nconst candidatesSelector = ['input', 'select', 'textarea', 'a[href]', 'button', '[tabindex]', 'audio[controls]', 'video[controls]', '[contenteditable]:not([contenteditable=\"false\"])'].join(',');\nfunction getTabIndex(node) {\n const tabindexAttr = parseInt(node.getAttribute('tabindex') || '', 10);\n if (!Number.isNaN(tabindexAttr)) {\n return tabindexAttr;\n }\n\n // Browsers do not return `tabIndex` correctly for contentEditable nodes;\n // https://bugs.chromium.org/p/chromium/issues/detail?id=661108&q=contenteditable%20tabindex&can=2\n // so if they don't have a tabindex attribute specifically set, assume it's 0.\n // in Chrome, , and elements get a default\n // `tabIndex` of -1 when the 'tabindex' attribute isn't specified in the DOM,\n // yet they are still part of the regular tab order; in FF, they get a default\n // `tabIndex` of 0; since Chrome still puts those elements in the regular tab\n // order, consider their tab index to be 0.\n if (node.contentEditable === 'true' || (node.nodeName === 'AUDIO' || node.nodeName === 'VIDEO' || node.nodeName === 'DETAILS') && node.getAttribute('tabindex') === null) {\n return 0;\n }\n return node.tabIndex;\n}\nfunction isNonTabbableRadio(node) {\n if (node.tagName !== 'INPUT' || node.type !== 'radio') {\n return false;\n }\n if (!node.name) {\n return false;\n }\n const getRadio = selector => node.ownerDocument.querySelector(`input[type=\"radio\"]${selector}`);\n let roving = getRadio(`[name=\"${node.name}\"]:checked`);\n if (!roving) {\n roving = getRadio(`[name=\"${node.name}\"]`);\n }\n return roving !== node;\n}\nfunction isNodeMatchingSelectorFocusable(node) {\n if (node.disabled || node.tagName === 'INPUT' && node.type === 'hidden' || isNonTabbableRadio(node)) {\n return false;\n }\n return true;\n}\nfunction defaultGetTabbable(root) {\n const regularTabNodes = [];\n const orderedTabNodes = [];\n Array.from(root.querySelectorAll(candidatesSelector)).forEach((node, i) => {\n const nodeTabIndex = getTabIndex(node);\n if (nodeTabIndex === -1 || !isNodeMatchingSelectorFocusable(node)) {\n return;\n }\n if (nodeTabIndex === 0) {\n regularTabNodes.push(node);\n } else {\n orderedTabNodes.push({\n documentOrder: i,\n tabIndex: nodeTabIndex,\n node: node\n });\n }\n });\n return orderedTabNodes.sort((a, b) => a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex).map(a => a.node).concat(regularTabNodes);\n}\nfunction defaultIsEnabled() {\n return true;\n}\n\n/**\n * @ignore - internal component.\n */\nfunction FocusTrap(props) {\n const {\n children,\n disableAutoFocus = false,\n disableEnforceFocus = false,\n disableRestoreFocus = false,\n getTabbable = defaultGetTabbable,\n isEnabled = defaultIsEnabled,\n open\n } = props;\n const ignoreNextEnforceFocus = React.useRef(false);\n const sentinelStart = React.useRef(null);\n const sentinelEnd = React.useRef(null);\n const nodeToRestore = React.useRef(null);\n const reactFocusEventTarget = React.useRef(null);\n // This variable is useful when disableAutoFocus is true.\n // It waits for the active element to move into the component to activate.\n const activated = React.useRef(false);\n const rootRef = React.useRef(null);\n const handleRef = useForkRef(getReactElementRef(children), rootRef);\n const lastKeydown = React.useRef(null);\n React.useEffect(() => {\n // We might render an empty child.\n if (!open || !rootRef.current) {\n return;\n }\n activated.current = !disableAutoFocus;\n }, [disableAutoFocus, open]);\n React.useEffect(() => {\n // We might render an empty child.\n if (!open || !rootRef.current) {\n return;\n }\n const doc = ownerDocument(rootRef.current);\n if (!rootRef.current.contains(doc.activeElement)) {\n if (!rootRef.current.hasAttribute('tabIndex')) {\n if (process.env.NODE_ENV !== 'production') {\n console.error(['MUI: The modal content node does not accept focus.', 'For the benefit of assistive technologies, ' + 'the tabIndex of the node is being set to \"-1\".'].join('\\n'));\n }\n rootRef.current.setAttribute('tabIndex', '-1');\n }\n if (activated.current) {\n rootRef.current.focus();\n }\n }\n return () => {\n // restoreLastFocus()\n if (!disableRestoreFocus) {\n // In IE11 it is possible for document.activeElement to be null resulting\n // in nodeToRestore.current being null.\n // Not all elements in IE11 have a focus method.\n // Once IE11 support is dropped the focus() call can be unconditional.\n if (nodeToRestore.current && nodeToRestore.current.focus) {\n ignoreNextEnforceFocus.current = true;\n nodeToRestore.current.focus();\n }\n nodeToRestore.current = null;\n }\n };\n // Missing `disableRestoreFocus` which is fine.\n // We don't support changing that prop on an open FocusTrap\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [open]);\n React.useEffect(() => {\n // We might render an empty child.\n if (!open || !rootRef.current) {\n return;\n }\n const doc = ownerDocument(rootRef.current);\n const loopFocus = nativeEvent => {\n lastKeydown.current = nativeEvent;\n if (disableEnforceFocus || !isEnabled() || nativeEvent.key !== 'Tab') {\n return;\n }\n\n // Make sure the next tab starts from the right place.\n // doc.activeElement refers to the origin.\n if (doc.activeElement === rootRef.current && nativeEvent.shiftKey) {\n // We need to ignore the next contain as\n // it will try to move the focus back to the rootRef element.\n ignoreNextEnforceFocus.current = true;\n if (sentinelEnd.current) {\n sentinelEnd.current.focus();\n }\n }\n };\n const contain = () => {\n const rootElement = rootRef.current;\n\n // Cleanup functions are executed lazily in React 17.\n // Contain can be called between the component being unmounted and its cleanup function being run.\n if (rootElement === null) {\n return;\n }\n if (!doc.hasFocus() || !isEnabled() || ignoreNextEnforceFocus.current) {\n ignoreNextEnforceFocus.current = false;\n return;\n }\n\n // The focus is already inside\n if (rootElement.contains(doc.activeElement)) {\n return;\n }\n\n // The disableEnforceFocus is set and the focus is outside of the focus trap (and sentinel nodes)\n if (disableEnforceFocus && doc.activeElement !== sentinelStart.current && doc.activeElement !== sentinelEnd.current) {\n return;\n }\n\n // if the focus event is not coming from inside the children's react tree, reset the refs\n if (doc.activeElement !== reactFocusEventTarget.current) {\n reactFocusEventTarget.current = null;\n } else if (reactFocusEventTarget.current !== null) {\n return;\n }\n if (!activated.current) {\n return;\n }\n let tabbable = [];\n if (doc.activeElement === sentinelStart.current || doc.activeElement === sentinelEnd.current) {\n tabbable = getTabbable(rootRef.current);\n }\n\n // one of the sentinel nodes was focused, so move the focus\n // to the first/last tabbable element inside the focus trap\n if (tabbable.length > 0) {\n var _lastKeydown$current, _lastKeydown$current2;\n const isShiftTab = Boolean(((_lastKeydown$current = lastKeydown.current) == null ? void 0 : _lastKeydown$current.shiftKey) && ((_lastKeydown$current2 = lastKeydown.current) == null ? void 0 : _lastKeydown$current2.key) === 'Tab');\n const focusNext = tabbable[0];\n const focusPrevious = tabbable[tabbable.length - 1];\n if (typeof focusNext !== 'string' && typeof focusPrevious !== 'string') {\n if (isShiftTab) {\n focusPrevious.focus();\n } else {\n focusNext.focus();\n }\n }\n // no tabbable elements in the trap focus or the focus was outside of the focus trap\n } else {\n rootElement.focus();\n }\n };\n doc.addEventListener('focusin', contain);\n doc.addEventListener('keydown', loopFocus, true);\n\n // With Edge, Safari and Firefox, no focus related events are fired when the focused area stops being a focused area.\n // for example https://bugzilla.mozilla.org/show_bug.cgi?id=559561.\n // Instead, we can look if the active element was restored on the BODY element.\n //\n // The whatwg spec defines how the browser should behave but does not explicitly mention any events:\n // https://html.spec.whatwg.org/multipage/interaction.html#focus-fixup-rule.\n const interval = setInterval(() => {\n if (doc.activeElement && doc.activeElement.tagName === 'BODY') {\n contain();\n }\n }, 50);\n return () => {\n clearInterval(interval);\n doc.removeEventListener('focusin', contain);\n doc.removeEventListener('keydown', loopFocus, true);\n };\n }, [disableAutoFocus, disableEnforceFocus, disableRestoreFocus, isEnabled, open, getTabbable]);\n const onFocus = event => {\n if (nodeToRestore.current === null) {\n nodeToRestore.current = event.relatedTarget;\n }\n activated.current = true;\n reactFocusEventTarget.current = event.target;\n const childrenPropsHandler = children.props.onFocus;\n if (childrenPropsHandler) {\n childrenPropsHandler(event);\n }\n };\n const handleFocusSentinel = event => {\n if (nodeToRestore.current === null) {\n nodeToRestore.current = event.relatedTarget;\n }\n activated.current = true;\n };\n return /*#__PURE__*/_jsxs(React.Fragment, {\n children: [/*#__PURE__*/_jsx(\"div\", {\n tabIndex: open ? 0 : -1,\n onFocus: handleFocusSentinel,\n ref: sentinelStart,\n \"data-testid\": \"sentinelStart\"\n }), /*#__PURE__*/React.cloneElement(children, {\n ref: handleRef,\n onFocus\n }), /*#__PURE__*/_jsx(\"div\", {\n tabIndex: open ? 0 : -1,\n onFocus: handleFocusSentinel,\n ref: sentinelEnd,\n \"data-testid\": \"sentinelEnd\"\n })]\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? FocusTrap.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * A single child content element.\n */\n children: elementAcceptingRef,\n /**\n * If `true`, the focus trap will not automatically shift focus to itself when it opens, and\n * replace it to the last focused element when it closes.\n * This also works correctly with any focus trap children that have the `disableAutoFocus` prop.\n *\n * Generally this should never be set to `true` as it makes the focus trap less\n * accessible to assistive technologies, like screen readers.\n * @default false\n */\n disableAutoFocus: PropTypes.bool,\n /**\n * If `true`, the focus trap will not prevent focus from leaving the focus trap while open.\n *\n * Generally this should never be set to `true` as it makes the focus trap less\n * accessible to assistive technologies, like screen readers.\n * @default false\n */\n disableEnforceFocus: PropTypes.bool,\n /**\n * If `true`, the focus trap will not restore focus to previously focused element once\n * focus trap is hidden or unmounted.\n * @default false\n */\n disableRestoreFocus: PropTypes.bool,\n /**\n * Returns an array of ordered tabbable nodes (i.e. in tab order) within the root.\n * For instance, you can provide the \"tabbable\" npm dependency.\n * @param {HTMLElement} root\n */\n getTabbable: PropTypes.func,\n /**\n * This prop extends the `open` prop.\n * It allows to toggle the open state without having to wait for a rerender when changing the `open` prop.\n * This prop should be memoized.\n * It can be used to support multiple focus trap mounted at the same time.\n * @default function defaultIsEnabled(): boolean {\n * return true;\n * }\n */\n isEnabled: PropTypes.func,\n /**\n * If `true`, focus is locked.\n */\n open: PropTypes.bool.isRequired\n} : void 0;\nif (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line\n FocusTrap['propTypes' + ''] = exactProp(FocusTrap.propTypes);\n}\nexport default FocusTrap;","import { unstable_ownerWindow as ownerWindow, unstable_ownerDocument as ownerDocument, unstable_getScrollbarSize as getScrollbarSize } from '@mui/utils';\n// Is a vertical scrollbar displayed?\nfunction isOverflowing(container) {\n const doc = ownerDocument(container);\n if (doc.body === container) {\n return ownerWindow(container).innerWidth > doc.documentElement.clientWidth;\n }\n return container.scrollHeight > container.clientHeight;\n}\nexport function ariaHidden(element, show) {\n if (show) {\n element.setAttribute('aria-hidden', 'true');\n } else {\n element.removeAttribute('aria-hidden');\n }\n}\nfunction getPaddingRight(element) {\n return parseInt(ownerWindow(element).getComputedStyle(element).paddingRight, 10) || 0;\n}\nfunction isAriaHiddenForbiddenOnElement(element) {\n // The forbidden HTML tags are the ones from ARIA specification that\n // can be children of body and can't have aria-hidden attribute.\n // cf. https://www.w3.org/TR/html-aria/#docconformance\n const forbiddenTagNames = ['TEMPLATE', 'SCRIPT', 'STYLE', 'LINK', 'MAP', 'META', 'NOSCRIPT', 'PICTURE', 'COL', 'COLGROUP', 'PARAM', 'SLOT', 'SOURCE', 'TRACK'];\n const isForbiddenTagName = forbiddenTagNames.indexOf(element.tagName) !== -1;\n const isInputHidden = element.tagName === 'INPUT' && element.getAttribute('type') === 'hidden';\n return isForbiddenTagName || isInputHidden;\n}\nfunction ariaHiddenSiblings(container, mountElement, currentElement, elementsToExclude, show) {\n const blacklist = [mountElement, currentElement, ...elementsToExclude];\n [].forEach.call(container.children, element => {\n const isNotExcludedElement = blacklist.indexOf(element) === -1;\n const isNotForbiddenElement = !isAriaHiddenForbiddenOnElement(element);\n if (isNotExcludedElement && isNotForbiddenElement) {\n ariaHidden(element, show);\n }\n });\n}\nfunction findIndexOf(items, callback) {\n let idx = -1;\n items.some((item, index) => {\n if (callback(item)) {\n idx = index;\n return true;\n }\n return false;\n });\n return idx;\n}\nfunction handleContainer(containerInfo, props) {\n const restoreStyle = [];\n const container = containerInfo.container;\n if (!props.disableScrollLock) {\n if (isOverflowing(container)) {\n // Compute the size before applying overflow hidden to avoid any scroll jumps.\n const scrollbarSize = getScrollbarSize(ownerDocument(container));\n restoreStyle.push({\n value: container.style.paddingRight,\n property: 'padding-right',\n el: container\n });\n // Use computed style, here to get the real padding to add our scrollbar width.\n container.style.paddingRight = `${getPaddingRight(container) + scrollbarSize}px`;\n\n // .mui-fixed is a global helper.\n const fixedElements = ownerDocument(container).querySelectorAll('.mui-fixed');\n [].forEach.call(fixedElements, element => {\n restoreStyle.push({\n value: element.style.paddingRight,\n property: 'padding-right',\n el: element\n });\n element.style.paddingRight = `${getPaddingRight(element) + scrollbarSize}px`;\n });\n }\n let scrollContainer;\n if (container.parentNode instanceof DocumentFragment) {\n scrollContainer = ownerDocument(container).body;\n } else {\n // Support html overflow-y: auto for scroll stability between pages\n // https://css-tricks.com/snippets/css/force-vertical-scrollbar/\n const parent = container.parentElement;\n const containerWindow = ownerWindow(container);\n scrollContainer = (parent == null ? void 0 : parent.nodeName) === 'HTML' && containerWindow.getComputedStyle(parent).overflowY === 'scroll' ? parent : container;\n }\n\n // Block the scroll even if no scrollbar is visible to account for mobile keyboard\n // screensize shrink.\n restoreStyle.push({\n value: scrollContainer.style.overflow,\n property: 'overflow',\n el: scrollContainer\n }, {\n value: scrollContainer.style.overflowX,\n property: 'overflow-x',\n el: scrollContainer\n }, {\n value: scrollContainer.style.overflowY,\n property: 'overflow-y',\n el: scrollContainer\n });\n scrollContainer.style.overflow = 'hidden';\n }\n const restore = () => {\n restoreStyle.forEach(({\n value,\n el,\n property\n }) => {\n if (value) {\n el.style.setProperty(property, value);\n } else {\n el.style.removeProperty(property);\n }\n });\n };\n return restore;\n}\nfunction getHiddenSiblings(container) {\n const hiddenSiblings = [];\n [].forEach.call(container.children, element => {\n if (element.getAttribute('aria-hidden') === 'true') {\n hiddenSiblings.push(element);\n }\n });\n return hiddenSiblings;\n}\n/**\n * @ignore - do not document.\n *\n * Proper state management for containers and the modals in those containers.\n * Simplified, but inspired by react-overlay's ModalManager class.\n * Used by the Modal to ensure proper styling of containers.\n */\nexport class ModalManager {\n constructor() {\n this.containers = void 0;\n this.modals = void 0;\n this.modals = [];\n this.containers = [];\n }\n add(modal, container) {\n let modalIndex = this.modals.indexOf(modal);\n if (modalIndex !== -1) {\n return modalIndex;\n }\n modalIndex = this.modals.length;\n this.modals.push(modal);\n\n // If the modal we are adding is already in the DOM.\n if (modal.modalRef) {\n ariaHidden(modal.modalRef, false);\n }\n const hiddenSiblings = getHiddenSiblings(container);\n ariaHiddenSiblings(container, modal.mount, modal.modalRef, hiddenSiblings, true);\n const containerIndex = findIndexOf(this.containers, item => item.container === container);\n if (containerIndex !== -1) {\n this.containers[containerIndex].modals.push(modal);\n return modalIndex;\n }\n this.containers.push({\n modals: [modal],\n container,\n restore: null,\n hiddenSiblings\n });\n return modalIndex;\n }\n mount(modal, props) {\n const containerIndex = findIndexOf(this.containers, item => item.modals.indexOf(modal) !== -1);\n const containerInfo = this.containers[containerIndex];\n if (!containerInfo.restore) {\n containerInfo.restore = handleContainer(containerInfo, props);\n }\n }\n remove(modal, ariaHiddenState = true) {\n const modalIndex = this.modals.indexOf(modal);\n if (modalIndex === -1) {\n return modalIndex;\n }\n const containerIndex = findIndexOf(this.containers, item => item.modals.indexOf(modal) !== -1);\n const containerInfo = this.containers[containerIndex];\n containerInfo.modals.splice(containerInfo.modals.indexOf(modal), 1);\n this.modals.splice(modalIndex, 1);\n\n // If that was the last modal in a container, clean up the container.\n if (containerInfo.modals.length === 0) {\n // The modal might be closed before it had the chance to be mounted in the DOM.\n if (containerInfo.restore) {\n containerInfo.restore();\n }\n if (modal.modalRef) {\n // In case the modal wasn't in the DOM yet.\n ariaHidden(modal.modalRef, ariaHiddenState);\n }\n ariaHiddenSiblings(containerInfo.container, modal.mount, modal.modalRef, containerInfo.hiddenSiblings, false);\n this.containers.splice(containerIndex, 1);\n } else {\n // Otherwise make sure the next top modal is visible to a screen reader.\n const nextTop = containerInfo.modals[containerInfo.modals.length - 1];\n // as soon as a modal is adding its modalRef is undefined. it can't set\n // aria-hidden because the dom element doesn't exist either\n // when modal was unmounted before modalRef gets null\n if (nextTop.modalRef) {\n ariaHidden(nextTop.modalRef, false);\n }\n }\n return modalIndex;\n }\n isTopModal(modal) {\n return this.modals.length > 0 && this.modals[this.modals.length - 1] === modal;\n }\n}","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport { unstable_ownerDocument as ownerDocument, unstable_useForkRef as useForkRef, unstable_useEventCallback as useEventCallback, unstable_createChainedFunction as createChainedFunction } from '@mui/utils';\nimport extractEventHandlers from '@mui/utils/extractEventHandlers';\nimport { ModalManager, ariaHidden } from './ModalManager';\nfunction getContainer(container) {\n return typeof container === 'function' ? container() : container;\n}\nfunction getHasTransition(children) {\n return children ? children.props.hasOwnProperty('in') : false;\n}\n\n// A modal manager used to track and manage the state of open Modals.\n// Modals don't open on the server so this won't conflict with concurrent requests.\nconst defaultManager = new ModalManager();\n/**\n *\n * Demos:\n *\n * - [Modal](https://mui.com/base-ui/react-modal/#hook)\n *\n * API:\n *\n * - [useModal API](https://mui.com/base-ui/react-modal/hooks-api/#use-modal)\n */\nfunction useModal(parameters) {\n const {\n container,\n disableEscapeKeyDown = false,\n disableScrollLock = false,\n // @ts-ignore internal logic - Base UI supports the manager as a prop too\n manager = defaultManager,\n closeAfterTransition = false,\n onTransitionEnter,\n onTransitionExited,\n children,\n onClose,\n open,\n rootRef\n } = parameters;\n\n // @ts-ignore internal logic\n const modal = React.useRef({});\n const mountNodeRef = React.useRef(null);\n const modalRef = React.useRef(null);\n const handleRef = useForkRef(modalRef, rootRef);\n const [exited, setExited] = React.useState(!open);\n const hasTransition = getHasTransition(children);\n let ariaHiddenProp = true;\n if (parameters['aria-hidden'] === 'false' || parameters['aria-hidden'] === false) {\n ariaHiddenProp = false;\n }\n const getDoc = () => ownerDocument(mountNodeRef.current);\n const getModal = () => {\n modal.current.modalRef = modalRef.current;\n modal.current.mount = mountNodeRef.current;\n return modal.current;\n };\n const handleMounted = () => {\n manager.mount(getModal(), {\n disableScrollLock\n });\n\n // Fix a bug on Chrome where the scroll isn't initially 0.\n if (modalRef.current) {\n modalRef.current.scrollTop = 0;\n }\n };\n const handleOpen = useEventCallback(() => {\n const resolvedContainer = getContainer(container) || getDoc().body;\n manager.add(getModal(), resolvedContainer);\n\n // The element was already mounted.\n if (modalRef.current) {\n handleMounted();\n }\n });\n const isTopModal = React.useCallback(() => manager.isTopModal(getModal()), [manager]);\n const handlePortalRef = useEventCallback(node => {\n mountNodeRef.current = node;\n if (!node) {\n return;\n }\n if (open && isTopModal()) {\n handleMounted();\n } else if (modalRef.current) {\n ariaHidden(modalRef.current, ariaHiddenProp);\n }\n });\n const handleClose = React.useCallback(() => {\n manager.remove(getModal(), ariaHiddenProp);\n }, [ariaHiddenProp, manager]);\n React.useEffect(() => {\n return () => {\n handleClose();\n };\n }, [handleClose]);\n React.useEffect(() => {\n if (open) {\n handleOpen();\n } else if (!hasTransition || !closeAfterTransition) {\n handleClose();\n }\n }, [open, handleClose, hasTransition, closeAfterTransition, handleOpen]);\n const createHandleKeyDown = otherHandlers => event => {\n var _otherHandlers$onKeyD;\n (_otherHandlers$onKeyD = otherHandlers.onKeyDown) == null || _otherHandlers$onKeyD.call(otherHandlers, event);\n\n // The handler doesn't take event.defaultPrevented into account:\n //\n // event.preventDefault() is meant to stop default behaviors like\n // clicking a checkbox to check it, hitting a button to submit a form,\n // and hitting left arrow to move the cursor in a text input etc.\n // Only special HTML elements have these default behaviors.\n if (event.key !== 'Escape' || event.which === 229 ||\n // Wait until IME is settled.\n !isTopModal()) {\n return;\n }\n if (!disableEscapeKeyDown) {\n // Swallow the event, in case someone is listening for the escape key on the body.\n event.stopPropagation();\n if (onClose) {\n onClose(event, 'escapeKeyDown');\n }\n }\n };\n const createHandleBackdropClick = otherHandlers => event => {\n var _otherHandlers$onClic;\n (_otherHandlers$onClic = otherHandlers.onClick) == null || _otherHandlers$onClic.call(otherHandlers, event);\n if (event.target !== event.currentTarget) {\n return;\n }\n if (onClose) {\n onClose(event, 'backdropClick');\n }\n };\n const getRootProps = (otherHandlers = {}) => {\n const propsEventHandlers = extractEventHandlers(parameters);\n\n // The custom event handlers shouldn't be spread on the root element\n delete propsEventHandlers.onTransitionEnter;\n delete propsEventHandlers.onTransitionExited;\n const externalEventHandlers = _extends({}, propsEventHandlers, otherHandlers);\n return _extends({\n role: 'presentation'\n }, externalEventHandlers, {\n onKeyDown: createHandleKeyDown(externalEventHandlers),\n ref: handleRef\n });\n };\n const getBackdropProps = (otherHandlers = {}) => {\n const externalEventHandlers = otherHandlers;\n return _extends({\n 'aria-hidden': true\n }, externalEventHandlers, {\n onClick: createHandleBackdropClick(externalEventHandlers),\n open\n });\n };\n const getTransitionProps = () => {\n const handleEnter = () => {\n setExited(false);\n if (onTransitionEnter) {\n onTransitionEnter();\n }\n };\n const handleExited = () => {\n setExited(true);\n if (onTransitionExited) {\n onTransitionExited();\n }\n if (closeAfterTransition) {\n handleClose();\n }\n };\n return {\n onEnter: createChainedFunction(handleEnter, children == null ? void 0 : children.props.onEnter),\n onExited: createChainedFunction(handleExited, children == null ? void 0 : children.props.onExited)\n };\n };\n return {\n getRootProps,\n getBackdropProps,\n getTransitionProps,\n rootRef: handleRef,\n portalRef: handlePortalRef,\n isTopModal,\n exited,\n hasTransition\n };\n}\nexport default useModal;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getModalUtilityClass(slot) {\n return generateUtilityClass('MuiModal', slot);\n}\nconst modalClasses = generateUtilityClasses('MuiModal', ['root', 'hidden', 'backdrop']);\nexport default modalClasses;","'use client';\n\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nconst _excluded = [\"BackdropComponent\", \"BackdropProps\", \"classes\", \"className\", \"closeAfterTransition\", \"children\", \"container\", \"component\", \"components\", \"componentsProps\", \"disableAutoFocus\", \"disableEnforceFocus\", \"disableEscapeKeyDown\", \"disablePortal\", \"disableRestoreFocus\", \"disableScrollLock\", \"hideBackdrop\", \"keepMounted\", \"onBackdropClick\", \"onClose\", \"onTransitionEnter\", \"onTransitionExited\", \"open\", \"slotProps\", \"slots\", \"theme\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport HTMLElementType from '@mui/utils/HTMLElementType';\nimport elementAcceptingRef from '@mui/utils/elementAcceptingRef';\nimport composeClasses from '@mui/utils/composeClasses';\nimport useSlotProps from '@mui/utils/useSlotProps';\nimport FocusTrap from '../Unstable_TrapFocus';\nimport Portal from '../Portal';\nimport styled from '../styles/styled';\nimport { useDefaultProps } from '../DefaultPropsProvider';\nimport Backdrop from '../Backdrop';\nimport useModal from './useModal';\nimport { getModalUtilityClass } from './modalClasses';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n open,\n exited,\n classes\n } = ownerState;\n const slots = {\n root: ['root', !open && exited && 'hidden'],\n backdrop: ['backdrop']\n };\n return composeClasses(slots, getModalUtilityClass, classes);\n};\nconst ModalRoot = styled('div', {\n name: 'MuiModal',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, !ownerState.open && ownerState.exited && styles.hidden];\n }\n})(({\n theme,\n ownerState\n}) => _extends({\n position: 'fixed',\n zIndex: (theme.vars || theme).zIndex.modal,\n right: 0,\n bottom: 0,\n top: 0,\n left: 0\n}, !ownerState.open && ownerState.exited && {\n visibility: 'hidden'\n}));\nconst ModalBackdrop = styled(Backdrop, {\n name: 'MuiModal',\n slot: 'Backdrop',\n overridesResolver: (props, styles) => {\n return styles.backdrop;\n }\n})({\n zIndex: -1\n});\n\n/**\n * Modal is a lower-level construct that is leveraged by the following components:\n *\n * - [Dialog](/material-ui/api/dialog/)\n * - [Drawer](/material-ui/api/drawer/)\n * - [Menu](/material-ui/api/menu/)\n * - [Popover](/material-ui/api/popover/)\n *\n * If you are creating a modal dialog, you probably want to use the [Dialog](/material-ui/api/dialog/) component\n * rather than directly using Modal.\n *\n * This component shares many concepts with [react-overlays](https://react-bootstrap.github.io/react-overlays/#modals).\n */\nconst Modal = /*#__PURE__*/React.forwardRef(function Modal(inProps, ref) {\n var _ref, _slots$root, _ref2, _slots$backdrop, _slotProps$root, _slotProps$backdrop;\n const props = useDefaultProps({\n name: 'MuiModal',\n props: inProps\n });\n const {\n BackdropComponent = ModalBackdrop,\n BackdropProps,\n className,\n closeAfterTransition = false,\n children,\n container,\n component,\n components = {},\n componentsProps = {},\n disableAutoFocus = false,\n disableEnforceFocus = false,\n disableEscapeKeyDown = false,\n disablePortal = false,\n disableRestoreFocus = false,\n disableScrollLock = false,\n hideBackdrop = false,\n keepMounted = false,\n onBackdropClick,\n open,\n slotProps,\n slots\n // eslint-disable-next-line react/prop-types\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const propsWithDefaults = _extends({}, props, {\n closeAfterTransition,\n disableAutoFocus,\n disableEnforceFocus,\n disableEscapeKeyDown,\n disablePortal,\n disableRestoreFocus,\n disableScrollLock,\n hideBackdrop,\n keepMounted\n });\n const {\n getRootProps,\n getBackdropProps,\n getTransitionProps,\n portalRef,\n isTopModal,\n exited,\n hasTransition\n } = useModal(_extends({}, propsWithDefaults, {\n rootRef: ref\n }));\n const ownerState = _extends({}, propsWithDefaults, {\n exited\n });\n const classes = useUtilityClasses(ownerState);\n const childProps = {};\n if (children.props.tabIndex === undefined) {\n childProps.tabIndex = '-1';\n }\n\n // It's a Transition like component\n if (hasTransition) {\n const {\n onEnter,\n onExited\n } = getTransitionProps();\n childProps.onEnter = onEnter;\n childProps.onExited = onExited;\n }\n const RootSlot = (_ref = (_slots$root = slots == null ? void 0 : slots.root) != null ? _slots$root : components.Root) != null ? _ref : ModalRoot;\n const BackdropSlot = (_ref2 = (_slots$backdrop = slots == null ? void 0 : slots.backdrop) != null ? _slots$backdrop : components.Backdrop) != null ? _ref2 : BackdropComponent;\n const rootSlotProps = (_slotProps$root = slotProps == null ? void 0 : slotProps.root) != null ? _slotProps$root : componentsProps.root;\n const backdropSlotProps = (_slotProps$backdrop = slotProps == null ? void 0 : slotProps.backdrop) != null ? _slotProps$backdrop : componentsProps.backdrop;\n const rootProps = useSlotProps({\n elementType: RootSlot,\n externalSlotProps: rootSlotProps,\n externalForwardedProps: other,\n getSlotProps: getRootProps,\n additionalProps: {\n ref,\n as: component\n },\n ownerState,\n className: clsx(className, rootSlotProps == null ? void 0 : rootSlotProps.className, classes == null ? void 0 : classes.root, !ownerState.open && ownerState.exited && (classes == null ? void 0 : classes.hidden))\n });\n const backdropProps = useSlotProps({\n elementType: BackdropSlot,\n externalSlotProps: backdropSlotProps,\n additionalProps: BackdropProps,\n getSlotProps: otherHandlers => {\n return getBackdropProps(_extends({}, otherHandlers, {\n onClick: e => {\n if (onBackdropClick) {\n onBackdropClick(e);\n }\n if (otherHandlers != null && otherHandlers.onClick) {\n otherHandlers.onClick(e);\n }\n }\n }));\n },\n className: clsx(backdropSlotProps == null ? void 0 : backdropSlotProps.className, BackdropProps == null ? void 0 : BackdropProps.className, classes == null ? void 0 : classes.backdrop),\n ownerState\n });\n if (!keepMounted && !open && (!hasTransition || exited)) {\n return null;\n }\n return /*#__PURE__*/_jsx(Portal, {\n ref: portalRef,\n container: container,\n disablePortal: disablePortal,\n children: /*#__PURE__*/_jsxs(RootSlot, _extends({}, rootProps, {\n children: [!hideBackdrop && BackdropComponent ? /*#__PURE__*/_jsx(BackdropSlot, _extends({}, backdropProps)) : null, /*#__PURE__*/_jsx(FocusTrap, {\n disableEnforceFocus: disableEnforceFocus,\n disableAutoFocus: disableAutoFocus,\n disableRestoreFocus: disableRestoreFocus,\n isEnabled: isTopModal,\n open: open,\n children: /*#__PURE__*/React.cloneElement(children, childProps)\n })]\n }))\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Modal.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * A backdrop component. This prop enables custom backdrop rendering.\n * @deprecated Use `slots.backdrop` instead. While this prop currently works, it will be removed in the next major version.\n * Use the `slots.backdrop` prop to make your application ready for the next version of Material UI.\n * @default styled(Backdrop, {\n * name: 'MuiModal',\n * slot: 'Backdrop',\n * overridesResolver: (props, styles) => {\n * return styles.backdrop;\n * },\n * })({\n * zIndex: -1,\n * })\n */\n BackdropComponent: PropTypes.elementType,\n /**\n * Props applied to the [`Backdrop`](/material-ui/api/backdrop/) element.\n * @deprecated Use `slotProps.backdrop` instead.\n */\n BackdropProps: PropTypes.object,\n /**\n * A single child content element.\n */\n children: elementAcceptingRef.isRequired,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * When set to true the Modal waits until a nested Transition is completed before closing.\n * @default false\n */\n closeAfterTransition: PropTypes.bool,\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.elementType,\n /**\n * The components used for each slot inside.\n *\n * This prop is an alias for the `slots` prop.\n * It's recommended to use the `slots` prop instead.\n *\n * @default {}\n */\n components: PropTypes.shape({\n Backdrop: PropTypes.elementType,\n Root: PropTypes.elementType\n }),\n /**\n * The extra props for the slot components.\n * You can override the existing props or add new ones.\n *\n * This prop is an alias for the `slotProps` prop.\n * It's recommended to use the `slotProps` prop instead, as `componentsProps` will be deprecated in the future.\n *\n * @default {}\n */\n componentsProps: PropTypes.shape({\n backdrop: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n root: PropTypes.oneOfType([PropTypes.func, PropTypes.object])\n }),\n /**\n * An HTML element or function that returns one.\n * The `container` will have the portal children appended to it.\n *\n * You can also provide a callback, which is called in a React layout effect.\n * This lets you set the container from a ref, and also makes server-side rendering possible.\n *\n * By default, it uses the body of the top-level document object,\n * so it's simply `document.body` most of the time.\n */\n container: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([HTMLElementType, PropTypes.func]),\n /**\n * If `true`, the modal will not automatically shift focus to itself when it opens, and\n * replace it to the last focused element when it closes.\n * This also works correctly with any modal children that have the `disableAutoFocus` prop.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n * @default false\n */\n disableAutoFocus: PropTypes.bool,\n /**\n * If `true`, the modal will not prevent focus from leaving the modal while open.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n * @default false\n */\n disableEnforceFocus: PropTypes.bool,\n /**\n * If `true`, hitting escape will not fire the `onClose` callback.\n * @default false\n */\n disableEscapeKeyDown: PropTypes.bool,\n /**\n * The `children` will be under the DOM hierarchy of the parent component.\n * @default false\n */\n disablePortal: PropTypes.bool,\n /**\n * If `true`, the modal will not restore focus to previously focused element once\n * modal is hidden or unmounted.\n * @default false\n */\n disableRestoreFocus: PropTypes.bool,\n /**\n * Disable the scroll lock behavior.\n * @default false\n */\n disableScrollLock: PropTypes.bool,\n /**\n * If `true`, the backdrop is not rendered.\n * @default false\n */\n hideBackdrop: PropTypes.bool,\n /**\n * Always keep the children in the DOM.\n * This prop can be useful in SEO situation or\n * when you want to maximize the responsiveness of the Modal.\n * @default false\n */\n keepMounted: PropTypes.bool,\n /**\n * Callback fired when the backdrop is clicked.\n * @deprecated Use the `onClose` prop with the `reason` argument to handle the `backdropClick` events.\n */\n onBackdropClick: PropTypes.func,\n /**\n * Callback fired when the component requests to be closed.\n * The `reason` parameter can optionally be used to control the response to `onClose`.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`.\n */\n onClose: PropTypes.func,\n /**\n * A function called when a transition enters.\n */\n onTransitionEnter: PropTypes.func,\n /**\n * A function called when a transition has exited.\n */\n onTransitionExited: PropTypes.func,\n /**\n * If `true`, the component is shown.\n */\n open: PropTypes.bool.isRequired,\n /**\n * The props used for each slot inside the Modal.\n * @default {}\n */\n slotProps: PropTypes.shape({\n backdrop: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n root: PropTypes.oneOfType([PropTypes.func, PropTypes.object])\n }),\n /**\n * The components used for each slot inside the Modal.\n * Either a string to use a HTML element or a component.\n * @default {}\n */\n slots: PropTypes.shape({\n backdrop: PropTypes.elementType,\n root: PropTypes.elementType\n }),\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object])\n} : void 0;\nexport default Modal;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getBackdropUtilityClass(slot) {\n return generateUtilityClass('MuiBackdrop', slot);\n}\nconst backdropClasses = generateUtilityClasses('MuiBackdrop', ['root', 'invisible']);\nexport default backdropClasses;","'use client';\n\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nconst _excluded = [\"children\", \"className\", \"component\", \"components\", \"componentsProps\", \"invisible\", \"open\", \"slotProps\", \"slots\", \"TransitionComponent\", \"transitionDuration\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport composeClasses from '@mui/utils/composeClasses';\nimport styled from '../styles/styled';\nimport { useDefaultProps } from '../DefaultPropsProvider';\nimport Fade from '../Fade';\nimport { getBackdropUtilityClass } from './backdropClasses';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n classes,\n invisible\n } = ownerState;\n const slots = {\n root: ['root', invisible && 'invisible']\n };\n return composeClasses(slots, getBackdropUtilityClass, classes);\n};\nconst BackdropRoot = styled('div', {\n name: 'MuiBackdrop',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, ownerState.invisible && styles.invisible];\n }\n})(({\n ownerState\n}) => _extends({\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}, ownerState.invisible && {\n backgroundColor: 'transparent'\n}));\nconst Backdrop = /*#__PURE__*/React.forwardRef(function Backdrop(inProps, ref) {\n var _slotProps$root, _ref, _slots$root;\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiBackdrop'\n });\n const {\n children,\n className,\n component = 'div',\n components = {},\n componentsProps = {},\n invisible = false,\n open,\n slotProps = {},\n slots = {},\n TransitionComponent = Fade,\n transitionDuration\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const ownerState = _extends({}, props, {\n component,\n invisible\n });\n const classes = useUtilityClasses(ownerState);\n const rootSlotProps = (_slotProps$root = slotProps.root) != null ? _slotProps$root : componentsProps.root;\n return /*#__PURE__*/_jsx(TransitionComponent, _extends({\n in: open,\n timeout: transitionDuration\n }, other, {\n children: /*#__PURE__*/_jsx(BackdropRoot, _extends({\n \"aria-hidden\": true\n }, rootSlotProps, {\n as: (_ref = (_slots$root = slots.root) != null ? _slots$root : components.Root) != null ? _ref : component,\n className: clsx(classes.root, className, rootSlotProps == null ? void 0 : rootSlotProps.className),\n ownerState: _extends({}, ownerState, rootSlotProps == null ? void 0 : rootSlotProps.ownerState),\n classes: classes,\n ref: ref,\n children: children\n }))\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? Backdrop.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\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.elementType,\n /**\n * The components used for each slot inside.\n *\n * This prop is an alias for the `slots` prop.\n * It's recommended to use the `slots` prop instead.\n *\n * @default {}\n */\n components: PropTypes.shape({\n Root: PropTypes.elementType\n }),\n /**\n * The extra props for the slot components.\n * You can override the existing props or add new ones.\n *\n * This prop is an alias for the `slotProps` prop.\n * It's recommended to use the `slotProps` prop instead, as `componentsProps` will be deprecated in the future.\n *\n * @default {}\n */\n componentsProps: PropTypes.shape({\n root: PropTypes.object\n }),\n /**\n * If `true`, the backdrop is invisible.\n * It can be used when rendering a popover or a custom select component.\n * @default false\n */\n invisible: PropTypes.bool,\n /**\n * If `true`, the component is shown.\n */\n open: PropTypes.bool.isRequired,\n /**\n * The extra props for the slot components.\n * You can override the existing props or add new ones.\n *\n * This prop is an alias for the `componentsProps` prop, which will be deprecated in the future.\n *\n * @default {}\n */\n slotProps: PropTypes.shape({\n root: PropTypes.object\n }),\n /**\n * The components used for each slot inside.\n *\n * This prop is an alias for the `components` prop, which will be deprecated in the future.\n *\n * @default {}\n */\n slots: PropTypes.shape({\n root: PropTypes.elementType\n }),\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * The component used for the transition.\n * [Follow this guide](/material-ui/transitions/#transitioncomponent-prop) to learn more about the requirements for this component.\n * @default Fade\n */\n TransitionComponent: PropTypes.elementType,\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 Backdrop;"],"sourceRoot":""}