ArgusSite/static/scripts/table.js
2023-07-16 19:09:25 +03:00

351 lines
9.9 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

// const devices = [
// {
// id: "1",
// group: "2-device-1",
// name: "Трамваи",
// plate: "AB1234",
// serial: "008803559E",
// sim: "1234567890",
// channels: 12,
// ip: "192.168.0.1",
// port: 17891,
// },
// {
// id: "2",
// group: "2-device-2",
// name: "Электробусы",
// plate: "BC2345",
// serial: "008803559E",
// sim: "2345678901",
// channels: 12,
// ip: "192.168.0.2",
// port: 17891,
// },
// {
// id: "3",
// group: "2-device-1",
// name: "Трамваи",
// plate: "CD3456",
// serial: "009800852A",
// sim: "3456789012",
// channels: 16,
// ip: "192.168.0.3",
// port: 17891,
// },
// {
// id: "4",
// group: "2-device-3",
// name: "Троллейбусы",
// plate: "DE4567",
// serial: "009800858D",
// sim: "4567890123",
// channels: 12,
// ip: "192.168.0.4",
// port: 17891,
// },
// {
// id: "5",
// group: "2-device-2",
// name: "Электробусы",
// plate: "EF5678",
// serial: "00980084FD",
// sim: "5678901234",
// channels: 16,
// ip: "192.168.0.5",
// port: 17891,
// },
// {
// id: "6",
// group: "2-device-1",
// name: "Трамваи",
// plate: "FG6789",
// serial: "0088036B7F",
// sim: "6789012345",
// channels: 16,
// ip: "192.168.0.6",
// port: 17891,
// },
// {
// id: "7",
// group: "2-device-4",
// name: "Старые ТС",
// plate: "GH7890",
// serial: "00880302CD",
// sim: "7890123456",
// channels: 12,
// ip: "192.168.0.7",
// port: 17891,
// },
// {
// id: "8",
// group: "2-device-4",
// name: "Старые ТС",
// plate: "HI8901",
// serial: "008802A035",
// sim: "8901234567",
// channels: 12,
// ip: "192.168.0.8",
// port: 17891,
// },
// {
// id: "9",
// group: "1-device-1",
// name: "Трамваи",
// plate: "IJ9012",
// serial: "008802A96A",
// sim: "9012345678",
// channels: 16,
// ip: "192.168.0.9",
// port: 17891,
// },
// {
// id: "10",
// group: "2-device-4",
// name: "Старые ТС",
// plate: "КТ32376",
// serial: "00880302C7",
// sim: "7012345678",
// channels: 14,
// ip: "192.168.0.10",
// port: 17891,
// },
// {
// id: "11",
// group: "2-device-3",
// name: "Троллейбусы",
// plate: "ОА33277",
// serial: "008802A035",
// sim: "9034234348",
// channels: 12,
// ip: "192.168.0.11",
// port: 17891,
// },
// {
// id: "12",
// group: "1-device-2",
// name: "Маршрутки",
// plate: "КЛ987102",
// serial: "009800852A",
// sim: "9023345678",
// channels: 10,
// ip: "192.168.0.12",
// port: 17891,
// },
// {
// id: "13",
// group: "3-device-1",
// name: "Троллейбусы",
// plate: "КЛ987102",
// serial: "0088036B78",
// sim: "9023345678",
// channels: 8,
// ip: "192.168.0.13",
// port: 17891,
// },
// {
// id: "14",
// group: "3-device-1",
// name: "Маршрутки",
// plate: "КЛ987102",
// serial: "0088036B7F",
// sim: "9023345678",
// channels: 8,
// ip: "192.168.0.14",
// port: 17891,
// },
// {
// id: "15",
// group: "1-device-1",
// name: "Трамваи",
// plate: "КЛ987102",
// serial: "008802A96A",
// sim: "9023345678",
// channels: 16,
// ip: "192.168.0.15",
// port: 17891,
// },
// ];
console.log(devices);
// Получаем высоту таблицы и определяем, сколько строк помещается на странице
let currentPage = 1;
let tableHeight = document.getElementById("table-area").offsetHeight;
let rowHeight = 60;
let rowsPerPage = Math.floor(tableHeight / rowHeight) - 2;
let filteredDevices = [...devices];
const createTable = () => {
const table = document.getElementById("deviceTable");
const tbody = table.querySelector("tbody");
// Очищаем таблицу
tbody.innerHTML = "";
// Добавляем строки таблицы
const startIndex = (currentPage - 1) * rowsPerPage;
const endIndex = startIndex + rowsPerPage;
const devicesToDisplay = filteredDevices.slice(startIndex, endIndex);
devicesToDisplay.forEach((device) => {
const row = document.createElement("tr");
// Добавляем чекбокс перед каждым рядом
const checkboxCell = document.createElement("td");
const checkbox = document.createElement("input");
checkbox.type = "checkbox";
checkbox.value = `device-${device.id}`;
checkbox.id = `device-${device.id}`;
const checkboxLabel = document.createElement("label");
checkboxLabel.setAttribute("for", `device-${device.id}`);
const checkboxDiv = document.createElement("div");
checkboxDiv.setAttribute("class", "checkmark");
checkboxLabel.appendChild(checkboxDiv);
checkboxCell.appendChild(checkbox);
checkboxCell.appendChild(checkboxLabel);
row.appendChild(checkboxCell);
// Добавляем ячейки с данными
const name = document.createElement("td");
name.textContent = device.name;
row.appendChild(name);
const plate = document.createElement("td");
plate.textContent = device.plate;
row.appendChild(plate);
const serial = document.createElement("td");
serial.textContent = device.serial;
row.appendChild(serial);
const status = document.createElement("td");
if (device.status === "true") {
status.textContent = "Включен";
status.setAttribute("style", "color:#32D74B");
} else {
status.textContent = "Выключен";
status.setAttribute("style", "color:#FF453A");
}
// status.textContent = device.status;
row.appendChild(status);
const sim = document.createElement("td");
sim.textContent = device.sim;
row.appendChild(sim);
const ip = document.createElement("td");
ip.textContent = device.ip;
row.appendChild(ip);
const port = document.createElement("td");
port.textContent = device.port;
row.appendChild(port);
// Добавляем кнопку удаления после каждого ряда
const trashCell = document.createElement("td");
trashCell.setAttribute("class", "optionsCell");
const trashButton = document.createElement("button");
trashButton.setAttribute("class", "trash");
trashButton.value = `delete-device-${device.id}`;
trashButton.id = `delete-device-${device.id}`;
const optionsButton = document.createElement("button");
optionsButton.setAttribute("class", "options");
optionsButton.setAttribute("onclick", `openForm("${device.id}")`);
optionsButton.value = `options-device-${device.id}`;
optionsButton.id = `options-device-${device.id}`;
trashCell.appendChild(optionsButton);
trashCell.appendChild(trashButton);
row.appendChild(trashCell);
tbody.appendChild(row);
});
};
window.addEventListener("resize", function (event) {
tableHeight = document.getElementById("table-area").offsetHeight;
rowHeight = 60;
rowsPerPage = Math.floor(tableHeight / rowHeight) - 2;
createTable();
createPagination();
});
const createPagination = () => {
const count = document.getElementById("count");
count.textContent = `Всего результатов: ${filteredDevices.length}`;
const pagination = document.getElementById("pagination");
pagination.innerHTML = "";
const pageCount = Math.ceil(filteredDevices.length / rowsPerPage);
for (let i = 1; i <= pageCount; i++) {
const pageLink = document.createElement("a");
pageLink.href = "#";
if (i === currentPage) {
document.querySelector("#device-all").checked = false;
pageLink.classList.add("active");
}
pageLink.textContent = i;
pageLink.addEventListener("click", (event) => {
event.preventDefault();
currentPage = i - 1;
currentPage = i;
createTable();
createPagination();
});
pagination.appendChild(pageLink);
}
// var currentPageSpan = document.createElement("span");
// currentPageSpan.textContent = currentPage;
// pagination.appendChild(currentPageSpan);
// Добавляем кнопки "Next" и "Previous"
// const prevButton = document.createElement("button");
// prevButton.innerText = "Previous";
// prevButton.onclick = () => {
// if (currentPage === 1) return;
// currentPage--;
// createTable();
// };
// pagination.appendChild(prevButton);
// const nextButton = document.createElement("button");
// nextButton.innerText = "Next";
// nextButton.onclick = () => {
// if (currentPage === pageCount) return;
// currentPage++;
// createTable();
// };
// pagination.appendChild(nextButton);
};
const applyFilterAndSearch = () => {
const searchValue = searchInput.value.toLowerCase();
const groupFilters = Array.from(
document.querySelectorAll('input[type="checkbox"].device-filter:checked')
).map((checkbox) => checkbox.value);
filteredDevices = devices.filter((device) => {
const searchString =
`${device.group} ${device.name} ${device.plate} ${device.number} ${device.serial} ${device.sim} ${device.channels} ${device.ip} ${device.port}`.toLowerCase();
const matchGroup =
groupFilters.length === 0 || groupFilters.includes(device.group);
const matchSearch = !searchValue || searchString.includes(searchValue);
return matchGroup && matchSearch;
});
currentPage = 1;
createTable();
createPagination();
};
const searchInput = document.getElementById("table-search");
searchInput.addEventListener("input", applyFilterAndSearch);
const filterCheckboxes = Array.from(
document.querySelectorAll('input[type="checkbox"].device-filter')
);
filterCheckboxes.forEach((checkbox) => {
checkbox.addEventListener("change", applyFilterAndSearch);
});
createTable();
createPagination();