summaryrefslogtreecommitdiff
path: root/http
diff options
context:
space:
mode:
authoremkael <emkael@tlen.pl>2017-06-08 00:36:16 +0200
committeremkael <emkael@tlen.pl>2017-06-08 00:36:16 +0200
commitf2c215082b8735a6851935f04122dcb6af3f5291 (patch)
treec7315e06ca95efb3c8104ef03230f0823482e582 /http
parent68a86f42f460ef3abf3a2e7995a96e7d7721df89 (diff)
Locking filters panel while filtering
Diffstat (limited to 'http')
-rw-r--r--http/res/ranking.js61
1 files changed, 35 insertions, 26 deletions
diff --git a/http/res/ranking.js b/http/res/ranking.js
index 063b32d..1e34732 100644
--- a/http/res/ranking.js
+++ b/http/res/ranking.js
@@ -98,7 +98,8 @@ var ranking = {
ranking.filterRows(params);
ranking.savedParams = params;
}
- $('table.table').css('opacity', 1);
+ $('table.table, .filters .panel-body').css('opacity', 1);
+ ranking.filtersDisabled = false;
var pagesize = 40;
var page = params.get('page') || [0];
var count = $('table.table-paginate').paginate(pagesize, parseInt(page[0]));
@@ -109,6 +110,8 @@ var ranking = {
ranking.buildPaginator('#bottom-paginator', count, pagesize, page[0] || 1);
},
+ filtersDisabled: false,
+
filterRows : function(params) {
$('table.table tbody tr').show().removeClass('gold silver bronze').each(function() {
var row = $(this);
@@ -176,36 +179,42 @@ var ranking = {
});
$('button[data-filter]').click(function(ev) {
- $('table.table').css('opacity', 0.1);
- var button = $(this);
- var params = ranking.parseHash(location.hash);
- var param = params.get(button.attr('data-filter'));
- var value = button.attr('data-value');
- var index = param ? param.indexOf(value) : -1;
- if (index > -1) {
- param = param.filter(function(v) { return v != value; });
- } else {
- if (!param || !ev.ctrlKey) {
- param = [];
+ if (!ranking.filtersDisabled) {
+ ranking.filtersDisabled = true;
+ $('table.table, .filters .panel-body').css('opacity', 0.1);
+ var button = $(this);
+ var params = ranking.parseHash(location.hash);
+ var param = params.get(button.attr('data-filter'));
+ var value = button.attr('data-value');
+ var index = param ? param.indexOf(value) : -1;
+ if (index > -1) {
+ param = param.filter(function(v) { return v != value; });
+ } else {
+ if (!param || !ev.ctrlKey) {
+ param = [];
+ }
+ param.push(value);
}
- param.push(value);
- }
- if (!param.length) {
- params.delete(button.attr('data-filter'));
- } else {
- params.set(button.attr('data-filter'), param);
+ if (!param.length) {
+ params.delete(button.attr('data-filter'));
+ } else {
+ params.set(button.attr('data-filter'), param);
+ }
+ params.delete('page');
+ location.hash = ranking.constructHash(params);
}
- params.delete('page');
- location.hash = ranking.constructHash(params);
});
$('button[data-clear]').click(function() {
- $('table.table').css('opacity', 0.1);
- var button = $(this);
- var params = ranking.parseHash(location.hash);
- params.delete(button.attr('data-clear'));
- params.delete('page');
- location.hash = ranking.constructHash(params);
+ if (!ranking.filtersDisabled) {
+ ranking.filtersDisabled = true;
+ $('table.table, .filters .panel-body').css('opacity', 0.1);
+ var button = $(this);
+ var params = ranking.parseHash(location.hash);
+ params.delete(button.attr('data-clear'));
+ params.delete('page');
+ location.hash = ranking.constructHash(params);
+ }
});
$(document).on('click', 'button.paginator-prev, button.paginator-next, button.paginator-page', ranking.changePage);