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 🙏

© 2026 – Pkg Stats / Ryan Hefner

cross-talk

v0.0.6-beta

Published

PostMessaging made simpler!

Readme

CrossTalk

PostMessaging made simpler!

Cross domain communication using post message, promisified!

Install

NPM users: npm install cross-talk --save

Yarn users: yarn add cross-talk

Import in project

Import CrossTalk in your project using ES6 syntax:

import CrossTalk from 'cross-talk'

Init CrossTalk

The first thing that needs to be done is init CrossTalk with config options.

CrossTalk.init({
  targetWindow: document.getElementById('myIFrame').contentWindow,
  targetEndpoint: 'http://test.example.com',
  sourceIdentifier: '@example-source',
  targetIdentifier: '@example-target'
})

API

Listen for message

CrossTalk.on('message-type', (data) => {
  // handle the data
});

on will listen for a message of type message-type from other windows.

Note that CrossTalk.on(...) does not return a promise as it is an ongoing subscription to the message-type events coming from external sources.

However it does return an Observable subscription that allows you to unsubscribe from the subscription at any point of time.

Listen for message once

CrossTalk.once('message-type')
  .then((data) => {
    // handle the data
  });

Calling once will subscribe to the message-type event coming from external sources and will unsubscribe if the event occurs once. So your handler will be only called once.

Note that CrossTalk.on(...) returns a Promise which gets resolved when an event of the specified type occurs.

Send a message

CrossTalk.send('message-type', data);

If you just want to send a message to targets and don't care of their actions, use send(...). It doesn't return anything.

Send a message and wait for response

CrossTalk.sendForResult('message-type', data)
  .then((data) => {
    // handle the data
  });

sendForResult(...) sends the event to target and waits for the same event to be received from external sources. It calls once(...) on the message-type provided by you and returns a promise.

Destruct CrossTalk

CrossTalk.stop();

This removes the event listener on message, clears the config object and the list of events occurred and not yet handled.

Future Plans

  • Add support for multiple targets
  • Add possibility to provide config for individual actions.
  • Add example and demo
  • Add tests

Contribute

Open an issue and feel free to contribute to this project.