/* * Wire * Copyright (C) 2021 Wire Swiss GmbH * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see http://www.gnu.org/licenses/. * */ import React, {forwardRef} from 'react'; import {TabIndex} from '@wireapp/react-ui-kit/lib/types/enums'; import cx from 'classnames'; import {Avatar, AVATAR_SIZE} from 'Components/Avatar'; import * as Icon from 'Components/Icon'; import {useKoSubscribableChildren} from 'Util/ComponentUtil'; import {handleKeyDown} from 'Util/KeyboardUtil'; import {User} from '../../../../entity/User'; type MentionSuggestionsItemProps = { isSelected: boolean; onMouseEnter: () => void; onSuggestionClick: () => void; suggestion: User; }; const MentionSuggestionsItemComponent: React.ForwardRefRenderFunction = ( {suggestion, onSuggestionClick, onMouseEnter, isSelected}, ref, ) => { const {name, expirationRemainingText, isTemporaryGuest, isExternal, isDirectGuest} = useKoSubscribableChildren( suggestion, ['name', 'expirationRemainingText', 'isTemporaryGuest', 'isExternal', 'isDirectGuest'], ); const onClick = (event: React.UIEvent) => { event.preventDefault(); onSuggestionClick(); }; return (
handleKeyDown(e, () => onClick(e))} onMouseEnter={onMouseEnter} className={cx('mention-suggestion-list__item', {'mention-suggestion-list__item--highlighted': isSelected})} data-uie-name="item-mention-suggestion" data-uie-value={suggestion.id} data-uie-selected={isSelected} ref={ref} >
{name}
{isTemporaryGuest ? (
{expirationRemainingText}
) : (
{suggestion.handle}
)} {isExternal && ( )} {suggestion.isFederated && ( )} {isDirectGuest && !suggestion.isFederated && ( )}
); }; const MentionSuggestionsItem = forwardRef(MentionSuggestionsItemComponent); export {MentionSuggestionsItem};