317 lines
8 KiB
TypeScript
317 lines
8 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';
|
|
import type { ConversationType } from '../state/ducks/conversations';
|
|
import { getPlaceholderContact } from '../state/selectors/conversations';
|
|
import { generateAci } from '../types/ServiceId';
|
|
import { FAKE_CALL_LINK } from '../test-both/helpers/fakeCallLink';
|
|
import { callLinkToConversation } from '../util/callLinks';
|
|
|
|
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());
|
|
|
|
const getUnknownContact = (): ConversationType => ({
|
|
...getPlaceholderContact(),
|
|
serviceId: generateAci(),
|
|
});
|
|
|
|
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}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function CallLinkUnknownContact(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={callLinkToConversation(FAKE_CALL_LINK, i18n)}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[getUnknownContact()]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function CallLink3UnknownContacts(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={callLinkToConversation(FAKE_CALL_LINK, i18n)}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[
|
|
getUnknownContact(),
|
|
getUnknownContact(),
|
|
getUnknownContact(),
|
|
]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function CallLink1Known1UnknownContact(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={callLinkToConversation(FAKE_CALL_LINK, i18n)}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[otherMembers[0], getUnknownContact()]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function CallLink1Known2UnknownContacts(): JSX.Element {
|
|
return (
|
|
<CallingPreCallInfo
|
|
conversation={callLinkToConversation(FAKE_CALL_LINK, i18n)}
|
|
groupMembers={otherMembers}
|
|
i18n={i18n}
|
|
me={getDefaultConversation()}
|
|
peekedParticipants={[
|
|
otherMembers[0],
|
|
getUnknownContact(),
|
|
getUnknownContact(),
|
|
]}
|
|
ringMode={RingMode.WillNotRing}
|
|
/>
|
|
);
|
|
}
|