mapserver/server/static/js/WebSocketChannel.js

54 lines
1.2 KiB
JavaScript
Raw Normal View History

2019-04-04 11:19:29 +03:00
/* exported WebSocketChannel */
2019-01-29 20:08:54 +03:00
2019-02-01 14:58:26 +03:00
function WebSocketChannel(){
2019-04-04 11:19:29 +03:00
this.wsUrl = window.location.protocol.replace("http", "ws") +
"//" + window.location.host +
window.location.pathname.substring(0, window.location.pathname.lastIndexOf("/")) +
"/api/ws";
2019-02-01 14:58:26 +03:00
this.listenerMap = {/* type -> [listeners] */};
}
2019-01-29 20:08:54 +03:00
2019-02-01 14:58:26 +03:00
WebSocketChannel.prototype.addListener = function(type, listener){
var list = this.listenerMap[type];
if (!list){
list = [];
this.listenerMap[type] = list;
}
2019-01-29 20:08:54 +03:00
2019-02-01 14:58:26 +03:00
list.push(listener);
};
2019-01-29 20:08:54 +03:00
2019-02-03 20:18:14 +03:00
WebSocketChannel.prototype.removeListener = function(type, listener){
var list = this.listenerMap[type];
if (!list){
2019-04-04 11:19:29 +03:00
return;
2019-02-03 20:18:14 +03:00
}
this.listenerMap[type] = list.filter(function(l){
return l != listener;
});
};
2019-02-01 14:58:26 +03:00
WebSocketChannel.prototype.connect = function(){
var ws = new WebSocket(this.wsUrl);
var self = this;
2019-01-29 20:08:54 +03:00
2019-02-01 14:58:26 +03:00
ws.onmessage = function(e){
var event = JSON.parse(e.data);
//rendered-tile, mapobject-created, mapobjects-cleared
2019-01-29 20:08:54 +03:00
2019-02-01 14:58:26 +03:00
var listeners = self.listenerMap[event.type];
if (listeners){
2019-02-03 20:04:01 +03:00
listeners.forEach(function(listener){
2019-02-01 14:58:26 +03:00
listener(event.data);
});
2019-01-29 20:08:54 +03:00
}
2019-04-04 11:19:29 +03:00
};
2019-01-29 20:08:54 +03:00
2019-02-01 14:58:26 +03:00
ws.onerror = function(){
//reconnect after some time
2019-03-22 20:14:39 +03:00
setTimeout(self.connect.bind(self), 1000);
2019-04-04 11:19:29 +03:00
};
2019-02-01 14:46:38 +03:00
};