dev #1

Merged
alientim merged 145 commits from dev into main 2025-10-12 13:44:14 +02:00
Showing only changes of commit 250a131542 - Show all commits

View File

@@ -29,12 +29,15 @@
</div>
{% endfor %}
</div>
<script>
document.addEventListener("DOMContentLoaded", () => {
const intervalMinutes = {{ interval | int }}; // aus DB
const intervalMinutes = {{ interval | int }}; // Intervall aus DB in Minuten
const intervalMilliseconds = intervalMinutes * 60 * 1000;
let lastUpdateTime = Date.now();
let reloadCountdown = null; // Reload-Timer (10s)
function parseLogTimestamp(ts) {
const parts = ts.match(/^(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})$/);
if (!parts) return Date.now();
@@ -46,9 +49,25 @@ document.addEventListener("DOMContentLoaded", () => {
const now = Date.now();
const elapsed = now - lastUpdateTime;
const remainingMs = intervalMilliseconds - (elapsed % intervalMilliseconds);
const remainingSec = Math.ceil(remainingMs / 1000);
document.getElementById("dashboard-timer").innerText =
`Nächste Prüfung in ${remainingSec} Sekunden`;
let remainingSec = Math.ceil(remainingMs / 1000);
const timerElem = document.getElementById("dashboard-timer");
if (remainingSec > 0) {
// Haupt-Timer läuft normal
timerElem.innerText = `Nächste Prüfung in ${remainingSec} Sekunden`;
} else {
// Haupt-Timer abgelaufen → Reload-Timer starten, falls noch nicht gestartet
if (reloadCountdown === null) {
reloadCountdown = 10; // 10 Sekunden Countdown
}
timerElem.innerText = `Aktualisieren der Seite in ${reloadCountdown} Sekunden`;
reloadCountdown--;
if (reloadCountdown < 0) {
window.location.reload(); // Seite neu laden
}
}
}
function fetchLastLog() {
@@ -72,10 +91,10 @@ document.addEventListener("DOMContentLoaded", () => {
.catch(err => console.error("Fehler beim Laden der Logs:", err));
}
// Timer alle 1 Sekunde aktualisieren
// Timer jede Sekunde aktualisieren
setInterval(updateTimer, 1000);
// einmal beim Laden die letzte Log-Zeit setzen
// einmal beim Laden letzte Log-Zeit setzen
fetchLastLog();
});
</script>