0.2.0 • Published 1 year ago

@kiolib/event-emitter v0.2.0

Weekly downloads
-
License
MIT
Repository
github
Last release
1 year ago

Installation

npm i @kiolib/event-emitter

Usage

With constraints

Create a custom type to limit the list of available events and describe the data associated with each of them:

  • keys - list of the allowed event names;
  • values - list of parameters which need to be send with specific event.
const { EventEmitter } from '@kiolib/event-emitter';

type EventMap = {
  meaningOfLife: [theAnswer: number];
  protagonist: [firstName: string, lastName: string];
  beep: [];
};

const emitter = new EventEmitter<EventMap>();

// subscribe to events
emitter.addEventListener(
  'meaningOfLife',
  answer => console.log(answer)
);
emitter.addEventListener(
  'protagonist',
  (firstName, lastName) => console.log(firstName, lastName)
);
emitter.addEventListener(
  'beep',
  () => console.log('beeped')
);

// emit events
emitter.emit('meaningOfLife', 42);
emitter.emit('protagonist', 'Arthur', 'Dent');
emitter.emit('beep');

Inheriting from EventEmitter

In the example below we are extending our custom UserService class from the EventEmitter to enable events support:

import { EventEmitter } from "./EventEmitter";

// user model
type User = {
  id: string;
  username: string;
};

// supported events for UserService 
type UserEvents = {
  login: [user: User];
  logout: [];
}

class UserService extends EventEmitter<UserEvents> {
  async login(username: string, password: string) {
    // authenticathion logic
    this.emit('login', { id: '42', username: 'arthur.dent' });
  }

  async logout() {
    // clear user data
    this.emit('logout');
  }
}

// creating service instance which will be shared in an application
const userService = new UserService();

// listening the login event to welcome user
userService.addEventListener(
  'login',
  user => window.alert(`Welcome, ${user.username}`)
);

// somewhere in your code user can login and will see the welcome message
userService.login('arthur.dent', 'not-a-real-password');

One-time subscription

Some events might occur only once and when that happens we are no longer interested in listening them. In this case we can configure the listener to unsubscribe itself after event emitted using the 3rd parameter - options:

// event emitter setup code from the first example
// (using EventMap constraint)

emitter.addEventListener('beep', listener, { once: true });
// or
emitter.once('beep', listener);

API

MethodDescription
addEventListener(name, listener, options) => voidSubscribe listener to a specific event
emit(name, ...payload) => voidEmit event by name with required payload data
removeEventListener(name, listener) => voidUnsubscribe listener from a specific event
removeAllEventListeners() => voidUnsubscribe all listeners from all events
on(name, listener, options) => voidalias for addEventListener
once(name, listener) => voidalias for addEventListener (with once=true in options)
off(name, listener) => voidalias for removeEventListener

License

Distributed under the MIT License.

0.2.0

1 year ago

0.1.0

1 year ago