Built-in rules
All built-in rules are available through the @regle/rules
package.
Don't forget to install it if you haven't:
pnpm add @regle/rules
npm install @regle/rules
yarn add @regle/rules
bun add @regle/rules
TIP
Every built-in rule will check if the value of the field is set before checking if it's valid.
This allow to have rules even if the field is not required.
alpha
Allows only alphabetic characters.
alphaNum
Allows only alphanumeric characters.
between
Params
min: Ref<number> | number | () => number
max: Ref<number> | number | () => number
Checks if a number is in specified bounds. min
and max
are both inclusive.
import { between } from '@regle/rules';
const maxCount = ref(6);
const { r$ } = useRegle({ count: 0 }, {
count: {
between: between(1, 6),
between: between(1, maxCount),
between: between(() => maxCount.value, 10)
},
})
checked
Requires a boolean value to be true
. This is useful for checkbox inputs.
contains
Params
contain: Ref<string> | string | () => string
Checks if the string contains the specified substring.
dateAfter
Params
after: Ref<string | Date> | string | Date | () => string | Date
Checks if the date is after the given parameter.
Metadata
| true
| {
$valid: false;
error: 'date-not-after';
}
| {
$valid: false;
error: 'value-or-paramater-not-a-date';
}
dateBefore
Params
before: Ref<string | Date> | string | Date | () => string | Date
Checks if the date is before the given parameter.
Metadata
| true
| {
$valid: false;
error: 'date-not-before';
}
| {
$valid: false;
error: 'value-or-paramater-not-a-date';
}
dateBetweeen
Params
before: Ref<string | Date> | string | Date | () => string | Date
after: Ref<string | Date> | string | Date | () => string | Date
Checks if the date falls between the specified bounds.
decimal
Allows positive and negative decimal numbers.
email
Validates email addresses. Always verify on the server to ensure the address is real and not already in use.
endsWith
Params
end: Ref<string> | string | () => string
Checks if the string ends with the specified substring.
exactLength
Params
count: Ref<number> | number | () => number
Requires the input value to have a strict specified length, inclusive. Works with arrays, objects and strings.
import { exactLength } from '@regle/rules';
const exactValue = ref(6);
const { r$ } = useRegle({ name: '' }, {
name: {
exactLength: exactLength(6),
exactLength: exactLength(exactValue),
exactLength: exactLength(() => exactValue.value)
},
})
exactValue
Params
count: Ref<number> | number | () => number
Requires a field to have a strict numeric value.
import { exactValue } from '@regle/rules';
const exactCount = ref(6);
const { r$ } = useRegle({ count: 0 }, {
count: {
exactValue: exactValue(6),
exactValue: exactValue(exactCount),
exactValue: exactValue(() => exactCount.value)
},
})
integer
Allows only integers (positive and negative).
ipAddress
Validates IPv4 addresses in dotted decimal notation 127.0.0.1.
macAddress
Params
separator?: string | Ref<string> | () => string
Validates MAC addresses. Call as a function to specify a custom separator (e.g., ':' or an empty string for 00ff1122334455).
import { macAddress } from '@regle/rules';
const maxCount = ref(6);
const { r$ } = useRegle({ address: '' }, {
address: {
macAddress: macAddress(),
},
})
maxLength
Params
max: Ref<number> | number | () => number
Works with
Array | Record | string | number
Requires the input value to have a maximum specified length, inclusive. Works with arrays, objects and strings.
import { maxLength } from '@regle/rules';
const maxValue = ref(6);
const { r$ } = useRegle({ name: '' }, {
name: {
maxLength: maxLength(6),
maxLength: maxLength(maxValue),
maxLength: maxLength(() => maxValue.value)
},
})
maxValue
Params
min: Ref<number> | number | () => number
Requires a field to have a specified maximum numeric value.
import { maxValue } from '@regle/rules';
const maxCount = ref(6);
const { r$ } = useRegle({ count: 0 }, {
count: {
maxValue: maxValue(6),
maxValue: maxValue(maxCount),
maxValue: maxValue(() => maxCount.value)
},
})
minLength
Params
min: Ref<number> | number | () => number
Works with
Array | Record | string | number
Requires the input value to have a minimum specified length, inclusive. Works with arrays, objects and strings.
import { minLength } from '@regle/rules';
const minValue = ref(6);
const { r$ } = useRegle({ name: '' }, {
name: {
minLength: minLength(6),
minLength: minLength(minValue),
minLength: minLength(() => minValue.value)
},
})
minValue
Params
min: Ref<number> | number | () => number
Works with
number
Requires a field to have a specified minimum numeric value.
import { minValue } from '@regle/rules';
const minCount = ref(6);
const { r$ } = useRegle({ count: 0 }, {
count: {
minValue: minValue(6),
minValue: minValue(minCount),
minValue: minValue(() => minCount.value)
},
})
nativeEnum
Validate against a native Typescript enum value. Similiar to Zod's nativeEnum
numeric
Allows only numeric values (including numeric strings).
oneOf
Allow only one of the values from a fixed Array of possible entries.
Params
options: MaybeRefOrGetter<Array<string | number>>
import { oneOf } from '@regle/rules';
const { r$ } = useRegle({ aliment: 'Fish' }, {
aliment: {
oneOf: oneOf(['Fish', 'Meat', 'Bone'])
},
})
regex
Params
...regexps: [...Ref<RegExp> | RegExp | () => RegExp]
Checks if the value matches one or more regular expressions.
required
Requires non-empty data. Checks for empty arrays and strings containing only whitespaces.
import {required} from '@regle/rules';
const {r$} = useRegle({name: ''}, {
name: {required},
})
requiredIf
Params
condition: Ref<unknown> | unknown | () => unknown
- the property to base therequired
validator on.
Requires non-empty data, only if provided data property, ref, or a function resolves to true
.
import { requiredIf } from '@regle/rules';
const form = ref({ name: '', condition: false });
const conditionRef = ref(false);
const { r$ } = useRegle(form, {
name: {
required: requiredIf(() => form.value.condition),
required: requiredIf(conditionRef),
},
})
requiredUnless
Params
condition: Ref<unknown> | unknown | () => unknown
- the property to base therequired
validator on.
Requires non-empty data, only if provided data property, ref, or a function resolves to false
.
import { requiredUnless } from '@regle/rules';
const form = ref({ name: '', condition: false });
const conditionRef = ref(false);
const { r$ } = useRegle(form, {
name: {
required: requiredUnless(() => form.value.condition),
required: requiredUnless(conditionRef)
},
})
sameAs
Params
target: unknown
Checks if the value matches the specified property or ref.
import { sameAs } from '@regle/rules';
const form = ref({
password: '',
confirmPassword: '',
});
const { r$ } = useRegle(form, {
confirmPassword: {
sameAs: sameAs(() => form.value.password),
}
})
startsWith
Params
start: Ref<string> | string | () => string
Checks if the string starts with the specified substring.
url
Validates URLs.