signal-desktop/ts/components/conversation/RemoveGroupMemberConfirmationDialog.tsx

56 lines
1.5 KiB
TypeScript
Raw Normal View History

2021-06-01 23:30:25 +00:00
// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import type { FunctionComponent } from 'react';
import React from 'react';
2021-06-01 23:30:25 +00:00
import type { ConversationType } from '../../state/ducks/conversations';
import type { LocalizerType } from '../../types/Util';
import { isAccessControlEnabled } from '../../groups/util';
2021-06-01 23:30:25 +00:00
import { ConfirmationDialog } from '../ConfirmationDialog';
import { Intl } from '../Intl';
import { ContactName } from './ContactName';
type PropsType = {
group: ConversationType;
2021-06-01 23:30:25 +00:00
conversation: ConversationType;
i18n: LocalizerType;
onClose: () => void;
onRemove: () => void;
};
2022-03-22 20:45:34 +00:00
export const RemoveGroupMemberConfirmationDialog: FunctionComponent<
PropsType
> = ({ conversation, group, i18n, onClose, onRemove }) => {
const descriptionKey = isAccessControlEnabled(
group.accessControlAddFromInviteLink
)
? 'RemoveGroupMemberConfirmation__description__with-link'
: 'RemoveGroupMemberConfirmation__description';
2022-03-22 20:45:34 +00:00
return (
<ConfirmationDialog
2022-09-27 20:24:21 +00:00
dialogName="RemoveGroupMemberConfirmationDialog"
2022-03-22 20:45:34 +00:00
actions={[
{
action: onRemove,
text: i18n('RemoveGroupMemberConfirmation__remove-button'),
style: 'negative',
},
]}
i18n={i18n}
onClose={onClose}
title={
<Intl
i18n={i18n}
id={descriptionKey}
components={{
name: <ContactName title={conversation.title} />,
}}
/>
}
/>
);
};