signal-desktop/ts/components/NewlyCreatedGroupInvitedContactsDialog.tsx

93 lines
2.8 KiB
TypeScript
Raw Normal View History

2021-03-03 20:09:58 +00:00
// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import type { FunctionComponent, ReactNode } from 'react';
import React from 'react';
2021-03-03 20:09:58 +00:00
2021-11-20 15:41:21 +00:00
import type { LocalizerType, ThemeType } from '../types/Util';
import type { ConversationType } from '../state/ducks/conversations';
2021-11-20 15:41:21 +00:00
import type { PreferredBadgeSelectorType } from '../state/selectors/badges';
2021-03-03 20:09:58 +00:00
import { Intl } from './Intl';
import { ContactName } from './conversation/ContactName';
import { GroupDialog } from './GroupDialog';
2021-09-21 20:45:25 +00:00
import { openLinkInWebBrowser } from '../util/openLinkInWebBrowser';
2021-03-03 20:09:58 +00:00
type PropsType = {
contacts: Array<ConversationType>;
2021-11-20 15:41:21 +00:00
getPreferredBadge: PreferredBadgeSelectorType;
2021-03-03 20:09:58 +00:00
i18n: LocalizerType;
onClose: () => void;
2021-11-20 15:41:21 +00:00
theme: ThemeType;
2021-03-03 20:09:58 +00:00
};
2021-11-11 22:43:05 +00:00
export const NewlyCreatedGroupInvitedContactsDialog: FunctionComponent<PropsType> =
2021-11-20 15:41:21 +00:00
({ contacts, getPreferredBadge, i18n, onClose, theme }) => {
2021-11-11 22:43:05 +00:00
let title: string;
let body: ReactNode;
if (contacts.length === 1) {
const contact = contacts[0];
2021-03-03 20:09:58 +00:00
2021-11-11 22:43:05 +00:00
title = i18n('NewlyCreatedGroupInvitedContactsDialog--title--one');
body = (
<>
<GroupDialog.Paragraph>
<Intl
i18n={i18n}
id="NewlyCreatedGroupInvitedContactsDialog--body--user-paragraph--one"
components={[<ContactName title={contact.title} />]}
/>
</GroupDialog.Paragraph>
<GroupDialog.Paragraph>
{i18n(
'NewlyCreatedGroupInvitedContactsDialog--body--info-paragraph'
)}
</GroupDialog.Paragraph>
</>
);
} else {
title = i18n('NewlyCreatedGroupInvitedContactsDialog--title--many', [
contacts.length.toString(),
]);
body = (
<>
<GroupDialog.Paragraph>
{i18n(
'NewlyCreatedGroupInvitedContactsDialog--body--user-paragraph--many'
)}
</GroupDialog.Paragraph>
<GroupDialog.Paragraph>
{i18n(
'NewlyCreatedGroupInvitedContactsDialog--body--info-paragraph'
)}
</GroupDialog.Paragraph>
2021-11-20 15:41:21 +00:00
<GroupDialog.Contacts
contacts={contacts}
getPreferredBadge={getPreferredBadge}
i18n={i18n}
theme={theme}
/>
2021-11-11 22:43:05 +00:00
</>
);
}
2021-03-03 20:09:58 +00:00
2021-11-11 22:43:05 +00:00
return (
<GroupDialog
i18n={i18n}
onClickPrimaryButton={onClose}
primaryButtonText={i18n('Confirmation--confirm')}
secondaryButtonText={i18n(
'NewlyCreatedGroupInvitedContactsDialog--body--learn-more'
)}
onClickSecondaryButton={() => {
openLinkInWebBrowser(
'https://support.signal.org/hc/articles/360007319331-Group-chats'
);
}}
onClose={onClose}
title={title}
>
{body}
</GroupDialog>
);
};