// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React, { useRef, useEffect } from 'react'; import classNames from 'classnames'; import type { SetRendererCanvasType } from '../state/ducks/calling.preload.ts'; import type { ConversationType } from '../state/ducks/conversations.preload.ts'; import type { LocalizerType } from '../types/Util.std.ts'; import { AvatarColors } from '../types/Colors.std.ts'; import { Avatar, AvatarSize } from './Avatar.dom.tsx'; import { CallBackgroundBlur } from './CallBackgroundBlur.dom.tsx'; import type { SizeCallbackType } from '../calling/VideoSupport.preload.ts'; type PropsType = { conversation: ConversationType; hasRemoteVideo: boolean; i18n: LocalizerType; isReconnecting: boolean; handleSize: SizeCallbackType; setRendererCanvas: (_: SetRendererCanvasType) => void; }; export function DirectCallRemoteParticipant({ conversation, hasRemoteVideo, i18n, isReconnecting, setRendererCanvas, handleSize, }: PropsType): React.JSX.Element { const remoteVideoRef = useRef(null); useEffect(() => { setRendererCanvas({ element: remoteVideoRef, sizeCallback: handleSize }); return () => { setRendererCanvas({ element: undefined, sizeCallback: undefined }); }; }, [handleSize, setRendererCanvas]); return hasRemoteVideo ? ( ) : ( renderAvatar(i18n, conversation) ); } function renderAvatar( i18n: LocalizerType, { avatarPlaceholderGradient, avatarUrl, color, hasAvatar, phoneNumber, profileName, title, }: Pick< ConversationType, | 'avatarPlaceholderGradient' | 'acceptedMessageRequest' | 'avatarUrl' | 'color' | 'hasAvatar' | 'isMe' | 'phoneNumber' | 'profileName' | 'title' > ): React.JSX.Element { return (
); }