Modifiers
Modifiers allow you to control the behavior and settings of validation rules in your application. They can be applied globally to all fields or customized per field.
Deep modifiers
Deep modifiers are specified as the third argument of the useRegle
composable. They apply recursively to all fields within your state.
const { r$ } = useRegle({}, {}, {""})
autoDirty
Type: boolean
Default: true
Automatically tracks changes in the state for all nested rules. If set to false
, you must manually call $touch
to mark fields as dirty.
lazy
Type: boolean
Default: false
Usage:
When set to false, tells the rules to be called on init, otherwise they are lazy and only called when the field is dirty.
externalErrors
Type: RegleExternalErrorTree<State>
Pass an object, matching your error state, that holds external validation errors. These can be from a backend validations or something else.
import { type RegleExternalErrorTree, useRegle } from '@regle/core'
const form = reactive({
email: '',
name: {
pseudo: '',
}
})
const externalErrors = ref<RegleExternalErrorTree<typeof form>>({});
const { r$ } = useRegle(form, {
email: { required },
name: {
pseudo: { required }
}
}, { externalErrors })
function submit() {
externalErrors.value = {
email: ["Email already exists"],
name: {
pseudo: ["Pseudo already exists"]
}
}
}
Result:
rewardEarly
Type: boolean
Default: false
Side effect: disable $autoDirty
when true
.
Enables the reward-early-punish-late
mode of Regle. This mode will not set fields as invalid once they are valid, unless manually triggered by or $validate
method.
This will have no effect only if you use autoDirty: true
.
clearExternalErrorsOnChange
Type: boolean
Default: true
This mode is similar to rewardEarly
, but only applies to external errors. Setting it to false
will keep the server errors until $clearExternalErrors
is called.
validationGroups
Type: (fields) => Record<string, (RegleFieldStatus |RegleCollectionStatus)[]>
Validation groups let you merge field properties under one, to better handle validation status.
You will have access to your declared groups in the r$.$groups
object.
import { useRegle } from '@regle/core';
import { required } from '@regle/rules';
const { r$ } = useRegle({ email: '', user: { firstName: '' } }, {
email: { required },
user: {
firstName: { required },
}
}, {
validationGroups: (fields) => ({
group1: [fields.email, fields.user.$fields.firstName]
})
})
r$.$groups.group1.
Per-field modifiers
Per-field modifiers allow to customize more precisely which behavior you want for each field.
const { r$ } = useRegle({ name: '' }, {
name: { $ }
})
$autoDirty
$lazy
and $rewardEarly
work the same as the deep modifiers.
$debounce
Type: number
(ms)
This let you declare the number of milliseconds the rule needs to wait before executing. Useful for async or heavy computations.
TIP
All async rules have a default debounce of 200ms
, you can disable or modify this setting with $debounce