2022-12-20 21:07:34 +00:00
|
|
|
import { ReactNode } from 'react';
|
|
|
|
import { Search, X } from 'lucide-react';
|
|
|
|
import clsx from 'clsx';
|
2022-07-06 14:05:17 +00:00
|
|
|
|
2022-11-13 08:10:18 +00:00
|
|
|
import { useLocalStorage } from '@/react/hooks/useLocalStorage';
|
2022-07-06 14:05:17 +00:00
|
|
|
import { AutomationTestingProps } from '@/types';
|
2022-11-21 17:33:08 +00:00
|
|
|
import { useDebounce } from '@/react/hooks/useDebounce';
|
2022-01-04 12:16:09 +00:00
|
|
|
|
2022-12-20 21:07:34 +00:00
|
|
|
import { Button } from '@@/buttons';
|
|
|
|
|
2022-07-06 14:05:17 +00:00
|
|
|
interface Props extends AutomationTestingProps {
|
2022-01-04 12:16:09 +00:00
|
|
|
value: string;
|
2022-03-08 12:14:23 +00:00
|
|
|
placeholder?: string;
|
2022-01-04 12:16:09 +00:00
|
|
|
onChange(value: string): void;
|
2022-12-20 21:07:34 +00:00
|
|
|
className?: string;
|
|
|
|
children?: ReactNode;
|
2022-01-04 12:16:09 +00:00
|
|
|
}
|
|
|
|
|
2022-03-08 12:14:23 +00:00
|
|
|
export function SearchBar({
|
|
|
|
value,
|
|
|
|
placeholder = 'Search...',
|
|
|
|
onChange,
|
2022-07-06 14:05:17 +00:00
|
|
|
'data-cy': dataCy,
|
2022-12-20 21:07:34 +00:00
|
|
|
className,
|
|
|
|
children,
|
2022-03-08 12:14:23 +00:00
|
|
|
}: Props) {
|
2022-07-06 14:05:17 +00:00
|
|
|
const [searchValue, setSearchValue] = useDebounce(value, onChange);
|
|
|
|
|
2022-12-20 21:07:34 +00:00
|
|
|
function onClear() {
|
|
|
|
setSearchValue('');
|
|
|
|
}
|
|
|
|
|
2022-01-04 12:16:09 +00:00
|
|
|
return (
|
2022-12-20 21:07:34 +00:00
|
|
|
<div
|
2023-01-26 20:18:48 +00:00
|
|
|
className={clsx('searchBar items-center flex min-w-[90px]', className)}
|
2022-12-20 21:07:34 +00:00
|
|
|
>
|
2022-11-28 02:00:28 +00:00
|
|
|
<Search className="searchIcon lucide shrink-0" />
|
2022-01-04 12:16:09 +00:00
|
|
|
<input
|
|
|
|
type="text"
|
|
|
|
className="searchInput"
|
2022-07-06 14:05:17 +00:00
|
|
|
value={searchValue}
|
|
|
|
onChange={(e) => setSearchValue(e.target.value)}
|
2022-03-08 12:14:23 +00:00
|
|
|
placeholder={placeholder}
|
2022-07-06 14:05:17 +00:00
|
|
|
data-cy={dataCy}
|
2022-01-04 12:16:09 +00:00
|
|
|
/>
|
2022-12-20 21:07:34 +00:00
|
|
|
{children}
|
|
|
|
<Button onClick={onClear} icon={X} color="none" disabled={!searchValue} />
|
2022-01-04 12:16:09 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-03-08 12:14:23 +00:00
|
|
|
export function useSearchBarState(
|
|
|
|
key: string
|
|
|
|
): [string, (value: string) => void] {
|
|
|
|
const filterKey = keyBuilder(key);
|
|
|
|
const [value, setValue] = useLocalStorage(filterKey, '', sessionStorage);
|
2022-01-04 12:16:09 +00:00
|
|
|
|
2022-03-08 12:14:23 +00:00
|
|
|
return [value, setValue];
|
2022-01-04 12:16:09 +00:00
|
|
|
|
2022-03-08 12:14:23 +00:00
|
|
|
function keyBuilder(key: string) {
|
|
|
|
return `datatable_text_filter_${key}`;
|
2022-01-04 12:16:09 +00:00
|
|
|
}
|
|
|
|
}
|