Custom Validation
data:image/s3,"s3://crabby-images/d7c32/d7c32c0fb95774b366c81639938fd44bbb0c3573" alt=""
data:image/s3,"s3://crabby-images/b21ac/b21ac2547b1068c59f0d9296bdf1bf662176c741" alt=""
data:image/s3,"s3://crabby-images/64141/641410970bf8a73069cae595f3dd4b3e4e00a17e" alt=""
data:image/s3,"s3://crabby-images/c3985/c39858ec4027dd26558f1986bf6f3bdc1f99db92" alt=""
data:image/s3,"s3://crabby-images/b42d8/b42d81140cfc56c87583b93290bacd6a03584384" alt=""
data:image/s3,"s3://crabby-images/3c686/3c6861eac74c8c66ca6fb51ef164892a0394203c" alt=""
data:image/s3,"s3://crabby-images/0cd85/0cd856c96a5c9e35d08a1e0d8dd05aad763d532a" alt=""
Start of documentation contentUse of
Allows custom validation rules in JavaScript with the onValidation
prop.
Use of onValidation
import { Formally, getNodeByName } from 'formally';
<Formally
onValidation={async ({
values,
errors: oldErrors,
hasErrors: oldHasErrors,
formallyData,
}) => {
const newErrors = oldErrors;
let newHasErrors = oldHasErrors;
// First get the Component (aka Node).
// You can use the 'name' attribute as a selector
const dobNode = getNodeByName(formallyData, 'dob');
if (dobNode) {
// Then get the value
const dobValue = values[dobNode.id];
if (typeof dobValue === 'string' && dobValue !== '') {
// Apply custom validation
if (!dobValue.match(/^\d\d\/\d\d\/\d\d\d\d$/)) {
newErrors[dobNode.id] = {
type: 'invalid',
message: '',
};
newHasErrors = true;
}
}
}
return { errors: newErrors, hasErrors: newHasErrors };
}}
/>;