forked from loujine/musicbrainz-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmb-display_sortable_table.user.js
105 lines (101 loc) · 4.19 KB
/
mb-display_sortable_table.user.js
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
101
102
103
104
105
/* global $ sidebar */
'use strict';
// ==UserScript==
// @name MusicBrainz: Display sort button on table columns
// @namespace mbz-loujine
// @author loujine
// @version 2021.11.6
// @downloadURL https://raw.githubusercontent.com/loujine/musicbrainz-scripts/master/mb-display_sortable_table.user.js
// @updateURL https://raw.githubusercontent.com/loujine/musicbrainz-scripts/master/mb-display_sortable_table.user.js
// @supportURL https://github.com/loujine/musicbrainz-scripts
// @icon https://raw.githubusercontent.com/loujine/musicbrainz-scripts/master/icon.png
// @description musicbrainz.org: Make table columns sortable
// @compatible firefox+tampermonkey
// @license MIT
// @require https://raw.githubusercontent.com/loujine/musicbrainz-scripts/master/mbz-loujine-common.js
// @include http*://*musicbrainz.org/work/*
// @exclude http*://*musicbrainz.org/work/create
// @exclude http*://*musicbrainz.org/work/*/*
// @include http*://*musicbrainz.org/instrument/*/recordings
// @include http*://*musicbrainz.org/instrument/*/recordings?page=*
// @include http*://*musicbrainz.org/artist/*/relationships
// @include http*://*musicbrainz.org/artist/*/releases
// @grant none
// @run-at document-end
// ==/UserScript==
function comparefct(index, title, asc) {
return function (row1, row2) {
const text1 = row1.querySelectorAll('td')[index].textContent;
const text2 = row2.querySelectorAll('td')[index].textContent;
if (index === 0) {
let d1 = new Date(text1.split(' – ')[0]);
let d2 = new Date(text2.split(' – ')[0]);
// consider missing dates as year 3000 if ascending order
// and year 1000 if descending
if (isNaN(d1.getDate())) {
d1 = new Date(asc ? 3000 : 1000, 0);
}
if (isNaN(d2.getDate())) {
d2 = new Date(asc ? 3000 : 1000, 0);
}
return d2 - d1;
}
if (title.startsWith('Length')) {
const regexp1 = new RegExp('(.*):(.*)').exec(text1);
const regexp2 = new RegExp('(.*):(.*)').exec(text2);
let t1 = parseInt(regexp1[1]) * 60 + parseInt(regexp1[2]);
let t2 = parseInt(regexp2[1]) * 60 + parseInt(regexp2[2]);
if (isNaN(t1)) {
t1 = asc ? 36000 : -1;
}
if (isNaN(t2)) {
t2 = asc ? 36000 : -1;
}
// consider missing durations as 10 hours if ascending order
// and -1 second if descending
return t2 - t1;
}
return text1.localeCompare(text2);
};
}
function sortByClickedColumn(evt) {
const table = $(evt.target).parents('table');
const colidx = $(evt.target).index();
const coltitle = evt.target.textContent;
let rowclass;
let rows = table.find('tbody tr.even,tbody tr.odd').not('.subh').get().sort(
comparefct(colidx, coltitle, this.asc) // eslint-disable-line no-invalid-this
);
// reverse order if clicked several times
this.asc = !this.asc; // eslint-disable-line no-invalid-this
if (!this.asc) { // eslint-disable-line no-invalid-this
rows = rows.reverse();
}
rows.forEach((row, idx) => {
row.classList.remove('even', 'odd');
rowclass = idx % 2 ? 'even' : 'odd';
row.classList.add(rowclass);
table.append(row);
});
table[0].querySelectorAll('tbody tr:not(.even,.odd,.subh)').forEach((row, idx) => {
table.append(row);
});
}
(function displaySidebar() {
sidebar.container().insertAdjacentHTML('beforeend', `
<h3>Sortable columns<h3>
<input type="button" id="makeSortable" value="Make columns sortable">
`);
})();
$(document).ready(function () {
document.getElementById('makeSortable').addEventListener('click', () => {
document.querySelectorAll('table.tbl thead th:not(.sortable)').forEach(
node => {
node.insertAdjacentHTML('beforeend', '<span>↕</span>');
node.addEventListener('click', sortByClickedColumn);
node.classList.add('sortable');
}
);
});
return false;
});