@modular-forms/react
Version:
The modular and type-safe form library for React
34 lines (33 loc) • 1.33 kB
JavaScript
import { batch } from '@preact/signals-react';
import { getFieldArrayStore, getFieldStore, updateFormInvalid } from '../utils';
import { focus } from './focus';
/**
* Sets the error of the specified field or field array.
*
* @param form The form of the field.
* @param name The name of the field.
* @param error The error message.
* @param options The error options.
*/
export function setError(form, name, error, { shouldActive = true, shouldTouched = false, shouldDirty = false, shouldFocus = !!error, } = {}) {
batch(() => {
for (const fieldOrFieldArray of [
getFieldStore(form, name),
getFieldArrayStore(form, name),
]) {
if (fieldOrFieldArray &&
(!shouldActive || fieldOrFieldArray.active.peek()) &&
(!shouldTouched || fieldOrFieldArray.touched.peek()) &&
(!shouldDirty || fieldOrFieldArray.dirty.peek())) {
// Set error to field or field array
fieldOrFieldArray.error.value = error;
// Focus element if set to "true"
if (error && 'value' in fieldOrFieldArray && shouldFocus) {
focus(form, name);
}
}
}
// Update invalid state of form
updateFormInvalid(form, !!error);
});
}