Skip to content

Built-in rules

All built-in rules are available through the @regle/rules package.

Don't forget to install it if you haven't:

sh
pnpm add @regle/rules
sh
npm install @regle/rules
sh
yarn add @regle/rules
sh
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.

ts
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

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

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

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

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

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

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

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

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

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

ts
import {required} from '@regle/rules';

const {r$} = useRegle({name: ''}, {
  name: {required},
})

requiredIf

Params

  • condition: Ref<unknown> | unknown | () => unknown - the property to base the required validator on.

Requires non-empty data, only if provided data property, ref, or a function resolves to true.

ts
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 the required validator on.

Requires non-empty data, only if provided data property, ref, or a function resolves to false.

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

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

Released under the MIT License. Logo by Johannes Lacourly