srv/poe_manager/templates/logs.html aktualisiert

This commit is contained in:
2025-10-08 18:57:12 +02:00
parent c957a32a86
commit 2c9a715d37

View File

@@ -16,14 +16,10 @@
<script>
document.addEventListener("DOMContentLoaded", () => {
// --- Seitentitel setzen ---
const baseTitle = document.title.split(" - ")[0];
document.title = baseTitle + " - Live Log";
// --- Intervallwerte ---
// --- Intervall aus Datenbank (Jinja Variable) ---
const intervalMinutes = {{ interval | int }};
const intervalMilliseconds = intervalMinutes * 60 * 1000;
let lastUpdateTime = Date.now();
let lastUpdateTime = Date.now(); // wird nach Log-Auswertung gesetzt
// --- Log laden ---
function fetchLog() {
@@ -31,13 +27,36 @@ document.addEventListener("DOMContentLoaded", () => {
.then(response => response.text())
.then(data => {
const box = document.getElementById("log-box");
// Zeilen filtern
const filteredLines = data
.split("\n")
.filter(line => !line.includes("ist erreichbar!"))
.join("\n");
box.innerText = filteredLines;
.filter(line => !line.includes("ist erreichbar!"));
box.innerText = filteredLines.join("\n");
box.scrollTop = box.scrollHeight;
lastUpdateTime = Date.now();
// --- Timer: letzte "----" Linie finden ---
let lastSeparatorIndex = -1;
for (let i = filteredLines.length - 1; i >= 0; i--) {
if (filteredLines[i].startsWith("--------------------------------------------------------------------")) {
lastSeparatorIndex = i;
break;
}
}
// ersten Zeitstempel nach Separator nehmen
if (lastSeparatorIndex >= 0 && lastSeparatorIndex + 1 < filteredLines.length) {
const firstLine = filteredLines[lastSeparatorIndex + 1];
const match = firstLine.match(/^(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2})/);
if (match) {
lastUpdateTime = new Date(match[1]).getTime();
} else {
lastUpdateTime = Date.now();
}
} else {
lastUpdateTime = Date.now();
}
})
.catch(err => console.error("Fehler beim Laden der Logs:", err));
}
@@ -54,9 +73,9 @@ document.addEventListener("DOMContentLoaded", () => {
document.getElementById("refresh-btn").addEventListener("click", fetchLog);
// --- Initial starten ---
setInterval(updateTimer, 1000);
fetchLog();
setInterval(fetchLog, intervalMilliseconds);
fetchLog(); // zuerst laden
setInterval(fetchLog, intervalMilliseconds); // automatische Updates nach DB-Intervall
setInterval(updateTimer, 1000); // Timer jede Sekunde
});
</script>