Commit 2869485c authored by JC Brand's avatar JC Brand

Fixes to trimming of chats.

- Don't trim if not connected.
- Move trimChats call to converse-minimized
- Immediately hide view to avoid race conditions.
parent 8f601e8c
...@@ -827,6 +827,19 @@ ...@@ -827,6 +827,19 @@
return this; return this;
}, },
afterShown: function () {
if (converse.connection.connected) {
// Without a connection, we haven't yet initialized
// localstorage
this.model.save();
}
this.setChatState(converse.ACTIVE);
this.scrollDown();
if (focus) {
this.focus();
}
},
show: function (focus) { show: function (focus) {
if (typeof this.debouncedShow === 'undefined') { if (typeof this.debouncedShow === 'undefined') {
/* We wrap the method in a debouncer and set it on the /* We wrap the method in a debouncer and set it on the
...@@ -839,19 +852,7 @@ ...@@ -839,19 +852,7 @@
return; return;
} }
this.initDragResize().setDimensions(); this.initDragResize().setDimensions();
this.$el.fadeIn(function () { this.$el.fadeIn(this.afterShown.bind(this));
if (converse.connection.connected) {
// Without a connection, we haven't yet initialized
// localstorage
this.model.save();
}
converse.chatboxviews.trimChats(this);
this.setChatState(converse.ACTIVE);
this.scrollDown();
if (focus) {
this.focus();
}
}.bind(this));
}, 250, true); }, 250, true);
} }
this.debouncedShow.apply(this, arguments); this.debouncedShow.apply(this, arguments);
......
...@@ -52,7 +52,9 @@ ...@@ -52,7 +52,9 @@
this._super.registerGlobalEventHandlers.apply(this, arguments); this._super.registerGlobalEventHandlers.apply(this, arguments);
$(window).on("resize", _.debounce(function (ev) { $(window).on("resize", _.debounce(function (ev) {
if (converse.connection.connected) {
converse.chatboxviews.trimChats(); converse.chatboxviews.trimChats();
}
}, 200)); }, 200));
}, },
...@@ -104,6 +106,13 @@ ...@@ -104,6 +106,13 @@
return this._super.initialize.apply(this, arguments); return this._super.initialize.apply(this, arguments);
}, },
afterShown: function () {
this._super.afterShown.apply(this, arguments);
if (!this.model.get('minimized')) {
converse.chatboxviews.trimChats(this);
}
},
shouldShowOnTextMessage: function () { shouldShowOnTextMessage: function () {
return !this.model.get('minimized') && return !this.model.get('minimized') &&
this._super.shouldShowOnTextMessage.apply(this, arguments); this._super.shouldShowOnTextMessage.apply(this, arguments);
...@@ -199,7 +208,7 @@ ...@@ -199,7 +208,7 @@
if (converse.no_trimming || (this.model.length <= 1)) { if (converse.no_trimming || (this.model.length <= 1)) {
return; return;
} }
var oldest_chat, boxes_width, var oldest_chat, boxes_width, view,
$minimized = converse.minimized_chats.$el, $minimized = converse.minimized_chats.$el,
minimized_width = _.contains(this.model.pluck('minimized'), true) ? $minimized.outerWidth(true) : 0, minimized_width = _.contains(this.model.pluck('minimized'), true) ? $minimized.outerWidth(true) : 0,
new_id = newchat ? newchat.model.get('id') : null; new_id = newchat ? newchat.model.get('id') : null;
...@@ -211,6 +220,14 @@ ...@@ -211,6 +220,14 @@
if ((minimized_width + boxes_width) > $('body').outerWidth(true)) { if ((minimized_width + boxes_width) > $('body').outerWidth(true)) {
oldest_chat = this.getOldestMaximizedChat([new_id]); oldest_chat = this.getOldestMaximizedChat([new_id]);
if (oldest_chat) { if (oldest_chat) {
// We hide the chat immediately, because waiting
// for the event to fire (and letting the
// ChatBoxView hide it then) causes race
// conditions.
view = this.get(oldest_chat.get('id'));
if (view) {
view.$el.hide();
}
oldest_chat.minimize(); oldest_chat.minimize();
} }
} }
...@@ -434,7 +451,9 @@ ...@@ -434,7 +451,9 @@
converse.on('controlBoxOpened', function (evt, chatbox) { converse.on('controlBoxOpened', function (evt, chatbox) {
// Wrapped in anon method because at scan time, chatboxviews // Wrapped in anon method because at scan time, chatboxviews
// attr not set yet. // attr not set yet.
if (converse.connection.connected) {
converse.chatboxviews.trimChats(chatbox); converse.chatboxviews.trimChats(chatbox);
}
}); });
} }
}); });
......
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