/ember-phoenix

Phoenix Framework integration and tooling for Ember.js apps

Primary LanguageJavaScriptMIT LicenseMIT

Ember-phoenix Build Status

Low-Level Use

You can import phoenix framework client-side utilities as an ES6 module

import { Socket } from 'phoenix';

let socket = new Socket('/socket', {
  logger: ((kind, msg, data) => {
    console.log(`${kind}: ${msg}`, data);
  })
});

Recommended Use

Build a service around a socket (you will usually have only one, since phoenix multiplexes for you)

import PhoenixSocket from 'phoenix/services/phoenix-socket';

export default PhoenixSocket.extend({
  
  init() {
    // You may listen to open, "close" and "error"
    this.on('open', () => {
      console.log('Socket was opened!');
    })
  },
  
  connect(/*url, options*/) {
    const myjwt = "abacnwih12eh12...";
    // connect the socket
    this.super("wss://myhost.com/socket/mysocket", {
      params: {token: myjwt}
    });

    // join a channel
    const channel = this.joinChannel("room:123", {
      nickname: "Mike"
    });

    // add message handlers
    chan.on("notification", () => _onNotification(...arguments));
  },

  _onNotification(message) {
    alert(`Notification: ${message}`);
  }
});

Installation

  • git clone this repository
  • npm install
  • bower install

Running

Running Tests

  • npm test (Runs ember try:testall to test your addon against multiple Ember versions)
  • ember test
  • ember test --server

Building

  • ember build

For more information on using ember-cli, visit http://www.ember-cli.com/.

Copyright

(c) 2016 Levanto Financial