summaryrefslogtreecommitdiff
path: root/http/res/ranking.js
blob: 2bba8a188df4c5c8d937033cf192e43370492f3a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
var playerClick = function(ev) {
    if (!$(ev.target).closest('a').size()) {
        var row = $(this);
        var pid = row.find('td.pid').text();
        if (pid) {
            var link = 'players/' + pid.trim() + '.html';
            location.href = link;
        }
    }
}

var parseHash = function() {
    var hash = location.hash.replace(/^#/, '');
    var hashParams = hash.split(';');
    var params = new Map();
    hashParams.forEach(function(hashParam) {
        var param = hashParam.split(':');
        if (param.length > 1) {
            params.set(param[0], param[1].split(','));
        }
    });
    return params;
}

var constructHash = function(params) {
    return Array.from(params).map(function(param) {
        return param[0] + ':' + param[1].join(',');
    }).join(';');
}

var readHash = function() {
    $('button.btn-primary').removeClass('btn-primary');
    var params = parseHash();
    params.forEach(function(values, param) {
        values.forEach(function(value) {
            $('button[data-filter="' + param + '"][data-value="' + value + '"]').addClass('btn-primary');
        });
    });
    var allParams = ['age', 'gender', 'region'];
    allParams.forEach(function(param) {
        if ($('button[data-filter="' + param + '"].btn-primary').size() == 0) {
            $('button[data-clear="' + param + '"]').addClass('btn-primary');
        } else {
            $('#filters').collapse();
        }
    });
    filterRows(params);
}

var filterRows = function(params) {
    $('table.table tbody tr').show().removeClass('gold silver bronze').each(function() {
        var row = $(this);
        params.forEach(function(value, param) {
            if (value.indexOf(row.find('td.' + param).text().trim()) == -1) {
                row.hide();
            }
        });
    });
    $('table.table tbody tr:visible').eq(0).addClass('gold');
    $('table.table tbody tr:visible').eq(1).addClass('silver');
    $('table.table tbody tr:visible').eq(2).addClass('bronze');
    $('table.table').css('opacity', 1);
}

$('.container .table tbody tr').click(playerClick);

$(document).ready(function() {
    $(window).on('hashchange', readHash).trigger('hashchange');
});

$('button[data-filter]').click(function() {
    $('table.table').css('opacity', 0.1);
    var button = $(this);
    var params = parseHash();
    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) {
            param = [];
        }
        param.push(value);
    }
    if (!param.length) {
        params.delete(button.attr('data-filter'));
    } else {
        params.set(button.attr('data-filter'), param);
    }
    location.hash = constructHash(params);
});

$('button[data-clear]').click(function() {
    $('table.table').css('opacity', 0.1);
    var button = $(this);
    var params = parseHash();
    params.delete(button.attr('data-clear'));
    location.hash = constructHash(params);
});