utopia-ui/src/Components/Profile/UserSettings.tsx
2025-02-09 20:32:41 +00:00

92 lines
2.7 KiB
TypeScript

/* eslint-disable @typescript-eslint/no-unsafe-argument */
/* eslint-disable @typescript-eslint/restrict-template-expressions */
import { useEffect, useState } from 'react'
import { useNavigate } from 'react-router-dom'
import { toast } from 'react-toastify'
import { useAuth } from '#components/Auth'
import { TextInput } from '#components/Input'
import { MapOverlayPage } from '#components/Templates'
import type { UserItem } from '#src/types/UserItem'
export function UserSettings() {
const { user, updateUser, loading /* token */ } = useAuth()
const [id, setId] = useState<string>('')
const [email, setEmail] = useState<string>('')
const [password, setPassword] = useState<string>('')
const [passwordChanged, setPasswordChanged] = useState<boolean>(false)
const navigate = useNavigate()
useEffect(() => {
setId(user?.id ? user.id : '')
setEmail(user?.email ? user.email : '')
setPassword(user?.password ? user.password : '')
}, [user])
const onUpdateUser = () => {
let changedUser = {} as UserItem
changedUser = { id, email, ...(passwordChanged && { password }) }
toast
.promise(updateUser(changedUser), {
pending: 'updating Profile ...',
success: 'Profile updated',
error: {
render({ data }) {
return `${data}`
},
},
})
.then(() => navigate('/'))
.catch((e) => {
throw e
})
}
return (
<MapOverlayPage
backdrop
className='tw-mx-4 tw-mt-4 tw-max-h-[calc(100dvh-96px)] tw-h-fit md:tw-w-[calc(50%-32px)] tw-w-[calc(100%-32px)] tw-max-w-xl !tw-left-auto tw-top-0 tw-bottom-0'
>
<div className={'tw-text-xl tw-font-semibold'}>Settings</div>
<div className='tw-divider tw-mt-2'></div>
<div className='tw-grid tw-grid-cols-1 tw-gap-6'>
<TextInput
type='email'
placeholder='new E-Mail'
defaultValue={user?.email ? user.email : ''}
updateFormValue={(v) => setEmail(v)}
/>
<TextInput
type='password'
placeholder='new Password'
defaultValue={user?.password ? user.password : ''}
updateFormValue={(v) => {
setPassword(v)
setPasswordChanged(true)
}}
/>
{/* <ToogleInput updateType="syncData" labelTitle="Sync Data" defaultValue={true} updateFormValue={updateFormValue}/> */}
</div>
<div className='tw-mt-8'>
<button
className={
loading
? ' tw-loading tw-btn-disabled tw-btn tw-btn-primary tw-float-right'
: 'tw-btn tw-btn-primary tw-float-right'
}
onClick={() => onUpdateUser()}
>
Update
</button>
</div>
</MapOverlayPage>
)
}