{"version":3,"sources":["../node_modules/@material-ui/lab/esm/SpeedDial/SpeedDial.js","../node_modules/@material-ui/lab/esm/SpeedDialIcon/SpeedDialIcon.js","../node_modules/@material-ui/lab/esm/TabList/TabList.js","../node_modules/@material-ui/lab/esm/TabContext/TabContext.js","../node_modules/@material-ui/lab/esm/SpeedDialAction/SpeedDialAction.js","../node_modules/@material-ui/lab/esm/TreeItem/TreeItem.js","../node_modules/@material-ui/lab/esm/TabPanel/TabPanel.js"],"names":["getOrientation","direction","SpeedDial","React","props","ref","ariaLabel","_props$FabProps","FabProps","origDialButtonRef","_objectWithoutProperties","childrenProp","children","classes","className","_props$direction","_props$hidden","hidden","icon","onBlur","onClose","onFocus","onKeyDown","onMouseEnter","onMouseLeave","onOpen","open","_props$TransitionComp","openIcon","TransitionComponent","Zoom","_props$transitionDura","transitionDuration","enter","duration","enteringScreen","exit","leavingScreen","TransitionProps","other","eventTimer","clearTimeout","current","focusedAction","nextItemArrowKey","actions","handleOwnFabRef","fabFef","handleFabRef","useForkRef","createHandleSpeedDialActionButtonRef","dialActionIndex","origButtonRef","buttonRef","undefined","handleClose","event","type","persist","setTimeout","handleOpen","focus","mouseenter","id","replace","allItems","toArray","filter","child","map","index","_child$props$FabProps","ChildFabProps","_extends","delay","length","concat","clsx","root","capitalize","role","value","min","max","key","toLowerCase","_nextItemArrowKey$cur","nextItemArrowKeyCurrent","preventDefault","actionStep","nextAction","in","timeout","unmountOnExit","Fab","color","onClick","fab","isMuiElement","actionsClosed","withStyles","theme","zIndex","speedDial","display","alignItems","pointerEvents","directionUp","flexDirection","marginBottom","paddingBottom","spacingActions","directionDown","marginTop","paddingTop","directionLeft","marginRight","paddingRight","directionRight","marginLeft","paddingLeft","transition","name","SpeedDialIcon","iconProp","openIconProp","iconClassName","iconOpen","iconWithOpenIconOpen","openIconClassName","openIconOpen","formatIcon","newClassName","AddIcon","muiName","height","transitions","create","short","transform","opacity","position","TabList","context","useTabContext","TypeError","getPanelId","getTabId","Tabs","Context","TabContext","idPrefix","_React$useState","setId","Math","round","random","useUniquePrefix","Provider","SpeedDialAction","_props$delay","TooltipClasses","_props$tooltipOpen","tooltipOpen","tooltipOpenProp","_props$tooltipPlaceme","tooltipPlacement","tooltipTitle","setTooltipOpen","transitionStyle","transitionDelay","size","fabClosed","tabIndex","style","staticTooltip","staticTooltipClosed","staticTooltipLabel","Tooltip","title","placement","margin","palette","text","secondary","backgroundColor","background","paper","emphasize","shorter","typography","body1","borderRadius","shape","boxShadow","shadows","padding","wordBreak","tooltipPlacementLeft","transformOrigin","right","tooltipPlacementRight","left","TreeItem","collapseIcon","endIcon","expandIcon","label","nodeId","onLabelClick","onIconClick","onMouseDown","Collapse","_React$useContext","TreeViewContext","contextIcons","icons","focusFirstNode","focusLastNode","focusNextNode","focusPreviousNode","focusByFirstCharacter","selectNode","selectRange","selectNextNode","selectPreviousNode","rangeSelectToFirst","rangeSelectToLast","selectAllNodes","expandAllSiblings","toggleExpansion","isExpanded","isFocused","isSelected","isTabbable","multiSelect","getParent","mapFirstChar","addNodeToNodeMap","removeNodeFromNodeMap","nodeRef","contentRef","handleRef","expandable","Boolean","Array","isArray","expanded","focused","tabbable","selected","useTheme","defaultCollapseIcon","defaultExpandIcon","defaultParentIcon","defaultEndIcon","ariaSelected","handleNextArrow","handlePreviousArrow","parent","childIds","forEach","push","textContent","substring","flag","altKey","currentTarget","target","str","ctrlPressed","ctrlKey","metaKey","shiftKey","end","stopPropagation","match","content","multiple","defaultPrevented","iconContainer","Typography","component","group","listStyle","outline","WebkitTapHighlightColor","action","hover","fade","primary","main","selectedOpacity","hoverOpacity","width","cursor","flexShrink","justifyContent","fontSize","TabPanel","tabId","spacing"],"mappings":"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","file":"static/js/main~66471083.7a1a8c90.chunk.js","sourcesContent":["import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { duration, withStyles } from '@material-ui/core/styles';\nimport Zoom from '@material-ui/core/Zoom';\nimport Fab from '@material-ui/core/Fab';\nimport { capitalize, isMuiElement, useForkRef } from '@material-ui/core/utils';\n\nfunction getOrientation(direction) {\n if (direction === 'up' || direction === 'down') {\n return 'vertical';\n }\n\n if (direction === 'right' || direction === 'left') {\n return 'horizontal';\n }\n\n return undefined;\n}\n\nfunction clamp(value, min, max) {\n if (value < min) {\n return min;\n }\n\n if (value > max) {\n return max;\n }\n\n return value;\n}\n\nvar dialRadius = 32;\nvar spacingActions = 16;\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n zIndex: theme.zIndex.speedDial,\n display: 'flex',\n alignItems: 'center',\n pointerEvents: 'none'\n },\n\n /* Styles applied to the Fab component. */\n fab: {\n pointerEvents: 'auto'\n },\n\n /* Styles applied to the root if direction=\"up\" */\n directionUp: {\n flexDirection: 'column-reverse',\n '& $actions': {\n flexDirection: 'column-reverse',\n marginBottom: -dialRadius,\n paddingBottom: spacingActions + dialRadius\n }\n },\n\n /* Styles applied to the root if direction=\"down\" */\n directionDown: {\n flexDirection: 'column',\n '& $actions': {\n flexDirection: 'column',\n marginTop: -dialRadius,\n paddingTop: spacingActions + dialRadius\n }\n },\n\n /* Styles applied to the root if direction=\"left\" */\n directionLeft: {\n flexDirection: 'row-reverse',\n '& $actions': {\n flexDirection: 'row-reverse',\n marginRight: -dialRadius,\n paddingRight: spacingActions + dialRadius\n }\n },\n\n /* Styles applied to the root if direction=\"right\" */\n directionRight: {\n flexDirection: 'row',\n '& $actions': {\n flexDirection: 'row',\n marginLeft: -dialRadius,\n paddingLeft: spacingActions + dialRadius\n }\n },\n\n /* Styles applied to the actions (`children` wrapper) element. */\n actions: {\n display: 'flex',\n pointerEvents: 'auto'\n },\n\n /* Styles applied to the actions (`children` wrapper) element if `open={false}`. */\n actionsClosed: {\n transition: 'top 0s linear 0.2s',\n pointerEvents: 'none'\n }\n };\n};\nvar SpeedDial = /*#__PURE__*/React.forwardRef(function SpeedDial(props, ref) {\n var ariaLabel = props.ariaLabel,\n _props$FabProps = props.FabProps;\n _props$FabProps = _props$FabProps === void 0 ? {} : _props$FabProps;\n\n var origDialButtonRef = _props$FabProps.ref,\n FabProps = _objectWithoutProperties(_props$FabProps, [\"ref\"]),\n childrenProp = props.children,\n classes = props.classes,\n className = props.className,\n _props$direction = props.direction,\n direction = _props$direction === void 0 ? 'up' : _props$direction,\n _props$hidden = props.hidden,\n hidden = _props$hidden === void 0 ? false : _props$hidden,\n icon = props.icon,\n onBlur = props.onBlur,\n onClose = props.onClose,\n onFocus = props.onFocus,\n onKeyDown = props.onKeyDown,\n onMouseEnter = props.onMouseEnter,\n onMouseLeave = props.onMouseLeave,\n onOpen = props.onOpen,\n open = props.open,\n openIcon = props.openIcon,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Zoom : _props$TransitionComp,\n _props$transitionDura = props.transitionDuration,\n transitionDuration = _props$transitionDura === void 0 ? {\n enter: duration.enteringScreen,\n exit: duration.leavingScreen\n } : _props$transitionDura,\n TransitionProps = props.TransitionProps,\n other = _objectWithoutProperties(props, [\"ariaLabel\", \"FabProps\", \"children\", \"classes\", \"className\", \"direction\", \"hidden\", \"icon\", \"onBlur\", \"onClose\", \"onFocus\", \"onKeyDown\", \"onMouseEnter\", \"onMouseLeave\", \"onOpen\", \"open\", \"openIcon\", \"TransitionComponent\", \"transitionDuration\", \"TransitionProps\"]);\n\n var eventTimer = React.useRef();\n React.useEffect(function () {\n return function () {\n clearTimeout(eventTimer.current);\n };\n }, []);\n /**\n * an index in actions.current\n */\n\n var focusedAction = React.useRef(0);\n /**\n * pressing this key while the focus is on a child SpeedDialAction focuses\n * the next SpeedDialAction.\n * It is equal to the first arrow key pressed while focus is on the SpeedDial\n * that is not orthogonal to the direction.\n * @type {utils.ArrowKey?}\n */\n\n var nextItemArrowKey = React.useRef();\n /**\n * refs to the Button that have an action associated to them in this SpeedDial\n * [Fab, ...(SpeedDialActions > Button)]\n * @type {HTMLButtonElement[]}\n */\n\n var actions = React.useRef([]);\n actions.current = [actions.current[0]];\n var handleOwnFabRef = React.useCallback(function (fabFef) {\n actions.current[0] = fabFef;\n }, []);\n var handleFabRef = useForkRef(origDialButtonRef, handleOwnFabRef);\n /**\n * creates a ref callback for the Button in a SpeedDialAction\n * Is called before the original ref callback for Button that was set in buttonProps\n *\n * @param dialActionIndex {number}\n * @param origButtonRef {React.RefObject?}\n */\n\n var createHandleSpeedDialActionButtonRef = function createHandleSpeedDialActionButtonRef(dialActionIndex, origButtonRef) {\n return function (buttonRef) {\n actions.current[dialActionIndex + 1] = buttonRef;\n\n if (origButtonRef) {\n origButtonRef(buttonRef);\n }\n };\n };\n\n var handleKeyDown = function handleKeyDown(event) {\n if (onKeyDown) {\n onKeyDown(event);\n }\n\n var key = event.key.replace('Arrow', '').toLowerCase();\n var _nextItemArrowKey$cur = nextItemArrowKey.current,\n nextItemArrowKeyCurrent = _nextItemArrowKey$cur === void 0 ? key : _nextItemArrowKey$cur;\n\n if (event.key === 'Escape') {\n if (onClose) {\n actions.current[0].focus();\n onClose(event, 'escapeKeyDown');\n }\n\n return;\n }\n\n if (getOrientation(key) === getOrientation(nextItemArrowKeyCurrent) && getOrientation(key) !== undefined) {\n event.preventDefault();\n var actionStep = key === nextItemArrowKeyCurrent ? 1 : -1; // stay within array indices\n\n var nextAction = clamp(focusedAction.current + actionStep, 0, actions.current.length - 1);\n actions.current[nextAction].focus();\n focusedAction.current = nextAction;\n nextItemArrowKey.current = nextItemArrowKeyCurrent;\n }\n };\n\n React.useEffect(function () {\n // actions were closed while navigation state was not reset\n if (!open) {\n focusedAction.current = 0;\n nextItemArrowKey.current = undefined;\n }\n }, [open]);\n\n var handleClose = function handleClose(event) {\n if (event.type === 'mouseleave' && onMouseLeave) {\n onMouseLeave(event);\n }\n\n if (event.type === 'blur' && onBlur) {\n onBlur(event);\n }\n\n clearTimeout(eventTimer.current);\n\n if (onClose) {\n if (event.type === 'blur') {\n event.persist();\n eventTimer.current = setTimeout(function () {\n onClose(event, 'blur');\n });\n } else {\n onClose(event, 'mouseLeave');\n }\n }\n };\n\n var handleClick = function handleClick(event) {\n if (FabProps.onClick) {\n FabProps.onClick(event);\n }\n\n clearTimeout(eventTimer.current);\n\n if (open) {\n if (onClose) {\n onClose(event, 'toggle');\n }\n } else if (onOpen) {\n onOpen(event, 'toggle');\n }\n };\n\n var handleOpen = function handleOpen(event) {\n if (event.type === 'mouseenter' && onMouseEnter) {\n onMouseEnter(event);\n }\n\n if (event.type === 'focus' && onFocus) {\n onFocus(event);\n } // When moving the focus between two items,\n // a chain if blur and focus event is triggered.\n // We only handle the last event.\n\n\n clearTimeout(eventTimer.current);\n\n if (onOpen && !open) {\n event.persist(); // Wait for a future focus or click event\n\n eventTimer.current = setTimeout(function () {\n var eventMap = {\n focus: 'focus',\n mouseenter: 'mouseEnter'\n };\n onOpen(event, eventMap[event.type]);\n });\n }\n }; // Filter the label for valid id characters.\n\n\n var id = ariaLabel.replace(/^[^a-z]+|[^\\w:.-]+/gi, '');\n var allItems = React.Children.toArray(childrenProp).filter(function (child) {\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: The SpeedDial component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n return /*#__PURE__*/React.isValidElement(child);\n });\n var children = allItems.map(function (child, index) {\n var _child$props$FabProps = child.props.FabProps;\n _child$props$FabProps = _child$props$FabProps === void 0 ? {} : _child$props$FabProps;\n\n var origButtonRef = _child$props$FabProps.ref,\n ChildFabProps = _objectWithoutProperties(_child$props$FabProps, [\"ref\"]);\n\n return /*#__PURE__*/React.cloneElement(child, {\n FabProps: _extends({}, ChildFabProps, {\n ref: createHandleSpeedDialActionButtonRef(index, origButtonRef)\n }),\n delay: 30 * (open ? index : allItems.length - index),\n open: open,\n id: \"\".concat(id, \"-action-\").concat(index)\n });\n });\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n className: clsx(classes.root, classes[\"direction\".concat(capitalize(direction))], className),\n ref: ref,\n role: \"presentation\",\n onKeyDown: handleKeyDown,\n onBlur: handleClose,\n onFocus: handleOpen,\n onMouseEnter: handleOpen,\n onMouseLeave: handleClose\n }, other), /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n in: !hidden,\n timeout: transitionDuration,\n unmountOnExit: true\n }, TransitionProps), /*#__PURE__*/React.createElement(Fab, _extends({\n color: \"primary\",\n \"aria-label\": ariaLabel,\n \"aria-haspopup\": \"true\",\n \"aria-expanded\": open,\n \"aria-controls\": \"\".concat(id, \"-actions\")\n }, FabProps, {\n onClick: handleClick,\n className: clsx(classes.fab, FabProps.className),\n ref: handleFabRef\n }), /*#__PURE__*/React.isValidElement(icon) && isMuiElement(icon, ['SpeedDialIcon']) ? /*#__PURE__*/React.cloneElement(icon, {\n open: open\n }) : icon)), /*#__PURE__*/React.createElement(\"div\", {\n id: \"\".concat(id, \"-actions\"),\n role: \"menu\",\n \"aria-orientation\": getOrientation(direction),\n className: clsx(classes.actions, !open && classes.actionsClosed)\n }, children));\n});\nprocess.env.NODE_ENV !== \"production\" ? SpeedDial.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 aria-label of the button element.\n * Also used to provide the `id` for the `SpeedDial` element and its children.\n */\n ariaLabel: PropTypes.string.isRequired,\n\n /**\n * SpeedDialActions to display when the SpeedDial is `open`.\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 direction the actions open relative to the floating action button.\n */\n direction: PropTypes.oneOf(['down', 'left', 'right', 'up']),\n\n /**\n * Props applied to the [`Fab`](/api/fab/) element.\n */\n FabProps: PropTypes.object,\n\n /**\n * If `true`, the SpeedDial will be hidden.\n */\n hidden: PropTypes.bool,\n\n /**\n * The icon to display in the SpeedDial Fab. The `SpeedDialIcon` component\n * provides a default Icon with animation.\n */\n icon: PropTypes.node,\n\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n\n /**\n * Callback fired when the component requests to be closed.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"toggle\"`, `\"blur\"`, `\"mouseLeave\"`, `\"escapeKeyDown\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseEnter: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseLeave: 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 * @param {string} reason Can be: `\"toggle\"`, `\"focus\"`, `\"mouseEnter\"`.\n */\n onOpen: PropTypes.func,\n\n /**\n * If `true`, the SpeedDial is open.\n */\n open: PropTypes.bool.isRequired,\n\n /**\n * The icon to display in the SpeedDial Fab when the SpeedDial is open.\n */\n openIcon: PropTypes.node,\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 * 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 * 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: 'MuiSpeedDial'\n})(SpeedDial);","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 '@material-ui/core/styles';\nimport AddIcon from '../internal/svg-icons/Add';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n height: 24\n },\n\n /* Styles applied to the icon component. */\n icon: {\n transition: theme.transitions.create(['transform', 'opacity'], {\n duration: theme.transitions.duration.short\n })\n },\n\n /* Styles applied to the icon component if `open={true}`. */\n iconOpen: {\n transform: 'rotate(45deg)'\n },\n\n /* Styles applied to the icon when and `openIcon` is provided and if `open={true}`. */\n iconWithOpenIconOpen: {\n opacity: 0\n },\n\n /* Styles applied to the `openIcon` if provided. */\n openIcon: {\n position: 'absolute',\n transition: theme.transitions.create(['transform', 'opacity'], {\n duration: theme.transitions.duration.short\n }),\n opacity: 0,\n transform: 'rotate(-45deg)'\n },\n\n /* Styles applied to the `openIcon` if provided and if `open={true}`. */\n openIconOpen: {\n transform: 'rotate(0deg)',\n opacity: 1\n }\n };\n};\nvar SpeedDialIcon = /*#__PURE__*/React.forwardRef(function SpeedDialIcon(props, ref) {\n var className = props.className,\n classes = props.classes,\n iconProp = props.icon,\n open = props.open,\n openIconProp = props.openIcon,\n other = _objectWithoutProperties(props, [\"className\", \"classes\", \"icon\", \"open\", \"openIcon\"]);\n\n var iconClassName = clsx(classes.icon, open && [classes.iconOpen, openIconProp && classes.iconWithOpenIconOpen]);\n var openIconClassName = clsx(classes.openIcon, open && classes.openIconOpen);\n\n function formatIcon(icon, newClassName) {\n if ( /*#__PURE__*/React.isValidElement(icon)) {\n return /*#__PURE__*/React.cloneElement(icon, {\n className: newClassName\n });\n }\n\n return icon;\n }\n\n return /*#__PURE__*/React.createElement(\"span\", _extends({\n className: clsx(classes.root, className),\n ref: ref\n }, other), openIconProp ? formatIcon(openIconProp, openIconClassName) : null, iconProp ? formatIcon(iconProp, iconClassName) : /*#__PURE__*/React.createElement(AddIcon, {\n className: iconClassName\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? SpeedDialIcon.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 * 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 icon to display in the SpeedDial Floating Action Button.\n */\n icon: PropTypes.node,\n\n /**\n * @ignore\n * If `true`, the SpeedDial is open.\n */\n open: PropTypes.bool,\n\n /**\n * The icon to display in the SpeedDial Floating Action Button when the SpeedDial is open.\n */\n openIcon: PropTypes.node\n} : void 0;\nSpeedDialIcon.muiName = 'SpeedDialIcon';\nexport default withStyles(styles, {\n name: 'MuiSpeedDialIcon'\n})(SpeedDialIcon);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport * as PropTypes from 'prop-types';\nimport Tabs from '@material-ui/core/Tabs';\nimport { useTabContext, getTabId, getPanelId } from '../TabContext';\nvar TabList = /*#__PURE__*/React.forwardRef(function TabList(props, ref) {\n var childrenProp = props.children,\n other = _objectWithoutProperties(props, [\"children\"]);\n\n var context = useTabContext();\n\n if (context === null) {\n throw new TypeError('No TabContext provided');\n }\n\n var children = React.Children.map(childrenProp, function (child) {\n return /*#__PURE__*/React.cloneElement(child, {\n // SOMEDAY: `Tabs` will set those themselves\n 'aria-controls': getPanelId(context, child.props.value),\n id: getTabId(context, child.props.value)\n });\n });\n return /*#__PURE__*/React.createElement(Tabs, _extends({}, other, {\n ref: ref,\n value: context.value\n }), children);\n});\nprocess.env.NODE_ENV !== \"production\" ? TabList.propTypes = {\n children: PropTypes.arrayOf(PropTypes.element)\n} : void 0;\nexport default TabList;","import * as React from 'react';\nimport * as PropTypes from 'prop-types';\n/**\n * @type {React.Context<{ idPrefix: string; value: string } | null>}\n */\n\nvar Context = React.createContext(null);\n\nif (process.env.NODE_ENV !== 'production') {\n Context.displayName = 'TabContext';\n}\n\nfunction useUniquePrefix() {\n var _React$useState = React.useState(null),\n id = _React$useState[0],\n setId = _React$useState[1];\n\n React.useEffect(function () {\n setId(\"mui-p-\".concat(Math.round(Math.random() * 1e5)));\n }, []);\n return id;\n}\n\nexport default function TabContext(props) {\n var children = props.children,\n value = props.value;\n var idPrefix = useUniquePrefix();\n var context = React.useMemo(function () {\n return {\n idPrefix: idPrefix,\n value: value\n };\n }, [idPrefix, value]);\n return /*#__PURE__*/React.createElement(Context.Provider, {\n value: context\n }, children);\n}\nprocess.env.NODE_ENV !== \"production\" ? TabContext.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 * The value of the currently selected `Tab`.\n */\n value: PropTypes.string.isRequired\n} : void 0;\n/**\n * @returns {unknown}\n */\n\nexport function useTabContext() {\n return React.useContext(Context);\n}\nexport function getPanelId(context, value) {\n var idPrefix = context.idPrefix;\n\n if (idPrefix === null) {\n return null;\n }\n\n return \"\".concat(context.idPrefix, \"-P-\").concat(value);\n}\nexport function getTabId(context, value) {\n var idPrefix = context.idPrefix;\n\n if (idPrefix === null) {\n return null;\n }\n\n return \"\".concat(context.idPrefix, \"-T-\").concat(value);\n}","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\n// @inheritedComponent Tooltip\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { emphasize, withStyles } from '@material-ui/core/styles';\nimport Fab from '@material-ui/core/Fab';\nimport Tooltip from '@material-ui/core/Tooltip';\nimport { capitalize } from '@material-ui/core/utils';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the Fab component. */\n fab: {\n margin: 8,\n color: theme.palette.text.secondary,\n backgroundColor: theme.palette.background.paper,\n '&:hover': {\n backgroundColor: emphasize(theme.palette.background.paper, 0.15)\n },\n transition: \"\".concat(theme.transitions.create('transform', {\n duration: theme.transitions.duration.shorter\n }), \", opacity 0.8s\"),\n opacity: 1\n },\n\n /* Styles applied to the Fab component if `open={false}`. */\n fabClosed: {\n opacity: 0,\n transform: 'scale(0)'\n },\n\n /* Styles applied to the root element if `tooltipOpen={true}`. */\n staticTooltip: {\n position: 'relative',\n display: 'flex',\n '& $staticTooltipLabel': {\n transition: theme.transitions.create(['transform', 'opacity'], {\n duration: theme.transitions.duration.shorter\n }),\n opacity: 1\n }\n },\n\n /* Styles applied to the root element if `tooltipOpen={true}` and `open={false}`. */\n staticTooltipClosed: {\n '& $staticTooltipLabel': {\n opacity: 0,\n transform: 'scale(0.5)'\n }\n },\n\n /* Styles applied to the static tooltip label if `tooltipOpen={true}`. */\n staticTooltipLabel: _extends({\n position: 'absolute'\n }, theme.typography.body1, {\n backgroundColor: theme.palette.background.paper,\n borderRadius: theme.shape.borderRadius,\n boxShadow: theme.shadows[1],\n color: theme.palette.text.secondary,\n padding: '4px 16px',\n wordBreak: 'keep-all'\n }),\n\n /* Styles applied to the root if `tooltipOpen={true}` and `tooltipPlacement=\"left\"`` */\n tooltipPlacementLeft: {\n alignItems: 'center',\n '& $staticTooltipLabel': {\n transformOrigin: '100% 50%',\n right: '100%',\n marginRight: 8\n }\n },\n\n /* Styles applied to the root if `tooltipOpen={true}` and `tooltipPlacement=\"right\"`` */\n tooltipPlacementRight: {\n alignItems: 'center',\n '& $staticTooltipLabel': {\n transformOrigin: '0% 50%',\n left: '100%',\n marginLeft: 8\n }\n }\n };\n};\nvar SpeedDialAction = /*#__PURE__*/React.forwardRef(function SpeedDialAction(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$delay = props.delay,\n delay = _props$delay === void 0 ? 0 : _props$delay,\n _props$FabProps = props.FabProps,\n FabProps = _props$FabProps === void 0 ? {} : _props$FabProps,\n icon = props.icon,\n id = props.id,\n open = props.open,\n TooltipClasses = props.TooltipClasses,\n _props$tooltipOpen = props.tooltipOpen,\n tooltipOpenProp = _props$tooltipOpen === void 0 ? false : _props$tooltipOpen,\n _props$tooltipPlaceme = props.tooltipPlacement,\n tooltipPlacement = _props$tooltipPlaceme === void 0 ? 'left' : _props$tooltipPlaceme,\n tooltipTitle = props.tooltipTitle,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"delay\", \"FabProps\", \"icon\", \"id\", \"open\", \"TooltipClasses\", \"tooltipOpen\", \"tooltipPlacement\", \"tooltipTitle\"]);\n\n var _React$useState = React.useState(tooltipOpenProp),\n tooltipOpen = _React$useState[0],\n setTooltipOpen = _React$useState[1];\n\n var handleTooltipClose = function handleTooltipClose() {\n setTooltipOpen(false);\n };\n\n var handleTooltipOpen = function handleTooltipOpen() {\n setTooltipOpen(true);\n };\n\n var transitionStyle = {\n transitionDelay: \"\".concat(delay, \"ms\")\n };\n var fab = /*#__PURE__*/React.createElement(Fab, _extends({\n size: \"small\",\n className: clsx(classes.fab, className, !open && classes.fabClosed),\n tabIndex: -1,\n role: \"menuitem\",\n \"aria-describedby\": \"\".concat(id, \"-label\")\n }, FabProps, {\n style: _extends({}, transitionStyle, FabProps.style)\n }), icon);\n\n if (tooltipOpenProp) {\n return /*#__PURE__*/React.createElement(\"span\", _extends({\n id: id,\n ref: ref,\n className: clsx(classes.staticTooltip, classes[\"tooltipPlacement\".concat(capitalize(tooltipPlacement))], !open && classes.staticTooltipClosed)\n }, other), /*#__PURE__*/React.createElement(\"span\", {\n style: transitionStyle,\n id: \"\".concat(id, \"-label\"),\n className: classes.staticTooltipLabel\n }, tooltipTitle), fab);\n }\n\n return /*#__PURE__*/React.createElement(Tooltip, _extends({\n id: id,\n ref: ref,\n title: tooltipTitle,\n placement: tooltipPlacement,\n onClose: handleTooltipClose,\n onOpen: handleTooltipOpen,\n open: open && tooltipOpen,\n classes: TooltipClasses\n }, other), fab);\n});\nprocess.env.NODE_ENV !== \"production\" ? SpeedDialAction.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 * 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 * Adds a transition delay, to allow a series of SpeedDialActions to be animated.\n */\n delay: PropTypes.number,\n\n /**\n * Props applied to the [`Fab`](/api/fab/) component.\n */\n FabProps: PropTypes.object,\n\n /**\n * The Icon to display in the SpeedDial Fab.\n */\n icon: PropTypes.node,\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 * If `true`, the tooltip is shown.\n */\n open: PropTypes.bool,\n\n /**\n * `classes` prop applied to the [`Tooltip`](/api/tooltip/) element.\n */\n TooltipClasses: PropTypes.object,\n\n /**\n * Make the tooltip always visible when the SpeedDial is open.\n */\n tooltipOpen: PropTypes.bool,\n\n /**\n * Placement of the tooltip.\n */\n tooltipPlacement: 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 * Label to display in the tooltip.\n */\n tooltipTitle: PropTypes.node\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiSpeedDialAction'\n})(SpeedDialAction);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n\n/* eslint-disable jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */\nimport * as React from 'react';\nimport clsx from 'clsx';\nimport PropTypes from 'prop-types';\nimport Typography from '@material-ui/core/Typography';\nimport Collapse from '@material-ui/core/Collapse';\nimport { fade, withStyles, useTheme } from '@material-ui/core/styles';\nimport { useForkRef } from '@material-ui/core/utils';\nimport TreeViewContext from '../TreeView/TreeViewContext';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n listStyle: 'none',\n margin: 0,\n padding: 0,\n outline: 0,\n WebkitTapHighlightColor: 'transparent',\n '&:focus > $content $label': {\n backgroundColor: theme.palette.action.hover\n },\n '&$selected > $content $label': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.selectedOpacity)\n },\n '&$selected > $content $label:hover, &$selected:focus > $content $label': {\n backgroundColor: fade(theme.palette.primary.main, theme.palette.action.selectedOpacity + theme.palette.action.hoverOpacity),\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n },\n\n /* Pseudo-class applied to the root element when expanded. */\n expanded: {},\n\n /* Pseudo-class applied to the root element when selected. */\n selected: {},\n\n /* Styles applied to the `role=\"group\"` element. */\n group: {\n margin: 0,\n padding: 0,\n marginLeft: 17\n },\n\n /* Styles applied to the tree node content. */\n content: {\n width: '100%',\n display: 'flex',\n alignItems: 'center',\n cursor: 'pointer'\n },\n\n /* Styles applied to the tree node icon and collapse/expand icon. */\n iconContainer: {\n marginRight: 4,\n width: 15,\n display: 'flex',\n flexShrink: 0,\n justifyContent: 'center',\n '& svg': {\n fontSize: 18\n }\n },\n\n /* Styles applied to the label element. */\n label: {\n width: '100%',\n paddingLeft: 4,\n position: 'relative',\n '&:hover': {\n backgroundColor: theme.palette.action.hover,\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n }\n };\n};\n\nvar isPrintableCharacter = function isPrintableCharacter(str) {\n return str && str.length === 1 && str.match(/\\S/);\n};\n\nvar TreeItem = /*#__PURE__*/React.forwardRef(function TreeItem(props, ref) {\n var children = props.children,\n classes = props.classes,\n className = props.className,\n collapseIcon = props.collapseIcon,\n endIcon = props.endIcon,\n expandIcon = props.expandIcon,\n iconProp = props.icon,\n label = props.label,\n nodeId = props.nodeId,\n onClick = props.onClick,\n onLabelClick = props.onLabelClick,\n onIconClick = props.onIconClick,\n onFocus = props.onFocus,\n onKeyDown = props.onKeyDown,\n onMouseDown = props.onMouseDown,\n _props$TransitionComp = props.TransitionComponent,\n TransitionComponent = _props$TransitionComp === void 0 ? Collapse : _props$TransitionComp,\n TransitionProps = props.TransitionProps,\n other = _objectWithoutProperties(props, [\"children\", \"classes\", \"className\", \"collapseIcon\", \"endIcon\", \"expandIcon\", \"icon\", \"label\", \"nodeId\", \"onClick\", \"onLabelClick\", \"onIconClick\", \"onFocus\", \"onKeyDown\", \"onMouseDown\", \"TransitionComponent\", \"TransitionProps\"]);\n\n var _React$useContext = React.useContext(TreeViewContext),\n contextIcons = _React$useContext.icons,\n focus = _React$useContext.focus,\n focusFirstNode = _React$useContext.focusFirstNode,\n focusLastNode = _React$useContext.focusLastNode,\n focusNextNode = _React$useContext.focusNextNode,\n focusPreviousNode = _React$useContext.focusPreviousNode,\n focusByFirstCharacter = _React$useContext.focusByFirstCharacter,\n selectNode = _React$useContext.selectNode,\n selectRange = _React$useContext.selectRange,\n selectNextNode = _React$useContext.selectNextNode,\n selectPreviousNode = _React$useContext.selectPreviousNode,\n rangeSelectToFirst = _React$useContext.rangeSelectToFirst,\n rangeSelectToLast = _React$useContext.rangeSelectToLast,\n selectAllNodes = _React$useContext.selectAllNodes,\n expandAllSiblings = _React$useContext.expandAllSiblings,\n toggleExpansion = _React$useContext.toggleExpansion,\n isExpanded = _React$useContext.isExpanded,\n isFocused = _React$useContext.isFocused,\n isSelected = _React$useContext.isSelected,\n isTabbable = _React$useContext.isTabbable,\n multiSelect = _React$useContext.multiSelect,\n getParent = _React$useContext.getParent,\n mapFirstChar = _React$useContext.mapFirstChar,\n addNodeToNodeMap = _React$useContext.addNodeToNodeMap,\n removeNodeFromNodeMap = _React$useContext.removeNodeFromNodeMap;\n\n var nodeRef = React.useRef(null);\n var contentRef = React.useRef(null);\n var handleRef = useForkRef(nodeRef, ref);\n var icon = iconProp;\n var expandable = Boolean(Array.isArray(children) ? children.length : children);\n var expanded = isExpanded ? isExpanded(nodeId) : false;\n var focused = isFocused ? isFocused(nodeId) : false;\n var tabbable = isTabbable ? isTabbable(nodeId) : false;\n var selected = isSelected ? isSelected(nodeId) : false;\n var icons = contextIcons || {};\n var theme = useTheme();\n\n if (!icon) {\n if (expandable) {\n if (!expanded) {\n icon = expandIcon || icons.defaultExpandIcon;\n } else {\n icon = collapseIcon || icons.defaultCollapseIcon;\n }\n\n if (!icon) {\n icon = icons.defaultParentIcon;\n }\n } else {\n icon = endIcon || icons.defaultEndIcon;\n }\n }\n\n var handleClick = function handleClick(event) {\n if (!focused) {\n focus(nodeId);\n }\n\n var multiple = multiSelect && (event.shiftKey || event.ctrlKey || event.metaKey); // If already expanded and trying to toggle selection don't close\n\n if (expandable && !event.defaultPrevented && !(multiple && isExpanded(nodeId))) {\n toggleExpansion(event, nodeId);\n }\n\n if (multiple) {\n if (event.shiftKey) {\n selectRange(event, {\n end: nodeId\n });\n } else {\n selectNode(event, nodeId, true);\n }\n } else {\n selectNode(event, nodeId);\n }\n\n if (onClick) {\n onClick(event);\n }\n };\n\n var handleMouseDown = function handleMouseDown(event) {\n if (event.shiftKey || event.ctrlKey || event.metaKey) {\n event.preventDefault();\n }\n\n if (onMouseDown) {\n onMouseDown(event);\n }\n };\n\n var handleNextArrow = function handleNextArrow(event) {\n if (expandable) {\n if (expanded) {\n focusNextNode(nodeId);\n } else {\n toggleExpansion(event);\n }\n }\n\n return true;\n };\n\n var handlePreviousArrow = function handlePreviousArrow(event) {\n if (expanded) {\n toggleExpansion(event, nodeId);\n return true;\n }\n\n var parent = getParent(nodeId);\n\n if (parent) {\n focus(parent);\n return true;\n }\n\n return false;\n };\n\n var handleKeyDown = function handleKeyDown(event) {\n var flag = false;\n var key = event.key;\n\n if (event.altKey || event.currentTarget !== event.target) {\n return;\n }\n\n var ctrlPressed = event.ctrlKey || event.metaKey;\n\n switch (key) {\n case ' ':\n if (nodeRef.current === event.currentTarget) {\n if (multiSelect && event.shiftKey) {\n flag = selectRange(event, {\n end: nodeId\n });\n } else if (multiSelect) {\n flag = selectNode(event, nodeId, true);\n } else {\n flag = selectNode(event, nodeId);\n }\n }\n\n event.stopPropagation();\n break;\n\n case 'Enter':\n if (nodeRef.current === event.currentTarget && expandable) {\n toggleExpansion(event);\n flag = true;\n }\n\n event.stopPropagation();\n break;\n\n case 'ArrowDown':\n if (multiSelect && event.shiftKey) {\n selectNextNode(event, nodeId);\n }\n\n focusNextNode(nodeId);\n flag = true;\n break;\n\n case 'ArrowUp':\n if (multiSelect && event.shiftKey) {\n selectPreviousNode(event, nodeId);\n }\n\n focusPreviousNode(nodeId);\n flag = true;\n break;\n\n case 'ArrowRight':\n if (theme.direction === 'rtl') {\n flag = handlePreviousArrow(event);\n } else {\n flag = handleNextArrow(event);\n }\n\n break;\n\n case 'ArrowLeft':\n if (theme.direction === 'rtl') {\n flag = handleNextArrow(event);\n } else {\n flag = handlePreviousArrow(event);\n }\n\n break;\n\n case 'Home':\n if (multiSelect && ctrlPressed && event.shiftKey) {\n rangeSelectToFirst(event, nodeId);\n }\n\n focusFirstNode();\n flag = true;\n break;\n\n case 'End':\n if (multiSelect && ctrlPressed && event.shiftKey) {\n rangeSelectToLast(event, nodeId);\n }\n\n focusLastNode();\n flag = true;\n break;\n\n default:\n if (key === '*') {\n expandAllSiblings(event, nodeId);\n flag = true;\n } else if (multiSelect && ctrlPressed && key.toLowerCase() === 'a') {\n flag = selectAllNodes(event);\n } else if (!ctrlPressed && !event.shiftKey && isPrintableCharacter(key)) {\n focusByFirstCharacter(nodeId, key);\n flag = true;\n }\n\n }\n\n if (flag) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n };\n\n var handleFocus = function handleFocus(event) {\n if (!focused && event.currentTarget === event.target) {\n focus(nodeId);\n }\n\n if (onFocus) {\n onFocus(event);\n }\n };\n\n React.useEffect(function () {\n if (addNodeToNodeMap) {\n var childIds = [];\n React.Children.forEach(children, function (child) {\n if ( /*#__PURE__*/React.isValidElement(child) && child.props.nodeId) {\n childIds.push(child.props.nodeId);\n }\n });\n addNodeToNodeMap(nodeId, childIds);\n }\n }, [children, nodeId, addNodeToNodeMap]);\n React.useEffect(function () {\n if (removeNodeFromNodeMap) {\n return function () {\n removeNodeFromNodeMap(nodeId);\n };\n }\n\n return undefined;\n }, [nodeId, removeNodeFromNodeMap]);\n React.useEffect(function () {\n if (mapFirstChar && label) {\n mapFirstChar(nodeId, contentRef.current.textContent.substring(0, 1).toLowerCase());\n }\n }, [mapFirstChar, nodeId, label]);\n React.useEffect(function () {\n if (focused) {\n nodeRef.current.focus();\n }\n }, [focused]);\n var ariaSelected;\n\n if (multiSelect) {\n ariaSelected = selected;\n } else if (selected) {\n // single-selection trees unset aria-selected\n ariaSelected = true;\n }\n\n return /*#__PURE__*/React.createElement(\"li\", _extends({\n className: clsx(classes.root, className, expanded && classes.expanded, selected && classes.selected),\n role: \"treeitem\",\n onKeyDown: handleKeyDown,\n onFocus: handleFocus,\n \"aria-expanded\": expandable ? expanded : null,\n \"aria-selected\": ariaSelected,\n ref: handleRef,\n tabIndex: tabbable ? 0 : -1\n }, other), /*#__PURE__*/React.createElement(\"div\", {\n className: classes.content,\n onClick: handleClick,\n onMouseDown: handleMouseDown,\n ref: contentRef\n }, /*#__PURE__*/React.createElement(\"div\", {\n onClick: onIconClick,\n className: classes.iconContainer\n }, icon), /*#__PURE__*/React.createElement(Typography, {\n onClick: onLabelClick,\n component: \"div\",\n className: classes.label\n }, label)), children && /*#__PURE__*/React.createElement(TransitionComponent, _extends({\n unmountOnExit: true,\n className: classes.group,\n in: expanded,\n component: \"ul\",\n role: \"group\"\n }, TransitionProps), children));\n});\nprocess.env.NODE_ENV !== \"production\" ? TreeItem.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 icon used to collapse the node.\n */\n collapseIcon: PropTypes.node,\n\n /**\n * The icon displayed next to a end node.\n */\n endIcon: PropTypes.node,\n\n /**\n * The icon used to expand the node.\n */\n expandIcon: PropTypes.node,\n\n /**\n * The icon to display next to the tree node's label.\n */\n icon: PropTypes.node,\n\n /**\n * The tree node label.\n */\n label: PropTypes.node,\n\n /**\n * The id of the node.\n */\n nodeId: PropTypes.string.isRequired,\n\n /**\n * @ignore\n */\n onClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * `onClick` handler for the icon container. Call `event.preventDefault()` to prevent `onNodeToggle` from being called.\n */\n onIconClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n\n /**\n * `onClick` handler for the label container. Call `event.preventDefault()` to prevent `onNodeToggle` from being called.\n */\n onLabelClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onMouseDown: PropTypes.func,\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: 'MuiTreeItem'\n})(TreeItem);","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 '@material-ui/core/styles';\nimport { getPanelId, getTabId, useTabContext } from '../TabContext';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n padding: theme.spacing(3)\n }\n };\n};\nvar TabPanel = /*#__PURE__*/React.forwardRef(function TabPanel(props, ref) {\n var children = props.children,\n className = props.className,\n classes = props.classes,\n value = props.value,\n other = _objectWithoutProperties(props, [\"children\", \"className\", \"classes\", \"value\"]);\n\n var context = useTabContext();\n\n if (context === null) {\n throw new TypeError('No TabContext provided');\n }\n\n var id = getPanelId(context, value);\n var tabId = getTabId(context, value);\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n \"aria-labelledby\": tabId,\n className: clsx(classes.root, className),\n hidden: value !== context.value,\n id: id,\n ref: ref,\n role: \"tabpanel\"\n }, other), value === context.value && children);\n});\nprocess.env.NODE_ENV !== \"production\" ? TabPanel.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 `value` of the corresponding `Tab`. Must use the index of the `Tab` when\n * no `value` was passed to `Tab`.\n */\n value: PropTypes.string.isRequired\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTabPanel'\n})(TabPanel);"],"sourceRoot":""}