dev #1
@@ -29,12 +29,15 @@
|
|||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
document.addEventListener("DOMContentLoaded", () => {
|
document.addEventListener("DOMContentLoaded", () => {
|
||||||
const intervalMinutes = {{ interval | int }}; // aus DB
|
const intervalMinutes = {{ interval | int }}; // Intervall aus DB in Minuten
|
||||||
const intervalMilliseconds = intervalMinutes * 60 * 1000;
|
const intervalMilliseconds = intervalMinutes * 60 * 1000;
|
||||||
let lastUpdateTime = Date.now();
|
let lastUpdateTime = Date.now();
|
||||||
|
|
||||||
|
let reloadCountdown = null; // Reload-Timer (10s)
|
||||||
|
|
||||||
function parseLogTimestamp(ts) {
|
function parseLogTimestamp(ts) {
|
||||||
const parts = ts.match(/^(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})$/);
|
const parts = ts.match(/^(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})$/);
|
||||||
if (!parts) return Date.now();
|
if (!parts) return Date.now();
|
||||||
@@ -46,9 +49,25 @@ document.addEventListener("DOMContentLoaded", () => {
|
|||||||
const now = Date.now();
|
const now = Date.now();
|
||||||
const elapsed = now - lastUpdateTime;
|
const elapsed = now - lastUpdateTime;
|
||||||
const remainingMs = intervalMilliseconds - (elapsed % intervalMilliseconds);
|
const remainingMs = intervalMilliseconds - (elapsed % intervalMilliseconds);
|
||||||
const remainingSec = Math.ceil(remainingMs / 1000);
|
let remainingSec = Math.ceil(remainingMs / 1000);
|
||||||
document.getElementById("dashboard-timer").innerText =
|
|
||||||
`Nächste Prüfung in ${remainingSec} Sekunden`;
|
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() {
|
function fetchLastLog() {
|
||||||
@@ -72,10 +91,10 @@ document.addEventListener("DOMContentLoaded", () => {
|
|||||||
.catch(err => console.error("Fehler beim Laden der Logs:", err));
|
.catch(err => console.error("Fehler beim Laden der Logs:", err));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Timer alle 1 Sekunde aktualisieren
|
// Timer jede Sekunde aktualisieren
|
||||||
setInterval(updateTimer, 1000);
|
setInterval(updateTimer, 1000);
|
||||||
|
|
||||||
// einmal beim Laden die letzte Log-Zeit setzen
|
// einmal beim Laden letzte Log-Zeit setzen
|
||||||
fetchLastLog();
|
fetchLastLog();
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
Reference in New Issue
Block a user