#React signup form 1. Explain how StateProvider works, share your thoughts with interviewer. 2. Take a look at /src/api/mock, explain how it works. 3. Check SubmitButton color and fix it 4. Implement client form validation in Signup component. (\*) Keep in mind task number 9. Rules: - Username, Email, Password, Repeat Password fields should have at least 6 characters length; - Password should match Repeat Password; - Validation should be done upon "SignUp" button click; - Fields that have invalid values should be marked (error and helperText props); 6. API response may have an error that should be displayed to user near corresponding field. 7. Make sure that UserName component renders new username after successful submit. 8. Implement the new SignupSuccess component. It should be shown instead of sign up form. 9. Implement server validation for appropriate fields. --- Code from mock.ts: ```typescript const fakeResponse = (userName) => ({ code: 200, user: { id: 42, userName, }, }); let a = 0; const api = { '/signup': function (userName: string, email: string, password: string) { a++; return new Promise((resolve, reject) => { setTimeout(() => { if (a % 2 === 0) { return resolve(fakeResponse(userName)); } else { return reject( new Error( `Username "${userName}" is already taken. Please try another one.` ) ); } }, 500); }); }, }; export default api; ```
Answer from AI
sobes.tech AI
-
StateProvider — это компонент, который предоставляет контекст состояния для дочерних компонентов. Он использует React Context API, чтобы хранить и передавать состояние и методы его изменения, позволяя избежать проп-дриллинга и централизовать управление состоянием.
-
В
/src/api/mockреализован мок API, который имитирует асинхронный запрос на сервер. Функция/signupпринимает данные пользователя и возвращает промис, который через 500 мс либо резолвится с успешным ответом, либо реджектится с ошибкой, имитируя ситуацию, когда имя пользователя уже занято (чередуется по вызовам). -
Чтобы исправить цвет кнопки SubmitButton, нужно проверить стили компонента и убедиться, что цвет соответствует дизайну. Например, если цвет задан через пропсы, исправить значение цвета на нужное.
-
Для валидации в компоненте Signup при клике на кнопку "SignUp" нужно проверить:
- Длина полей Username, Email, Password, Repeat Password >= 6
- Password и Repeat Password совпадают
Поля с ошибками пометить с помощью props error и helperText.
Пример валидации:
const validate = () => {
const errors = {};
if (username.length < 6) errors.username = 'Минимум 6 символов';
if (email.length < 6) errors.email = 'Минимум 6 символов';
if (password.length < 6) errors.password = 'Минимум 6 символов';
if (repeatPassword.length < 6) errors.repeatPassword = 'Минимум 6 символов';
if (password !== repeatPassword) errors.repeatPassword = 'Пароли не совпадают';
setErrors(errors);
return Object.keys(errors).length === 0;
};
const handleSubmit = () => {
if (!validate()) return;
// отправка данных
};
-
Если API возвращает ошибку, её нужно отобразить рядом с соответствующим полем, например, если имя пользователя занято — показать ошибку у поля Username.
-
После успешной регистрации компонент UserName должен обновиться и отобразить новое имя пользователя, полученное из ответа API.
-
Компонент SignupSuccess отображается вместо формы после успешной регистрации, показывая сообщение об успешном завершении.
-
Серверная валидация реализована в мок API: при каждом втором запросе возвращается ошибка, что имя пользователя занято. Клиент должен корректно обрабатывать эту ошибку и показывать пользователю.
Таким образом, задача включает работу с состоянием, валидацией, обработкой ошибок и отображением разных состояний UI.