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

118 lines
3.2 KiB
TypeScript
Raw Normal View History

// Copyright 2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import type { Meta, StoryFn } from '@storybook/react';
import React from 'react';
import { action } from '@storybook/addon-actions';
import type { PropsType } from './StoriesSettingsModal';
import enMessages from '../../_locales/en/messages.json';
import { StoriesSettingsModal } from './StoriesSettingsModal';
import {
getDefaultConversation,
getDefaultGroup,
} from '../test-both/helpers/getDefaultConversation';
import { setupI18n } from '../util/setupI18n';
2022-08-02 19:31:55 +00:00
import {
getMyStories,
getFakeDistributionList,
} from '../test-both/helpers/getFakeDistributionLists';
const i18n = setupI18n('en', enMessages);
export default {
title: 'Components/StoriesSettingsModal',
component: StoriesSettingsModal,
argTypes: {
2022-10-25 22:18:42 +00:00
storyViewReceiptsEnabled: { control: 'boolean' },
},
args: {
candidateConversations: Array.from(Array(100), () =>
getDefaultConversation()
),
signalConnections: Array.from(Array(42), getDefaultConversation),
distributionLists: [],
groupStories: Array.from(Array(2), getDefaultGroup),
getPreferredBadge: () => undefined,
hideStoriesSettings: action('hideStoriesSettings'),
i18n,
me: getDefaultConversation(),
onDeleteList: action('onDeleteList'),
toggleGroupsForStorySend: action('toggleGroupsForStorySend'),
onDistributionListCreated: () => Promise.resolve(''),
onHideMyStoriesFrom: action('onHideMyStoriesFrom'),
onRemoveMembers: action('onRemoveMembers'),
onRepliesNReactionsChanged: action('onRepliesNReactionsChanged'),
onViewersUpdated: action('onViewersUpdated'),
setMyStoriesToAllSignalConnections: action(
'setMyStoriesToAllSignalConnections'
),
toggleSignalConnectionsModal: action('toggleSignalConnectionsModal'),
setStoriesDisabled: action('setStoriesDisabled'),
getConversationByServiceId: () => getDefaultGroup(),
},
} satisfies Meta<PropsType>;
2022-11-18 00:45:19 +00:00
// eslint-disable-next-line react/function-component-definition
const Template: StoryFn<PropsType> = args => <StoriesSettingsModal {...args} />;
export const MyStories = Template.bind({});
2022-08-02 19:31:55 +00:00
{
const myStories = getMyStories();
MyStories.args = {
distributionLists: [
{
...myStories,
members: [],
},
],
};
}
export const MyStoriesBlockList = Template.bind({});
2022-08-02 19:31:55 +00:00
{
const myStories = getMyStories();
MyStoriesBlockList.args = {
distributionLists: [
{
...myStories,
members: Array.from(Array(2), () => getDefaultConversation()),
},
],
};
}
export const MyStoriesExclusive = Template.bind({});
2022-08-02 19:31:55 +00:00
{
const myStories = getMyStories();
MyStoriesExclusive.args = {
distributionLists: [
{
...myStories,
isBlockList: false,
members: Array.from(Array(11), () => getDefaultConversation()),
},
],
};
}
export const SingleList = Template.bind({});
2022-08-02 19:31:55 +00:00
{
const myStories = getMyStories();
const fakeDistroList = getFakeDistributionList();
SingleList.args = {
distributionLists: [
{
...myStories,
members: [],
},
{
...fakeDistroList,
members: fakeDistroList.memberServiceIds.map(() =>
getDefaultConversation()
),
2022-08-02 19:31:55 +00:00
},
],
};
}