Sobes.tech
Back to questions
Middle
1

#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.

Companies where asked
Mayflower

Answer from AI

sobes.tech AI

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

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

  3. Чтобы исправить цвет кнопки SubmitButton, нужно проверить стили или пропсы, которые ей передаются, и убедиться, что цвет соответствует дизайну. Например, если цвет задан через CSS-класс, проверить правильность класса или заменить inline-стиль.

  4. Для валидации формы в компоненте Signup при клике на кнопку "Sign Up" нужно:

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 нужно отображать сообщения рядом с соответствующими полями, например, обновляя состояние ошибок.

  2. После успешной отправки обновлять компонент UserName, чтобы отобразить новый username.

  3. Компонент SignupSuccess должен показываться вместо формы после успешной регистрации, например, через условный рендеринг.

  4. Серверная валидация — это проверка данных на backend, которая возвращает ошибки, если данные некорректны. Клиент должен обрабатывать эти ошибки и отображать их пользователю.