Skip to content

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.

ts
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.

ts
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.

ts
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.

ts
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

Released under the MIT License. Logo by Johannes Lacourly