aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/common
diff options
context:
space:
mode:
authorStas Vilchik <vilchiks@gmail.com>2014-10-15 10:55:53 +0200
committerStas Vilchik <vilchiks@gmail.com>2014-10-15 11:10:12 +0200
commit01ae5b1fed246ac25e15e8efe2ba75fd0c5b9516 (patch)
treea40a853903198741c0ea1eb5ded151e796ce6bde /server/sonar-web/src/main/js/common
parent875f335cfa7c8bd07ca84de6b42d3bc57c85c71c (diff)
downloadsonarqube-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.js47
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();
}
}