The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Rocket.Chat/client/components/FilterByText.tsx

37 lines
1.1 KiB

import { Box, Icon, TextInput } from '@rocket.chat/fuselage';
import React, { FC, ChangeEvent, FormEvent, memo, useCallback, useEffect, useState } from 'react';
import { useTranslation } from '../contexts/TranslationContext';
type FilterByTextProps = {
placeholder?: string;
onChange: (filter: { text: string }) => void;
};
const FilterByText: FC<FilterByTextProps> = ({
placeholder,
onChange: setFilter,
...props
}) => {
const t = useTranslation();
const [text, setText] = useState('');
const handleInputChange = useCallback((event: ChangeEvent<HTMLInputElement>) => {
setText(event.currentTarget.value);
}, []);
useEffect(() => {
setFilter({ text });
}, [setFilter, text]);
const handleFormSubmit = useCallback((event: FormEvent<HTMLFormElement>) => {
event.preventDefault();
}, []);
return <Box mb='x16' is='form' onSubmit={handleFormSubmit} display='flex' flexDirection='column' {...props}>
<TextInput placeholder={placeholder ?? t('Search')} addon={<Icon name='magnifier' size='x20'/>} onChange={handleInputChange} value={text} />
</Box>;
};
export default memo(FilterByText);