diff options
author | Stas Vilchik <vilchiks@gmail.com> | 2014-10-15 10:55:53 +0200 |
---|---|---|
committer | Stas Vilchik <vilchiks@gmail.com> | 2014-10-15 11:10:12 +0200 |
commit | 01ae5b1fed246ac25e15e8efe2ba75fd0c5b9516 (patch) | |
tree | a40a853903198741c0ea1eb5ded151e796ce6bde /server/sonar-web/src/main/js/common | |
parent | 875f335cfa7c8bd07ca84de6b42d3bc57c85c71c (diff) | |
download | sonarqube-01ae5b1fed246ac25e15e8efe2ba75fd0c5b9516.tar.gz sonarqube-01ae5b1fed246ac25e15e8efe2ba75fd0c5b9516.zip |
SONAR-5736 The select list component does not fetch more than one page
Diffstat (limited to 'server/sonar-web/src/main/js/common')
-rw-r--r-- | server/sonar-web/src/main/js/common/select-list.js | 47 |
1 files changed, 27 insertions, 20 deletions
diff --git a/server/sonar-web/src/main/js/common/select-list.js b/server/sonar-web/src/main/js/common/select-list.js index e19dea825ec..30ca5e50a6f 100644 --- a/server/sonar-web/src/main/js/common/select-list.js +++ b/server/sonar-web/src/main/js/common/select-list.js @@ -51,8 +51,10 @@ requirejs(['backbone'], function (Backbone) { settings = $.extend(this.settings, options); settings.data.page = nextPage; - + settings.remove = false; this.fetch(settings); + } else { + options.error(); } } @@ -171,6 +173,28 @@ requirejs(['backbone'], function (Backbone) { this.listenTo(this.collection, 'remove', this.removeModel); this.listenTo(this.collection, 'change:selected', this.confirmFilter); this.settings = options.settings; + + var that = this; + this.showFetchSpinner = function () { + that.$listContainer.addClass('loading'); + }; + this.hideFetchSpinner = function () { + that.$listContainer.removeClass('loading'); + }; + + var onScroll = function () { + that.showFetchSpinner(); + + that.collection.fetchNextPage({ + success: function () { + that.hideFetchSpinner(); + }, + error: function () { + that.hideFetchSpinner(); + } + }); + }; + this.onScroll = _.throttle(onScroll, 1000); }, render: function () { @@ -331,29 +355,12 @@ requirejs(['backbone'], function (Backbone) { this.filterBySelection(); }, - showFetchSpinner: function () { - this.$listContainer.addClass('loading'); - }, - - hideFetchSpinner: function () { - this.$listContainer.removeClass('loading'); - }, - scroll: function () { var scrollBottom = this.$listContainer.scrollTop() >= - this.$list[0].scrollHeight - this.$listContainer.outerHeight(), - that = this; + this.$list[0].scrollHeight - this.$listContainer.outerHeight(); if (scrollBottom && this.collection.more) { - $.throttle(250, function () { - that.showFetchSpinner(); - - that.collection.fetchNextPage({ - success: function () { - that.hideFetchSpinner(); - } - }); - })(); + this.onScroll(); } } |