index.tsx 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. 'use client'
  2. import { useTranslation } from 'react-i18next'
  3. import { RiCloseLine } from '@remixicon/react'
  4. import cn from '@/utils/classnames'
  5. import Button from '@/app/components/base/button'
  6. import Modal from '@/app/components/base/modal'
  7. import { AlertTriangle } from '@/app/components/base/icons/src/vender/solid/alertsAndFeedback'
  8. type ConfirmModalProps = {
  9. show: boolean
  10. onConfirm?: () => void
  11. onClose: () => void
  12. }
  13. const ConfirmModal = ({ show, onConfirm, onClose }: ConfirmModalProps) => {
  14. const { t } = useTranslation()
  15. return (
  16. <Modal
  17. className={cn('p-8 max-w-[600px] w-[600px]')}
  18. isShow={show}
  19. onClose={() => { }}
  20. >
  21. <div className='absolute right-4 top-4 p-2 cursor-pointer' onClick={onClose}>
  22. <RiCloseLine className='w-4 h-4 text-text-tertiary' />
  23. </div>
  24. <div className='w-12 h-12 p-3 bg-background-section rounded-xl border-[0.5px] border-divider-regular shadow-xl'>
  25. <AlertTriangle className='w-6 h-6 text-[rgb(247,144,9)]' />
  26. </div>
  27. <div className='relative mt-3 text-xl font-semibold leading-[30px] text-text-primary'>{t('tools.createTool.confirmTitle')}</div>
  28. <div className='my-1 text-text-tertiary text-sm leading-5'>
  29. {t('tools.createTool.confirmTip')}
  30. </div>
  31. <div className='pt-6 flex justify-end items-center'>
  32. <div className='flex items-center'>
  33. <Button className='mr-2' onClick={onClose}>{t('common.operation.cancel')}</Button>
  34. <Button variant="warning" onClick={onConfirm}>{t('common.operation.confirm')}</Button>
  35. </div>
  36. </div>
  37. </Modal>
  38. )
  39. }
  40. export default ConfirmModal