npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

typesafe-agent-events

v1.0.2

Published

A tiny TypeScript library for creating type-safe action creators and handlers, facilitating secure and efficient communication between agents such as iframes and web workers.

Downloads

24

Readme

TypeSafe Agent Actions

typesafe-agent-events is a minimalistic TypeScript library designed to facilitate seamless and type-safe communications between different agents like web workers or iframes in web development environments. It addresses the common challenges developers face when managing communications between disparate system components, particularly when dealing with various action types and payloads.

This library is especially useful when you need to ensure the integrity and reliability of messages passed between different parts of your application, preventing issues related to message type mismatches and ensuring that the payloads conform to expected types.

Prerequisites

  • The purpose of the library is to provide help with types, and is not be suitable for projects not utilizing TypeScript.

Why TypeSafe Agent Actions?

Developing efficient and scalable web applications often requires the integration of different system components. Managing communications between these components can be challenging and error-prone, especially when dealing with various types of payloads and actions.

typesafe-agent-events offers a simple and lightweight solution to these challenges, enabling developers to define, create, and handle actions with type safety. It aims to provide a straightforward approach to managing communications between different components without the need for complex setups or heavy libraries.

Installation

npm install typesafe-agent-events

Usage

Defining Actions

Define actions using the createActionCreators function. This function takes a configuration object where you specify the actions and their associated payloads.

// workerApi.ts
import { createActionCreators } from 'typesafe-agent-events';

type WorkConfig = {...}; // Define the shape of your work configuration

// Define actions to be sent to the worker
export const toWorker = createActionCreators({
  start: (payload: WorkConfig) => payload, // Action with a payload
  stop: () => undefined, // Action without a payload
});

// Define actions to be received from the worker
export const fromWorker = createActionCreators({
  progress: (payload: number) => payload,
  done: (payload: string) => payload,
});

Sending Actions

Use bindActionDispatch to associate an action creator object with a dispatch function, enabling the sending of actions with full type safety.

import { toWorker } from './workerApi';
import { bindActionDispatch } from 'typesafe-agent-events';

const worker = new Worker('./worker.ts', { type: 'module' });
const postToWorker = bindActionDispatch(toWorker, (action) => worker.postMessage(action));

postToWorker.start({ ... }); // Send a 'start' action to the worker

Handling Actions

createHandler provides type-help when defining a handler function, using the type of an action creators object.

import { fromWorker } from './workerApi';
import { createHandler } from 'typesafe-agent-events';

const worker = new Worker('./worker.ts', { type: 'module' });
const handler = createHandler<typeof fromWorker>({
  progress(payload) { ... },
  done(payload) { ... },
});

worker.onmessage = (event) => {
  handler(event.data);
};

worker example

Here's how you can set up typesafe-agent-events within a worker to handle actions and communicate back to the main thread:

// worker.ts
import { fromWorker, toWorker } from './workerApi';
import { createHandler, bindActionDispatch } from 'typesafe-agent-events';

// Bind actions to post messages back to the main thread
const postToMain = bindActionDispatch(fromWorker, self.postMessage.bind(self));

// Assume DoerOfWork is a hypothetical object representing a task doer in your application
const task = new DoerOfWork();

// Create a handler to manage incoming actions from the main thread
const handler = createHandler<typeof toWorker>({
  start(payload) {
    // Start the task and set up callbacks for progress and completion
    task.start({
      config: payload,
      onProgress: (progress) => postToMain.progress(progress), 
      onDone: (result) => postToMain.done(result)
    });
  },
  stop() {
    // Stop the ongoing task
    task.stop();
  },
});

API Documentation

createActionCreators

Description

Creates action creators based on the provided action map.

Parameters

  • actionMap (Object): An object where keys are action types and values are payload transformation functions.

Return Type

An object containing action creators.

Example

const actions = createActionCreators({
  increment: (payload: number) => payload,
});

bindActionDispatch

Description

Binds action creators to a dispatch function, allowing actions to be dispatched directly.

Parameters

  • actionsCreators: {[type:string]: (payload) => {type, payload}}: An object containing action creators.
  • dispatch: (action: any) => void: A function to dispatch actions.

Return Type

An object containing bound action dispatchers. The dis

Example

const boundActions = bindActionDispatch(actions, dispatchFunction);

bindPostMessage

Description

Binds action creators to the postMessage method of an agent, allowing actions to be posted directly to the worker.

Parameters

  • actions: T (Object): An object containing action creators.
  • agent: { postMessage: (event: MessageEvent) => void }: An object with a postMessage method.

Return Type

An object containing bound action dispatchers.

Example

const boundActions = bindPostMessage(actions, worker);

createHandler

Description

Creates a handler function to handle received actions based on the provided action handlers. The handler function returns a boolean indicating whether the action was handled or not.

Parameters

  • defs: { [k in keyof T]: (payload: any) => void }: An object containing action handlers.

Return Type

A function to handle received actions. The returned function will return true if the action was handled, and false if it was not.

Example

const handler = createHandler<typeof actionCreators>({
  increment: (payload) => console.log(payload),
});

const wasHandled = handler(someAction); // will be either true or false

createDataHandler

Description

Creates a data handler function to handle received data events based on the provided action handlers. An optional default handler can be provided to handle events for which no specific handler is defined.

Parameters

  • defs: { [k in keyof T]: (payload: any) => void } & { default?: (event: any) => void } (Object): An object containing action handlers and an optional default handler to handle any unspecified events.

Return Type

A function to handle received data events.

Example

const dataHandler = createDataHandler({
  increment: (payload) => console.log(payload),
  default: (event) => console.error('Unhandled event:', event), // Optional default handler
});

dataHandler(someEvent); // Calls the corresponding handler or the default handler if no match is found

License

typesafe-agent-events is released under the MIT License.