Commit 8b0670d3 authored by JC Brand's avatar JC Brand

Update the available rooms list when users join or leave.

parent 2fb4a885
/*!
* Converse.js (Web-based instant messaging with XMPP)
* http://opkode.com
*
* Copyright (c) 2012 Jan-Carel Brand
* Dual licensed under the MIT and GPL Licenses
*/
var xmppchat = (function (jarnxmpp, $, console) { var xmppchat = (function (jarnxmpp, $, console) {
var ob = jarnxmpp; var ob = jarnxmpp;
/* FIXME: XEP-0136 specifies 'urn:xmpp:archive' but the mod_archive_odbc /* FIXME: XEP-0136 specifies 'urn:xmpp:archive' but the mod_archive_odbc
* add-on for ejabberd wants the URL below. This might break for other * add-on for ejabberd wants the URL below. This might break for other
* Jabber servers. * Jabber servers.
*/ */
ob.Collections = { ob.messages = {};
'URI': 'http://www.xmpp.org/extensions/xep-0136.html#ns' ob.messages.ClientStorage = (function () {
};
ob.Messages = {};
ob.Messages.ClientStorage = (function () {
// TODO: Messages must be encrypted with a key and salt // TODO: Messages must be encrypted with a key and salt
methods = {}; methods = {};
...@@ -31,13 +34,16 @@ var xmppchat = (function (jarnxmpp, $, console) { ...@@ -31,13 +34,16 @@ var xmppchat = (function (jarnxmpp, $, console) {
return methods; return methods;
})(); })();
ob.Messages.getMessages = function (jid, callback) { ob.messages.getMessages = function (jid, callback) {
var bare_jid = Strophe.getBareJidFromJid(jid), var bare_jid = Strophe.getBareJidFromJid(jid),
msgs = this.ClientStorage.getMessages(bare_jid); msgs = this.ClientStorage.getMessages(bare_jid);
callback(msgs); callback(msgs);
}; };
ob.Collections.getLastCollection = function (jid, callback) { ob.collections = {
'URI': 'http://www.xmpp.org/extensions/xep-0136.html#ns'
};
ob.collections.getLastCollection = function (jid, callback) {
var bare_jid = Strophe.getBareJidFromJid(jid), var bare_jid = Strophe.getBareJidFromJid(jid),
iq = $iq({'type':'get'}) iq = $iq({'type':'get'})
.c('list', {'xmlns': this.URI, .c('list', {'xmlns': this.URI,
...@@ -55,7 +61,7 @@ var xmppchat = (function (jarnxmpp, $, console) { ...@@ -55,7 +61,7 @@ var xmppchat = (function (jarnxmpp, $, console) {
}); });
}; };
ob.Collections.getLastMessages = function (jid, callback) { ob.collections.getLastMessages = function (jid, callback) {
var that = this; var that = this;
this.getLastCollection(jid, function (result) { this.getLastCollection(jid, function (result) {
// Retrieve the last page of a collection (max 30 elements). // Retrieve the last page of a collection (max 30 elements).
...@@ -155,6 +161,10 @@ xmppchat.ChatBoxView = Backbone.View.extend({ ...@@ -155,6 +161,10 @@ xmppchat.ChatBoxView = Backbone.View.extend({
$chat_content = $(this.el).find('.chat-content'), $chat_content = $(this.el).find('.chat-content'),
user_id = Strophe.getNodeFromJid(jid); user_id = Strophe.getNodeFromJid(jid);
if (xmppchat.xmppstatus.getOwnStatus() === 'offline') {
// only update the UI if the user is not offline
return;
}
if (!body) { if (!body) {
if (composing.length > 0) { if (composing.length > 0) {
this.insertStatusNotification('is typing'); this.insertStatusNotification('is typing');
...@@ -162,11 +172,7 @@ xmppchat.ChatBoxView = Backbone.View.extend({ ...@@ -162,11 +172,7 @@ xmppchat.ChatBoxView = Backbone.View.extend({
} }
} else { } else {
// TODO: ClientStorage // TODO: ClientStorage
xmppchat.Messages.ClientStorage.addMessage(jid, body, 'from'); xmppchat.messages.ClientStorage.addMessage(jid, body, 'from');
if (xmppchat.xmppstatus.getOwnStatus() === 'offline') {
// only update the UI if the user is not offline
return;
}
$chat_content.find('div.chat-event').remove(); $chat_content.find('div.chat-event').remove();
$chat_content.append( $chat_content.append(
this.message_template({ this.message_template({
...@@ -182,7 +188,7 @@ xmppchat.ChatBoxView = Backbone.View.extend({ ...@@ -182,7 +188,7 @@ xmppchat.ChatBoxView = Backbone.View.extend({
insertClientStoredMessages: function () { insertClientStoredMessages: function () {
var that = this; var that = this;
xmppchat.Messages.getMessages(this.model.get('jid'), function (msgs) { xmppchat.messages.getMessages(this.model.get('jid'), function (msgs) {
var $content = that.$el.find('.chat-content'); var $content = that.$el.find('.chat-content');
for (var i=0; i<_.size(msgs); i++) { for (var i=0; i<_.size(msgs); i++) {
var msg = msgs[i], var msg = msgs[i],
...@@ -224,7 +230,7 @@ xmppchat.ChatBoxView = Backbone.View.extend({ ...@@ -224,7 +230,7 @@ xmppchat.ChatBoxView = Backbone.View.extend({
.c('body').t(text).up() .c('body').t(text).up()
.c('active', {'xmlns': 'http://jabber.org/protocol/chatstates'}); .c('active', {'xmlns': 'http://jabber.org/protocol/chatstates'});
xmppchat.connection.send(message); xmppchat.connection.send(message);
xmppchat.Messages.ClientStorage.addMessage(bare_jid, text, 'to'); xmppchat.messages.ClientStorage.addMessage(bare_jid, text, 'to');
this.appendMessage(text); this.appendMessage(text);
}, },
...@@ -423,9 +429,18 @@ xmppchat.RoomsPanel = Backbone.View.extend({ ...@@ -423,9 +429,18 @@ xmppchat.RoomsPanel = Backbone.View.extend({
'<%=name%></a></dd>'), '<%=name%></a></dd>'),
initialize: function () { initialize: function () {
this.on('update-rooms-list', function (ev) {
this.updateRoomsList();
});
this.trigger('update-rooms-list');
},
updateRoomsList: function () {
// FIXME: Hardcoded
xmppchat.connection.muc.listRooms('conference.devbox', $.proxy(function (iq) { xmppchat.connection.muc.listRooms('conference.devbox', $.proxy(function (iq) {
var room, name, jid, var room, name, jid,
rooms = $(iq).find('query').find('item'); rooms = $(iq).find('query').find('item');
this.$el.find('#available-chatrooms').find('dd.chatroom').remove();
if (rooms.length) { if (rooms.length) {
this.$el.find('#available-chatrooms dt').show(); this.$el.find('#available-chatrooms dt').show();
} else { } else {
...@@ -519,8 +534,11 @@ xmppchat.ChatRoomView = xmppchat.ChatBoxView.extend({ ...@@ -519,8 +534,11 @@ xmppchat.ChatRoomView = xmppchat.ChatBoxView.extend({
xmppchat.connection.muc.leave( xmppchat.connection.muc.leave(
this.model.get('jid'), this.model.get('jid'),
this.model.get('nick'), this.model.get('nick'),
function () {}, this.onLeave,
undefined); undefined);
delete xmppchat.chatboxesview.views[this.model.get('jid')];
xmppchat.chatboxesview.model.remove(this.model.get('jid'));
this.remove();
}, },
keyPressed: function (ev) { keyPressed: function (ev) {
...@@ -578,6 +596,13 @@ xmppchat.ChatRoomView = xmppchat.ChatBoxView.extend({ ...@@ -578,6 +596,13 @@ xmppchat.ChatRoomView = xmppchat.ChatBoxView.extend({
$.proxy(this.onRoster, this)); $.proxy(this.onRoster, this));
}, },
onLeave: function () {
var controlboxview = xmppchat.chatboxesview.views['online-users-container'];
if (controlboxview) {
controlboxview.roomspanel.trigger('update-rooms-list');
}
},
onPresence: function (presence, room) { onPresence: function (presence, room) {
var nick = room.nick, var nick = room.nick,
from = $(presence).attr('from'); from = $(presence).attr('from');
...@@ -628,6 +653,10 @@ xmppchat.ChatRoomView = xmppchat.ChatBoxView.extend({ ...@@ -628,6 +653,10 @@ xmppchat.ChatRoomView = xmppchat.ChatBoxView.extend({
}, },
onRoster: function (roster, room) { onRoster: function (roster, room) {
var controlboxview = xmppchat.chatboxesview.views['online-users-container'];
if (controlboxview) {
controlboxview.roomspanel.trigger('update-rooms-list');
}
this.$el.find('.participant-list').empty(); this.$el.find('.participant-list').empty();
for (var i=0; i<_.size(roster); i++) { for (var i=0; i<_.size(roster); i++) {
this.$el.find('.participant-list').append('<li>' + _.keys(roster)[i] + '</li>'); this.$el.find('.participant-list').append('<li>' + _.keys(roster)[i] + '</li>');
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment