elm/core-js/Signal/WebSocket.js

37 lines
1.1 KiB
JavaScript
Raw Normal View History

2013-01-30 11:54:49 +00:00
Elm.WebSocket = function() {
var JS = Elm.JavaScript;
/** open :: String -> Signal String -> Signal String
2013-01-30 11:54:49 +00:00
Create a web-socket. The first argument is the URL of the desired
web-socket server. The input signal holds the outgoing messages,
and the resulting signal contains the incoming ones.
**/
function open(url) { return function(outgoing) {
2013-01-30 11:54:49 +00:00
var incoming = Elm.Signal.constant(["Nil"]);
var ws = new window.WebSocket(JS.castStringToJSString(url));
var pending = [];
var ready = false;
2013-01-30 11:54:49 +00:00
ws.onopen = function(e) {
var len = pending.length;
for (var i = 0; i < len; ++i) { ws.send(pending[i]); }
ready = true;
2013-01-30 11:54:49 +00:00
};
ws.onmessage = function(event) {
Dispatcher.notify(incoming.id, JS.castJSStringToString(event.data));
};
function send(msg) {
2013-01-30 11:54:49 +00:00
var s = JS.castStringToJSString(msg);
ready ? ws.send(s) : pending.push(s);
2013-01-30 11:54:49 +00:00
}
function take1(x) { return function(y) { return x; } }
return Elm.Signal.lift2(take1)(incoming)(Elm.Signal.lift(send)(outgoing));
2013-01-30 11:54:49 +00:00
};
}
return {open:open};
2013-01-30 11:54:49 +00:00
}();