// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only /* eslint-disable react/no-array-index-key */ import React, { useContext } from 'react'; import { createPortal } from 'react-dom'; import FocusTrap from 'focus-trap-react'; import { Avatar, AvatarSize } from './Avatar'; import { ContactName } from './conversation/ContactName'; import { InContactsIcon } from './InContactsIcon'; import type { LocalizerType } from '../types/Util'; import type { ServiceIdString } from '../types/ServiceId'; import { sortByTitle } from '../util/sortByTitle'; import type { ConversationType } from '../state/ducks/conversations'; import { isInSystemContacts } from '../util/isInSystemContacts'; import { ModalContainerContext } from './ModalHost'; type ParticipantType = ConversationType & { hasRemoteAudio?: boolean; hasRemoteVideo?: boolean; presenting?: boolean; }; export type PropsType = { readonly i18n: LocalizerType; readonly onClose: () => void; readonly ourServiceId: ServiceIdString | undefined; readonly participants: Array; }; export const CallingParticipantsList = React.memo( function CallingParticipantsListInner({ i18n, onClose, ourServiceId, participants, }: PropsType) { const [root, setRoot] = React.useState(null); const modalContainer = useContext(ModalContainerContext) ?? document.body; const sortedParticipants = React.useMemo>( () => sortByTitle(participants), [participants] ); React.useEffect(() => { const div = document.createElement('div'); modalContainer.appendChild(div); setRoot(div); return () => { modalContainer.removeChild(div); setRoot(null); }; }, [modalContainer]); const handleCancel = React.useCallback( (e: React.MouseEvent) => { if (e.target === e.currentTarget) { onClose(); } }, [onClose] ); if (!root) { return null; } return createPortal(
{!participants.length && i18n('icu:calling__in-this-call--zero')} {participants.length === 1 && i18n('icu:calling__in-this-call--one')} {participants.length > 1 && i18n('icu:calling__in-this-call--many', { people: String(participants.length), })}
    {sortedParticipants.map( (participant: ParticipantType, index: number) => (
  • {ourServiceId && participant.serviceId === ourServiceId ? ( {i18n('icu:you')} ) : ( <> {isInSystemContacts(participant) ? ( {' '} ) : null} )}
    {participant.hasRemoteAudio === false ? ( ) : null} {participant.hasRemoteVideo === false ? ( ) : null} {participant.presenting ? ( ) : null}
  • ) )}
, root ); } );