import React from 'react' import { useTranslation } from 'react-i18next' import { DialogRoot, DialogContent, DialogHeader, DialogTitle, DialogBody, DialogFooter, DialogActionTrigger, Button, Text, } from '@chakra-ui/react' import { useClearChainSubmissionsMutation } from '../__data__/api/api' import { toaster } from './ui/toaster' import type { ChallengeChain } from '../types/challenge' interface ClearSubmissionsDialogProps { isOpen: boolean onClose: () => void chain: ChallengeChain | null } export const ClearSubmissionsDialog: React.FC = ({ isOpen, onClose, chain, }) => { const { t } = useTranslation() const [clearSubmissions, { isLoading }] = useClearChainSubmissionsMutation() const handleConfirm = async () => { if (!chain) return try { await clearSubmissions(chain.id).unwrap() toaster.create({ title: t('challenge.admin.common.success'), description: t('challenge.admin.chains.clear.submissions.success'), type: 'success', }) onClose() } catch (err) { toaster.create({ title: t('challenge.admin.common.error'), description: t('challenge.admin.chains.clear.submissions.error'), type: 'error', }) } } if (!chain) return null return ( !e.open && onClose()}> {t('challenge.admin.chains.clear.submissions.dialog.title')} {t('challenge.admin.chains.clear.submissions.dialog.message', { name: chain.name })} ) }