Change lineinfo into async promise
This commit is contained in:
parent
dd77529cba
commit
5ed02a5e54
|
@ -277,7 +277,7 @@ weechat.factory('handlers', ['$rootScope', 'colors', 'models', 'plugins', functi
|
||||||
|
|
||||||
}]);
|
}]);
|
||||||
|
|
||||||
weechat.factory('connection', ['$q', '$rootScope', '$log', 'handlers', 'colors', 'models', function($q, $rootScope, $log, handlers, colors, models) {
|
weechat.factory('connection', ['$q', '$rootScope', '$log', '$store', 'handlers', 'colors', 'models', function($q, $rootScope, $log, storage, handlers, colors, models) {
|
||||||
protocol = new WeeChatProtocol();
|
protocol = new WeeChatProtocol();
|
||||||
var websocket = null;
|
var websocket = null;
|
||||||
|
|
||||||
|
@ -314,14 +314,16 @@ weechat.factory('connection', ['$q', '$rootScope', '$log', 'handlers', 'colors',
|
||||||
websocket.binaryType = "arraybuffer"
|
websocket.binaryType = "arraybuffer"
|
||||||
|
|
||||||
websocket.onopen = function (evt) {
|
websocket.onopen = function (evt) {
|
||||||
doSend(WeeChatProtocol.formatInit({
|
$log.info("Connected to relay");
|
||||||
|
doSend(WeeChatProtocol.formatInit({
|
||||||
password: passwd,
|
password: passwd,
|
||||||
compression: 'off'
|
compression: 'off'
|
||||||
}));
|
}));
|
||||||
doSendWithCallback(WeeChatProtocol.formatHdata({
|
doSendWithCallback(WeeChatProtocol.formatHdata({
|
||||||
path: 'buffer:gui_buffers(*)',
|
path: 'buffer:gui_buffers(*)',
|
||||||
keys: ['number,full_name,short_name,title']
|
keys: ['number,full_name,short_name,title']
|
||||||
})).then(function(hdata) {
|
})).then(function(message) {
|
||||||
|
$log.info("Parsing bufinfo");
|
||||||
var bufferInfos = message['objects'][0]['content'];
|
var bufferInfos = message['objects'][0]['content'];
|
||||||
// buffers objects
|
// buffers objects
|
||||||
for (var i = 0; i < bufferInfos.length ; i++) {
|
for (var i = 0; i < bufferInfos.length ; i++) {
|
||||||
|
@ -332,16 +334,19 @@ weechat.factory('connection', ['$q', '$rootScope', '$log', 'handlers', 'colors',
|
||||||
models.setActiveBuffer(buffer.id);
|
models.setActiveBuffer(buffer.id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
$rootScope.connected = true;
|
||||||
// Request latest buffer lines for each buffer
|
}).then(function() {
|
||||||
$rootScope.getLines();
|
$log.info("Parsing lineinfo");
|
||||||
|
doSendWithCallback(WeeChatProtocol.formatHdata({
|
||||||
|
path: "buffer:gui_buffers(*)/own_lines/last_line(-"+storage.get('lines')+")/data",
|
||||||
|
keys: []
|
||||||
|
})).then(function(hdata) {
|
||||||
|
handlers.handleLineInfo(hdata);
|
||||||
|
});
|
||||||
|
}).then(function() {
|
||||||
|
doSend(WeeChatProtocol.formatSync({}));
|
||||||
|
$log.info("Synced");
|
||||||
});
|
});
|
||||||
doSend(WeeChatProtocol.formatSync({}));
|
|
||||||
|
|
||||||
$log.info("Connected to relay");
|
|
||||||
$rootScope.connected = true;
|
|
||||||
$rootScope.$apply();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
websocket.onclose = function (evt) {
|
websocket.onclose = function (evt) {
|
||||||
|
@ -380,18 +385,9 @@ weechat.factory('connection', ['$q', '$rootScope', '$log', 'handlers', 'colors',
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
var getLines = function(count) {
|
|
||||||
doSendWithCallback(WeeChatProtocol.formatHdata({
|
|
||||||
path: "buffer:gui_buffers(*)/own_lines/last_line(-"+count+")/data",
|
|
||||||
keys: []
|
|
||||||
})).then(function(hdata) {
|
|
||||||
handlers.handleLineInfo(hdata);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
send: doSend,
|
send: doSend,
|
||||||
getLines: getLines,
|
|
||||||
connect: connect,
|
connect: connect,
|
||||||
sendMessage: sendMessage
|
sendMessage: sendMessage
|
||||||
}
|
}
|
||||||
|
@ -481,9 +477,6 @@ weechat.controller('WeechatCtrl', ['$rootScope', '$scope', '$store', '$timeout',
|
||||||
$scope.connect = function() {
|
$scope.connect = function() {
|
||||||
connection.connect($scope.host, $scope.port, $scope.password, $scope.ssl);
|
connection.connect($scope.host, $scope.port, $scope.password, $scope.ssl);
|
||||||
}
|
}
|
||||||
$rootScope.getLines = function() {
|
|
||||||
connection.getLines($scope.lines);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Function gets called from bufferLineAdded code if user should be notified */
|
/* Function gets called from bufferLineAdded code if user should be notified */
|
||||||
$rootScope.createHighlight = function(buffer, message) {
|
$rootScope.createHighlight = function(buffer, message) {
|
||||||
|
|
Loading…
Reference in New Issue