import React, { useEffect, useRef, useState } from 'react' import { createPortal } from 'react-dom' import { useTranslation } from 'react-i18next' import Button from '../button' export type IConfirm = { className?: string isShow: boolean type?: 'info' | 'warning' title: string content?: React.ReactNode confirmText?: string | null onConfirm: () => void cancelText?: string onCancel: () => void isLoading?: boolean isDisabled?: boolean showConfirm?: boolean showCancel?: boolean maskClosable?: boolean } function Confirm({ isShow, type = 'warning', title, content, confirmText, cancelText, onConfirm, onCancel, showConfirm = true, showCancel = true, isLoading = false, isDisabled = false, maskClosable = true, }: IConfirm) { const { t } = useTranslation() const dialogRef = useRef(null) const [isVisible, setIsVisible] = useState(isShow) const confirmTxt = confirmText || `${t('common.operation.confirm')}` const cancelTxt = cancelText || `${t('common.operation.cancel')}` useEffect(() => { const handleKeyDown = (event: KeyboardEvent) => { if (event.key === 'Escape') onCancel() } document.addEventListener('keydown', handleKeyDown) return () => { document.removeEventListener('keydown', handleKeyDown) } }, [onCancel]) const handleClickOutside = (event: MouseEvent) => { if (maskClosable && dialogRef.current && !dialogRef.current.contains(event.target as Node)) onCancel() } useEffect(() => { document.addEventListener('mousedown', handleClickOutside) return () => { document.removeEventListener('mousedown', handleClickOutside) } }, [maskClosable]) useEffect(() => { if (isShow) { setIsVisible(true) } else { const timer = setTimeout(() => setIsVisible(false), 200) return () => clearTimeout(timer) } }, [isShow]) if (!isVisible) return null return createPortal(
{ e.preventDefault() e.stopPropagation() }}>
{title}
{content}
{showCancel && } {showConfirm && }
, document.body, ) } export default React.memo(Confirm)