srv/poe_manager/templates/logs.html aktualisiert
This commit is contained in:
@@ -15,39 +15,44 @@
|
||||
</div>
|
||||
|
||||
<script>
|
||||
function parseLogTimestamp(ts) {
|
||||
// ts = "2025-10-08 16:48:16"
|
||||
const parts = ts.match(/^(\d{4})-(\d{2})-(\d{2}) (\d{2}):(\d{2}):(\d{2})$/);
|
||||
if (!parts) return Date.now();
|
||||
const [, year, month, day, hour, minute, second] = parts.map(Number);
|
||||
return new Date(year, month - 1, day, hour, minute, second).getTime();
|
||||
}
|
||||
|
||||
document.addEventListener("DOMContentLoaded", () => {
|
||||
const intervalMinutes = {{ interval | int }};
|
||||
const intervalMilliseconds = intervalMinutes * 60 * 1000;
|
||||
let lastUpdateTime = Date.now(); // wird nach Log-Auswertung gesetzt
|
||||
let lastUpdateTime = Date.now();
|
||||
|
||||
function fetchLog() {
|
||||
fetch("{{ url_for('get_log') }}")
|
||||
.then(response => response.text())
|
||||
.then(res => res.text())
|
||||
.then(data => {
|
||||
const box = document.getElementById("log-box");
|
||||
|
||||
const filteredLines = data
|
||||
.split("\n")
|
||||
.filter(line => !line.includes("ist erreichbar!"));
|
||||
|
||||
box.innerText = filteredLines.join("\n");
|
||||
box.scrollTop = box.scrollHeight;
|
||||
|
||||
// letzte Separator-Linie finden
|
||||
let lastSeparatorIndex = -1;
|
||||
// letzte Separator-Linie
|
||||
let lastSep = -1;
|
||||
for (let i = filteredLines.length - 1; i >= 0; i--) {
|
||||
if (filteredLines[i].startsWith("--------------------------------------------------------------------")) {
|
||||
lastSeparatorIndex = i;
|
||||
lastSep = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// ersten Zeitstempel nach Separator nehmen
|
||||
if (lastSeparatorIndex >= 0 && lastSeparatorIndex + 1 < filteredLines.length) {
|
||||
const firstLine = filteredLines[lastSeparatorIndex + 1];
|
||||
if (lastSep >= 0 && lastSep + 1 < filteredLines.length) {
|
||||
const firstLine = filteredLines[lastSep + 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();
|
||||
lastUpdateTime = parseLogTimestamp(match[1]);
|
||||
} else {
|
||||
lastUpdateTime = Date.now();
|
||||
}
|
||||
@@ -55,7 +60,7 @@ document.addEventListener("DOMContentLoaded", () => {
|
||||
lastUpdateTime = Date.now();
|
||||
}
|
||||
})
|
||||
.catch(err => console.error("Fehler beim Laden der Logs:", err));
|
||||
.catch(err => console.error(err));
|
||||
}
|
||||
|
||||
function updateTimer() {
|
||||
@@ -72,6 +77,7 @@ document.addEventListener("DOMContentLoaded", () => {
|
||||
setInterval(fetchLog, intervalMilliseconds);
|
||||
setInterval(updateTimer, 1000);
|
||||
});
|
||||
|
||||
</script>
|
||||
|
||||
{% endblock %}
|
||||
|
||||
Reference in New Issue
Block a user