Skip to content

Latest commit

 

History

History
128 lines (99 loc) · 1.92 KB

modella.md

File metadata and controls

128 lines (99 loc) · 1.92 KB
title category layout prism_languages intro
Modella
JavaScript libraries
2017/sheet
coffeescript
[Modella](https://www.npmjs.com/package/modella) allows you to create simple models in JavaScript. This is a guide on basic usage of Modella in CoffeeScript.

Defining models

User = Modella('User')
  .attr('name')
  .attr('email', { required: true })
  .use(require('modella-validators'))
  .validator (u) ->
    u.error('username', 'is required')  unless u.has('username')

Instances

user
  .name()
  .name('John')
  .set(name: 'John')
  .has('name')   # → true
  .isNew()
  .isValid()
  .save (err) ->
  .remove (err) ->
  .removed
  .model         # === User

Events

Emitting

Model.emit('event', [data...])
record.emit('event', [data...])

List of events

user
  .on 'save', ->
  .on 'create', ->
  .on 'saving', (data, done) -> done()
  .on 'remove', ->
  .on 'removing', (data, done) -> done()
  .on 'valid', ->
  .on 'invalid', ->
  .on 'change', ->
  .on 'change email', ->
  .on 'initializing', (instance, attrs) ->
  .on 'initialize', ->
  .on 'error', -> failed to save model
  .on 'setting', (instance, attrs) ->  # on Model#set()
  .on 'attr', -> # new attr via Model.attr()

Misc

Plugins

MyPlugin = ->
  return (Model) ->

    Model.method = ...
    Model.prototype.method = ...
    Model.attr(...)

    Model

A plugin is a function that returns a model decorator (ie, a function that takes in a model and returns a model).

Memory

User
  .all (err, users) ->
  .find id, (err, user) ->
  .remove ->
  .save ->
  .update ->