onSubmit не работает в `react-material-ui-form-validator`
я использую
react-material-ui-form-validator
в моем проекте. Но не срабатывает, когда я отправляю форму. Я много пробовал, но не смог решить проблему. Я не мог понять почему
onSubmit
не работают. Кто-нибудь может это объяснить?
State
constructor(props) {
super(props);
this.form = React.createRef();
this.state = {
open: false,
currentColor: 'purple',
newName: '',
colors: [],
};
}
Validation Rule & handling events
componentDidMount() {
const { colors, currentColor } = this.state;
ValidatorForm.addValidationRule('isColorNameUnique', (value) => {
colors.every(({ name }) => name.toLowerCase() !== value.toLowerCase());
});
// eslint-disable-next-line no-unused-vars
ValidatorForm.addValidationRule('isColorUnique', (value) => {
colors.every(({ color }) => color !== currentColor);
});
}
addNewColor = (event) => {
event.preventDefault();
const { currentColor, colors, newName } = this.state;
const newColor = { color: currentColor, name: newName };
this.setState({ colors: [...colors, newColor], newName: '' });
};
handleChange = (evt) => {
this.setState({ newName: evt.target.value });
};
Validator Form
<ValidatorForm onSubmit={this.addNewColor} ref={this.form}>
<TextValidator
className={classes.textValidator}
value={newName}
placeholder="Color Name"
variant="filled"
margin="normal"
onChange={this.handleChange}
validators={['required', 'isColorNameUnique', 'isColorUnique']}
errorMessages={[
'this field is required',
'Color name must be Unique',
'Color already used',
]}
/>
<Button
className={classes.buttonCenter}
type="submit"
variant="contained"
color="primary"
style={{ backgroundColor: `${currentColor}` }}
>
Add Color
</Button>
</ValidatorForm>
1 ответ
Я исправил проблему. Раньше он не возвращал
true or false
значение вместо этого он вернул
undefined
. Теперь код вернет либо
true
или же
false
componentDidMount() {
ValidatorForm.addValidationRule('isColorNameUnique', (value) =>
// eslint-disable-next-line react/destructuring-assignment
this.state.colors.every(({ name }) => name.toLowerCase() !== value.toLowerCase())
);
ValidatorForm.addValidationRule('isColorUnique', () =>
// eslint-disable-next-line react/destructuring-assignment
this.state.colors.every(({ color }) => color !== this.state.currentColor)
);
}