Commit 94637781 authored by JC Brand's avatar JC Brand

Some optimization changes.

Don't sort roster contacts needlessly.
Don't call show() or hide() needlessly.
No need for setting a 'sorted' attr on the last item.
parent c5e44a02
...@@ -2257,44 +2257,41 @@ ...@@ -2257,44 +2257,41 @@
$contact_requests.after(view.render().el); $contact_requests.after(view.render().el);
$contact_requests.after($contact_requests.siblings('dd.requesting-xmpp-contact').tsort(crit)); $contact_requests.after($contact_requests.siblings('dd.requesting-xmpp-contact').tsort(crit));
} else if (subscription === 'both' || subscription === 'to') { } else if (subscription === 'both' || subscription === 'to') {
if (!item.get('sorted')) { if ($.contains(document.documentElement, view.el)) {
// this attribute will be true only after all of the elements have been added on the page
// at this point all offline
$my_contacts.after(view.render().el);
}
else {
// just by calling render will be enough to change the icon of the existing item without
// having to reinsert it and the sort will come from the presence change
view.render(); view.render();
} else {
$my_contacts.after(view.render().el);
} }
} }
presence_change = view.model.changed.chat_status; presence_change = view.model.changed.chat_status;
if (presence_change) { if (presence_change) {
// resort all items only if the model has changed it's chat_status as this render $my_contacts.siblings('dd.current-xmpp-contact.'+presence_change).tsort('a', crit);
// is also triggered when the resource is changed which always comes before the presence change $my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.offline'));
// therefore we avoid resorting when the change doesn't affect the position of the item $my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.unavailable'));
$my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.offline').tsort('a', crit)); $my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.away'));
$my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.unavailable').tsort('a', crit)); $my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.dnd'));
$my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.away').tsort('a', crit)); $my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.online'));
$my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.dnd').tsort('a', crit));
$my_contacts.after($my_contacts.siblings('dd.current-xmpp-contact.online').tsort('a', crit));
} }
if (item.get('is_last') && !item.get('sorted')) { if (item.get('is_last')) {
// this will be true after all of the roster items have been added with the default if (!this.$el.is(':visible')) {
// options where all of the items are offline and now we can show the rosterView // Once all initial roster items have been added, we
item.set('sorted', true); // can show the roster.
this.initialSort(); this.initialSort();
this.$el.show(); this.$el.show();
}
converse.xmppstatus.sendPresence(); converse.xmppstatus.sendPresence();
} }
} }
// Hide the headings if there are no contacts under them // Hide the headings if there are no contacts under them
_.each([$my_contacts, $contact_requests, $pending_contacts], function (h) { _.each([$my_contacts, $contact_requests, $pending_contacts], function (h) {
if (h.nextUntil('dt').length) { if (h.nextUntil('dt').length) {
h.show(); if (!h.is(':visible')) {
h.show();
}
} }
else { else if (h.is(':visible')) {
h.hide(); h.hide();
} }
}); });
......
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