signal-desktop/ts/components/conversation/conversation-details/ConversationDetailsMembershipList.stories.tsx

121 lines
3.1 KiB
TypeScript
Raw Normal View History

2021-03-11 21:29:31 +00:00
// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import * as React from 'react';
2021-03-11 21:29:31 +00:00
import { isBoolean } from 'lodash';
import { action } from '@storybook/addon-actions';
import { number } from '@storybook/addon-knobs';
2021-09-18 00:30:08 +00:00
import { setupI18n } from '../../../util/setupI18n';
import enMessages from '../../../../_locales/en/messages.json';
import { getDefaultConversation } from '../../../test-both/helpers/getDefaultConversation';
2021-11-02 23:01:13 +00:00
import { ThemeType } from '../../../types/Util';
import type {
Props,
GroupV2Membership,
} from './ConversationDetailsMembershipList';
import { ConversationDetailsMembershipList } from './ConversationDetailsMembershipList';
const i18n = setupI18n('en', enMessages);
2022-06-07 00:48:02 +00:00
export default {
title:
'Components/Conversation/ConversationDetails/ConversationDetailsMembershipList',
};
const createMemberships = (
numberOfMemberships = 10
): Array<GroupV2Membership> => {
return Array.from(
new Array(number('number of memberships', numberOfMemberships))
).map(
(_, i): GroupV2Membership => ({
isAdmin: i % 3 === 0,
2021-03-02 16:27:11 +00:00
member: getDefaultConversation({
isMe: i === 2,
}),
})
);
};
const createProps = (overrideProps: Partial<Props>): Props => ({
2021-03-11 21:29:31 +00:00
canAddNewMembers: isBoolean(overrideProps.canAddNewMembers)
? overrideProps.canAddNewMembers
: false,
2021-09-21 22:37:10 +00:00
conversationId: '123',
2021-11-17 21:11:21 +00:00
getPreferredBadge: () => undefined,
i18n,
memberships: overrideProps.memberships || [],
2021-03-02 16:27:11 +00:00
showContactModal: action('showContactModal'),
2021-03-11 21:29:31 +00:00
startAddingNewMembers: action('startAddingNewMembers'),
2021-11-02 23:01:13 +00:00
theme: ThemeType.light,
});
2022-06-07 00:48:02 +00:00
export const Few = (): JSX.Element => {
const memberships = createMemberships(3);
const props = createProps({ memberships });
return <ConversationDetailsMembershipList {...props} />;
2022-06-07 00:48:02 +00:00
};
2022-06-07 00:48:02 +00:00
export const Limit = (): JSX.Element => {
const memberships = createMemberships(5);
const props = createProps({ memberships });
return <ConversationDetailsMembershipList {...props} />;
2022-06-07 00:48:02 +00:00
};
2022-06-07 00:48:02 +00:00
export const Limit1 = (): JSX.Element => {
const memberships = createMemberships(6);
const props = createProps({ memberships });
return <ConversationDetailsMembershipList {...props} />;
2022-06-07 00:48:02 +00:00
};
Limit1.story = {
name: 'Limit +1',
};
2022-06-07 00:48:02 +00:00
export const Limit2 = (): JSX.Element => {
const memberships = createMemberships(7);
const props = createProps({ memberships });
return <ConversationDetailsMembershipList {...props} />;
2022-06-07 00:48:02 +00:00
};
2022-06-07 00:48:02 +00:00
Limit2.story = {
name: 'Limit +2',
};
export const Many = (): JSX.Element => {
const memberships = createMemberships(100);
const props = createProps({ memberships });
return <ConversationDetailsMembershipList {...props} />;
2022-06-07 00:48:02 +00:00
};
2022-06-07 00:48:02 +00:00
export const None = (): JSX.Element => {
const props = createProps({ memberships: [] });
return <ConversationDetailsMembershipList {...props} />;
2022-06-07 00:48:02 +00:00
};
2021-03-11 21:29:31 +00:00
2022-06-07 00:48:02 +00:00
export const CanAddNewMembers = (): JSX.Element => {
2021-03-11 21:29:31 +00:00
const memberships = createMemberships(10);
const props = createProps({ canAddNewMembers: true, memberships });
return <ConversationDetailsMembershipList {...props} />;
2022-06-07 00:48:02 +00:00
};
CanAddNewMembers.story = {
name: 'Can add new members',
};