0xV3NOMx
Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64



Your IP : 3.128.226.114


Current Path : /var/www/qptran/static/js/
Upload File :
Current File : /var/www/qptran/static/js/0.69926822.chunk.js.map

{"version":3,"sources":["../node_modules/lodash-es/without.js","../node_modules/lodash-es/_baseFilter.js","../node_modules/lodash-es/filter.js","../node_modules/lodash-es/isArrayLikeObject.js","../node_modules/lodash-es/_baseDifference.js","../node_modules/semantic-ui-react/dist/es/addons/TextArea/TextArea.js","../node_modules/lodash-es/compact.js","../node_modules/lodash-es/_arrayEvery.js","../node_modules/lodash-es/_baseEvery.js","../node_modules/lodash-es/every.js","../node_modules/lodash-es/dropRight.js","../node_modules/lodash-es/_asciiSize.js","../node_modules/lodash-es/_hasUnicode.js","../node_modules/lodash-es/_unicodeSize.js","../node_modules/lodash-es/_stringSize.js","../node_modules/lodash-es/size.js","../node_modules/lodash-es/difference.js","../node_modules/lodash-es/union.js","../node_modules/lodash-es/isEqual.js","../node_modules/semantic-ui-react/dist/es/elements/Flag/Flag.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownDivider.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownItem.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownHeader.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownMenu.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownSearchInput.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/DropdownText.js","../node_modules/lodash-es/escapeRegExp.js","../node_modules/lodash-es/_basePropertyOf.js","../node_modules/lodash-es/_deburrLetter.js","../node_modules/lodash-es/deburr.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/utils/getMenuOptions.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/utils/getSelectedIndex.js","../node_modules/semantic-ui-react/dist/es/modules/Dropdown/Dropdown.js","../node_modules/lodash-es/set.js","../node_modules/semantic-ui-react/dist/es/modules/Checkbox/Checkbox.js","../node_modules/semantic-ui-react/dist/es/addons/Radio/Radio.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormField.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormButton.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormCheckbox.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormDropdown.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormGroup.js","../node_modules/semantic-ui-react/dist/es/elements/Input/Input.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormInput.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormRadio.js","../node_modules/semantic-ui-react/dist/es/addons/Select/Select.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormSelect.js","../node_modules/semantic-ui-react/dist/es/collections/Form/FormTextArea.js","../node_modules/semantic-ui-react/dist/es/collections/Form/Form.js"],"names":["without","array","values","collection","predicate","result","value","index","push","isArray","iteratee","comparator","includes","isCommon","length","valuesLength","outer","computed","valuesIndex","TextArea","_Component","_this","_len","arguments","args","Array","_key","call","apply","this","concat","ref","focus","current","handleChange","e","props","handleInput","prototype","render","_this$props","rows","rest","ElementType","createElement","innerRef","onChange","onInput","handledProps","propTypes","defaultProps","as","resIndex","guard","func","undefined","n","toInteger","reHasUnicode","RegExp","string","test","rsAstral","rsCombo","rsFitz","rsNonAstral","rsRegional","rsSurrPair","reOptMod","rsSeq","join","rsSymbol","reUnicode","lastIndex","isArrayLike","isString","tag","size","isArrayLikeObject","arrays","other","_PureComponent","Flag","className","name","classes","getUnhandledProps","getElementType","create","DropdownDivider","DropdownItem","handleClick","active","children","content","disabled","description","flag","icon","image","label","selected","text","iconName","someByType","ariaOptions","role","isNil","onClick","flagElement","autoGenerateKey","iconElement","Icon","imageElement","Image","labelElement","Label","descriptionElement","val","textElement","opts","DropdownHeader","DropdownMenu","direction","open","scrolling","DropdownSearchInput","autoComplete","tabIndex","type","DropdownText","reRegExpChar","reHasRegExpChar","source","replace","object","key","reLatin","reComboMark","getMenuOptions","config","additionLabel","additionPosition","allowAdditions","deburr","multiple","options","search","searchQuery","filteredOptions","opt","strippedQuery","re","addItem","isValidElement","cloneElement","unshift","getSelectedIndex","newSelectedIndex","selectedIndex","menuOptions","enabledIndexes","memo","item","firstIndex","activeIndex","map","option","renderItemContent","Fragment","Dropdown","searchRef","sizerRef","closeOnChange","close","closeOnEscape","getCode","Escape","preventDefault","moveSelectionOnKeyDown","_moves","_this$props2","selectOnNavigation","state","move","ArrowDown","ArrowUp","nextIndex","getSelectedIndexAfterMove","makeSelectedItemActive","setState","openOnSpace","_e$target","_e$target2","_e$target3","shouldHandleEvent","Spacebar","shouldPreventDefault","target","tagName","isContentEditable","openOnArrow","_this$state","code","_this$state2","getSelectedItem","selectedValue","newValue","selectItemOnEnter","_this$state3","Enter","optionSize","nextValue","clearSearchQuery","removeItemOnBackspace","_this$props3","_this$state4","Backspace","closeOnDocumentClick","closeOnBlur","doesNodeContainClick","handleMouseDown","isMouseDown","document","addEventListener","handleDocumentMouseUp","removeEventListener","_this$props4","minCharacters","_this$state5","stopPropagation","toggle","handleIconClick","clearable","hasValue","clearValue","handleItemClick","_this$props5","currentValue","nativeEvent","stopImmediatePropagation","isAdditionItem","handleFocus","handleBlur","currentTarget","contains","activeElement","_this$props6","selectOnBlur","handleSearchChange","_ref","newQuery","handleKeyDown","getItemByValue","getDropdownAriaOptions","_this$props7","loading","handleLabelClick","labelProps","selectedLabel","handleLabelRemove","offset","startIndex","wrapSelection","handleIconOverrides","predefinedProps","computeSearchInputTabIndex","_this$props8","computeSearchInputWidth","style","display","textContent","searchWidth","Math","ceil","getBoundingClientRect","width","removeProperty","computeTabIndex","_this$props9","handleSearchInputOverrides","inputProps","scrollSelectedItemIntoView","menu","querySelector","isOutOfUpperView","offsetTop","scrollTop","isOutOfLowerView","clientHeight","setOpenDirection","dropdownRect","menuHeight","spaceAtTheBottom","documentElement","top","height","spaceAtTheTop","upward","triggerSetState","_this$props10","callback","handleClose","hasSearchFocus","blur","hasDropdownFocus","hasFocus","renderText","selectedItem","_this$props11","placeholder","_this$state6","_text","renderSearchInput","_this$props12","searchInput","Ref","overrideProps","renderSearchSizer","_this$props13","renderLabels","_this$props14","renderLabel","_this$state7","selectedItems","onRemove","renderOptions","_this$props15","lazyLoad","noResultsMessage","_this$state8","isActive","optValue","i","pointerEvents","generateKey","renderMenu","_this$props16","header","getDropdownMenuAriaOptions","menuChild","only","_proto","getInitialAutoControlledState","getAutoControlledStateFromProps","nextProps","computedState","prevState","derivedState","__options","__value","componentDidMount","shouldComponentUpdate","nextState","componentDidUpdate","prevProps","_this$props17","openOnFocus","openable","_this$props18","_this$props19","basic","button","compact","error","fluid","floating","inline","labeled","pointing","selection","simple","trigger","_this$state9","onBlur","onKeyDown","onMouseDown","onFocus","on","autoControlledProps","Divider","Header","Item","Menu","SearchInput","Text","path","Checkbox","inputRef","labelRef","canToggle","radio","readOnly","checked","id","indeterminate","isInputClick","isLabelClick","isRootClick","hasId","isClickFromMouse","defaultPrevented","handleMouseUp","setIndeterminate","slider","unhandled","_partitionHTMLProps","htmlProps","htmlInputProps","htmlFor","onMouseUp","Radio","FormField","control","required","errorPointing","errorLabel","prompt","errorLabelBefore","errorLabelAfter","ariaAttrs","controlProps","FormButton","Button","FormCheckbox","FormDropdown","FormGroup","grouped","unstackable","widths","Input","computeIcon","select","handleChildOverrides","child","c","partitionProps","_this2","action","actionPosition","iconPosition","input","inverted","labelPosition","transparent","_this$partitionProps","childElements","toArray","actionElement","FormInput","FormRadio","Select","FormSelect","FormTextArea","Form","_args","handleSubmit","_len2","_key2","reply","success","warning","onSubmit","Field","Group"],"mappings":"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U,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,IACV,SAAU,KACV,SAAU,KACV,SAAU,KACV,SAAU,KACV,SAAU,KACV,SAAU,MC/LRC,GAAU,8CAeVC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","file":"static/js/0.69926822.chunk.js","sourcesContent":["import baseDifference from './_baseDifference.js';\nimport baseRest from './_baseRest.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\n/**\n * Creates an array excluding all given values using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.pull`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...*} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.xor\n * @example\n *\n * _.without([2, 1, 2, 3], 1, 2);\n * // => [3]\n */\n\nvar without = baseRest(function (array, values) {\n  return isArrayLikeObject(array) ? baseDifference(array, values) : [];\n});\nexport default without;","import baseEach from './_baseEach.js';\n/**\n * The base implementation of `_.filter` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\n\nfunction baseFilter(collection, predicate) {\n  var result = [];\n  baseEach(collection, function (value, index, collection) {\n    if (predicate(value, index, collection)) {\n      result.push(value);\n    }\n  });\n  return result;\n}\n\nexport default baseFilter;","import arrayFilter from './_arrayFilter.js';\nimport baseFilter from './_baseFilter.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\n/**\n * Iterates over elements of `collection`, returning an array of all elements\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * **Note:** Unlike `_.remove`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.reject\n * @example\n *\n * var users = [\n *   { 'user': 'barney', 'age': 36, 'active': true },\n *   { 'user': 'fred',   'age': 40, 'active': false }\n * ];\n *\n * _.filter(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, { 'age': 36, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.filter(users, 'active');\n * // => objects for ['barney']\n *\n * // Combining several predicates using `_.overEvery` or `_.overSome`.\n * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]]));\n * // => objects for ['fred', 'barney']\n */\n\nfunction filter(collection, predicate) {\n  var func = isArray(collection) ? arrayFilter : baseFilter;\n  return func(collection, baseIteratee(predicate, 3));\n}\n\nexport default filter;","import isArrayLike from './isArrayLike.js';\nimport isObjectLike from './isObjectLike.js';\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n *  else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\n\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\n}\n\nexport default isArrayLikeObject;","import SetCache from './_SetCache.js';\nimport arrayIncludes from './_arrayIncludes.js';\nimport arrayIncludesWith from './_arrayIncludesWith.js';\nimport arrayMap from './_arrayMap.js';\nimport baseUnary from './_baseUnary.js';\nimport cacheHas from './_cacheHas.js';\n/** Used as the size to enable large array optimizations. */\n\nvar LARGE_ARRAY_SIZE = 200;\n/**\n * The base implementation of methods like `_.difference` without support\n * for excluding multiple arrays or iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Array} values The values to exclude.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n */\n\nfunction baseDifference(array, values, iteratee, comparator) {\n  var index = -1,\n      includes = arrayIncludes,\n      isCommon = true,\n      length = array.length,\n      result = [],\n      valuesLength = values.length;\n\n  if (!length) {\n    return result;\n  }\n\n  if (iteratee) {\n    values = arrayMap(values, baseUnary(iteratee));\n  }\n\n  if (comparator) {\n    includes = arrayIncludesWith;\n    isCommon = false;\n  } else if (values.length >= LARGE_ARRAY_SIZE) {\n    includes = cacheHas;\n    isCommon = false;\n    values = new SetCache(values);\n  }\n\n  outer: while (++index < length) {\n    var value = array[index],\n        computed = iteratee == null ? value : iteratee(value);\n    value = comparator || value !== 0 ? value : 0;\n\n    if (isCommon && computed === computed) {\n      var valuesIndex = valuesLength;\n\n      while (valuesIndex--) {\n        if (values[valuesIndex] === computed) {\n          continue outer;\n        }\n      }\n\n      result.push(value);\n    } else if (!includes(values, computed, comparator)) {\n      result.push(value);\n    }\n  }\n\n  return result;\n}\n\nexport default baseDifference;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _invoke from \"lodash-es/invoke\";\nimport _get from \"lodash-es/get\";\nimport { Ref } from '@fluentui/react-component-ref';\nimport PropTypes from 'prop-types';\nimport React, { Component, createRef } from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\n/**\n * A TextArea can be used to allow for extended user input.\n * @see Form\n */\n\nvar TextArea = /*#__PURE__*/function (_Component) {\n  _inheritsLoose(TextArea, _Component);\n\n  function TextArea() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _Component.call.apply(_Component, [this].concat(args)) || this;\n    _this.ref = /*#__PURE__*/createRef();\n\n    _this.focus = function () {\n      return _this.ref.current.focus();\n    };\n\n    _this.handleChange = function (e) {\n      var value = _get(e, 'target.value');\n\n      _invoke(_this.props, 'onChange', e, _extends({}, _this.props, {\n        value: value\n      }));\n    };\n\n    _this.handleInput = function (e) {\n      var value = _get(e, 'target.value');\n\n      _invoke(_this.props, 'onInput', e, _extends({}, _this.props, {\n        value: value\n      }));\n    };\n\n    return _this;\n  }\n\n  var _proto = TextArea.prototype;\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        rows = _this$props.rows,\n        value = _this$props.value;\n    var rest = getUnhandledProps(TextArea, this.props);\n    var ElementType = getElementType(TextArea, this.props);\n    return /*#__PURE__*/React.createElement(Ref, {\n      innerRef: this.ref\n    }, /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n      onChange: this.handleChange,\n      onInput: this.handleInput,\n      rows: rows,\n      value: value\n    })));\n  };\n\n  return TextArea;\n}(Component);\n\nTextArea.handledProps = [\"as\", \"onChange\", \"onInput\", \"rows\", \"value\"];\nTextArea.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /**\n   * Called on change.\n   * @param {SyntheticEvent} event - The React SyntheticEvent object\n   * @param {object} data - All props and the event value.\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * Called on input.\n   * @param {SyntheticEvent} event - The React SyntheticEvent object\n   * @param {object} data - All props and the event value.\n   */\n  onInput: PropTypes.func,\n\n  /** Indicates row count for a TextArea. */\n  rows: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n  /** The value of the textarea. */\n  value: PropTypes.oneOfType([PropTypes.number, PropTypes.string])\n} : {};\nTextArea.defaultProps = {\n  as: 'textarea',\n  rows: 3\n};\nexport default TextArea;","/**\n * Creates an array with all falsey values removed. The values `false`, `null`,\n * `0`, `\"\"`, `undefined`, and `NaN` are falsey.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to compact.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.compact([0, 1, false, 2, '', 3]);\n * // => [1, 2, 3]\n */\nfunction compact(array) {\n  var index = -1,\n      length = array == null ? 0 : array.length,\n      resIndex = 0,\n      result = [];\n\n  while (++index < length) {\n    var value = array[index];\n\n    if (value) {\n      result[resIndex++] = value;\n    }\n  }\n\n  return result;\n}\n\nexport default compact;","/**\n * A specialized version of `_.every` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n *  else `false`.\n */\nfunction arrayEvery(array, predicate) {\n  var index = -1,\n      length = array == null ? 0 : array.length;\n\n  while (++index < length) {\n    if (!predicate(array[index], index, array)) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nexport default arrayEvery;","import baseEach from './_baseEach.js';\n/**\n * The base implementation of `_.every` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n *  else `false`\n */\n\nfunction baseEvery(collection, predicate) {\n  var result = true;\n  baseEach(collection, function (value, index, collection) {\n    result = !!predicate(value, index, collection);\n    return result;\n  });\n  return result;\n}\n\nexport default baseEvery;","import arrayEvery from './_arrayEvery.js';\nimport baseEvery from './_baseEvery.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\nimport isIterateeCall from './_isIterateeCall.js';\n/**\n * Checks if `predicate` returns truthy for **all** elements of `collection`.\n * Iteration is stopped once `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * **Note:** This method returns `true` for\n * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because\n * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of\n * elements of empty collections.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n *  else `false`.\n * @example\n *\n * _.every([true, 1, null, 'yes'], Boolean);\n * // => false\n *\n * var users = [\n *   { 'user': 'barney', 'age': 36, 'active': false },\n *   { 'user': 'fred',   'age': 40, 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.every(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.every(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.every(users, 'active');\n * // => false\n */\n\nfunction every(collection, predicate, guard) {\n  var func = isArray(collection) ? arrayEvery : baseEvery;\n\n  if (guard && isIterateeCall(collection, predicate, guard)) {\n    predicate = undefined;\n  }\n\n  return func(collection, baseIteratee(predicate, 3));\n}\n\nexport default every;","import baseSlice from './_baseSlice.js';\nimport toInteger from './toInteger.js';\n/**\n * Creates a slice of `array` with `n` elements dropped from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.dropRight([1, 2, 3]);\n * // => [1, 2]\n *\n * _.dropRight([1, 2, 3], 2);\n * // => [1]\n *\n * _.dropRight([1, 2, 3], 5);\n * // => []\n *\n * _.dropRight([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n\nfunction dropRight(array, n, guard) {\n  var length = array == null ? 0 : array.length;\n\n  if (!length) {\n    return [];\n  }\n\n  n = guard || n === undefined ? 1 : toInteger(n);\n  n = length - n;\n  return baseSlice(array, 0, n < 0 ? 0 : n);\n}\n\nexport default dropRight;","import baseProperty from './_baseProperty.js';\n/**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n\nvar asciiSize = baseProperty('length');\nexport default asciiSize;","/** Used to compose unicode character classes. */\nvar rsAstralRange = \"\\\\ud800-\\\\udfff\",\n    rsComboMarksRange = \"\\\\u0300-\\\\u036f\",\n    reComboHalfMarksRange = \"\\\\ufe20-\\\\ufe2f\",\n    rsComboSymbolsRange = \"\\\\u20d0-\\\\u20ff\",\n    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n    rsVarRange = \"\\\\ufe0e\\\\ufe0f\";\n/** Used to compose unicode capture groups. */\n\nvar rsZWJ = \"\\\\u200d\";\n/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\n\nvar reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n/**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\n\nfunction hasUnicode(string) {\n  return reHasUnicode.test(string);\n}\n\nexport default hasUnicode;","/** Used to compose unicode character classes. */\nvar rsAstralRange = \"\\\\ud800-\\\\udfff\",\n    rsComboMarksRange = \"\\\\u0300-\\\\u036f\",\n    reComboHalfMarksRange = \"\\\\ufe20-\\\\ufe2f\",\n    rsComboSymbolsRange = \"\\\\u20d0-\\\\u20ff\",\n    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n    rsVarRange = \"\\\\ufe0e\\\\ufe0f\";\n/** Used to compose unicode capture groups. */\n\nvar rsAstral = '[' + rsAstralRange + ']',\n    rsCombo = '[' + rsComboRange + ']',\n    rsFitz = \"\\\\ud83c[\\\\udffb-\\\\udfff]\",\n    rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n    rsNonAstral = '[^' + rsAstralRange + ']',\n    rsRegional = \"(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}\",\n    rsSurrPair = \"[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]\",\n    rsZWJ = \"\\\\u200d\";\n/** Used to compose unicode regexes. */\n\nvar reOptMod = rsModifier + '?',\n    rsOptVar = '[' + rsVarRange + ']?',\n    rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n    rsSeq = rsOptVar + reOptMod + rsOptJoin,\n    rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\n\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n/**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n\nfunction unicodeSize(string) {\n  var result = reUnicode.lastIndex = 0;\n\n  while (reUnicode.test(string)) {\n    ++result;\n  }\n\n  return result;\n}\n\nexport default unicodeSize;","import asciiSize from './_asciiSize.js';\nimport hasUnicode from './_hasUnicode.js';\nimport unicodeSize from './_unicodeSize.js';\n/**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\n\nfunction stringSize(string) {\n  return hasUnicode(string) ? unicodeSize(string) : asciiSize(string);\n}\n\nexport default stringSize;","import baseKeys from './_baseKeys.js';\nimport getTag from './_getTag.js';\nimport isArrayLike from './isArrayLike.js';\nimport isString from './isString.js';\nimport stringSize from './_stringSize.js';\n/** `Object#toString` result references. */\n\nvar mapTag = '[object Map]',\n    setTag = '[object Set]';\n/**\n * Gets the size of `collection` by returning its length for array-like\n * values or the number of own enumerable string keyed properties for objects.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @returns {number} Returns the collection size.\n * @example\n *\n * _.size([1, 2, 3]);\n * // => 3\n *\n * _.size({ 'a': 1, 'b': 2 });\n * // => 2\n *\n * _.size('pebbles');\n * // => 7\n */\n\nfunction size(collection) {\n  if (collection == null) {\n    return 0;\n  }\n\n  if (isArrayLike(collection)) {\n    return isString(collection) ? stringSize(collection) : collection.length;\n  }\n\n  var tag = getTag(collection);\n\n  if (tag == mapTag || tag == setTag) {\n    return collection.size;\n  }\n\n  return baseKeys(collection).length;\n}\n\nexport default size;","import baseDifference from './_baseDifference.js';\nimport baseFlatten from './_baseFlatten.js';\nimport baseRest from './_baseRest.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\n/**\n * Creates an array of `array` values not included in the other given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * **Note:** Unlike `_.pullAll`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.without, _.xor\n * @example\n *\n * _.difference([2, 1], [2, 3]);\n * // => [1]\n */\n\nvar difference = baseRest(function (array, values) {\n  return isArrayLikeObject(array) ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true)) : [];\n});\nexport default difference;","import baseFlatten from './_baseFlatten.js';\nimport baseRest from './_baseRest.js';\nimport baseUniq from './_baseUniq.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\n/**\n * Creates an array of unique values, in order, from all given arrays using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.union([2], [1, 2]);\n * // => [2, 1]\n */\n\nvar union = baseRest(function (arrays) {\n  return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\n});\nexport default union;","import baseIsEqual from './_baseIsEqual.js';\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\n\nfunction isEqual(value, other) {\n  return baseIsEqual(value, other);\n}\n\nexport default isEqual;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React, { PureComponent } from 'react';\nimport { createShorthandFactory, customPropTypes, getElementType, getUnhandledProps } from '../../lib';\nexport var names = ['ad', 'andorra', 'ae', 'united arab emirates', 'uae', 'af', 'afghanistan', 'ag', 'antigua', 'ai', 'anguilla', 'al', 'albania', 'am', 'armenia', 'an', 'netherlands antilles', 'ao', 'angola', 'ar', 'argentina', 'as', 'american samoa', 'at', 'austria', 'au', 'australia', 'aw', 'aruba', 'ax', 'aland islands', 'az', 'azerbaijan', 'ba', 'bosnia', 'bb', 'barbados', 'bd', 'bangladesh', 'be', 'belgium', 'bf', 'burkina faso', 'bg', 'bulgaria', 'bh', 'bahrain', 'bi', 'burundi', 'bj', 'benin', 'bm', 'bermuda', 'bn', 'brunei', 'bo', 'bolivia', 'br', 'brazil', 'bs', 'bahamas', 'bt', 'bhutan', 'bv', 'bouvet island', 'bw', 'botswana', 'by', 'belarus', 'bz', 'belize', 'ca', 'canada', 'cc', 'cocos islands', 'cd', 'congo', 'cf', 'central african republic', 'cg', 'congo brazzaville', 'ch', 'switzerland', 'ci', 'cote divoire', 'ck', 'cook islands', 'cl', 'chile', 'cm', 'cameroon', 'cn', 'china', 'co', 'colombia', 'cr', 'costa rica', 'cs', 'cu', 'cuba', 'cv', 'cape verde', 'cx', 'christmas island', 'cy', 'cyprus', 'cz', 'czech republic', 'de', 'germany', 'dj', 'djibouti', 'dk', 'denmark', 'dm', 'dominica', 'do', 'dominican republic', 'dz', 'algeria', 'ec', 'ecuador', 'england', 'gb eng', 'ee', 'estonia', 'eg', 'egypt', 'eh', 'western sahara', 'er', 'eritrea', 'es', 'spain', 'et', 'ethiopia', 'eu', 'european union', 'fi', 'finland', 'fj', 'fiji', 'fk', 'falkland islands', 'fm', 'micronesia', 'fo', 'faroe islands', 'fr', 'france', 'ga', 'gabon', 'gb', 'uk', 'united kingdom', 'gd', 'grenada', 'ge', 'georgia', 'gf', 'french guiana', 'gh', 'ghana', 'gi', 'gibraltar', 'gl', 'greenland', 'gm', 'gambia', 'gn', 'guinea', 'gp', 'guadeloupe', 'gq', 'equatorial guinea', 'gr', 'greece', 'gs', 'sandwich islands', 'gt', 'guatemala', 'gu', 'guam', 'gw', 'guinea-bissau', 'gy', 'guyana', 'hk', 'hong kong', 'hm', 'heard island', 'hn', 'honduras', 'hr', 'croatia', 'ht', 'haiti', 'hu', 'hungary', 'id', 'indonesia', 'ie', 'ireland', 'il', 'israel', 'in', 'india', 'io', 'indian ocean territory', 'iq', 'iraq', 'ir', 'iran', 'is', 'iceland', 'it', 'italy', 'jm', 'jamaica', 'jo', 'jordan', 'jp', 'japan', 'ke', 'kenya', 'kg', 'kyrgyzstan', 'kh', 'cambodia', 'ki', 'kiribati', 'km', 'comoros', 'kn', 'saint kitts and nevis', 'kp', 'north korea', 'kr', 'south korea', 'kw', 'kuwait', 'ky', 'cayman islands', 'kz', 'kazakhstan', 'la', 'laos', 'lb', 'lebanon', 'lc', 'saint lucia', 'li', 'liechtenstein', 'lk', 'sri lanka', 'lr', 'liberia', 'ls', 'lesotho', 'lt', 'lithuania', 'lu', 'luxembourg', 'lv', 'latvia', 'ly', 'libya', 'ma', 'morocco', 'mc', 'monaco', 'md', 'moldova', 'me', 'montenegro', 'mg', 'madagascar', 'mh', 'marshall islands', 'mk', 'macedonia', 'ml', 'mali', 'mm', 'myanmar', 'burma', 'mn', 'mongolia', 'mo', 'macau', 'mp', 'northern mariana islands', 'mq', 'martinique', 'mr', 'mauritania', 'ms', 'montserrat', 'mt', 'malta', 'mu', 'mauritius', 'mv', 'maldives', 'mw', 'malawi', 'mx', 'mexico', 'my', 'malaysia', 'mz', 'mozambique', 'na', 'namibia', 'nc', 'new caledonia', 'ne', 'niger', 'nf', 'norfolk island', 'ng', 'nigeria', 'ni', 'nicaragua', 'nl', 'netherlands', 'no', 'norway', 'np', 'nepal', 'nr', 'nauru', 'nu', 'niue', 'nz', 'new zealand', 'om', 'oman', 'pa', 'panama', 'pe', 'peru', 'pf', 'french polynesia', 'pg', 'new guinea', 'ph', 'philippines', 'pk', 'pakistan', 'pl', 'poland', 'pm', 'saint pierre', 'pn', 'pitcairn islands', 'pr', 'puerto rico', 'ps', 'palestine', 'pt', 'portugal', 'pw', 'palau', 'py', 'paraguay', 'qa', 'qatar', 're', 'reunion', 'ro', 'romania', 'rs', 'serbia', 'ru', 'russia', 'rw', 'rwanda', 'sa', 'saudi arabia', 'sb', 'solomon islands', 'sc', 'seychelles', 'gb sct', 'scotland', 'sd', 'sudan', 'se', 'sweden', 'sg', 'singapore', 'sh', 'saint helena', 'si', 'slovenia', 'sj', 'svalbard', 'jan mayen', 'sk', 'slovakia', 'sl', 'sierra leone', 'sm', 'san marino', 'sn', 'senegal', 'so', 'somalia', 'sr', 'suriname', 'st', 'sao tome', 'sv', 'el salvador', 'sy', 'syria', 'sz', 'swaziland', 'tc', 'caicos islands', 'td', 'chad', 'tf', 'french territories', 'tg', 'togo', 'th', 'thailand', 'tj', 'tajikistan', 'tk', 'tokelau', 'tl', 'timorleste', 'tm', 'turkmenistan', 'tn', 'tunisia', 'to', 'tonga', 'tr', 'turkey', 'tt', 'trinidad', 'tv', 'tuvalu', 'tw', 'taiwan', 'tz', 'tanzania', 'ua', 'ukraine', 'ug', 'uganda', 'um', 'us minor islands', 'us', 'america', 'united states', 'uy', 'uruguay', 'uz', 'uzbekistan', 'va', 'vatican city', 'vc', 'saint vincent', 've', 'venezuela', 'vg', 'british virgin islands', 'vi', 'us virgin islands', 'vn', 'vietnam', 'vu', 'vanuatu', 'gb wls', 'wales', 'wf', 'wallis and futuna', 'ws', 'samoa', 'ye', 'yemen', 'yt', 'mayotte', 'za', 'south africa', 'zm', 'zambia', 'zw', 'zimbabwe'];\n/**\n * A flag is is used to represent a political state.\n */\n\nvar Flag = /*#__PURE__*/function (_PureComponent) {\n  _inheritsLoose(Flag, _PureComponent);\n\n  function Flag() {\n    return _PureComponent.apply(this, arguments) || this;\n  }\n\n  var _proto = Flag.prototype;\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        className = _this$props.className,\n        name = _this$props.name;\n    var classes = cx(name, 'flag', className);\n    var rest = getUnhandledProps(Flag, this.props);\n    var ElementType = getElementType(Flag, this.props);\n    return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n      className: classes\n    }));\n  };\n\n  return Flag;\n}(PureComponent);\n\nFlag.handledProps = [\"as\", \"className\", \"name\"];\nFlag.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Flag name, can use the two digit country code, the full name, or a common alias. */\n  name: customPropTypes.suggest(names)\n} : {};\nFlag.defaultProps = {\n  as: 'i'\n};\nFlag.create = createShorthandFactory(Flag, function (value) {\n  return {\n    name: value\n  };\n});\nexport default Flag;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\n/**\n * A dropdown menu can contain dividers to separate related content.\n */\n\nfunction DropdownDivider(props) {\n  var className = props.className;\n  var classes = cx('divider', className);\n  var rest = getUnhandledProps(DropdownDivider, props);\n  var ElementType = getElementType(DropdownDivider, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    className: classes\n  }));\n}\n\nDropdownDivider.handledProps = [\"as\", \"className\"];\nDropdownDivider.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Additional classes. */\n  className: PropTypes.string\n} : {};\nexport default DropdownDivider;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _isNil from \"lodash-es/isNil\";\nimport _invoke from \"lodash-es/invoke\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport { childrenUtils, createShorthand, createShorthandFactory, customPropTypes, getElementType, getUnhandledProps, useKeyOnly } from '../../lib';\nimport Flag from '../../elements/Flag';\nimport Icon from '../../elements/Icon';\nimport Image from '../../elements/Image';\nimport Label from '../../elements/Label';\n/**\n * An item sub-component for Dropdown component.\n */\n\nvar DropdownItem = /*#__PURE__*/function (_Component) {\n  _inheritsLoose(DropdownItem, _Component);\n\n  function DropdownItem() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _Component.call.apply(_Component, [this].concat(args)) || this;\n\n    _this.handleClick = function (e) {\n      _invoke(_this.props, 'onClick', e, _this.props);\n    };\n\n    return _this;\n  }\n\n  var _proto = DropdownItem.prototype;\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        active = _this$props.active,\n        children = _this$props.children,\n        className = _this$props.className,\n        content = _this$props.content,\n        disabled = _this$props.disabled,\n        description = _this$props.description,\n        flag = _this$props.flag,\n        icon = _this$props.icon,\n        image = _this$props.image,\n        label = _this$props.label,\n        selected = _this$props.selected,\n        text = _this$props.text;\n    var classes = cx(useKeyOnly(active, 'active'), useKeyOnly(disabled, 'disabled'), useKeyOnly(selected, 'selected'), 'item', className); // add default dropdown icon if item contains another menu\n\n    var iconName = _isNil(icon) ? childrenUtils.someByType(children, 'DropdownMenu') && 'dropdown' : icon;\n    var rest = getUnhandledProps(DropdownItem, this.props);\n    var ElementType = getElementType(DropdownItem, this.props);\n    var ariaOptions = {\n      role: 'option',\n      'aria-disabled': disabled,\n      'aria-checked': active,\n      'aria-selected': selected\n    };\n\n    if (!childrenUtils.isNil(children)) {\n      return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, ariaOptions, {\n        className: classes,\n        onClick: this.handleClick\n      }), children);\n    }\n\n    var flagElement = Flag.create(flag, {\n      autoGenerateKey: false\n    });\n    var iconElement = Icon.create(iconName, {\n      autoGenerateKey: false\n    });\n    var imageElement = Image.create(image, {\n      autoGenerateKey: false\n    });\n    var labelElement = Label.create(label, {\n      autoGenerateKey: false\n    });\n    var descriptionElement = createShorthand('span', function (val) {\n      return {\n        children: val\n      };\n    }, description, {\n      defaultProps: {\n        className: 'description'\n      },\n      autoGenerateKey: false\n    });\n    var textElement = createShorthand('span', function (val) {\n      return {\n        children: val\n      };\n    }, childrenUtils.isNil(content) ? text : content, {\n      defaultProps: {\n        className: 'text'\n      },\n      autoGenerateKey: false\n    });\n    return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, ariaOptions, {\n      className: classes,\n      onClick: this.handleClick\n    }), imageElement, iconElement, flagElement, labelElement, descriptionElement, textElement);\n  };\n\n  return DropdownItem;\n}(Component);\n\nDropdownItem.handledProps = [\"active\", \"as\", \"children\", \"className\", \"content\", \"description\", \"disabled\", \"flag\", \"icon\", \"image\", \"label\", \"onClick\", \"selected\", \"text\", \"value\"];\nDropdownItem.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Style as the currently chosen item. */\n  active: PropTypes.bool,\n\n  /** Primary content. */\n  children: PropTypes.node,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Shorthand for primary content. */\n  content: customPropTypes.contentShorthand,\n\n  /** Additional text with less emphasis. */\n  description: customPropTypes.itemShorthand,\n\n  /** A dropdown item can be disabled. */\n  disabled: PropTypes.bool,\n\n  /** Shorthand for Flag. */\n  flag: customPropTypes.itemShorthand,\n\n  /** Shorthand for Icon. */\n  icon: customPropTypes.itemShorthand,\n\n  /** Shorthand for Image. */\n  image: customPropTypes.itemShorthand,\n\n  /** Shorthand for Label. */\n  label: customPropTypes.itemShorthand,\n\n  /**\n   * Called on click.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props.\n   */\n  onClick: PropTypes.func,\n\n  /**\n   * The item currently selected by keyboard shortcut.\n   * This is not the active item.\n   */\n  selected: PropTypes.bool,\n\n  /** Display text. */\n  text: customPropTypes.contentShorthand,\n\n  /** Stored value. */\n  value: PropTypes.oneOfType([PropTypes.bool, PropTypes.number, PropTypes.string])\n} : {};\nDropdownItem.create = createShorthandFactory(DropdownItem, function (opts) {\n  return opts;\n});\nexport default DropdownItem;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { childrenUtils, createShorthandFactory, customPropTypes, getElementType, getUnhandledProps } from '../../lib';\nimport Icon from '../../elements/Icon';\n/**\n * A dropdown menu can contain a header.\n */\n\nfunction DropdownHeader(props) {\n  var children = props.children,\n      className = props.className,\n      content = props.content,\n      icon = props.icon;\n  var classes = cx('header', className);\n  var rest = getUnhandledProps(DropdownHeader, props);\n  var ElementType = getElementType(DropdownHeader, props);\n\n  if (!childrenUtils.isNil(children)) {\n    return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n      className: classes\n    }), children);\n  }\n\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    className: classes\n  }), Icon.create(icon, {\n    autoGenerateKey: false\n  }), content);\n}\n\nDropdownHeader.handledProps = [\"as\", \"children\", \"className\", \"content\", \"icon\"];\nDropdownHeader.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function) */\n  as: PropTypes.elementType,\n\n  /** Primary content. */\n  children: PropTypes.node,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Shorthand for primary content. */\n  content: customPropTypes.contentShorthand,\n\n  /** Shorthand for Icon. */\n  icon: customPropTypes.itemShorthand\n} : {};\nDropdownHeader.create = createShorthandFactory(DropdownHeader, function (content) {\n  return {\n    content: content\n  };\n});\nexport default DropdownHeader;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { childrenUtils, customPropTypes, getElementType, getUnhandledProps, useKeyOnly } from '../../lib';\n/**\n * A dropdown menu can contain a menu.\n */\n\nfunction DropdownMenu(props) {\n  var children = props.children,\n      className = props.className,\n      content = props.content,\n      direction = props.direction,\n      open = props.open,\n      scrolling = props.scrolling;\n  var classes = cx(direction, useKeyOnly(open, 'visible'), useKeyOnly(scrolling, 'scrolling'), 'menu transition', className);\n  var rest = getUnhandledProps(DropdownMenu, props);\n  var ElementType = getElementType(DropdownMenu, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    className: classes\n  }), childrenUtils.isNil(children) ? content : children);\n}\n\nDropdownMenu.handledProps = [\"as\", \"children\", \"className\", \"content\", \"direction\", \"open\", \"scrolling\"];\nDropdownMenu.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Primary content. */\n  children: PropTypes.node,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Shorthand for primary content. */\n  content: customPropTypes.contentShorthand,\n\n  /** A dropdown menu can open to the left or to the right. */\n  direction: PropTypes.oneOf(['left', 'right']),\n\n  /** Whether or not the dropdown menu is displayed. */\n  open: PropTypes.bool,\n\n  /** A dropdown menu can scroll. */\n  scrolling: PropTypes.bool\n} : {};\nexport default DropdownMenu;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _invoke from \"lodash-es/invoke\";\nimport _get from \"lodash-es/get\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport { createShorthandFactory, getUnhandledProps } from '../../lib';\n/**\n * A search item sub-component for Dropdown component.\n */\n\nvar DropdownSearchInput = /*#__PURE__*/function (_Component) {\n  _inheritsLoose(DropdownSearchInput, _Component);\n\n  function DropdownSearchInput() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _Component.call.apply(_Component, [this].concat(args)) || this;\n\n    _this.handleChange = function (e) {\n      var value = _get(e, 'target.value');\n\n      _invoke(_this.props, 'onChange', e, _extends({}, _this.props, {\n        value: value\n      }));\n    };\n\n    return _this;\n  }\n\n  var _proto = DropdownSearchInput.prototype;\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        autoComplete = _this$props.autoComplete,\n        className = _this$props.className,\n        tabIndex = _this$props.tabIndex,\n        type = _this$props.type,\n        value = _this$props.value;\n    var classes = cx('search', className);\n    var rest = getUnhandledProps(DropdownSearchInput, this.props);\n    return /*#__PURE__*/React.createElement(\"input\", _extends({}, rest, {\n      \"aria-autocomplete\": \"list\",\n      autoComplete: autoComplete,\n      className: classes,\n      onChange: this.handleChange,\n      tabIndex: tabIndex,\n      type: type,\n      value: value\n    }));\n  };\n\n  return DropdownSearchInput;\n}(Component);\n\nDropdownSearchInput.handledProps = [\"as\", \"autoComplete\", \"className\", \"tabIndex\", \"type\", \"value\"];\nDropdownSearchInput.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** An input can have the auto complete. */\n  autoComplete: PropTypes.string,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** An input can receive focus. */\n  tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n  /** The HTML input type. */\n  type: PropTypes.string,\n\n  /** Stored value. */\n  value: PropTypes.oneOfType([PropTypes.number, PropTypes.string])\n} : {};\nDropdownSearchInput.defaultProps = {\n  autoComplete: 'off',\n  type: 'text'\n};\nDropdownSearchInput.create = createShorthandFactory(DropdownSearchInput, function (type) {\n  return {\n    type: type\n  };\n});\nexport default DropdownSearchInput;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { childrenUtils, createShorthandFactory, customPropTypes, getElementType, getUnhandledProps } from '../../lib';\n/**\n * A dropdown contains a selected value.\n */\n\nfunction DropdownText(props) {\n  var children = props.children,\n      className = props.className,\n      content = props.content;\n  var classes = cx('divider', className);\n  var rest = getUnhandledProps(DropdownText, props);\n  var ElementType = getElementType(DropdownText, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({\n    \"aria-atomic\": true,\n    \"aria-live\": \"polite\",\n    role: \"alert\"\n  }, rest, {\n    className: classes\n  }), childrenUtils.isNil(children) ? content : children);\n}\n\nDropdownText.handledProps = [\"as\", \"children\", \"className\", \"content\"];\nDropdownText.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Primary content. */\n  children: PropTypes.node,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Shorthand for primary content. */\n  content: customPropTypes.contentShorthand\n} : {};\nDropdownText.create = createShorthandFactory(DropdownText, function (val) {\n  return {\n    content: val\n  };\n});\nexport default DropdownText;","import toString from './toString.js';\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\n\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g,\n    reHasRegExpChar = RegExp(reRegExpChar.source);\n/**\n * Escapes the `RegExp` special characters \"^\", \"$\", \"\\\", \".\", \"*\", \"+\",\n * \"?\", \"(\", \")\", \"[\", \"]\", \"{\", \"}\", and \"|\" in `string`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escapeRegExp('[lodash](https://lodash.com/)');\n * // => '\\[lodash\\]\\(https://lodash\\.com/\\)'\n */\n\nfunction escapeRegExp(string) {\n  string = toString(string);\n  return string && reHasRegExpChar.test(string) ? string.replace(reRegExpChar, '\\\\$&') : string;\n}\n\nexport default escapeRegExp;","/**\n * The base implementation of `_.propertyOf` without support for deep paths.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyOf(object) {\n  return function (key) {\n    return object == null ? undefined : object[key];\n  };\n}\n\nexport default basePropertyOf;","import basePropertyOf from './_basePropertyOf.js';\n/** Used to map Latin Unicode letters to basic Latin letters. */\n\nvar deburredLetters = {\n  // Latin-1 Supplement block.\n  '\\xc0': 'A',\n  '\\xc1': 'A',\n  '\\xc2': 'A',\n  '\\xc3': 'A',\n  '\\xc4': 'A',\n  '\\xc5': 'A',\n  '\\xe0': 'a',\n  '\\xe1': 'a',\n  '\\xe2': 'a',\n  '\\xe3': 'a',\n  '\\xe4': 'a',\n  '\\xe5': 'a',\n  '\\xc7': 'C',\n  '\\xe7': 'c',\n  '\\xd0': 'D',\n  '\\xf0': 'd',\n  '\\xc8': 'E',\n  '\\xc9': 'E',\n  '\\xca': 'E',\n  '\\xcb': 'E',\n  '\\xe8': 'e',\n  '\\xe9': 'e',\n  '\\xea': 'e',\n  '\\xeb': 'e',\n  '\\xcc': 'I',\n  '\\xcd': 'I',\n  '\\xce': 'I',\n  '\\xcf': 'I',\n  '\\xec': 'i',\n  '\\xed': 'i',\n  '\\xee': 'i',\n  '\\xef': 'i',\n  '\\xd1': 'N',\n  '\\xf1': 'n',\n  '\\xd2': 'O',\n  '\\xd3': 'O',\n  '\\xd4': 'O',\n  '\\xd5': 'O',\n  '\\xd6': 'O',\n  '\\xd8': 'O',\n  '\\xf2': 'o',\n  '\\xf3': 'o',\n  '\\xf4': 'o',\n  '\\xf5': 'o',\n  '\\xf6': 'o',\n  '\\xf8': 'o',\n  '\\xd9': 'U',\n  '\\xda': 'U',\n  '\\xdb': 'U',\n  '\\xdc': 'U',\n  '\\xf9': 'u',\n  '\\xfa': 'u',\n  '\\xfb': 'u',\n  '\\xfc': 'u',\n  '\\xdd': 'Y',\n  '\\xfd': 'y',\n  '\\xff': 'y',\n  '\\xc6': 'Ae',\n  '\\xe6': 'ae',\n  '\\xde': 'Th',\n  '\\xfe': 'th',\n  '\\xdf': 'ss',\n  // Latin Extended-A block.\n  \"\\u0100\": 'A',\n  \"\\u0102\": 'A',\n  \"\\u0104\": 'A',\n  \"\\u0101\": 'a',\n  \"\\u0103\": 'a',\n  \"\\u0105\": 'a',\n  \"\\u0106\": 'C',\n  \"\\u0108\": 'C',\n  \"\\u010A\": 'C',\n  \"\\u010C\": 'C',\n  \"\\u0107\": 'c',\n  \"\\u0109\": 'c',\n  \"\\u010B\": 'c',\n  \"\\u010D\": 'c',\n  \"\\u010E\": 'D',\n  \"\\u0110\": 'D',\n  \"\\u010F\": 'd',\n  \"\\u0111\": 'd',\n  \"\\u0112\": 'E',\n  \"\\u0114\": 'E',\n  \"\\u0116\": 'E',\n  \"\\u0118\": 'E',\n  \"\\u011A\": 'E',\n  \"\\u0113\": 'e',\n  \"\\u0115\": 'e',\n  \"\\u0117\": 'e',\n  \"\\u0119\": 'e',\n  \"\\u011B\": 'e',\n  \"\\u011C\": 'G',\n  \"\\u011E\": 'G',\n  \"\\u0120\": 'G',\n  \"\\u0122\": 'G',\n  \"\\u011D\": 'g',\n  \"\\u011F\": 'g',\n  \"\\u0121\": 'g',\n  \"\\u0123\": 'g',\n  \"\\u0124\": 'H',\n  \"\\u0126\": 'H',\n  \"\\u0125\": 'h',\n  \"\\u0127\": 'h',\n  \"\\u0128\": 'I',\n  \"\\u012A\": 'I',\n  \"\\u012C\": 'I',\n  \"\\u012E\": 'I',\n  \"\\u0130\": 'I',\n  \"\\u0129\": 'i',\n  \"\\u012B\": 'i',\n  \"\\u012D\": 'i',\n  \"\\u012F\": 'i',\n  \"\\u0131\": 'i',\n  \"\\u0134\": 'J',\n  \"\\u0135\": 'j',\n  \"\\u0136\": 'K',\n  \"\\u0137\": 'k',\n  \"\\u0138\": 'k',\n  \"\\u0139\": 'L',\n  \"\\u013B\": 'L',\n  \"\\u013D\": 'L',\n  \"\\u013F\": 'L',\n  \"\\u0141\": 'L',\n  \"\\u013A\": 'l',\n  \"\\u013C\": 'l',\n  \"\\u013E\": 'l',\n  \"\\u0140\": 'l',\n  \"\\u0142\": 'l',\n  \"\\u0143\": 'N',\n  \"\\u0145\": 'N',\n  \"\\u0147\": 'N',\n  \"\\u014A\": 'N',\n  \"\\u0144\": 'n',\n  \"\\u0146\": 'n',\n  \"\\u0148\": 'n',\n  \"\\u014B\": 'n',\n  \"\\u014C\": 'O',\n  \"\\u014E\": 'O',\n  \"\\u0150\": 'O',\n  \"\\u014D\": 'o',\n  \"\\u014F\": 'o',\n  \"\\u0151\": 'o',\n  \"\\u0154\": 'R',\n  \"\\u0156\": 'R',\n  \"\\u0158\": 'R',\n  \"\\u0155\": 'r',\n  \"\\u0157\": 'r',\n  \"\\u0159\": 'r',\n  \"\\u015A\": 'S',\n  \"\\u015C\": 'S',\n  \"\\u015E\": 'S',\n  \"\\u0160\": 'S',\n  \"\\u015B\": 's',\n  \"\\u015D\": 's',\n  \"\\u015F\": 's',\n  \"\\u0161\": 's',\n  \"\\u0162\": 'T',\n  \"\\u0164\": 'T',\n  \"\\u0166\": 'T',\n  \"\\u0163\": 't',\n  \"\\u0165\": 't',\n  \"\\u0167\": 't',\n  \"\\u0168\": 'U',\n  \"\\u016A\": 'U',\n  \"\\u016C\": 'U',\n  \"\\u016E\": 'U',\n  \"\\u0170\": 'U',\n  \"\\u0172\": 'U',\n  \"\\u0169\": 'u',\n  \"\\u016B\": 'u',\n  \"\\u016D\": 'u',\n  \"\\u016F\": 'u',\n  \"\\u0171\": 'u',\n  \"\\u0173\": 'u',\n  \"\\u0174\": 'W',\n  \"\\u0175\": 'w',\n  \"\\u0176\": 'Y',\n  \"\\u0177\": 'y',\n  \"\\u0178\": 'Y',\n  \"\\u0179\": 'Z',\n  \"\\u017B\": 'Z',\n  \"\\u017D\": 'Z',\n  \"\\u017A\": 'z',\n  \"\\u017C\": 'z',\n  \"\\u017E\": 'z',\n  \"\\u0132\": 'IJ',\n  \"\\u0133\": 'ij',\n  \"\\u0152\": 'Oe',\n  \"\\u0153\": 'oe',\n  \"\\u0149\": \"'n\",\n  \"\\u017F\": 's'\n};\n/**\n * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A\n * letters to basic Latin letters.\n *\n * @private\n * @param {string} letter The matched letter to deburr.\n * @returns {string} Returns the deburred letter.\n */\n\nvar deburrLetter = basePropertyOf(deburredLetters);\nexport default deburrLetter;","import deburrLetter from './_deburrLetter.js';\nimport toString from './toString.js';\n/** Used to match Latin Unicode letters (excluding mathematical operators). */\n\nvar reLatin = /[\\xc0-\\xd6\\xd8-\\xf6\\xf8-\\xff\\u0100-\\u017f]/g;\n/** Used to compose unicode character classes. */\n\nvar rsComboMarksRange = \"\\\\u0300-\\\\u036f\",\n    reComboHalfMarksRange = \"\\\\ufe20-\\\\ufe2f\",\n    rsComboSymbolsRange = \"\\\\u20d0-\\\\u20ff\",\n    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange;\n/** Used to compose unicode capture groups. */\n\nvar rsCombo = '[' + rsComboRange + ']';\n/**\n * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and\n * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).\n */\n\nvar reComboMark = RegExp(rsCombo, 'g');\n/**\n * Deburrs `string` by converting\n * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)\n * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)\n * letters to basic Latin letters and removing\n * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to deburr.\n * @returns {string} Returns the deburred string.\n * @example\n *\n * _.deburr('déjà vu');\n * // => 'deja vu'\n */\n\nfunction deburr(string) {\n  string = toString(string);\n  return string && string.replace(reLatin, deburrLetter).replace(reComboMark, '');\n}\n\nexport default deburr;","import _some from \"lodash-es/some\";\nimport _escapeRegExp from \"lodash-es/escapeRegExp\";\nimport _deburr from \"lodash-es/deburr\";\nimport _isFunction from \"lodash-es/isFunction\";\nimport _includes from \"lodash-es/includes\";\nimport _filter from \"lodash-es/filter\";\nimport React from 'react'; // There are times when we need to calculate the options based on a value\n// that hasn't yet been persisted to state.\n\nexport default function getMenuOptions(config) {\n  var additionLabel = config.additionLabel,\n      additionPosition = config.additionPosition,\n      allowAdditions = config.allowAdditions,\n      deburr = config.deburr,\n      multiple = config.multiple,\n      options = config.options,\n      search = config.search,\n      searchQuery = config.searchQuery,\n      value = config.value;\n  var filteredOptions = options; // filter out active options\n\n  if (multiple) {\n    filteredOptions = _filter(filteredOptions, function (opt) {\n      return !_includes(value, opt.value);\n    });\n  } // filter by search query\n\n\n  if (search && searchQuery) {\n    if (_isFunction(search)) {\n      filteredOptions = search(filteredOptions, searchQuery);\n    } else {\n      // remove diacritics on search input and options, if deburr prop is set\n      var strippedQuery = deburr ? _deburr(searchQuery) : searchQuery;\n      var re = new RegExp(_escapeRegExp(strippedQuery), 'i');\n      filteredOptions = _filter(filteredOptions, function (opt) {\n        return re.test(deburr ? _deburr(opt.text) : opt.text);\n      });\n    }\n  } // insert the \"add\" item\n\n\n  if (allowAdditions && search && searchQuery && !_some(filteredOptions, {\n    text: searchQuery\n  })) {\n    var additionLabelElement = /*#__PURE__*/React.isValidElement(additionLabel) ? /*#__PURE__*/React.cloneElement(additionLabel, {\n      key: 'addition-label'\n    }) : additionLabel || '';\n    var addItem = {\n      key: 'addition',\n      // by using an array, we can pass multiple elements, but when doing so\n      // we must specify a `key` for React to know which one is which\n      text: [additionLabelElement, /*#__PURE__*/React.createElement(\"b\", {\n        key: \"addition-query\"\n      }, searchQuery)],\n      value: searchQuery,\n      className: 'addition',\n      'data-additional': true\n    };\n    if (additionPosition === 'top') filteredOptions.unshift(addItem);else filteredOptions.push(addItem);\n  }\n\n  return filteredOptions;\n}\ngetMenuOptions.handledProps = [];","import _includes from \"lodash-es/includes\";\nimport _find from \"lodash-es/find\";\nimport _findIndex from \"lodash-es/findIndex\";\nimport _reduce from \"lodash-es/reduce\";\nimport getMenuOptions from './getMenuOptions';\nexport default function getSelectedIndex(config) {\n  var additionLabel = config.additionLabel,\n      additionPosition = config.additionPosition,\n      allowAdditions = config.allowAdditions,\n      deburr = config.deburr,\n      multiple = config.multiple,\n      options = config.options,\n      search = config.search,\n      searchQuery = config.searchQuery,\n      selectedIndex = config.selectedIndex,\n      value = config.value;\n  var menuOptions = getMenuOptions({\n    value: value,\n    options: options,\n    searchQuery: searchQuery,\n    additionLabel: additionLabel,\n    additionPosition: additionPosition,\n    allowAdditions: allowAdditions,\n    deburr: deburr,\n    multiple: multiple,\n    search: search\n  });\n\n  var enabledIndexes = _reduce(menuOptions, function (memo, item, index) {\n    if (!item.disabled) memo.push(index);\n    return memo;\n  }, []);\n\n  var newSelectedIndex; // update the selected index\n\n  if (!selectedIndex || selectedIndex < 0) {\n    var firstIndex = enabledIndexes[0]; // Select the currently active item, if none, use the first item.\n    // Multiple selects remove active items from the list,\n    // their initial selected index should be 0.\n\n    newSelectedIndex = multiple ? firstIndex : _findIndex(menuOptions, ['value', value]) || enabledIndexes[0];\n  } else if (multiple) {\n    newSelectedIndex = _find(enabledIndexes, function (index) {\n      return index >= selectedIndex;\n    }); // multiple selects remove options from the menu as they are made active\n    // keep the selected index within range of the remaining items\n\n    if (selectedIndex >= menuOptions.length - 1) {\n      newSelectedIndex = enabledIndexes[enabledIndexes.length - 1];\n    }\n  } else {\n    var activeIndex = _findIndex(menuOptions, ['value', value]); // regular selects can only have one active item\n    // set the selected index to the currently active item\n\n\n    newSelectedIndex = _includes(enabledIndexes, activeIndex) ? activeIndex : undefined;\n  }\n\n  if (!newSelectedIndex || newSelectedIndex < 0) {\n    newSelectedIndex = enabledIndexes[0];\n  }\n\n  return newSelectedIndex;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _includes from \"lodash-es/includes\";\nimport _compact from \"lodash-es/compact\";\nimport _map from \"lodash-es/map\";\nimport _every from \"lodash-es/every\";\nimport _without from \"lodash-es/without\";\nimport _find from \"lodash-es/find\";\nimport _dropRight from \"lodash-es/dropRight\";\nimport _isEmpty from \"lodash-es/isEmpty\";\nimport _size from \"lodash-es/size\";\nimport _difference from \"lodash-es/difference\";\nimport _union from \"lodash-es/union\";\nimport _get from \"lodash-es/get\";\nimport _noop from \"lodash-es/noop\";\nimport _isUndefined from \"lodash-es/isUndefined\";\nimport _invoke from \"lodash-es/invoke\";\nimport _has from \"lodash-es/has\";\nimport _isEqual from \"lodash-es/isEqual\";\nimport _isFunction from \"lodash-es/isFunction\";\nimport _pick from \"lodash-es/pick\";\nimport _isNil from \"lodash-es/isNil\";\nimport EventStack from '@semantic-ui-react/event-stack';\nimport { Ref } from '@fluentui/react-component-ref';\nimport cx from 'clsx';\nimport keyboardKey from 'keyboard-key';\nimport PropTypes from 'prop-types';\nimport React, { Children, cloneElement, createRef } from 'react';\nimport shallowEqual from 'shallowequal';\nimport { ModernAutoControlledComponent as Component, childrenUtils, customPropTypes, doesNodeContainClick, getElementType, getUnhandledProps, objectDiff, useKeyOnly, useKeyOrValueAndKey } from '../../lib';\nimport Icon from '../../elements/Icon';\nimport Label from '../../elements/Label';\nimport Flag from '../../elements/Flag';\nimport Image from '../../elements/Image';\nimport DropdownDivider from './DropdownDivider';\nimport DropdownItem from './DropdownItem';\nimport DropdownHeader from './DropdownHeader';\nimport DropdownMenu from './DropdownMenu';\nimport DropdownSearchInput from './DropdownSearchInput';\nimport DropdownText from './DropdownText';\nimport getMenuOptions from './utils/getMenuOptions';\nimport getSelectedIndex from './utils/getSelectedIndex';\n\nvar getKeyOrValue = function getKeyOrValue(key, value) {\n  return _isNil(key) ? value : key;\n};\n\nvar getKeyAndValues = function getKeyAndValues(options) {\n  return options ? options.map(function (option) {\n    return _pick(option, ['key', 'value']);\n  }) : options;\n};\n\nfunction renderItemContent(item) {\n  var flag = item.flag,\n      image = item.image,\n      text = item.text; // TODO: remove this in v3\n  // This maintains compatibility with Shorthand API in v1 as this might be called in \"Label.create()\"\n\n  if (_isFunction(text)) {\n    return text;\n  }\n\n  return {\n    content: /*#__PURE__*/React.createElement(React.Fragment, null, Flag.create(flag), Image.create(image), text)\n  };\n}\n/**\n * A dropdown allows a user to select a value from a series of options.\n * @see Form\n * @see Select\n * @see Menu\n */\n\n\nvar Dropdown = /*#__PURE__*/function (_Component) {\n  _inheritsLoose(Dropdown, _Component);\n\n  function Dropdown() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _Component.call.apply(_Component, [this].concat(args)) || this;\n    _this.searchRef = /*#__PURE__*/createRef();\n    _this.sizerRef = /*#__PURE__*/createRef();\n    _this.ref = /*#__PURE__*/createRef();\n\n    _this.handleChange = function (e, value) {\n      _invoke(_this.props, 'onChange', e, _extends({}, _this.props, {\n        value: value\n      }));\n    };\n\n    _this.closeOnChange = function (e) {\n      var _this$props = _this.props,\n          closeOnChange = _this$props.closeOnChange,\n          multiple = _this$props.multiple;\n      var shouldClose = _isUndefined(closeOnChange) ? !multiple : closeOnChange;\n\n      if (shouldClose) {\n        _this.close(e, _noop);\n      }\n    };\n\n    _this.closeOnEscape = function (e) {\n      if (!_this.props.closeOnEscape) return;\n      if (keyboardKey.getCode(e) !== keyboardKey.Escape) return;\n      e.preventDefault();\n\n      _this.close(e);\n    };\n\n    _this.moveSelectionOnKeyDown = function (e) {\n      var _moves;\n\n      var _this$props2 = _this.props,\n          multiple = _this$props2.multiple,\n          selectOnNavigation = _this$props2.selectOnNavigation;\n      var open = _this.state.open;\n\n      if (!open) {\n        return;\n      }\n\n      var moves = (_moves = {}, _moves[keyboardKey.ArrowDown] = 1, _moves[keyboardKey.ArrowUp] = -1, _moves);\n      var move = moves[keyboardKey.getCode(e)];\n\n      if (move === undefined) {\n        return;\n      }\n\n      e.preventDefault();\n\n      var nextIndex = _this.getSelectedIndexAfterMove(move);\n\n      if (!multiple && selectOnNavigation) {\n        _this.makeSelectedItemActive(e, nextIndex);\n      }\n\n      _this.setState({\n        selectedIndex: nextIndex\n      });\n    };\n\n    _this.openOnSpace = function (e) {\n      var _e$target, _e$target2, _e$target3;\n\n      var shouldHandleEvent = _this.state.focus && !_this.state.open && keyboardKey.getCode(e) === keyboardKey.Spacebar;\n      var shouldPreventDefault = ((_e$target = e.target) == null ? void 0 : _e$target.tagName) !== 'INPUT' && ((_e$target2 = e.target) == null ? void 0 : _e$target2.tagName) !== 'TEXTAREA' && ((_e$target3 = e.target) == null ? void 0 : _e$target3.isContentEditable) !== true;\n\n      if (shouldHandleEvent) {\n        if (shouldPreventDefault) {\n          e.preventDefault();\n        }\n\n        _this.open(e);\n      }\n    };\n\n    _this.openOnArrow = function (e) {\n      var _this$state = _this.state,\n          focus = _this$state.focus,\n          open = _this$state.open;\n\n      if (focus && !open) {\n        var code = keyboardKey.getCode(e);\n\n        if (code === keyboardKey.ArrowDown || code === keyboardKey.ArrowUp) {\n          e.preventDefault();\n\n          _this.open(e);\n        }\n      }\n    };\n\n    _this.makeSelectedItemActive = function (e, selectedIndex) {\n      var _this$state2 = _this.state,\n          open = _this$state2.open,\n          value = _this$state2.value;\n      var multiple = _this.props.multiple;\n\n      var item = _this.getSelectedItem(selectedIndex);\n\n      var selectedValue = _get(item, 'value');\n\n      var disabled = _get(item, 'disabled'); // prevent selecting null if there was no selected item value\n      // prevent selecting duplicate items when the dropdown is closed\n      // prevent selecting disabled items\n\n\n      if (_isNil(selectedValue) || !open || disabled) {\n        return value;\n      } // state value may be undefined\n\n\n      var newValue = multiple ? _union(value, [selectedValue]) : selectedValue;\n      var valueHasChanged = multiple ? !!_difference(newValue, value).length : newValue !== value;\n\n      if (valueHasChanged) {\n        // notify the onChange prop that the user is trying to change value\n        _this.setState({\n          value: newValue\n        });\n\n        _this.handleChange(e, newValue); // Heads up! This event handler should be called after `onChange`\n        // Notify the onAddItem prop if this is a new value\n\n\n        if (item['data-additional']) {\n          _invoke(_this.props, 'onAddItem', e, _extends({}, _this.props, {\n            value: selectedValue\n          }));\n        }\n      }\n\n      return value;\n    };\n\n    _this.selectItemOnEnter = function (e) {\n      var search = _this.props.search;\n      var _this$state3 = _this.state,\n          open = _this$state3.open,\n          selectedIndex = _this$state3.selectedIndex;\n\n      if (!open) {\n        return;\n      }\n\n      var shouldSelect = keyboardKey.getCode(e) === keyboardKey.Enter || // https://github.com/Semantic-Org/Semantic-UI-React/pull/3766\n      !search && keyboardKey.getCode(e) === keyboardKey.Spacebar;\n\n      if (!shouldSelect) {\n        return;\n      }\n\n      e.preventDefault();\n\n      var optionSize = _size(getMenuOptions({\n        value: _this.state.value,\n        options: _this.props.options,\n        searchQuery: _this.state.searchQuery,\n        additionLabel: _this.props.additionLabel,\n        additionPosition: _this.props.additionPosition,\n        allowAdditions: _this.props.allowAdditions,\n        deburr: _this.props.deburr,\n        multiple: _this.props.multiple,\n        search: _this.props.search\n      }));\n\n      if (search && optionSize === 0) {\n        return;\n      }\n\n      var nextValue = _this.makeSelectedItemActive(e, selectedIndex); // This is required as selected value may be the same\n\n\n      _this.setState({\n        selectedIndex: getSelectedIndex({\n          additionLabel: _this.props.additionLabel,\n          additionPosition: _this.props.additionPosition,\n          allowAdditions: _this.props.allowAdditions,\n          deburr: _this.props.deburr,\n          multiple: _this.props.multiple,\n          search: _this.props.search,\n          selectedIndex: selectedIndex,\n          value: nextValue,\n          options: _this.props.options,\n          searchQuery: ''\n        })\n      });\n\n      _this.closeOnChange(e);\n\n      _this.clearSearchQuery();\n\n      if (search) {\n        _invoke(_this.searchRef.current, 'focus');\n      }\n    };\n\n    _this.removeItemOnBackspace = function (e) {\n      var _this$props3 = _this.props,\n          multiple = _this$props3.multiple,\n          search = _this$props3.search;\n      var _this$state4 = _this.state,\n          searchQuery = _this$state4.searchQuery,\n          value = _this$state4.value;\n      if (keyboardKey.getCode(e) !== keyboardKey.Backspace) return;\n      if (searchQuery || !search || !multiple || _isEmpty(value)) return;\n      e.preventDefault(); // remove most recent value\n\n      var newValue = _dropRight(value);\n\n      _this.setState({\n        value: newValue\n      });\n\n      _this.handleChange(e, newValue);\n    };\n\n    _this.closeOnDocumentClick = function (e) {\n      if (!_this.props.closeOnBlur) return; // If event happened in the dropdown, ignore it\n\n      if (_this.ref.current && doesNodeContainClick(_this.ref.current, e)) return;\n\n      _this.close();\n    };\n\n    _this.handleMouseDown = function (e) {\n      _this.isMouseDown = true;\n\n      _invoke(_this.props, 'onMouseDown', e, _this.props);\n\n      document.addEventListener('mouseup', _this.handleDocumentMouseUp);\n    };\n\n    _this.handleDocumentMouseUp = function () {\n      _this.isMouseDown = false;\n      document.removeEventListener('mouseup', _this.handleDocumentMouseUp);\n    };\n\n    _this.handleClick = function (e) {\n      var _this$props4 = _this.props,\n          minCharacters = _this$props4.minCharacters,\n          search = _this$props4.search;\n      var _this$state5 = _this.state,\n          open = _this$state5.open,\n          searchQuery = _this$state5.searchQuery;\n\n      _invoke(_this.props, 'onClick', e, _this.props); // prevent closeOnDocumentClick()\n\n\n      e.stopPropagation();\n      if (!search) return _this.toggle(e);\n\n      if (open) {\n        _invoke(_this.searchRef.current, 'focus');\n\n        return;\n      }\n\n      if (searchQuery.length >= minCharacters || minCharacters === 1) {\n        _this.open(e);\n\n        return;\n      }\n\n      _invoke(_this.searchRef.current, 'focus');\n    };\n\n    _this.handleIconClick = function (e) {\n      var clearable = _this.props.clearable;\n\n      var hasValue = _this.hasValue();\n\n      _invoke(_this.props, 'onClick', e, _this.props); // prevent handleClick()\n\n\n      e.stopPropagation();\n\n      if (clearable && hasValue) {\n        _this.clearValue(e);\n      } else {\n        _this.toggle(e);\n      }\n    };\n\n    _this.handleItemClick = function (e, item) {\n      var _this$props5 = _this.props,\n          multiple = _this$props5.multiple,\n          search = _this$props5.search;\n      var currentValue = _this.state.value;\n      var value = item.value; // prevent toggle() in handleClick()\n\n      e.stopPropagation(); // prevent closeOnDocumentClick() if multiple or item is disabled\n\n      if (multiple || item.disabled) {\n        e.nativeEvent.stopImmediatePropagation();\n      }\n\n      if (item.disabled) {\n        return;\n      }\n\n      var isAdditionItem = item['data-additional'];\n      var newValue = multiple ? _union(_this.state.value, [value]) : value;\n      var valueHasChanged = multiple ? !!_difference(newValue, currentValue).length : newValue !== currentValue; // notify the onChange prop that the user is trying to change value\n\n      if (valueHasChanged) {\n        _this.setState({\n          value: newValue\n        });\n\n        _this.handleChange(e, newValue);\n      }\n\n      _this.clearSearchQuery();\n\n      if (search) {\n        _invoke(_this.searchRef.current, 'focus');\n      } else {\n        _invoke(_this.ref.current, 'focus');\n      }\n\n      _this.closeOnChange(e); // Heads up! This event handler should be called after `onChange`\n      // Notify the onAddItem prop if this is a new value\n\n\n      if (isAdditionItem) {\n        _invoke(_this.props, 'onAddItem', e, _extends({}, _this.props, {\n          value: value\n        }));\n      }\n    };\n\n    _this.handleFocus = function (e) {\n      var focus = _this.state.focus;\n      if (focus) return;\n\n      _invoke(_this.props, 'onFocus', e, _this.props);\n\n      _this.setState({\n        focus: true\n      });\n    };\n\n    _this.handleBlur = function (e) {\n      // Heads up! Don't remove this.\n      // https://github.com/Semantic-Org/Semantic-UI-React/issues/1315\n      var currentTarget = _get(e, 'currentTarget');\n\n      if (currentTarget && currentTarget.contains(document.activeElement)) return;\n      var _this$props6 = _this.props,\n          closeOnBlur = _this$props6.closeOnBlur,\n          multiple = _this$props6.multiple,\n          selectOnBlur = _this$props6.selectOnBlur; // do not \"blur\" when the mouse is down inside of the Dropdown\n\n      if (_this.isMouseDown) return;\n\n      _invoke(_this.props, 'onBlur', e, _this.props);\n\n      if (selectOnBlur && !multiple) {\n        _this.makeSelectedItemActive(e, _this.state.selectedIndex);\n\n        if (closeOnBlur) _this.close();\n      }\n\n      _this.setState({\n        focus: false\n      });\n\n      _this.clearSearchQuery();\n    };\n\n    _this.handleSearchChange = function (e, _ref) {\n      var value = _ref.value; // prevent propagating to this.props.onChange()\n\n      e.stopPropagation();\n      var minCharacters = _this.props.minCharacters;\n      var open = _this.state.open;\n      var newQuery = value;\n\n      _invoke(_this.props, 'onSearchChange', e, _extends({}, _this.props, {\n        searchQuery: newQuery\n      }));\n\n      _this.setState({\n        searchQuery: newQuery,\n        selectedIndex: 0\n      }); // open search dropdown on search query\n\n\n      if (!open && newQuery.length >= minCharacters) {\n        _this.open();\n\n        return;\n      } // close search dropdown if search query is too small\n\n\n      if (open && minCharacters !== 1 && newQuery.length < minCharacters) _this.close();\n    };\n\n    _this.handleKeyDown = function (e) {\n      _this.moveSelectionOnKeyDown(e);\n\n      _this.openOnArrow(e);\n\n      _this.openOnSpace(e);\n\n      _this.selectItemOnEnter(e);\n\n      _invoke(_this.props, 'onKeyDown', e);\n    };\n\n    _this.getSelectedItem = function (selectedIndex) {\n      var options = getMenuOptions({\n        value: _this.state.value,\n        options: _this.props.options,\n        searchQuery: _this.state.searchQuery,\n        additionLabel: _this.props.additionLabel,\n        additionPosition: _this.props.additionPosition,\n        allowAdditions: _this.props.allowAdditions,\n        deburr: _this.props.deburr,\n        multiple: _this.props.multiple,\n        search: _this.props.search\n      });\n      return _get(options, \"[\" + selectedIndex + \"]\");\n    };\n\n    _this.getItemByValue = function (value) {\n      var options = _this.props.options;\n      return _find(options, {\n        value: value\n      });\n    };\n\n    _this.getDropdownAriaOptions = function () {\n      var _this$props7 = _this.props,\n          loading = _this$props7.loading,\n          disabled = _this$props7.disabled,\n          search = _this$props7.search,\n          multiple = _this$props7.multiple;\n      var open = _this.state.open;\n      var ariaOptions = {\n        role: search ? 'combobox' : 'listbox',\n        'aria-busy': loading,\n        'aria-disabled': disabled,\n        'aria-expanded': !!open\n      };\n\n      if (ariaOptions.role === 'listbox') {\n        ariaOptions['aria-multiselectable'] = multiple;\n      }\n\n      return ariaOptions;\n    };\n\n    _this.clearSearchQuery = function () {\n      var searchQuery = _this.state.searchQuery;\n      if (searchQuery === undefined || searchQuery === '') return;\n\n      _this.setState({\n        searchQuery: ''\n      });\n    };\n\n    _this.handleLabelClick = function (e, labelProps) {\n      // prevent focusing search input on click\n      e.stopPropagation();\n\n      _this.setState({\n        selectedLabel: labelProps.value\n      });\n\n      _invoke(_this.props, 'onLabelClick', e, labelProps);\n    };\n\n    _this.handleLabelRemove = function (e, labelProps) {\n      // prevent focusing search input on click\n      e.stopPropagation();\n      var value = _this.state.value;\n\n      var newValue = _without(value, labelProps.value);\n\n      _this.setState({\n        value: newValue\n      });\n\n      _this.handleChange(e, newValue);\n    };\n\n    _this.getSelectedIndexAfterMove = function (offset, startIndex) {\n      if (startIndex === void 0) {\n        startIndex = _this.state.selectedIndex;\n      }\n\n      var options = getMenuOptions({\n        value: _this.state.value,\n        options: _this.props.options,\n        searchQuery: _this.state.searchQuery,\n        additionLabel: _this.props.additionLabel,\n        additionPosition: _this.props.additionPosition,\n        allowAdditions: _this.props.allowAdditions,\n        deburr: _this.props.deburr,\n        multiple: _this.props.multiple,\n        search: _this.props.search\n      }); // Prevent infinite loop\n      // TODO: remove left part of condition after children API will be removed\n\n      if (options === undefined || _every(options, 'disabled')) return;\n      var lastIndex = options.length - 1;\n      var wrapSelection = _this.props.wrapSelection; // next is after last, wrap to beginning\n      // next is before first, wrap to end\n\n      var nextIndex = startIndex + offset; // if 'wrapSelection' is set to false and selection is after last or before first, it just does not change\n\n      if (!wrapSelection && (nextIndex > lastIndex || nextIndex < 0)) {\n        nextIndex = startIndex;\n      } else if (nextIndex > lastIndex) {\n        nextIndex = 0;\n      } else if (nextIndex < 0) {\n        nextIndex = lastIndex;\n      }\n\n      if (options[nextIndex].disabled) {\n        return _this.getSelectedIndexAfterMove(offset, nextIndex);\n      }\n\n      return nextIndex;\n    };\n\n    _this.handleIconOverrides = function (predefinedProps) {\n      var clearable = _this.props.clearable;\n      var classes = cx(clearable && _this.hasValue() && 'clear', predefinedProps.className);\n      return {\n        className: classes,\n        onClick: function onClick(e) {\n          _invoke(predefinedProps, 'onClick', e, predefinedProps);\n\n          _this.handleIconClick(e);\n        }\n      };\n    };\n\n    _this.clearValue = function (e) {\n      var multiple = _this.props.multiple;\n      var newValue = multiple ? [] : '';\n\n      _this.setState({\n        value: newValue\n      });\n\n      _this.handleChange(e, newValue);\n    };\n\n    _this.computeSearchInputTabIndex = function () {\n      var _this$props8 = _this.props,\n          disabled = _this$props8.disabled,\n          tabIndex = _this$props8.tabIndex;\n      if (!_isNil(tabIndex)) return tabIndex;\n      return disabled ? -1 : 0;\n    };\n\n    _this.computeSearchInputWidth = function () {\n      var searchQuery = _this.state.searchQuery;\n\n      if (_this.sizerRef.current && searchQuery) {\n        // resize the search input, temporarily show the sizer so we can measure it\n        _this.sizerRef.current.style.display = 'inline';\n        _this.sizerRef.current.textContent = searchQuery;\n        var searchWidth = Math.ceil(_this.sizerRef.current.getBoundingClientRect().width);\n\n        _this.sizerRef.current.style.removeProperty('display');\n\n        return searchWidth;\n      }\n    };\n\n    _this.computeTabIndex = function () {\n      var _this$props9 = _this.props,\n          disabled = _this$props9.disabled,\n          search = _this$props9.search,\n          tabIndex = _this$props9.tabIndex; // don't set a root node tabIndex as the search input has its own tabIndex\n\n      if (search) return undefined;\n      if (disabled) return -1;\n      return _isNil(tabIndex) ? 0 : tabIndex;\n    };\n\n    _this.handleSearchInputOverrides = function (predefinedProps) {\n      return {\n        onChange: function onChange(e, inputProps) {\n          _invoke(predefinedProps, 'onChange', e, inputProps);\n\n          _this.handleSearchChange(e, inputProps);\n        }\n      };\n    };\n\n    _this.hasValue = function () {\n      var multiple = _this.props.multiple;\n      var value = _this.state.value;\n      return multiple ? !_isEmpty(value) : !_isNil(value) && value !== '';\n    };\n\n    _this.scrollSelectedItemIntoView = function () {\n      if (!_this.ref.current) return;\n\n      var menu = _this.ref.current.querySelector('.menu.visible');\n\n      if (!menu) return;\n      var item = menu.querySelector('.item.selected');\n      if (!item) return;\n      var isOutOfUpperView = item.offsetTop < menu.scrollTop;\n      var isOutOfLowerView = item.offsetTop + item.clientHeight > menu.scrollTop + menu.clientHeight;\n\n      if (isOutOfUpperView) {\n        menu.scrollTop = item.offsetTop;\n      } else if (isOutOfLowerView) {\n        // eslint-disable-next-line no-mixed-operators\n        menu.scrollTop = item.offsetTop + item.clientHeight - menu.clientHeight;\n      }\n    };\n\n    _this.setOpenDirection = function () {\n      if (!_this.ref.current) return;\n\n      var menu = _this.ref.current.querySelector('.menu.visible');\n\n      if (!menu) return;\n\n      var dropdownRect = _this.ref.current.getBoundingClientRect();\n\n      var menuHeight = menu.clientHeight;\n      var spaceAtTheBottom = document.documentElement.clientHeight - dropdownRect.top - dropdownRect.height - menuHeight;\n      var spaceAtTheTop = dropdownRect.top - menuHeight;\n      var upward = spaceAtTheBottom < 0 && spaceAtTheTop > spaceAtTheBottom; // set state only if there's a relevant difference\n\n      if (!upward !== !_this.state.upward) {\n        _this.setState({\n          upward: upward\n        });\n      }\n    };\n\n    _this.open = function (e, triggerSetState) {\n      if (e === void 0) {\n        e = null;\n      }\n\n      if (triggerSetState === void 0) {\n        triggerSetState = true;\n      }\n\n      var _this$props10 = _this.props,\n          disabled = _this$props10.disabled,\n          search = _this$props10.search;\n      if (disabled) return;\n      if (search) _invoke(_this.searchRef.current, 'focus');\n\n      _invoke(_this.props, 'onOpen', e, _this.props);\n\n      if (triggerSetState) {\n        _this.setState({\n          open: true\n        });\n      }\n\n      _this.scrollSelectedItemIntoView();\n    };\n\n    _this.close = function (e, callback) {\n      if (callback === void 0) {\n        callback = _this.handleClose;\n      }\n\n      if (_this.state.open) {\n        _invoke(_this.props, 'onClose', e, _this.props);\n\n        _this.setState({\n          open: false\n        }, callback);\n      }\n    };\n\n    _this.handleClose = function () {\n      var hasSearchFocus = document.activeElement === _this.searchRef.current; // https://github.com/Semantic-Org/Semantic-UI-React/issues/627\n      // Blur the Dropdown on close so it is blurred after selecting an item.\n      // This is to prevent it from re-opening when switching tabs after selecting an item.\n\n      if (!hasSearchFocus && _this.ref.current) {\n        _this.ref.current.blur();\n      }\n\n      var hasDropdownFocus = document.activeElement === _this.ref.current;\n      var hasFocus = hasSearchFocus || hasDropdownFocus; // We need to keep the virtual model in sync with the browser focus change\n      // https://github.com/Semantic-Org/Semantic-UI-React/issues/692\n\n      _this.setState({\n        focus: hasFocus\n      });\n    };\n\n    _this.toggle = function (e) {\n      return _this.state.open ? _this.close(e) : _this.open(e);\n    };\n\n    _this.renderText = function () {\n      var _this$props11 = _this.props,\n          multiple = _this$props11.multiple,\n          placeholder = _this$props11.placeholder,\n          search = _this$props11.search,\n          text = _this$props11.text;\n      var _this$state6 = _this.state,\n          searchQuery = _this$state6.searchQuery,\n          selectedIndex = _this$state6.selectedIndex,\n          value = _this$state6.value,\n          open = _this$state6.open;\n\n      var hasValue = _this.hasValue();\n\n      var classes = cx(placeholder && !hasValue && 'default', 'text', search && searchQuery && 'filtered');\n      var _text = placeholder;\n      var selectedItem;\n\n      if (text) {\n        _text = text;\n      } else if (open && !multiple) {\n        selectedItem = _this.getSelectedItem(selectedIndex);\n      } else if (hasValue) {\n        selectedItem = _this.getItemByValue(value);\n      }\n\n      return DropdownText.create(selectedItem ? renderItemContent(selectedItem) : _text, {\n        defaultProps: {\n          className: classes\n        }\n      });\n    };\n\n    _this.renderSearchInput = function () {\n      var _this$props12 = _this.props,\n          search = _this$props12.search,\n          searchInput = _this$props12.searchInput;\n      var searchQuery = _this.state.searchQuery;\n      return search && /*#__PURE__*/React.createElement(Ref, {\n        innerRef: _this.searchRef\n      }, DropdownSearchInput.create(searchInput, {\n        defaultProps: {\n          style: {\n            width: _this.computeSearchInputWidth()\n          },\n          tabIndex: _this.computeSearchInputTabIndex(),\n          value: searchQuery\n        },\n        overrideProps: _this.handleSearchInputOverrides\n      }));\n    };\n\n    _this.renderSearchSizer = function () {\n      var _this$props13 = _this.props,\n          search = _this$props13.search,\n          multiple = _this$props13.multiple;\n      return search && multiple && /*#__PURE__*/React.createElement(\"span\", {\n        className: \"sizer\",\n        ref: _this.sizerRef\n      });\n    };\n\n    _this.renderLabels = function () {\n      var _this$props14 = _this.props,\n          multiple = _this$props14.multiple,\n          renderLabel = _this$props14.renderLabel;\n      var _this$state7 = _this.state,\n          selectedLabel = _this$state7.selectedLabel,\n          value = _this$state7.value;\n\n      if (!multiple || _isEmpty(value)) {\n        return;\n      }\n\n      var selectedItems = _map(value, _this.getItemByValue); // if no item could be found for a given state value the selected item will be undefined\n      // compact the selectedItems so we only have actual objects left\n\n\n      return _map(_compact(selectedItems), function (item, index) {\n        var defaultProps = {\n          active: item.value === selectedLabel,\n          as: 'a',\n          key: getKeyOrValue(item.key, item.value),\n          onClick: _this.handleLabelClick,\n          onRemove: _this.handleLabelRemove,\n          value: item.value\n        };\n        return Label.create(renderLabel(item, index, defaultProps), {\n          defaultProps: defaultProps\n        });\n      });\n    };\n\n    _this.renderOptions = function () {\n      var _this$props15 = _this.props,\n          lazyLoad = _this$props15.lazyLoad,\n          multiple = _this$props15.multiple,\n          search = _this$props15.search,\n          noResultsMessage = _this$props15.noResultsMessage;\n      var _this$state8 = _this.state,\n          open = _this$state8.open,\n          selectedIndex = _this$state8.selectedIndex,\n          value = _this$state8.value; // lazy load, only render options when open\n\n      if (lazyLoad && !open) return null;\n      var options = getMenuOptions({\n        value: _this.state.value,\n        options: _this.props.options,\n        searchQuery: _this.state.searchQuery,\n        additionLabel: _this.props.additionLabel,\n        additionPosition: _this.props.additionPosition,\n        allowAdditions: _this.props.allowAdditions,\n        deburr: _this.props.deburr,\n        multiple: _this.props.multiple,\n        search: _this.props.search\n      });\n\n      if (noResultsMessage !== null && search && _isEmpty(options)) {\n        return /*#__PURE__*/React.createElement(\"div\", {\n          className: \"message\"\n        }, noResultsMessage);\n      }\n\n      var isActive = multiple ? function (optValue) {\n        return _includes(value, optValue);\n      } : function (optValue) {\n        return optValue === value;\n      };\n      return _map(options, function (opt, i) {\n        return DropdownItem.create(_extends({\n          active: isActive(opt.value),\n          selected: selectedIndex === i\n        }, opt, {\n          key: getKeyOrValue(opt.key, opt.value),\n          // Needed for handling click events on disabled items\n          style: _extends({}, opt.style, {\n            pointerEvents: 'all'\n          })\n        }), {\n          generateKey: false,\n          overrideProps: function overrideProps(predefinedProps) {\n            return {\n              onClick: function onClick(e, item) {\n                predefinedProps.onClick == null ? void 0 : predefinedProps.onClick(e, item);\n\n                _this.handleItemClick(e, item);\n              }\n            };\n          }\n        });\n      });\n    };\n\n    _this.renderMenu = function () {\n      var _this$props16 = _this.props,\n          children = _this$props16.children,\n          direction = _this$props16.direction,\n          header = _this$props16.header;\n      var open = _this.state.open;\n\n      var ariaOptions = _this.getDropdownMenuAriaOptions(); // single menu child\n\n\n      if (!childrenUtils.isNil(children)) {\n        var menuChild = Children.only(children);\n        var className = cx(direction, useKeyOnly(open, 'visible'), menuChild.props.className);\n        return /*#__PURE__*/cloneElement(menuChild, _extends({\n          className: className\n        }, ariaOptions));\n      }\n\n      return /*#__PURE__*/React.createElement(DropdownMenu, _extends({}, ariaOptions, {\n        direction: direction,\n        open: open\n      }), DropdownHeader.create(header, {\n        autoGenerateKey: false\n      }), _this.renderOptions());\n    };\n\n    return _this;\n  }\n\n  var _proto = Dropdown.prototype;\n\n  _proto.getInitialAutoControlledState = function getInitialAutoControlledState() {\n    return {\n      focus: false,\n      searchQuery: ''\n    };\n  };\n\n  Dropdown.getAutoControlledStateFromProps = function getAutoControlledStateFromProps(nextProps, computedState, prevState) {\n    // These values are stored only for a comparison on next getAutoControlledStateFromProps()\n    var derivedState = {\n      __options: nextProps.options,\n      __value: computedState.value\n    }; // The selected index is only dependent:\n\n    var shouldComputeSelectedIndex = // On value change\n    !shallowEqual(prevState.__value, computedState.value) || // On option keys/values, we only check those properties to avoid recursive performance impacts.\n    // https://github.com/Semantic-Org/Semantic-UI-React/issues/3000\n    !_isEqual(getKeyAndValues(nextProps.options), getKeyAndValues(prevState.__options));\n\n    if (shouldComputeSelectedIndex) {\n      derivedState.selectedIndex = getSelectedIndex({\n        additionLabel: nextProps.additionLabel,\n        additionPosition: nextProps.additionPosition,\n        allowAdditions: nextProps.allowAdditions,\n        deburr: nextProps.deburr,\n        multiple: nextProps.multiple,\n        search: nextProps.search,\n        selectedIndex: computedState.selectedIndex,\n        value: computedState.value,\n        options: nextProps.options,\n        searchQuery: computedState.searchQuery\n      });\n    }\n\n    return derivedState;\n  };\n\n  _proto.componentDidMount = function componentDidMount() {\n    var open = this.state.open;\n\n    if (open) {\n      this.open(null, false);\n    }\n  };\n\n  _proto.shouldComponentUpdate = function shouldComponentUpdate(nextProps, nextState) {\n    return !shallowEqual(nextProps, this.props) || !shallowEqual(nextState, this.state);\n  };\n\n  _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n    // eslint-disable-line complexity\n    var _this$props17 = this.props,\n        closeOnBlur = _this$props17.closeOnBlur,\n        minCharacters = _this$props17.minCharacters,\n        openOnFocus = _this$props17.openOnFocus,\n        search = _this$props17.search;\n    /* eslint-disable no-console */\n\n    if (process.env.NODE_ENV !== 'production') {\n      // in development, validate value type matches dropdown type\n      var isNextValueArray = Array.isArray(this.props.value);\n\n      var hasValue = _has(this.props, 'value');\n\n      if (hasValue && this.props.multiple && !isNextValueArray) {\n        console.error('Dropdown `value` must be an array when `multiple` is set.' + (\" Received type: `\" + Object.prototype.toString.call(this.props.value) + \"`.\"));\n      } else if (hasValue && !this.props.multiple && isNextValueArray) {\n        console.error('Dropdown `value` must not be an array when `multiple` is not set.' + ' Either set `multiple={true}` or use a string or number value.');\n      }\n    }\n    /* eslint-enable no-console */\n    // focused / blurred\n\n\n    if (!prevState.focus && this.state.focus) {\n      if (!this.isMouseDown) {\n        var openable = !search || search && minCharacters === 1 && !this.state.open;\n        if (openOnFocus && openable) this.open();\n      }\n    } else if (prevState.focus && !this.state.focus) {\n      if (!this.isMouseDown && closeOnBlur) {\n        this.close();\n      }\n    } // opened / closed\n\n\n    if (!prevState.open && this.state.open) {\n      this.setOpenDirection();\n      this.scrollSelectedItemIntoView();\n    } else if (prevState.open && !this.state.open) {}\n\n    if (prevState.selectedIndex !== this.state.selectedIndex) {\n      this.scrollSelectedItemIntoView();\n    }\n  } // ----------------------------------------\n  // Document Event Handlers\n  // ----------------------------------------\n  // onChange needs to receive a value\n  // can't rely on props.value if we are controlled\n  ;\n\n  _proto.getDropdownMenuAriaOptions = function getDropdownMenuAriaOptions() {\n    var _this$props18 = this.props,\n        search = _this$props18.search,\n        multiple = _this$props18.multiple;\n    var ariaOptions = {};\n\n    if (search) {\n      ariaOptions['aria-multiselectable'] = multiple;\n      ariaOptions.role = 'listbox';\n    }\n\n    return ariaOptions;\n  } // ----------------------------------------\n  // Setters\n  // ----------------------------------------\n  ;\n\n  _proto.render = function render() {\n    var _this$props19 = this.props,\n        basic = _this$props19.basic,\n        button = _this$props19.button,\n        className = _this$props19.className,\n        compact = _this$props19.compact,\n        disabled = _this$props19.disabled,\n        error = _this$props19.error,\n        fluid = _this$props19.fluid,\n        floating = _this$props19.floating,\n        icon = _this$props19.icon,\n        inline = _this$props19.inline,\n        item = _this$props19.item,\n        labeled = _this$props19.labeled,\n        loading = _this$props19.loading,\n        multiple = _this$props19.multiple,\n        pointing = _this$props19.pointing,\n        search = _this$props19.search,\n        selection = _this$props19.selection,\n        scrolling = _this$props19.scrolling,\n        simple = _this$props19.simple,\n        trigger = _this$props19.trigger;\n    var _this$state9 = this.state,\n        focus = _this$state9.focus,\n        open = _this$state9.open,\n        upward = _this$state9.upward; // Classes\n\n    var classes = cx('ui', useKeyOnly(open, 'active visible'), useKeyOnly(disabled, 'disabled'), useKeyOnly(error, 'error'), useKeyOnly(loading, 'loading'), useKeyOnly(basic, 'basic'), useKeyOnly(button, 'button'), useKeyOnly(compact, 'compact'), useKeyOnly(fluid, 'fluid'), useKeyOnly(floating, 'floating'), useKeyOnly(inline, 'inline'), // TODO: consider augmentation to render Dropdowns as Button/Menu, solves icon/link item issues\n    // https://github.com/Semantic-Org/Semantic-UI-React/issues/401#issuecomment-240487229\n    // TODO: the icon class is only required when a dropdown is a button\n    // useKeyOnly(icon, 'icon'),\n    useKeyOnly(labeled, 'labeled'), useKeyOnly(item, 'item'), useKeyOnly(multiple, 'multiple'), useKeyOnly(search, 'search'), useKeyOnly(selection, 'selection'), useKeyOnly(simple, 'simple'), useKeyOnly(scrolling, 'scrolling'), useKeyOnly(upward, 'upward'), useKeyOrValueAndKey(pointing, 'pointing'), 'dropdown', className);\n    var rest = getUnhandledProps(Dropdown, this.props);\n    var ElementType = getElementType(Dropdown, this.props);\n    var ariaOptions = this.getDropdownAriaOptions(ElementType, this.props);\n    return /*#__PURE__*/React.createElement(Ref, {\n      innerRef: this.ref\n    }, /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, ariaOptions, {\n      className: classes,\n      onBlur: this.handleBlur,\n      onClick: this.handleClick,\n      onKeyDown: this.handleKeyDown,\n      onMouseDown: this.handleMouseDown,\n      onFocus: this.handleFocus,\n      onChange: this.handleChange,\n      tabIndex: this.computeTabIndex()\n    }), this.renderLabels(), this.renderSearchInput(), this.renderSearchSizer(), trigger || this.renderText(), Icon.create(icon, {\n      overrideProps: this.handleIconOverrides,\n      autoGenerateKey: false\n    }), this.renderMenu(), open && /*#__PURE__*/React.createElement(EventStack, {\n      name: \"keydown\",\n      on: this.closeOnEscape\n    }), open && /*#__PURE__*/React.createElement(EventStack, {\n      name: \"click\",\n      on: this.closeOnDocumentClick\n    }), focus && /*#__PURE__*/React.createElement(EventStack, {\n      name: \"keydown\",\n      on: this.removeItemOnBackspace\n    })));\n  };\n\n  return Dropdown;\n}(Component);\n\nDropdown.handledProps = [\"additionLabel\", \"additionPosition\", \"allowAdditions\", \"as\", \"basic\", \"button\", \"children\", \"className\", \"clearable\", \"closeOnBlur\", \"closeOnChange\", \"closeOnEscape\", \"compact\", \"deburr\", \"defaultOpen\", \"defaultSearchQuery\", \"defaultSelectedLabel\", \"defaultUpward\", \"defaultValue\", \"direction\", \"disabled\", \"error\", \"floating\", \"fluid\", \"header\", \"icon\", \"inline\", \"item\", \"labeled\", \"lazyLoad\", \"loading\", \"minCharacters\", \"multiple\", \"noResultsMessage\", \"onAddItem\", \"onBlur\", \"onChange\", \"onClick\", \"onClose\", \"onFocus\", \"onLabelClick\", \"onMouseDown\", \"onOpen\", \"onSearchChange\", \"open\", \"openOnFocus\", \"options\", \"placeholder\", \"pointing\", \"renderLabel\", \"scrolling\", \"search\", \"searchInput\", \"searchQuery\", \"selectOnBlur\", \"selectOnNavigation\", \"selectedLabel\", \"selection\", \"simple\", \"tabIndex\", \"text\", \"trigger\", \"upward\", \"value\", \"wrapSelection\"];\nexport { Dropdown as default };\nDropdown.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Label prefixed to an option added by a user. */\n  additionLabel: PropTypes.oneOfType([PropTypes.element, PropTypes.string]),\n\n  /** Position of the `Add: ...` option in the dropdown list ('top' or 'bottom'). */\n  additionPosition: PropTypes.oneOf(['top', 'bottom']),\n\n  /**\n   * Allow user additions to the list of options (boolean).\n   * Requires the use of `selection`, `options` and `search`.\n   */\n  allowAdditions: customPropTypes.every([customPropTypes.demand(['options', 'selection', 'search']), PropTypes.bool]),\n\n  /** A Dropdown can reduce its complexity. */\n  basic: PropTypes.bool,\n\n  /** Format the Dropdown to appear as a button. */\n  button: PropTypes.bool,\n\n  /** Primary content. */\n  children: customPropTypes.every([customPropTypes.disallow(['options', 'selection']), customPropTypes.givenProps({\n    children: PropTypes.any.isRequired\n  }, PropTypes.element.isRequired)]),\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Using the clearable setting will let users remove their selection from a dropdown. */\n  clearable: PropTypes.bool,\n\n  /** Whether or not the menu should close when the dropdown is blurred. */\n  closeOnBlur: PropTypes.bool,\n\n  /** Whether or not the dropdown should close when the escape key is pressed. */\n  closeOnEscape: PropTypes.bool,\n\n  /**\n   * Whether or not the menu should close when a value is selected from the dropdown.\n   * By default, multiple selection dropdowns will remain open on change, while single\n   * selection dropdowns will close on change.\n   */\n  closeOnChange: PropTypes.bool,\n\n  /** A compact dropdown has no minimum width. */\n  compact: PropTypes.bool,\n\n  /** Whether or not the dropdown should strip diacritics in options and input search */\n  deburr: PropTypes.bool,\n\n  /** Initial value of open. */\n  defaultOpen: PropTypes.bool,\n\n  /** Initial value of searchQuery. */\n  defaultSearchQuery: PropTypes.string,\n\n  /** Currently selected label in multi-select. */\n  defaultSelectedLabel: customPropTypes.every([customPropTypes.demand(['multiple']), PropTypes.oneOfType([PropTypes.number, PropTypes.string])]),\n\n  /** Initial value of upward. */\n  defaultUpward: PropTypes.bool,\n\n  /** Initial value or value array if multiple. */\n  defaultValue: PropTypes.oneOfType([PropTypes.number, PropTypes.string, PropTypes.bool, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.bool]))]),\n\n  /** A dropdown menu can open to the left or to the right. */\n  direction: PropTypes.oneOf(['left', 'right']),\n\n  /** A disabled dropdown menu or item does not allow user interaction. */\n  disabled: PropTypes.bool,\n\n  /** An errored dropdown can alert a user to a problem. */\n  error: PropTypes.bool,\n\n  /** A dropdown menu can contain floated content. */\n  floating: PropTypes.bool,\n\n  /** A dropdown can take the full width of its parent */\n  fluid: PropTypes.bool,\n\n  /** A dropdown menu can contain a header. */\n  header: PropTypes.node,\n\n  /** Shorthand for Icon. */\n  icon: PropTypes.oneOfType([PropTypes.node, PropTypes.object]),\n\n  /** A dropdown can be formatted to appear inline in other content. */\n  inline: PropTypes.bool,\n\n  /** A dropdown can be formatted as a Menu item. */\n  item: PropTypes.bool,\n\n  /** A dropdown can be labeled. */\n  labeled: PropTypes.bool,\n\n  /** A dropdown can defer rendering its options until it is open. */\n  lazyLoad: PropTypes.bool,\n\n  /** A dropdown can show that it is currently loading data. */\n  loading: PropTypes.bool,\n\n  /** The minimum characters for a search to begin showing results. */\n  minCharacters: PropTypes.number,\n\n  /** A selection dropdown can allow multiple selections. */\n  multiple: PropTypes.bool,\n\n  /** Message to display when there are no results. */\n  noResultsMessage: PropTypes.node,\n\n  /**\n   * Called when a user adds a new item. Use this to update the options list.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props and the new item's value.\n   */\n  onAddItem: PropTypes.func,\n\n  /**\n   * Called on blur.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props.\n   */\n  onBlur: PropTypes.func,\n\n  /**\n   * Called when the user attempts to change the value.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props and proposed value.\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * Called on click.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props.\n   */\n  onClick: PropTypes.func,\n\n  /**\n   * Called when a close event happens.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props.\n   */\n  onClose: PropTypes.func,\n\n  /**\n   * Called on focus.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props.\n   */\n  onFocus: PropTypes.func,\n\n  /**\n   * Called when a multi-select label is clicked.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All label props.\n   */\n  onLabelClick: PropTypes.func,\n\n  /**\n   * Called on mousedown.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props.\n   */\n  onMouseDown: PropTypes.func,\n\n  /**\n   * Called when an open event happens.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props.\n   */\n  onOpen: PropTypes.func,\n\n  /**\n   * Called on search input change.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props, includes current value of searchQuery.\n   */\n  onSearchChange: PropTypes.func,\n\n  /** Controls whether or not the dropdown menu is displayed. */\n  open: PropTypes.bool,\n\n  /** Whether or not the menu should open when the dropdown is focused. */\n  openOnFocus: PropTypes.bool,\n\n  /** Array of Dropdown.Item props e.g. `{ text: '', value: '' }` */\n  options: customPropTypes.every([customPropTypes.disallow(['children']), PropTypes.arrayOf(PropTypes.shape(DropdownItem.propTypes))]),\n\n  /** Placeholder text. */\n  placeholder: PropTypes.string,\n\n  /** A dropdown can be formatted so that its menu is pointing. */\n  pointing: PropTypes.oneOfType([PropTypes.bool, PropTypes.oneOf(['left', 'right', 'top', 'top left', 'top right', 'bottom', 'bottom left', 'bottom right'])]),\n\n  /**\n   * Mapped over the active items and returns shorthand for the active item Labels.\n   * Only applies to `multiple` Dropdowns.\n   *\n   * @param {object} item - A currently active dropdown item.\n   * @param {number} index - The current index.\n   * @param {object} defaultLabelProps - The default props for an active item Label.\n   * @returns {*} Shorthand for a Label.\n   */\n  renderLabel: PropTypes.func,\n\n  /** A dropdown can have its menu scroll. */\n  scrolling: PropTypes.bool,\n\n  /**\n   * A selection dropdown can allow a user to search through a large list of choices.\n   * Pass a function here to replace the default search.\n   */\n  search: PropTypes.oneOfType([PropTypes.bool, PropTypes.func]),\n\n  /** A shorthand for a search input. */\n  searchInput: PropTypes.oneOfType([PropTypes.array, PropTypes.node, PropTypes.object]),\n\n  /** Current value of searchQuery. Creates a controlled component. */\n  searchQuery: PropTypes.string,\n  // TODO 'searchInMenu' or 'search='in menu' or ???  How to handle this markup and functionality?\n\n  /** Define whether the highlighted item should be selected on blur. */\n  selectOnBlur: PropTypes.bool,\n\n  /**\n   * Whether or not to change the value when navigating the menu using arrow keys.\n   * Setting to false will require enter or left click to confirm a choice.\n   */\n  selectOnNavigation: PropTypes.bool,\n\n  /** Currently selected label in multi-select. */\n  selectedLabel: customPropTypes.every([customPropTypes.demand(['multiple']), PropTypes.oneOfType([PropTypes.string, PropTypes.number])]),\n\n  /** A dropdown can be used to select between choices in a form. */\n  selection: customPropTypes.every([customPropTypes.disallow(['children']), customPropTypes.demand(['options']), PropTypes.bool]),\n\n  /** A simple dropdown can open without Javascript. */\n  simple: PropTypes.bool,\n\n  /** A dropdown can receive focus. */\n  tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n  /** The text displayed in the dropdown, usually for the active item. */\n  text: PropTypes.string,\n\n  /** Custom element to trigger the menu to become visible. Takes place of 'text'. */\n  trigger: customPropTypes.every([customPropTypes.disallow(['selection', 'text']), PropTypes.node]),\n\n  /** Current value or value array if multiple. Creates a controlled component. */\n  value: PropTypes.oneOfType([PropTypes.bool, PropTypes.string, PropTypes.number, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.bool, PropTypes.string, PropTypes.number]))]),\n\n  /** Controls whether the dropdown will open upward. */\n  upward: PropTypes.bool,\n\n  /**\n   * A dropdown will go to the last element when ArrowUp is pressed on the first,\n   * or go to the first when ArrowDown is pressed on the last( aka infinite selection )\n   */\n  wrapSelection: PropTypes.bool\n} : {};\nDropdown.defaultProps = {\n  additionLabel: 'Add ',\n  additionPosition: 'top',\n  closeOnBlur: true,\n  closeOnEscape: true,\n  deburr: false,\n  icon: 'dropdown',\n  minCharacters: 1,\n  noResultsMessage: 'No results found.',\n  openOnFocus: true,\n  renderLabel: renderItemContent,\n  searchInput: 'text',\n  selectOnBlur: true,\n  selectOnNavigation: true,\n  wrapSelection: true\n};\nDropdown.autoControlledProps = ['open', 'searchQuery', 'selectedLabel', 'value', 'upward'];\nDropdown.Divider = DropdownDivider;\nDropdown.Header = DropdownHeader;\nDropdown.Item = DropdownItem;\nDropdown.Menu = DropdownMenu;\nDropdown.SearchInput = DropdownSearchInput;\nDropdown.Text = DropdownText;","import baseSet from './_baseSet.js';\n/**\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\n * it's created. Arrays are created for missing index properties while objects\n * are created for all other missing properties. Use `_.setWith` to customize\n * `path` creation.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.set(object, 'a[0].b.c', 4);\n * console.log(object.a[0].b.c);\n * // => 4\n *\n * _.set(object, ['x', '0', 'y', 'z'], 5);\n * console.log(object.x[0].y.z);\n * // => 5\n */\n\nfunction set(object, path, value) {\n  return object == null ? object : baseSet(object, path, value);\n}\n\nexport default set;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _set from \"lodash-es/set\";\nimport _invoke from \"lodash-es/invoke\";\nimport _get from \"lodash-es/get\";\nimport _isNil from \"lodash-es/isNil\";\nimport { Ref } from '@fluentui/react-component-ref';\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React, { createRef } from 'react';\nimport { ModernAutoControlledComponent as Component, createHTMLLabel, customPropTypes, getElementType, getUnhandledProps, htmlInputAttrs, partitionHTMLProps, useKeyOnly } from '../../lib';\n/**\n * A checkbox allows a user to select a value from a small set of options, often binary.\n * @see Form\n * @see Radio\n */\n\nvar Checkbox = /*#__PURE__*/function (_Component) {\n  _inheritsLoose(Checkbox, _Component);\n\n  function Checkbox() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _Component.call.apply(_Component, [this].concat(args)) || this;\n    _this.inputRef = /*#__PURE__*/createRef();\n    _this.labelRef = /*#__PURE__*/createRef();\n\n    _this.canToggle = function () {\n      var _this$props = _this.props,\n          disabled = _this$props.disabled,\n          radio = _this$props.radio,\n          readOnly = _this$props.readOnly;\n      var checked = _this.state.checked;\n      return !disabled && !readOnly && !(radio && checked);\n    };\n\n    _this.computeTabIndex = function () {\n      var _this$props2 = _this.props,\n          disabled = _this$props2.disabled,\n          tabIndex = _this$props2.tabIndex;\n      if (!_isNil(tabIndex)) return tabIndex;\n      return disabled ? -1 : 0;\n    };\n\n    _this.handleClick = function (e) {\n      var id = _this.props.id;\n      var _this$state = _this.state,\n          checked = _this$state.checked,\n          indeterminate = _this$state.indeterminate;\n\n      var isInputClick = _invoke(_this.inputRef.current, 'contains', e.target);\n\n      var isLabelClick = _invoke(_this.labelRef.current, 'contains', e.target);\n\n      var isRootClick = !isLabelClick && !isInputClick;\n      var hasId = !_isNil(id);\n      var isLabelClickAndForwardedToInput = isLabelClick && hasId; // https://github.com/Semantic-Org/Semantic-UI-React/pull/3351\n\n      if (!isLabelClickAndForwardedToInput) {\n        _invoke(_this.props, 'onClick', e, _extends({}, _this.props, {\n          checked: !checked,\n          indeterminate: !!indeterminate\n        }));\n      }\n\n      if (_this.isClickFromMouse) {\n        _this.isClickFromMouse = false;\n\n        if (isLabelClick && !hasId) {\n          _this.handleChange(e);\n        } // Changes should be triggered for the slider variation\n\n\n        if (isRootClick) {\n          _this.handleChange(e);\n        }\n\n        if (isLabelClick && hasId) {\n          // To prevent two clicks from being fired from the component we have to stop the propagation\n          // from the \"input\" click: https://github.com/Semantic-Org/Semantic-UI-React/issues/3433\n          e.stopPropagation();\n        }\n      }\n    };\n\n    _this.handleChange = function (e) {\n      var checked = _this.state.checked;\n      if (!_this.canToggle()) return;\n\n      _invoke(_this.props, 'onChange', e, _extends({}, _this.props, {\n        checked: !checked,\n        indeterminate: false\n      }));\n\n      _this.setState({\n        checked: !checked,\n        indeterminate: false\n      });\n    };\n\n    _this.handleMouseDown = function (e) {\n      var _this$state2 = _this.state,\n          checked = _this$state2.checked,\n          indeterminate = _this$state2.indeterminate;\n\n      _invoke(_this.props, 'onMouseDown', e, _extends({}, _this.props, {\n        checked: !!checked,\n        indeterminate: !!indeterminate\n      }));\n\n      if (!e.defaultPrevented) {\n        _invoke(_this.inputRef.current, 'focus');\n      } // Heads up!\n      // We need to call \"preventDefault\" to keep element focused.\n\n\n      e.preventDefault();\n    };\n\n    _this.handleMouseUp = function (e) {\n      var _this$state3 = _this.state,\n          checked = _this$state3.checked,\n          indeterminate = _this$state3.indeterminate;\n      _this.isClickFromMouse = true;\n\n      _invoke(_this.props, 'onMouseUp', e, _extends({}, _this.props, {\n        checked: !!checked,\n        indeterminate: !!indeterminate\n      }));\n    };\n\n    _this.setIndeterminate = function () {\n      var indeterminate = _this.state.indeterminate;\n\n      _set(_this.inputRef, 'current.indeterminate', !!indeterminate);\n    };\n\n    return _this;\n  }\n\n  var _proto = Checkbox.prototype;\n\n  _proto.componentDidMount = function componentDidMount() {\n    this.setIndeterminate();\n  };\n\n  _proto.componentDidUpdate = function componentDidUpdate() {\n    this.setIndeterminate();\n  };\n\n  _proto.render = function render() {\n    var _this$props3 = this.props,\n        className = _this$props3.className,\n        disabled = _this$props3.disabled,\n        label = _this$props3.label,\n        id = _this$props3.id,\n        name = _this$props3.name,\n        radio = _this$props3.radio,\n        readOnly = _this$props3.readOnly,\n        slider = _this$props3.slider,\n        toggle = _this$props3.toggle,\n        type = _this$props3.type,\n        value = _this$props3.value;\n    var _this$state4 = this.state,\n        checked = _this$state4.checked,\n        indeterminate = _this$state4.indeterminate;\n    var classes = cx('ui', useKeyOnly(checked, 'checked'), useKeyOnly(disabled, 'disabled'), useKeyOnly(indeterminate, 'indeterminate'), // auto apply fitted class to compact white space when there is no label\n    // https://semantic-ui.com/modules/checkbox.html#fitted\n    useKeyOnly(_isNil(label), 'fitted'), useKeyOnly(radio, 'radio'), useKeyOnly(readOnly, 'read-only'), useKeyOnly(slider, 'slider'), useKeyOnly(toggle, 'toggle'), 'checkbox', className);\n    var unhandled = getUnhandledProps(Checkbox, this.props);\n    var ElementType = getElementType(Checkbox, this.props);\n\n    var _partitionHTMLProps = partitionHTMLProps(unhandled, {\n      htmlProps: htmlInputAttrs\n    }),\n        htmlInputProps = _partitionHTMLProps[0],\n        rest = _partitionHTMLProps[1]; // Heads Up!\n    // Do not remove empty labels, they are required by SUI CSS\n\n\n    var labelElement = createHTMLLabel(label, {\n      defaultProps: {\n        htmlFor: id\n      },\n      autoGenerateKey: false\n    }) || /*#__PURE__*/React.createElement(\"label\", {\n      htmlFor: id\n    });\n    return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n      className: classes,\n      onClick: this.handleClick,\n      onChange: this.handleChange,\n      onMouseDown: this.handleMouseDown,\n      onMouseUp: this.handleMouseUp\n    }), /*#__PURE__*/React.createElement(Ref, {\n      innerRef: this.inputRef\n    }, /*#__PURE__*/React.createElement(\"input\", _extends({}, htmlInputProps, {\n      checked: checked,\n      className: \"hidden\",\n      disabled: disabled,\n      id: id,\n      name: name,\n      readOnly: true,\n      tabIndex: this.computeTabIndex(),\n      type: type,\n      value: value\n    }))), /*#__PURE__*/React.createElement(Ref, {\n      innerRef: this.labelRef\n    }, labelElement));\n  };\n\n  return Checkbox;\n}(Component);\n\nCheckbox.handledProps = [\"as\", \"checked\", \"className\", \"defaultChecked\", \"defaultIndeterminate\", \"disabled\", \"fitted\", \"id\", \"indeterminate\", \"label\", \"name\", \"onChange\", \"onClick\", \"onMouseDown\", \"onMouseUp\", \"radio\", \"readOnly\", \"slider\", \"tabIndex\", \"toggle\", \"type\", \"value\"];\nexport { Checkbox as default };\nCheckbox.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Whether or not checkbox is checked. */\n  checked: PropTypes.bool,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** The initial value of checked. */\n  defaultChecked: PropTypes.bool,\n\n  /** Whether or not checkbox is indeterminate. */\n  defaultIndeterminate: PropTypes.bool,\n\n  /** A checkbox can appear disabled and be unable to change states */\n  disabled: PropTypes.bool,\n\n  /** Removes padding for a label. Auto applied when there is no label. */\n  fitted: PropTypes.bool,\n\n  /** A unique identifier. */\n  id: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n  /** Whether or not checkbox is indeterminate. */\n  indeterminate: PropTypes.bool,\n\n  /** The text of the associated label element. */\n  label: customPropTypes.itemShorthand,\n\n  /** The HTML input name. */\n  name: PropTypes.string,\n\n  /**\n   * Called when the user attempts to change the checked state.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props and proposed checked/indeterminate state.\n   */\n  onChange: PropTypes.func,\n\n  /**\n   * Called when the checkbox or label is clicked.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props and current checked/indeterminate state.\n   */\n  onClick: PropTypes.func,\n\n  /**\n   * Called when the user presses down on the mouse.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props and current checked/indeterminate state.\n   */\n  onMouseDown: PropTypes.func,\n\n  /**\n   * Called when the user releases the mouse.\n   *\n   * @param {SyntheticEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props and current checked/indeterminate state.\n   */\n  onMouseUp: PropTypes.func,\n\n  /** Format as a radio element. This means it is an exclusive option. */\n  radio: customPropTypes.every([PropTypes.bool, customPropTypes.disallow(['slider', 'toggle'])]),\n\n  /** A checkbox can be read-only and unable to change states. */\n  readOnly: PropTypes.bool,\n\n  /** Format to emphasize the current selection state. */\n  slider: customPropTypes.every([PropTypes.bool, customPropTypes.disallow(['radio', 'toggle'])]),\n\n  /** A checkbox can receive focus. */\n  tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n  /** Format to show an on or off choice. */\n  toggle: customPropTypes.every([PropTypes.bool, customPropTypes.disallow(['radio', 'slider'])]),\n\n  /** HTML input type, either checkbox or radio. */\n  type: PropTypes.oneOf(['checkbox', 'radio']),\n\n  /** The HTML input value. */\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number])\n} : {};\nCheckbox.defaultProps = {\n  type: 'checkbox'\n};\nCheckbox.autoControlledProps = ['checked', 'indeterminate'];","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport React from 'react';\nimport { getUnhandledProps } from '../../lib';\nimport Checkbox from '../../modules/Checkbox';\n/**\n * A Radio is sugar for <Checkbox radio />.\n * Useful for exclusive groups of sliders or toggles.\n * @see Checkbox\n * @see Form\n */\n\nfunction Radio(props) {\n  var slider = props.slider,\n      toggle = props.toggle,\n      type = props.type;\n  var rest = getUnhandledProps(Radio, props); // const ElementType = getElementType(Radio, props)\n  // radio, slider, toggle are exclusive\n  // use an undefined radio if slider or toggle are present\n\n  var radio = !(slider || toggle) || undefined;\n  return /*#__PURE__*/React.createElement(Checkbox, _extends({}, rest, {\n    type: type,\n    radio: radio,\n    slider: slider,\n    toggle: toggle\n  }));\n}\n\nRadio.handledProps = [\"slider\", \"toggle\", \"type\"];\nRadio.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** Format to emphasize the current selection state. */\n  slider: Checkbox.propTypes.slider,\n\n  /** Format to show an on or off choice. */\n  toggle: Checkbox.propTypes.toggle,\n\n  /** HTML input type, either checkbox or radio. */\n  type: Checkbox.propTypes.type\n} : {};\nRadio.defaultProps = {\n  type: 'radio'\n};\nexport default Radio;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _isNil from \"lodash-es/isNil\";\nimport _get from \"lodash-es/get\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React, { createElement } from 'react';\nimport { childrenUtils, createHTMLLabel, customPropTypes, getElementType, getUnhandledProps, SUI, useKeyOnly, useWidthProp } from '../../lib';\nimport Label from '../../elements/Label';\nimport Checkbox from '../../modules/Checkbox';\nimport Radio from '../../addons/Radio';\n/**\n * A field is a form element containing a label and an input.\n * @see Form\n * @see Button\n * @see Checkbox\n * @see Dropdown\n * @see Input\n * @see Radio\n * @see Select\n * @see Visibility\n */\n\nfunction FormField(props) {\n  var children = props.children,\n      className = props.className,\n      content = props.content,\n      control = props.control,\n      disabled = props.disabled,\n      error = props.error,\n      inline = props.inline,\n      label = props.label,\n      required = props.required,\n      type = props.type,\n      width = props.width,\n      id = props.id;\n  var classes = cx(useKeyOnly(disabled, 'disabled'), useKeyOnly(error, 'error'), useKeyOnly(inline, 'inline'), useKeyOnly(required, 'required'), useWidthProp(width, 'wide'), 'field', className);\n  var rest = getUnhandledProps(FormField, props);\n  var ElementType = getElementType(FormField, props);\n\n  var errorPointing = _get(error, 'pointing', 'above');\n\n  var errorLabel = Label.create(error, {\n    autoGenerateKey: false,\n    defaultProps: {\n      prompt: true,\n      pointing: errorPointing,\n      id: id ? id + \"-error-message\" : undefined,\n      role: 'alert',\n      'aria-atomic': true\n    }\n  });\n  var errorLabelBefore = (errorPointing === 'below' || errorPointing === 'right') && errorLabel;\n  var errorLabelAfter = (errorPointing === 'above' || errorPointing === 'left') && errorLabel; // ----------------------------------------\n  // No Control\n  // ----------------------------------------\n\n  if (_isNil(control)) {\n    if (_isNil(label)) {\n      return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n        className: classes,\n        id: id\n      }), childrenUtils.isNil(children) ? content : children);\n    }\n\n    return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n      className: classes,\n      id: id\n    }), errorLabelBefore, createHTMLLabel(label, {\n      autoGenerateKey: false\n    }), errorLabelAfter);\n  } // ----------------------------------------\n  // Checkbox/Radio Control\n  // ----------------------------------------\n\n\n  var ariaDescribedBy = id && error ? id + \"-error-message\" : null;\n  var ariaAttrs = {\n    'aria-describedby': ariaDescribedBy,\n    'aria-invalid': error ? true : undefined\n  };\n\n  var controlProps = _extends({}, rest, {\n    content: content,\n    children: children,\n    disabled: disabled,\n    required: required,\n    type: type,\n    id: id\n  }); // wrap HTML checkboxes/radios in the label\n\n\n  if (control === 'input' && (type === 'checkbox' || type === 'radio')) {\n    return /*#__PURE__*/React.createElement(ElementType, {\n      className: classes\n    }, /*#__PURE__*/React.createElement(\"label\", null, errorLabelBefore, /*#__PURE__*/createElement(control, _extends({}, ariaAttrs, controlProps)), \" \", label, errorLabelAfter));\n  } // pass label prop to controls that support it\n\n\n  if (control === Checkbox || control === Radio) {\n    return /*#__PURE__*/React.createElement(ElementType, {\n      className: classes\n    }, errorLabelBefore, /*#__PURE__*/createElement(control, _extends({}, ariaAttrs, controlProps, {\n      label: label\n    })), errorLabelAfter);\n  } // ----------------------------------------\n  // Other Control\n  // ----------------------------------------\n\n\n  return /*#__PURE__*/React.createElement(ElementType, {\n    className: classes\n  }, createHTMLLabel(label, {\n    defaultProps: {\n      htmlFor: id\n    },\n    autoGenerateKey: false\n  }), errorLabelBefore, /*#__PURE__*/createElement(control, _extends({}, ariaAttrs, controlProps)), errorLabelAfter);\n}\n\nFormField.handledProps = [\"as\", \"children\", \"className\", \"content\", \"control\", \"disabled\", \"error\", \"id\", \"inline\", \"label\", \"required\", \"type\", \"width\"];\nFormField.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Primary content. */\n  children: PropTypes.node,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Shorthand for primary content. */\n  content: customPropTypes.contentShorthand,\n\n  /**\n   * A form control component (i.e. Dropdown) or HTML tagName (i.e. 'input').\n   * Extra FormField props are passed to the control component.\n   * Mutually exclusive with children.\n   */\n  control: PropTypes.oneOfType([PropTypes.elementType, PropTypes.oneOf(['button', 'input', 'select', 'textarea'])]),\n\n  /** Individual fields may be disabled. */\n  disabled: PropTypes.bool,\n\n  /** Individual fields may display an error state along with a message. */\n  error: PropTypes.oneOfType([PropTypes.bool, customPropTypes.itemShorthand]),\n\n  /** The id of the control */\n  id: PropTypes.string,\n\n  /** A field can have its label next to instead of above it. */\n  inline: PropTypes.bool,\n  // Heads Up!\n  // Do not disallow children with `label` shorthand\n  // The `control` might accept a `label` prop and `children`\n\n  /** Mutually exclusive with children. */\n  label: PropTypes.oneOfType([PropTypes.node, PropTypes.object]),\n\n  /** A field can show that input is mandatory. */\n  required: PropTypes.bool,\n\n  /** Passed to the control component (i.e. <input type='password' />) */\n  type: customPropTypes.every([customPropTypes.demand(['control']) // don't strictly validate HTML types\n  // a control might be passed that uses a `type` prop with unknown values\n  // let the control validate if for us\n  ]),\n\n  /** A field can specify its width in grid columns */\n  width: PropTypes.oneOf(SUI.WIDTHS)\n} : {};\nexport default FormField;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\nimport Button from '../../elements/Button';\nimport FormField from './FormField';\n/**\n * Sugar for <Form.Field control={Button} />.\n * @see Button\n * @see Form\n */\n\nfunction FormButton(props) {\n  var control = props.control;\n  var rest = getUnhandledProps(FormButton, props);\n  var ElementType = getElementType(FormButton, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    control: control\n  }));\n}\n\nFormButton.handledProps = [\"as\", \"control\"];\nFormButton.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** A FormField control prop. */\n  control: FormField.propTypes.control\n} : {};\nFormButton.defaultProps = {\n  as: FormField,\n  control: Button\n};\nexport default FormButton;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\nimport Checkbox from '../../modules/Checkbox';\nimport FormField from './FormField';\n/**\n * Sugar for <Form.Field control={Checkbox} />.\n * @see Checkbox\n * @see Form\n */\n\nfunction FormCheckbox(props) {\n  var control = props.control;\n  var rest = getUnhandledProps(FormCheckbox, props);\n  var ElementType = getElementType(FormCheckbox, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    control: control\n  }));\n}\n\nFormCheckbox.handledProps = [\"as\", \"control\"];\nFormCheckbox.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** A FormField control prop. */\n  control: FormField.propTypes.control\n} : {};\nFormCheckbox.defaultProps = {\n  as: FormField,\n  control: Checkbox\n};\nexport default FormCheckbox;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\nimport Dropdown from '../../modules/Dropdown';\nimport FormField from './FormField';\n/**\n * Sugar for <Form.Field control={Dropdown} />.\n * @see Dropdown\n * @see Form\n */\n\nfunction FormDropdown(props) {\n  var control = props.control;\n  var rest = getUnhandledProps(FormDropdown, props);\n  var ElementType = getElementType(FormDropdown, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    control: control\n  }));\n}\n\nFormDropdown.handledProps = [\"as\", \"control\"];\nFormDropdown.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** A FormField control prop. */\n  control: FormField.propTypes.control\n} : {};\nFormDropdown.defaultProps = {\n  as: FormField,\n  control: Dropdown\n};\nexport default FormDropdown;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { customPropTypes, getElementType, getUnhandledProps, SUI, useKeyOnly, useWidthProp } from '../../lib';\n/**\n * A set of fields can appear grouped together.\n * @see Form\n */\n\nfunction FormGroup(props) {\n  var children = props.children,\n      className = props.className,\n      grouped = props.grouped,\n      inline = props.inline,\n      unstackable = props.unstackable,\n      widths = props.widths;\n  var classes = cx(useKeyOnly(grouped, 'grouped'), useKeyOnly(inline, 'inline'), useKeyOnly(unstackable, 'unstackable'), useWidthProp(widths, null, true), 'fields', className);\n  var rest = getUnhandledProps(FormGroup, props);\n  var ElementType = getElementType(FormGroup, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    className: classes\n  }), children);\n}\n\nFormGroup.handledProps = [\"as\", \"children\", \"className\", \"grouped\", \"inline\", \"unstackable\", \"widths\"];\nFormGroup.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** Primary content. */\n  children: PropTypes.node,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Fields can show related choices. */\n  grouped: customPropTypes.every([customPropTypes.disallow(['inline']), PropTypes.bool]),\n\n  /** Multiple fields may be inline in a row. */\n  inline: customPropTypes.every([customPropTypes.disallow(['grouped']), PropTypes.bool]),\n\n  /** A form group can prevent itself from stacking on mobile. */\n  unstackable: PropTypes.bool,\n\n  /** Fields Groups can specify their width in grid columns or automatically divide fields to be equal width. */\n  widths: PropTypes.oneOf([].concat(SUI.WIDTHS, ['equal']))\n} : {};\nexport default FormGroup;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _includes from \"lodash-es/includes\";\nimport _map from \"lodash-es/map\";\nimport _invoke from \"lodash-es/invoke\";\nimport _get from \"lodash-es/get\";\nimport _isNil from \"lodash-es/isNil\";\nimport { handleRef } from '@fluentui/react-component-ref';\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React, { Children, cloneElement, Component, createRef } from 'react';\nimport { childrenUtils, createHTMLInput, createShorthandFactory, customPropTypes, getElementType, getUnhandledProps, partitionHTMLProps, useKeyOnly, useValueAndKey } from '../../lib';\nimport Button from '../Button';\nimport Icon from '../Icon';\nimport Label from '../Label';\n/**\n * An Input is a field used to elicit a response from a user.\n * @see Button\n * @see Form\n * @see Icon\n * @see Label\n */\n\nvar Input = /*#__PURE__*/function (_Component) {\n  _inheritsLoose(Input, _Component);\n\n  function Input() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _Component.call.apply(_Component, [this].concat(args)) || this;\n    _this.inputRef = /*#__PURE__*/createRef();\n\n    _this.computeIcon = function () {\n      var _this$props = _this.props,\n          loading = _this$props.loading,\n          icon = _this$props.icon;\n      if (!_isNil(icon)) return icon;\n      if (loading) return 'spinner';\n    };\n\n    _this.computeTabIndex = function () {\n      var _this$props2 = _this.props,\n          disabled = _this$props2.disabled,\n          tabIndex = _this$props2.tabIndex;\n      if (!_isNil(tabIndex)) return tabIndex;\n      if (disabled) return -1;\n    };\n\n    _this.focus = function () {\n      return _this.inputRef.current.focus();\n    };\n\n    _this.select = function () {\n      return _this.inputRef.current.select();\n    };\n\n    _this.handleChange = function (e) {\n      var value = _get(e, 'target.value');\n\n      _invoke(_this.props, 'onChange', e, _extends({}, _this.props, {\n        value: value\n      }));\n    };\n\n    _this.handleChildOverrides = function (child, defaultProps) {\n      return _extends({}, defaultProps, child.props, {\n        ref: function ref(c) {\n          handleRef(child.ref, c);\n          _this.inputRef.current = c;\n        }\n      });\n    };\n\n    _this.partitionProps = function () {\n      var _this$props3 = _this.props,\n          disabled = _this$props3.disabled,\n          type = _this$props3.type;\n\n      var tabIndex = _this.computeTabIndex();\n\n      var unhandled = getUnhandledProps(Input, _this.props);\n\n      var _partitionHTMLProps = partitionHTMLProps(unhandled),\n          htmlInputProps = _partitionHTMLProps[0],\n          rest = _partitionHTMLProps[1];\n\n      return [_extends({}, htmlInputProps, {\n        disabled: disabled,\n        type: type,\n        tabIndex: tabIndex,\n        onChange: _this.handleChange,\n        ref: _this.inputRef\n      }), rest];\n    };\n\n    return _this;\n  }\n\n  var _proto = Input.prototype;\n\n  _proto.render = function render() {\n    var _this2 = this;\n\n    var _this$props4 = this.props,\n        action = _this$props4.action,\n        actionPosition = _this$props4.actionPosition,\n        children = _this$props4.children,\n        className = _this$props4.className,\n        disabled = _this$props4.disabled,\n        error = _this$props4.error,\n        fluid = _this$props4.fluid,\n        focus = _this$props4.focus,\n        icon = _this$props4.icon,\n        iconPosition = _this$props4.iconPosition,\n        input = _this$props4.input,\n        inverted = _this$props4.inverted,\n        label = _this$props4.label,\n        labelPosition = _this$props4.labelPosition,\n        loading = _this$props4.loading,\n        size = _this$props4.size,\n        transparent = _this$props4.transparent,\n        type = _this$props4.type;\n    var classes = cx('ui', size, useKeyOnly(disabled, 'disabled'), useKeyOnly(error, 'error'), useKeyOnly(fluid, 'fluid'), useKeyOnly(focus, 'focus'), useKeyOnly(inverted, 'inverted'), useKeyOnly(loading, 'loading'), useKeyOnly(transparent, 'transparent'), useValueAndKey(actionPosition, 'action') || useKeyOnly(action, 'action'), useValueAndKey(iconPosition, 'icon') || useKeyOnly(icon || loading, 'icon'), useValueAndKey(labelPosition, 'labeled') || useKeyOnly(label, 'labeled'), 'input', className);\n    var ElementType = getElementType(Input, this.props);\n\n    var _this$partitionProps = this.partitionProps(),\n        htmlInputProps = _this$partitionProps[0],\n        rest = _this$partitionProps[1]; // Render with children\n    // ----------------------------------------\n\n\n    if (!childrenUtils.isNil(children)) {\n      // add htmlInputProps to the `<input />` child\n      var childElements = _map(Children.toArray(children), function (child) {\n        if (child.type !== 'input') return child;\n        return /*#__PURE__*/cloneElement(child, _this2.handleChildOverrides(child, htmlInputProps));\n      });\n\n      return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n        className: classes\n      }), childElements);\n    } // Render Shorthand\n    // ----------------------------------------\n\n\n    var actionElement = Button.create(action, {\n      autoGenerateKey: false\n    });\n    var labelElement = Label.create(label, {\n      defaultProps: {\n        className: cx('label', // add 'left|right corner'\n        _includes(labelPosition, 'corner') && labelPosition)\n      },\n      autoGenerateKey: false\n    });\n    return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n      className: classes\n    }), actionPosition === 'left' && actionElement, labelPosition !== 'right' && labelElement, createHTMLInput(input || type, {\n      defaultProps: htmlInputProps,\n      autoGenerateKey: false\n    }), Icon.create(this.computeIcon(), {\n      autoGenerateKey: false\n    }), actionPosition !== 'left' && actionElement, labelPosition === 'right' && labelElement);\n  };\n\n  return Input;\n}(Component);\n\nInput.handledProps = [\"action\", \"actionPosition\", \"as\", \"children\", \"className\", \"disabled\", \"error\", \"fluid\", \"focus\", \"icon\", \"iconPosition\", \"input\", \"inverted\", \"label\", \"labelPosition\", \"loading\", \"onChange\", \"size\", \"tabIndex\", \"transparent\", \"type\"];\nInput.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** An Input can be formatted to alert the user to an action they may perform. */\n  action: PropTypes.oneOfType([PropTypes.bool, customPropTypes.itemShorthand]),\n\n  /** An action can appear along side an Input on the left or right. */\n  actionPosition: PropTypes.oneOf(['left']),\n\n  /** Primary content. */\n  children: PropTypes.node,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** An Input field can show that it is disabled. */\n  disabled: PropTypes.bool,\n\n  /** An Input field can show the data contains errors. */\n  error: PropTypes.bool,\n\n  /** Take on the size of its container. */\n  fluid: PropTypes.bool,\n\n  /** An Input field can show a user is currently interacting with it. */\n  focus: PropTypes.bool,\n\n  /** Optional Icon to display inside the Input. */\n  icon: PropTypes.oneOfType([PropTypes.bool, customPropTypes.itemShorthand]),\n\n  /** An Icon can appear inside an Input on the left or right. */\n  iconPosition: PropTypes.oneOf(['left']),\n\n  /** Shorthand for creating the HTML Input. */\n  input: customPropTypes.itemShorthand,\n\n  /** Format to appear on dark backgrounds. */\n  inverted: PropTypes.bool,\n\n  /** Optional Label to display along side the Input. */\n  label: customPropTypes.itemShorthand,\n\n  /** A Label can appear outside an Input on the left or right. */\n  labelPosition: PropTypes.oneOf(['left', 'right', 'left corner', 'right corner']),\n\n  /** An Icon Input field can show that it is currently loading data. */\n  loading: PropTypes.bool,\n\n  /**\n   * Called on change.\n   *\n   * @param {ChangeEvent} event - React's original SyntheticEvent.\n   * @param {object} data - All props and a proposed value.\n   */\n  onChange: PropTypes.func,\n\n  /** An Input can vary in size. */\n  size: PropTypes.oneOf(['mini', 'small', 'large', 'big', 'huge', 'massive']),\n\n  /** An Input can receive focus. */\n  tabIndex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n  /** Transparent Input has no background. */\n  transparent: PropTypes.bool,\n\n  /** The HTML input type. */\n  type: PropTypes.string\n} : {};\nInput.defaultProps = {\n  type: 'text'\n};\nInput.create = createShorthandFactory(Input, function (type) {\n  return {\n    type: type\n  };\n});\nexport default Input;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\nimport Input from '../../elements/Input';\nimport FormField from './FormField';\n/**\n * Sugar for <Form.Field control={Input} />.\n * @see Form\n * @see Input\n */\n\nfunction FormInput(props) {\n  var control = props.control;\n  var rest = getUnhandledProps(FormInput, props);\n  var ElementType = getElementType(FormInput, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    control: control\n  }));\n}\n\nFormInput.handledProps = [\"as\", \"control\"];\nFormInput.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** A FormField control prop. */\n  control: FormField.propTypes.control\n} : {};\nFormInput.defaultProps = {\n  as: FormField,\n  control: Input\n};\nexport default FormInput;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\nimport Radio from '../../addons/Radio';\nimport FormField from './FormField';\n/**\n * Sugar for <Form.Field control={Radio} />.\n * @see Form\n * @see Radio\n */\n\nfunction FormRadio(props) {\n  var control = props.control;\n  var rest = getUnhandledProps(FormRadio, props);\n  var ElementType = getElementType(FormRadio, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    control: control\n  }));\n}\n\nFormRadio.handledProps = [\"as\", \"control\"];\nFormRadio.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** A FormField control prop. */\n  control: FormField.propTypes.control\n} : {};\nFormRadio.defaultProps = {\n  as: FormField,\n  control: Radio\n};\nexport default FormRadio;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport Dropdown from '../../modules/Dropdown';\n/**\n * A Select is sugar for <Dropdown selection />.\n * @see Dropdown\n * @see Form\n */\n\nfunction Select(props) {\n  return /*#__PURE__*/React.createElement(Dropdown, _extends({}, props, {\n    selection: true\n  }));\n}\n\nSelect.handledProps = [\"options\"];\nSelect.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** Array of Dropdown.Item props e.g. `{ text: '', value: '' }` */\n  options: PropTypes.arrayOf(PropTypes.shape(Dropdown.Item.propTypes)).isRequired\n} : {};\nSelect.Divider = Dropdown.Divider;\nSelect.Header = Dropdown.Header;\nSelect.Item = Dropdown.Item;\nSelect.Menu = Dropdown.Menu;\nexport default Select;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\nimport Select from '../../addons/Select';\nimport Dropdown from '../../modules/Dropdown';\nimport FormField from './FormField';\n/**\n * Sugar for <Form.Field control={Select} />.\n * @see Form\n * @see Select\n */\n\nfunction FormSelect(props) {\n  var control = props.control,\n      options = props.options;\n  var rest = getUnhandledProps(FormSelect, props);\n  var ElementType = getElementType(FormSelect, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    control: control,\n    options: options\n  }));\n}\n\nFormSelect.handledProps = [\"as\", \"control\", \"options\"];\nFormSelect.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** A FormField control prop. */\n  control: FormField.propTypes.control,\n\n  /** Array of Dropdown.Item props e.g. `{ text: '', value: '' }` */\n  options: PropTypes.arrayOf(PropTypes.shape(Dropdown.Item.propTypes)).isRequired\n} : {};\nFormSelect.defaultProps = {\n  as: FormField,\n  control: Select\n};\nexport default FormSelect;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport { getElementType, getUnhandledProps } from '../../lib';\nimport TextArea from '../../addons/TextArea';\nimport FormField from './FormField';\n/**\n * Sugar for <Form.Field control={TextArea} />.\n * @see Form\n * @see TextArea\n */\n\nfunction FormTextArea(props) {\n  var control = props.control;\n  var rest = getUnhandledProps(FormTextArea, props);\n  var ElementType = getElementType(FormTextArea, props);\n  return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n    control: control\n  }));\n}\n\nFormTextArea.handledProps = [\"as\", \"control\"];\nFormTextArea.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** A FormField control prop. */\n  control: FormField.propTypes.control\n} : {};\nFormTextArea.defaultProps = {\n  as: FormField,\n  control: TextArea\n};\nexport default FormTextArea;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _without from \"lodash-es/without\";\nimport _invoke from \"lodash-es/invoke\";\nimport cx from 'clsx';\nimport PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport { getElementType, getUnhandledProps, SUI, useKeyOnly, useWidthProp } from '../../lib';\nimport FormButton from './FormButton';\nimport FormCheckbox from './FormCheckbox';\nimport FormDropdown from './FormDropdown';\nimport FormField from './FormField';\nimport FormGroup from './FormGroup';\nimport FormInput from './FormInput';\nimport FormRadio from './FormRadio';\nimport FormSelect from './FormSelect';\nimport FormTextArea from './FormTextArea';\n/**\n * A Form displays a set of related user input fields in a structured way.\n * @see Button\n * @see Checkbox\n * @see Dropdown\n * @see Input\n * @see Message\n * @see Radio\n * @see Select\n * @see Visibility\n */\n\nvar Form = /*#__PURE__*/function (_Component) {\n  _inheritsLoose(Form, _Component);\n\n  function Form() {\n    var _this;\n\n    for (var _len = arguments.length, _args = new Array(_len), _key = 0; _key < _len; _key++) {\n      _args[_key] = arguments[_key];\n    }\n\n    _this = _Component.call.apply(_Component, [this].concat(_args)) || this;\n\n    _this.handleSubmit = function (e) {\n      var action = _this.props.action; // Heads up! Third party libs can pass own data as first argument, we need to check that it has preventDefault()\n      // method.\n\n      if (typeof action !== 'string') _invoke(e, 'preventDefault');\n\n      for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n        args[_key2 - 1] = arguments[_key2];\n      }\n\n      _invoke.apply(void 0, [_this.props, 'onSubmit', e, _this.props].concat(args));\n    };\n\n    return _this;\n  }\n\n  var _proto = Form.prototype;\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        action = _this$props.action,\n        children = _this$props.children,\n        className = _this$props.className,\n        error = _this$props.error,\n        inverted = _this$props.inverted,\n        loading = _this$props.loading,\n        reply = _this$props.reply,\n        size = _this$props.size,\n        success = _this$props.success,\n        unstackable = _this$props.unstackable,\n        warning = _this$props.warning,\n        widths = _this$props.widths;\n    var classes = cx('ui', size, useKeyOnly(error, 'error'), useKeyOnly(inverted, 'inverted'), useKeyOnly(loading, 'loading'), useKeyOnly(reply, 'reply'), useKeyOnly(success, 'success'), useKeyOnly(unstackable, 'unstackable'), useKeyOnly(warning, 'warning'), useWidthProp(widths, null, true), 'form', className);\n    var rest = getUnhandledProps(Form, this.props);\n    var ElementType = getElementType(Form, this.props);\n    return /*#__PURE__*/React.createElement(ElementType, _extends({}, rest, {\n      action: action,\n      className: classes,\n      onSubmit: this.handleSubmit\n    }), children);\n  };\n\n  return Form;\n}(Component);\n\nForm.handledProps = [\"action\", \"as\", \"children\", \"className\", \"error\", \"inverted\", \"loading\", \"onSubmit\", \"reply\", \"size\", \"success\", \"unstackable\", \"warning\", \"widths\"];\nForm.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /** An element type to render as (string or function). */\n  as: PropTypes.elementType,\n\n  /** The HTML form action */\n  action: PropTypes.string,\n\n  /** Primary content. */\n  children: PropTypes.node,\n\n  /** Additional classes. */\n  className: PropTypes.string,\n\n  /** Automatically show any error Message children. */\n  error: PropTypes.bool,\n\n  /** A form can have its color inverted for contrast. */\n  inverted: PropTypes.bool,\n\n  /** Automatically show a loading indicator. */\n  loading: PropTypes.bool,\n\n  /** The HTML form submit handler. */\n  onSubmit: PropTypes.func,\n\n  /** A comment can contain a form to reply to a comment. This may have arbitrary content. */\n  reply: PropTypes.bool,\n\n  /** A form can vary in size. */\n  size: PropTypes.oneOf(_without(SUI.SIZES, 'medium')),\n\n  /** Automatically show any success Message children. */\n  success: PropTypes.bool,\n\n  /** A form can prevent itself from stacking on mobile. */\n  unstackable: PropTypes.bool,\n\n  /** Automatically show any warning Message children. */\n  warning: PropTypes.bool,\n\n  /** Forms can automatically divide fields to be equal width. */\n  widths: PropTypes.oneOf(['equal'])\n} : {};\nForm.defaultProps = {\n  as: 'form'\n};\nForm.Field = FormField;\nForm.Button = FormButton;\nForm.Checkbox = FormCheckbox;\nForm.Dropdown = FormDropdown;\nForm.Group = FormGroup;\nForm.Input = FormInput;\nForm.Radio = FormRadio;\nForm.Select = FormSelect;\nForm.TextArea = FormTextArea;\nexport default Form;"],"sourceRoot":""}