event-sign

0.3.0 • Public • Published

Example

var EventSign = require('event-sign');

// Define events
var CounterEvent = EventSign.define(['increment', 'decrement', 'error']);

function Counter(current) {
    this._current = current || 0;
}
Counter.prototype.count = function (number) {
    var self = this;

    // event has transmitter, receiver properies
    //   and both objects have methods of the defined events.
    var event = new CounterEvent();

    process.nextTick(function () {
        if (typeof number !== 'number') {
            // equal emitter.emit('error', ..)
            event.transmitter.error(Error('argument is not number'));
        }

        self._current += number;

        if (number > 0) {
            // equal emitter.emit('increment', ..)
            event.transmitter.increment(self._current);
        } else if (number < 0) {
            // equal emitter.emit('decrement', ..)
            event.transmitter.decrement(self._current);
        }
    });

    return event.receiver;
};


var counter = new Counter();

counter.count(10)   // gets event receiver, and add listners.
       .error( function (err) {
           throw err;
       })
       .increment( function (result) {
           console.log('Increments, and now ' + result);
       })
       .decrement( function (result) {
           console.log('Decrements, and now ' + result);
       });

Installation

$ npm install event-sign

Features

EventSign.define( events )

Defines events.

  • Arguments

    • events (array): event names
  • Returns

    • A constructor function, and can be used to create new instances for defined events.

event.transmitter

A wrapper of event emitting. If you define event done , event.transmitter has done method.

event.transmitter.done(some, parameter);

And same this.

emitter.emit('done', some, parameter);

event.receiver

A wrapper of event listning. If you define event done , event.receiver has done method.

event.receiver.done( function(some, parameter) { ... } );

And same this.

emitter.on('done', function(some, parameter) { ... });

License

event-sign is licensed under the MIT license.

Readme

Keywords

none

Package Sidebar

Install

npm i event-sign

Weekly Downloads

0

Version

0.3.0

License

none

Last publish

Collaborators

  • kumatch