Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

phosphor-signaling

Package Overview
Dependencies
Maintainers
1
Versions
15
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

phosphor-signaling

A module for type-safe inter-object communication.

  • 0.9.5
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
22
increased by22.22%
Maintainers
1
Weekly downloads
 
Created
Source

phosphor-signaling

A module for type-safe inter-object communication.

API Docs

Package Install

Prerequisites

  • node
npm install --save phosphor-signaling

Source Build

Prerequisites

git clone https://github.com/phosphorjs/phosphor-signaling.git
cd phosphor-signaling
npm install

Rebuild

npm run clean
npm run build

Run Tests

Follow the source build instructions first.

npm test

Build Docs

Follow the source build instructions first.

npm run docs

Navigate to docs/index.html.

Supported Runtimes

The runtime versions which are currently known to work are listed below. Earlier versions may also work, but come with no guarantees.

  • Node 0.12.7+
  • IE 11+
  • Firefox 32+
  • Chrome 38+

Usage Examples

Start by defining the model object and its signals:

TypeScript

import { ISignal, signal } from 'phosphor-signaling';


class Model {

  @signal
  itemAdded: ISignal<{ index: number, item: string }>;

  constructor(name) {
    this._name = name;
  }

  get name(): string {
    return this._name;
  }

  get items(): string[] {
    return this._items.slice();
  }

  addItem(item: string): void {
    var i = this._items.length;
    this._items.push(item);
    this.itemAdded.emit({ index: i, item: item });
  }

  private _name: string;
  private _items: string[] = [];
}

ES5

var signal = require('phosphor-signaling').signal;


function Model(name) {
  this._name = name;
  this._items = [];
}


signal(Model.prototype, 'itemAdded');


Object.defineProperty(Model.prototype, 'name', {
  get: function() { return this._name; },
});


Object.defineProperty(Model.prototype, 'items', {
  get: function() { return this._items.slice(); },
});


Object.prototype.addItem = function(item) {
  var i = this._items.length;
  this._items.push(item);
  this.itemAdded.emit({ index: i, item: item });
};

Next, define the handler(s) which will consume the signals:

If the same handler is connected to multiple signals, it may want to get a reference to the object emitting the signal which caused it to be invoked. This can be done with the emitter() function.

TypeScript

import { emitter } from 'phosphor-signaling';


function logger(args: { index: number, item: name }): void {
  var model = <Model>emitter();
  console.log(model.name, args.index, args.name);
}


class ItemCounter {

  constructor(model: Model, item: string) {
    this._model = model;
    this._item = item;
    model.itemAdded.connect(this._onItemAdded, this);
  }

  dispose(): void {
    this._model.itemAdded.disconnect(this._onItemAdded, this);
    this._model = null;
  }

  get count(): number {
    return this._count;
  }

  private _onItemAdded(args: { index: number, item: name }): void {
    if (args.item === this._item) this._count++;
  }

  private _model: Model;
  private _name: string;
  private _count = 0;
}

ES5

var emitter = require('phosphor-signaling').emitter;


function logger(args) {
  var model = emitter();
  console.log(model.name, args.index, args.name);
}


function ItemCounter(model, item) {
  this._count = 0;
  this._model = model;
  this._item = item;
  model.itemAdded.connect(this._onItemAdded, this);
}


ItemCounter.prototype.dispose = function() {
  this._model.itemAdded.disconnect(this._onItemAdded, this);
  this._model = null;
};


Object.defineProperty(ItemCounter.prototype, 'count', {
  get: function() { return this._count; },
});


ItemCounter.prototype._onItemAdded = function(args) {
  if (args.item === this._item) this._count++;
};

Next, connect the handlers to the signals:

var m1 = new Model('foo');
var m2 = new Model('bar');
var m3 = new Model('baz');

var c1 = new ItemCounter(m1, 'quail');
var c2 = new ItemCounter(m1, 'robbin');
var c3 = new ItemCounter(m1, 'chicken');

m1.itemAdded.connect(logger);
m2.itemAdded.connect(logger);
m3.itemAdded.connect(logger);

Make some changes to the models:

m1.addItem('turkey');
m1.addItem('fowl');
m1.addItem('quail');

m2.addItem('buzzard');

m3.addItem('hen');

Disconnect the logger from all models in a single-shot:

TypeScript

import { disconnectReceiver } from 'phosphor-signaling';

disconnectReceiver(logger);

ES5

var disconnectReceiver = require('phosphor-signaling').disconnectReceiver;

disconnectReceiver(logger);

Disconnect a particular model from all handlers in a single-shot:

TypeScript

import { disconnectEmitter } from 'phosphor-signaling';

disconnectEmitter(m1);

ES5

var disconnectEmitter = require('phosphor-signaling').disconnectEmitter;

disconnectEmitter(m1);

Keywords

FAQs

Package last updated on 16 Aug 2015

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc