Angular Phoenix
Provides angular bindings to Phoenix so we can run events within the digest loop.
I've also taken the liberty of Promisifying phoenix!
Installing
$ bower install --save angular-phoenix
Note: You must have the original phoenix.js
loaded prior to this
How to use
This is incomplete and only allows for a single socket connection per client
First we need to set our socket base url and add a global dependency.
angular.module('myApp', ['angular-phoenix'])
.config(['PhoenixProvider', PhoenixProvider => {
PhoenixProvider.setUrl('ws//localhost:9000/ws')
}])
Now were ready!!!
Joining a channel
You can only join a channel once, if you provide a new message it will leave then rejoin the channel.
Just like normal phoenix we call Phoenix.join
however we also can take scope!
Phoenix.join($scope, 'name', {})
.then(chann => {
chann.on('message', handler)
})
Phoenix.join('name', {})
.then(chann => {
chann.on('message', hander)
})
Leaving a channel
Phoenix.leave('name')
Accessing base phoenix or current socket
Phoenix.base
Phoenix.socket