angular-browserify-event-dispatcher

0.0.7 • Public • Published

Sometimes it's nice to use a global event bus in your applications. This dispatcher wraps a bit of the eventing functionality from $rootScope to create an event bus that other actors in your application can use.

DispatchingController

The dispatching controller is a mixin for your controllers to enhance their behavior.

 
angular.module('my-module', [
    require('angular-browserify-event-dispatcher').name
])
/**
 * This is how you'd use the dispatcher  
 */
.controller('myController', function ($scope, DispatchingController) {
              var time = new Date();
 
              // `this` scope can be an issue here. It might be 
              // required to assign `var myController = this` 
              // in some cases.
              //
              // this could be `angular.extend` vs the Object.mixin ;)
              angular.extend(this, new DispatchingController($scope));
 
              this.listen('hi', function (event, msg) {
                console.log('event handled:', time, msg, event);
              });
 
              this.dispatch('hi', 'from controller')
            })
.service('myService', function(dispatch) {
  dispatch('hi', 'from service');
})

Package Sidebar

Install

npm i angular-browserify-event-dispatcher

Weekly Downloads

4

Version

0.0.7

License

MIT

Last publish

Collaborators

  • joelhooks