// Copyright 2019 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { FunctionComponent, ReactNode } from 'react'; import React, { useCallback } from 'react'; import { ContactName } from '../conversation/ContactName'; import type { BodyRangesForDisplayType } from '../../types/BodyRange'; import { processBodyRangesForSearchResult } from '../../types/BodyRange'; import type { LocalizerType, ThemeType } from '../../types/Util'; import { BaseConversationListItem } from './BaseConversationListItem'; import type { ConversationType, ShowConversationType, } from '../../state/ducks/conversations'; import type { PreferredBadgeSelectorType } from '../../state/selectors/badges'; import { Intl } from '../Intl'; import { MessageTextRenderer, RenderLocation, } from '../conversation/MessageTextRenderer'; export type PropsDataType = { isSelected?: boolean; isSearchingInConversation?: boolean; id: string; conversationId: string; sentAt?: number; snippet: string; body: string; bodyRanges: BodyRangesForDisplayType; from: Pick< ConversationType, | 'acceptedMessageRequest' | 'avatarPath' | 'badges' | 'color' | 'isMe' | 'phoneNumber' | 'profileName' | 'sharedGroupNames' | 'title' | 'type' | 'unblurredAvatarPath' >; to: Pick< ConversationType, 'isMe' | 'phoneNumber' | 'profileName' | 'title' | 'type' >; }; type PropsHousekeepingType = { getPreferredBadge: PreferredBadgeSelectorType; i18n: LocalizerType; showConversation: ShowConversationType; theme: ThemeType; }; export type PropsType = PropsDataType & PropsHousekeepingType; const renderPerson = ( i18n: LocalizerType, person: Readonly<{ isMe?: boolean; title: string; }> ): ReactNode => person.isMe ? i18n('icu:you') : ; export const MessageSearchResult: FunctionComponent = React.memo( function MessageSearchResult({ body, bodyRanges, conversationId, from, getPreferredBadge, i18n, id, sentAt, showConversation, snippet, theme, to, }) { const onClickItem = useCallback(() => { showConversation({ conversationId, messageId: id }); }, [showConversation, conversationId, id]); if (!from || !to) { return
; } const isNoteToSelf = from.isMe && to.isMe; let headerName: ReactNode; if (isNoteToSelf) { headerName = i18n('icu:noteToSelf'); } else if (from.isMe) { if (to.type === 'group') { headerName = ( ); } else { headerName = ( ); } } else { // eslint-disable-next-line no-lonely-if if (to.type === 'group') { headerName = ( ); } else { headerName = ( ); } } const { cleanedSnippet, bodyRanges: displayBodyRanges } = processBodyRangesForSearchResult({ snippet, body, bodyRanges }); const messageText = ( null} renderLocation={RenderLocation.SearchResult} textLength={cleanedSnippet.length} /> ); return ( ); } );