{"version":3,"sources":["../node_modules/@material-ui/core/esm/AppBar/AppBar.js","../node_modules/@material-ui/core/esm/Tab/Tab.js","../node_modules/@material-ui/core/esm/utils/scrollLeft.js","../node_modules/@material-ui/core/esm/internal/animate.js","../node_modules/@material-ui/core/esm/Tabs/ScrollbarSize.js","../node_modules/@material-ui/core/esm/Tabs/TabIndicator.js","../node_modules/@material-ui/core/esm/internal/svg-icons/KeyboardArrowLeft.js","../node_modules/@material-ui/core/esm/internal/svg-icons/KeyboardArrowRight.js","../node_modules/@material-ui/core/esm/TabScrollButton/TabScrollButton.js","../node_modules/@material-ui/core/esm/Tabs/Tabs.js"],"names":["AppBar","React","props","ref","classes","className","_props$color","color","_props$position","position","other","_objectWithoutProperties","Paper","_extends","square","component","elevation","clsx","root","concat","capitalize","withStyles","theme","backgroundColorDefault","palette","type","grey","display","flexDirection","width","boxSizing","zIndex","appBar","flexShrink","positionFixed","top","left","right","positionAbsolute","positionSticky","positionStatic","positionRelative","colorDefault","backgroundColor","getContrastText","colorPrimary","primary","main","contrastText","colorSecondary","secondary","colorInherit","colorTransparent","name","Tab","_props$disabled","disabled","_props$disableFocusRi","disableFocusRipple","fullWidth","icon","indicator","label","onChange","onClick","onFocus","selected","selectionFollowsFocus","_props$textColor","textColor","value","_props$wrapped","wrapped","ButtonBase","focusRipple","labelIcon","role","event","tabIndex","wrapper","_extends2","typography","button","maxWidth","minWidth","minHeight","padding","_defineProperty","breakpoints","up","paddingTop","marginBottom","textColorInherit","opacity","textColorPrimary","text","textColorSecondary","flexGrow","flexBasis","fontSize","pxToRem","lineHeight","alignItems","justifyContent","cachedType","detectScrollType","dummy","document","createElement","appendChild","createTextNode","dir","style","height","overflow","body","scrollLeft","removeChild","getNormalizedScrollLeft","element","direction","scrollWidth","clientWidth","easeInOutSin","time","Math","sin","PI","styles","ScrollbarSize","scrollbarHeight","nodeRef","setMeasurements","current","offsetHeight","clientHeight","handleResize","debounce","prevHeight","window","addEventListener","clear","removeEventListener","TabIndicator","orientation","vertical","bottom","transition","transitions","create","createSvgIcon","d","_ref","KeyboardArrowLeft","_ref2","KeyboardArrowRight","TabScrollButton","classNameProp","transform","Tabs","ariaLabel","ariaLabelledBy","action","_props$centered","centered","childrenProp","children","_props$component","Component","_props$indicatorColor","indicatorColor","_props$orientation","_props$ScrollButtonCo","ScrollButtonComponent","_props$scrollButtons","scrollButtons","_props$TabIndicatorPr","TabIndicatorProps","TabScrollButtonProps","_props$variant","variant","useTheme","scrollable","isRtl","scrollStart","start","end","clientSize","size","_React$useState","mounted","setMounted","_React$useState2","indicatorStyle","setIndicatorStyle","_React$useState3","displayScroll","setDisplayScroll","_React$useState4","scrollerStyle","setScrollerStyle","valueToIndex","Map","tabsRef","tabListRef","getTabsMeta","tabsMeta","tabMeta","tabsNode","rect","getBoundingClientRect","scrollTop","scrollLeftNormalized","_children","length","tab","get","process","updateIndicatorState","useEventCallback","_newIndicatorStyle","_getTabsMeta","startValue","correction","newIndicatorStyle","isNaN","dStart","abs","dSize","scroll","scrollValue","property","to","options","arguments","undefined","cb","_options$ease","ease","_options$duration","duration","from","cancelled","cancel","step","timestamp","Error","min","requestAnimationFrame","animate","moveTabsScroll","delta","handleStartScrollClick","handleEndScrollClick","handleScrollbarSizeChange","scrollSelectedIntoView","_getTabsMeta2","nextScrollStart","_nextScrollStart","updateScrollButtonState","showStartScroll","showEndScroll","_tabsRef$current","scrollHeight","win","ownerWindow","handleTabsScroll","updateIndicator","updateScrollButtons","childIndex","map","child","childValue","set","conditionalElements","scrollbarSizeListener","scrollButtonsActive","showScrollButtons","scrollButtonStart","scrollButtonsDesktop","scrollButtonEnd","getConditionalElements","scroller","fixed","onScroll","flexContainer","flexContainerVertical","onKeyDown","target","getAttribute","newFocusTarget","previousItemKey","nextItemKey","key","previousElementSibling","lastChild","nextElementSibling","firstChild","focus","preventDefault","WebkitOverflowScrolling","flex","whiteSpace","overflowX","scrollbarWidth","down"],"mappings":"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","file":"static/js/12.e59a86d3.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 PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nimport Paper from '../Paper';\nexport var styles = function styles(theme) {\n var backgroundColorDefault = theme.palette.type === 'light' ? theme.palette.grey[100] : theme.palette.grey[900];\n return {\n /* Styles applied to the root element. */\n root: {\n display: 'flex',\n flexDirection: 'column',\n width: '100%',\n boxSizing: 'border-box',\n // Prevent padding issue with the Modal and fixed positioned AppBar.\n zIndex: theme.zIndex.appBar,\n flexShrink: 0\n },\n\n /* Styles applied to the root element if `position=\"fixed\"`. */\n positionFixed: {\n position: 'fixed',\n top: 0,\n left: 'auto',\n right: 0,\n '@media print': {\n // Prevent the app bar to be visible on each printed page.\n position: 'absolute'\n }\n },\n\n /* Styles applied to the root element if `position=\"absolute\"`. */\n positionAbsolute: {\n position: 'absolute',\n top: 0,\n left: 'auto',\n right: 0\n },\n\n /* Styles applied to the root element if `position=\"sticky\"`. */\n positionSticky: {\n // ⚠️ sticky is not supported by IE 11.\n position: 'sticky',\n top: 0,\n left: 'auto',\n right: 0\n },\n\n /* Styles applied to the root element if `position=\"static\"`. */\n positionStatic: {\n position: 'static'\n },\n\n /* Styles applied to the root element if `position=\"relative\"`. */\n positionRelative: {\n position: 'relative'\n },\n\n /* Styles applied to the root element if `color=\"default\"`. */\n colorDefault: {\n backgroundColor: backgroundColorDefault,\n color: theme.palette.getContrastText(backgroundColorDefault)\n },\n\n /* Styles applied to the root element if `color=\"primary\"`. */\n colorPrimary: {\n backgroundColor: theme.palette.primary.main,\n color: theme.palette.primary.contrastText\n },\n\n /* Styles applied to the root element if `color=\"secondary\"`. */\n colorSecondary: {\n backgroundColor: theme.palette.secondary.main,\n color: theme.palette.secondary.contrastText\n },\n\n /* Styles applied to the root element if `color=\"inherit\"`. */\n colorInherit: {\n color: 'inherit'\n },\n\n /* Styles applied to the root element if `color=\"transparent\"`. */\n colorTransparent: {\n backgroundColor: 'transparent',\n color: 'inherit'\n }\n };\n};\nvar AppBar = /*#__PURE__*/React.forwardRef(function AppBar(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$color = props.color,\n color = _props$color === void 0 ? 'primary' : _props$color,\n _props$position = props.position,\n position = _props$position === void 0 ? 'fixed' : _props$position,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"color\", \"position\"]);\n\n return /*#__PURE__*/React.createElement(Paper, _extends({\n square: true,\n component: \"header\",\n elevation: 4,\n className: clsx(classes.root, classes[\"position\".concat(capitalize(position))], classes[\"color\".concat(capitalize(color))], className, position === 'fixed' && 'mui-fixed'),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? AppBar.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 color of the component. It supports those theme colors that make sense for this component.\n */\n color: PropTypes.oneOf(['default', 'inherit', 'primary', 'secondary', 'transparent']),\n\n /**\n * The positioning type. The behavior of the different options is described\n * [in the MDN web docs](https://developer.mozilla.org/en-US/docs/Learn/CSS/CSS_layout/Positioning).\n * Note: `sticky` is not universally supported and will fall back to `static` when unavailable.\n */\n position: PropTypes.oneOf(['absolute', 'fixed', 'relative', 'static', 'sticky'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiAppBar'\n})(AppBar);","import _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport ButtonBase from '../ButtonBase';\nimport capitalize from '../utils/capitalize';\nimport unsupportedProp from '../utils/unsupportedProp';\nexport var styles = function styles(theme) {\n var _extends2;\n\n return {\n /* Styles applied to the root element. */\n root: _extends({}, theme.typography.button, (_extends2 = {\n maxWidth: 264,\n minWidth: 72,\n position: 'relative',\n boxSizing: 'border-box',\n minHeight: 48,\n flexShrink: 0,\n padding: '6px 12px'\n }, _defineProperty(_extends2, theme.breakpoints.up('sm'), {\n padding: '6px 24px'\n }), _defineProperty(_extends2, \"overflow\", 'hidden'), _defineProperty(_extends2, \"whiteSpace\", 'normal'), _defineProperty(_extends2, \"textAlign\", 'center'), _defineProperty(_extends2, theme.breakpoints.up('sm'), {\n minWidth: 160\n }), _extends2)),\n\n /* Styles applied to the root element if both `icon` and `label` are provided. */\n labelIcon: {\n minHeight: 72,\n paddingTop: 9,\n '& $wrapper > *:first-child': {\n marginBottom: 6\n }\n },\n\n /* Styles applied to the root element if the parent [`Tabs`](/api/tabs/) has `textColor=\"inherit\"`. */\n textColorInherit: {\n color: 'inherit',\n opacity: 0.7,\n '&$selected': {\n opacity: 1\n },\n '&$disabled': {\n opacity: 0.5\n }\n },\n\n /* Styles applied to the root element if the parent [`Tabs`](/api/tabs/) has `textColor=\"primary\"`. */\n textColorPrimary: {\n color: theme.palette.text.secondary,\n '&$selected': {\n color: theme.palette.primary.main\n },\n '&$disabled': {\n color: theme.palette.text.disabled\n }\n },\n\n /* Styles applied to the root element if the parent [`Tabs`](/api/tabs/) has `textColor=\"secondary\"`. */\n textColorSecondary: {\n color: theme.palette.text.secondary,\n '&$selected': {\n color: theme.palette.secondary.main\n },\n '&$disabled': {\n color: theme.palette.text.disabled\n }\n },\n\n /* Pseudo-class applied to the root element if `selected={true}` (controlled by the Tabs component). */\n selected: {},\n\n /* Pseudo-class applied to the root element if `disabled={true}` (controlled by the Tabs component). */\n disabled: {},\n\n /* Styles applied to the root element if `fullWidth={true}` (controlled by the Tabs component). */\n fullWidth: {\n flexShrink: 1,\n flexGrow: 1,\n flexBasis: 0,\n maxWidth: 'none'\n },\n\n /* Styles applied to the root element if `wrapped={true}`. */\n wrapped: {\n fontSize: theme.typography.pxToRem(12),\n lineHeight: 1.5\n },\n\n /* Styles applied to the `icon` and `label`'s wrapper element. */\n wrapper: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '100%',\n flexDirection: 'column'\n }\n };\n};\nvar Tab = /*#__PURE__*/React.forwardRef(function Tab(props, ref) {\n var classes = props.classes,\n className = props.className,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disableFocusRi = props.disableFocusRipple,\n disableFocusRipple = _props$disableFocusRi === void 0 ? false : _props$disableFocusRi,\n fullWidth = props.fullWidth,\n icon = props.icon,\n indicator = props.indicator,\n label = props.label,\n onChange = props.onChange,\n onClick = props.onClick,\n onFocus = props.onFocus,\n selected = props.selected,\n selectionFollowsFocus = props.selectionFollowsFocus,\n _props$textColor = props.textColor,\n textColor = _props$textColor === void 0 ? 'inherit' : _props$textColor,\n value = props.value,\n _props$wrapped = props.wrapped,\n wrapped = _props$wrapped === void 0 ? false : _props$wrapped,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"disabled\", \"disableFocusRipple\", \"fullWidth\", \"icon\", \"indicator\", \"label\", \"onChange\", \"onClick\", \"onFocus\", \"selected\", \"selectionFollowsFocus\", \"textColor\", \"value\", \"wrapped\"]);\n\n var handleClick = function handleClick(event) {\n if (onChange) {\n onChange(event, value);\n }\n\n if (onClick) {\n onClick(event);\n }\n };\n\n var handleFocus = function handleFocus(event) {\n if (selectionFollowsFocus && !selected && onChange) {\n onChange(event, value);\n }\n\n if (onFocus) {\n onFocus(event);\n }\n };\n\n return /*#__PURE__*/React.createElement(ButtonBase, _extends({\n focusRipple: !disableFocusRipple,\n className: clsx(classes.root, classes[\"textColor\".concat(capitalize(textColor))], className, disabled && classes.disabled, selected && classes.selected, label && icon && classes.labelIcon, fullWidth && classes.fullWidth, wrapped && classes.wrapped),\n ref: ref,\n role: \"tab\",\n \"aria-selected\": selected,\n disabled: disabled,\n onClick: handleClick,\n onFocus: handleFocus,\n tabIndex: selected ? 0 : -1\n }, other), /*#__PURE__*/React.createElement(\"span\", {\n className: classes.wrapper\n }, icon, label), indicator);\n});\nprocess.env.NODE_ENV !== \"production\" ? Tab.propTypes = {\n /**\n * This prop isn't supported.\n * Use the `component` prop if you need to change the children structure.\n */\n children: unsupportedProp,\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.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the tab will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, the keyboard focus ripple will be disabled.\n */\n disableFocusRipple: PropTypes.bool,\n\n /**\n * If `true`, the ripple effect will be disabled.\n */\n disableRipple: PropTypes.bool,\n\n /**\n * @ignore\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The icon element.\n */\n icon: PropTypes.node,\n\n /**\n * @ignore\n * For server-side rendering consideration, we let the selected tab\n * render the indicator.\n */\n indicator: PropTypes.node,\n\n /**\n * The label element.\n */\n label: PropTypes.node,\n\n /**\n * @ignore\n */\n onChange: PropTypes.func,\n\n /**\n * @ignore\n */\n onClick: PropTypes.func,\n\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n\n /**\n * @ignore\n */\n selected: PropTypes.bool,\n\n /**\n * @ignore\n */\n selectionFollowsFocus: PropTypes.bool,\n\n /**\n * @ignore\n */\n textColor: PropTypes.oneOf(['secondary', 'primary', 'inherit']),\n\n /**\n * You can provide your own value. Otherwise, we fallback to the child position index.\n */\n value: PropTypes.any,\n\n /**\n * Tab labels appear in a single row.\n * They can use a second line if needed.\n */\n wrapped: PropTypes.bool\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTab'\n})(Tab);","// Source from https://github.com/alitaheri/normalize-scroll-left\nvar cachedType;\n/**\n * Based on the jquery plugin https://github.com/othree/jquery.rtl-scroll-type\n *\n * Types of scrollLeft, assiming scrollWidth=100 and direction is rtl.\n *\n * Browser | Type | <- Most Left | Most Right -> | Initial\n * -------------- | ------------- | ------------ | ------------- | -------\n * WebKit | default | 0 | 100 | 100\n * Firefox/Opera | negative | -100 | 0 | 0\n * IE/Edge | reverse | 100 | 0 | 0\n */\n\nexport function detectScrollType() {\n if (cachedType) {\n return cachedType;\n }\n\n var dummy = document.createElement('div');\n dummy.appendChild(document.createTextNode('ABCD'));\n dummy.dir = 'rtl';\n dummy.style.fontSize = '14px';\n dummy.style.width = '4px';\n dummy.style.height = '1px';\n dummy.style.position = 'absolute';\n dummy.style.top = '-1000px';\n dummy.style.overflow = 'scroll';\n document.body.appendChild(dummy);\n cachedType = 'reverse';\n\n if (dummy.scrollLeft > 0) {\n cachedType = 'default';\n } else {\n dummy.scrollLeft = 1;\n\n if (dummy.scrollLeft === 0) {\n cachedType = 'negative';\n }\n }\n\n document.body.removeChild(dummy);\n return cachedType;\n} // Based on https://stackoverflow.com/a/24394376\n\nexport function getNormalizedScrollLeft(element, direction) {\n var scrollLeft = element.scrollLeft; // Perform the calculations only when direction is rtl to avoid messing up the ltr bahavior\n\n if (direction !== 'rtl') {\n return scrollLeft;\n }\n\n var type = detectScrollType();\n\n switch (type) {\n case 'negative':\n return element.scrollWidth - element.clientWidth + scrollLeft;\n\n case 'reverse':\n return element.scrollWidth - element.clientWidth - scrollLeft;\n\n default:\n return scrollLeft;\n }\n}","function easeInOutSin(time) {\n return (1 + Math.sin(Math.PI * time - Math.PI / 2)) / 2;\n}\n\nexport default function animate(property, element, to) {\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n var cb = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : function () {};\n var _options$ease = options.ease,\n ease = _options$ease === void 0 ? easeInOutSin : _options$ease,\n _options$duration = options.duration,\n duration = _options$duration === void 0 ? 300 : _options$duration;\n var start = null;\n var from = element[property];\n var cancelled = false;\n\n var cancel = function cancel() {\n cancelled = true;\n };\n\n var step = function step(timestamp) {\n if (cancelled) {\n cb(new Error('Animation cancelled'));\n return;\n }\n\n if (start === null) {\n start = timestamp;\n }\n\n var time = Math.min(1, (timestamp - start) / duration);\n element[property] = ease(time) * (to - from) + from;\n\n if (time >= 1) {\n requestAnimationFrame(function () {\n cb(null);\n });\n return;\n }\n\n requestAnimationFrame(step);\n };\n\n if (from === to) {\n cb(new Error('Element already at target position'));\n return cancel;\n }\n\n requestAnimationFrame(step);\n return cancel;\n}","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 debounce from '../utils/debounce';\nvar styles = {\n width: 99,\n height: 99,\n position: 'absolute',\n top: -9999,\n overflow: 'scroll'\n};\n/**\n * @ignore - internal component.\n * The component originates from https://github.com/STORIS/react-scrollbar-size.\n * It has been moved into the core in order to minimize the bundle size.\n */\n\nexport default function ScrollbarSize(props) {\n var onChange = props.onChange,\n other = _objectWithoutProperties(props, [\"onChange\"]);\n\n var scrollbarHeight = React.useRef();\n var nodeRef = React.useRef(null);\n\n var setMeasurements = function setMeasurements() {\n scrollbarHeight.current = nodeRef.current.offsetHeight - nodeRef.current.clientHeight;\n };\n\n React.useEffect(function () {\n var handleResize = debounce(function () {\n var prevHeight = scrollbarHeight.current;\n setMeasurements();\n\n if (prevHeight !== scrollbarHeight.current) {\n onChange(scrollbarHeight.current);\n }\n });\n window.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n window.removeEventListener('resize', handleResize);\n };\n }, [onChange]);\n React.useEffect(function () {\n setMeasurements();\n onChange(scrollbarHeight.current);\n }, [onChange]);\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n style: styles,\n ref: nodeRef\n }, other));\n}\nprocess.env.NODE_ENV !== \"production\" ? ScrollbarSize.propTypes = {\n onChange: PropTypes.func.isRequired\n} : void 0;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport withStyles from '../styles/withStyles';\nimport capitalize from '../utils/capitalize';\nexport var styles = function styles(theme) {\n return {\n root: {\n position: 'absolute',\n height: 2,\n bottom: 0,\n width: '100%',\n transition: theme.transitions.create()\n },\n colorPrimary: {\n backgroundColor: theme.palette.primary.main\n },\n colorSecondary: {\n backgroundColor: theme.palette.secondary.main\n },\n vertical: {\n height: '100%',\n width: 2,\n right: 0\n }\n };\n};\n/**\n * @ignore - internal component.\n */\n\nvar TabIndicator = /*#__PURE__*/React.forwardRef(function TabIndicator(props, ref) {\n var classes = props.classes,\n className = props.className,\n color = props.color,\n orientation = props.orientation,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"color\", \"orientation\"]);\n\n return /*#__PURE__*/React.createElement(\"span\", _extends({\n className: clsx(classes.root, classes[\"color\".concat(capitalize(color))], className, orientation === 'vertical' && classes.vertical),\n ref: ref\n }, other));\n});\nprocess.env.NODE_ENV !== \"production\" ? TabIndicator.propTypes = {\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.isRequired,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * @ignore\n * The color of the tab indicator.\n */\n color: PropTypes.oneOf(['primary', 'secondary']).isRequired,\n\n /**\n * The tabs orientation (layout flow direction).\n */\n orientation: PropTypes.oneOf(['horizontal', 'vertical']).isRequired\n} : void 0;\nexport default withStyles(styles, {\n name: 'PrivateTabIndicator'\n})(TabIndicator);","import * as React from 'react';\nimport createSvgIcon from '../../utils/createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z\"\n}), 'KeyboardArrowLeft');","import * as React from 'react';\nimport createSvgIcon from '../../utils/createSvgIcon';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z\"\n}), 'KeyboardArrowRight');","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\n\n/* eslint-disable jsx-a11y/aria-role */\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport KeyboardArrowLeft from '../internal/svg-icons/KeyboardArrowLeft';\nimport KeyboardArrowRight from '../internal/svg-icons/KeyboardArrowRight';\nimport withStyles from '../styles/withStyles';\nimport ButtonBase from '../ButtonBase';\nexport var styles = {\n /* Styles applied to the root element. */\n root: {\n width: 40,\n flexShrink: 0,\n opacity: 0.8,\n '&$disabled': {\n opacity: 0\n }\n },\n\n /* Styles applied to the root element if `orientation=\"vertical\"`. */\n vertical: {\n width: '100%',\n height: 40,\n '& svg': {\n transform: 'rotate(90deg)'\n }\n },\n\n /* Pseudo-class applied to the root element if `disabled={true}`. */\n disabled: {}\n};\n\nvar _ref = /*#__PURE__*/React.createElement(KeyboardArrowLeft, {\n fontSize: \"small\"\n});\n\nvar _ref2 = /*#__PURE__*/React.createElement(KeyboardArrowRight, {\n fontSize: \"small\"\n});\n\nvar TabScrollButton = /*#__PURE__*/React.forwardRef(function TabScrollButton(props, ref) {\n var classes = props.classes,\n classNameProp = props.className,\n direction = props.direction,\n orientation = props.orientation,\n disabled = props.disabled,\n other = _objectWithoutProperties(props, [\"classes\", \"className\", \"direction\", \"orientation\", \"disabled\"]);\n\n return /*#__PURE__*/React.createElement(ButtonBase, _extends({\n component: \"div\",\n className: clsx(classes.root, classNameProp, disabled && classes.disabled, orientation === 'vertical' && classes.vertical),\n ref: ref,\n role: null,\n tabIndex: null\n }, other), direction === 'left' ? _ref : _ref2);\n});\nprocess.env.NODE_ENV !== \"production\" ? TabScrollButton.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 * Which direction should the button indicate?\n */\n direction: PropTypes.oneOf(['left', 'right']).isRequired,\n\n /**\n * If `true`, the element will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * The tabs orientation (layout flow direction).\n */\n orientation: PropTypes.oneOf(['horizontal', 'vertical']).isRequired\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTabScrollButton'\n})(TabScrollButton);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutProperties from \"@babel/runtime/helpers/esm/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport * as React from 'react';\nimport { isFragment } from 'react-is';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport { refType } from '@material-ui/utils';\nimport debounce from '../utils/debounce';\nimport ownerWindow from '../utils/ownerWindow';\nimport { getNormalizedScrollLeft, detectScrollType } from '../utils/scrollLeft';\nimport animate from '../internal/animate';\nimport ScrollbarSize from './ScrollbarSize';\nimport withStyles from '../styles/withStyles';\nimport TabIndicator from './TabIndicator';\nimport TabScrollButton from '../TabScrollButton';\nimport useEventCallback from '../utils/useEventCallback';\nimport useTheme from '../styles/useTheme';\nexport var styles = function styles(theme) {\n return {\n /* Styles applied to the root element. */\n root: {\n overflow: 'hidden',\n minHeight: 48,\n WebkitOverflowScrolling: 'touch',\n // Add iOS momentum scrolling.\n display: 'flex'\n },\n\n /* Styles applied to the root element if `orientation=\"vertical\"`. */\n vertical: {\n flexDirection: 'column'\n },\n\n /* Styles applied to the flex container element. */\n flexContainer: {\n display: 'flex'\n },\n\n /* Styles applied to the flex container element if `orientation=\"vertical\"`. */\n flexContainerVertical: {\n flexDirection: 'column'\n },\n\n /* Styles applied to the flex container element if `centered={true}` & `!variant=\"scrollable\"`. */\n centered: {\n justifyContent: 'center'\n },\n\n /* Styles applied to the tablist element. */\n scroller: {\n position: 'relative',\n display: 'inline-block',\n flex: '1 1 auto',\n whiteSpace: 'nowrap'\n },\n\n /* Styles applied to the tablist element if `!variant=\"scrollable\"`\b\b\b. */\n fixed: {\n overflowX: 'hidden',\n width: '100%'\n },\n\n /* Styles applied to the tablist element if `variant=\"scrollable\"`. */\n scrollable: {\n overflowX: 'scroll',\n // Hide dimensionless scrollbar on MacOS\n scrollbarWidth: 'none',\n // Firefox\n '&::-webkit-scrollbar': {\n display: 'none' // Safari + Chrome\n\n }\n },\n\n /* Styles applied to the `ScrollButtonComponent` component. */\n scrollButtons: {},\n\n /* Styles applied to the `ScrollButtonComponent` component if `scrollButtons=\"auto\"` or scrollButtons=\"desktop\"`. */\n scrollButtonsDesktop: _defineProperty({}, theme.breakpoints.down('xs'), {\n display: 'none'\n }),\n\n /* Styles applied to the `TabIndicator` component. */\n indicator: {}\n };\n};\nvar Tabs = /*#__PURE__*/React.forwardRef(function Tabs(props, ref) {\n var ariaLabel = props['aria-label'],\n ariaLabelledBy = props['aria-labelledby'],\n action = props.action,\n _props$centered = props.centered,\n centered = _props$centered === void 0 ? false : _props$centered,\n childrenProp = props.children,\n classes = props.classes,\n className = props.className,\n _props$component = props.component,\n Component = _props$component === void 0 ? 'div' : _props$component,\n _props$indicatorColor = props.indicatorColor,\n indicatorColor = _props$indicatorColor === void 0 ? 'secondary' : _props$indicatorColor,\n onChange = props.onChange,\n _props$orientation = props.orientation,\n orientation = _props$orientation === void 0 ? 'horizontal' : _props$orientation,\n _props$ScrollButtonCo = props.ScrollButtonComponent,\n ScrollButtonComponent = _props$ScrollButtonCo === void 0 ? TabScrollButton : _props$ScrollButtonCo,\n _props$scrollButtons = props.scrollButtons,\n scrollButtons = _props$scrollButtons === void 0 ? 'auto' : _props$scrollButtons,\n selectionFollowsFocus = props.selectionFollowsFocus,\n _props$TabIndicatorPr = props.TabIndicatorProps,\n TabIndicatorProps = _props$TabIndicatorPr === void 0 ? {} : _props$TabIndicatorPr,\n TabScrollButtonProps = props.TabScrollButtonProps,\n _props$textColor = props.textColor,\n textColor = _props$textColor === void 0 ? 'inherit' : _props$textColor,\n value = props.value,\n _props$variant = props.variant,\n variant = _props$variant === void 0 ? 'standard' : _props$variant,\n other = _objectWithoutProperties(props, [\"aria-label\", \"aria-labelledby\", \"action\", \"centered\", \"children\", \"classes\", \"className\", \"component\", \"indicatorColor\", \"onChange\", \"orientation\", \"ScrollButtonComponent\", \"scrollButtons\", \"selectionFollowsFocus\", \"TabIndicatorProps\", \"TabScrollButtonProps\", \"textColor\", \"value\", \"variant\"]);\n\n var theme = useTheme();\n var scrollable = variant === 'scrollable';\n var isRtl = theme.direction === 'rtl';\n var vertical = orientation === 'vertical';\n var scrollStart = vertical ? 'scrollTop' : 'scrollLeft';\n var start = vertical ? 'top' : 'left';\n var end = vertical ? 'bottom' : 'right';\n var clientSize = vertical ? 'clientHeight' : 'clientWidth';\n var size = vertical ? 'height' : 'width';\n\n if (process.env.NODE_ENV !== 'production') {\n if (centered && scrollable) {\n console.error('Material-UI: You can not use the `centered={true}` and `variant=\"scrollable\"` properties ' + 'at the same time on a `Tabs` component.');\n }\n }\n\n var _React$useState = React.useState(false),\n mounted = _React$useState[0],\n setMounted = _React$useState[1];\n\n var _React$useState2 = React.useState({}),\n indicatorStyle = _React$useState2[0],\n setIndicatorStyle = _React$useState2[1];\n\n var _React$useState3 = React.useState({\n start: false,\n end: false\n }),\n displayScroll = _React$useState3[0],\n setDisplayScroll = _React$useState3[1];\n\n var _React$useState4 = React.useState({\n overflow: 'hidden',\n marginBottom: null\n }),\n scrollerStyle = _React$useState4[0],\n setScrollerStyle = _React$useState4[1];\n\n var valueToIndex = new Map();\n var tabsRef = React.useRef(null);\n var tabListRef = React.useRef(null);\n\n var getTabsMeta = function getTabsMeta() {\n var tabsNode = tabsRef.current;\n var tabsMeta;\n\n if (tabsNode) {\n var rect = tabsNode.getBoundingClientRect(); // create a new object with ClientRect class props + scrollLeft\n\n tabsMeta = {\n clientWidth: tabsNode.clientWidth,\n scrollLeft: tabsNode.scrollLeft,\n scrollTop: tabsNode.scrollTop,\n scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\n scrollWidth: tabsNode.scrollWidth,\n top: rect.top,\n bottom: rect.bottom,\n left: rect.left,\n right: rect.right\n };\n }\n\n var tabMeta;\n\n if (tabsNode && value !== false) {\n var _children = tabListRef.current.children;\n\n if (_children.length > 0) {\n var tab = _children[valueToIndex.get(value)];\n\n if (process.env.NODE_ENV !== 'production') {\n if (!tab) {\n console.error([\"Material-UI: The value provided to the Tabs component is invalid.\", \"None of the Tabs' children match with `\".concat(value, \"`.\"), valueToIndex.keys ? \"You can provide one of the following values: \".concat(Array.from(valueToIndex.keys()).join(', '), \".\") : null].join('\\n'));\n }\n }\n\n tabMeta = tab ? tab.getBoundingClientRect() : null;\n }\n }\n\n return {\n tabsMeta: tabsMeta,\n tabMeta: tabMeta\n };\n };\n\n var updateIndicatorState = useEventCallback(function () {\n var _newIndicatorStyle;\n\n var _getTabsMeta = getTabsMeta(),\n tabsMeta = _getTabsMeta.tabsMeta,\n tabMeta = _getTabsMeta.tabMeta;\n\n var startValue = 0;\n\n if (tabMeta && tabsMeta) {\n if (vertical) {\n startValue = tabMeta.top - tabsMeta.top + tabsMeta.scrollTop;\n } else {\n var correction = isRtl ? tabsMeta.scrollLeftNormalized + tabsMeta.clientWidth - tabsMeta.scrollWidth : tabsMeta.scrollLeft;\n startValue = tabMeta.left - tabsMeta.left + correction;\n }\n }\n\n var newIndicatorStyle = (_newIndicatorStyle = {}, _defineProperty(_newIndicatorStyle, start, startValue), _defineProperty(_newIndicatorStyle, size, tabMeta ? tabMeta[size] : 0), _newIndicatorStyle);\n\n if (isNaN(indicatorStyle[start]) || isNaN(indicatorStyle[size])) {\n setIndicatorStyle(newIndicatorStyle);\n } else {\n var dStart = Math.abs(indicatorStyle[start] - newIndicatorStyle[start]);\n var dSize = Math.abs(indicatorStyle[size] - newIndicatorStyle[size]);\n\n if (dStart >= 1 || dSize >= 1) {\n setIndicatorStyle(newIndicatorStyle);\n }\n }\n });\n\n var scroll = function scroll(scrollValue) {\n animate(scrollStart, tabsRef.current, scrollValue);\n };\n\n var moveTabsScroll = function moveTabsScroll(delta) {\n var scrollValue = tabsRef.current[scrollStart];\n\n if (vertical) {\n scrollValue += delta;\n } else {\n scrollValue += delta * (isRtl ? -1 : 1); // Fix for Edge\n\n scrollValue *= isRtl && detectScrollType() === 'reverse' ? -1 : 1;\n }\n\n scroll(scrollValue);\n };\n\n var handleStartScrollClick = function handleStartScrollClick() {\n moveTabsScroll(-tabsRef.current[clientSize]);\n };\n\n var handleEndScrollClick = function handleEndScrollClick() {\n moveTabsScroll(tabsRef.current[clientSize]);\n };\n\n var handleScrollbarSizeChange = React.useCallback(function (scrollbarHeight) {\n setScrollerStyle({\n overflow: null,\n marginBottom: -scrollbarHeight\n });\n }, []);\n\n var getConditionalElements = function getConditionalElements() {\n var conditionalElements = {};\n conditionalElements.scrollbarSizeListener = scrollable ? /*#__PURE__*/React.createElement(ScrollbarSize, {\n className: classes.scrollable,\n onChange: handleScrollbarSizeChange\n }) : null;\n var scrollButtonsActive = displayScroll.start || displayScroll.end;\n var showScrollButtons = scrollable && (scrollButtons === 'auto' && scrollButtonsActive || scrollButtons === 'desktop' || scrollButtons === 'on');\n conditionalElements.scrollButtonStart = showScrollButtons ? /*#__PURE__*/React.createElement(ScrollButtonComponent, _extends({\n orientation: orientation,\n direction: isRtl ? 'right' : 'left',\n onClick: handleStartScrollClick,\n disabled: !displayScroll.start,\n className: clsx(classes.scrollButtons, scrollButtons !== 'on' && classes.scrollButtonsDesktop)\n }, TabScrollButtonProps)) : null;\n conditionalElements.scrollButtonEnd = showScrollButtons ? /*#__PURE__*/React.createElement(ScrollButtonComponent, _extends({\n orientation: orientation,\n direction: isRtl ? 'left' : 'right',\n onClick: handleEndScrollClick,\n disabled: !displayScroll.end,\n className: clsx(classes.scrollButtons, scrollButtons !== 'on' && classes.scrollButtonsDesktop)\n }, TabScrollButtonProps)) : null;\n return conditionalElements;\n };\n\n var scrollSelectedIntoView = useEventCallback(function () {\n var _getTabsMeta2 = getTabsMeta(),\n tabsMeta = _getTabsMeta2.tabsMeta,\n tabMeta = _getTabsMeta2.tabMeta;\n\n if (!tabMeta || !tabsMeta) {\n return;\n }\n\n if (tabMeta[start] < tabsMeta[start]) {\n // left side of button is out of view\n var nextScrollStart = tabsMeta[scrollStart] + (tabMeta[start] - tabsMeta[start]);\n scroll(nextScrollStart);\n } else if (tabMeta[end] > tabsMeta[end]) {\n // right side of button is out of view\n var _nextScrollStart = tabsMeta[scrollStart] + (tabMeta[end] - tabsMeta[end]);\n\n scroll(_nextScrollStart);\n }\n });\n var updateScrollButtonState = useEventCallback(function () {\n if (scrollable && scrollButtons !== 'off') {\n var _tabsRef$current = tabsRef.current,\n scrollTop = _tabsRef$current.scrollTop,\n scrollHeight = _tabsRef$current.scrollHeight,\n clientHeight = _tabsRef$current.clientHeight,\n scrollWidth = _tabsRef$current.scrollWidth,\n clientWidth = _tabsRef$current.clientWidth;\n var showStartScroll;\n var showEndScroll;\n\n if (vertical) {\n showStartScroll = scrollTop > 1;\n showEndScroll = scrollTop < scrollHeight - clientHeight - 1;\n } else {\n var scrollLeft = getNormalizedScrollLeft(tabsRef.current, theme.direction); // use 1 for the potential rounding error with browser zooms.\n\n showStartScroll = isRtl ? scrollLeft < scrollWidth - clientWidth - 1 : scrollLeft > 1;\n showEndScroll = !isRtl ? scrollLeft < scrollWidth - clientWidth - 1 : scrollLeft > 1;\n }\n\n if (showStartScroll !== displayScroll.start || showEndScroll !== displayScroll.end) {\n setDisplayScroll({\n start: showStartScroll,\n end: showEndScroll\n });\n }\n }\n });\n React.useEffect(function () {\n var handleResize = debounce(function () {\n updateIndicatorState();\n updateScrollButtonState();\n });\n var win = ownerWindow(tabsRef.current);\n win.addEventListener('resize', handleResize);\n return function () {\n handleResize.clear();\n win.removeEventListener('resize', handleResize);\n };\n }, [updateIndicatorState, updateScrollButtonState]);\n var handleTabsScroll = React.useCallback(debounce(function () {\n updateScrollButtonState();\n }));\n React.useEffect(function () {\n return function () {\n handleTabsScroll.clear();\n };\n }, [handleTabsScroll]);\n React.useEffect(function () {\n setMounted(true);\n }, []);\n React.useEffect(function () {\n updateIndicatorState();\n updateScrollButtonState();\n });\n React.useEffect(function () {\n scrollSelectedIntoView();\n }, [scrollSelectedIntoView, indicatorStyle]);\n React.useImperativeHandle(action, function () {\n return {\n updateIndicator: updateIndicatorState,\n updateScrollButtons: updateScrollButtonState\n };\n }, [updateIndicatorState, updateScrollButtonState]);\n var indicator = /*#__PURE__*/React.createElement(TabIndicator, _extends({\n className: classes.indicator,\n orientation: orientation,\n color: indicatorColor\n }, TabIndicatorProps, {\n style: _extends({}, indicatorStyle, TabIndicatorProps.style)\n }));\n var childIndex = 0;\n var children = React.Children.map(childrenProp, function (child) {\n if (! /*#__PURE__*/React.isValidElement(child)) {\n return null;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (isFragment(child)) {\n console.error([\"Material-UI: The Tabs component doesn't accept a Fragment as a child.\", 'Consider providing an array instead.'].join('\\n'));\n }\n }\n\n var childValue = child.props.value === undefined ? childIndex : child.props.value;\n valueToIndex.set(childValue, childIndex);\n var selected = childValue === value;\n childIndex += 1;\n return /*#__PURE__*/React.cloneElement(child, {\n fullWidth: variant === 'fullWidth',\n indicator: selected && !mounted && indicator,\n selected: selected,\n selectionFollowsFocus: selectionFollowsFocus,\n onChange: onChange,\n textColor: textColor,\n value: childValue\n });\n });\n\n var handleKeyDown = function handleKeyDown(event) {\n var target = event.target; // Keyboard navigation assumes that [role=\"tab\"] are siblings\n // though we might warn in the future about nested, interactive elements\n // as a a11y violation\n\n var role = target.getAttribute('role');\n\n if (role !== 'tab') {\n return;\n }\n\n var newFocusTarget = null;\n var previousItemKey = orientation !== \"vertical\" ? 'ArrowLeft' : 'ArrowUp';\n var nextItemKey = orientation !== \"vertical\" ? 'ArrowRight' : 'ArrowDown';\n\n if (orientation !== \"vertical\" && theme.direction === 'rtl') {\n // swap previousItemKey with nextItemKey\n previousItemKey = 'ArrowRight';\n nextItemKey = 'ArrowLeft';\n }\n\n switch (event.key) {\n case previousItemKey:\n newFocusTarget = target.previousElementSibling || tabListRef.current.lastChild;\n break;\n\n case nextItemKey:\n newFocusTarget = target.nextElementSibling || tabListRef.current.firstChild;\n break;\n\n case 'Home':\n newFocusTarget = tabListRef.current.firstChild;\n break;\n\n case 'End':\n newFocusTarget = tabListRef.current.lastChild;\n break;\n\n default:\n break;\n }\n\n if (newFocusTarget !== null) {\n newFocusTarget.focus();\n event.preventDefault();\n }\n };\n\n var conditionalElements = getConditionalElements();\n return /*#__PURE__*/React.createElement(Component, _extends({\n className: clsx(classes.root, className, vertical && classes.vertical),\n ref: ref\n }, other), conditionalElements.scrollButtonStart, conditionalElements.scrollbarSizeListener, /*#__PURE__*/React.createElement(\"div\", {\n className: clsx(classes.scroller, scrollable ? classes.scrollable : classes.fixed),\n style: scrollerStyle,\n ref: tabsRef,\n onScroll: handleTabsScroll\n }, /*#__PURE__*/React.createElement(\"div\", {\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n className: clsx(classes.flexContainer, vertical && classes.flexContainerVertical, centered && !scrollable && classes.centered),\n onKeyDown: handleKeyDown,\n ref: tabListRef,\n role: \"tablist\"\n }, children), mounted && indicator), conditionalElements.scrollButtonEnd);\n});\nprocess.env.NODE_ENV !== \"production\" ? Tabs.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 * Callback fired when the component mounts.\n * This is useful when you want to trigger an action programmatically.\n * It supports two actions: `updateIndicator()` and `updateScrollButtons()`\n *\n * @param {object} actions This object contains all possible actions\n * that can be triggered programmatically.\n */\n action: refType,\n\n /**\n * The label for the Tabs as a string.\n */\n 'aria-label': PropTypes.string,\n\n /**\n * An id or list of ids separated by a space that label the Tabs.\n */\n 'aria-labelledby': PropTypes.string,\n\n /**\n * If `true`, the tabs will be centered.\n * This property is intended for large views.\n */\n centered: PropTypes.bool,\n\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes\n /* @typescript-to-proptypes-ignore */\n .elementType,\n\n /**\n * Determines the color of the indicator.\n */\n indicatorColor: PropTypes.oneOf(['primary', 'secondary']),\n\n /**\n * Callback fired when the value changes.\n *\n * @param {object} event The event source of the callback\n * @param {any} value We default to the index of the child (number)\n */\n onChange: PropTypes.func,\n\n /**\n * The tabs orientation (layout flow direction).\n */\n orientation: PropTypes.oneOf(['horizontal', 'vertical']),\n\n /**\n * The component used to render the scroll buttons.\n */\n ScrollButtonComponent: PropTypes.elementType,\n\n /**\n * Determine behavior of scroll buttons when tabs are set to scroll:\n *\n * - `auto` will only present them when not all the items are visible.\n * - `desktop` will only present them on medium and larger viewports.\n * - `on` will always present them.\n * - `off` will never present them.\n */\n scrollButtons: PropTypes.oneOf(['auto', 'desktop', 'off', 'on']),\n\n /**\n * If `true` the selected tab changes on focus. Otherwise it only\n * changes on activation.\n */\n selectionFollowsFocus: PropTypes.bool,\n\n /**\n * Props applied to the tab indicator element.\n */\n TabIndicatorProps: PropTypes.object,\n\n /**\n * Props applied to the [`TabScrollButton`](/api/tab-scroll-button/) element.\n */\n TabScrollButtonProps: PropTypes.object,\n\n /**\n * Determines the color of the `Tab`.\n */\n textColor: PropTypes.oneOf(['inherit', 'primary', 'secondary']),\n\n /**\n * The value of the currently selected `Tab`.\n * If you don't want any selected `Tab`, you can set this property to `false`.\n */\n value: PropTypes.any,\n\n /**\n * Determines additional display behavior of the tabs:\n *\n * - `scrollable` will invoke scrolling properties and allow for horizontally\n * scrolling (or swiping) of the tab bar.\n * -`fullWidth` will make the tabs grow to use all the available space,\n * which should be used for small views, like on mobile.\n * - `standard` will render the default state.\n */\n variant: PropTypes.oneOf(['fullWidth', 'scrollable', 'standard'])\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiTabs'\n})(Tabs);"],"sourceRoot":""}