mirror of
https://github.com/pi-hole/web.git
synced 2025-12-20 02:38:28 +00:00
utils: remove duplicate function and convert changeTableButtonStates to vanilla JS
Signed-off-by: XhmikosR <xhmikosr@gmail.com>
This commit is contained in:
@@ -418,33 +418,6 @@ function checkMessages() {
|
||||
});
|
||||
}
|
||||
|
||||
// Show only the appropriate delete buttons in datatables
|
||||
function changeBulkDeleteStates(table) {
|
||||
const allRows = table.rows({ filter: "applied" }).data().length;
|
||||
const pageLength = table.page.len();
|
||||
const selectedRows = table.rows(".selected").data().length;
|
||||
|
||||
if (selectedRows === 0) {
|
||||
// Nothing selected
|
||||
$(".selectAll").removeClass("hidden");
|
||||
$(".selectMore").addClass("hidden");
|
||||
$(".removeAll").addClass("hidden");
|
||||
$(".deleteSelected").addClass("hidden");
|
||||
} else if (selectedRows >= pageLength || selectedRows === allRows) {
|
||||
// Whole page is selected (or all available messages were selected)
|
||||
$(".selectAll").addClass("hidden");
|
||||
$(".selectMore").addClass("hidden");
|
||||
$(".removeAll").removeClass("hidden");
|
||||
$(".deleteSelected").removeClass("hidden");
|
||||
} else {
|
||||
// Some rows are selected, but not all
|
||||
$(".selectAll").addClass("hidden");
|
||||
$(".selectMore").removeClass("hidden");
|
||||
$(".removeAll").addClass("hidden");
|
||||
$(".deleteSelected").removeClass("hidden");
|
||||
}
|
||||
}
|
||||
|
||||
function doLogout(url) {
|
||||
$.ajax({
|
||||
url: document.body.dataset.apiurl + "/auth",
|
||||
@@ -474,30 +447,35 @@ function renderTimespan(data, type) {
|
||||
return data;
|
||||
}
|
||||
|
||||
// Show only the appropriate buttons
|
||||
// Show only the appropriate delete buttons in datatables
|
||||
function changeTableButtonStates(table) {
|
||||
const selectAllElements = document.querySelectorAll(".selectAll");
|
||||
const selectMoreElements = document.querySelectorAll(".selectMore");
|
||||
const removeAllElements = document.querySelectorAll(".removeAll");
|
||||
const deleteSelectedElements = document.querySelectorAll(".deleteSelected");
|
||||
|
||||
const allRows = table.rows({ filter: "applied" }).data().length;
|
||||
const pageLength = table.page.len();
|
||||
const selectedRows = table.rows(".selected").data().length;
|
||||
|
||||
if (selectedRows === 0) {
|
||||
// Nothing selected
|
||||
$(".selectAll").removeClass("hidden");
|
||||
$(".selectMore").addClass("hidden");
|
||||
$(".removeAll").addClass("hidden");
|
||||
$(".deleteSelected").addClass("hidden");
|
||||
for (const el of selectAllElements) el.classList.remove("hidden");
|
||||
for (const el of selectMoreElements) el.classList.add("hidden");
|
||||
for (const el of removeAllElements) el.classList.add("hidden");
|
||||
for (const el of deleteSelectedElements) el.classList.add("hidden");
|
||||
} else if (selectedRows >= pageLength || selectedRows === allRows) {
|
||||
// Whole page is selected (or all available messages were selected)
|
||||
$(".selectAll").addClass("hidden");
|
||||
$(".selectMore").addClass("hidden");
|
||||
$(".removeAll").removeClass("hidden");
|
||||
$(".deleteSelected").removeClass("hidden");
|
||||
for (const el of selectAllElements) el.classList.add("hidden");
|
||||
for (const el of selectMoreElements) el.classList.add("hidden");
|
||||
for (const el of removeAllElements) el.classList.remove("hidden");
|
||||
for (const el of deleteSelectedElements) el.classList.remove("hidden");
|
||||
} else {
|
||||
// Some rows are selected, but not all
|
||||
$(".selectAll").addClass("hidden");
|
||||
$(".selectMore").removeClass("hidden");
|
||||
$(".removeAll").addClass("hidden");
|
||||
$(".deleteSelected").removeClass("hidden");
|
||||
for (const el of selectAllElements) el.classList.add("hidden");
|
||||
for (const el of selectMoreElements) el.classList.remove("hidden");
|
||||
for (const el of removeAllElements) el.classList.add("hidden");
|
||||
for (const el of deleteSelectedElements) el.classList.remove("hidden");
|
||||
}
|
||||
}
|
||||
|
||||
@@ -722,7 +700,6 @@ globalThis.utils = (function () {
|
||||
toPercent,
|
||||
colorBar,
|
||||
checkMessages,
|
||||
changeBulkDeleteStates,
|
||||
doLogout,
|
||||
renderTimestamp,
|
||||
renderTimespan,
|
||||
|
||||
Reference in New Issue
Block a user