502ea174ab
Co-authored-by: Scott Nonnenberg <scott@signal.org>
247 lines
6 KiB
TypeScript
247 lines
6 KiB
TypeScript
// Copyright 2021 Signal Messenger, LLC
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
import React from 'react';
|
|
import { times } from 'lodash';
|
|
import type { Meta } from '@storybook/react';
|
|
import { setupI18n } from '../util/setupI18n';
|
|
import enMessages from '../../_locales/en/messages.json';
|
|
import { getDefaultConversation } from '../test-both/helpers/getDefaultConversation';
|
|
import type { PropsType } from './CallingPreCallInfo';
|
|
import { CallingPreCallInfo, RingMode } from './CallingPreCallInfo';
|
|
|
|
const i18n = setupI18n('en', enMessages);
|
|
const getDefaultGroupConversation = () =>
|
|
getDefaultConversation({
|
|
name: 'Tahoe Trip',
|
|
phoneNumber: undefined,
|
|
profileName: undefined,
|
|
title: 'Tahoe Trip',
|
|
type: 'group',
|
|
});
|
|
const otherMembers = times(6, () => getDefaultConversation());
|
|
|
|
export default {
|
|
title: 'Components/CallingPreCallInfo',
|
|
} satisfies Meta<PropsType>;
|
|
|
|
export function DirectConversation(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultConversation()}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Ring0(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 0)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Ring1(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 1)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Ring2(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 2)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Ring3(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 3)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Ring4(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 4)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Notify0(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 0)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Notify1(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 1)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Notify2(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 2)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Notify3(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 3)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Notify4(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers.slice(0, 4)}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Peek1(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={otherMembers.slice(0, 1)}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Peek2(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={otherMembers.slice(0, 2)}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Peek3(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={otherMembers.slice(0, 3)}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Peek4(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={otherMembers.slice(0, 4)}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function GroupConversationYouOnAnOtherDevice(): JSX.Element {
|
|
const me = getDefaultConversation();
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={me}
|
|
peekedParticipants={[me]}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function GroupConversationCallIsFull(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={getDefaultGroupConversation()}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
isCallFull
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={otherMembers}
|
|
ringMode={RingMode.WillRing}
|
|
/>
|
|
);
|
|
}
|