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/RoomAutoComplete/RoomAutoComplete.js

50 lines
1.3 KiB

import { AutoComplete, Option, Box } from '@rocket.chat/fuselage';
import React, { memo, useMemo, useState } from 'react';
import { useEndpointData } from '../../hooks/useEndpointData';
import RoomAvatar from '../avatar/RoomAvatar';
import Avatar from './Avatar';
const query = (term = '') => ({ selector: JSON.stringify({ name: term }) });
const RoomAutoComplete = (props) => {
const [filter, setFilter] = useState('');
const { value: data } = useEndpointData(
'rooms.autocomplete.channelAndPrivate',
useMemo(() => query(filter), [filter]),
);
const options = useMemo(
() =>
(data &&
data.items.map(({ name, _id, avatarETag, t }) => ({
value: _id,
label: { name, avatarETag, type: t },
}))) ||
[],
[data],
);
return (
<AutoComplete
{...props}
filter={filter}
setFilter={setFilter}
renderSelected={({ value, label }) => (
<>
<Box margin='none' mi='x2'>
<RoomAvatar size='x20' room={{ type: label?.type || 'c', _id: value, ...label }} />{' '}
</Box>
<Box margin='none' mi='x2'>
{label?.name}
</Box>
</>
)}
renderItem={({ value, label, ...props }) => (
<Option key={value} {...props} label={label.name} avatar={<Avatar value={value} {...label} />} />
)}
options={options}
/>
);
};
export default memo(RoomAutoComplete);