Skip to content

Displaying errors

Regle is a headless library, allowing you to display error messages in any way you choose. You can also use its internal state to apply classes or trigger behaviors dynamically.

Showing errors messages

You can display your errors by iterating though r$.$errors.xxx, xxx being the field you need to check.

You can also access r$.$fields.xxx.$errors or r$.$fields.xxx.$silentErrors.

App.vue
vue
<template>
  <
input
v-model='
r$
.
$value
.
email
'
:
class
="{
error
:
r$
.
$fields
.
email
.
$error
}"
placeholder
='Type your email'
/> <
li
v-for="
error
of
r$
.
$errors
.
email
"
:
key
='
error
'>
{{
error
}}
</
li
>
</template> <script setup lang='ts'> import {
useRegle
} from '@regle/core';
import {
required
,
minLength
,
email
} from '@regle/rules';
const {
r$
} =
useRegle
({
email
: '' }, {
email
: {
required
,
email
,
minLength
:
minLength
(4)}
}) </script>

Result:

Applying an error and valid class

App.vue
vue
<template>
  <
input
:
class
="{
error
:
r$
.
$fields
.
email
.
$error
,
valid
:
r$
.
$fields
.
email
.
$correct
}" v-model='
r$
.
$value
.
email
'
placeholder
='Type your email'
/> <
ul
>
<
li
v-for="
error
of
r$
.
$errors
.
email
"
:
key
='
error
'>
{{
error
}}
</
li
>
</
ul
>
</template> <script setup lang='ts'> import {
useRegle
} from '@regle/core';
import {
required
,
minLength
,
email
} from '@regle/rules';
import {
ref
} from 'vue';
const {
r$
} =
useRegle
({
email
: '' }, {
email
: {
required
,
minLength
:
minLength
(4),
email
}
}) </script> <style> input.error { border-color: red; } input.valid { border-color: green; } </style>

Result:

Display flat errors

If you want to display the complete list of errors of a form, or the total count of errors, you can use the flatErrors utility.

It will return an array of error strings.

ts
import { 
flatErrors
,
useRegle
} from '@regle/core';
import {
email
,
minLength
,
required
} from '@regle/rules';
const {
r$
} =
useRegle
(
{
name
: '',
level0
: {
email
: 'bar' } },
{
name
: {
required
,
minLength
:
minLength
(5) },
level0
: {
email
: {
email
},
}, } );
r$
.
$validate
();
const
flattenErrors
=
flatErrors
(
r$
.
$errors
);
// [ // "This field is required", // "Value must be an valid email address" // ]

includePath option

This helper also include an option to have the path of the property (compatible with lodash get) next to the error.

ts
import { 
flatErrors
,
useRegle
} from '@regle/core';
import {
email
,
minLength
,
required
} from '@regle/rules';
const {
r$
} =
useRegle
(
{
name
: '',
level0
: {
email
: 'bar' } },
{
name
: {
required
,
minLength
:
minLength
(5) },
level0
: {
email
: {
email
},
}, } );
r$
.
$validate
();
const
flattenErrors
=
flatErrors
(
r$
.
$errors
, {
includePath
: true});
// [ // { error: "This field is required", path: "name" }, // { error: "Value must be an valid email address", path: "level0.email"} // ]

Released under the MIT License. Logo by Johannes Lacourly