2023-07-31 21:45:27 +03:00
|
|
|
|
import { useLayoutEffect, useState } from 'react';
|
|
|
|
|
import { toast } from 'react-toastify';
|
|
|
|
|
|
|
|
|
|
import TextInput from '../../components/Common/TextInput';
|
2023-07-31 23:47:18 +03:00
|
|
|
|
import { useUserProfile } from '../../context/UserProfileContext';
|
2023-07-31 21:45:27 +03:00
|
|
|
|
import { IUserUpdateData } from '../../utils/models';
|
2023-08-10 13:53:19 +03:00
|
|
|
|
import { ChangePassword } from './ChangePassword';
|
2023-07-31 21:45:27 +03:00
|
|
|
|
|
2023-07-15 17:46:19 +03:00
|
|
|
|
|
2023-07-26 10:59:55 +03:00
|
|
|
|
export function UserProfile() {
|
2023-08-10 13:53:19 +03:00
|
|
|
|
const { updateUser, user, processing, error } = useUserProfile();
|
2023-07-31 21:45:27 +03:00
|
|
|
|
|
|
|
|
|
const [username, setUsername] = useState('');
|
|
|
|
|
const [email, setEmail] = useState('');
|
|
|
|
|
const [first_name, setFirstName] = useState('');
|
|
|
|
|
const [last_name, setLastName] = useState('');
|
2023-08-10 13:53:19 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// const [showChangePassword, setShowChangePassword] = useState(false);
|
|
|
|
|
|
2023-07-31 21:45:27 +03:00
|
|
|
|
|
|
|
|
|
useLayoutEffect(() => {
|
|
|
|
|
if (user) {
|
|
|
|
|
setUsername(user.username);
|
|
|
|
|
setEmail(user.email);
|
|
|
|
|
setFirstName(user.first_name);
|
|
|
|
|
setLastName(user.last_name);
|
|
|
|
|
}
|
|
|
|
|
}, [user]);
|
|
|
|
|
|
2023-07-31 23:47:18 +03:00
|
|
|
|
function handleSubmit(event: React.FormEvent<HTMLFormElement>) {
|
2023-07-31 21:45:27 +03:00
|
|
|
|
event.preventDefault();
|
|
|
|
|
const data: IUserUpdateData = {
|
|
|
|
|
username: username,
|
|
|
|
|
email: email,
|
|
|
|
|
first_name: first_name,
|
|
|
|
|
last_name: last_name,
|
|
|
|
|
};
|
|
|
|
|
updateUser(data, () => toast.success('Изменения сохранены'));
|
2023-07-31 23:47:18 +03:00
|
|
|
|
}
|
2023-07-31 21:45:27 +03:00
|
|
|
|
|
2023-07-25 20:27:29 +03:00
|
|
|
|
return (
|
2023-08-10 13:53:19 +03:00
|
|
|
|
<div><h1 className='flex justify-center py-2'> Учетные данные пользователя </h1>
|
|
|
|
|
<div className='flex flex-row justify-center py-2'>
|
|
|
|
|
<div className='flex-grow max-w-sm px-4 '>
|
|
|
|
|
<form onSubmit={handleSubmit} className='flex-grow px-6 py-2 border center min-w-fit'>
|
2023-07-31 23:47:18 +03:00
|
|
|
|
<TextInput id='username'
|
|
|
|
|
label='Логин:'
|
|
|
|
|
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)}/>
|
2023-08-10 13:53:19 +03:00
|
|
|
|
<div className='flex items-center justify-center my-4'>
|
2023-07-31 23:47:18 +03:00
|
|
|
|
<button
|
|
|
|
|
type='submit'
|
2023-08-10 13:53:19 +03:00
|
|
|
|
className='px-2 py-1 bg-green-500 border center'
|
2023-07-31 23:47:18 +03:00
|
|
|
|
disabled={processing}>
|
2023-08-10 13:53:19 +03:00
|
|
|
|
<span>Сохранить мои данные</span>
|
2023-07-31 23:47:18 +03:00
|
|
|
|
</button>
|
2023-07-31 21:45:27 +03:00
|
|
|
|
</div>
|
|
|
|
|
|
2023-08-10 13:53:19 +03:00
|
|
|
|
</form>
|
|
|
|
|
</div>
|
|
|
|
|
<ChangePassword />
|
|
|
|
|
</div>
|
2023-07-25 20:27:29 +03:00
|
|
|
|
</div>
|
2023-07-31 21:45:27 +03:00
|
|
|
|
)}
|