2021-03-11 21:29:31 +00:00
|
|
|
// Copyright 2021 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2021-10-26 19:15:33 +00:00
|
|
|
import type { ComponentProps } from 'react';
|
|
|
|
import React, { useState } from 'react';
|
2021-03-11 21:29:31 +00:00
|
|
|
import { times } from 'lodash';
|
|
|
|
import { action } from '@storybook/addon-actions';
|
2023-10-11 19:06:43 +00:00
|
|
|
import type { Meta } from '@storybook/react';
|
2021-03-11 21:29:31 +00:00
|
|
|
import { sleep } from '../../../util/sleep';
|
2022-04-05 00:38:22 +00:00
|
|
|
import { makeLookup } from '../../../util/makeLookup';
|
|
|
|
import { deconstructLookup } from '../../../util/deconstructLookup';
|
2021-09-18 00:30:08 +00:00
|
|
|
import { setupI18n } from '../../../util/setupI18n';
|
2022-04-05 00:38:22 +00:00
|
|
|
import type { ConversationType } from '../../../state/ducks/conversations';
|
2021-03-11 21:29:31 +00:00
|
|
|
import enMessages from '../../../../_locales/en/messages.json';
|
|
|
|
import { getDefaultConversation } from '../../../test-both/helpers/getDefaultConversation';
|
|
|
|
import { AddGroupMembersModal } from './AddGroupMembersModal';
|
2022-04-05 00:38:22 +00:00
|
|
|
import { ChooseGroupMembersModal } from './AddGroupMembersModal/ChooseGroupMembersModal';
|
|
|
|
import { ConfirmAdditionsModal } from './AddGroupMembersModal/ConfirmAdditionsModal';
|
2021-03-11 21:29:31 +00:00
|
|
|
import { RequestState } from './util';
|
2021-11-02 23:01:13 +00:00
|
|
|
import { ThemeType } from '../../../types/Util';
|
2023-08-10 16:43:33 +00:00
|
|
|
import { makeFakeLookupConversationWithoutServiceId } from '../../../test-both/helpers/fakeLookupConversationWithoutServiceId';
|
2021-03-11 21:29:31 +00:00
|
|
|
|
|
|
|
const i18n = setupI18n('en', enMessages);
|
|
|
|
|
2022-06-07 00:48:02 +00:00
|
|
|
export default {
|
|
|
|
title: 'Components/Conversation/ConversationDetails/AddGroupMembersModal',
|
2023-10-11 19:06:43 +00:00
|
|
|
} satisfies Meta<PropsType>;
|
2021-03-11 21:29:31 +00:00
|
|
|
|
|
|
|
const allCandidateContacts = times(50, () => getDefaultConversation());
|
2022-04-05 00:38:22 +00:00
|
|
|
let allCandidateContactsLookup = makeLookup(allCandidateContacts, 'id');
|
|
|
|
|
2023-08-10 16:43:33 +00:00
|
|
|
const lookupConversationWithoutServiceId =
|
|
|
|
makeFakeLookupConversationWithoutServiceId(convo => {
|
2022-04-05 00:38:22 +00:00
|
|
|
allCandidateContacts.push(convo);
|
|
|
|
allCandidateContactsLookup = makeLookup(allCandidateContacts, 'id');
|
2023-08-10 16:43:33 +00:00
|
|
|
});
|
2021-03-11 21:29:31 +00:00
|
|
|
|
|
|
|
type PropsType = ComponentProps<typeof AddGroupMembersModal>;
|
|
|
|
|
2022-04-05 00:38:22 +00:00
|
|
|
const createProps = (
|
|
|
|
overrideProps: Partial<PropsType> = {},
|
2023-10-06 15:45:43 +00:00
|
|
|
candidateContacts: Array<ConversationType> = allCandidateContacts
|
2022-04-05 00:38:22 +00:00
|
|
|
): PropsType => ({
|
2021-03-11 21:29:31 +00:00
|
|
|
clearRequestError: action('clearRequestError'),
|
|
|
|
conversationIdsAlreadyInGroup: new Set(),
|
|
|
|
groupTitle: 'Tahoe Trip',
|
|
|
|
i18n,
|
|
|
|
onClose: action('onClose'),
|
|
|
|
makeRequest: async (conversationIds: ReadonlyArray<string>) => {
|
|
|
|
action('onMakeRequest')(conversationIds);
|
|
|
|
},
|
2022-10-24 20:46:36 +00:00
|
|
|
maxGroupSize: 1001,
|
|
|
|
maxRecommendedGroupSize: 151,
|
2021-03-11 21:29:31 +00:00
|
|
|
requestState: RequestState.Inactive,
|
2022-04-05 00:38:22 +00:00
|
|
|
renderChooseGroupMembersModal: props => {
|
|
|
|
const { selectedConversationIds } = props;
|
|
|
|
return (
|
|
|
|
<ChooseGroupMembersModal
|
|
|
|
{...props}
|
|
|
|
candidateContacts={candidateContacts}
|
|
|
|
selectedContacts={deconstructLookup(
|
|
|
|
allCandidateContactsLookup,
|
|
|
|
selectedConversationIds
|
|
|
|
)}
|
|
|
|
regionCode="US"
|
|
|
|
getPreferredBadge={() => undefined}
|
2024-01-05 22:47:29 +00:00
|
|
|
ourE164={undefined}
|
2023-11-07 23:45:33 +00:00
|
|
|
ourUsername={undefined}
|
2022-04-05 00:38:22 +00:00
|
|
|
theme={ThemeType.light}
|
|
|
|
i18n={i18n}
|
2023-08-10 16:43:33 +00:00
|
|
|
lookupConversationWithoutServiceId={lookupConversationWithoutServiceId}
|
2022-04-05 00:38:22 +00:00
|
|
|
showUserNotFoundModal={action('showUserNotFoundModal')}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
},
|
|
|
|
renderConfirmAdditionsModal: props => {
|
|
|
|
const { selectedConversationIds } = props;
|
|
|
|
return (
|
|
|
|
<ConfirmAdditionsModal
|
|
|
|
{...props}
|
|
|
|
i18n={i18n}
|
|
|
|
selectedContacts={deconstructLookup(
|
|
|
|
allCandidateContactsLookup,
|
|
|
|
selectedConversationIds
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
},
|
2021-03-11 21:29:31 +00:00
|
|
|
...overrideProps,
|
|
|
|
});
|
|
|
|
|
2022-11-18 00:45:19 +00:00
|
|
|
export function Default(): JSX.Element {
|
|
|
|
return <AddGroupMembersModal {...createProps()} />;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function Only3Contacts(): JSX.Element {
|
|
|
|
return (
|
|
|
|
<AddGroupMembersModal
|
|
|
|
{...createProps({}, allCandidateContacts.slice(0, 3))}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
2021-03-11 21:29:31 +00:00
|
|
|
|
2022-11-18 00:45:19 +00:00
|
|
|
export function NoCandidateContacts(): JSX.Element {
|
|
|
|
return <AddGroupMembersModal {...createProps({}, [])} />;
|
|
|
|
}
|
2021-03-11 21:29:31 +00:00
|
|
|
|
2022-11-18 00:45:19 +00:00
|
|
|
export function EveryoneAlreadyAdded(): JSX.Element {
|
|
|
|
return (
|
|
|
|
<AddGroupMembersModal
|
|
|
|
{...createProps({
|
|
|
|
conversationIdsAlreadyInGroup: new Set(
|
|
|
|
allCandidateContacts.map(contact => contact.id)
|
|
|
|
),
|
|
|
|
})}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
2022-06-07 00:48:02 +00:00
|
|
|
|
2022-11-18 00:45:19 +00:00
|
|
|
function RequestFailsAfter1SecondWrapper() {
|
|
|
|
const [requestState, setRequestState] = useState(RequestState.Inactive);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<AddGroupMembersModal
|
|
|
|
{...createProps({
|
|
|
|
clearRequestError: () => {
|
|
|
|
setRequestState(RequestState.Inactive);
|
|
|
|
},
|
|
|
|
makeRequest: async () => {
|
|
|
|
setRequestState(RequestState.Active);
|
|
|
|
await sleep(1000);
|
|
|
|
setRequestState(RequestState.InactiveWithError);
|
|
|
|
},
|
|
|
|
requestState,
|
|
|
|
})}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function RequestFailsAfter1Second(): JSX.Element {
|
|
|
|
return <RequestFailsAfter1SecondWrapper />;
|
|
|
|
}
|