angular2-websocket

WebJar for angular2-websocket

License

License

Categories

Categories

Angular User Interface Web Frameworks
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

angular2-websocket
Last Version

Last Version

0.9.0
Release Date

Release Date

Type

Type

jar
Description

Description

angular2-websocket
WebJar for angular2-websocket
Project URL

Project URL

http://webjars.org
Source Code Management

Source Code Management

https://github.com/afrad/angular2-websocket

Download angular2-websocket

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/angular2-websocket/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>angular2-websocket</artifactId>
    <version>0.9.0</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/angular2-websocket/
implementation 'org.webjars.npm:angular2-websocket:0.9.0'
// https://jarcasting.com/artifacts/org.webjars.npm/angular2-websocket/
implementation ("org.webjars.npm:angular2-websocket:0.9.0")
'org.webjars.npm:angular2-websocket:jar:0.9.0'
<dependency org="org.webjars.npm" name="angular2-websocket" rev="0.9.0">
  <artifact name="angular2-websocket" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='angular2-websocket', version='0.9.0')
)
libraryDependencies += "org.webjars.npm" % "angular2-websocket" % "0.9.0"
[org.webjars.npm/angular2-websocket "0.9.0"]

Dependencies

compile (1)

Group / Artifact Type Version
org.webjars.npm : bluebird jar [3.4.6,4)

Project Modules

There are no modules declared in this project.

angular2websocket

Based on https://github.com/AngularClass/angular-websocket and migrated to Angular2

Installation

npm install angular2-websocket

Usage:

import {$WebSocket} from 'angular2-websocket/angular2-websocket'
var ws = new $WebSocket("url");
ws.send(event);

also ws.getDataStream() returns Subject to which you can attach an Observer (https://github.com/Reactive-Extensions/RxJS)

Compilation

npm run typings
npm run compile

The default value for binary type is 'arrayBuffer'.

example

import {$WebSocket, WebSocketSendMode} from 'angular2-websocket/angular2-websocket';
  
// connect
var ws = new $WebSocket("ws://127.0.0.1:7000");
// you can send immediately after connect, 
// data will cached until connect open and immediately send or connect fail.
  
// when connect fail, websocket will reconnect or not,
// you can set {WebSocketConfig.reconnectIfNotNormalClose = true} to enable auto reconnect
// all cached data will lost when connect close if not reconnect
  
  
// set received message callback
ws.onMessage(
    (msg: MessageEvent)=> {
        console.log("onMessage ", msg.data);
    },
    {autoApply: false}
);
  
// set received message stream
ws.getDataStream().subscribe(
    (msg)=> {
        console.log("next", msg.data);
        ws.close(false);
    },
    (msg)=> {
        console.log("error", msg);
    },
    ()=> {
        console.log("complete");
    }
);
  
// send with default send mode (now default send mode is Observer)
ws.send("some thing").subscribe(
        (msg)=> {
            console.log("next", msg.data);
        },
        (msg)=> {
            console.log("error", msg);
        },
        ()=> {
            console.log("complete");
        }
    );
  
ws.send("by default, this will never be sent, because Observer is cold.");
ws.send("by default, this will be sent, because Observer is hot.").publish().connect();
  
ws.setSendMode(WebSocketSendMode.Direct);
ws.send("this will be sent Direct, because send mode is set to Direct.");
  
ws.send("this will be sent and return Promise.", WebSocketSendMode.Promise).then(
        (T) => {
            console.log("is send");
        },
        (T) => {
            console.log("not send");
        }
    );
  
ws.send("this will be sent and return Observer.").subscribe(
        (msg)=> {
            console.log("next", msg.data);
        },
        (msg)=> {
            console.log("error", msg);
        },
        ()=> {
            console.log("complete");
        }
    );

ws.close(false);    // close
ws.close(true);    // close immediately

Binary type

To set the binary type for the websocket one can provide it as string in the constructor. Allowed types are:

  • 'blob' (default)
  • 'arraybuffer'
var ws = new $WebSocket("ws://127.0.0.1:7000", null, null, 'arraybuffer');

Versions

Version
0.9.0
0.6.2