import React, { useState, useEffect } from 'react'; import SearchIcon from '@material-ui/icons/Search'; import { InputBase, List, ListItem, Paper, Divider, ClickAwayListener } from '@material-ui/core'; import { makeStyles } from '@material-ui/core/styles'; import { User } from 'which-types'; import { get } from '../../requests'; import UserStrip from '../UserStrip/UserStrip'; import { useNavigate } from '../../hooks/useNavigate'; const INTERVAL = 300; const LIMIT = 7; const useStyles = makeStyles(theme => ({ root: { position: 'relative', background: 'rgba(255, 255, 255, 0.5)', borderRadius: '2px', padding: theme.spacing(0.5), display: 'flex', alignItems: 'center' }, results: { position: 'absolute', width: '100%', top: theme.spacing(5) }, listItem: { padding: 0 } })); const SearchBar: React.FC = () => { const [results, setResults] = useState([]); const [query, setQuery] = useState(''); const [debouncedQuery, setDebouncedQuery] = useState(query); const { navigate } = useNavigate(); const classes = useStyles(); useEffect(() => { const handler = setTimeout(() => setDebouncedQuery(query), INTERVAL); return () => clearTimeout(handler); }, [query]); useEffect(() => { const fetchPolls = () => { get(`/users?username[$regex]=${debouncedQuery}&$limit=${LIMIT}`) .then(response => setResults(response.data)) .catch(() => setResults([])); }; if (debouncedQuery) fetchPolls(); else setResults([]); }, [debouncedQuery]); const handleChange = (event: React.ChangeEvent): void => { setQuery(event.target.value.trim()); }; const handleClose = () => { setDebouncedQuery(''); setQuery(''); }; const handleNavigate = (index: number) => () => { navigate('profile', results[index]._id); handleClose(); }; const SearchResults = ( { results.map((result, index) => (
{(index < results.length - 1) && }
)) }
); return (
{results.length > 0 && SearchResults}
); }; export default SearchBar;