Socket
Socket
Sign inDemoInstall

react-search-autocomplete

Package Overview
Dependencies
Maintainers
1
Versions
55
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-search-autocomplete - npm Package Compare versions

Comparing version 2.0.4 to 3.0.0

dist/components/ReactSearchAutocomplete.js

4

dist/index.js

@@ -13,5 +13,5 @@ "use strict";

var _ReactSearchAutocomplete = _interopRequireDefault(require("./ReactSearchAutocomplete.js"));
var _ReactSearchAutocomplete = _interopRequireDefault(require("./components/ReactSearchAutocomplete.js"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdFNlYXJjaEF1dG9jb21wbGV0ZSBmcm9tICcuL1JlYWN0U2VhcmNoQXV0b2NvbXBsZXRlLmpzJ1xuXG5leHBvcnQgeyBSZWFjdFNlYXJjaEF1dG9jb21wbGV0ZSB9XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdFNlYXJjaEF1dG9jb21wbGV0ZSBmcm9tICcuL2NvbXBvbmVudHMvUmVhY3RTZWFyY2hBdXRvY29tcGxldGUuanMnXG5cbmV4cG9ydCB7IFJlYWN0U2VhcmNoQXV0b2NvbXBsZXRlIH1cbiJdfQ==

@@ -86,3 +86,4 @@ "use strict";

return _objectSpread({}, result.item);
});
}).slice(0, maxResults);
useCaching ? debounceOnSearch(searchString, (0, _utils.isCached)(keyword), newResults) : debounceOnSearch(searchString, [], newResults);

