UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

496 lines (426 loc) 60.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _reactLifecyclesCompat = require("react-lifecycles-compat"); var _propTypes = _interopRequireDefault(require("prop-types")); var _fuzzy = _interopRequireDefault(require("fuzzy")); var _classnames = _interopRequireDefault(require("classnames")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _window = require("global/window"); var _accessor = _interopRequireDefault(require("./accessor")); var _dropdownList = _interopRequireWildcard(require("./dropdown-list")); var _icons = require("../icons"); var _keyevent = _interopRequireDefault(require("../../../constants/keyevent")); var _templateObject, _templateObject2, _templateObject3, _templateObject4; function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } var DEFAULT_CLASS = 'typeahead'; /** * Copied mostly from 'react-typeahead', an auto-completing text input * * Renders an text input that shows options nearby that you can use the * keyboard or mouse to select. */ var TypeaheadWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n background-color: ", ";\n box-shadow: ", ";\n\n :focus {\n outline: 0;\n }\n"])), function (props) { return props.light ? props.theme.dropdownListBgdLT : props.theme.dropdownListBgd; }, function (props) { return props.theme.dropdownListShadow; }); var InputBox = _styledComponents["default"].div.attrs({ className: 'typeahead__input_box' })(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 8px;\n"]))); var TypeaheadInput = _styledComponents["default"].input(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n ", " :hover {\n cursor: pointer;\n background-color: ", ";\n }\n"])), function (props) { return props.light ? props.theme.inputLT : props.theme.secondaryInput; }, function (props) { return props.light ? props.theme.selectBackgroundLT : props.theme.secondaryInputBgd; }); var InputIcon = _styledComponents["default"].div.attrs({ className: 'typeahead__input_icon' })(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n right: 15px;\n top: 14px;\n color: ", ";\n"])), function (props) { return props.theme.inputPlaceholderColor; }); function generateSearchFunction(props) { var searchOptions = props.searchOptions, filterOption = props.filterOption; if (typeof searchOptions === 'function') { if (filterOption !== null) { _window.console.warn('searchOptions prop is being used, filterOption prop will be ignored'); } return searchOptions; } else if (typeof filterOption === 'function') { // use custom filter option return function (value, options) { return options.filter(function (o) { return filterOption(value, o); }); }; } var mapper = typeof filterOption === 'string' ? _accessor["default"].generateAccessor(filterOption) : _accessor["default"].IDENTITY_FN; return function (value, options) { return _fuzzy["default"].filter(value, options, { extract: mapper }).map(function (res) { return options[res.index]; }); }; } function getOptionsForValue(value, props, state) { var options = props.options, showOptionsWhenEmpty = props.showOptionsWhenEmpty; if (!props.searchable) { // directly pass through options if can not be searched return options; } if (shouldSkipSearch(value, state, showOptionsWhenEmpty)) { return options; } var searchOptions = generateSearchFunction(props); return searchOptions(value, options); } function shouldSkipSearch(input, state, showOptionsWhenEmpty) { var emptyValue = !input || input.trim().length === 0; // this.state must be checked because it may not be defined yet if this function // is called from within getInitialState var isFocused = state && state.isFocused; return !(showOptionsWhenEmpty && isFocused) && emptyValue; } var Typeahead = /*#__PURE__*/function (_Component) { (0, _inherits2["default"])(Typeahead, _Component); var _super = _createSuper(Typeahead); function Typeahead(props) { var _this; (0, _classCallCheck2["default"])(this, Typeahead); _this = _super.call(this, props); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "root", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "entry", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "focus", function () { if (_this.entry.current) { _this.entry.current.focus(); } }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_hasCustomValue", function () { return _this.props.allowCustomValues > 0 && _this.state.entryValue.length >= _this.props.allowCustomValues && _this.state.searchResults.indexOf(_this.state.entryValue) < 0; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_getCustomValue", function () { return _this._hasCustomValue() ? _this.state.entryValue : null; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onOptionSelected", function (option, event) { if (_this.props.searchable) { // reset entry input _this.setState({ searchResults: getOptionsForValue('', _this.props, _this.state), selection: '', entryValue: '' }); } return _this.props.onOptionSelected(option, event); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onTextEntryUpdated", function () { if (_this.props.searchable) { var value = _this.entry.current.value; _this.setState({ searchResults: getOptionsForValue(value, _this.props, _this.state), selection: '', entryValue: value }); } }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onEnter", function (event) { var selection = _this.getSelection(); if (!selection) { return _this.props.onKeyDown(event); } return _this._onOptionSelected(selection, event); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onEscape", function () { _this.setState({ selectionIndex: null }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onTab", function (event) { var selection = _this.getSelection(); var option = selection ? selection : _this.state.searchResults.length > 0 ? _this.state.searchResults[0] : null; if (option === null && _this._hasCustomValue()) { option = _this._getCustomValue(); } if (option !== null) { return _this._onOptionSelected(option, event); } }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "eventMap", function (event) { var events = {}; events[_keyevent["default"].DOM_VK_UP] = _this.navUp; events[_keyevent["default"].DOM_VK_DOWN] = _this.navDown; events[_keyevent["default"].DOM_VK_RETURN] = events[_keyevent["default"].DOM_VK_ENTER] = _this._onEnter; events[_keyevent["default"].DOM_VK_ESCAPE] = _this._onEscape; events[_keyevent["default"].DOM_VK_TAB] = _this._onTab; return events; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_nav", function (delta) { if (!_this._hasHint()) { return; } var newIndex = _this.state.selectionIndex === null ? delta === 1 ? 0 : delta : _this.state.selectionIndex + delta; var length = _this.props.maxVisible ? _this.state.searchResults.slice(0, _this.props.maxVisible).length : _this.state.searchResults.length; if (_this._hasCustomValue()) { length += 1; } if (newIndex < 0) { newIndex += length; } else if (newIndex >= length) { newIndex -= length; } _this.setState({ selectionIndex: newIndex }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "navDown", function () { _this._nav(1); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "navUp", function () { _this._nav(-1); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onChange", function (event) { if (_this.props.onChange) { _this.props.onChange(event); } _this._onTextEntryUpdated(); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onKeyDown", function (event) { // If there are no visible elements, don't perform selector navigation. // Just pass this up to the upstream onKeydown handler. // Also skip if the user is pressing the shift key, since none of our handlers are looking for shift if (!_this._hasHint() || event.shiftKey) { return _this.props.onKeyDown(event); } var handler = _this.eventMap()[event.keyCode]; if (handler) { handler(event); } else { return _this.props.onKeyDown(event); } // Don't propagate the keystroke back to the DOM/browser event.preventDefault(); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onFocus", function (event) { _this.setState({ isFocused: true }); if (_this.props.onFocus) { return _this.props.onFocus(event); } }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onBlur", function (event) { _this.setState({ isFocused: false }); if (_this.props.onBlur) { return _this.props.onBlur(event); } }); _this.state = { /** @type {ReadonlyArray<string>} */ searchResults: [], // This should be called something else, 'entryValue' entryValue: _this.props.value || _this.props.initialValue, // A valid typeahead value selection: _this.props.value, // Index of the selection selectionIndex: null, // Keep track of the focus state of the input element, to determine // whether to show options when empty (if showOptionsWhenEmpty is true) isFocused: false }; return _this; } (0, _createClass2["default"])(Typeahead, [{ key: "componentDidMount", value: function componentDidMount() { // call focus on entry or div to trigger key events listener if (this.entry.current) { this.entry.current.focus(); } else { this.root.current.focus(); } } }, { key: "_renderIncrementalSearchResults", value: function _renderIncrementalSearchResults() { return /*#__PURE__*/_react["default"].createElement(this.props.customListComponent, { fixedOptions: this.props.fixedOptions, options: this.props.maxVisible ? this.state.searchResults.slice(0, this.props.maxVisible) : this.state.searchResults, areResultsTruncated: this.props.maxVisible && this.state.searchResults.length > this.props.maxVisible, resultsTruncatedMessage: this.props.resultsTruncatedMessage, onOptionSelected: this._onOptionSelected, allowCustomValues: this.props.allowCustomValues, customValue: this._getCustomValue(), customClasses: this.props.customClasses, customListItemComponent: this.props.customListItemComponent, customListHeaderComponent: this.props.customListHeaderComponent, selectionIndex: this.state.selectionIndex, defaultClassNames: this.props.defaultClassNames, displayOption: this.props.displayOption, selectedItems: this.props.selectedItems, light: this.props.light }); } }, { key: "getSelection", value: function getSelection() { var index = this.state.selectionIndex; if (this._hasCustomValue()) { if (index === 0) { return this.state.entryValue; } index--; } if (this._hasFixedOptions()) { return index < this.props.fixedOptions.length ? this.props.fixedOptions[index] : this.state.searchResults[index - this.props.fixedOptions.length]; } return this.state.searchResults[index]; } }, { key: "_renderHiddenInput", value: function _renderHiddenInput() { if (!this.props.name) { return null; } return /*#__PURE__*/_react["default"].createElement("input", { type: "hidden", name: this.props.name, value: this.state.selection }); } }, { key: "_hasHint", value: function _hasHint() { return this.state.searchResults.length > 0 || this._hasCustomValue(); } }, { key: "_hasFixedOptions", value: function _hasFixedOptions() { return Array.isArray(this.props.fixedOptions) && this.props.fixedOptions.length; } }, { key: "render", value: function render() { var inputClasses = {}; inputClasses[this.props.customClasses.input] = Boolean(this.props.customClasses.input); var inputClassList = (0, _classnames["default"])(inputClasses); var classes = (0, _defineProperty2["default"])({}, DEFAULT_CLASS, this.props.defaultClassNames); classes[this.props.className] = Boolean(this.props.className); var classList = (0, _classnames["default"])(classes); return /*#__PURE__*/_react["default"].createElement(TypeaheadWrapper, { className: classList, ref: this.root, tabIndex: "0", onKeyDown: this._onKeyDown, onKeyPress: this.props.onKeyPress, onKeyUp: this.props.onKeyUp, onFocus: this._onFocus, light: this.props.light }, this._renderHiddenInput(), this.props.searchable ? /*#__PURE__*/_react["default"].createElement(InputBox, null, /*#__PURE__*/_react["default"].createElement(TypeaheadInput, (0, _extends2["default"])({ ref: this.entry, type: "text", disabled: this.props.disabled }, this.props.inputProps, { placeholder: this.props.placeholder, className: inputClassList, value: this.state.entryValue, onChange: this._onChange, onBlur: this._onBlur, light: this.props.light })), /*#__PURE__*/_react["default"].createElement(InputIcon, null, /*#__PURE__*/_react["default"].createElement(this.props.inputIcon, { height: "18px" }))) : null, this._renderIncrementalSearchResults()); } }], [{ key: "getDerivedStateFromProps", value: function getDerivedStateFromProps(props, state) { // invoked after a component is instantiated as well as before it is re-rendered var searchResults = getOptionsForValue(state.entryValue, props, state); return { searchResults: searchResults }; } }]); return Typeahead; }(_react.Component); (0, _defineProperty2["default"])(Typeahead, "propTypes", { name: _propTypes["default"].string, customClasses: _propTypes["default"].object, maxVisible: _propTypes["default"].number, resultsTruncatedMessage: _propTypes["default"].string, options: _propTypes["default"].arrayOf(_propTypes["default"].any), fixedOptions: _propTypes["default"].arrayOf(_propTypes["default"].any), allowCustomValues: _propTypes["default"].number, initialValue: _propTypes["default"].string, value: _propTypes["default"].string, placeholder: _propTypes["default"].string, disabled: _propTypes["default"].bool, textarea: _propTypes["default"].bool, inputProps: _propTypes["default"].object, onOptionSelected: _propTypes["default"].func, onChange: _propTypes["default"].func, onKeyDown: _propTypes["default"].func, onKeyPress: _propTypes["default"].func, onKeyUp: _propTypes["default"].func, onFocus: _propTypes["default"].func, onBlur: _propTypes["default"].func, filterOption: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].func]), searchOptions: _propTypes["default"].func, displayOption: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].func]), inputDisplayOption: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].func]), formInputOption: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].func]), defaultClassNames: _propTypes["default"].bool, customListComponent: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]), customListItemComponent: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]), customListHeaderComponent: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]), showOptionsWhenEmpty: _propTypes["default"].bool, searchable: _propTypes["default"].bool }); (0, _defineProperty2["default"])(Typeahead, "defaultProps", { options: [], customClasses: {}, allowCustomValues: 0, initialValue: '', value: '', placeholder: '', disabled: false, textarea: false, inputProps: {}, onOptionSelected: function onOptionSelected(option) {}, onChange: function onChange(event) {}, onKeyDown: function onKeyDown(event) {}, onKeyPress: function onKeyPress(event) {}, onKeyUp: function onKeyUp(event) {}, onFocus: function onFocus(event) {}, onBlur: function onBlur(event) {}, filterOption: null, searchOptions: null, inputDisplayOption: null, defaultClassNames: true, customListComponent: _dropdownList["default"], customListItemComponent: _dropdownList.ListItem, inputIcon: _icons.Search, customListHeaderComponent: null, showOptionsWhenEmpty: true, searchable: true, resultsTruncatedMessage: null }); (0, _reactLifecyclesCompat.polyfill)(Typeahead); var _default = Typeahead; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/item-selector/typeahead.js"],"names":["DEFAULT_CLASS","TypeaheadWrapper","styled","div","props","light","theme","dropdownListBgdLT","dropdownListBgd","dropdownListShadow","InputBox","attrs","className","TypeaheadInput","input","inputLT","secondaryInput","selectBackgroundLT","secondaryInputBgd","InputIcon","inputPlaceholderColor","generateSearchFunction","searchOptions","filterOption","Console","warn","value","options","filter","o","mapper","Accessor","generateAccessor","IDENTITY_FN","fuzzy","extract","map","res","index","getOptionsForValue","state","showOptionsWhenEmpty","searchable","shouldSkipSearch","emptyValue","trim","length","isFocused","Typeahead","entry","current","focus","allowCustomValues","entryValue","searchResults","indexOf","_hasCustomValue","option","event","setState","selection","onOptionSelected","getSelection","onKeyDown","_onOptionSelected","selectionIndex","_getCustomValue","events","KeyEvent","DOM_VK_UP","navUp","DOM_VK_DOWN","navDown","DOM_VK_RETURN","DOM_VK_ENTER","_onEnter","DOM_VK_ESCAPE","_onEscape","DOM_VK_TAB","_onTab","delta","_hasHint","newIndex","maxVisible","slice","_nav","onChange","_onTextEntryUpdated","shiftKey","handler","eventMap","keyCode","preventDefault","onFocus","onBlur","initialValue","root","fixedOptions","resultsTruncatedMessage","customClasses","customListItemComponent","customListHeaderComponent","defaultClassNames","displayOption","selectedItems","_hasFixedOptions","name","Array","isArray","inputClasses","Boolean","inputClassList","classes","classList","_onKeyDown","onKeyPress","onKeyUp","_onFocus","_renderHiddenInput","disabled","inputProps","placeholder","_onChange","_onBlur","_renderIncrementalSearchResults","Component","PropTypes","string","object","number","arrayOf","any","bool","textarea","func","oneOfType","inputDisplayOption","formInputOption","customListComponent","element","DropdownList","ListItem","inputIcon","Search"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {Component, createRef} from 'react';\nimport {polyfill} from 'react-lifecycles-compat';\nimport PropTypes from 'prop-types';\nimport fuzzy from 'fuzzy';\nimport classNames from 'classnames';\nimport styled from 'styled-components';\nimport {console as Console} from 'global/window';\n\nimport Accessor from './accessor';\nimport DropdownList, {ListItem} from './dropdown-list';\nimport {Search} from 'components/common/icons';\nimport KeyEvent from 'constants/keyevent';\n\nconst DEFAULT_CLASS = 'typeahead';\n/**\n * Copied mostly from 'react-typeahead', an auto-completing text input\n *\n * Renders an text input that shows options nearby that you can use the\n * keyboard or mouse to select.\n */\n\nconst TypeaheadWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  background-color: ${props =>\n    props.light ? props.theme.dropdownListBgdLT : props.theme.dropdownListBgd};\n  box-shadow: ${props => props.theme.dropdownListShadow};\n\n  :focus {\n    outline: 0;\n  }\n`;\n\nconst InputBox = styled.div.attrs({\n  className: 'typeahead__input_box'\n})`\n  padding: 8px;\n`;\n\nconst TypeaheadInput = styled.input`\n  ${props => (props.light ? props.theme.inputLT : props.theme.secondaryInput)} :hover {\n    cursor: pointer;\n    background-color: ${props =>\n      props.light ? props.theme.selectBackgroundLT : props.theme.secondaryInputBgd};\n  }\n`;\n\nconst InputIcon = styled.div.attrs({\n  className: 'typeahead__input_icon'\n})`\n  position: absolute;\n  right: 15px;\n  top: 14px;\n  color: ${props => props.theme.inputPlaceholderColor};\n`;\n\nfunction generateSearchFunction(props) {\n  const {searchOptions, filterOption} = props;\n  if (typeof searchOptions === 'function') {\n    if (filterOption !== null) {\n      Console.warn('searchOptions prop is being used, filterOption prop will be ignored');\n    }\n    return searchOptions;\n  } else if (typeof filterOption === 'function') {\n    // use custom filter option\n    return (value, options) => options.filter(o => filterOption(value, o));\n  }\n\n  const mapper =\n    typeof filterOption === 'string'\n      ? Accessor.generateAccessor(filterOption)\n      : Accessor.IDENTITY_FN;\n\n  return (value, options) =>\n    fuzzy.filter(value, options, {extract: mapper}).map(res => options[res.index]);\n}\n\nfunction getOptionsForValue(value, props, state) {\n  const {options, showOptionsWhenEmpty} = props;\n\n  if (!props.searchable) {\n    // directly pass through options if can not be searched\n    return options;\n  }\n  if (shouldSkipSearch(value, state, showOptionsWhenEmpty)) {\n    return options;\n  }\n\n  const searchOptions = generateSearchFunction(props);\n  return searchOptions(value, options);\n}\n\nfunction shouldSkipSearch(input, state, showOptionsWhenEmpty) {\n  const emptyValue = !input || input.trim().length === 0;\n\n  // this.state must be checked because it may not be defined yet if this function\n  // is called from within getInitialState\n  const isFocused = state && state.isFocused;\n  return !(showOptionsWhenEmpty && isFocused) && emptyValue;\n}\n\nclass Typeahead extends Component {\n  static propTypes = {\n    name: PropTypes.string,\n    customClasses: PropTypes.object,\n    maxVisible: PropTypes.number,\n    resultsTruncatedMessage: PropTypes.string,\n    options: PropTypes.arrayOf(PropTypes.any),\n    fixedOptions: PropTypes.arrayOf(PropTypes.any),\n    allowCustomValues: PropTypes.number,\n    initialValue: PropTypes.string,\n    value: PropTypes.string,\n    placeholder: PropTypes.string,\n    disabled: PropTypes.bool,\n    textarea: PropTypes.bool,\n    inputProps: PropTypes.object,\n    onOptionSelected: PropTypes.func,\n    onChange: PropTypes.func,\n    onKeyDown: PropTypes.func,\n    onKeyPress: PropTypes.func,\n    onKeyUp: PropTypes.func,\n    onFocus: PropTypes.func,\n    onBlur: PropTypes.func,\n    filterOption: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    searchOptions: PropTypes.func,\n    displayOption: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    inputDisplayOption: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    formInputOption: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    defaultClassNames: PropTypes.bool,\n    customListComponent: PropTypes.oneOfType([PropTypes.element, PropTypes.func]),\n    customListItemComponent: PropTypes.oneOfType([PropTypes.element, PropTypes.func]),\n    customListHeaderComponent: PropTypes.oneOfType([PropTypes.element, PropTypes.func]),\n    showOptionsWhenEmpty: PropTypes.bool,\n    searchable: PropTypes.bool\n  };\n\n  static defaultProps = {\n    options: [],\n    customClasses: {},\n    allowCustomValues: 0,\n    initialValue: '',\n    value: '',\n    placeholder: '',\n    disabled: false,\n    textarea: false,\n    inputProps: {},\n    onOptionSelected(option) {},\n    onChange(event) {},\n    onKeyDown(event) {},\n    onKeyPress(event) {},\n    onKeyUp(event) {},\n    onFocus(event) {},\n    onBlur(event) {},\n    filterOption: null,\n    searchOptions: null,\n    inputDisplayOption: null,\n    defaultClassNames: true,\n    customListComponent: DropdownList,\n    customListItemComponent: ListItem,\n    inputIcon: Search,\n    customListHeaderComponent: null,\n    showOptionsWhenEmpty: true,\n    searchable: true,\n    resultsTruncatedMessage: null\n  };\n\n  static getDerivedStateFromProps(props, state) {\n    //  invoked after a component is instantiated as well as before it is re-rendered\n    const searchResults = getOptionsForValue(state.entryValue, props, state);\n\n    return {searchResults};\n  }\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      /** @type {ReadonlyArray<string>} */\n      searchResults: [],\n\n      // This should be called something else, 'entryValue'\n      entryValue: this.props.value || this.props.initialValue,\n\n      // A valid typeahead value\n      selection: this.props.value,\n\n      // Index of the selection\n      selectionIndex: null,\n\n      // Keep track of the focus state of the input element, to determine\n      // whether to show options when empty (if showOptionsWhenEmpty is true)\n      isFocused: false\n    };\n  }