UNPKG

@elastic/react-search-ui

Version:

A React library for building search experiences

266 lines (232 loc) 31.6 kB
import _slicedToArray from "@babel/runtime/helpers/slicedToArray"; import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties"; import _classCallCheck from "@babel/runtime/helpers/classCallCheck"; import _createClass from "@babel/runtime/helpers/createClass"; import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn"; import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf"; import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized"; import _inherits from "@babel/runtime/helpers/inherits"; import _defineProperty from "@babel/runtime/helpers/defineProperty"; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { keys.push.apply(keys, Object.getOwnPropertySymbols(object)); } if (enumerableOnly) keys = keys.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } import PropTypes from "prop-types"; import { Component } from "react"; import { SearchBox } from "@elastic/react-search-ui-views"; import { withSearch } from ".."; import { Result, Suggestion } from "../types"; export var SearchBoxContainer = /*#__PURE__*/ function (_Component) { _inherits(SearchBoxContainer, _Component); function SearchBoxContainer() { var _getPrototypeOf2; var _this; _classCallCheck(this, SearchBoxContainer); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _possibleConstructorReturn(this, (_getPrototypeOf2 = _getPrototypeOf(SearchBoxContainer)).call.apply(_getPrototypeOf2, [this].concat(args))); _defineProperty(_assertThisInitialized(_this), "state", { isFocused: false }); _defineProperty(_assertThisInitialized(_this), "handleFocus", function () { _this.setState({ isFocused: true }); }); _defineProperty(_assertThisInitialized(_this), "handleBlur", function () { _this.setState({ isFocused: false }); }); _defineProperty(_assertThisInitialized(_this), "completeSuggestion", function (searchTerm) { var _this$props = _this.props, shouldClearFilters = _this$props.shouldClearFilters, setSearchTerm = _this$props.setSearchTerm; setSearchTerm(searchTerm, { shouldClearFilters: shouldClearFilters }); }); _defineProperty(_assertThisInitialized(_this), "handleSubmit", function (e) { var _this$props2 = _this.props, shouldClearFilters = _this$props2.shouldClearFilters, searchTerm = _this$props2.searchTerm, setSearchTerm = _this$props2.setSearchTerm; e.preventDefault(); setSearchTerm(searchTerm, { shouldClearFilters: shouldClearFilters }); }); _defineProperty(_assertThisInitialized(_this), "handleChange", function (value) { var _this$props3 = _this.props, autocompleteMinimumCharacters = _this$props3.autocompleteMinimumCharacters, autocompleteResults = _this$props3.autocompleteResults, autocompleteSuggestions = _this$props3.autocompleteSuggestions, shouldClearFilters = _this$props3.shouldClearFilters, searchAsYouType = _this$props3.searchAsYouType, setSearchTerm = _this$props3.setSearchTerm, debounceLength = _this$props3.debounceLength; var options = _objectSpread({ autocompleteMinimumCharacters: autocompleteMinimumCharacters }, (autocompleteResults || autocompleteSuggestions || searchAsYouType) && { debounce: debounceLength || 200 }, { shouldClearFilters: shouldClearFilters, refresh: !!searchAsYouType, autocompleteResults: !!autocompleteResults, autocompleteSuggestions: !!autocompleteSuggestions }); setSearchTerm(value, options); }); _defineProperty(_assertThisInitialized(_this), "handleNotifyAutocompleteSelected", function (selection) { var _this$props4 = _this.props, autocompleteResults = _this$props4.autocompleteResults, trackAutocompleteClickThrough = _this$props4.trackAutocompleteClickThrough; // Because suggestions don't count as clickthroughs, only // results if (autocompleteResults && autocompleteResults.shouldTrackClickThrough !== false && !selection.suggestion) { var _autocompleteResults$ = autocompleteResults.clickThroughTags, clickThroughTags = _autocompleteResults$ === void 0 ? [] : _autocompleteResults$; var id = selection.id.raw; trackAutocompleteClickThrough(id, clickThroughTags); } }); _defineProperty(_assertThisInitialized(_this), "defaultOnSelectAutocomplete", function (selection) { var autocompleteResults = _this.props.autocompleteResults; _this.handleNotifyAutocompleteSelected(selection); if (!selection.suggestion) { var url = selection[autocompleteResults.urlField] ? selection[autocompleteResults.urlField].raw : ""; if (url) { var target = autocompleteResults.linkTarget || "_self"; window.open(url, target); } } else { _this.completeSuggestion(selection.suggestion); } }); return _this; } _createClass(SearchBoxContainer, [{ key: "render", value: function render() { var _this2 = this; var isFocused = this.state.isFocused; var _this$props5 = this.props, autocompleteMinimumCharacters = _this$props5.autocompleteMinimumCharacters, autocompleteResults = _this$props5.autocompleteResults, autocompleteSuggestions = _this$props5.autocompleteSuggestions, autocompletedResults = _this$props5.autocompletedResults, autocompletedSuggestions = _this$props5.autocompletedSuggestions, className = _this$props5.className, autocompleteView = _this$props5.autocompleteView, inputProps = _this$props5.inputProps, inputView = _this$props5.inputView, onSelectAutocomplete = _this$props5.onSelectAutocomplete, onSubmit = _this$props5.onSubmit, searchTerm = _this$props5.searchTerm, view = _this$props5.view, rest = _objectWithoutProperties(_this$props5, ["autocompleteMinimumCharacters", "autocompleteResults", "autocompleteSuggestions", "autocompletedResults", "autocompletedSuggestions", "className", "autocompleteView", "inputProps", "inputView", "onSelectAutocomplete", "onSubmit", "searchTerm", "view"]); var View = view || SearchBox; var useAutocomplete = (!!autocompleteResults || !!autocompleteSuggestions) && searchTerm.length >= autocompleteMinimumCharacters; var autocompletedSuggestionsCount = Object.entries(autocompletedSuggestions // eslint-disable-next-line no-unused-vars ).reduce(function (acc, _ref) { var _ref2 = _slicedToArray(_ref, 2), _ = _ref2[0], value = _ref2[1]; return acc + value.length; }, 0); var allAutocompletedItemsCount = autocompletedSuggestionsCount + autocompletedResults.length; var handleOnSelectAutocomplete; if (onSelectAutocomplete) { handleOnSelectAutocomplete = function handleOnSelectAutocomplete(selection) { onSelectAutocomplete(selection, { notifyAutocompleteSelected: _this2.handleNotifyAutocompleteSelected, completeSuggestion: _this2.completeSuggestion, autocompleteResults: _this2.props.autocompleteResults }, _this2.defaultOnSelectAutocomplete); }; } return View(_objectSpread({ allAutocompletedItemsCount: allAutocompletedItemsCount, autocompleteView: autocompleteView, autocompleteResults: autocompleteResults, autocompleteSuggestions: autocompleteSuggestions, autocompletedResults: autocompletedResults, autocompletedSuggestions: autocompletedSuggestions, className: className, autocompletedSuggestionsCount: autocompletedSuggestionsCount, completeSuggestion: this.completeSuggestion, isFocused: isFocused, notifyAutocompleteSelected: this.handleNotifyAutocompleteSelected, onChange: function onChange(value) { return _this2.handleChange(value); }, onSelectAutocomplete: handleOnSelectAutocomplete || this.defaultOnSelectAutocomplete, onSubmit: onSubmit ? function (e) { e.preventDefault(); onSubmit(searchTerm); } : this.handleSubmit, useAutocomplete: useAutocomplete, value: searchTerm, inputProps: _objectSpread({ onFocus: this.handleFocus, onBlur: this.handleBlur }, inputProps), inputView: inputView }, rest)); } }]); return SearchBoxContainer; }(Component); _defineProperty(SearchBoxContainer, "propTypes", { // Props autocompleteMinimumCharacters: PropTypes.number, autocompleteResults: PropTypes.oneOfType([PropTypes.bool, PropTypes.shape({ clickThroughTags: PropTypes.arrayOf(PropTypes.string), linkTarget: PropTypes.string, sectionTitle: PropTypes.string, shouldTrackClickThrough: PropTypes.bool, titleField: PropTypes.string.isRequired, urlField: PropTypes.string.isRequired })]), autocompleteSuggestions: PropTypes.oneOfType([PropTypes.bool, PropTypes.exact({ sectionTitle: PropTypes.string }), PropTypes.objectOf(PropTypes.exact({ sectionTitle: PropTypes.string }))]), autocompleteView: PropTypes.func, className: PropTypes.string, shouldClearFilters: PropTypes.bool, debounceLength: PropTypes.number, inputProps: PropTypes.object, inputView: PropTypes.func, onSelectAutocomplete: PropTypes.func, onSubmit: PropTypes.func, searchAsYouType: PropTypes.bool, view: PropTypes.func, // State autocompletedResults: PropTypes.arrayOf(Result).isRequired, autocompletedSuggestions: PropTypes.objectOf(PropTypes.arrayOf(Suggestion)).isRequired, searchTerm: PropTypes.string.isRequired, // Actions setSearchTerm: PropTypes.func.isRequired, trackAutocompleteClickThrough: PropTypes.func.isRequired }); _defineProperty(SearchBoxContainer, "defaultProps", { autocompleteMinimumCharacters: 0, shouldClearFilters: true }); export default withSearch(function (_ref3) { var autocompletedResults = _ref3.autocompletedResults, autocompletedSuggestions = _ref3.autocompletedSuggestions, searchTerm = _ref3.searchTerm, setSearchTerm = _ref3.setSearchTerm, trackAutocompleteClickThrough = _ref3.trackAutocompleteClickThrough; return { autocompletedResults: autocompletedResults, autocompletedSuggestions: autocompletedSuggestions, searchTerm: searchTerm, setSearchTerm: setSearchTerm, trackAutocompleteClickThrough: trackAutocompleteClickThrough }; })(SearchBoxContainer); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/containers/SearchBox.js"],"names":["PropTypes","Component","SearchBox","withSearch","Result","Suggestion","SearchBoxContainer","isFocused","setState","searchTerm","props","shouldClearFilters","setSearchTerm","e","preventDefault","value","autocompleteMinimumCharacters","autocompleteResults","autocompleteSuggestions","searchAsYouType","debounceLength","options","debounce","refresh","selection","trackAutocompleteClickThrough","shouldTrackClickThrough","suggestion","clickThroughTags","id","raw","handleNotifyAutocompleteSelected","url","urlField","target","linkTarget","window","open","completeSuggestion","state","autocompletedResults","autocompletedSuggestions","className","autocompleteView","inputProps","inputView","onSelectAutocomplete","onSubmit","view","rest","View","useAutocomplete","length","autocompletedSuggestionsCount","Object","entries","reduce","acc","_","allAutocompletedItemsCount","handleOnSelectAutocomplete","notifyAutocompleteSelected","defaultOnSelectAutocomplete","onChange","handleChange","handleSubmit","onFocus","handleFocus","onBlur","handleBlur","number","oneOfType","bool","shape","arrayOf","string","sectionTitle","titleField","isRequired","exact","objectOf","func","object"],"mappings":"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","sourcesContent":["import PropTypes from \"prop-types\";\nimport { Component } from \"react\";\nimport { SearchBox } from \"@elastic/react-search-ui-views\";\n\nimport { withSearch } from \"..\";\nimport { Result, Suggestion } from \"../types\";\n\nexport class SearchBoxContainer extends Component {\n  static propTypes = {\n    // Props\n    autocompleteMinimumCharacters: PropTypes.number,\n    autocompleteResults: PropTypes.oneOfType([\n      PropTypes.bool,\n      PropTypes.shape({\n        clickThroughTags: PropTypes.arrayOf(PropTypes.string),\n        linkTarget: PropTypes.string,\n        sectionTitle: PropTypes.string,\n        shouldTrackClickThrough: PropTypes.bool,\n        titleField: PropTypes.string.isRequired,\n        urlField: PropTypes.string.isRequired\n      })\n    ]),\n    autocompleteSuggestions: PropTypes.oneOfType([\n      PropTypes.bool,\n      PropTypes.exact({\n        sectionTitle: PropTypes.string\n      }),\n      PropTypes.objectOf(\n        PropTypes.exact({\n          sectionTitle: PropTypes.string\n        })\n      )\n    ]),\n    autocompleteView: PropTypes.func,\n    className: PropTypes.string,\n    shouldClearFilters: PropTypes.bool,\n    debounceLength: PropTypes.number,\n    inputProps: PropTypes.object,\n    inputView: PropTypes.func,\n    onSelectAutocomplete: PropTypes.func,\n    onSubmit: PropTypes.func,\n    searchAsYouType: PropTypes.bool,\n    view: PropTypes.func,\n    // State\n    autocompletedResults: PropTypes.arrayOf(Result).isRequired,\n    autocompletedSuggestions: PropTypes.objectOf(PropTypes.arrayOf(Suggestion))\n      .isRequired,\n    searchTerm: PropTypes.string.isRequired,\n    // Actions\n    setSearchTerm: PropTypes.func.isRequired,\n    trackAutocompleteClickThrough: PropTypes.func.isRequired\n  };\n\n  static defaultProps = {\n    autocompleteMinimumCharacters: 0,\n    shouldClearFilters: true\n  };\n\n  state = {\n    isFocused: false\n  };\n\n  handleFocus = () => {\n    this.setState({\n      isFocused: true\n    });\n  };\n\n  handleBlur = () => {\n    this.setState({\n      isFocused: false\n    });\n  };\n\n  completeSuggestion = searchTerm => {\n    const { shouldClearFilters, setSearchTerm } = this.props;\n    setSearchTerm(searchTerm, {\n      shouldClearFilters\n    });\n  };\n\n  handleSubmit = e => {\n    const { shouldClearFilters, searchTerm, setSearchTerm } = this.props;\n\n    e.preventDefault();\n    setSearchTerm(searchTerm, {\n      shouldClearFilters\n    });\n  };\n\n  handleChange = value => {\n    const {\n      autocompleteMinimumCharacters,\n      autocompleteResults,\n      autocompleteSuggestions,\n      shouldClearFilters,\n      searchAsYouType,\n      setSearchTerm,\n      debounceLength\n    } = this.props;\n\n    const options = {\n      autocompleteMinimumCharacters,\n      ...((autocompleteResults ||\n        autocompleteSuggestions ||\n        searchAsYouType) && {\n        debounce: debounceLength || 200\n      }),\n      shouldClearFilters,\n      refresh: !!searchAsYouType,\n      autocompleteResults: !!autocompleteResults,\n      autocompleteSuggestions: !!autocompleteSuggestions\n    };\n\n    setSearchTerm(value, options);\n  };\n\n  handleNotifyAutocompleteSelected = selection => {\n    const { autocompleteResults, trackAutocompleteClickThrough } = this.props;\n    // Because suggestions don't count as clickthroughs, only\n    // results\n    if (\n      autocompleteResults &&\n      autocompleteResults.shouldTrackClickThrough !== false &&\n      !selection.suggestion\n    ) {\n      const { clickThroughTags = [] } = autocompleteResults;\n      const id = selection.id.raw;\n      trackAutocompleteClickThrough(id, clickThroughTags);\n    }\n  };\n\n  defaultOnSelectAutocomplete = selection => {\n    const { autocompleteResults } = this.props;\n\n    this.handleNotifyAutocompleteSelected(selection);\n    if (!selection.suggestion) {\n      const url = selection[autocompleteResults.urlField]\n        ? selection[autocompleteResults.urlField].raw\n        : \"\";\n      if (url) {\n        const target = autocompleteResults.linkTarget || \"_self\";\n        window.open(url, target);\n      }\n    } else {\n      this.completeSuggestion(selection.suggestion);\n    }\n  };\n\n  render() {\n    const { isFocused } = this.state;\n    const {\n      autocompleteMinimumCharacters,\n      autocompleteResults,\n      autocompleteSuggestions,\n      autocompletedResults,\n      autocompletedSuggestions,\n      className,\n      autocompleteView,\n      inputProps,\n      inputView,\n      onSelectAutocomplete,\n      onSubmit,\n      searchTerm,\n      view,\n      ...rest\n    } = this.props;\n\n    const View = view || SearchBox;\n    const useAutocomplete =\n      (!!autocompleteResults || !!autocompleteSuggestions) &&\n      searchTerm.length >= autocompleteMinimumCharacters;\n    const autocompletedSuggestionsCount = Object.entries(\n      autocompletedSuggestions\n      // eslint-disable-next-line no-unused-vars\n    ).reduce((acc, [_, value]) => acc + value.length, 0);\n    const allAutocompletedItemsCount =\n      autocompletedSuggestionsCount + autocompletedResults.length;\n\n    let handleOnSelectAutocomplete;\n    if (onSelectAutocomplete) {\n      handleOnSelectAutocomplete = selection => {\n        onSelectAutocomplete(\n          selection,\n          {\n            notifyAutocompleteSelected: this.handleNotifyAutocompleteSelected,\n            completeSuggestion: this.completeSuggestion,\n            autocompleteResults: this.props.autocompleteResults\n          },\n          this.defaultOnSelectAutocomplete\n        );\n      };\n    }\n\n    return View({\n      allAutocompletedItemsCount: allAutocompletedItemsCount,\n      autocompleteView,\n      autocompleteResults: autocompleteResults,\n      autocompleteSuggestions: autocompleteSuggestions,\n      autocompletedResults: autocompletedResults,\n      autocompletedSuggestions: autocompletedSuggestions,\n      className,\n      autocompletedSuggestionsCount: autocompletedSuggestionsCount,\n      completeSuggestion: this.completeSuggestion,\n      isFocused: isFocused,\n      notifyAutocompleteSelected: this.handleNotifyAutocompleteSelected,\n      onChange: value => this.handleChange(value),\n      onSelectAutocomplete:\n        handleOnSelectAutocomplete || this.defaultOnSelectAutocomplete,\n      onSubmit: onSubmit\n        ? e => {\n            e.preventDefault();\n            onSubmit(searchTerm);\n          }\n        : this.handleSubmit,\n      useAutocomplete: useAutocomplete,\n      value: searchTerm,\n      inputProps: {\n        onFocus: this.handleFocus,\n        onBlur: this.handleBlur,\n        ...inputProps\n      },\n      inputView,\n      ...rest\n    });\n  }\n}\n\nexport default withSearch(\n  ({\n    autocompletedResults,\n    autocompletedSuggestions,\n    searchTerm,\n    setSearchTerm,\n    trackAutocompleteClickThrough\n  }) => ({\n    autocompletedResults,\n    autocompletedSuggestions,\n    searchTerm,\n    setSearchTerm,\n    trackAutocompleteClickThrough\n  })\n)(SearchBoxContainer);\n"]}