// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React, { useCallback } from 'react'; import { BaseConversationListItem } from './BaseConversationListItem'; import type { LocalizerType } from '../../types/Util'; import type { LookupConversationWithoutUuidActionsType } from '../../util/lookupConversationWithoutUuid'; import type { ShowConversationType } from '../../state/ducks/conversations'; type PropsData = { username: string; isFetchingUsername: boolean; }; type PropsHousekeeping = { i18n: LocalizerType; showConversation: ShowConversationType; } & LookupConversationWithoutUuidActionsType; export type Props = PropsData & PropsHousekeeping; export function UsernameSearchResultListItem({ i18n, isFetchingUsername, lookupConversationWithoutUuid, username, showUserNotFoundModal, setIsFetchingUUID, showConversation, }: Props): JSX.Element { const usernameText = i18n('at-username', { username }); const boundOnClick = useCallback(async () => { if (isFetchingUsername) { return; } const conversationId = await lookupConversationWithoutUuid({ showUserNotFoundModal, setIsFetchingUUID, type: 'username', username, }); if (conversationId !== undefined) { showConversation({ conversationId }); } }, [ isFetchingUsername, lookupConversationWithoutUuid, setIsFetchingUUID, showConversation, showUserNotFoundModal, username, ]); return ( ); }