| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  | // Copyright 2024 Signal Messenger, LLC
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  | import React, { type ReactNode, useCallback, useEffect, useMemo } from 'react'; | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  | import type { ConversationType } from '../../state/ducks/conversations'; | 
					
						
							|  |  |  | import type { LocalizerType } from '../../types/Util'; | 
					
						
							|  |  |  | import { isInSystemContacts } from '../../util/isInSystemContacts'; | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  | import { Avatar, AvatarBlur, AvatarSize } from '../Avatar'; | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  | import { Modal } from '../Modal'; | 
					
						
							|  |  |  | import { UserText } from '../UserText'; | 
					
						
							|  |  |  | import { SharedGroupNames } from '../SharedGroupNames'; | 
					
						
							|  |  |  | import { About } from './About'; | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  | import { I18n } from '../I18n'; | 
					
						
							| 
									
										
										
										
											2024-06-20 14:39:40 -04:00
										 |  |  | import { canHaveNicknameAndNote } from '../../util/nicknames'; | 
					
						
							| 
									
										
										
										
											2024-04-03 15:41:13 -07:00
										 |  |  | import { Tooltip, TooltipPlacement } from '../Tooltip'; | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | function muted(parts: Array<string | JSX.Element>) { | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <span className="AboutContactModal__TitleWithoutNickname">{parts}</span> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export type PropsType = Readonly<{ | 
					
						
							|  |  |  |   i18n: LocalizerType; | 
					
						
							|  |  |  |   onClose: () => void; | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  |   onOpenNotePreviewModal: () => void; | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   conversation: ConversationType; | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |   fromOrAddedByTrustedContact?: boolean; | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   isSignalConnection: boolean; | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |   pendingAvatarDownload?: boolean; | 
					
						
							|  |  |  |   startAvatarDownload?: (id: string) => unknown; | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   toggleSignalConnectionsModal: () => void; | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |   toggleSafetyNumberModal: (id: string) => void; | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |   toggleProfileNameWarningModal: () => void; | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   updateSharedGroups: (id: string) => void; | 
					
						
							|  |  |  | }>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export function AboutContactModal({ | 
					
						
							|  |  |  |   i18n, | 
					
						
							|  |  |  |   conversation, | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |   fromOrAddedByTrustedContact, | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   isSignalConnection, | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |   pendingAvatarDownload, | 
					
						
							|  |  |  |   startAvatarDownload, | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   toggleSignalConnectionsModal, | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |   toggleSafetyNumberModal, | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |   toggleProfileNameWarningModal, | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   updateSharedGroups, | 
					
						
							|  |  |  |   onClose, | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  |   onOpenNotePreviewModal, | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  | }: PropsType): JSX.Element { | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |   const { avatarUrl, hasAvatar, isMe } = conversation; | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     // Kick off the expensive hydration of the current sharedGroupNames
 | 
					
						
							|  |  |  |     updateSharedGroups(conversation.id); | 
					
						
							|  |  |  |   }, [conversation.id, updateSharedGroups]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |   // If hasAvatar is true, we show the download button instead of blur
 | 
					
						
							|  |  |  |   const enableClickToLoad = !avatarUrl && !isMe && hasAvatar; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const avatarBlur = enableClickToLoad | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |     ? AvatarBlur.BlurPictureWithClickToView | 
					
						
							|  |  |  |     : AvatarBlur.NoBlur; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |   const avatarOnClick = useMemo(() => { | 
					
						
							|  |  |  |     if (!enableClickToLoad) { | 
					
						
							|  |  |  |       return undefined; | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |     return () => { | 
					
						
							|  |  |  |       if (!pendingAvatarDownload && startAvatarDownload) { | 
					
						
							|  |  |  |         startAvatarDownload(conversation.id); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }, [ | 
					
						
							|  |  |  |     conversation.id, | 
					
						
							|  |  |  |     startAvatarDownload, | 
					
						
							|  |  |  |     enableClickToLoad, | 
					
						
							|  |  |  |     pendingAvatarDownload, | 
					
						
							|  |  |  |   ]); | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   const onSignalConnectionClick = useCallback( | 
					
						
							|  |  |  |     (ev: React.MouseEvent) => { | 
					
						
							|  |  |  |       ev.preventDefault(); | 
					
						
							|  |  |  |       toggleSignalConnectionsModal(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     [toggleSignalConnectionsModal] | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |   const onVerifiedClick = useCallback( | 
					
						
							|  |  |  |     (ev: React.MouseEvent) => { | 
					
						
							|  |  |  |       ev.preventDefault(); | 
					
						
							|  |  |  |       toggleSafetyNumberModal(conversation.id); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     [toggleSafetyNumberModal, conversation.id] | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |   const onProfileNameWarningClick = useCallback( | 
					
						
							|  |  |  |     (ev: React.MouseEvent) => { | 
					
						
							|  |  |  |       ev.preventDefault(); | 
					
						
							|  |  |  |       toggleProfileNameWarningModal(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     [toggleProfileNameWarningModal] | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |   let statusRow: JSX.Element | undefined; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  |   if (isMe) { | 
					
						
							|  |  |  |     // No status for ourselves
 | 
					
						
							|  |  |  |   } else if (conversation.isBlocked) { | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |     statusRow = ( | 
					
						
							|  |  |  |       <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |         <i className="AboutContactModal__row__icon AboutContactModal__row__icon--blocked" /> | 
					
						
							|  |  |  |         {i18n('icu:AboutContactModal__blocked', { | 
					
						
							|  |  |  |           name: conversation.title, | 
					
						
							|  |  |  |         })} | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } else if (!conversation.acceptedMessageRequest) { | 
					
						
							|  |  |  |     statusRow = ( | 
					
						
							|  |  |  |       <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |         <i className="AboutContactModal__row__icon AboutContactModal__row__icon--message-request" /> | 
					
						
							|  |  |  |         {i18n('icu:AboutContactModal__message-request')} | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } else if (!conversation.hasMessages && !conversation.profileSharing) { | 
					
						
							|  |  |  |     statusRow = ( | 
					
						
							|  |  |  |       <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |         <i className="AboutContactModal__row__icon AboutContactModal__row__icon--no-dms" /> | 
					
						
							|  |  |  |         {i18n('icu:AboutContactModal__no-dms', { | 
					
						
							|  |  |  |           name: conversation.title, | 
					
						
							|  |  |  |         })} | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |   return ( | 
					
						
							|  |  |  |     <Modal | 
					
						
							|  |  |  |       key="main" | 
					
						
							|  |  |  |       modalName="AboutContactModal" | 
					
						
							|  |  |  |       moduleClassName="AboutContactModal" | 
					
						
							|  |  |  |       hasXButton | 
					
						
							|  |  |  |       i18n={i18n} | 
					
						
							|  |  |  |       onClose={onClose} | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       <div className="AboutContactModal__row AboutContactModal__row--centered"> | 
					
						
							|  |  |  |         <Avatar | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |           avatarPlaceholderGradient={conversation.avatarPlaceholderGradient} | 
					
						
							| 
									
										
										
										
											2024-07-11 12:44:09 -07:00
										 |  |  |           avatarUrl={conversation.avatarUrl} | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |           blur={avatarBlur} | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |           onClick={avatarOnClick} | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |           badge={undefined} | 
					
						
							|  |  |  |           color={conversation.color} | 
					
						
							|  |  |  |           conversationType="direct" | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |           hasAvatar={conversation.hasAvatar} | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |           i18n={i18n} | 
					
						
							| 
									
										
										
										
											2025-03-26 13:27:04 -07:00
										 |  |  |           loading={pendingAvatarDownload && !conversation.avatarUrl} | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |           profileName={conversation.profileName} | 
					
						
							|  |  |  |           sharedGroupNames={[]} | 
					
						
							|  |  |  |           size={AvatarSize.TWO_HUNDRED_SIXTEEN} | 
					
						
							|  |  |  |           title={conversation.title} | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |         <h3 className="AboutContactModal__title"> | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  |           {isMe | 
					
						
							|  |  |  |             ? i18n('icu:AboutContactModal__title--myself') | 
					
						
							|  |  |  |             : i18n('icu:AboutContactModal__title')} | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |         </h3> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |         <i className="AboutContactModal__row__icon AboutContactModal__row__icon--profile" /> | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-28 15:28:50 -07:00
										 |  |  |         {canHaveNicknameAndNote(conversation) && | 
					
						
							| 
									
										
										
										
											2024-04-03 15:41:13 -07:00
										 |  |  |         (conversation.nicknameGivenName || conversation.nicknameFamilyName) && | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  |         conversation.titleNoNickname ? ( | 
					
						
							|  |  |  |           <span> | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |             <I18n | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               id="icu:AboutContactModal__TitleAndTitleWithoutNickname" | 
					
						
							|  |  |  |               components={{ | 
					
						
							|  |  |  |                 nickname: <UserText text={conversation.title} />, | 
					
						
							|  |  |  |                 titleNoNickname: ( | 
					
						
							| 
									
										
										
										
											2024-04-03 15:41:13 -07:00
										 |  |  |                   <Tooltip | 
					
						
							|  |  |  |                     className="AboutContactModal__TitleWithoutNickname__Tooltip" | 
					
						
							|  |  |  |                     direction={TooltipPlacement.Top} | 
					
						
							|  |  |  |                     content={ | 
					
						
							| 
									
										
										
										
											2024-05-15 14:48:02 -07:00
										 |  |  |                       <I18n | 
					
						
							| 
									
										
										
										
											2024-04-03 15:41:13 -07:00
										 |  |  |                         i18n={i18n} | 
					
						
							|  |  |  |                         id="icu:AboutContactModal__TitleWithoutNickname__Tooltip" | 
					
						
							|  |  |  |                         components={{ | 
					
						
							|  |  |  |                           title: ( | 
					
						
							|  |  |  |                             <UserText text={conversation.titleNoNickname} /> | 
					
						
							|  |  |  |                           ), | 
					
						
							|  |  |  |                         }} | 
					
						
							|  |  |  |                       /> | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     delay={0} | 
					
						
							|  |  |  |                   > | 
					
						
							|  |  |  |                     <UserText text={conversation.titleNoNickname} /> | 
					
						
							|  |  |  |                   </Tooltip> | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  |                 ), | 
					
						
							|  |  |  |                 muted, | 
					
						
							|  |  |  |               }} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           </span> | 
					
						
							|  |  |  |         ) : ( | 
					
						
							|  |  |  |           <UserText text={conversation.title} /> | 
					
						
							|  |  |  |         )} | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |       </div> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-18 12:35:09 -05:00
										 |  |  |       {!isMe && !fromOrAddedByTrustedContact ? ( | 
					
						
							|  |  |  |         <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |           <i | 
					
						
							|  |  |  |             className={`AboutContactModal__row__icon AboutContactModal__row__icon--${conversation.type === 'group' ? 'group' : 'direct'}-question`} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |           <button | 
					
						
							|  |  |  |             type="button" | 
					
						
							|  |  |  |             className="AboutContactModal__button" | 
					
						
							|  |  |  |             onClick={onProfileNameWarningClick} | 
					
						
							|  |  |  |           > | 
					
						
							|  |  |  |             <I18n | 
					
						
							|  |  |  |               components={{ | 
					
						
							|  |  |  |                 // eslint-disable-next-line react/no-unstable-nested-components
 | 
					
						
							|  |  |  |                 clickable: (parts: ReactNode) => <>{parts}</>, | 
					
						
							|  |  |  |               }} | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               id={ | 
					
						
							|  |  |  |                 conversation.type === 'group' | 
					
						
							|  |  |  |                   ? 'icu:ConversationHero--group-names' | 
					
						
							|  |  |  |                   : 'icu:ConversationHero--profile-names' | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           </button> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       ) : null} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  |       {!isMe && conversation.isVerified ? ( | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |         <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |           <i className="AboutContactModal__row__icon AboutContactModal__row__icon--verified" /> | 
					
						
							|  |  |  |           <button | 
					
						
							|  |  |  |             type="button" | 
					
						
							|  |  |  |             className="AboutContactModal__verified" | 
					
						
							|  |  |  |             onClick={onVerifiedClick} | 
					
						
							|  |  |  |           > | 
					
						
							|  |  |  |             {i18n('icu:AboutContactModal__verified')} | 
					
						
							|  |  |  |           </button> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       ) : null} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  |       {!isMe && conversation.about ? ( | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |         <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |           <i className="AboutContactModal__row__icon AboutContactModal__row__icon--about" /> | 
					
						
							|  |  |  |           <About | 
					
						
							|  |  |  |             className="AboutContactModal__about" | 
					
						
							|  |  |  |             text={conversation.about} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       ) : null} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  |       {!isMe && isSignalConnection ? ( | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |         <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |           <i className="AboutContactModal__row__icon AboutContactModal__row__icon--connections" /> | 
					
						
							|  |  |  |           <button | 
					
						
							|  |  |  |             type="button" | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  |             className="AboutContactModal__button" | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |             onClick={onSignalConnectionClick} | 
					
						
							|  |  |  |           > | 
					
						
							|  |  |  |             {i18n('icu:AboutContactModal__signal-connection')} | 
					
						
							|  |  |  |           </button> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       ) : null} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  |       {!isMe && isInSystemContacts(conversation) ? ( | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |         <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |           <i className="AboutContactModal__row__icon AboutContactModal__row__icon--person" /> | 
					
						
							|  |  |  |           {i18n('icu:AboutContactModal__system-contact', { | 
					
						
							| 
									
										
										
										
											2024-03-18 17:46:47 -07:00
										 |  |  |             name: | 
					
						
							|  |  |  |               conversation.systemGivenName || | 
					
						
							|  |  |  |               conversation.firstName || | 
					
						
							|  |  |  |               conversation.title, | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |           })} | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       ) : null} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       {conversation.phoneNumber ? ( | 
					
						
							|  |  |  |         <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |           <i className="AboutContactModal__row__icon AboutContactModal__row__icon--phone" /> | 
					
						
							|  |  |  |           <UserText text={conversation.phoneNumber} /> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       ) : null} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  |       {!isMe && ( | 
					
						
							|  |  |  |         <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |           <i className="AboutContactModal__row__icon AboutContactModal__row__icon--group" /> | 
					
						
							|  |  |  |           <div> | 
					
						
							|  |  |  |             <SharedGroupNames | 
					
						
							|  |  |  |               i18n={i18n} | 
					
						
							|  |  |  |               sharedGroupNames={conversation.sharedGroupNames || []} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-02-16 14:16:13 -08:00
										 |  |  |       )} | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-20 14:39:40 -04:00
										 |  |  |       {conversation.note && ( | 
					
						
							| 
									
										
										
										
											2024-03-26 12:48:33 -07:00
										 |  |  |         <div className="AboutContactModal__row"> | 
					
						
							|  |  |  |           <i className="AboutContactModal__row__icon AboutContactModal__row__icon--note" /> | 
					
						
							|  |  |  |           <button | 
					
						
							|  |  |  |             type="button" | 
					
						
							|  |  |  |             className="AboutContactModal__button" | 
					
						
							|  |  |  |             onClick={onOpenNotePreviewModal} | 
					
						
							|  |  |  |           > | 
					
						
							|  |  |  |             <div className="AboutContactModal__OneLineEllipsis"> | 
					
						
							|  |  |  |               <UserText text={conversation.note} /> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |           </button> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       )} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-14 12:29:17 -08:00
										 |  |  |       {statusRow} | 
					
						
							| 
									
										
										
										
											2024-02-05 18:13:13 -08:00
										 |  |  |     </Modal> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | } |