Привязка страницы не работает должным образом для поля TextValidator первой ошибки, используемого из response-material-ui-form-validator только в браузере firefox
Я работаю над проектом React и использую TextValidators для полей ввода. Когда я отправляю форму, привязка не идет к первому полю ввода ошибки (TextValidator) должным образом в браузере Firefox(это означает, что поле ошибки не отображается полностью). Он отлично работает в браузерах Chrome и Safari. Я использую document.getElementById(validationErrors[index].props.id).focus();для фокуса в поле ввода первой ошибки. Есть ли за этим какая-то причина?
код:
import React from 'react';
import { Button, Typography } from '@material-ui/core';
import { TextValidator, ValidatorForm } from 'react-material-ui-form-validator';
const Textfields = () => {
const [value, setValue] = React.useState({
name: '',
email: '',
phone: '',
address: ''
});
const handleSubmit = (e) => {
e.preventDefault();
};
ValidatorForm.addValidationRule('required', (value) => {
if (value) {
return true;
}
else if (value === null) {
return true;
}
else {
return false;
}
});
const handleErrors = (errors) => {
let validationErrors = errors;
console.log(validationErrors)
for (let index = 0; index < validationErrors.length; index++) {
if (validationErrors[index].state.isValid === false) {
if ((validationErrors[index].props.id) === "name") {
document.getElementById(validationErrors[index].props.id).focus();
return;
}
}
if (validationErrors[index].state.isValid === false) {
if ((validationErrors[index].props.id) === "email") {
document.getElementById(validationErrors[index].props.id).focus({ preventScroll: false });
return;
}
}
if (validationErrors[index].state.isValid === false) {
if ((validationErrors[index].props.id) === "phone") {
document.getElementById(validationErrors[index].props.id).focus({ preventScroll: false });
return;
}
}
if (validationErrors[index].state.isValid === false) {
if ((validationErrors[index].props.id) === "address") {
document.getElementById(validationErrors[index].props.id).focus({ preventScroll: false });
return;
}
}
}
};
return (
<div>
<Typography variant="h5">Validations</Typography>
<div>
<ValidatorForm
// ref="form"
onSubmit={handleSubmit}
onError={handleErrors}
>
<div style={{ marginTop: '400px' }}>
<TextValidator
key={1}
label="Name"
value={value.name}
onChange={(e) => setValue({ ...value, name: e.target.value })}
// name="name"
validators={["required"]}
errorMessages={['This field is required.']}
id="name"
/>
</div>
<div style={{ marginTop: '400px' }}>
<TextValidator
label="Email"
onChange={(e) => setValue({ ...value, email: e.target.value })}
name="email"
id="email"
value={value.email}
validators={["required"]}
errorMessages={['This field is required.']}
/>
</div>
<div style={{ marginTop: '400px' }}>
<TextValidator
label="Phone"
onChange={(e) => setValue({ ...value, phone: e.target.value })}
name="phone"
id="phone"
value={value.phone}
validators={["required"]}
errorMessages={['This field is required.']}
/>
</div>
<div style={{ marginTop: '400px' }}>
<TextValidator
label="address"
onChange={(e) => setValue({ ...value, address: e.target.value })}
name="address"
id="address"
value={value.address}
validators={["required"]}
errorMessages={['This field is required.']}
/>
</div>
<div>
<Button type="submit" style={{ marginTop: '20px', marginBottom: '20px' }}>Submit</Button>
</div>
</ValidatorForm>
</div >
</div>
)
}
export default Textfields
Ссылка на песочницу: https://codesandbox.io/s/basiccard-material-demo-forked-rswoi?file=/demo.js