// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ReactNode } from 'react'; import React, { useState } from 'react'; import { Avatar, AvatarSize } from '../../Avatar'; import { AvatarLightbox } from '../../AvatarLightbox'; import type { ConversationType } from '../../../state/ducks/conversations'; import { GroupDescription } from '../GroupDescription'; import { About } from '../About'; import type { LocalizerType, ThemeType } from '../../../types/Util'; import { assertDev } from '../../../util/assert'; import { BadgeDialog } from '../../BadgeDialog'; import type { BadgeType } from '../../../badges/types'; import { UserText } from '../../UserText'; import { isInSystemContacts } from '../../../util/isInSystemContacts'; import { InContactsIcon } from '../../InContactsIcon'; export type Props = { areWeASubscriber: boolean; badges?: ReadonlyArray; canEdit: boolean; conversation: ConversationType; i18n: LocalizerType; isGroup: boolean; isMe: boolean; membersCount: number | null; startEditing: (isGroupTitle: boolean) => void; toggleAboutContactModal: (contactId: string) => void; theme: ThemeType; }; enum ConversationDetailsHeaderActiveModal { ShowingAvatar, ShowingBadges, } export function ConversationDetailsHeader({ areWeASubscriber, badges, canEdit, conversation, i18n, isGroup, isMe, membersCount, startEditing, toggleAboutContactModal, theme, }: Props): JSX.Element { const [activeModal, setActiveModal] = useState< undefined | ConversationDetailsHeaderActiveModal >(); let preferredBadge: undefined | BadgeType; let subtitle: ReactNode; let hasNestedButton = false; if (isGroup) { if (conversation.groupDescription) { subtitle = ( ); hasNestedButton = true; } else if (canEdit) { subtitle = i18n('icu:ConversationDetailsHeader--add-group-description'); } else { subtitle = i18n('icu:ConversationDetailsHeader--members', { number: membersCount ?? 0, }); } } else if (!isMe) { subtitle = (
); preferredBadge = badges?.[0]; } const avatar = ( { setActiveModal(ConversationDetailsHeaderActiveModal.ShowingAvatar); }} onClickBadge={() => { setActiveModal(ConversationDetailsHeaderActiveModal.ShowingBadges); }} sharedGroupNames={[]} theme={theme} /> ); let modal: ReactNode; switch (activeModal) { case ConversationDetailsHeaderActiveModal.ShowingAvatar: modal = ( { setActiveModal(undefined); }} /> ); break; case ConversationDetailsHeaderActiveModal.ShowingBadges: modal = ( { setActiveModal(undefined); }} title={conversation.title} /> ); break; default: modal = null; break; } if (canEdit) { assertDev(isGroup, 'Only groups support editable title'); return (
{modal} {avatar} {hasNestedButton ? (
{subtitle}
) : ( )}
); } let title: JSX.Element; if (isMe) { title = (
{i18n('icu:noteToSelf')}
); } else if (isGroup) { title = (
); } else { title = ( ); } return (
{modal} {avatar} {title}
{subtitle}
); }