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

40 lines
1.1 KiB

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