GitXplorerGitXplorer
t

base-events

public
15 stars
0 forks
2 issues

Commits

List of commits on branch master.
Unverified
74f629ec5d7abe507bdffa7f54b191f0bb07c0c1

0.0.5

ttuchk4 committed 8 years ago
Unverified
a7a19e39584a12d704d0e2e715582b978c2b1292

fix deps

ttuchk4 committed 8 years ago
Unverified
a1525b983f5ba3a32144d5caa0ff4711aff6c577

Update README.md

ttuchk4 committed 9 years ago
Unverified
643a0bc6a24f0478243867b6b3905af7fdea3677

0.0.4

ttuchk4 committed 9 years ago
Unverified
a609b320b1bbbd5429de42c878019b8b5bf9cd73

update README.md

ttuchk4 committed 9 years ago
Unverified
ecb036715eb11b98894731f5c39d4b1fed75bceb

update README.md

ttuchk4 committed 9 years ago

README

The README file for this repository.

Base events

Provides easy way to subscribe and emit events. Super light component

npm install --save base-events

How to use

import BaseEvents from 'base-events';

const events = new BaseEvents();

events.on('a.b.c', () => {
  console.log('a.b.c fired');
});

events.once('x.y.z', () => {
  console.log('x.y.z fired');
});

events.emit('a.b.c');
events.emit('x.y.z');

events.emit('x.y.z'); // will not emit x.y.z for second time


const off = events.on('a', () => {
  // ....
});

off(); // unsubscribe listener

Extends

import BaseEvents from 'base-events';

class Manager extends BaseEvents {
  constructor() {
    super();
  }
  
  add(component) {
    // ...
    this.emit('component.add', {
      component
    });
  }
}

const manager = new Manager();

manager.on('component.add', ({ component }) => { 
 // ....
});

Available methods

  • on(event, callback) - subscribe for event. Returns unsubscribe function
  • once(event, callback) - subscribe for event. Will be emitted only one time
  • emit(event, arguments) - trigger event with provided arguments

Community

You are always welcome for ideas and pull requests :)

TODO

const events = new BaseEvents();

events.on('a', () => { ... });
events.on('a.*', () => { ... });
events.on('a.b.c', () => { ... });
events.on('a.*.c', () => { ... });


events.emit('a', params); // available listeners: a
events.emit('a.b.c', params); // available listeners: a.* / a.b.c / a.*.c
events.emit('a.B.c', params); // available listeners: a.*.c

events.emit('x.y.z', params); // no listeners
events.emit('a', params);  // available listeners: a