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

134 lines
3.5 KiB
TypeScript
Raw Normal View History

2022-08-02 19:31:55 +00:00
// Copyright 2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import type { Meta } from '@storybook/react';
2022-08-02 19:31:55 +00:00
import React from 'react';
import { action } from '@storybook/addon-actions';
2022-08-02 19:31:55 +00:00
import type { PropsType } from './SendStoryModal';
import enMessages from '../../_locales/en/messages.json';
import { SendStoryModal } from './SendStoryModal';
2022-08-10 18:37:19 +00:00
import {
getDefaultConversation,
getDefaultGroup,
} from '../test-both/helpers/getDefaultConversation';
2022-08-02 19:31:55 +00:00
import { setupI18n } from '../util/setupI18n';
import {
getMyStories,
2022-08-30 19:13:32 +00:00
getFakeDistributionListsWithMembers,
2022-08-02 19:31:55 +00:00
} from '../test-both/helpers/getFakeDistributionLists';
import { VIDEO_MP4 } from '../types/MIME';
import type { StoryDistributionIdString } from '../types/StoryDistributionId';
2022-08-02 19:31:55 +00:00
const i18n = setupI18n('en', enMessages);
2022-08-30 19:13:32 +00:00
const myStories = {
...getMyStories(),
members: [],
};
2022-08-02 19:31:55 +00:00
export default {
title: 'Components/SendStoryModal',
component: SendStoryModal,
args: {
draftAttachment: {
contentType: VIDEO_MP4,
fileName: 'pixabay-Soap-Bubble-7141.mp4',
url: '/fixtures/pixabay-Soap-Bubble-7141.mp4',
size: 1,
},
candidateConversations: Array.from(Array(100), () =>
getDefaultConversation()
),
distributionLists: [myStories],
getPreferredBadge: () => undefined,
groupConversations: Array.from(Array(7), getDefaultGroup),
groupStories: Array.from(Array(2), getDefaultGroup),
hasFirstStoryPostExperience: false,
i18n,
me: getDefaultConversation(),
onClose: action('onClose'),
onDeleteList: action('onDeleteList'),
onDistributionListCreated: () =>
Promise.resolve('' as StoryDistributionIdString),
onHideMyStoriesFrom: action('onHideMyStoriesFrom'),
onMediaPlaybackStart: action('onMediaPlaybackStart'),
onSend: action('onSend'),
onViewersUpdated: action('onViewersUpdated'),
setMyStoriesToAllSignalConnections: action(
'setMyStoriesToAllSignalConnections'
),
mostRecentActiveStoryTimestampByGroupOrDistributionList: {},
signalConnections: Array.from(Array(42), getDefaultConversation),
toggleGroupsForStorySend: () => Promise.resolve(),
toggleSignalConnectionsModal: action('toggleSignalConnectionsModal'),
2022-08-02 19:31:55 +00:00
},
} satisfies Meta<PropsType>;
2022-08-02 19:31:55 +00:00
export function Modal(args: PropsType): JSX.Element {
return (
<SendStoryModal
{...args}
distributionLists={getFakeDistributionListsWithMembers()}
/>
);
}
2022-08-02 19:31:55 +00:00
export function BlockList(args: PropsType): JSX.Element {
return (
<SendStoryModal
{...args}
distributionLists={[
{ ...getMyStories(), members: [getDefaultConversation()] },
]}
groupStories={[]}
/>
);
}
export function AllowList(args: PropsType): JSX.Element {
return (
<SendStoryModal
{...args}
distributionLists={[
{
...getMyStories(),
isBlockList: false,
members: [getDefaultConversation()],
},
]}
groupStories={[]}
/>
);
}
export function FirstTime(args: PropsType): JSX.Element {
return (
<SendStoryModal
{...args}
distributionLists={[myStories]}
groupStories={[]}
hasFirstStoryPostExperience
/>
);
}
2022-08-30 19:13:32 +00:00
export function FirstTimeAlreadyConfiguredOnMobile(
args: PropsType
): JSX.Element {
return (
<SendStoryModal
{...args}
distributionLists={[
{
...myStories,
isBlockList: false,
members: Array.from(Array(3), getDefaultConversation),
},
]}
groupStories={[]}
hasFirstStoryPostExperience
/>
);
}