Sobes.tech
Назад к вопросам
Middle
2

#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 "Sign Up" 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.

Компании, где спрашивали
Mayflower

Ответ от нейросети

sobes.tech AI

  1. StateProvider — это компонент, который обычно используется для управления глобальным состоянием приложения в React, часто с использованием Context API. Он предоставляет состояние и методы его изменения всем вложенным компонентам, позволяя избежать "проброса" пропсов через множество уровней.

  2. В папке /src/api/mock обычно размещаются моки API — имитация серверных ответов для разработки и тестирования без реального бэкенда. Это может быть набор функций, возвращающих промисы с фиктивными данными или задержкой, чтобы симулировать реальные запросы.

  3. Чтобы исправить цвет кнопки SubmitButton, нужно проверить стили, которые к ней применяются, и убедиться, что цвет соответствует дизайну. Например, если используется Material-UI, можно задать цвет через проп color или через sx/style:

<SubmitButton color="primary">Sign Up</SubmitButton>
  1. Для валидации формы в компоненте Signup при клике на кнопку "Sign Up" нужно:
  • Проверить длину каждого поля (не менее 6 символов)
  • Проверить, что пароль совпадает с повтором
  • Отметить поля с ошибками, используя error и helperText (например, в TextField из Material-UI)

Пример валидации:

const [errors, setErrors] = React.useState({});

const validate = () => {
  const newErrors = {};
  if (username.length < 6) newErrors.username = 'Минимум 6 символов';
  if (email.length < 6) newErrors.email = 'Минимум 6 символов';
  if (password.length < 6) newErrors.password = 'Минимум 6 символов';
  if (repeatPassword.length < 6) newErrors.repeatPassword = 'Минимум 6 символов';
  if (password !== repeatPassword) {
    newErrors.password = 'Пароли не совпадают';
    newErrors.repeatPassword = 'Пароли не совпадают';
  }
  setErrors(newErrors);
  return Object.keys(newErrors).length === 0;
};

const handleSubmit = () => {
  if (validate()) {
    // отправка данных
  }
};
  1. Если API возвращает ошибку для конкретного поля, нужно отобразить её рядом с этим полем, например, обновив состояние ошибок:
setErrors(prev => ({ ...prev, [field]: apiErrorMessage }));
  1. Компонент UserName должен получать новое имя пользователя из состояния после успешной регистрации и рендерить его. Это можно сделать через пропсы или глобальный стейт.

  2. Новый компонент SignupSuccess — простой компонент, который отображается вместо формы после успешной регистрации:

function SignupSuccess() {
  return <div>Регистрация прошла успешно! Добро пожаловать!</div>;
}
  1. Серверная валидация — это проверка данных на бэкенде. Клиент должен отправлять данные, а сервер возвращать ошибки, если они есть. Клиент обрабатывает эти ошибки и отображает их пользователю. Это важно для безопасности и целостности данных.