mirror of
https://github.com/naturalcrit/homebrewery.git
synced 2026-01-06 12:12:42 +00:00
fix issue with async setState using Event.persist()
This commit is contained in:
@@ -56,6 +56,7 @@ const MetadataEditor = createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
handleFieldChange : function(name, e){
|
handleFieldChange : function(name, e){
|
||||||
|
e.persist();
|
||||||
const inputRules = validations[name] ?? [];
|
const inputRules = validations[name] ?? [];
|
||||||
const validationErr = inputRules.map((rule)=>rule(e.target.value)).filter(Boolean);
|
const validationErr = inputRules.map((rule)=>rule(e.target.value)).filter(Boolean);
|
||||||
this.setState((prevState)=>({
|
this.setState((prevState)=>({
|
||||||
@@ -63,20 +64,22 @@ const MetadataEditor = createClass({
|
|||||||
...(prevState.errs ?? {}),
|
...(prevState.errs ?? {}),
|
||||||
[name] : validationErr.length > 0 ? validationErr : undefined
|
[name] : validationErr.length > 0 ? validationErr : undefined
|
||||||
}
|
}
|
||||||
}));
|
}), ()=>{
|
||||||
if(Object.values(this.state.errs ?? {}).filter(Boolean).length === 0){
|
if(Object.values(this.state.errs ?? {}).filter(Boolean).length === 0){
|
||||||
e.target.setCustomValidity('');
|
e.target.setCustomValidity('');
|
||||||
this.props.onChange({
|
this.props.onChange({
|
||||||
...this.props.metadata,
|
...this.props.metadata,
|
||||||
[name] : e.target.value
|
[name] : e.target.value
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
const errMessage = this.state.errs[name].map((err)=>{
|
const errMessage = this.state.errs[name].map((err)=>{
|
||||||
return `- ${err}`;
|
return `- ${err}`;
|
||||||
}).join('\n');
|
}).join('\n');
|
||||||
e.target.setCustomValidity(errMessage);
|
e.target.setCustomValidity(errMessage);
|
||||||
e.target.reportValidity();
|
e.target.reportValidity();
|
||||||
};
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user