signal-desktop/ts/components/GroupCallRemoteParticipant.stories.tsx

239 lines
5.4 KiB
TypeScript
Raw Normal View History

2023-01-03 19:55:46 +00:00
// Copyright 2020 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import * as React from 'react';
import { memoize } from 'lodash';
import type { Meta } from '@storybook/react';
import type { PropsType } from './GroupCallRemoteParticipant';
import { GroupCallRemoteParticipant } from './GroupCallRemoteParticipant';
import { getDefaultConversation } from '../test-both/helpers/getDefaultConversation';
import { FRAME_BUFFER_SIZE } from '../calling/constants';
2021-09-18 00:30:08 +00:00
import { setupI18n } from '../util/setupI18n';
import { generateAci } from '../types/ServiceId';
import enMessages from '../../_locales/en/messages.json';
import type { CallingImageDataCache } from './CallManager';
import { MINUTE } from '../util/durations';
const i18n = setupI18n('en', enMessages);
2022-05-19 03:28:51 +00:00
type OverridePropsType = {
audioLevel?: number;
remoteParticipantsCount?: number;
2022-05-19 03:28:51 +00:00
} & (
| {
isInPip: true;
}
| {
isInPip: false;
height: number;
left: number;
top: number;
width: number;
2022-05-19 03:28:51 +00:00
}
);
const getFrameBuffer = memoize(() => Buffer.alloc(FRAME_BUFFER_SIZE));
const createProps = (
overrideProps: OverridePropsType,
2022-05-19 03:28:51 +00:00
{
2024-01-23 19:08:21 +00:00
addedTime,
2022-05-19 03:28:51 +00:00
isBlocked = false,
2024-01-23 19:08:21 +00:00
isHandRaised = false,
2022-05-19 03:28:51 +00:00
hasRemoteAudio = false,
2024-01-23 19:08:21 +00:00
mediaKeysReceived = true,
presenting = false,
2022-05-19 03:28:51 +00:00
}: {
2024-01-23 19:08:21 +00:00
addedTime?: number;
2022-05-19 03:28:51 +00:00
isBlocked?: boolean;
hasRemoteAudio?: boolean;
2024-01-23 19:08:21 +00:00
mediaKeysReceived?: boolean;
presenting?: boolean;
2023-12-06 21:52:29 +00:00
isHandRaised?: boolean;
2022-05-19 03:28:51 +00:00
} = {}
): PropsType => ({
getFrameBuffer,
getGroupCallVideoFrameSource: () => {
return { receiveVideoFrame: () => undefined };
},
imageDataCache: React.createRef<CallingImageDataCache>(),
i18n,
2022-05-19 03:28:51 +00:00
audioLevel: 0,
remoteParticipant: {
aci: generateAci(),
2024-01-23 19:08:21 +00:00
addedTime,
demuxId: 123,
2022-05-19 03:28:51 +00:00
hasRemoteAudio,
hasRemoteVideo: true,
2023-12-06 21:52:29 +00:00
isHandRaised,
2024-01-23 19:08:21 +00:00
mediaKeysReceived,
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',
2023-08-16 20:54:39 +00:00
serviceId: generateAci(),
}),
},
remoteParticipantsCount: 1,
isActiveSpeakerInSpeakerView: false,
isCallReconnecting: false,
joinedAt: new Date().getTime() - MINUTE,
...overrideProps,
});
2022-06-07 00:48:02 +00:00
export default {
title: 'Components/GroupCallRemoteParticipant',
argTypes: {},
args: {},
} satisfies Meta<PropsType>;
2022-11-18 00:45:19 +00:00
export function Default(): JSX.Element {
return (
<GroupCallRemoteParticipant
{...createProps({
2022-05-19 03:28:51 +00:00
isInPip: false,
height: 120,
left: 0,
top: 0,
width: 120,
2022-11-18 00:45:19 +00:00
})}
/>
);
}
2022-05-19 03:28:51 +00:00
2022-11-18 00:45:19 +00:00
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: 0.5,
remoteParticipantsCount,
},
{ hasRemoteAudio: true, presenting }
);
}
2022-11-18 00:45:19 +00:00
return (
<>
<GroupCallRemoteParticipant {...createSpeakingProps(0, 1, false)} />
<GroupCallRemoteParticipant {...createSpeakingProps(1, 2, false)} />
<GroupCallRemoteParticipant {...createSpeakingProps(2, 2, true)} />
</>
2022-11-18 00:45:19 +00:00
);
}
2023-12-06 21:52:29 +00:00
export function HandRaised(): JSX.Element {
return (
<GroupCallRemoteParticipant
{...createProps(
{
isInPip: false,
height: 120,
left: 0,
top: 0,
width: 120,
},
{ isHandRaised: true }
)}
/>
);
}
2022-11-18 00:45:19 +00:00
export function IsInPip(): JSX.Element {
return (
<GroupCallRemoteParticipant
{...createProps({
isInPip: true,
})}
/>
);
}
2022-11-18 00:45:19 +00:00
export function Blocked(): JSX.Element {
return (
<GroupCallRemoteParticipant
{...createProps(
{
isInPip: false,
height: 120,
left: 0,
top: 0,
width: 120,
},
{ isBlocked: true }
)}
/>
);
}
2024-01-23 19:08:21 +00:00
export function NoMediaKeys(): JSX.Element {
return (
<GroupCallRemoteParticipant
{...createProps(
{
isInPip: false,
height: 120,
left: 0,
top: 0,
width: 120,
},
{
addedTime: Date.now() - MINUTE,
2024-01-23 19:08:21 +00:00
hasRemoteAudio: true,
mediaKeysReceived: false,
}
)}
/>
);
}
export function NoMediaKeysBlockedIntermittent(): JSX.Element {
const [isBlocked, setIsBlocked] = React.useState(false);
React.useEffect(() => {
const interval = setInterval(() => {
setIsBlocked(value => !value);
}, 6000);
return () => clearInterval(interval);
}, [isBlocked]);
const [mediaKeysReceived, setMediaKeysReceived] = React.useState(false);
React.useEffect(() => {
const interval = setInterval(() => {
setMediaKeysReceived(value => !value);
}, 3000);
return () => clearInterval(interval);
}, [mediaKeysReceived]);
return (
<GroupCallRemoteParticipant
{...createProps(
{
isInPip: false,
height: 120,
left: 0,
top: 0,
width: 120,
},
{
addedTime: Date.now() - 60 * 1000,
hasRemoteAudio: true,
mediaKeysReceived,
isBlocked,
}
)}
/>
);
}