Added some basic shared components, utils, hooks

This commit is contained in:
ireic
2019-12-08 03:49:49 +01:00
parent 6be3ac2e77
commit 3143f66a0f
82 changed files with 40121 additions and 5 deletions

View File

@@ -0,0 +1,36 @@
export const is = {
match: (testFn, message = '') => (value, fieldValues) => !testFn(value, fieldValues) && message,
required: () => value => isNilOrEmptyString(value) && 'This field is required',
minLength: min => value => !!value && value.length < min && `Must be at least ${min} characters`,
maxLength: max => value => !!value && value.length > max && `Must be at most ${max} characters`,
notEmptyArray: () => value =>
Array.isArray(value) && value.length === 0 && 'Please add at least one item',
email: () => value => !!value && !/.+@.+\..+/.test(value) && 'Must be a valid email',
url: () => value =>
!!value &&
// eslint-disable-next-line no-useless-escape
!/^(?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~:/?#[\]@!\$&'\(\)\*\+,;=.]+$/.test(value) &&
'Must be a valid URL',
};
const isNilOrEmptyString = value => value === undefined || value === null || value === '';
export const generateErrors = (fieldValues, fieldValidators) => {
const errors = {};
Object.entries(fieldValidators).forEach(([fieldName, validators]) => {
[validators].flat().forEach(validator => {
const errorMessage = validator(fieldValues[fieldName], fieldValues);
if (errorMessage && !errors[fieldName]) {
errors[fieldName] = errorMessage;
}
});
});
return errors;
};