@stacksjs/ts-validation
Version:
A simple TypeScript starter kit using Bun.
79 lines (72 loc) • 1.89 kB
TypeScript
import type { IntegerValidatorType, ValidationNames } from '../types';
export declare class IntegerValidator extends NumberValidator implements IntegerValidatorType {
public name: ValidationNames = 'integer'
constructor() {
super()
this.rules = this.rules.filter(rule => rule.name !== 'number')
this.addRule({
name: 'integer',
test: (value: number) => {
if (typeof value !== 'number' || Number.isNaN(value) || !Number.isFinite(value)) {
return false
}
return Number.isInteger(value)
},
message: 'Must be a valid integer',
})
}
min(min: number): this {
return this.addRule({
name: 'min',
test: (value: number) => {
if (typeof value !== 'number')
return false
return value >= min
},
message: 'Must be at least {min}',
params: { min },
})
}
max(max: number): this {
return this.addRule({
name: 'max',
test: (value: number) => {
if (typeof value !== 'number')
return false
return value <= max
},
message: 'Must be at most {max}',
params: { max },
})
}
positive(): this {
return this.addRule({
name: 'positive',
test: (value: number) => {
if (typeof value !== 'number')
return false
return value > 0
},
message: 'Must be a positive integer',
})
}
negative(): this {
return this.addRule({
name: 'negative',
test: (value: number) => {
if (typeof value !== 'number')
return false
return value < 0
},
message: 'Must be a negative integer',
})
}
custom(fn: (value: number) => boolean, message: string): this {
return this.addRule({
name: 'custom',
test: fn,
message,
})
}
}
export declare function integer(): IntegerValidator;