// Copyright 2022 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import type { ConversationType, ShowConversationType, } from '../../../state/ducks/conversations'; import type { LocalizerType } from '../../../types/Util'; import { Avatar, AvatarSize } from '../../Avatar'; import { ConversationDetailsIcon, IconType } from './ConversationDetailsIcon'; import { PanelRow } from './PanelRow'; import { PanelSection } from './PanelSection'; type Props = { contactId: string; i18n: LocalizerType; groupsInCommon: ReadonlyArray; toggleAddUserToAnotherGroupModal: (contactId?: string) => void; showConversation: ShowConversationType; }; export function ConversationDetailsGroups({ contactId, i18n, groupsInCommon, toggleAddUserToAnotherGroupModal, showConversation, }: Props): JSX.Element { const [showAllGroups, setShowAllGroups] = React.useState(false); const maxShownGroupCount = 5; const isMoreThanMaxShown = groupsInCommon.length - maxShownGroupCount > 1; const groupsToShow = showAllGroups ? groupsInCommon.length : maxShownGroupCount; return ( 0 ? i18n('icu:ConversationDetailsGroups--title', { count: groupsInCommon.length, }) : i18n( 'icu:ConversationDetailsGroups--title--with-zero-groups-in-common' ) } > } label={i18n('icu:ConversationDetailsGroups--add-to-group')} onClick={() => toggleAddUserToAnotherGroupModal(contactId)} /> {groupsInCommon.slice(0, groupsToShow).map(group => ( showConversation({ conversationId: group.id, switchToAssociatedView: true, }) } icon={ } label={group.title} /> ))} {!showAllGroups && isMoreThanMaxShown && ( } onClick={() => setShowAllGroups(true)} label={i18n('icu:ConversationDetailsGroups--show-all')} /> )} ); }