Skip to content

Latest commit

 

History

History
101 lines (70 loc) · 2.02 KB

README.md

File metadata and controls

101 lines (70 loc) · 2.02 KB

Build Status rethink.js js-standard-style

smoke-signal

Simple small functional event observer for the browser and node

Installation

npm install smoke-signal

Usage

var signal = require('smoke-signal')

var onMySignal = signal()

// attach listenerFn to event
var listener = onMySignal.push(listenerFn)

// allow to listen only once
var listener = onMySignal.once(listenerFn)

// trigger event
onMySignal.trigger()

// unlisten to event
onMySignal.pull(listenerFn)

// pause listening (pretty much the same as `onMySignal.pull(listenerFn)`)
listener.pause()

// resume listening (pretty much the same as `onMySignal.push(listenerFn)`)
listener.resume()

// remove all listeners
onMySignal.clear()

It's also possible to listen and trigger with args

var signal = require('smoke-signal')

var onMySignal = signal()

// attach listenerFn to event
onMySignal.push(function(arg) {
  // arg === 'foo'
})

// trigger event
onMySignal.trigger('foo')

Error handling

There are three ways of handling errors in listener, ignore (default), log, handle

To log the errors initialize with option logExceptions.

var signal = require('smoke-signal')

var onMySignal = signal({
  logExceptions: true
})

// attach listenerFn to event
onMySignal.push(function() {
  throw new Error('BOOM!')
})

// trigger event
onMySignal.trigger()
// logs error to std.error

To handle errors initialize with option onError

var signal = require('smoke-signal')

var onMySignal = signal({
  onError: function(err) {
    // do something about the error here
  }
})

// attach listenerFn to event
onMySignal.push(function() {
  throw new Error('BOOM!')
})

// trigger event
onMySignal.trigger()