44 lines
1.1 KiB
TypeScript
44 lines
1.1 KiB
TypeScript
import { IconX } from '@tabler/icons-react';
|
|
import { FC } from 'react';
|
|
|
|
import { useTranslation } from 'next-i18next';
|
|
|
|
interface Props {
|
|
placeholder: string;
|
|
searchTerm: string;
|
|
onSearch: (searchTerm: string) => void;
|
|
}
|
|
const Search: FC<Props> = ({ placeholder, searchTerm, onSearch }) => {
|
|
const { t } = useTranslation('sidebar');
|
|
|
|
const handleSearchChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
onSearch(e.target.value);
|
|
};
|
|
|
|
const clearSearch = () => {
|
|
onSearch('');
|
|
};
|
|
|
|
return (
|
|
<div className="relative flex items-center">
|
|
<input
|
|
className="w-full flex-1 rounded-md border border-neutral-700 bg-[#161519] px-4 py-3 pr-10 text-[14px] leading-3 text-white"
|
|
type="text"
|
|
placeholder={t(placeholder) || ''}
|
|
value={searchTerm}
|
|
onChange={handleSearchChange}
|
|
/>
|
|
|
|
{searchTerm && (
|
|
<IconX
|
|
className="absolute right-4 cursor-pointer text-neutral-300 hover:text-neutral-400"
|
|
size={18}
|
|
onClick={clearSearch}
|
|
/>
|
|
)}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default Search;
|