{"version":3,"sources":["../node_modules/@material-ui/lab/esm/internal/svg-icons/Close.js","../node_modules/@material-ui/lab/esm/internal/svg-icons/ArrowDropDown.js","../node_modules/@material-ui/lab/esm/useAutocomplete/useAutocomplete.js","../node_modules/@material-ui/lab/esm/Autocomplete/Autocomplete.js"],"names":["createSvgIcon","React","d","stripDiacritics","string","normalize","replace","findIndex","array","comp","i","length","defaultFilterOptions","config","arguments","undefined","_config$ignoreAccents","ignoreAccents","_config$ignoreCase","ignoreCase","limit","_config$matchFrom","matchFrom","stringify","_config$trim","trim","options","_ref","inputValue","getOptionLabel","input","toLowerCase","filteredOptions","filter","option","candidate","indexOf","slice","createFilterOptions","useAutocomplete","props","_props$autoComplete","autoComplete","_props$autoHighlight","autoHighlight","_props$autoSelect","autoSelect","_props$blurOnSelect","blurOnSelect","_props$clearOnBlur","clearOnBlur","freeSolo","_props$clearOnEscape","clearOnEscape","_props$componentName","componentName","_props$debug","debug","_props$defaultValue","defaultValue","multiple","_props$disableClearab","disableClearable","_props$disableCloseOn","disableCloseOnSelect","_props$disabledItemsF","disabledItemsFocusable","_props$disableListWra","disableListWrap","_props$filterOptions","filterOptions","_props$filterSelected","filterSelectedOptions","_props$freeSolo","getOptionDisabled","_props$getOptionLabel","getOptionLabelProp","_props$getOptionSelec","getOptionSelected","value","groupBy","_props$handleHomeEndK","handleHomeEndKeys","idProp","id","_props$includeInputIn","includeInputInList","inputValueProp","_props$multiple","onChange","onClose","onHighlightChange","onInputChange","onOpen","openProp","open","_props$openOnFocus","openOnFocus","_props$selectOnFocus","selectOnFocus","valueProp","useId","ignoreFocus","firstFocus","inputRef","listboxRef","_React$useState","anchorEl","setAnchorEl","_React$useState2","focusedTag","setFocusedTag","defaultHighlighted","highlightedIndexRef","_useControlled","useControlled","controlled","default","name","_useControlled2","_slicedToArray","setValue","_useControlled3","state","_useControlled4","setInputValue","_React$useState3","focused","setFocused","resetInputValue","useEventCallback","event","newValue","newInputValue","optionLabel","_useControlled5","_useControlled6","setOpenState","inputValueIsSelectedValue","popupOpen","some","value2","focusTag","tagToFocus","current","focus","querySelector","concat","setHighlightedIndex","_ref2","index","_ref2$reason","reason","removeAttribute","setAttribute","prev","listboxNode","parentElement","scrollHeight","clientHeight","element","scrollBottom","scrollTop","elementBottom","offsetTop","offsetHeight","changeHighlightedIndex","_ref3","diff","_ref3$direction","direction","_ref3$reason","nextIndex","nextFocus","nextFocusDisabled","disabled","getAttribute","hasAttribute","validOptionIndex","maxIndex","newIndex","Math","abs","getNextIndex","setSelectionRange","syncHighlightedIndex","valueItem","currentOption","val","itemIndex","optionItem","handleListboxRef","node","setRef","handleOpen","handleClose","handleValue","details","isTouch","selectNewValue","reasonProp","origin","Array","isArray","push","splice","blur","handleFocusTag","nextTag","validTagIndex","handleClear","handleKeyDown","other","key","preventDefault","which","stopPropagation","onKeyDown","handleFocus","handleBlur","document","activeElement","handleInputChange","target","handleOptionMouseOver","Number","currentTarget","handleOptionTouchStart","handleOptionClick","handleTagDelete","handlePopupIndicator","handleMouseDown","handleClick","selectionEnd","selectionStart","select","handleInputMouseDown","dirty","groupedOptions","Map","reduce","acc","group","getRootProps","_extends","role","onMouseDown","onClick","getInputLabelProps","htmlFor","getInputProps","onBlur","onFocus","ref","autoCapitalize","spellCheck","getClearProps","tabIndex","getPopupIndicatorProps","getTagProps","_ref4","onDelete","getListboxProps","getOptionProps","_ref5","selected","onMouseOver","onTouchStart","DisablePortal","_objectWithoutProperties","CloseIcon","fontSize","ArrowDropDownIcon","Autocomplete","startAdornment","ChipProps","classes","className","_props$clearText","clearText","_props$closeIcon","closeIcon","_props$closeText","closeText","_props$disabled","_props$disablePortal","disablePortal","_props$forcePopupIcon","forcePopupIcon","_props$fullWidth","fullWidth","_props$getLimitTagsTe","getLimitTagsText","more","x","_props$limitTags","limitTags","_props$ListboxCompone","ListboxComponent","ListboxProps","_props$loading","loading","_props$loadingText","loadingText","_props$noOptionsText","noOptionsText","_props$openText","openText","_props$PaperComponent","PaperComponent","Paper","_props$PopperComponen","PopperComponent","PopperComponentProp","Popper","_props$popupIcon","popupIcon","renderGroupProp","renderGroup","renderInput","renderOptionProp","renderOption","renderTags","_props$size","size","_useAutocomplete","getCustomizedTagProps","params","clsx","tag","tagSizeSmall","map","Chip","label","ListSubheader","groupLabel","component","groupUl","children","renderListOption","optionProps","hasClearIcon","hasPopupIcon","root","InputLabelProps","InputProps","inputRoot","endAdornment","IconButton","title","clearIndicator","clearIndicatorDirty","popupIndicator","popupIndicatorOpen","inputProps","inputFocused","popper","popperDisablePortal","style","width","clientWidth","paper","noOptions","listbox","option2","index2","withStyles","theme","_option","visibility","margin","maxWidth","flexWrap","paddingRight","minWidth","paddingBottom","padding","paddingLeft","right","paddingTop","flexGrow","textOverflow","opacity","position","top","marginRight","transform","zIndex","modal","typography","body1","overflow","listStyle","maxHeight","color","palette","text","secondary","minHeight","display","justifyContent","alignItems","cursor","boxSizing","outline","WebkitTapHighlightColor","_defineProperty","breakpoints","up","backgroundColor","action","hover","disabledOpacity","pointerEvents","background"],"mappings":"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","file":"static/js/1.4679cf47.chunk.js","sourcesContent":["import * as React from 'react';\nimport { createSvgIcon } from '@material-ui/core/utils';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"\n}), 'Close');","import * as React from 'react';\nimport { createSvgIcon } from '@material-ui/core/utils';\n/**\n * @ignore - internal component.\n */\n\nexport default createSvgIcon( /*#__PURE__*/React.createElement(\"path\", {\n d: \"M7 10l5 5 5-5z\"\n}), 'ArrowDropDown');","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _slicedToArray from \"@babel/runtime/helpers/esm/slicedToArray\";\nimport _typeof from \"@babel/runtime/helpers/esm/typeof\";\n\n/* eslint-disable no-constant-condition */\nimport * as React from 'react';\nimport { setRef, useEventCallback, useControlled, unstable_useId as useId } from '@material-ui/core/utils'; // https://stackoverflow.com/questions/990904/remove-accents-diacritics-in-a-string-in-javascript\n// Give up on IE 11 support for this feature\n\nfunction stripDiacritics(string) {\n return typeof string.normalize !== 'undefined' ? string.normalize('NFD').replace(/[\\u0300-\\u036f]/g, '') : string;\n}\n\nexport function createFilterOptions() {\n var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var _config$ignoreAccents = config.ignoreAccents,\n ignoreAccents = _config$ignoreAccents === void 0 ? true : _config$ignoreAccents,\n _config$ignoreCase = config.ignoreCase,\n ignoreCase = _config$ignoreCase === void 0 ? true : _config$ignoreCase,\n limit = config.limit,\n _config$matchFrom = config.matchFrom,\n matchFrom = _config$matchFrom === void 0 ? 'any' : _config$matchFrom,\n stringify = config.stringify,\n _config$trim = config.trim,\n trim = _config$trim === void 0 ? false : _config$trim;\n return function (options, _ref) {\n var inputValue = _ref.inputValue,\n getOptionLabel = _ref.getOptionLabel;\n var input = trim ? inputValue.trim() : inputValue;\n\n if (ignoreCase) {\n input = input.toLowerCase();\n }\n\n if (ignoreAccents) {\n input = stripDiacritics(input);\n }\n\n var filteredOptions = options.filter(function (option) {\n var candidate = (stringify || getOptionLabel)(option);\n\n if (ignoreCase) {\n candidate = candidate.toLowerCase();\n }\n\n if (ignoreAccents) {\n candidate = stripDiacritics(candidate);\n }\n\n return matchFrom === 'start' ? candidate.indexOf(input) === 0 : candidate.indexOf(input) > -1;\n });\n return typeof limit === 'number' ? filteredOptions.slice(0, limit) : filteredOptions;\n };\n} // To replace with .findIndex() once we stop IE 11 support.\n\nfunction findIndex(array, comp) {\n for (var i = 0; i < array.length; i += 1) {\n if (comp(array[i])) {\n return i;\n }\n }\n\n return -1;\n}\n\nvar defaultFilterOptions = createFilterOptions(); // Number of options to jump in list box when pageup and pagedown keys are used.\n\nvar pageSize = 5;\nexport default function useAutocomplete(props) {\n var _props$autoComplete = props.autoComplete,\n autoComplete = _props$autoComplete === void 0 ? false : _props$autoComplete,\n _props$autoHighlight = props.autoHighlight,\n autoHighlight = _props$autoHighlight === void 0 ? false : _props$autoHighlight,\n _props$autoSelect = props.autoSelect,\n autoSelect = _props$autoSelect === void 0 ? false : _props$autoSelect,\n _props$blurOnSelect = props.blurOnSelect,\n blurOnSelect = _props$blurOnSelect === void 0 ? false : _props$blurOnSelect,\n _props$clearOnBlur = props.clearOnBlur,\n clearOnBlur = _props$clearOnBlur === void 0 ? !props.freeSolo : _props$clearOnBlur,\n _props$clearOnEscape = props.clearOnEscape,\n clearOnEscape = _props$clearOnEscape === void 0 ? false : _props$clearOnEscape,\n _props$componentName = props.componentName,\n componentName = _props$componentName === void 0 ? 'useAutocomplete' : _props$componentName,\n _props$debug = props.debug,\n debug = _props$debug === void 0 ? false : _props$debug,\n _props$defaultValue = props.defaultValue,\n defaultValue = _props$defaultValue === void 0 ? props.multiple ? [] : null : _props$defaultValue,\n _props$disableClearab = props.disableClearable,\n disableClearable = _props$disableClearab === void 0 ? false : _props$disableClearab,\n _props$disableCloseOn = props.disableCloseOnSelect,\n disableCloseOnSelect = _props$disableCloseOn === void 0 ? false : _props$disableCloseOn,\n _props$disabledItemsF = props.disabledItemsFocusable,\n disabledItemsFocusable = _props$disabledItemsF === void 0 ? false : _props$disabledItemsF,\n _props$disableListWra = props.disableListWrap,\n disableListWrap = _props$disableListWra === void 0 ? false : _props$disableListWra,\n _props$filterOptions = props.filterOptions,\n filterOptions = _props$filterOptions === void 0 ? defaultFilterOptions : _props$filterOptions,\n _props$filterSelected = props.filterSelectedOptions,\n filterSelectedOptions = _props$filterSelected === void 0 ? false : _props$filterSelected,\n _props$freeSolo = props.freeSolo,\n freeSolo = _props$freeSolo === void 0 ? false : _props$freeSolo,\n getOptionDisabled = props.getOptionDisabled,\n _props$getOptionLabel = props.getOptionLabel,\n getOptionLabelProp = _props$getOptionLabel === void 0 ? function (option) {\n return option;\n } : _props$getOptionLabel,\n _props$getOptionSelec = props.getOptionSelected,\n getOptionSelected = _props$getOptionSelec === void 0 ? function (option, value) {\n return option === value;\n } : _props$getOptionSelec,\n groupBy = props.groupBy,\n _props$handleHomeEndK = props.handleHomeEndKeys,\n handleHomeEndKeys = _props$handleHomeEndK === void 0 ? !props.freeSolo : _props$handleHomeEndK,\n idProp = props.id,\n _props$includeInputIn = props.includeInputInList,\n includeInputInList = _props$includeInputIn === void 0 ? false : _props$includeInputIn,\n inputValueProp = props.inputValue,\n _props$multiple = props.multiple,\n multiple = _props$multiple === void 0 ? false : _props$multiple,\n onChange = props.onChange,\n onClose = props.onClose,\n onHighlightChange = props.onHighlightChange,\n onInputChange = props.onInputChange,\n onOpen = props.onOpen,\n openProp = props.open,\n _props$openOnFocus = props.openOnFocus,\n openOnFocus = _props$openOnFocus === void 0 ? false : _props$openOnFocus,\n options = props.options,\n _props$selectOnFocus = props.selectOnFocus,\n selectOnFocus = _props$selectOnFocus === void 0 ? !props.freeSolo : _props$selectOnFocus,\n valueProp = props.value;\n var id = useId(idProp);\n var getOptionLabel = getOptionLabelProp;\n\n if (process.env.NODE_ENV !== 'production') {\n getOptionLabel = function getOptionLabel(option) {\n var optionLabel = getOptionLabelProp(option);\n\n if (typeof optionLabel !== 'string') {\n var erroneousReturn = optionLabel === undefined ? 'undefined' : \"\".concat(_typeof(optionLabel), \" (\").concat(optionLabel, \")\");\n console.error(\"Material-UI: The `getOptionLabel` method of \".concat(componentName, \" returned \").concat(erroneousReturn, \" instead of a string for \").concat(JSON.stringify(option), \".\"));\n }\n\n return optionLabel;\n };\n }\n\n var ignoreFocus = React.useRef(false);\n var firstFocus = React.useRef(true);\n var inputRef = React.useRef(null);\n var listboxRef = React.useRef(null);\n\n var _React$useState = React.useState(null),\n anchorEl = _React$useState[0],\n setAnchorEl = _React$useState[1];\n\n var _React$useState2 = React.useState(-1),\n focusedTag = _React$useState2[0],\n setFocusedTag = _React$useState2[1];\n\n var defaultHighlighted = autoHighlight ? 0 : -1;\n var highlightedIndexRef = React.useRef(defaultHighlighted);\n\n var _useControlled = useControlled({\n controlled: valueProp,\n default: defaultValue,\n name: componentName\n }),\n _useControlled2 = _slicedToArray(_useControlled, 2),\n value = _useControlled2[0],\n setValue = _useControlled2[1];\n\n var _useControlled3 = useControlled({\n controlled: inputValueProp,\n default: '',\n name: componentName,\n state: 'inputValue'\n }),\n _useControlled4 = _slicedToArray(_useControlled3, 2),\n inputValue = _useControlled4[0],\n setInputValue = _useControlled4[1];\n\n var _React$useState3 = React.useState(false),\n focused = _React$useState3[0],\n setFocused = _React$useState3[1];\n\n var resetInputValue = useEventCallback(function (event, newValue) {\n var newInputValue;\n\n if (multiple) {\n newInputValue = '';\n } else if (newValue == null) {\n newInputValue = '';\n } else {\n var optionLabel = getOptionLabel(newValue);\n newInputValue = typeof optionLabel === 'string' ? optionLabel : '';\n }\n\n if (inputValue === newInputValue) {\n return;\n }\n\n setInputValue(newInputValue);\n\n if (onInputChange) {\n onInputChange(event, newInputValue, 'reset');\n }\n });\n React.useEffect(function () {\n resetInputValue(null, value);\n }, [value, resetInputValue]);\n\n var _useControlled5 = useControlled({\n controlled: openProp,\n default: false,\n name: componentName,\n state: 'open'\n }),\n _useControlled6 = _slicedToArray(_useControlled5, 2),\n open = _useControlled6[0],\n setOpenState = _useControlled6[1];\n\n var inputValueIsSelectedValue = !multiple && value != null && inputValue === getOptionLabel(value);\n var popupOpen = open;\n var filteredOptions = popupOpen ? filterOptions(options.filter(function (option) {\n if (filterSelectedOptions && (multiple ? value : [value]).some(function (value2) {\n return value2 !== null && getOptionSelected(option, value2);\n })) {\n return false;\n }\n\n return true;\n }), // we use the empty string to manipulate `filterOptions` to not filter any options\n // i.e. the filter predicate always returns true\n {\n inputValue: inputValueIsSelectedValue ? '' : inputValue,\n getOptionLabel: getOptionLabel\n }) : [];\n\n if (process.env.NODE_ENV !== 'production') {\n if (value !== null && !freeSolo && options.length > 0) {\n var missingValue = (multiple ? value : [value]).filter(function (value2) {\n return !options.some(function (option) {\n return getOptionSelected(option, value2);\n });\n });\n\n if (missingValue.length > 0) {\n console.warn([\"Material-UI: The value provided to \".concat(componentName, \" is invalid.\"), \"None of the options match with `\".concat(missingValue.length > 1 ? JSON.stringify(missingValue) : JSON.stringify(missingValue[0]), \"`.\"), 'You can use the `getOptionSelected` prop to customize the equality test.'].join('\\n'));\n }\n }\n }\n\n var focusTag = useEventCallback(function (tagToFocus) {\n if (tagToFocus === -1) {\n inputRef.current.focus();\n } else {\n anchorEl.querySelector(\"[data-tag-index=\\\"\".concat(tagToFocus, \"\\\"]\")).focus();\n }\n }); // Ensure the focusedTag is never inconsistent\n\n React.useEffect(function () {\n if (multiple && focusedTag > value.length - 1) {\n setFocusedTag(-1);\n focusTag(-1);\n }\n }, [value, multiple, focusedTag, focusTag]);\n\n function validOptionIndex(index, direction) {\n if (!listboxRef.current || index === -1) {\n return -1;\n }\n\n var nextFocus = index;\n\n while (true) {\n // Out of range\n if (direction === 'next' && nextFocus === filteredOptions.length || direction === 'previous' && nextFocus === -1) {\n return -1;\n }\n\n var option = listboxRef.current.querySelector(\"[data-option-index=\\\"\".concat(nextFocus, \"\\\"]\")); // Same logic as MenuList.js\n\n var nextFocusDisabled = disabledItemsFocusable ? false : option && (option.disabled || option.getAttribute('aria-disabled') === 'true');\n\n if (option && !option.hasAttribute('tabindex') || nextFocusDisabled) {\n // Move to the next element.\n nextFocus += direction === 'next' ? 1 : -1;\n } else {\n return nextFocus;\n }\n }\n }\n\n var setHighlightedIndex = useEventCallback(function (_ref2) {\n var event = _ref2.event,\n index = _ref2.index,\n _ref2$reason = _ref2.reason,\n reason = _ref2$reason === void 0 ? 'auto' : _ref2$reason;\n highlightedIndexRef.current = index; // does the index exist?\n\n if (index === -1) {\n inputRef.current.removeAttribute('aria-activedescendant');\n } else {\n inputRef.current.setAttribute('aria-activedescendant', \"\".concat(id, \"-option-\").concat(index));\n }\n\n if (onHighlightChange) {\n onHighlightChange(event, index === -1 ? null : filteredOptions[index], reason);\n }\n\n if (!listboxRef.current) {\n return;\n }\n\n var prev = listboxRef.current.querySelector('[data-focus]');\n\n if (prev) {\n prev.removeAttribute('data-focus');\n }\n\n var listboxNode = listboxRef.current.parentElement.querySelector('[role=\"listbox\"]'); // \"No results\"\n\n if (!listboxNode) {\n return;\n }\n\n if (index === -1) {\n listboxNode.scrollTop = 0;\n return;\n }\n\n var option = listboxRef.current.querySelector(\"[data-option-index=\\\"\".concat(index, \"\\\"]\"));\n\n if (!option) {\n return;\n }\n\n option.setAttribute('data-focus', 'true'); // Scroll active descendant into view.\n // Logic copied from https://www.w3.org/TR/wai-aria-practices/examples/listbox/js/listbox.js\n //\n // Consider this API instead once it has a better browser support:\n // .scrollIntoView({ scrollMode: 'if-needed', block: 'nearest' });\n\n if (listboxNode.scrollHeight > listboxNode.clientHeight && reason !== 'mouse') {\n var element = option;\n var scrollBottom = listboxNode.clientHeight + listboxNode.scrollTop;\n var elementBottom = element.offsetTop + element.offsetHeight;\n\n if (elementBottom > scrollBottom) {\n listboxNode.scrollTop = elementBottom - listboxNode.clientHeight;\n } else if (element.offsetTop - element.offsetHeight * (groupBy ? 1.3 : 0) < listboxNode.scrollTop) {\n listboxNode.scrollTop = element.offsetTop - element.offsetHeight * (groupBy ? 1.3 : 0);\n }\n }\n });\n var changeHighlightedIndex = useEventCallback(function (_ref3) {\n var event = _ref3.event,\n diff = _ref3.diff,\n _ref3$direction = _ref3.direction,\n direction = _ref3$direction === void 0 ? 'next' : _ref3$direction,\n _ref3$reason = _ref3.reason,\n reason = _ref3$reason === void 0 ? 'auto' : _ref3$reason;\n\n if (!popupOpen) {\n return;\n }\n\n var getNextIndex = function getNextIndex() {\n var maxIndex = filteredOptions.length - 1;\n\n if (diff === 'reset') {\n return defaultHighlighted;\n }\n\n if (diff === 'start') {\n return 0;\n }\n\n if (diff === 'end') {\n return maxIndex;\n }\n\n var newIndex = highlightedIndexRef.current + diff;\n\n if (newIndex < 0) {\n if (newIndex === -1 && includeInputInList) {\n return -1;\n }\n\n if (disableListWrap && highlightedIndexRef.current !== -1 || Math.abs(diff) > 1) {\n return 0;\n }\n\n return maxIndex;\n }\n\n if (newIndex > maxIndex) {\n if (newIndex === maxIndex + 1 && includeInputInList) {\n return -1;\n }\n\n if (disableListWrap || Math.abs(diff) > 1) {\n return maxIndex;\n }\n\n return 0;\n }\n\n return newIndex;\n };\n\n var nextIndex = validOptionIndex(getNextIndex(), direction);\n setHighlightedIndex({\n index: nextIndex,\n reason: reason,\n event: event\n }); // Sync the content of the input with the highlighted option.\n\n if (autoComplete && diff !== 'reset') {\n if (nextIndex === -1) {\n inputRef.current.value = inputValue;\n } else {\n var option = getOptionLabel(filteredOptions[nextIndex]);\n inputRef.current.value = option; // The portion of the selected suggestion that has not been typed by the user,\n // a completion string, appears inline after the input cursor in the textbox.\n\n var index = option.toLowerCase().indexOf(inputValue.toLowerCase());\n\n if (index === 0 && inputValue.length > 0) {\n inputRef.current.setSelectionRange(inputValue.length, option.length);\n }\n }\n }\n });\n var syncHighlightedIndex = React.useCallback(function () {\n if (!popupOpen) {\n return;\n }\n\n var valueItem = multiple ? value[0] : value; // The popup is empty, reset\n\n if (filteredOptions.length === 0 || valueItem == null) {\n changeHighlightedIndex({\n diff: 'reset'\n });\n return;\n }\n\n if (!listboxRef.current) {\n return;\n } // Synchronize the value with the highlighted index\n\n\n if (!filterSelectedOptions && valueItem != null) {\n var currentOption = filteredOptions[highlightedIndexRef.current]; // Keep the current highlighted index if possible\n\n if (multiple && currentOption && findIndex(value, function (val) {\n return getOptionSelected(currentOption, val);\n }) !== -1) {\n return;\n }\n\n var itemIndex = findIndex(filteredOptions, function (optionItem) {\n return getOptionSelected(optionItem, valueItem);\n });\n\n if (itemIndex === -1) {\n changeHighlightedIndex({\n diff: 'reset'\n });\n } else {\n setHighlightedIndex({\n index: itemIndex\n });\n }\n\n return;\n } // Prevent the highlighted index to leak outside the boundaries.\n\n\n if (highlightedIndexRef.current >= filteredOptions.length - 1) {\n setHighlightedIndex({\n index: filteredOptions.length - 1\n });\n return;\n } // Restore the focus to the previous index.\n\n\n setHighlightedIndex({\n index: highlightedIndexRef.current\n }); // Ignore filteredOptions (and options, getOptionSelected, getOptionLabel) not to break the scroll position\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [// Only sync the highlighted index when the option switch between empty and not\n // eslint-disable-next-line react-hooks/exhaustive-deps\n filteredOptions.length === 0, // Don't sync the highlighted index with the value when multiple\n // eslint-disable-next-line react-hooks/exhaustive-deps\n multiple ? false : value, filterSelectedOptions, changeHighlightedIndex, setHighlightedIndex, popupOpen, inputValue, multiple]);\n var handleListboxRef = useEventCallback(function (node) {\n setRef(listboxRef, node);\n\n if (!node) {\n return;\n }\n\n syncHighlightedIndex();\n });\n React.useEffect(function () {\n syncHighlightedIndex();\n }, [syncHighlightedIndex]);\n\n var handleOpen = function handleOpen(event) {\n if (open) {\n return;\n }\n\n setOpenState(true);\n\n if (onOpen) {\n onOpen(event);\n }\n };\n\n var handleClose = function handleClose(event, reason) {\n if (!open) {\n return;\n }\n\n setOpenState(false);\n\n if (onClose) {\n onClose(event, reason);\n }\n };\n\n var handleValue = function handleValue(event, newValue, reason, details) {\n if (value === newValue) {\n return;\n }\n\n if (onChange) {\n onChange(event, newValue, reason, details);\n }\n\n setValue(newValue);\n };\n\n var isTouch = React.useRef(false);\n\n var selectNewValue = function selectNewValue(event, option) {\n var reasonProp = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'select-option';\n var origin = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'options';\n var reason = reasonProp;\n var newValue = option;\n\n if (multiple) {\n newValue = Array.isArray(value) ? value.slice() : [];\n\n if (process.env.NODE_ENV !== 'production') {\n var matches = newValue.filter(function (val) {\n return getOptionSelected(option, val);\n });\n\n if (matches.length > 1) {\n console.error([\"Material-UI: The `getOptionSelected` method of \".concat(componentName, \" do not handle the arguments correctly.\"), \"The component expects a single value to match a given option but found \".concat(matches.length, \" matches.\")].join('\\n'));\n }\n }\n\n var itemIndex = findIndex(newValue, function (valueItem) {\n return getOptionSelected(option, valueItem);\n });\n\n if (itemIndex === -1) {\n newValue.push(option);\n } else if (origin !== 'freeSolo') {\n newValue.splice(itemIndex, 1);\n reason = 'remove-option';\n }\n }\n\n resetInputValue(event, newValue);\n handleValue(event, newValue, reason, {\n option: option\n });\n\n if (!disableCloseOnSelect) {\n handleClose(event, reason);\n }\n\n if (blurOnSelect === true || blurOnSelect === 'touch' && isTouch.current || blurOnSelect === 'mouse' && !isTouch.current) {\n inputRef.current.blur();\n }\n };\n\n function validTagIndex(index, direction) {\n if (index === -1) {\n return -1;\n }\n\n var nextFocus = index;\n\n while (true) {\n // Out of range\n if (direction === 'next' && nextFocus === value.length || direction === 'previous' && nextFocus === -1) {\n return -1;\n }\n\n var option = anchorEl.querySelector(\"[data-tag-index=\\\"\".concat(nextFocus, \"\\\"]\")); // Same logic as MenuList.js\n\n if (option && (!option.hasAttribute('tabindex') || option.disabled || option.getAttribute('aria-disabled') === 'true')) {\n nextFocus += direction === 'next' ? 1 : -1;\n } else {\n return nextFocus;\n }\n }\n }\n\n var handleFocusTag = function handleFocusTag(event, direction) {\n if (!multiple) {\n return;\n }\n\n handleClose(event, 'toggleInput');\n var nextTag = focusedTag;\n\n if (focusedTag === -1) {\n if (inputValue === '' && direction === 'previous') {\n nextTag = value.length - 1;\n }\n } else {\n nextTag += direction === 'next' ? 1 : -1;\n\n if (nextTag < 0) {\n nextTag = 0;\n }\n\n if (nextTag === value.length) {\n nextTag = -1;\n }\n }\n\n nextTag = validTagIndex(nextTag, direction);\n setFocusedTag(nextTag);\n focusTag(nextTag);\n };\n\n var handleClear = function handleClear(event) {\n ignoreFocus.current = true;\n setInputValue('');\n\n if (onInputChange) {\n onInputChange(event, '', 'clear');\n }\n\n handleValue(event, multiple ? [] : null, 'clear');\n };\n\n var handleKeyDown = function handleKeyDown(other) {\n return function (event) {\n if (focusedTag !== -1 && ['ArrowLeft', 'ArrowRight'].indexOf(event.key) === -1) {\n setFocusedTag(-1);\n focusTag(-1);\n }\n\n switch (event.key) {\n case 'Home':\n if (popupOpen && handleHomeEndKeys) {\n // Prevent scroll of the page\n event.preventDefault();\n changeHighlightedIndex({\n diff: 'start',\n direction: 'next',\n reason: 'keyboard',\n event: event\n });\n }\n\n break;\n\n case 'End':\n if (popupOpen && handleHomeEndKeys) {\n // Prevent scroll of the page\n event.preventDefault();\n changeHighlightedIndex({\n diff: 'end',\n direction: 'previous',\n reason: 'keyboard',\n event: event\n });\n }\n\n break;\n\n case 'PageUp':\n // Prevent scroll of the page\n event.preventDefault();\n changeHighlightedIndex({\n diff: -pageSize,\n direction: 'previous',\n reason: 'keyboard',\n event: event\n });\n handleOpen(event);\n break;\n\n case 'PageDown':\n // Prevent scroll of the page\n event.preventDefault();\n changeHighlightedIndex({\n diff: pageSize,\n direction: 'next',\n reason: 'keyboard',\n event: event\n });\n handleOpen(event);\n break;\n\n case 'ArrowDown':\n // Prevent cursor move\n event.preventDefault();\n changeHighlightedIndex({\n diff: 1,\n direction: 'next',\n reason: 'keyboard',\n event: event\n });\n handleOpen(event);\n break;\n\n case 'ArrowUp':\n // Prevent cursor move\n event.preventDefault();\n changeHighlightedIndex({\n diff: -1,\n direction: 'previous',\n reason: 'keyboard',\n event: event\n });\n handleOpen(event);\n break;\n\n case 'ArrowLeft':\n handleFocusTag(event, 'previous');\n break;\n\n case 'ArrowRight':\n handleFocusTag(event, 'next');\n break;\n\n case 'Enter':\n // Wait until IME is settled.\n if (event.which === 229) {\n break;\n }\n\n if (highlightedIndexRef.current !== -1 && popupOpen) {\n var option = filteredOptions[highlightedIndexRef.current];\n var disabled = getOptionDisabled ? getOptionDisabled(option) : false; // We don't want to validate the form.\n\n event.preventDefault();\n\n if (disabled) {\n return;\n }\n\n selectNewValue(event, option, 'select-option'); // Move the selection to the end.\n\n if (autoComplete) {\n inputRef.current.setSelectionRange(inputRef.current.value.length, inputRef.current.value.length);\n }\n } else if (freeSolo && inputValue !== '' && inputValueIsSelectedValue === false) {\n if (multiple) {\n // Allow people to add new values before they submit the form.\n event.preventDefault();\n }\n\n selectNewValue(event, inputValue, 'create-option', 'freeSolo');\n }\n\n break;\n\n case 'Escape':\n if (popupOpen) {\n // Avoid Opera to exit fullscreen mode.\n event.preventDefault(); // Avoid the Modal to handle the event.\n\n event.stopPropagation();\n handleClose(event, 'escape');\n } else if (clearOnEscape && (inputValue !== '' || multiple && value.length > 0)) {\n // Avoid Opera to exit fullscreen mode.\n event.preventDefault(); // Avoid the Modal to handle the event.\n\n event.stopPropagation();\n handleClear(event);\n }\n\n break;\n\n case 'Backspace':\n if (multiple && inputValue === '' && value.length > 0) {\n var index = focusedTag === -1 ? value.length - 1 : focusedTag;\n var newValue = value.slice();\n newValue.splice(index, 1);\n handleValue(event, newValue, 'remove-option', {\n option: value[index]\n });\n }\n\n break;\n\n default:\n }\n\n if (other.onKeyDown) {\n other.onKeyDown(event);\n }\n };\n };\n\n var handleFocus = function handleFocus(event) {\n setFocused(true);\n\n if (openOnFocus && !ignoreFocus.current) {\n handleOpen(event);\n }\n };\n\n var handleBlur = function handleBlur(event) {\n // Ignore the event when using the scrollbar with IE 11\n if (listboxRef.current !== null && document.activeElement === listboxRef.current.parentElement) {\n inputRef.current.focus();\n return;\n }\n\n setFocused(false);\n firstFocus.current = true;\n ignoreFocus.current = false;\n\n if (debug && inputValue !== '') {\n return;\n }\n\n if (autoSelect && highlightedIndexRef.current !== -1 && popupOpen) {\n selectNewValue(event, filteredOptions[highlightedIndexRef.current], 'blur');\n } else if (autoSelect && freeSolo && inputValue !== '') {\n selectNewValue(event, inputValue, 'blur', 'freeSolo');\n } else if (clearOnBlur) {\n resetInputValue(event, value);\n }\n\n handleClose(event, 'blur');\n };\n\n var handleInputChange = function handleInputChange(event) {\n var newValue = event.target.value;\n\n if (inputValue !== newValue) {\n setInputValue(newValue);\n\n if (onInputChange) {\n onInputChange(event, newValue, 'input');\n }\n }\n\n if (newValue === '') {\n if (!disableClearable && !multiple) {\n handleValue(event, null, 'clear');\n }\n } else {\n handleOpen(event);\n }\n };\n\n var handleOptionMouseOver = function handleOptionMouseOver(event) {\n setHighlightedIndex({\n event: event,\n index: Number(event.currentTarget.getAttribute('data-option-index')),\n reason: 'mouse'\n });\n };\n\n var handleOptionTouchStart = function handleOptionTouchStart() {\n isTouch.current = true;\n };\n\n var handleOptionClick = function handleOptionClick(event) {\n var index = Number(event.currentTarget.getAttribute('data-option-index'));\n selectNewValue(event, filteredOptions[index], 'select-option');\n isTouch.current = false;\n };\n\n var handleTagDelete = function handleTagDelete(index) {\n return function (event) {\n var newValue = value.slice();\n newValue.splice(index, 1);\n handleValue(event, newValue, 'remove-option', {\n option: value[index]\n });\n };\n };\n\n var handlePopupIndicator = function handlePopupIndicator(event) {\n if (open) {\n handleClose(event, 'toggleInput');\n } else {\n handleOpen(event);\n }\n }; // Prevent input blur when interacting with the combobox\n\n\n var handleMouseDown = function handleMouseDown(event) {\n if (event.target.getAttribute('id') !== id) {\n event.preventDefault();\n }\n }; // Focus the input when interacting with the combobox\n\n\n var handleClick = function handleClick() {\n inputRef.current.focus();\n\n if (selectOnFocus && firstFocus.current && inputRef.current.selectionEnd - inputRef.current.selectionStart === 0) {\n inputRef.current.select();\n }\n\n firstFocus.current = false;\n };\n\n var handleInputMouseDown = function handleInputMouseDown(event) {\n if (inputValue === '' || !open) {\n handlePopupIndicator(event);\n }\n };\n\n var dirty = freeSolo && inputValue.length > 0;\n dirty = dirty || (multiple ? value.length > 0 : value !== null);\n var groupedOptions = filteredOptions;\n\n if (groupBy) {\n // used to keep track of key and indexes in the result array\n var indexBy = new Map();\n var warn = false;\n groupedOptions = filteredOptions.reduce(function (acc, option, index) {\n var group = groupBy(option);\n\n if (acc.length > 0 && acc[acc.length - 1].group === group) {\n acc[acc.length - 1].options.push(option);\n } else {\n if (process.env.NODE_ENV !== 'production') {\n if (indexBy.get(group) && !warn) {\n console.warn(\"Material-UI: The options provided combined with the `groupBy` method of \".concat(componentName, \" returns duplicated headers.\"), 'You can solve the issue by sorting the options with the output of `groupBy`.');\n warn = true;\n }\n\n indexBy.set(group, true);\n }\n\n acc.push({\n key: index,\n index: index,\n group: group,\n options: [option]\n });\n }\n\n return acc;\n }, []);\n }\n\n return {\n getRootProps: function getRootProps() {\n var other = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n return _extends({\n 'aria-owns': popupOpen ? \"\".concat(id, \"-popup\") : null,\n role: 'combobox',\n 'aria-expanded': popupOpen\n }, other, {\n onKeyDown: handleKeyDown(other),\n onMouseDown: handleMouseDown,\n onClick: handleClick\n });\n },\n getInputLabelProps: function getInputLabelProps() {\n return {\n id: \"\".concat(id, \"-label\"),\n htmlFor: id\n };\n },\n getInputProps: function getInputProps() {\n return {\n id: id,\n value: inputValue,\n onBlur: handleBlur,\n onFocus: handleFocus,\n onChange: handleInputChange,\n onMouseDown: handleInputMouseDown,\n // if open then this is handled imperativeley so don't let react override\n // only have an opinion about this when closed\n 'aria-activedescendant': popupOpen ? '' : null,\n 'aria-autocomplete': autoComplete ? 'both' : 'list',\n 'aria-controls': popupOpen ? \"\".concat(id, \"-popup\") : null,\n // Disable browser's suggestion that might overlap with the popup.\n // Handle autocomplete but not autofill.\n autoComplete: 'off',\n ref: inputRef,\n autoCapitalize: 'none',\n spellCheck: 'false'\n };\n },\n getClearProps: function getClearProps() {\n return {\n tabIndex: -1,\n onClick: handleClear\n };\n },\n getPopupIndicatorProps: function getPopupIndicatorProps() {\n return {\n tabIndex: -1,\n onClick: handlePopupIndicator\n };\n },\n getTagProps: function getTagProps(_ref4) {\n var index = _ref4.index;\n return {\n key: index,\n 'data-tag-index': index,\n tabIndex: -1,\n onDelete: handleTagDelete(index)\n };\n },\n getListboxProps: function getListboxProps() {\n return {\n role: 'listbox',\n id: \"\".concat(id, \"-popup\"),\n 'aria-labelledby': \"\".concat(id, \"-label\"),\n ref: handleListboxRef,\n onMouseDown: function onMouseDown(event) {\n // Prevent blur\n event.preventDefault();\n }\n };\n },\n getOptionProps: function getOptionProps(_ref5) {\n var index = _ref5.index,\n option = _ref5.option;\n var selected = (multiple ? value : [value]).some(function (value2) {\n return value2 != null && getOptionSelected(option, value2);\n });\n var disabled = getOptionDisabled ? getOptionDisabled(option) : false;\n return {\n key: index,\n tabIndex: -1,\n role: 'option',\n id: \"\".concat(id, \"-option-\").concat(index),\n onMouseOver: handleOptionMouseOver,\n onClick: handleOptionClick,\n onTouchStart: handleOptionTouchStart,\n 'data-option-index': index,\n 'aria-disabled': disabled,\n 'aria-selected': selected\n };\n },\n id: id,\n inputValue: inputValue,\n value: value,\n dirty: dirty,\n popupOpen: popupOpen,\n focused: focused || focusedTag !== -1,\n anchorEl: anchorEl,\n setAnchorEl: setAnchorEl,\n focusedTag: focusedTag,\n groupedOptions: groupedOptions\n };\n}","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 '@material-ui/core/styles';\nimport Popper from '@material-ui/core/Popper';\nimport ListSubheader from '@material-ui/core/ListSubheader';\nimport Paper from '@material-ui/core/Paper';\nimport IconButton from '@material-ui/core/IconButton';\nimport Chip from '@material-ui/core/Chip';\nimport CloseIcon from '../internal/svg-icons/Close';\nimport ArrowDropDownIcon from '../internal/svg-icons/ArrowDropDown';\nimport useAutocomplete, { createFilterOptions } from '../useAutocomplete';\nexport { createFilterOptions };\nexport var styles = function styles(theme) {\n var _option;\n\n return {\n /* Styles applied to the root element. */\n root: {\n '&$focused $clearIndicatorDirty': {\n visibility: 'visible'\n },\n\n /* Avoid double tap issue on iOS */\n '@media (pointer: fine)': {\n '&:hover $clearIndicatorDirty': {\n visibility: 'visible'\n }\n }\n },\n\n /* Styles applied to the root element if `fullWidth={true}`. */\n fullWidth: {\n width: '100%'\n },\n\n /* Pseudo-class applied to the root element if focused. */\n focused: {},\n\n /* Styles applied to the tag elements, e.g. the chips. */\n tag: {\n margin: 3,\n maxWidth: 'calc(100% - 6px)'\n },\n\n /* Styles applied to the tag elements, e.g. the chips if `size=\"small\"`. */\n tagSizeSmall: {\n margin: 2,\n maxWidth: 'calc(100% - 4px)'\n },\n\n /* Styles applied when the popup icon is rendered. */\n hasPopupIcon: {},\n\n /* Styles applied when the clear icon is rendered. */\n hasClearIcon: {},\n\n /* Styles applied to the Input element. */\n inputRoot: {\n flexWrap: 'wrap',\n '$hasPopupIcon &, $hasClearIcon &': {\n paddingRight: 26 + 4\n },\n '$hasPopupIcon$hasClearIcon &': {\n paddingRight: 52 + 4\n },\n '& $input': {\n width: 0,\n minWidth: 30\n },\n '&[class*=\"MuiInput-root\"]': {\n paddingBottom: 1,\n '& $input': {\n padding: 4\n },\n '& $input:first-child': {\n padding: '6px 0'\n }\n },\n '&[class*=\"MuiInput-root\"][class*=\"MuiInput-marginDense\"]': {\n '& $input': {\n padding: '4px 4px 5px'\n },\n '& $input:first-child': {\n padding: '3px 0 6px'\n }\n },\n '&[class*=\"MuiOutlinedInput-root\"]': {\n padding: 9,\n '$hasPopupIcon &, $hasClearIcon &': {\n paddingRight: 26 + 4 + 9\n },\n '$hasPopupIcon$hasClearIcon &': {\n paddingRight: 52 + 4 + 9\n },\n '& $input': {\n padding: '9.5px 4px'\n },\n '& $input:first-child': {\n paddingLeft: 6\n },\n '& $endAdornment': {\n right: 9\n }\n },\n '&[class*=\"MuiOutlinedInput-root\"][class*=\"MuiOutlinedInput-marginDense\"]': {\n padding: 6,\n '& $input': {\n padding: '4.5px 4px'\n }\n },\n '&[class*=\"MuiFilledInput-root\"]': {\n paddingTop: 19,\n paddingLeft: 8,\n '$hasPopupIcon &, $hasClearIcon &': {\n paddingRight: 26 + 4 + 9\n },\n '$hasPopupIcon$hasClearIcon &': {\n paddingRight: 52 + 4 + 9\n },\n '& $input': {\n padding: '9px 4px'\n },\n '& $endAdornment': {\n right: 9\n }\n },\n '&[class*=\"MuiFilledInput-root\"][class*=\"MuiFilledInput-marginDense\"]': {\n paddingBottom: 1,\n '& $input': {\n padding: '4.5px 4px'\n }\n }\n },\n\n /* Styles applied to the input element. */\n input: {\n flexGrow: 1,\n textOverflow: 'ellipsis',\n opacity: 0\n },\n\n /* Styles applied to the input element if tag focused. */\n inputFocused: {\n opacity: 1\n },\n\n /* Styles applied to the endAdornment element. */\n endAdornment: {\n // We use a position absolute to support wrapping tags.\n position: 'absolute',\n right: 0,\n top: 'calc(50% - 14px)' // Center vertically\n\n },\n\n /* Styles applied to the clear indicator. */\n clearIndicator: {\n marginRight: -2,\n padding: 4,\n visibility: 'hidden'\n },\n\n /* Styles applied to the clear indicator if the input is dirty. */\n clearIndicatorDirty: {},\n\n /* Styles applied to the popup indicator. */\n popupIndicator: {\n padding: 2,\n marginRight: -2\n },\n\n /* Styles applied to the popup indicator if the popup is open. */\n popupIndicatorOpen: {\n transform: 'rotate(180deg)'\n },\n\n /* Styles applied to the popper element. */\n popper: {\n zIndex: theme.zIndex.modal\n },\n\n /* Styles applied to the popper element if `disablePortal={true}`. */\n popperDisablePortal: {\n position: 'absolute'\n },\n\n /* Styles applied to the `Paper` component. */\n paper: _extends({}, theme.typography.body1, {\n overflow: 'hidden',\n margin: '4px 0'\n }),\n\n /* Styles applied to the `listbox` component. */\n listbox: {\n listStyle: 'none',\n margin: 0,\n padding: '8px 0',\n maxHeight: '40vh',\n overflow: 'auto'\n },\n\n /* Styles applied to the loading wrapper. */\n loading: {\n color: theme.palette.text.secondary,\n padding: '14px 16px'\n },\n\n /* Styles applied to the no option wrapper. */\n noOptions: {\n color: theme.palette.text.secondary,\n padding: '14px 16px'\n },\n\n /* Styles applied to the option elements. */\n option: (_option = {\n minHeight: 48,\n display: 'flex',\n justifyContent: 'flex-start',\n alignItems: 'center',\n cursor: 'pointer',\n paddingTop: 6,\n boxSizing: 'border-box',\n outline: '0',\n WebkitTapHighlightColor: 'transparent',\n paddingBottom: 6,\n paddingLeft: 16,\n paddingRight: 16\n }, _defineProperty(_option, theme.breakpoints.up('sm'), {\n minHeight: 'auto'\n }), _defineProperty(_option, '&[aria-selected=\"true\"]', {\n backgroundColor: theme.palette.action.selected\n }), _defineProperty(_option, '&[data-focus=\"true\"]', {\n backgroundColor: theme.palette.action.hover\n }), _defineProperty(_option, '&:active', {\n backgroundColor: theme.palette.action.selected\n }), _defineProperty(_option, '&[aria-disabled=\"true\"]', {\n opacity: theme.palette.action.disabledOpacity,\n pointerEvents: 'none'\n }), _option),\n\n /* Styles applied to the group's label elements. */\n groupLabel: {\n backgroundColor: theme.palette.background.paper,\n top: -8\n },\n\n /* Styles applied to the group's ul elements. */\n groupUl: {\n padding: 0,\n '& $option': {\n paddingLeft: 24\n }\n }\n };\n};\n\nfunction DisablePortal(props) {\n // eslint-disable-next-line react/prop-types\n var anchorEl = props.anchorEl,\n open = props.open,\n other = _objectWithoutProperties(props, [\"anchorEl\", \"open\"]);\n\n return /*#__PURE__*/React.createElement(\"div\", other);\n}\n\nvar _ref = /*#__PURE__*/React.createElement(CloseIcon, {\n fontSize: \"small\"\n});\n\nvar _ref2 = /*#__PURE__*/React.createElement(ArrowDropDownIcon, null);\n\nvar Autocomplete = /*#__PURE__*/React.forwardRef(function Autocomplete(props, ref) {\n /* eslint-disable no-unused-vars */\n var _props$autoComplete = props.autoComplete,\n autoComplete = _props$autoComplete === void 0 ? false : _props$autoComplete,\n _props$autoHighlight = props.autoHighlight,\n autoHighlight = _props$autoHighlight === void 0 ? false : _props$autoHighlight,\n _props$autoSelect = props.autoSelect,\n autoSelect = _props$autoSelect === void 0 ? false : _props$autoSelect,\n _props$blurOnSelect = props.blurOnSelect,\n blurOnSelect = _props$blurOnSelect === void 0 ? false : _props$blurOnSelect,\n ChipProps = props.ChipProps,\n classes = props.classes,\n className = props.className,\n _props$clearOnBlur = props.clearOnBlur,\n clearOnBlur = _props$clearOnBlur === void 0 ? !props.freeSolo : _props$clearOnBlur,\n _props$clearOnEscape = props.clearOnEscape,\n clearOnEscape = _props$clearOnEscape === void 0 ? false : _props$clearOnEscape,\n _props$clearText = props.clearText,\n clearText = _props$clearText === void 0 ? 'Clear' : _props$clearText,\n _props$closeIcon = props.closeIcon,\n closeIcon = _props$closeIcon === void 0 ? _ref : _props$closeIcon,\n _props$closeText = props.closeText,\n closeText = _props$closeText === void 0 ? 'Close' : _props$closeText,\n _props$debug = props.debug,\n debug = _props$debug === void 0 ? false : _props$debug,\n _props$defaultValue = props.defaultValue,\n defaultValue = _props$defaultValue === void 0 ? props.multiple ? [] : null : _props$defaultValue,\n _props$disableClearab = props.disableClearable,\n disableClearable = _props$disableClearab === void 0 ? false : _props$disableClearab,\n _props$disableCloseOn = props.disableCloseOnSelect,\n disableCloseOnSelect = _props$disableCloseOn === void 0 ? false : _props$disableCloseOn,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n _props$disabledItemsF = props.disabledItemsFocusable,\n disabledItemsFocusable = _props$disabledItemsF === void 0 ? false : _props$disabledItemsF,\n _props$disableListWra = props.disableListWrap,\n disableListWrap = _props$disableListWra === void 0 ? false : _props$disableListWra,\n _props$disablePortal = props.disablePortal,\n disablePortal = _props$disablePortal === void 0 ? false : _props$disablePortal,\n filterOptions = props.filterOptions,\n _props$filterSelected = props.filterSelectedOptions,\n filterSelectedOptions = _props$filterSelected === void 0 ? false : _props$filterSelected,\n _props$forcePopupIcon = props.forcePopupIcon,\n forcePopupIcon = _props$forcePopupIcon === void 0 ? 'auto' : _props$forcePopupIcon,\n _props$freeSolo = props.freeSolo,\n freeSolo = _props$freeSolo === void 0 ? false : _props$freeSolo,\n _props$fullWidth = props.fullWidth,\n fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,\n _props$getLimitTagsTe = props.getLimitTagsText,\n getLimitTagsText = _props$getLimitTagsTe === void 0 ? function (more) {\n return \"+\".concat(more);\n } : _props$getLimitTagsTe,\n getOptionDisabled = props.getOptionDisabled,\n _props$getOptionLabel = props.getOptionLabel,\n getOptionLabel = _props$getOptionLabel === void 0 ? function (x) {\n return x;\n } : _props$getOptionLabel,\n getOptionSelected = props.getOptionSelected,\n groupBy = props.groupBy,\n _props$handleHomeEndK = props.handleHomeEndKeys,\n handleHomeEndKeys = _props$handleHomeEndK === void 0 ? !props.freeSolo : _props$handleHomeEndK,\n idProp = props.id,\n _props$includeInputIn = props.includeInputInList,\n includeInputInList = _props$includeInputIn === void 0 ? false : _props$includeInputIn,\n inputValueProp = props.inputValue,\n _props$limitTags = props.limitTags,\n limitTags = _props$limitTags === void 0 ? -1 : _props$limitTags,\n _props$ListboxCompone = props.ListboxComponent,\n ListboxComponent = _props$ListboxCompone === void 0 ? 'ul' : _props$ListboxCompone,\n ListboxProps = props.ListboxProps,\n _props$loading = props.loading,\n loading = _props$loading === void 0 ? false : _props$loading,\n _props$loadingText = props.loadingText,\n loadingText = _props$loadingText === void 0 ? 'Loading…' : _props$loadingText,\n _props$multiple = props.multiple,\n multiple = _props$multiple === void 0 ? false : _props$multiple,\n _props$noOptionsText = props.noOptionsText,\n noOptionsText = _props$noOptionsText === void 0 ? 'No options' : _props$noOptionsText,\n onChange = props.onChange,\n onClose = props.onClose,\n onHighlightChange = props.onHighlightChange,\n onInputChange = props.onInputChange,\n onOpen = props.onOpen,\n open = props.open,\n _props$openOnFocus = props.openOnFocus,\n openOnFocus = _props$openOnFocus === void 0 ? false : _props$openOnFocus,\n _props$openText = props.openText,\n openText = _props$openText === void 0 ? 'Open' : _props$openText,\n options = props.options,\n _props$PaperComponent = props.PaperComponent,\n PaperComponent = _props$PaperComponent === void 0 ? Paper : _props$PaperComponent,\n _props$PopperComponen = props.PopperComponent,\n PopperComponentProp = _props$PopperComponen === void 0 ? Popper : _props$PopperComponen,\n _props$popupIcon = props.popupIcon,\n popupIcon = _props$popupIcon === void 0 ? _ref2 : _props$popupIcon,\n renderGroupProp = props.renderGroup,\n renderInput = props.renderInput,\n renderOptionProp = props.renderOption,\n renderTags = props.renderTags,\n _props$selectOnFocus = props.selectOnFocus,\n selectOnFocus = _props$selectOnFocus === void 0 ? !props.freeSolo : _props$selectOnFocus,\n _props$size = props.size,\n size = _props$size === void 0 ? 'medium' : _props$size,\n valueProp = props.value,\n other = _objectWithoutProperties(props, [\"autoComplete\", \"autoHighlight\", \"autoSelect\", \"blurOnSelect\", \"ChipProps\", \"classes\", \"className\", \"clearOnBlur\", \"clearOnEscape\", \"clearText\", \"closeIcon\", \"closeText\", \"debug\", \"defaultValue\", \"disableClearable\", \"disableCloseOnSelect\", \"disabled\", \"disabledItemsFocusable\", \"disableListWrap\", \"disablePortal\", \"filterOptions\", \"filterSelectedOptions\", \"forcePopupIcon\", \"freeSolo\", \"fullWidth\", \"getLimitTagsText\", \"getOptionDisabled\", \"getOptionLabel\", \"getOptionSelected\", \"groupBy\", \"handleHomeEndKeys\", \"id\", \"includeInputInList\", \"inputValue\", \"limitTags\", \"ListboxComponent\", \"ListboxProps\", \"loading\", \"loadingText\", \"multiple\", \"noOptionsText\", \"onChange\", \"onClose\", \"onHighlightChange\", \"onInputChange\", \"onOpen\", \"open\", \"openOnFocus\", \"openText\", \"options\", \"PaperComponent\", \"PopperComponent\", \"popupIcon\", \"renderGroup\", \"renderInput\", \"renderOption\", \"renderTags\", \"selectOnFocus\", \"size\", \"value\"]);\n /* eslint-enable no-unused-vars */\n\n\n var PopperComponent = disablePortal ? DisablePortal : PopperComponentProp;\n\n var _useAutocomplete = useAutocomplete(_extends({}, props, {\n componentName: 'Autocomplete'\n })),\n getRootProps = _useAutocomplete.getRootProps,\n getInputProps = _useAutocomplete.getInputProps,\n getInputLabelProps = _useAutocomplete.getInputLabelProps,\n getPopupIndicatorProps = _useAutocomplete.getPopupIndicatorProps,\n getClearProps = _useAutocomplete.getClearProps,\n getTagProps = _useAutocomplete.getTagProps,\n getListboxProps = _useAutocomplete.getListboxProps,\n getOptionProps = _useAutocomplete.getOptionProps,\n value = _useAutocomplete.value,\n dirty = _useAutocomplete.dirty,\n id = _useAutocomplete.id,\n popupOpen = _useAutocomplete.popupOpen,\n focused = _useAutocomplete.focused,\n focusedTag = _useAutocomplete.focusedTag,\n anchorEl = _useAutocomplete.anchorEl,\n setAnchorEl = _useAutocomplete.setAnchorEl,\n inputValue = _useAutocomplete.inputValue,\n groupedOptions = _useAutocomplete.groupedOptions;\n\n var startAdornment;\n\n if (multiple && value.length > 0) {\n var getCustomizedTagProps = function getCustomizedTagProps(params) {\n return _extends({\n className: clsx(classes.tag, size === 'small' && classes.tagSizeSmall),\n disabled: disabled\n }, getTagProps(params));\n };\n\n if (renderTags) {\n startAdornment = renderTags(value, getCustomizedTagProps);\n } else {\n startAdornment = value.map(function (option, index) {\n return /*#__PURE__*/React.createElement(Chip, _extends({\n label: getOptionLabel(option),\n size: size\n }, getCustomizedTagProps({\n index: index\n }), ChipProps));\n });\n }\n }\n\n if (limitTags > -1 && Array.isArray(startAdornment)) {\n var more = startAdornment.length - limitTags;\n\n if (!focused && more > 0) {\n startAdornment = startAdornment.splice(0, limitTags);\n startAdornment.push( /*#__PURE__*/React.createElement(\"span\", {\n className: classes.tag,\n key: startAdornment.length\n }, getLimitTagsText(more)));\n }\n }\n\n var defaultRenderGroup = function defaultRenderGroup(params) {\n return /*#__PURE__*/React.createElement(\"li\", {\n key: params.key\n }, /*#__PURE__*/React.createElement(ListSubheader, {\n className: classes.groupLabel,\n component: \"div\"\n }, params.group), /*#__PURE__*/React.createElement(\"ul\", {\n className: classes.groupUl\n }, params.children));\n };\n\n var renderGroup = renderGroupProp || defaultRenderGroup;\n var renderOption = renderOptionProp || getOptionLabel;\n\n var renderListOption = function renderListOption(option, index) {\n var optionProps = getOptionProps({\n option: option,\n index: index\n });\n return /*#__PURE__*/React.createElement(\"li\", _extends({}, optionProps, {\n className: classes.option\n }), renderOption(option, {\n selected: optionProps['aria-selected'],\n inputValue: inputValue\n }));\n };\n\n var hasClearIcon = !disableClearable && !disabled;\n var hasPopupIcon = (!freeSolo || forcePopupIcon === true) && forcePopupIcon !== false;\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(\"div\", _extends({\n ref: ref,\n className: clsx(classes.root, className, focused && classes.focused, fullWidth && classes.fullWidth, hasClearIcon && classes.hasClearIcon, hasPopupIcon && classes.hasPopupIcon)\n }, getRootProps(other)), renderInput({\n id: id,\n disabled: disabled,\n fullWidth: true,\n size: size === 'small' ? 'small' : undefined,\n InputLabelProps: getInputLabelProps(),\n InputProps: {\n ref: setAnchorEl,\n className: classes.inputRoot,\n startAdornment: startAdornment,\n endAdornment: /*#__PURE__*/React.createElement(\"div\", {\n className: classes.endAdornment\n }, hasClearIcon ? /*#__PURE__*/React.createElement(IconButton, _extends({}, getClearProps(), {\n \"aria-label\": clearText,\n title: clearText,\n className: clsx(classes.clearIndicator, dirty && classes.clearIndicatorDirty)\n }), closeIcon) : null, hasPopupIcon ? /*#__PURE__*/React.createElement(IconButton, _extends({}, getPopupIndicatorProps(), {\n disabled: disabled,\n \"aria-label\": popupOpen ? closeText : openText,\n title: popupOpen ? closeText : openText,\n className: clsx(classes.popupIndicator, popupOpen && classes.popupIndicatorOpen)\n }), popupIcon) : null)\n },\n inputProps: _extends({\n className: clsx(classes.input, focusedTag === -1 && classes.inputFocused),\n disabled: disabled\n }, getInputProps())\n })), popupOpen && anchorEl ? /*#__PURE__*/React.createElement(PopperComponent, {\n className: clsx(classes.popper, disablePortal && classes.popperDisablePortal),\n style: {\n width: anchorEl ? anchorEl.clientWidth : null\n },\n role: \"presentation\",\n anchorEl: anchorEl,\n open: true\n }, /*#__PURE__*/React.createElement(PaperComponent, {\n className: classes.paper\n }, loading && groupedOptions.length === 0 ? /*#__PURE__*/React.createElement(\"div\", {\n className: classes.loading\n }, loadingText) : null, groupedOptions.length === 0 && !freeSolo && !loading ? /*#__PURE__*/React.createElement(\"div\", {\n className: classes.noOptions\n }, noOptionsText) : null, groupedOptions.length > 0 ? /*#__PURE__*/React.createElement(ListboxComponent, _extends({\n className: classes.listbox\n }, getListboxProps(), ListboxProps), groupedOptions.map(function (option, index) {\n if (groupBy) {\n return renderGroup({\n key: option.key,\n group: option.group,\n children: option.options.map(function (option2, index2) {\n return renderListOption(option2, option.index + index2);\n })\n });\n }\n\n return renderListOption(option, index);\n })) : null)) : null);\n});\nprocess.env.NODE_ENV !== \"production\" ? Autocomplete.propTypes = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n\n /**\n * If `true`, the portion of the selected suggestion that has not been typed by the user,\n * known as the completion string, appears inline after the input cursor in the textbox.\n * The inline completion string is visually highlighted and has a selected state.\n */\n autoComplete: PropTypes.bool,\n\n /**\n * If `true`, the first option is automatically highlighted.\n */\n autoHighlight: PropTypes.bool,\n\n /**\n * If `true`, the selected option becomes the value of the input\n * when the Autocomplete loses focus unless the user chooses\n * a different option or changes the character string in the input.\n */\n autoSelect: PropTypes.bool,\n\n /**\n * Control if the input should be blurred when an option is selected:\n *\n * - `false` the input is not blurred.\n * - `true` the input is always blurred.\n * - `touch` the input is blurred after a touch event.\n * - `mouse` the input is blurred after a mouse event.\n */\n blurOnSelect: PropTypes.oneOfType([PropTypes.oneOf(['mouse', 'touch']), PropTypes.bool]),\n\n /**\n * Props applied to the [`Chip`](/api/chip/) element.\n */\n ChipProps: PropTypes.object,\n\n /**\n * Override or extend the styles applied to the component.\n * See [CSS API](#css) below for more details.\n */\n classes: PropTypes.object,\n\n /**\n * @ignore\n */\n className: PropTypes.string,\n\n /**\n * If `true`, the input's text will be cleared on blur if no value is selected.\n *\n * Set to `true` if you want to help the user enter a new value.\n * Set to `false` if you want to help the user resume his search.\n */\n clearOnBlur: PropTypes.bool,\n\n /**\n * If `true`, clear all values when the user presses escape and the popup is closed.\n */\n clearOnEscape: PropTypes.bool,\n\n /**\n * Override the default text for the *clear* icon button.\n *\n * For localization purposes, you can use the provided [translations](/guides/localization/).\n */\n clearText: PropTypes.string,\n\n /**\n * The icon to display in place of the default close icon.\n */\n closeIcon: PropTypes.node,\n\n /**\n * Override the default text for the *close popup* icon button.\n *\n * For localization purposes, you can use the provided [translations](/guides/localization/).\n */\n closeText: PropTypes.string,\n\n /**\n * If `true`, the popup will ignore the blur event if the input is filled.\n * You can inspect the popup markup with your browser tools.\n * Consider this option when you need to customize the component.\n */\n debug: PropTypes.bool,\n\n /**\n * The default input value. Use when the component is not controlled.\n */\n defaultValue: PropTypes.any,\n\n /**\n * If `true`, the input can't be cleared.\n */\n disableClearable: PropTypes\n /* @typescript-to-proptypes-ignore */\n .bool,\n\n /**\n * If `true`, the popup won't close when a value is selected.\n */\n disableCloseOnSelect: PropTypes.bool,\n\n /**\n * If `true`, the input will be disabled.\n */\n disabled: PropTypes.bool,\n\n /**\n * If `true`, will allow focus on disabled items.\n */\n disabledItemsFocusable: PropTypes.bool,\n\n /**\n * If `true`, the list box in the popup will not wrap focus.\n */\n disableListWrap: PropTypes.bool,\n\n /**\n * Disable the portal behavior.\n * The children stay within it's parent DOM hierarchy.\n */\n disablePortal: PropTypes.bool,\n\n /**\n * A filter function that determines the options that are eligible.\n *\n * @param {T[]} options The options to render.\n * @param {object} state The state of the component.\n * @returns {T[]}\n */\n filterOptions: PropTypes.func,\n\n /**\n * If `true`, hide the selected options from the list box.\n */\n filterSelectedOptions: PropTypes.bool,\n\n /**\n * Force the visibility display of the popup icon.\n */\n forcePopupIcon: PropTypes.oneOfType([PropTypes.oneOf(['auto']), PropTypes.bool]),\n\n /**\n * If `true`, the Autocomplete is free solo, meaning that the user input is not bound to provided options.\n */\n freeSolo: PropTypes\n /* @typescript-to-proptypes-ignore */\n .bool,\n\n /**\n * If `true`, the input will take up the full width of its container.\n */\n fullWidth: PropTypes.bool,\n\n /**\n * The label to display when the tags are truncated (`limitTags`).\n *\n * @param {number} more The number of truncated tags.\n * @returns {ReactNode}\n */\n getLimitTagsText: PropTypes.func,\n\n /**\n * Used to determine the disabled state for a given option.\n *\n * @param {T} option The option to test.\n * @returns {boolean}\n */\n getOptionDisabled: PropTypes.func,\n\n /**\n * Used to determine the string value for a given option.\n * It's used to fill the input (and the list box options if `renderOption` is not provided).\n *\n * @param {T} option\n * @returns {string}\n */\n getOptionLabel: PropTypes.func,\n\n /**\n * Used to determine if an option is selected, considering the current value.\n * Uses strict equality by default.\n *\n * @param {T} option The option to test.\n * @param {T} value The value to test against.\n * @returns {boolean}\n */\n getOptionSelected: PropTypes.func,\n\n /**\n * If provided, the options will be grouped under the returned string.\n * The groupBy value is also used as the text for group headings when `renderGroup` is not provided.\n *\n * @param {T} options The options to group.\n * @returns {string}\n */\n groupBy: PropTypes.func,\n\n /**\n * If `true`, the component handles the \"Home\" and \"End\" keys when the popup is open.\n * It should move focus to the first option and last option, respectively.\n */\n handleHomeEndKeys: PropTypes.bool,\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 highlight can move to the input.\n */\n includeInputInList: PropTypes.bool,\n\n /**\n * The input value.\n */\n inputValue: PropTypes.string,\n\n /**\n * The maximum number of tags that will be visible when not focused.\n * Set `-1` to disable the limit.\n */\n limitTags: PropTypes.number,\n\n /**\n * The component used to render the listbox.\n */\n ListboxComponent: PropTypes.elementType,\n\n /**\n * Props applied to the Listbox element.\n */\n ListboxProps: PropTypes.object,\n\n /**\n * If `true`, the component is in a loading state.\n */\n loading: PropTypes.bool,\n\n /**\n * Text to display when in a loading state.\n *\n * For localization purposes, you can use the provided [translations](/guides/localization/).\n */\n loadingText: PropTypes.node,\n\n /**\n * If `true`, `value` must be an array and the menu will support multiple selections.\n */\n multiple: PropTypes\n /* @typescript-to-proptypes-ignore */\n .bool,\n\n /**\n * Text to display when there are no options.\n *\n * For localization purposes, you can use the provided [translations](/guides/localization/).\n */\n noOptionsText: PropTypes.node,\n\n /**\n * Callback fired when the value changes.\n *\n * @param {object} event The event source of the callback.\n * @param {T|T[]} value The new value of the component.\n * @param {string} reason One of \"create-option\", \"select-option\", \"remove-option\", \"blur\" or \"clear\".\n */\n onChange: PropTypes.func,\n\n /**\n * Callback fired when the popup requests to be closed.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"toggleInput\"`, `\"escape\"`, `\"select-option\"`, `\"blur\"`.\n */\n onClose: PropTypes.func,\n\n /**\n * Callback fired when the highlight option changes.\n *\n * @param {object} event The event source of the callback.\n * @param {T} option The highlighted option.\n * @param {string} reason Can be: `\"keyboard\"`, `\"auto\"`, `\"mouse\"`.\n */\n onHighlightChange: PropTypes.func,\n\n /**\n * Callback fired when the input value changes.\n *\n * @param {object} event The event source of the callback.\n * @param {string} value The new value of the text input.\n * @param {string} reason Can be: `\"input\"` (user input), `\"reset\"` (programmatic change), `\"clear\"`.\n */\n onInputChange: PropTypes.func,\n\n /**\n * Callback fired when the popup requests to be opened.\n * Use in controlled mode (see open).\n *\n * @param {object} event The event source of the callback.\n */\n onOpen: PropTypes.func,\n\n /**\n * Control the popup` open state.\n */\n open: PropTypes.bool,\n\n /**\n * If `true`, the popup will open on input focus.\n */\n openOnFocus: PropTypes.bool,\n\n /**\n * Override the default text for the *open popup* icon button.\n *\n * For localization purposes, you can use the provided [translations](/guides/localization/).\n */\n openText: PropTypes.string,\n\n /**\n * Array of options.\n */\n options: PropTypes.array.isRequired,\n\n /**\n * The component used to render the body of the popup.\n */\n PaperComponent: PropTypes.elementType,\n\n /**\n * The component used to position the popup.\n */\n PopperComponent: PropTypes.elementType,\n\n /**\n * The icon to display in place of the default popup icon.\n */\n popupIcon: PropTypes.node,\n\n /**\n * Render the group.\n *\n * @param {any} option The group to render.\n * @returns {ReactNode}\n */\n renderGroup: PropTypes.func,\n\n /**\n * Render the input.\n *\n * @param {object} params\n * @returns {ReactNode}\n */\n renderInput: PropTypes.func.isRequired,\n\n /**\n * Render the option, use `getOptionLabel` by default.\n *\n * @param {T} option The option to render.\n * @param {object} state The state of the component.\n * @returns {ReactNode}\n */\n renderOption: PropTypes.func,\n\n /**\n * Render the selected value.\n *\n * @param {T[]} value The `value` provided to the component.\n * @param {function} getTagProps A tag props getter.\n * @returns {ReactNode}\n */\n renderTags: PropTypes.func,\n\n /**\n * If `true`, the input's text will be selected on focus.\n * It helps the user clear the selected value.\n */\n selectOnFocus: PropTypes.bool,\n\n /**\n * The size of the autocomplete.\n */\n size: PropTypes.oneOf(['medium', 'small']),\n\n /**\n * The value of the autocomplete.\n *\n * The value must have reference equality with the option in order to be selected.\n * You can customize the equality behavior with the `getOptionSelected` prop.\n */\n value: PropTypes.any\n} : void 0;\nexport default withStyles(styles, {\n name: 'MuiAutocomplete'\n})(Autocomplete);"],"sourceRoot":""}