var helpers = (function (helpers) { helpers.oc = function (a) { // Thanks to Jonathan Snook: http://snook.ca var o = {}; for(var i=0; i= 30) { msgs.shift(); } msgs.push(now+' '+direction+' '+msg); store.set(bare_jid, msgs); }; methods.getMessages = function (jid) { return store.get(jid) || []; }; return methods; })(); ob.Messages.getMessages = function (jid, callback) { var bare_jid = Strophe.getBareJidFromJid(jid), msgs = this.ClientStorage.getMessages(bare_jid); callback(msgs); }; ob.Messages.sendMessage = function (jid, text, callback) { // TODO: Look in ChatPartners to see what resources we have for the recipient. // if we have one resource, we sent to only that resources, if we have multiple // we send to the bare jid. // FIXME: see if @@content-transform is required var message, that = this; $.getJSON(portal_url + '/content-transform?', {text: text}, function (data) { message = $msg({to: jid, type: 'chat'}) .c('body').t(data.text).up() .c('active', {'xmlns': 'http://jabber.org/protocol/chatstates'}); xmppchat.connection.send(message); that.ClientStorage.addMessage(jid, data.text, 'to'); callback(); }); }; ob.Messages.messageReceived = function (message) { var jid = $(message).attr('from'), bare_jid = Strophe.getBareJidFromJid(jid), resource = Strophe.getResourceFromJid(jid), delayed = $(message).find('delay').length > 0, body = $(message).children('body').text(), event = jQuery.Event('jarnxmpp.message'); if (body !== "") { var xhtml_body = $(message).find('html > body').contents(); if (xhtml_body.length > 0) { event.mtype = 'xhtml'; event.body = xhtml_body.html(); } else { event.body = body; event.mtype = 'text'; } } event.from = jid; event.delayed = delayed; event.message = message; ob.ChatPartners.add(bare_jid, resource); if (event.body) { ob.Messages.ClientStorage.addMessage(jid, event.body, 'from'); } if ((xmppchat.Storage.get(xmppchat.username+'-xmpp-status') || 'online') !== 'offline') { // Only trigger the UI event if the user is not offline. $(document).trigger(event); } return true; }; ob.Collections.getLastCollection = function (jid, callback) { var bare_jid = Strophe.getBareJidFromJid(jid), iq = $iq({'type':'get'}) .c('list', {'xmlns': this.URI, 'with': bare_jid }) .c('set', {'xmlns': 'http://jabber.org/protocol/rsm'}) .c('before').up() .c('max') .t('1'); xmppchat.connection.sendIQ(iq, callback, function () { console.log('Error while retrieving collections'); }); }; ob.Collections.getLastMessages = function (jid, callback) { var that = this; this.getLastCollection(jid, function (result) { // Retrieve the last page of a collection (max 30 elements). var $collection = $(result).find('chat'), jid = $collection.attr('with'), start = $collection.attr('start'), iq = $iq({'type':'get'}) .c('retrieve', {'start': start, 'xmlns': that.URI, 'with': jid }) .c('set', {'xmlns': 'http://jabber.org/protocol/rsm'}) .c('max') .t('30'); xmppchat.connection.sendIQ(iq, callback); }); }; ob.Presence.getOwnStatus = function () { return xmppchat.Storage.get(xmppchat.username+'-xmpp-status'); }; ob.Presence.onlineCount = function () { return xmppchat.ChatPartners.getTotal(); }; ob.Presence.sendPresence = function (type) { if (type === undefined) { type = this.getOwnStatus() || 'online'; } xmppchat.connection.send($pres({'type':type})); }; ob.Taskbuffer = (function ($) { // Executes tasks one after another (i.e next task is started only when // the previous one has been completed). buffer = {}; // Tasks must be objects with keys: 'that', 'method' and 'parameters' // 'that' the context for the method, while 'parameters' is the list of arguments // passed to it. buffer.tasks = []; buffer.deferred = $.when(); buffer.handleTasks = function () { var task; // If the current deferred task is resolved and there are more tasks if (buffer.deferred.isResolved() && buffer.tasks.length > 0) { // Get the next task in the queue and set the new deferred. task = buffer.tasks.shift(); buffer.deferred = $.when(task.method.apply(task.that, task.parameters)); if (buffer.tasks.length > 0) { buffer.deferred.done(buffer.handleTasks); } } }; return buffer; })(jQuery); return ob; })(jarnxmpp || {}, jQuery, console || {log: function(){}}); xmppchat.ChatBox = Backbone.Model.extend({ hash: function (str) { var shaobj = new jsSHA(str); return shaobj.getHash("HEX"); }, initialize: function () { this.set({ 'user_id' : Strophe.getNodeFromJid(this.get('jid')), 'chat_id' : this.hash(this.get('jid')) }); } }); xmppchat.ChatBoxView = Backbone.View.extend({ tagName: 'div', className: 'chatbox', events: { 'click .close-chatbox-button': 'closeChat' }, addChatToCookie: function () { var cookie = jQuery.cookie('chats-open-'+xmppchat.username), jid = this.model.get('jid'), new_cookie, open_chats = []; if (cookie) { open_chats = cookie.split('|'); } if (!_.has(open_chats, jid)) { // Update the cookie if this new chat is not yet in it. open_chats.push(jid); new_cookie = open_chats.join('|'); jQuery.cookie('chats-open-'+xmppchat.username, new_cookie, {path: '/'}); console.log('updated cookie = ' + new_cookie + '\n'); } }, removeChatFromCookie: function () { var cookie = jQuery.cookie('chats-open-'+xmppchat.username), open_chats = [], new_chats = []; if (cookie) { open_chats = cookie.split('|'); } for (var i=0; i < open_chats.length; i++) { if (open_chats[i] != this.model.get('jid')) { new_chats.push(open_chats[i]); } } if (new_chats.length) { jQuery.cookie('chats-open-'+xmppchat.username, new_chats.join('|'), {path: '/'}); } else { jQuery.cookie('chats-open-'+xmppchat.username, null, {path: '/'}); } }, closeChat: function () { var that = this; $('#'+this.model.get('chat_id')).hide('fast', function () { that.removeChatFromCookie(that.model.get('id')); // Only reorder chats if it wasn't the last chat being closed. var offset = parseInt($(that.el).css('right'), 10) + xmppchat.chatboxesview.chatbox_width; if ($("div[style*='right: "+offset+"px']").length > 0) { xmppchat.chatboxesview.reorderChats(); } }); }, initialize: function (){ $('body').append($(this.el).hide()); }, template: _.template('
' + '
<%= user_id %>
' + 'X' + '
' + '
' + '
' + '
' + '