// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ReactNode } from 'react'; import React, { useState } from 'react'; import classNames from 'classnames'; import type { LocalizerType } from '../../../types/Util'; import { ConfirmationDialog } from '../../ConfirmationDialog'; import { Tooltip, TooltipPlacement } from '../../Tooltip'; import { PanelRow } from './PanelRow'; import { PanelSection } from './PanelSection'; import { ConversationDetailsIcon, IconType } from './ConversationDetailsIcon'; export type Props = { acceptConversation: (id: string) => void; blockConversation: (id: string) => void; cannotLeaveBecauseYouAreLastAdmin: boolean; conversationId: string; conversationTitle: string; i18n: LocalizerType; isBlocked: boolean; isGroup: boolean; left: boolean; onLeave: () => void; }; export function ConversationDetailsActions({ acceptConversation, blockConversation, cannotLeaveBecauseYouAreLastAdmin, conversationId, conversationTitle, i18n, isBlocked, isGroup, left, onLeave, }: Props): JSX.Element { const [confirmLeave, gLeave] = useState(false); const [confirmGroupBlock, gGroupBlock] = useState(false); const [confirmGroupUnblock, gGroupUnblock] = useState(false); const [confirmDirectBlock, gDirectBlock] = useState(false); const [confirmDirectUnblock, gDirectUnblock] = useState(false); let leaveGroupNode: ReactNode; if (isGroup && !left) { leaveGroupNode = ( gLeave(true)} icon={ } label={
{i18n('icu:ConversationDetailsActions--leave-group')}
} /> ); if (cannotLeaveBecauseYouAreLastAdmin) { leaveGroupNode = ( {leaveGroupNode} ); } } let blockNode: ReactNode; if (isGroup && !isBlocked) { blockNode = ( gGroupBlock(true)} icon={ } label={
{i18n('icu:ConversationDetailsActions--block-group')}
} /> ); } else if (isGroup && isBlocked) { blockNode = ( gGroupUnblock(true)} icon={ } label={
{i18n('icu:ConversationDetailsActions--unblock-group')}
} /> ); } else { const label = isBlocked ? i18n('icu:MessageRequests--unblock') : i18n('icu:MessageRequests--block'); blockNode = ( (isBlocked ? gDirectUnblock(true) : gDirectBlock(true))} icon={ } label={
{label}
} /> ); } if (cannotLeaveBecauseYouAreLastAdmin) { blockNode = ( {blockNode} ); } return ( <> {leaveGroupNode} {blockNode} {confirmLeave && ( gLeave(false)} title={i18n( 'icu:ConversationDetailsActions--leave-group-modal-title' )} > {i18n('icu:ConversationDetailsActions--leave-group-modal-content')} )} {confirmGroupBlock && ( blockConversation(conversationId), style: 'affirmative', }, ]} i18n={i18n} onClose={() => gGroupBlock(false)} title={i18n( 'icu:ConversationDetailsActions--block-group-modal-title', { groupName: conversationTitle, } )} > {i18n('icu:ConversationDetailsActions--block-group-modal-content')} )} {confirmGroupUnblock && ( acceptConversation(conversationId), style: 'affirmative', }, ]} i18n={i18n} onClose={() => gGroupUnblock(false)} title={i18n( 'icu:ConversationDetailsActions--unblock-group-modal-title', { groupName: conversationTitle, } )} > {i18n('icu:ConversationDetailsActions--unblock-group-modal-content')} )} {confirmDirectBlock && ( blockConversation(conversationId), style: 'affirmative', }, ]} i18n={i18n} onClose={() => gDirectBlock(false)} title={i18n('icu:MessageRequests--block-direct-confirm-title', { title: conversationTitle, })} > {i18n('icu:MessageRequests--block-direct-confirm-body')} )} {confirmDirectUnblock && ( acceptConversation(conversationId), style: 'affirmative', }, ]} i18n={i18n} onClose={() => gDirectUnblock(false)} title={i18n('icu:MessageRequests--unblock-direct-confirm-title', { name: conversationTitle, })} > {i18n('icu:MessageRequests--unblock-direct-confirm-body')} )} ); }