UNPKG

orionsoft-react-scripts

Version:

Orionsoft Configuration and scripts for Create React App.

23 lines (19 loc) 794 B
import editDistance from 'damerau-levenshtein'; // Minimum edit distance to be considered a good suggestion. const THRESHOLD = 2; /** * Returns an array of suggestions given a word and a dictionary and limit of suggestions * to return. */ export default function getSuggestion(word, dictionary = [], limit = 2) { const distances = dictionary.reduce((suggestions, dictionaryWord) => { const distance = editDistance(word.toUpperCase(), dictionaryWord.toUpperCase()); const { steps } = distance; suggestions[dictionaryWord] = steps; // eslint-disable-line return suggestions; }, {}); return Object.keys(distances) .filter(suggestion => distances[suggestion] <= THRESHOLD) .sort((a, b) => distances[a] - distances[b]) // Sort by distance .slice(0, limit); }