lakmus-michaelmyers
TypeScript icon, indicating that this package has built-in type declarations

0.3.0 • Public • Published

Lakmus

Fluent validation in TypeScript.

Features

  • 20+ built-in validators
  • Refactoring-friendly (generic property selectors)
  • Multilanguage

Inspired by .NET FluentValidation

Demo

export class Person {
    public id: number;
    public name: string;
    public address: Address;
    public phoneNumbers: PhoneNumber[];
    public hasDiscount: boolean;
    public discountValue: number;
}
 
export class Address {
    public country: string;
    public city: string;
    public street: string;
    public houseNumber: string;
}
 
export class PhoneNumber {
    public country: string;
    public code: string;
    public number: string;
}
 
export class PersonValidator extends Validator<Person> {
    constructor() {
        super();
 
        // not null & max length;
        this.ruleFor(x => x.name)
            .notNull()
            .maxLength(100);
 
        // nested objection validation;
        this.ruleFor(x => x.address)
            .notNull()
            .setValidator(new AddressValidator());
 
        // collection validation;
        this.ruleFor(x => x.phoneNumbers)
            .notNull()
            .setCollectionValidator(new PhoneNumberValidator());
 
        this.when(x => x.hasDiscount, () => {
            this.ruleFor(x => x.discountValue)
                .notNull();
        });
    }
}
 
export class AddressValidator extends Validator<Address> {
    constructor() {
        super();
 
        this.ruleFor(x => x.city)
            .notNull().maxLength(50);
 
        this.ruleFor(x => x.street)
            .notNull().maxLength(50);
    }
}
 
export class PhoneNumberValidator extends Validator<PhoneNumber> {
    constructor() {
        super();
 
        this.ruleFor(x => x.country)
            .notNull().maxLength(3);
 
        this.ruleFor(x => x.code)
            .notNull().maxLength(5);
 
        // predicate and custom error message;
        this.ruleFor(x => x.number)
            .notNull().maxLength(7)
            .must((number, phoneNumber) => (phoneNumber.code || "").length + (phoneNumber.country || "").length + (phoneNumber.number || "").length == 11)
            .withMessage("Please enter a valid phone number.");
    }
}
 
// set custom property name resolver: discountValue -> Discount Value
ValidatorOptions.propertyNameResolver = ApStyleTitleCasePropertyNameResolver;
 
// initialize object to validate;
var person = new Person();
 
// create validator;
var validator = new PersonValidator();
// or get it from factory (recommended) 
validator = ValidatorFactory.getValidator(PersonValidator);
 
// validate;
var result = validator.validate(person);
 
// process result;
if (result.isValid) {
    console.log("Is valid.");
}
else {
    console.log(result.errors.map(x => x.errorMessage).join("\n"));
}

License

MIT

Package Sidebar

Install

npm i lakmus-michaelmyers

Weekly Downloads

1

Version

0.3.0

License

MIT

Last publish

Collaborators

  • michaelmyers