// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { memoize, noop } from 'lodash'; import { select } from '@storybook/addon-knobs'; import type { PropsType } from './GroupCallRemoteParticipant'; import { GroupCallRemoteParticipant } from './GroupCallRemoteParticipant'; import { getDefaultConversation } from '../test-both/helpers/getDefaultConversation'; import { FRAME_BUFFER_SIZE } from '../calling/constants'; import { setupI18n } from '../util/setupI18n'; import { generateAci } from '../types/ServiceId'; import enMessages from '../../_locales/en/messages.json'; const i18n = setupI18n('en', enMessages); type OverridePropsType = { audioLevel?: number; remoteParticipantsCount?: number; } & ( | { isInPip: true; } | { isInPip: false; height: number; left: number; top: number; width: number; } ); const getFrameBuffer = memoize(() => Buffer.alloc(FRAME_BUFFER_SIZE)); const createProps = ( overrideProps: OverridePropsType, { isBlocked = false, hasRemoteAudio = false, presenting = false, }: { isBlocked?: boolean; hasRemoteAudio?: boolean; presenting?: boolean; } = {} ): PropsType => ({ getFrameBuffer, // eslint-disable-next-line @typescript-eslint/no-explicit-any getGroupCallVideoFrameSource: noop as any, i18n, audioLevel: 0, remoteParticipant: { demuxId: 123, hasRemoteAudio, hasRemoteVideo: true, presenting, sharingScreen: false, videoAspectRatio: 1.3, ...getDefaultConversation({ isBlocked: Boolean(isBlocked), title: 'Pablo Diego José Francisco de Paula Juan Nepomuceno María de los Remedios Cipriano de la Santísima Trinidad Ruiz y Picasso', serviceId: generateAci(), }), }, remoteParticipantsCount: 1, isActiveSpeakerInSpeakerView: false, ...overrideProps, }); export default { title: 'Components/GroupCallRemoteParticipant', }; export function Default(): JSX.Element { return ( ); } export function Speaking(): JSX.Element { function createSpeakingProps( index: number, remoteParticipantsCount: number, presenting: boolean ) { return createProps( { isInPip: false, height: 120, left: (120 + 10) * index, top: 0, width: 120, audioLevel: select('audioLevel', [0, 0.5, 1], 0.5), remoteParticipantsCount, }, { hasRemoteAudio: true, presenting } ); } return ( <> ); } export function IsInPip(): JSX.Element { return ( ); } IsInPip.story = { name: 'isInPip', }; export function Blocked(): JSX.Element { return ( ); }