import withSitePaths from 'Components/utils/withSitePaths' import { encodeRuleName, parentName } from 'Engine/rules.js' import { compose, pick, sortBy, take } from 'ramda' import React, { useEffect, useState } from 'react' import Highlighter from 'react-highlight-words' import { useTranslation } from 'react-i18next' import { Link, Redirect } from 'react-router-dom' import Worker from 'worker-loader!./SearchBar.worker.js' import { capitalise0 } from '../utils' const worker = new Worker() let SearchBar = ({ rules, showDefaultList, finally: finallyCallback, sitePaths }) => { const [input, setInput] = useState('') const [selectedOption, setSelectedOption] = useState(null) const [results, setResults] = useState([]) const { i18n } = useTranslation() useEffect(() => { worker.postMessage({ rules: rules.map( pick(['title', 'espace', 'description', 'name', 'dottedName']) ) }) worker.onmessage = ({ data: results }) => setResults(results) }, []) let renderOptions = rules => { let options = (rules && sortBy(rule => rule.dottedName, rules)) || take(5)(results) return