Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/georapbox/angular-pubsub
Angular 1.x implementation of the Publish–Subscribe pattern.
https://github.com/georapbox/angular-pubsub
angularjs callback events javascript publish publish-subscribe pubsub register subscribe topic
Last synced: 2 months ago
JSON representation
Angular 1.x implementation of the Publish–Subscribe pattern.
- Host: GitHub
- URL: https://github.com/georapbox/angular-pubsub
- Owner: georapbox
- License: mit
- Created: 2014-10-26T11:16:50.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2017-07-20T14:27:08.000Z (over 7 years ago)
- Last Synced: 2024-10-05T12:59:09.897Z (4 months ago)
- Topics: angularjs, callback, events, javascript, publish, publish-subscribe, pubsub, register, subscribe, topic
- Language: JavaScript
- Homepage:
- Size: 12.7 KB
- Stars: 32
- Watchers: 4
- Forks: 13
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# angular-PubSub
Angular 1.x implementation of the [Publish–Subscribe](http://en.wikipedia.org/wiki/Publish%E2%80%93subscribe_pattern) pattern.> ### NOTE: This repository is no longer maintained.
> The current repository and the `npm` package are not going anywhere but for future projects, please consider using [PubSub](https://github.com/georapbox/PubSub) package instead. Check the `examples` folder for a working example in Angular 1.x application.[![npm version](https://badge.fury.io/js/angular-PubSub.svg)](http://badge.fury.io/js/angular-PubSub)
[![Dependencies](https://david-dm.org/georapbox/angular-PubSub.svg?theme=shields.io)](https://david-dm.org/georapbox/angular-PubSub)
[![devDependency Status](https://david-dm.org/georapbox/angular-PubSub/dev-status.svg)](https://david-dm.org/georapbox/angular-PubSub#info=devDependencies)## Installation
### Git installation
`$ git clone https://github.com/georapbox/angular-PubSub.git`
### npm installation
`$ npm install angular-PubSub --save`
### Bower installation
`$ bower install angular.pubsub`## Using PubSub
### Register
Include `angular-pubsub.js` in your project after `angular.js` and register to your application:
```js
var app = angular.module('app', ['PubSub']);
```### Inject as dependancey
Inject the service as a dependancy of the application modules, to use it:
```js
var MyController = app.controller('MyController', ['PubSub', function (PubSub) {
// do your stuff here...
}]);
```### Subscribing events
The "listener" is the function to be executed when an event is emitted.
```js
function listener(data, topic) {
console.log('An event is published.');
console.log(topic);
console.log(data);
}// Subscribe to event
var sub = PubSub.subscribe('event-name', listener);// Subscribe to event and execute only one time
var subOnce = PubSub.subscribeOnce('event-name', listener)
```### Publishing events
The `publish` method takes two arguments:- The first one is the name of the event.
- The second one (optional) is the data we may want to pass along as. We can pass data along using an array or an object as shown below.
```js
PubSub.publish('event-name', {prop1: value1, prop2: value2});
```### Unsubscribing events
There are two ways to unsubscribe an event:- Unsubscribe from a specific topic based on a tokenized reference to the subscription.
```js
PubSub.unsubscribe(sub);
```
- Unsubscribe from a specific topic based on topic name. This way we can unsubscribe all events with the same name.
```js
PubSub.unsubscribe('event-name');
```## Methods aliases
- `on` - `subscribe`
- `once` - `subscribeOnce`
- `trigger` - `publish`
- `off` - `unsubscribe`## Minify
```sh
$ npm run minify
```