// Copyright 2015 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import { render, unmountComponentAtNode } from 'react-dom'; import { ConfirmationDialog } from '../components/ConfirmationDialog'; type ConfirmationDialogViewProps = { onTopOfEverything?: boolean; dialogName: string; cancelText?: string; confirmStyle?: 'affirmative' | 'negative'; title: string; description?: string; okText: string; noMouseClose?: boolean; reject?: (error: Error) => void; resolve: () => void; }; let confirmationDialogViewNode: HTMLElement | undefined; let confirmationDialogPreviousFocus: HTMLElement | undefined; function removeConfirmationDialog() { if (!confirmationDialogViewNode) { return; } window.reduxActions?.globalModals.toggleConfirmationModal(false); unmountComponentAtNode(confirmationDialogViewNode); document.body.removeChild(confirmationDialogViewNode); if ( confirmationDialogPreviousFocus && typeof confirmationDialogPreviousFocus.focus === 'function' ) { confirmationDialogPreviousFocus.focus(); } confirmationDialogViewNode = undefined; } export function showConfirmationDialog( options: ConfirmationDialogViewProps ): void { if (confirmationDialogViewNode) { removeConfirmationDialog(); } window.reduxActions?.globalModals.toggleConfirmationModal(true); confirmationDialogViewNode = document.createElement('div'); document.body.appendChild(confirmationDialogViewNode); confirmationDialogPreviousFocus = document.activeElement as HTMLElement; render( { options.resolve(); }, style: options.confirmStyle, text: options.okText || window.i18n('icu:ok'), }, ]} cancelText={options.cancelText || window.i18n('icu:cancel')} i18n={window.i18n} onCancel={() => { if (options.reject) { options.reject(new Error('showConfirmationDialog: onCancel called')); } }} onClose={() => { removeConfirmationDialog(); }} title={options.title} noMouseClose={options.noMouseClose} > {options.description} , confirmationDialogViewNode ); }