Feature: X-App-Version Header + api.js auto-reload bei navigate() — kein Banner-Click mehr nötig (SW by-v798)

This commit is contained in:
rene 2026-05-09 19:55:13 +02:00
parent 67f042df75
commit d91cc8da26
4 changed files with 29 additions and 14 deletions

View file

@ -45,6 +45,12 @@ const API = (() => {
throw new APIError(msg, 0, 'network');
}
// Versions-Check: Server meldet neue Version → beim nächsten Seitenwechsel neu laden
const serverVer = response.headers.get('x-app-version');
if (serverVer && serverVer !== APP_VER && !window._byUpdatePending) {
window._byUpdatePending = true;
}
if (response.status === 204) return null;
let data;

View file

@ -3,7 +3,7 @@
Router, State-Management, Navigation, Initialisierung.
============================================================ */
const APP_VER = '797'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VER = '798'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VERSION = '1.5.0'; // ← semantische Version, wird bei make release gesetzt
const IS_STAGING = location.hostname === 'staging.banyaro.app';
// Cache-Bust-Parameter nach Update-Reload sofort entfernen
@ -119,6 +119,12 @@ const App = (() => {
// ----------------------------------------------------------
function navigate(pageId, pushHistory = true, params = {}) {
if (!pages[pageId]) return;
// Neue Version vom Server erkannt → jetzt sicher neu laden (kein aktiver Speichervorgang)
if (window._byUpdatePending) {
window._byUpdatePending = false;
location.replace('/?_t=' + Date.now());
return;
}
if (window.Worlds?._visible) window.Worlds.hide();
// Aktive Seite ausblenden
@ -1045,17 +1051,6 @@ const App = (() => {
banner.querySelector('#upd-btn-close').addEventListener('click', () => banner.remove());
banner.querySelector('#upd-btn-reload').addEventListener('click', () => {
const btn = banner.querySelector('#upd-btn-reload');
btn.textContent = 'Lädt…';
btn.disabled = true;
// Cleanup fire-and-forget — kein await, nie blockieren
try {
navigator.serviceWorker?.getRegistrations()
.then(regs => regs.forEach(r => r.unregister())).catch(() => {});
caches.keys()
.then(keys => keys.forEach(k => caches.delete(k))).catch(() => {});
} catch { }
// Sofort neu laden — nicht auf Cleanup warten
location.href = '/?_nocache=' + Date.now();
});
}