import Fuse from 'fuse.js'; import React from 'react'; export default function Filter({ items, query = '', isCaseSensitive = false, keys, output, }: { items: Array, query: string, isCaseSensitive?: boolean, keys: Array, output: (filteredItems: Array>) => U, }) { if (query.length > 0) { const fuse = new Fuse(items, { isCaseSensitive, keys, }); const filteredItems = fuse.search(query); return ( <>{output(filteredItems)} ); } return ( <> {output(items.map((item, refIndex) => ({ item, refIndex, })))} ); }