// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React, { useEffect, useState } from 'react'; import type { Props as AvatarProps } from '../Avatar'; import { Avatar, AvatarSize, AvatarBlur } from '../Avatar'; import { ContactName } from './ContactName'; import { About } from './About'; import { GroupDescription } from './GroupDescription'; import { SharedGroupNames } from '../SharedGroupNames'; import type { LocalizerType, ThemeType } from '../../types/Util'; import type { HasStories } from '../../types/Stories'; import type { ViewUserStoriesActionCreatorType } from '../../state/ducks/stories'; import { StoryViewModeType } from '../../types/Stories'; import { ConfirmationDialog } from '../ConfirmationDialog'; import { shouldBlurAvatar } from '../../util/shouldBlurAvatar'; import { openLinkInWebBrowser } from '../../util/openLinkInWebBrowser'; import { Button, ButtonVariant } from '../Button'; import { SafetyTipsModal } from '../SafetyTipsModal'; export type Props = { about?: string; acceptedMessageRequest?: boolean; groupDescription?: string; hasStories?: HasStories; id: string; i18n: LocalizerType; isMe: boolean; isSignalConversation?: boolean; membersCount?: number; phoneNumber?: string; sharedGroupNames?: ReadonlyArray; unblurAvatar: (conversationId: string) => void; unblurredAvatarPath?: string; updateSharedGroups: (conversationId: string) => unknown; theme: ThemeType; viewUserStories: ViewUserStoriesActionCreatorType; toggleAboutContactModal: (conversationId: string) => unknown; } & Omit; const renderMembershipRow = ({ acceptedMessageRequest, conversationType, i18n, isMe, onClickMessageRequestWarning, onToggleSafetyTips, phoneNumber, sharedGroupNames, }: Pick< Props, | 'acceptedMessageRequest' | 'conversationType' | 'i18n' | 'isMe' | 'phoneNumber' > & Required> & { onClickMessageRequestWarning: () => void; onToggleSafetyTips: (showSafetyTips: boolean) => void; }) => { if (conversationType !== 'direct') { return null; } if (isMe) { return (
{i18n('icu:noteToSelfHero')}
); } const safetyTipsButton = (
); if (sharedGroupNames.length > 0) { return (
{safetyTipsButton}
); } if (acceptedMessageRequest) { if (phoneNumber) { return null; } return (
{i18n('icu:no-groups-in-common')} {safetyTipsButton}
); } return (
{i18n('icu:no-groups-in-common-warning')}  
{safetyTipsButton}
); }; export function ConversationHero({ i18n, about, acceptedMessageRequest, avatarPath, badge, color, conversationType, groupDescription, hasStories, id, isMe, isSignalConversation, membersCount, sharedGroupNames = [], phoneNumber, profileName, theme, title, unblurAvatar, unblurredAvatarPath, updateSharedGroups, viewUserStories, toggleAboutContactModal, }: Props): JSX.Element { const [isShowingSafetyTips, setIsShowingSafetyTips] = useState(false); const [isShowingMessageRequestWarning, setIsShowingMessageRequestWarning] = useState(false); const closeMessageRequestWarning = () => { setIsShowingMessageRequestWarning(false); }; useEffect(() => { // Kick off the expensive hydration of the current sharedGroupNames updateSharedGroups(id); }, [id, updateSharedGroups]); let avatarBlur: AvatarBlur = AvatarBlur.NoBlur; let avatarOnClick: undefined | (() => void); if ( shouldBlurAvatar({ acceptedMessageRequest, avatarPath, isMe, sharedGroupNames, unblurredAvatarPath, }) ) { avatarBlur = AvatarBlur.BlurPictureWithClickToView; avatarOnClick = () => unblurAvatar(id); } else if (hasStories) { avatarOnClick = () => { viewUserStories({ conversationId: id, storyViewMode: StoryViewModeType.User, }); }; } let titleElem: JSX.Element | undefined; if (isMe) { titleElem = <>{i18n('icu:noteToSelf')}; } else if (isSignalConversation || conversationType !== 'direct') { titleElem = ( ); } else if (title) { titleElem = ( ); } /* eslint-disable no-nested-ternary */ return ( <>

{titleElem} {isMe && }

{about && !isMe && (
)} {!isMe ? (
{groupDescription ? ( ) : membersCount != null ? ( i18n('icu:ConversationHero--members', { count: membersCount }) ) : null}
) : null} {!isSignalConversation && renderMembershipRow({ acceptedMessageRequest, conversationType, i18n, isMe, onClickMessageRequestWarning() { setIsShowingMessageRequestWarning(true); }, onToggleSafetyTips(showSafetyTips: boolean) { setIsShowingSafetyTips(showSafetyTips); }, phoneNumber, sharedGroupNames, })} {!isSignalConversation && (
{i18n('icu:messageHistoryUnsynced')}
)}
{isShowingMessageRequestWarning && ( { openLinkInWebBrowser( 'https://support.signal.org/hc/articles/360007459591' ); closeMessageRequestWarning(); }, }, ]} > {i18n('icu:MessageRequestWarning__dialog__details')} )} {isShowingSafetyTips && ( { setIsShowingSafetyTips(false); }} /> )} ); /* eslint-enable no-nested-ternary */ }