ConceptPortal-public/rsconcept/frontend/src/pages/UserProfilePage/EditorProfile.tsx

92 lines
2.7 KiB
TypeScript
Raw Normal View History

2023-08-26 17:26:49 +03:00
import { useLayoutEffect, useState } from 'react';
import { toast } from 'react-toastify';
import SubmitButton from '../../components/common/SubmitButton';
import TextInput from '../../components/common/TextInput';
2023-08-26 17:26:49 +03:00
import { useUserProfile } from '../../context/UserProfileContext';
import useModificationPrompt from '../../hooks/useModificationPrompt';
2023-09-11 20:31:54 +03:00
import { IUserUpdateData } from '../../models/library';
2023-08-26 17:26:49 +03:00
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('');
const { isModified, setIsModified } = useModificationPrompt();
2023-08-27 15:39:49 +03:00
useLayoutEffect(() => {
if (!user) {
setIsModified(false);
return;
}
setIsModified(
user.email !== email ||
user.first_name !== first_name ||
user.last_name !== last_name
);
}, [user, user?.email, user?.first_name, user?.last_name, email, first_name, last_name, setIsModified]);
2023-08-27 15:39:49 +03:00
2023-08-26 17:26:49 +03:00
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 (
<form onSubmit={handleSubmit} className='px-6 py-2 flex flex-col gap-8 min-w-[18rem]'>
<div className='flex flex-col gap-3'>
2023-11-05 16:31:49 +03:00
<TextInput id='username'
label='Логин'
tooltip='Логин изменить нельзя'
2023-11-05 18:41:28 +03:00
disabled
value={username}
/>
<TextInput id='first_name'
label='Имя'
value={first_name}
2023-11-05 18:41:28 +03:00
allowEnter
onChange={event => setFirstName(event.target.value)}
/>
2023-11-05 18:41:28 +03:00
<TextInput id='last_name'
label='Фамилия'
value={last_name}
allowEnter
onChange={event => setLastName(event.target.value)}
/>
<TextInput id='email'
label='Электронная почта'
allowEnter
value={email}
onChange={event => setEmail(event.target.value)}
/>
</div>
<div className='flex justify-center w-full'>
<SubmitButton
text='Сохранить данные'
loading={processing}
disabled={!isModified}
/>
</div>
</form>
2023-08-26 17:26:49 +03:00
)
}
export default EditorProfile;