Commit fc48e029 authored by JC Brand's avatar JC Brand

More lazily render the bookmarks list

Could still be improved.
parent ee6c5dbf
...@@ -2175,7 +2175,7 @@ ...@@ -2175,7 +2175,7 @@
color: #818479; color: #818479;
margin-bottom: 0.5em; } margin-bottom: 0.5em; }
#conversejs #controlbox .bookmarks-list .bookmarks li { #conversejs #controlbox .bookmarks-list .bookmarks li {
padding: 0.3em 1em; } padding: 0.1em 1em; }
#conversejs #controlbox .bookmarks-list .bookmarks li .open-room { #conversejs #controlbox .bookmarks-list .bookmarks li .open-room {
display: inline-block; display: inline-block;
overflow: hidden; overflow: hidden;
......
#conversejs { #conversejs {
#controlbox { #controlbox {
.bookmarks-list { .bookmarks-list {
margin-top: 2em;
.bookmarks-toggle { .bookmarks-toggle {
display: block; display: block;
font-weight: bold; font-weight: bold;
...@@ -10,7 +9,7 @@ ...@@ -10,7 +9,7 @@
} }
.bookmarks { .bookmarks {
li { li {
padding: 0.3em 1em; padding: 0.1em 1em;
.open-room { .open-room {
display: inline-block; display: inline-block;
overflow: hidden; overflow: hidden;
......
...@@ -108,6 +108,8 @@ ...@@ -108,6 +108,8 @@
} }
#chatrooms { #chatrooms {
padding-top: 2em;
form.add-chatroom { form.add-chatroom {
input[type=button], input[type=button],
input[type=submit], input[type=submit],
......
...@@ -385,6 +385,8 @@ ...@@ -385,6 +385,8 @@
describe("The rooms panel", function () { describe("The rooms panel", function () {
beforeEach(function () { beforeEach(function () {
test_utils.openRoomsPanel(); test_utils.openRoomsPanel();
converse.bookmarks.reset();
converse.chatboxviews.get('controlbox').$('#chatrooms ul.bookmarks').html('');
}); });
it("shows a list of bookmarks", function () { it("shows a list of bookmarks", function () {
......
...@@ -312,12 +312,6 @@ ...@@ -312,12 +312,6 @@
'label_bookmarks': __('Bookmarked Rooms') 'label_bookmarks': __('Bookmarked Rooms')
})); }));
this.$bookmarks = this.$('.bookmarks'); this.$bookmarks = this.$('.bookmarks');
var controlboxview = converse.chatboxviews.get('controlbox');
if (_.isUndefined(controlboxview)) {
return this.$el;
}
controlboxview.$('#chatrooms .bookmarks-list').remove();
this.$el.prependTo(controlboxview.$('#chatrooms'));
return this.$el; return this.$el;
}, },
...@@ -332,18 +326,20 @@ ...@@ -332,18 +326,20 @@
}, },
onBookmarkAdded: function (item) { onBookmarkAdded: function (item) {
if (_.isUndefined(this.$bookmarks)) { // TODO: Try to come up with a way to avoid DOM reflows.
this.render(); var $bookmark = $(converse.templates.bookmark({
}
this.$bookmarks.append($(
converse.templates.bookmark({
'name': item.get('name'), 'name': item.get('name'),
'jid': item.get('jid'), 'jid': item.get('jid'),
'open_title': __('Click to open this room'), 'open_title': __('Click to open this room'),
'info_title': __('Show more information on this room'), 'info_title': __('Show more information on this room'),
'info_remove': __('Remove this bookmark') 'info_remove': __('Remove this bookmark')
}) }));
)); if (_.isUndefined(this.$bookmarks)) {
this.render();
var controlboxview = converse.chatboxviews.get('controlbox');
this.$el.prependTo(controlboxview.$('#chatrooms'));
}
this.$bookmarks.append($bookmark);
}, },
toggleBookmarksList: function (ev) { toggleBookmarksList: function (ev) {
...@@ -365,9 +361,6 @@ ...@@ -365,9 +361,6 @@
{'model': converse.bookmarks} {'model': converse.bookmarks}
); );
converse.bookmarks.fetchBookmarks(); converse.bookmarks.fetchBookmarks();
// TODO: think of performance here... we probably only want to
// show the bookmarks after they have been fetched
converse.bookmarksview.render();
}; };
converse.on('connected', converse.initBookmarks); converse.on('connected', converse.initBookmarks);
converse.on('reconnected', converse.initBookmarks); converse.on('reconnected', converse.initBookmarks);
......
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