event-sign
v0.3.0
Published
Defines event specification and creates event transmit/receive wrapper.
Downloads
1
Readme
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.