Skip to content

Latest commit

 

History

History
160 lines (108 loc) · 3.88 KB

README.md

File metadata and controls

160 lines (108 loc) · 3.88 KB

FluntJS

Build Status Coverage Status License: MIT

What is Flunt?

Inspired in Flunt, Every app has business rules and validations, and you probably will need to keep all the errors and notifications that happened and send it to somewhere, maybe to your UI.

Flunt implements the Notification Pattern and helps you to track everything that happend, consolidating your notifications and making it easy to access and manipulate.

Installation

$ npm install flunt-js --save

How to use

ES6

import Flunt from 'flunt-js';

// extends your class to Flunt.Notifiable
class Customer extends Flunt.Notifiable{

  constructor(name, lastname, age){
    super()
    this.name = name;
    this.lastname = lastname;
    this.age = age;

    super.AddNotifications(
      new Flunt.Contract()
        .isRequired(name, "Name", "Name is required")
        .isRequired(lastname, "Lastname", "Lastname is required")
        .isGreaterThan(age, 18, "Age", "You need more than 18 years")
    )
  }
}

// instance class
var customer = new Customer(null, "Goncalves", 10);

// take your messages
customer.notifications.forEach(element => {
  console.log(element.message)
});

//take all notifications
console.log(customer.notifications)

ES5

const Flunt = require('flunt-js');

// extends your class to Flunt.Notifiable
class Customer extends Flunt.Notifiable{

  constructor(name, lastname, age){
    super()
    this.name = name;
    this.lastname = lastname;
    this.age = age;

    super.AddNotifications(
      new Flunt.Contract()
        .isRequired(name, "Name", "Name is required")
        .isRequired(lastname, "Lastname", "Lastname is required")
        .isGreaterThan(age, 18, "Age", "You need more than 18 years")
    )
  }
}

// To use class
module.exports = Customer

// instance class
var customer = new Customer(null, "Goncalves", 10);

// take your messages
customer.notifications.forEach(element => {
  console.log(element.message)
});

//take all notifications
console.log(customer.notifications)

Methods

Follow the methods that the library provides.

Contract

Validations methods.

--

Example

isRequired(value, property, message)
hasMinLen(value, min,property, message)
hasMaxLen(value, max, property, message)
isFixedLen(value, len, property, message)
isEmail(value, property, message)
IsGreaterThan(val, comparer, property, message)

//To get messages and notifications
getNotifications()
getMessages()

// To know if is valid
isValid()

Notifiable

Class turn another class notifiable and works with flunt.

--

Example

AddNotification(property, message)
AddNotifications(contract)

// To get messages
getMessages()

// To know if is valid
isValid()

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.

Versioning

We use SemVer for versioning. For the versions available, see the tags on this repository.

Authors

Jhones Gonçalves
Jhones Gonçalves

See also the list of contributors who participated in this project.

License

This project is licensed under the MIT License - see the LICENSE.md file for details