signal-desktop/ts/components/NewlyCreatedGroupInvitedContactsDialog.tsx

95 lines
2.6 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
2022-11-18 00:45:19 +00:00
import type { 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';
2024-05-15 21:48:02 +00:00
import { I18n } from './I18n';
2021-03-03 20:09:58 +00:00
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
export type PropsType = {
2021-03-03 20:09:58 +00:00
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
};
2022-11-18 00:45:19 +00:00
export function NewlyCreatedGroupInvitedContactsDialog({
contacts,
getPreferredBadge,
i18n,
onClose,
theme,
}: PropsType): JSX.Element {
2022-03-22 20:45:34 +00:00
let body: ReactNode;
if (contacts.length === 1) {
const contact = contacts[0];
2021-03-03 20:09:58 +00:00
2022-03-22 20:45:34 +00:00
body = (
<>
<GroupDialog.Paragraph>
2024-05-15 21:48:02 +00:00
<I18n
2021-11-20 15:41:21 +00:00
i18n={i18n}
2023-03-30 00:03:25 +00:00
id="icu:NewlyCreatedGroupInvitedContactsDialog--body--user-paragraph--one"
2023-03-27 23:37:39 +00:00
components={{ name: <ContactName title={contact.title} /> }}
2021-11-20 15:41:21 +00:00
/>
2022-03-22 20:45:34 +00:00
</GroupDialog.Paragraph>
<GroupDialog.Paragraph>
2023-03-30 00:03:25 +00:00
{i18n(
'icu:NewlyCreatedGroupInvitedContactsDialog--body--info-paragraph'
)}
2022-03-22 20:45:34 +00:00
</GroupDialog.Paragraph>
</>
);
} else {
body = (
<>
<GroupDialog.Paragraph>
{i18n(
2023-03-30 00:03:25 +00:00
'icu:NewlyCreatedGroupInvitedContactsDialog--body--user-paragraph--many'
2022-03-22 20:45:34 +00:00
)}
</GroupDialog.Paragraph>
<GroupDialog.Paragraph>
2023-03-30 00:03:25 +00:00
{i18n(
'icu:NewlyCreatedGroupInvitedContactsDialog--body--info-paragraph'
)}
2022-03-22 20:45:34 +00:00
</GroupDialog.Paragraph>
<GroupDialog.Contacts
contacts={contacts}
getPreferredBadge={getPreferredBadge}
i18n={i18n}
theme={theme}
/>
</>
2021-11-11 22:43:05 +00:00
);
2022-03-22 20:45:34 +00:00
}
return (
<GroupDialog
i18n={i18n}
onClickPrimaryButton={onClose}
2023-03-30 00:03:25 +00:00
primaryButtonText={i18n('icu:Confirmation--confirm')}
2022-03-22 20:45:34 +00:00
secondaryButtonText={i18n(
2023-03-30 00:03:25 +00:00
'icu:NewlyCreatedGroupInvitedContactsDialog--body--learn-more'
2022-03-22 20:45:34 +00:00
)}
onClickSecondaryButton={() => {
openLinkInWebBrowser(
'https://support.signal.org/hc/articles/360007319331-Group-chats'
);
}}
onClose={onClose}
2023-04-03 19:03:00 +00:00
title={i18n('icu:NewlyCreatedGroupInvitedContactsDialog--title', {
count: contacts.length,
})}
2022-03-22 20:45:34 +00:00
>
{body}
</GroupDialog>
);
2022-11-18 00:45:19 +00:00
}