Back to Nuclear

Events

packages/docs/plugins/events.md

latest2.2 KB
Original Source

Events

Events API for plugins

The Events API is a typed pub/sub system that lets plugins react to player lifecycle events. The player emits events and the plugins subscribe to them.

{% hint style="info" %} Access events via api.Events.* in your plugin's lifecycle hooks. The on method is synchronous and returns an unsubscribe function. {% endhint %}


Core concepts

Event model

Plugins subscribe to named events using api.Events.on(eventName, listener). Each event carries a typed payload. The player fires events at specific moments during playback, and all registered listeners for that event run in the order they were added.

Available events

EventPayloadWhen fired
trackStartedTrackA track begins playing (audio has buffered and started).
trackFinishedTrackA track finishes playing naturally (audio reaches the end). Not fired on skip or stop.

Cleanup

on returns an unsubscribe function. Always call it during onDisable to prevent memory leaks and stale listeners.


Usage

Subscribing to events:

typescript
import type { NuclearPluginAPI } from '@nuclearplayer/plugin-sdk';

export default {
  onEnable(api: NuclearPluginAPI) {
    const unsubscribe = api.Events.on('trackFinished', (track) => {
      api.Logger.info(`Finished: ${track.title}`);
    });

    // Return a cleanup function for onDisable
    return () => {
      unsubscribe();
    };
  },
};

Reference

typescript
// Subscriptions
api.Events.on<E extends keyof PluginEventMap>(
  event: E,
  listener: (payload: PluginEventMap[E]) => void | Promise<void>
): () => void

Types

typescript
type PluginEventMap = {
  trackStarted: Track;   // from @nuclearplayer/model
  trackFinished: Track;
};

type PluginEventListener<E extends keyof PluginEventMap> = (
  payload: PluginEventMap[E],
) => void | Promise<void>;

The Track payload has this shape:

typescript
type Track = {
  title: string;
  artists: ArtistCredit[];
  album?: AlbumRef;
  durationMs?: number;
  trackNumber?: number;
  disc?: string;
  artwork?: ArtworkSet;
  tags?: string[];
  source: ProviderRef;
};