Skip to content
James edited this page Jun 24, 2017 · 12 revisions

⛓ chain-able

NPM version docs Dependencies fliphub BuildStatus Coverage Status Codacy Badge gzip size fluent

interfaces that describe their intentions

🗣 expressive

traditional

class Traditional {
  constructor() {
    this.data = {}
  }
  build(index, name, object) {
    this.data.index = index
    this.data.name = name
    this.data.object = object
  }
}
const classico = new Traditional()
classico.build(1, 'string', {object: true})

fluent

class Fluent extends Chain {
  constructor(parent) {
    super(parent)
    this.extend(['index', 'name', 'object'])
  }
}
const chain = new Chain()
  .index(1)
  .name('string')
  .object(true)

📦 install

yarn add chain-able
npm i chain-able --save

🏰 benefits

writing an api using chain-able means:

  • write 1 api,
  • get 3 apis as a result!
    • 🍉 persistable, rehydratable, & transferrable configurations
    • ⛓ fluent/chainable api
    • 🍦 vanilla object syntax

🎁 features

🔗 related

Clone this wiki locally