signal-desktop/ts/components/conversation/conversation-details/AddGroupMembersModal/ConfirmAdditionsModal.tsx

110 lines
3.2 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
2022-11-18 00:45:19 +00:00
import type { ReactNode } from 'react';
import React from 'react';
2021-03-11 21:29:31 +00:00
import type { LocalizerType } from '../../../../types/Util';
import { assertDev } from '../../../../util/assert';
2021-03-11 21:29:31 +00:00
import { ModalHost } from '../../../ModalHost';
import { Button, ButtonVariant } from '../../../Button';
import { Spinner } from '../../../Spinner';
import type { ConversationType } from '../../../../state/ducks/conversations';
2021-03-11 21:29:31 +00:00
import { RequestState } from '../util';
import { Intl } from '../../../Intl';
import { ContactName } from '../../ContactName';
2023-04-20 17:03:43 +00:00
import { UserText } from '../../../UserText';
2021-03-11 21:29:31 +00:00
export type StatePropsType = {
2021-03-11 21:29:31 +00:00
groupTitle: string;
i18n: LocalizerType;
makeRequest: () => void;
onClose: () => void;
requestState: RequestState;
selectedContacts: ReadonlyArray<ConversationType>;
};
type PropsType = StatePropsType;
2022-11-18 00:45:19 +00:00
export function ConfirmAdditionsModal({
2021-03-11 21:29:31 +00:00
groupTitle,
i18n,
makeRequest,
onClose,
requestState,
selectedContacts,
2022-11-18 00:45:19 +00:00
}: PropsType): JSX.Element {
2021-03-11 21:29:31 +00:00
const firstContact = selectedContacts[0];
assertDev(
2021-03-11 21:29:31 +00:00
firstContact,
'Expected at least one conversation to be selected but none were picked'
);
2023-04-20 17:03:43 +00:00
const groupTitleNode: JSX.Element = <UserText text={groupTitle} />;
2021-03-11 21:29:31 +00:00
let headerText: ReactNode;
if (selectedContacts.length === 1) {
headerText = (
<Intl
i18n={i18n}
2023-03-30 00:03:25 +00:00
id="icu:AddGroupMembersModal--confirm-title--one"
2021-03-11 21:29:31 +00:00
components={{
person: <ContactName title={firstContact.title} />,
2021-03-11 21:29:31 +00:00
group: groupTitleNode,
}}
/>
);
} else {
headerText = (
<Intl
i18n={i18n}
2023-03-30 00:03:25 +00:00
id="icu:AddGroupMembersModal--confirm-title--many"
2021-03-11 21:29:31 +00:00
components={{
2023-04-03 19:03:00 +00:00
count: selectedContacts.length,
2021-03-11 21:29:31 +00:00
group: groupTitleNode,
}}
/>
);
}
let buttonContents: ReactNode;
if (requestState === RequestState.Active) {
buttonContents = (
<Spinner size="20px" svgSize="small" direction="on-avatar" />
);
} else if (selectedContacts.length === 1) {
2023-03-30 00:03:25 +00:00
buttonContents = i18n('icu:AddGroupMembersModal--confirm-button--one');
2021-03-11 21:29:31 +00:00
} else {
2023-03-30 00:03:25 +00:00
buttonContents = i18n('icu:AddGroupMembersModal--confirm-button--many');
2021-03-11 21:29:31 +00:00
}
return (
2022-09-27 20:24:21 +00:00
<ModalHost
modalName="AddGroupMemberModal.ConfirmAdditionsModal"
onClose={onClose}
>
2021-03-11 21:29:31 +00:00
<div className="module-AddGroupMembersModal module-AddGroupMembersModal--confirm-adds">
<h1 className="module-AddGroupMembersModal__header">{headerText}</h1>
{requestState === RequestState.InactiveWithError && (
<div className="module-AddGroupMembersModal__error-message">
2023-03-30 00:03:25 +00:00
{i18n('icu:updateGroupAttributes__error-message')}
2021-03-11 21:29:31 +00:00
</div>
)}
<div className="module-AddGroupMembersModal__button-container">
<Button onClick={onClose} variant={ButtonVariant.Secondary}>
2023-03-30 00:03:25 +00:00
{i18n('icu:cancel')}
2021-03-11 21:29:31 +00:00
</Button>
<Button
disabled={requestState === RequestState.Active}
onClick={makeRequest}
variant={ButtonVariant.Primary}
>
{buttonContents}
</Button>
</div>
</div>
</ModalHost>
);
2022-11-18 00:45:19 +00:00
}