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

63 lines
1.4 KiB

import { Box, Icon, TextInput, Button } 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;
displayButton: boolean;
textButton: string;
onButtonClick: () => void;
inputRef: () => void;
};
const FilterByText: FC<FilterByTextProps> = ({
placeholder,
onChange: setFilter,
displayButton: display = false,
textButton = '',
onButtonClick,
inputRef,
...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='row'
{...props}
>
<TextInput
placeholder={placeholder ?? t('Search')}
ref={inputRef}
addon={<Icon name='magnifier' size='x20' />}
onChange={handleInputChange}
value={text}
/>
<Button onClick={onButtonClick} display={display ? 'block' : 'none'} mis='x8' primary>
{textButton}
</Button>
</Box>
);
};
export default memo(FilterByText);