@@ -105,6 +106,6 @@ if (useCaching) {

var debounceOnSearch = _react["default"].useCallback(inputDebounce > 0 ? (0, _utils.debounce)(function (keyword, cached) {
return onSearch(keyword, cached);
}, inputDebounce) : function (keyword, cached) {
return onSearch(keyword, cached);
var debounceOnSearch = _react["default"].useCallback(inputDebounce > 0 ? (0, _utils.debounce)(function (keyword, cached, results) {
return onSearch(keyword, cached, results);
}, inputDebounce) : function (keyword, cached, results) {
return onSearch(keyword, cached, results);
}, []);

@@ -114,9 +115,2 @@

setSearchString(event.target.value);
var keyword = event.target.value.toLowerCase();
if (useCaching) {
onSearch && debounceOnSearch(event.target.value, (0, _utils.isCached)(keyword));
} else {
onSearch && debounceOnSearch(event.target.value, false);
}
};

@@ -151,2 +145,3 @@

fuseOptions: _defaults.defaultFuseOptions,
onSearch: function onSearch() {},
useCaching: false,

@@ -176,2 +171,2 @@ inputDebounce: 200,

};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ReactSearchAutocomplete.js"],"names":["ReactSearchAutocomplete","props","items","fuseOptions","useCaching","inputDebounce","onSearch","onSelect","onFocus","showIcon","maxResults","placeholder","autoFocus","styling","resultStringKeyName","theme","defaultTheme","options","defaultFuseOptions","React","useState","searchString","setSearchString","results","setResults","useEffect","sessionStorage","clear","keyword","toLowerCase","length","fuse","Fuse","newResults","search","map","result","item","JSON","parse","getItem","setItem","stringify","debounceOnSearch","useCallback","cached","handleSetSearchString","event","target","value","defaultProps","propTypes","PropTypes","array","object","bool","number","func","string"],"mappings":"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","sourcesContent":["import React from 'react'\nimport PropTypes from 'prop-types'\nimport Fuse from 'fuse.js'\nimport { defaultTheme, GlobalStyle, defaultFuseOptions } from './defaults/defaults'\nimport Results from './Results/Results'\nimport { StyledReactSearchAutocomplete } from './StyledReactSearchAutocomplete'\nimport SearchInput from './SearchInput/SearchInput'\nimport { ThemeProvider } from 'styled-components'\nimport { debounce, isCached } from './utils/utils'\n\nexport default function ReactSearchAutocomplete(props) {\n  const {\n    items,\n    fuseOptions,\n    useCaching,\n    inputDebounce,\n    onSearch,\n    onSelect,\n    onFocus,\n    showIcon,\n    maxResults,\n    placeholder,\n    autoFocus,\n    styling,\n    resultStringKeyName\n  } = props\n\n  const theme = { ...defaultTheme, ...styling }\n  const options = { ...defaultFuseOptions, ...fuseOptions }\n\n  const [searchString, setSearchString] = React.useState('')\n  const [results, setResults] = React.useState()\n\n  React.useEffect(() => {\n    if (useCaching) sessionStorage.clear()\n  }, [items])\n\n  React.useEffect(() => {\n    const keyword = searchString?.toLowerCase()\n\n    if (keyword?.length > 0) {\n      const fuse = new Fuse(items, options)\n      const newResults = fuse.search(searchString).map((result) => ({ ...result.item }))\n\n      if (useCaching) {\n        if (keyword in sessionStorage) {\n          setResults(JSON.parse(sessionStorage.getItem(keyword)))\n        } else {\n          sessionStorage.setItem(keyword, JSON.stringify(newResults))\n          setResults(newResults)\n        }\n      } else {\n        setResults(newResults)\n      }\n    } else {\n      setResults([])\n    }\n  }, [searchString, items, useCaching])\n\n  // This is used to debounce the onSearch props function\n  const debounceOnSearch = React.useCallback(\n    inputDebounce > 0\n      ? debounce((keyword, cached) => onSearch(keyword, cached), inputDebounce)\n      : (keyword, cached) => onSearch(keyword, cached),\n    []\n  )\n\n  const handleSetSearchString = (event) => {\n    setSearchString(event.target.value)\n    const keyword = event.target.value.toLowerCase()\n    if (useCaching) {\n      onSearch && debounceOnSearch(event.target.value, isCached(keyword))\n    } else {\n      onSearch && debounceOnSearch(event.target.value, false)\n    }\n  }\n\n  return (\n    <ThemeProvider theme={theme}>\n      <GlobalStyle />\n      <StyledReactSearchAutocomplete>\n        <div className=\"wrapper\">\n          <SearchInput\n            searchString={searchString}\n            setSearchString={handleSetSearchString}\n            autoFocus={autoFocus}\n            onBlur={() => setResults([])}\n            onFocus={onFocus}\n            placeholder={placeholder}\n            showIcon={showIcon}\n          />\n          <Results\n            results={results}\n            onClick={onSelect}\n            setSearchString={setSearchString}\n            showIcon={showIcon}\n            maxResults={maxResults}\n            resultStringKeyName={resultStringKeyName}\n          />\n        </div>\n      </StyledReactSearchAutocomplete>\n    </ThemeProvider>\n  )\n}\n\nReactSearchAutocomplete.defaultProps = {\n  items: [],\n  fuseOptions: defaultFuseOptions,\n  useCaching: false,\n  inputDebounce: 200,\n  showIcon: true,\n  maxResults: 10,\n  placeholder: '',\n  autoFocus: false,\n  styling: {},\n  resultStringKeyName: 'name'\n}\n\nReactSearchAutocomplete.propTypes = {\n  items: PropTypes.array,\n  fuseOptions: PropTypes.object,\n  useCaching: PropTypes.bool,\n  inputDebounce: PropTypes.number,\n  onSearch: PropTypes.func,\n  onSelect: PropTypes.func,\n  onFocus: PropTypes.func,\n  showIcon: PropTypes.bool,\n  maxResults: PropTypes.number,\n  placeholder: PropTypes.string,\n  autoFocus: PropTypes.bool,\n  styling: PropTypes.object,\n  resultStringKeyName: PropTypes.string\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ReactSearchAutocomplete.js"],"names":["ReactSearchAutocomplete","props","items","fuseOptions","useCaching","inputDebounce","onSearch","onSelect","onFocus","showIcon","maxResults","placeholder","autoFocus","styling","resultStringKeyName","theme","defaultTheme","options","defaultFuseOptions","React","useState","searchString","setSearchString","results","setResults","useEffect","sessionStorage","clear","keyword","toLowerCase","length","fuse","Fuse","newResults","search","map","result","item","slice","debounceOnSearch","JSON","parse","getItem","setItem","stringify","useCallback","cached","handleSetSearchString","event","target","value","defaultProps","propTypes","PropTypes","array","object","bool","number","func","string"],"mappings":"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","sourcesContent":["import React from 'react'\nimport PropTypes from 'prop-types'\nimport Fuse from 'fuse.js'\nimport { defaultTheme, GlobalStyle, defaultFuseOptions } from './defaults/defaults'\nimport Results from './Results/Results'\nimport { StyledReactSearchAutocomplete } from './StyledReactSearchAutocomplete'\nimport SearchInput from './SearchInput/SearchInput'\nimport { ThemeProvider } from 'styled-components'\nimport { debounce, isCached } from './utils/utils'\n\nexport default function ReactSearchAutocomplete(props) {\n  const {\n    items,\n    fuseOptions,\n    useCaching,\n    inputDebounce,\n    onSearch,\n    onSelect,\n    onFocus,\n    showIcon,\n    maxResults,\n    placeholder,\n    autoFocus,\n    styling,\n    resultStringKeyName\n  } = props\n\n  const theme = { ...defaultTheme, ...styling }\n  const options = { ...defaultFuseOptions, ...fuseOptions }\n\n  const [searchString, setSearchString] = React.useState('')\n  const [results, setResults] = React.useState()\n\n  React.useEffect(() => {\n    if (useCaching) sessionStorage.clear()\n  }, [items])\n\n  React.useEffect(() => {\n    const keyword = searchString?.toLowerCase()\n\n    if (keyword?.length > 0) {\n      const fuse = new Fuse(items, options)\n      const newResults = fuse\n        .search(searchString)\n        .map((result) => ({ ...result.item }))\n        .slice(0, maxResults)\n\n      useCaching\n        ? debounceOnSearch(searchString, isCached(keyword), newResults)\n        : debounceOnSearch(searchString, [], newResults)\n\n      if (useCaching) {\n        if (keyword in sessionStorage) {\n          setResults(JSON.parse(sessionStorage.getItem(keyword)))\n        } else {\n          sessionStorage.setItem(keyword, JSON.stringify(newResults))\n          setResults(newResults)\n        }\n      } else {\n        setResults(newResults)\n      }\n    } else {\n      setResults([])\n    }\n  }, [searchString, items, useCaching])\n\n  // This is used to debounce the onSearch props function\n  const debounceOnSearch = React.useCallback(\n    inputDebounce > 0\n      ? debounce((keyword, cached, results) => onSearch(keyword, cached, results), inputDebounce)\n      : (keyword, cached, results) => onSearch(keyword, cached, results),\n    []\n  )\n\n  const handleSetSearchString = (event) => {\n    setSearchString(event.target.value)\n  }\n\n  return (\n    <ThemeProvider theme={theme}>\n      <GlobalStyle />\n      <StyledReactSearchAutocomplete>\n        <div className=\"wrapper\">\n          <SearchInput\n            searchString={searchString}\n            setSearchString={handleSetSearchString}\n            autoFocus={autoFocus}\n            onBlur={() => setResults([])}\n            onFocus={onFocus}\n            placeholder={placeholder}\n            showIcon={showIcon}\n          />\n          <Results\n            results={results}\n            onClick={onSelect}\n            setSearchString={setSearchString}\n            showIcon={showIcon}\n            maxResults={maxResults}\n            resultStringKeyName={resultStringKeyName}\n          />\n        </div>\n      </StyledReactSearchAutocomplete>\n    </ThemeProvider>\n  )\n}\n\nReactSearchAutocomplete.defaultProps = {\n  items: [],\n  fuseOptions: defaultFuseOptions,\n  onSearch: () => {},\n  useCaching: false,\n  inputDebounce: 200,\n  showIcon: true,\n  maxResults: 10,\n  placeholder: '',\n  autoFocus: false,\n  styling: {},\n  resultStringKeyName: 'name'\n}\n\nReactSearchAutocomplete.propTypes = {\n  items: PropTypes.array,\n  fuseOptions: PropTypes.object,\n  useCaching: PropTypes.bool,\n  inputDebounce: PropTypes.number,\n  onSearch: PropTypes.func,\n  onSelect: PropTypes.func,\n  onFocus: PropTypes.func,\n  showIcon: PropTypes.bool,\n  maxResults: PropTypes.number,\n  placeholder: PropTypes.string,\n  autoFocus: PropTypes.bool,\n  styling: PropTypes.object,\n  resultStringKeyName: PropTypes.string\n}\n"]}

@@ -36,6 +36,6 @@ "use strict";

if (cachedValues) return cachedValues;
return false;
return [];
};
exports.isCached = isCached;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy91dGlscy5qcyJdLCJuYW1lcyI6WyJkZWJvdW5jZSIsImZ1bmMiLCJ3YWl0IiwiaW1tZWRpYXRlIiwidGltZW91dCIsImNvbnRleHQiLCJhcmdzIiwiYXJndW1lbnRzIiwibGF0ZXIiLCJhcHBseSIsImNsZWFyVGltZW91dCIsInNldFRpbWVvdXQiLCJpc0NhY2hlZCIsImtleXdvcmQiLCJ0b0xvd2VyQ2FzZSIsImNhY2hlZFZhbHVlcyIsIkpTT04iLCJwYXJzZSIsInNlc3Npb25TdG9yYWdlIiwiZ2V0SXRlbSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBTyxTQUFTQSxRQUFULENBQWtCQyxJQUFsQixFQUF3QkMsSUFBeEIsRUFBOEJDLFNBQTlCLEVBQXlDO0FBQzlDLE1BQUlDLE9BQUo7QUFDQSxTQUFPLFlBQVk7QUFDakIsUUFBSUMsT0FBTyxHQUFHLElBQWQ7QUFBQSxRQUNFQyxJQUFJLEdBQUdDLFNBRFQ7O0FBRUEsUUFBSUMsS0FBSyxHQUFHLFNBQVJBLEtBQVEsR0FBWTtBQUN0QkosTUFBQUEsT0FBTyxHQUFHLElBQVY7QUFDQSxVQUFJLENBQUNELFNBQUwsRUFBZ0JGLElBQUksQ0FBQ1EsS0FBTCxDQUFXSixPQUFYLEVBQW9CQyxJQUFwQjtBQUNqQixLQUhEOztBQUlBLFFBQUlILFNBQVMsSUFBSSxDQUFDQyxPQUFsQixFQUEyQkgsSUFBSSxDQUFDUSxLQUFMLENBQVdKLE9BQVgsRUFBb0JDLElBQXBCO0FBQzNCSSxJQUFBQSxZQUFZLENBQUNOLE9BQUQsQ0FBWjtBQUNBQSxJQUFBQSxPQUFPLEdBQUdPLFVBQVUsQ0FBQ0gsS0FBRCxFQUFRTixJQUFSLENBQXBCO0FBQ0QsR0FWRDtBQVdEO0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBRU8sSUFBTVUsUUFBUSxHQUFHLFNBQVhBLFFBQVcsQ0FBQ0MsT0FBRCxFQUFhO0FBQ25DQSxFQUFBQSxPQUFPLEdBQUdBLE9BQU8sQ0FBQ0MsV0FBUixFQUFWO0FBQ0EsTUFBTUMsWUFBWSxHQUFHQyxJQUFJLENBQUNDLEtBQUwsQ0FBV0MsY0FBYyxDQUFDQyxPQUFmLENBQXVCTixPQUFPLENBQUNDLFdBQVIsRUFBdkIsQ0FBWCxDQUFyQjtBQUNBLE1BQUlDLFlBQUosRUFBa0IsT0FBT0EsWUFBUDtBQUNsQixTQUFPLEtBQVA7QUFDRCxDQUxNIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGRlYm91bmNlKGZ1bmMsIHdhaXQsIGltbWVkaWF0ZSkge1xuICB2YXIgdGltZW91dFxuICByZXR1cm4gZnVuY3Rpb24gKCkge1xuICAgIHZhciBjb250ZXh0ID0gdGhpcyxcbiAgICAgIGFyZ3MgPSBhcmd1bWVudHNcbiAgICB2YXIgbGF0ZXIgPSBmdW5jdGlvbiAoKSB7XG4gICAgICB0aW1lb3V0ID0gbnVsbFxuICAgICAgaWYgKCFpbW1lZGlhdGUpIGZ1bmMuYXBwbHkoY29udGV4dCwgYXJncylcbiAgICB9XG4gICAgaWYgKGltbWVkaWF0ZSAmJiAhdGltZW91dCkgZnVuYy5hcHBseShjb250ZXh0LCBhcmdzKVxuICAgIGNsZWFyVGltZW91dCh0aW1lb3V0KVxuICAgIHRpbWVvdXQgPSBzZXRUaW1lb3V0KGxhdGVyLCB3YWl0KVxuICB9XG59XG5cbi8qKlxuICogVGhpcyBmdW5jdGlvbiB3aWxsIHJldHVybiB0aGUgY2FjaGVkVmFsdWVzIGlmIHRoZXkgZXhpc3Qgb3IgZmFsc2UgaWYgbm90XG4gKlxuICogQHBhcmFtIHtzdHJpbmd9IGtleXdvcmQgVGhlIHN0cmluZyB0aGUgdXNlciBpcyBzZWFyY2hpbmdcbiAqL1xuXG5leHBvcnQgY29uc3QgaXNDYWNoZWQgPSAoa2V5d29yZCkgPT4ge1xuICBrZXl3b3JkID0ga2V5d29yZC50b0xvd2VyQ2FzZSgpXG4gIGNvbnN0IGNhY2hlZFZhbHVlcyA9IEpTT04ucGFyc2Uoc2Vzc2lvblN0b3JhZ2UuZ2V0SXRlbShrZXl3b3JkLnRvTG93ZXJDYXNlKCkpKVxuICBpZiAoY2FjaGVkVmFsdWVzKSByZXR1cm4gY2FjaGVkVmFsdWVzXG4gIHJldHVybiBmYWxzZVxufVxuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy91dGlscy5qcyJdLCJuYW1lcyI6WyJkZWJvdW5jZSIsImZ1bmMiLCJ3YWl0IiwiaW1tZWRpYXRlIiwidGltZW91dCIsImNvbnRleHQiLCJhcmdzIiwiYXJndW1lbnRzIiwibGF0ZXIiLCJhcHBseSIsImNsZWFyVGltZW91dCIsInNldFRpbWVvdXQiLCJpc0NhY2hlZCIsImtleXdvcmQiLCJ0b0xvd2VyQ2FzZSIsImNhY2hlZFZhbHVlcyIsIkpTT04iLCJwYXJzZSIsInNlc3Npb25TdG9yYWdlIiwiZ2V0SXRlbSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBTyxTQUFTQSxRQUFULENBQWtCQyxJQUFsQixFQUF3QkMsSUFBeEIsRUFBOEJDLFNBQTlCLEVBQXlDO0FBQzlDLE1BQUlDLE9BQUo7QUFDQSxTQUFPLFlBQVk7QUFDakIsUUFBSUMsT0FBTyxHQUFHLElBQWQ7QUFBQSxRQUNFQyxJQUFJLEdBQUdDLFNBRFQ7O0FBRUEsUUFBSUMsS0FBSyxHQUFHLFNBQVJBLEtBQVEsR0FBWTtBQUN0QkosTUFBQUEsT0FBTyxHQUFHLElBQVY7QUFDQSxVQUFJLENBQUNELFNBQUwsRUFBZ0JGLElBQUksQ0FBQ1EsS0FBTCxDQUFXSixPQUFYLEVBQW9CQyxJQUFwQjtBQUNqQixLQUhEOztBQUlBLFFBQUlILFNBQVMsSUFBSSxDQUFDQyxPQUFsQixFQUEyQkgsSUFBSSxDQUFDUSxLQUFMLENBQVdKLE9BQVgsRUFBb0JDLElBQXBCO0FBQzNCSSxJQUFBQSxZQUFZLENBQUNOLE9BQUQsQ0FBWjtBQUNBQSxJQUFBQSxPQUFPLEdBQUdPLFVBQVUsQ0FBQ0gsS0FBRCxFQUFRTixJQUFSLENBQXBCO0FBQ0QsR0FWRDtBQVdEO0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBRU8sSUFBTVUsUUFBUSxHQUFHLFNBQVhBLFFBQVcsQ0FBQ0MsT0FBRCxFQUFhO0FBQ25DQSxFQUFBQSxPQUFPLEdBQUdBLE9BQU8sQ0FBQ0MsV0FBUixFQUFWO0FBQ0EsTUFBTUMsWUFBWSxHQUFHQyxJQUFJLENBQUNDLEtBQUwsQ0FBV0MsY0FBYyxDQUFDQyxPQUFmLENBQXVCTixPQUFPLENBQUNDLFdBQVIsRUFBdkIsQ0FBWCxDQUFyQjtBQUVBLE1BQUlDLFlBQUosRUFBa0IsT0FBT0EsWUFBUDtBQUNsQixTQUFPLEVBQVA7QUFDRCxDQU5NIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGRlYm91bmNlKGZ1bmMsIHdhaXQsIGltbWVkaWF0ZSkge1xuICB2YXIgdGltZW91dFxuICByZXR1cm4gZnVuY3Rpb24gKCkge1xuICAgIHZhciBjb250ZXh0ID0gdGhpcyxcbiAgICAgIGFyZ3MgPSBhcmd1bWVudHNcbiAgICB2YXIgbGF0ZXIgPSBmdW5jdGlvbiAoKSB7XG4gICAgICB0aW1lb3V0ID0gbnVsbFxuICAgICAgaWYgKCFpbW1lZGlhdGUpIGZ1bmMuYXBwbHkoY29udGV4dCwgYXJncylcbiAgICB9XG4gICAgaWYgKGltbWVkaWF0ZSAmJiAhdGltZW91dCkgZnVuYy5hcHBseShjb250ZXh0LCBhcmdzKVxuICAgIGNsZWFyVGltZW91dCh0aW1lb3V0KVxuICAgIHRpbWVvdXQgPSBzZXRUaW1lb3V0KGxhdGVyLCB3YWl0KVxuICB9XG59XG5cbi8qKlxuICogVGhpcyBmdW5jdGlvbiB3aWxsIHJldHVybiB0aGUgY2FjaGVkVmFsdWVzIGlmIHRoZXkgZXhpc3Qgb3IgZmFsc2UgaWYgbm90XG4gKlxuICogQHBhcmFtIHtzdHJpbmd9IGtleXdvcmQgVGhlIHN0cmluZyB0aGUgdXNlciBpcyBzZWFyY2hpbmdcbiAqL1xuXG5leHBvcnQgY29uc3QgaXNDYWNoZWQgPSAoa2V5d29yZCkgPT4ge1xuICBrZXl3b3JkID0ga2V5d29yZC50b0xvd2VyQ2FzZSgpXG4gIGNvbnN0IGNhY2hlZFZhbHVlcyA9IEpTT04ucGFyc2Uoc2Vzc2lvblN0b3JhZ2UuZ2V0SXRlbShrZXl3b3JkLnRvTG93ZXJDYXNlKCkpKVxuXG4gIGlmIChjYWNoZWRWYWx1ZXMpIHJldHVybiBjYWNoZWRWYWx1ZXNcbiAgcmV0dXJuIFtdXG59XG4iXX0=

@@ -5,3 +5,3 @@ {

"license": "MIT",
"version": "2.0.4",
"version": "3.0.0",
"description": "A search box for React",

@@ -8,0 +8,0 @@ "main": "dist/index.js",

@@ -9,2 +9,10 @@ ![travis](https://travis-ci.com/sickdyd/react-search-autocomplete.svg?branch=master)

`3.0.0`
- `onSearch` will have as the first argument of the callback the `keyword` searched and for the second the `results`
- `onSearch` `results` now will be `[]` instead of `false` if there are no cached results or results
- Greatly improved performance with large amount of items
`2.0.4`
- Support for different `items` structure is now properly working

@@ -67,7 +75,8 @@ - `useCaching` is now by default set to `false`

const handleOnSearch = (string, cached) => {
// onSearch returns the string searched and if
// the values are cached. If the values are cached
// "cached" contains the cached values, if not, returns false
console.log(string, cached)
const handleOnSearch = (string, results) => {
// onSearch will have as the first callback parameter
// the string searched and for the second the results.
// If useCached is true and results are are cached it
// returns cached results
console.log(string, results)
}

@@ -109,81 +118,81 @@

items,
// The list of items that can be filtered, it can be an array of
// any type of object. By default the search will be done on the
// property "name", to change this behaviour, change the `fuseOptions`
// prop. Remember that the component uses the key "name" in your
// items list to display the result. If your list of items does not
// have a "name" key, use `resultStringKeyName` to tell what key
// (string) to use to display in the results.
fuseOptions,
// To know more about fuse params, visit https://fusejs.io/
//
// By default set to:
// {
// shouldSort: true,
// threshold: 0.6,
// location: 0,
// distance: 100,
// maxPatternLength: 32,
// minMatchCharLength: 1,
// keys: [
// "name",
// ]
// }
//
// `keys` represent the keys in `items` where the search will be
// performed.
//
// Imagine for example that I want to search in `items` by `title`
// and `description` in the following items, and display the `title`;
// this is how to do it:
//
// const items = [
// {
// id: 0,
// title: 'Titanic',
// description: 'A movie about love'
// },
// {
// id: 1,
// title: 'Dead Poets Society',
// description: 'A movie about poetry and the meaning of life'
// }
// ]
//
// I can pass the fuseOptions prop as follows:
//
// <ReactSearchAutocomplete
// items={items}
// fuseOptions={{ keys: ["title", "description"] }}
// // necessary, otherwise the results will be blank
// resultStringKeyName="title"
// />
//
resultStringKeyName,
// The key in `items` that contains the string to display in the
// results
useCaching,
// Default value: false. If set to true, the items will
// be stored in sessionStorage, and each time onSearch
// is called, cached will be true.
inputDebounce,
// Default value: 200. When the user is typing, before
// calling onSearch wait this amount of ms.
onSearch,
// The callback function called when the user is searching.
onSelect,
// The callback function called when the user selects an item
// from the filtered list.
onFocus,
// The callback function called when the user focuses the input.
showIcon,
// Default value: true. If set to false, the icon is hidden.
maxResults,
// Default value: 10. The max number of results to show at once.
placeholder,
// Default value: "". The placeholder of the search box.
autoFocus,
// Default value: false. If set to true, automatically
// set focus on the input.
styling
// The list of items that can be filtered, it can be an array of
// any type of object. By default the search will be done on the
// property "name", to change this behaviour, change the `fuseOptions`
// prop. Remember that the component uses the key "name" in your
// items list to display the result. If your list of items does not
// have a "name" key, use `resultStringKeyName` to tell what key
// (string) to use to display in the results.
fuseOptions,
// To know more about fuse params, visit https://fusejs.io/
//
// By default set to:
// {
// shouldSort: true,
// threshold: 0.6,
// location: 0,
// distance: 100,
// maxPatternLength: 32,
// minMatchCharLength: 1,
// keys: [
// "name",
// ]
// }
//
// `keys` represent the keys in `items` where the search will be
// performed.
//
// Imagine for example that I want to search in `items` by `title`
// and `description` in the following items, and display the `title`;
// this is how to do it:
//
// const items = [
// {
// id: 0,
// title: 'Titanic',
// description: 'A movie about love'
// },
// {
// id: 1,
// title: 'Dead Poets Society',
// description: 'A movie about poetry and the meaning of life'
// }
// ]
//
// I can pass the fuseOptions prop as follows:
//
// <ReactSearchAutocomplete
// items={items}
// fuseOptions={{ keys: ["title", "description"] }}
// // necessary, otherwise the results will be blank
// resultStringKeyName="title"
// />
//
resultStringKeyName,
// The key in `items` that contains the string to display in the
// results
useCaching,
// Default value: false. If set to true, the items will
// be stored in sessionStorage, and each time onSearch
// is called, cached will be true.
inputDebounce,
// Default value: 200. When the user is typing, before
// calling onSearch wait this amount of ms.
onSearch,
// The callback function called when the user is searching
onSelect,
// The callback function called when the user selects an item
// from the filtered list.
onFocus,
// The callback function called when the user focuses the input.
showIcon,
// Default value: true. If set to false, the icon is hidden.
maxResults,
// Default value: 10. The max number of results to show at once.
placeholder,
// Default value: "". The placeholder of the search box.
autoFocus,
// Default value: false. If set to true, automatically
// set focus on the input.
styling
// The styling prop allows you to customize the

@@ -190,0 +199,0 @@ // look of the searchbox

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc