Commit d1bafdb3 authored by JC Brand's avatar JC Brand

Re-render only the tab when `num_unread` changes.

parent f9fb13a7
...@@ -43,6 +43,7 @@ ...@@ -43,6 +43,7 @@
"use strict"; "use strict";
var USERS_PANEL_ID = 'users'; var USERS_PANEL_ID = 'users';
var CHATBOX_TYPE = 'chatbox';
// Strophe methods for building stanzas // Strophe methods for building stanzas
var Strophe = converse.env.Strophe, var Strophe = converse.env.Strophe,
Backbone = converse.env.Backbone, Backbone = converse.env.Backbone,
...@@ -287,6 +288,7 @@ ...@@ -287,6 +288,7 @@
'$parent': this.$el.find('.controlbox-panes') '$parent': this.$el.find('.controlbox-panes')
}); });
this.contactspanel.insertIntoDOM(); this.contactspanel.insertIntoDOM();
_converse.xmppstatusview = new _converse.XMPPStatusView({ _converse.xmppstatusview = new _converse.XMPPStatusView({
'model': _converse.xmppstatus 'model': _converse.xmppstatus
}); });
...@@ -585,23 +587,11 @@ ...@@ -585,23 +587,11 @@
initialize: function (cfg) { initialize: function (cfg) {
this.parent_el = cfg.$parent[0]; this.parent_el = cfg.$parent[0];
this.tab_el = document.createElement('li'); this.tab_el = document.createElement('li');
_converse.chatboxes.on('change:num_unread', this.render, this); _converse.chatboxes.on('change:num_unread', this.renderTab, this);
}, },
render: function () { render: function () {
var controlbox = _converse.chatboxes.get('controlbox'); this.renderTab();
var is_current = controlbox.get('active-panel') === USERS_PANEL_ID;
var isChatBox = function (item) {
return item.get('type') == 'chatbox';
}
var chatrooms = fp.filter(isChatBox, _converse.chatboxes.models);
this.tab_el.innerHTML = tpl_contacts_tab({
'label_contacts': LABEL_CONTACTS,
'is_current': is_current,
'num_unread': fp.sum(fp.map(fp.curry(utils.getAttribute)('num_unread'), chatrooms))
});
var widgets = tpl_contacts_panel({ var widgets = tpl_contacts_panel({
label_online: __('Online'), label_online: __('Online'),
...@@ -620,17 +610,28 @@ ...@@ -620,17 +610,28 @@
} }
this.el.innerHTML = widgets; this.el.innerHTML = widgets;
if (!is_current) { var controlbox = _converse.chatboxes.get('controlbox');
this.$el.addClass('hidden'); if (controlbox.get('active-panel') !== USERS_PANEL_ID) {
this.el.classList.add('hidden');
} }
return this; return this;
}, },
renderTab: function () {
var controlbox = _converse.chatboxes.get('controlbox');
var chats = fp.filter(_.partial(utils.isOfType, CHATBOX_TYPE), _converse.chatboxes.models);
this.tab_el.innerHTML = tpl_contacts_tab({
'label_contacts': LABEL_CONTACTS,
'is_current': controlbox.get('active-panel') === USERS_PANEL_ID,
'num_unread': fp.sum(fp.map(fp.curry(utils.getAttribute)('num_unread'), chats))
});
},
insertIntoDOM: function () { insertIntoDOM: function () {
this.parent_el.appendChild(this.render().el); this.parent_el.appendChild(this.render().el);
this.tabs = this.parent_el.parentNode.querySelector('#controlbox-tabs'); this.tabs = this.parent_el.parentNode.querySelector('#controlbox-tabs');
this.tabs.appendChild(this.tab_el); this.tabs.appendChild(this.tab_el);
this.$el.find('.search-xmpp ul').append( this.$('.search-xmpp ul').append(
this.generateAddContactHTML() this.generateAddContactHTML()
); );
return this; return this;
......
...@@ -2385,7 +2385,7 @@ ...@@ -2385,7 +2385,7 @@
this.tab_el = document.createElement('li'); this.tab_el = document.createElement('li');
this.model.on('change:muc_domain', this.onDomainChange, this); this.model.on('change:muc_domain', this.onDomainChange, this);
this.model.on('change:nick', this.onNickChange, this); this.model.on('change:nick', this.onNickChange, this);
_converse.chatboxes.on('change:num_unread', this.render, this); _converse.chatboxes.on('change:num_unread', this.renderTab, this);
}, },
render: function () { render: function () {
...@@ -2398,19 +2398,25 @@ ...@@ -2398,19 +2398,25 @@
'label_join': __('Join Room'), 'label_join': __('Join Room'),
'label_show_rooms': __('Show rooms') 'label_show_rooms': __('Show rooms')
}); });
this.renderTab();
var controlbox = _converse.chatboxes.get('controlbox'); var controlbox = _converse.chatboxes.get('controlbox');
var is_current = controlbox.get('active-panel') === ROOMS_PANEL_ID; if (controlbox.get('active-panel') !== ROOMS_PANEL_ID) {
var isChatroom = fp.curry(utils.isInstance)(_converse.ChatRoom) this.el.classList.add('hidden');
var chatrooms = fp.filter(isChatroom, _converse.chatboxes.models); }
return this;
},
renderTab: function () {
var controlbox = _converse.chatboxes.get('controlbox');
var chatrooms = fp.filter(
_.partial(utils.isOfType, CHATROOMS_TYPE),
_converse.chatboxes.models
);
this.tab_el.innerHTML = tpl_chatrooms_tab({ this.tab_el.innerHTML = tpl_chatrooms_tab({
'label_rooms': __('Rooms'), 'label_rooms': __('Rooms'),
'is_current': is_current, 'is_current': controlbox.get('active-panel') === ROOMS_PANEL_ID,
'num_unread': fp.sum(fp.map(fp.curry(utils.getAttribute)('num_unread'), chatrooms)) 'num_unread': fp.sum(fp.map(fp.curry(utils.getAttribute)('num_unread'), chatrooms))
}); });
if (!is_current) {
this.el.classList.add('hidden');
}
return this;
}, },
insertIntoDOM: function () { insertIntoDOM: function () {
......
...@@ -281,8 +281,6 @@ ...@@ -281,8 +281,6 @@
_converse.on('rosterGroupsFetched', this.positionFetchedGroups, this); _converse.on('rosterGroupsFetched', this.positionFetchedGroups, this);
_converse.on('rosterContactsFetched', this.update, this); _converse.on('rosterContactsFetched', this.update, this);
this.createRosterFilter(); this.createRosterFilter();
}, },
render: function () { render: function () {
......
...@@ -471,6 +471,10 @@ ...@@ -471,6 +471,10 @@
return utils.detectLocale(isSupportedByLibrary) || 'en'; return utils.detectLocale(isSupportedByLibrary) || 'en';
}; };
utils.isOfType = function (type, item) {
return item.get('type') == type;
}
utils.isInstance = function (type, item) { utils.isInstance = function (type, item) {
return item instanceof type; return item instanceof type;
}; };
......
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