This package has been deprecated

Author message:

No longer maintained

@wcom/events
TypeScript icon, indicating that this package has built-in type declarations

1.0.6 • Public • Published

@wcom/events

package-badge license-badge coverage-badge semantic-release-badge

Introduction

A simple library containing a collection of decorators and helpers for working with events inside web components. This library is expected to be used with TypeScript, make sure to set experimentalDecorators to true in tsconfig.json.

Install

# npm
$: npm install @wcom/events

# yarn
$: yarn add @wcom/events

# pnpm
$: pnpm install @wcom/events

Usage

EventEmitter

Dispatches a custom event from the given target. Mainly used to type the emitter returned from the @event decorator.

import { EventEmitter } from '@wcom/events';

const target = document.createElement('<div></div>');
const emitter = new EventEmitter<string>(target, 'myEvent', { bubbles: true });
emitter.emit('apples');

Disposal

A disposal bin used to add cleanup callbacks that can be called when required. Mostly used to add stop event listener callbacks returned from listenTo.

import { Disposal } from '@wcom/events';

const disposal = new Disposal();

function onClick() {
  // ...
}

function onResize() {
  // ...
}

// Add cleanup callbacks.
disposal.add(listenTo(window, 'click', onClick);
disposal.add(listenTo(window, 'resize', onResize);

// Empty the bin and flush callbacks.
disposal.empty();

@event

Decorator that creates an EventEmitter on the given class property that will dispatch events from the host element. By default all events emitted bubble up the DOM tree and through the shadows into the light.

import { event } from '@wcom/events';

class MyComponent extends HTMLElement {
  // 1.
  @event() myEvent!: EventEmitter<string>;

  // 2.
  @event({
    name: 'customEventName',
    bubbles: true,
    composed: true,
  }) anotherEvent!: EventEmitter<void>
}

@listen

Attaches an event listener to the host element or the given target. The event name can be inferred from the method name if it is named following JSX conventions such as onEventName, which will listen for eventName. The listener is automatically cleaned up when the element is disconnected from the DOM.

import { listen } from '@wcom/events';

class MyComponent extends HTMLElement {
  // 1.
  @listen('customEvent')
  onSomeEvent() {
    // ...
  }

  // 2. Target can be set to `document`, `window` or `undefined` which will default to host.
  @listen('click', { target: 'window' })
  onWindowClick() {
    // ...
  }

  // 3. Event name is inferred here as `myEvent`.
  @listen()
  onMyEvent() {
    // ...
  }
}

listenTo

Listens to an event on the given target and returns a cleanup function to stop listening.

import { listenTo } from '@wcom/events';

function onResize() {
  // ...
}

// Options are listed with their default values.
const off = listenTo(window, 'resize', onResize, { 
  capture: false, 
  passive: false, 
  once: false,
});

// Stop listening.
off();

Package Sidebar

Install

npm i @wcom/events

Weekly Downloads

7

Version

1.0.6

License

MIT

Unpacked Size

27 kB

Total Files

9

Last publish

Collaborators

  • mihar-22