mirror of
https://github.com/IRBorisov/ConceptPortal.git
synced 2025-06-26 13:00:39 +03:00
68 lines
2.2 KiB
TypeScript
68 lines
2.2 KiB
TypeScript
![]() |
import { useLayoutEffect, useState } from 'react';
|
||
|
import { toast } from 'react-toastify';
|
||
|
|
||
|
import SubmitButton from '../../components/Common/SubmitButton';
|
||
|
import TextInput from '../../components/Common/TextInput';
|
||
|
import { useUserProfile } from '../../context/UserProfileContext';
|
||
|
import { IUserUpdateData } from '../../utils/models';
|
||
|
|
||
|
function EditorProfile() {
|
||
|
const { updateUser, user, processing } = useUserProfile();
|
||
|
|
||
|
const [username, setUsername] = useState('');
|
||
|
const [email, setEmail] = useState('');
|
||
|
const [first_name, setFirstName] = useState('');
|
||
|
const [last_name, setLastName] = useState('');
|
||
|
|
||
|
useLayoutEffect(() => {
|
||
|
if (user) {
|
||
|
setUsername(user.username);
|
||
|
setEmail(user.email);
|
||
|
setFirstName(user.first_name);
|
||
|
setLastName(user.last_name);
|
||
|
}
|
||
|
}, [user]);
|
||
|
|
||
|
function handleSubmit(event: React.FormEvent<HTMLFormElement>) {
|
||
|
event.preventDefault();
|
||
|
const data: IUserUpdateData = {
|
||
|
username: username,
|
||
|
email: email,
|
||
|
first_name: first_name,
|
||
|
last_name: last_name,
|
||
|
};
|
||
|
updateUser(data, () => toast.success('Изменения сохранены'));
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<div className='flex py-2'>
|
||
|
<form onSubmit={handleSubmit} className='px-6 min-w-[18rem]'>
|
||
|
<div>
|
||
|
<TextInput id='username'
|
||
|
label='Логин'
|
||
|
tooltip='Логин изменить нельзя'
|
||
|
disabled={true}
|
||
|
value={username}
|
||
|
onChange={event => setUsername(event.target.value)}
|
||
|
/>
|
||
|
<TextInput id='first_name'
|
||
|
label="Имя"
|
||
|
value={first_name}
|
||
|
onChange={event => setFirstName(event.target.value)}
|
||
|
/>
|
||
|
<TextInput id='last_name' label="Фамилия" value={last_name} onChange={event => setLastName(event.target.value)}/>
|
||
|
<TextInput id='email' label="Электронная почта" value={email} onChange={event => setEmail(event.target.value)}/>
|
||
|
</div>
|
||
|
<div className='flex justify-center w-full mt-10'>
|
||
|
<SubmitButton
|
||
|
text='Сохранить данные'
|
||
|
loading={processing}
|
||
|
/>
|
||
|
</div>
|
||
|
</form>
|
||
|
</div>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
export default EditorProfile;
|
||
|
|