// Copyright 2021-2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import * as React from 'react';
import { storiesOf } from '@storybook/react';
import { action } from '@storybook/addon-actions';
import { setupI18n } from '../../util/setupI18n';
import enMessages from '../../../_locales/en/messages.json';
import { CallMode } from '../../types/Calling';
import { CallingNotification } from './CallingNotification';
import type { CallingNotificationType } from '../../util/callingNotification';
const i18n = setupI18n('en', enMessages);
const story = storiesOf('Components/Conversation/CallingNotification', module);
const getCommonProps = () => ({
conversationId: 'fake-conversation-id',
i18n,
isNextItemCallingNotification: false,
messageId: 'fake-message-id',
now: Date.now(),
returnToActiveCall: action('returnToActiveCall'),
startCallingLobby: action('startCallingLobby'),
});
[false, true].forEach(wasIncoming => {
[false, true].forEach(wasVideoCall => {
[false, true].forEach(wasDeclined => {
const direction = wasIncoming ? 'incoming' : 'outgoing';
const type = wasVideoCall ? 'video' : 'audio';
const acceptance = wasDeclined ? 'declined' : 'accepted';
const storyName = `Direct call: ${direction} ${type} call, ${acceptance}`;
story.add(storyName, () => (
));
});
});
});
story.add('Two incoming direct calls back-to-back', () => {
const call1: CallingNotificationType = {
callMode: CallMode.Direct,
wasIncoming: true,
wasVideoCall: true,
wasDeclined: false,
acceptedTime: 1618894800000,
endedTime: 1618894800000,
};
const call2: CallingNotificationType = {
callMode: CallMode.Direct,
wasIncoming: true,
wasVideoCall: false,
wasDeclined: false,
endedTime: 1618894800000,
};
return (
<>
>
);
});
story.add('Two outgoing direct calls back-to-back', () => {
const call1: CallingNotificationType = {
callMode: CallMode.Direct,
wasIncoming: false,
wasVideoCall: true,
wasDeclined: false,
acceptedTime: 1618894800000,
endedTime: 1618894800000,
};
const call2: CallingNotificationType = {
callMode: CallMode.Direct,
wasIncoming: false,
wasVideoCall: false,
wasDeclined: false,
endedTime: 1618894800000,
};
return (
<>
>
);
});
[
undefined,
{ isMe: false, title: 'Alice' },
{ isMe: true, title: 'Alicia' },
].forEach(creator => {
let startedBy: string;
if (!creator) {
startedBy = 'with unknown creator';
} else if (creator.isMe) {
startedBy = 'started by you';
} else {
startedBy = 'started by someone else';
}
const storyName = `Group call: active, ${startedBy}`;
story.add(storyName, () => (
));
});
story.add('Group call: started by someone with a long name', () => {
const longName = '😤🪐🦆'.repeat(50);
return (
);
});
story.add('Group call: active, call full', () => (
));
story.add('Group call: ended', () => (
));