// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import type { LocalizerType } from '../types/Util'; import { CallMode } from '../types/Calling'; export type PropsType = { callMode: CallMode; i18n: LocalizerType; isAdhocJoinRequestPending?: boolean; groupMemberCount?: number; participantCount: number; toggleParticipants: () => void; }; export function CallParticipantCount({ callMode, i18n, isAdhocJoinRequestPending, groupMemberCount, participantCount, toggleParticipants, }: PropsType): JSX.Element { const isToggleVisible = Boolean(participantCount) || callMode === CallMode.Adhoc; const count = participantCount || groupMemberCount || 1; let innerText: string | undefined; if (callMode === CallMode.Adhoc) { if (isAdhocJoinRequestPending) { innerText = i18n( 'icu:CallControls__InfoDisplay--adhoc-join-request-pending' ); } else if (!participantCount) { innerText = i18n('icu:CallControls__InfoDisplay--adhoc-call'); } } if (!innerText) { innerText = i18n('icu:CallControls__InfoDisplay--participants', { count: String(count), }); } // Call not started, can't click to show participants if (!isToggleVisible) { return ( {innerText} ); } return ( ); }