import { useLayoutEffect, useState } from 'react'; import { useLocation } from 'react-router-dom'; import { MagnifyingGlassIcon } from '../../components/Icons'; import { useAuth } from '../../context/AuthContext'; import { ILibraryFilter } from '../../utils/models'; interface SearchPanelProps { filter: ILibraryFilter setFilter: React.Dispatch> } function SearchPanel({ filter, setFilter }: SearchPanelProps) { const search = useLocation().search; const { user } = useAuth(); const [query, setQuery] = useState('') useLayoutEffect(() => { const filterType = new URLSearchParams(search).get('filter'); if (filterType === 'common') { setQuery(''); setFilter({ is_common: true }); } else if (filterType === 'personal' && user) { setQuery(''); setFilter({ ownedBy: user.id! }); } }, [user, search, setQuery, setFilter]); return (
setQuery(data.target.value)} />
); } export default SearchPanel; {/*
setFilterText(event.target.value)} />
*/}