From 525ebc41f093ce406fca73037f6df75bc346f4fd Mon Sep 17 00:00:00 2001 From: Breizh Date: Mon, 26 Sep 2022 00:44:52 +0200 Subject: [PATCH] Restauration de la fonction de tri --- assets/sort.js | 62 ++++++++++++++++++++++++++++++++++++++++++++++++++ generator.sh | 2 +- 2 files changed, 63 insertions(+), 1 deletion(-) create mode 100644 assets/sort.js diff --git a/assets/sort.js b/assets/sort.js new file mode 100644 index 0000000..89a1bd7 --- /dev/null +++ b/assets/sort.js @@ -0,0 +1,62 @@ +function sortTable(n) { + var table, rows, switching, i, x, y, shouldSwitch, dir, switchcount = 0; + table = document.getElementById("maintable"); + switching = true; + // Set the sorting direction to ascending: + dir = "asc"; + /* Make a loop that will continue until + no switching has been done: */ + while (switching) { + // Start by saying: no switching is done: + switching = false; + rows = table.rows; + /* Loop through all table rows (except the + first, which contains table headers): */ + for (i = 1; i < (rows.length - 1); i++) { + // Start by saying there should be no switching: + shouldSwitch = false; + /* Get the two elements you want to compare, + one from current row and one from the next: */ + x = rows[i].getElementsByTagName("TD")[n]; + y = rows[i + 1].getElementsByTagName("TD")[n]; + /* Check if the two rows should switch place, + based on the direction, asc or desc: */ + if (dir == "asc") { + if (n == 1 && Number(x.dataset.kbytes) > Number(y.dataset.kbytes)) { + shouldSwitch = true; + break; + } + else if (n != 1 && x.innerHTML.toLowerCase() > y.innerHTML.toLowerCase()) { + // If so, mark as a switch and break the loop: + shouldSwitch = true; + break; + } + } else if (dir == "desc") { + if (n == 1 && Number(x.dataset.kbytes) < Number(y.dataset.kbytes)) { + shouldSwitch = true; + break; + } + else if (n != 1 && x.innerHTML.toLowerCase() < y.innerHTML.toLowerCase()) { + // If so, mark as a switch and break the loop: + shouldSwitch = true; + break; + } + } + } + if (shouldSwitch) { + /* If a switch has been marked, make the switch + and mark that a switch has been done: */ + rows[i].parentNode.insertBefore(rows[i + 1], rows[i]); + switching = true; + // Each time a switch is done, increase this count by 1: + switchcount ++; + } else { + /* If no switching has been done AND the direction is "asc", + set the direction to "desc" and run the while loop again. */ + if (switchcount == 0 && dir == "asc") { + dir = "desc"; + switching = true; + } + } + } +} diff --git a/generator.sh b/generator.sh index bdd5a06..a06ef6c 100755 --- a/generator.sh +++ b/generator.sh @@ -58,7 +58,7 @@ DELIM footer() { cat < - + DELIM