// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import { times } from 'lodash'; import { action } from '@storybook/addon-actions'; 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 './ContactSpoofingReviewDialog'; import { ContactSpoofingReviewDialog } from './ContactSpoofingReviewDialog'; import { ContactSpoofingType } from '../../util/contactSpoofing'; import { ThemeType } from '../../types/Util'; const i18n = setupI18n('en', enMessages); export default { title: 'Components/Conversation/ContactSpoofingReviewDialog', } satisfies Meta; const getCommonProps = () => ({ acceptConversation: action('acceptConversation'), reportSpam: action('reportSpam'), blockAndReportSpam: action('blockAndReportSpam'), blockConversation: action('blockConversation'), conversationId: 'some-conversation-id', deleteConversation: action('deleteConversation'), getPreferredBadge: () => undefined, groupConversationId: 'convo-id', i18n, onClose: action('onClose'), showContactModal: action('showContactModal'), toggleSignalConnectionsModal: action('toggleSignalConnectionsModal'), updateSharedGroups: action('updateSharedGroups'), removeMember: action('removeMember'), theme: ThemeType.light, }); export function DirectConversationsWithSameTitle(): JSX.Element { return ( ); } export function NotAdminMany(): JSX.Element { return ( ({ oldName: 'Alicia', isSignalConnection: false, conversation: getDefaultConversation({ title: 'Alice' }), })), Bob: times(3, () => ({ isSignalConnection: false, conversation: getDefaultConversation({ title: 'Bob' }), })), Charlie: times(5, () => ({ isSignalConnection: false, conversation: getDefaultConversation({ title: 'Charlie' }), })), }} /> ); } export function NotAdminOne(): JSX.Element { return ( ); } export function AdminMany(): JSX.Element { return ( ({ oldName: 'Alicia', isSignalConnection: false, conversation: getDefaultConversation({ title: 'Alice' }), })), Bob: times(3, () => ({ isSignalConnection: false, conversation: getDefaultConversation({ title: 'Bob' }), })), Charlie: times(5, () => ({ isSignalConnection: false, conversation: getDefaultConversation({ title: 'Charlie' }), })), }} /> ); } export function AdminOne(): JSX.Element { return ( ); }