Files
scripts/email-cleaner/components/ConfirmationModal.tsx

80 lines
3.2 KiB
TypeScript
Executable File

/**
* ConfirmationModal.tsx
*
* @author Descomplicar® Crescimento Digital
* @link https://descomplicar.pt
* @copyright 2025 Descomplicar®
*/
import React from 'react';
interface ConfirmationModalProps {
isOpen: boolean;
onClose: () => void;
onConfirm: () => void;
categoryName: string;
emailCount: number;
}
const ConfirmationModal: React.FC<ConfirmationModalProps> = ({
isOpen,
onClose,
onConfirm,
categoryName,
emailCount,
}) => {
if (!isOpen) return null;
return (
<div
className="fixed inset-0 bg-black/60 backdrop-blur-sm z-50 flex items-center justify-center p-4"
aria-modal="true"
role="dialog"
>
<div className="bg-white dark:bg-slate-800 rounded-xl shadow-2xl p-6 w-full max-w-md transform transition-all"
role="document"
>
<div className="text-center">
<div className="mx-auto flex items-center justify-center h-12 w-12 rounded-full bg-red-100 dark:bg-red-900/50 mb-4">
<svg className="h-6 w-6 text-red-600 dark:text-red-400" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" strokeWidth="1.5" stroke="currentColor">
<path strokeLinecap="round" strokeLinejoin="round" d="M12 9v3.75m-9.303 3.376c-.866 1.5.217 3.374 1.948 3.374h14.71c1.73 0 2.813-1.874 1.948-3.374L13.949 3.378c-.866-1.5-3.032-1.5-3.898 0L2.697 16.126zM12 15.75h.007v.008H12v-.008z" />
</svg>
</div>
<h3 className="text-lg font-semibold text-slate-900 dark:text-white" id="modal-title">
Confirmar Limpeza
</h3>
<div className="mt-2">
<p className="text-sm text-slate-500 dark:text-slate-400">
Você tem certeza que deseja remover permanentemente{' '}
<span className="font-bold text-slate-700 dark:text-slate-200">{emailCount} e-mails</span> da categoria{' '}
<span className="font-bold text-slate-700 dark:text-slate-200">{categoryName}</span>?
</p>
<p className="text-xs text-slate-400 dark:text-slate-500 mt-1">
Esta ação não pode ser desfeita.
</p>
</div>
</div>
<div className="mt-6 flex justify-center gap-4">
<button
type="button"
className="w-full justify-center rounded-md border border-slate-300 dark:border-slate-600 px-4 py-2 bg-white dark:bg-slate-800 text-base font-medium text-slate-700 dark:text-slate-200 shadow-sm hover:bg-slate-50 dark:hover:bg-slate-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-sky-500 dark:focus:ring-offset-slate-900 sm:text-sm"
onClick={onClose}
>
Cancelar
</button>
<button
type="button"
className="w-full justify-center rounded-md border border-transparent px-4 py-2 bg-red-600 text-base font-medium text-white shadow-sm hover:bg-red-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-red-500 dark:focus:ring-offset-slate-900 sm:text-sm"
onClick={onConfirm}
>
Sim, Limpar
</button>
</div>
</div>
</div>
);
};
export default ConfirmationModal;