// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ComponentProps } from 'react'; import React, { useState } from 'react'; import { times } from 'lodash'; import { action } from '@storybook/addon-actions'; import { sleep } from '../../../util/sleep'; import { makeLookup } from '../../../util/makeLookup'; import { deconstructLookup } from '../../../util/deconstructLookup'; import { setupI18n } from '../../../util/setupI18n'; import type { ConversationType } from '../../../state/ducks/conversations'; import enMessages from '../../../../_locales/en/messages.json'; import { getDefaultConversation } from '../../../test-both/helpers/getDefaultConversation'; import { AddGroupMembersModal } from './AddGroupMembersModal'; import { ChooseGroupMembersModal } from './AddGroupMembersModal/ChooseGroupMembersModal'; import { ConfirmAdditionsModal } from './AddGroupMembersModal/ConfirmAdditionsModal'; import { RequestState } from './util'; import { ThemeType } from '../../../types/Util'; import { makeFakeLookupConversationWithoutServiceId } from '../../../test-both/helpers/fakeLookupConversationWithoutServiceId'; const i18n = setupI18n('en', enMessages); export default { title: 'Components/Conversation/ConversationDetails/AddGroupMembersModal', }; const allCandidateContacts = times(50, () => getDefaultConversation()); let allCandidateContactsLookup = makeLookup(allCandidateContacts, 'id'); const lookupConversationWithoutServiceId = makeFakeLookupConversationWithoutServiceId(convo => { allCandidateContacts.push(convo); allCandidateContactsLookup = makeLookup(allCandidateContacts, 'id'); }); type PropsType = ComponentProps; const createProps = ( overrideProps: Partial = {}, candidateContacts: Array = allCandidateContacts ): PropsType => ({ clearRequestError: action('clearRequestError'), conversationIdsAlreadyInGroup: new Set(), groupTitle: 'Tahoe Trip', i18n, onClose: action('onClose'), makeRequest: async (conversationIds: ReadonlyArray) => { action('onMakeRequest')(conversationIds); }, maxGroupSize: 1001, maxRecommendedGroupSize: 151, requestState: RequestState.Inactive, renderChooseGroupMembersModal: props => { const { selectedConversationIds } = props; return ( undefined} theme={ThemeType.light} i18n={i18n} lookupConversationWithoutServiceId={lookupConversationWithoutServiceId} showUserNotFoundModal={action('showUserNotFoundModal')} isUsernamesEnabled /> ); }, renderConfirmAdditionsModal: props => { const { selectedConversationIds } = props; return ( ); }, ...overrideProps, }); export function Default(): JSX.Element { return ; } export function Only3Contacts(): JSX.Element { return ( ); } Only3Contacts.story = { name: 'Only 3 contacts', }; export function NoCandidateContacts(): JSX.Element { return ; } NoCandidateContacts.story = { name: 'No candidate contacts', }; export function EveryoneAlreadyAdded(): JSX.Element { return ( contact.id) ), })} /> ); } EveryoneAlreadyAdded.story = { name: 'Everyone already added', }; function RequestFailsAfter1SecondWrapper() { const [requestState, setRequestState] = useState(RequestState.Inactive); return ( { setRequestState(RequestState.Inactive); }, makeRequest: async () => { setRequestState(RequestState.Active); await sleep(1000); setRequestState(RequestState.InactiveWithError); }, requestState, })} /> ); } export function RequestFailsAfter1Second(): JSX.Element { return ; } RequestFailsAfter1Second.story = { name: 'Request fails after 1 second', };