'use client'
|
import { useTranslation } from 'react-i18next'
|
import { useCallback, useState } from 'react'
|
import { useRouter } from 'next/navigation'
|
import { useDeleteAccountFeedback } from '../state'
|
import { useAppContext } from '@/context/app-context'
|
import Button from '@/app/components/base/button'
|
import CustomDialog from '@/app/components/base/dialog'
|
import Textarea from '@/app/components/base/textarea'
|
import Toast from '@/app/components/base/toast'
|
import { logout } from '@/service/common'
|
|
type DeleteAccountProps = {
|
onCancel: () => void
|
onConfirm: () => void
|
}
|
|
export default function FeedBack(props: DeleteAccountProps) {
|
const { t } = useTranslation()
|
const { userProfile } = useAppContext()
|
const router = useRouter()
|
const [userFeedback, setUserFeedback] = useState('')
|
const { isPending, mutateAsync: sendFeedback } = useDeleteAccountFeedback()
|
|
const handleSuccess = useCallback(async () => {
|
try {
|
await logout({
|
url: '/logout',
|
params: {},
|
})
|
localStorage.removeItem('refresh_token')
|
localStorage.removeItem('console_token')
|
router.push('/signin')
|
Toast.notify({ type: 'info', message: t('common.account.deleteSuccessTip') })
|
}
|
catch (error) { console.error(error) }
|
}, [router, t])
|
|
const handleSubmit = useCallback(async () => {
|
try {
|
await sendFeedback({ feedback: userFeedback, email: userProfile.email })
|
props.onConfirm()
|
await handleSuccess()
|
}
|
catch (error) { console.error(error) }
|
}, [handleSuccess, userFeedback, sendFeedback, userProfile, props])
|
|
const handleSkip = useCallback(() => {
|
props.onCancel()
|
handleSuccess()
|
}, [handleSuccess, props])
|
return <CustomDialog
|
show={true}
|
onClose={props.onCancel}
|
title={t('common.account.feedbackTitle')}
|
className="max-w-[480px]"
|
footer={false}
|
>
|
<label className='system-sm-semibold mb-1 mt-3 flex items-center text-text-secondary'>{t('common.account.feedbackLabel')}</label>
|
<Textarea rows={6} value={userFeedback} placeholder={t('common.account.feedbackPlaceholder') as string} onChange={(e) => {
|
setUserFeedback(e.target.value)
|
}} />
|
<div className='mt-3 flex w-full flex-col gap-2'>
|
<Button className='w-full' loading={isPending} variant='primary' onClick={handleSubmit}>{t('common.operation.submit')}</Button>
|
<Button className='w-full' onClick={handleSkip}>{t('common.operation.skip')}</Button>
|
</div>
|
</CustomDialog>
|
}
|