Fix: SW-Update via updatefound+statechange (primär), controllerchange (Backup) — SW by-v797

This commit is contained in:
rene 2026-05-09 19:47:14 +02:00
parent 209d6703ad
commit 67f042df75
3 changed files with 15 additions and 5 deletions

View file

@ -327,7 +327,7 @@ MEDIA_DIR = os.getenv("MEDIA_DIR", "/data/media")
os.makedirs(MEDIA_DIR, exist_ok=True) os.makedirs(MEDIA_DIR, exist_ok=True)
app.mount("/media", StaticFiles(directory=MEDIA_DIR), name="media") app.mount("/media", StaticFiles(directory=MEDIA_DIR), name="media")
APP_VER = "796" # muss mit APP_VER in app.js übereinstimmen APP_VER = "797" # muss mit APP_VER in app.js übereinstimmen
@app.get("/.well-known/assetlinks.json") @app.get("/.well-known/assetlinks.json")
async def assetlinks(): async def assetlinks():

View file

@ -628,20 +628,30 @@
window.addEventListener('load', () => { window.addEventListener('load', () => {
navigator.serviceWorker.register('/sw.js', { updateViaCache: 'none' }) navigator.serviceWorker.register('/sw.js', { updateViaCache: 'none' })
.then(reg => { .then(reg => {
// iOS PWA: Update sofort prüfen (Standalone-Modus prüft sonst nicht automatisch)
reg.update(); reg.update();
// Primär: neuer SW hat aktiviert → sofort neu laden
reg.addEventListener('updatefound', () => {
const sw = reg.installing;
if (!sw) return;
sw.addEventListener('statechange', () => {
if (sw.state === 'activated') {
window.location.replace('/?_t=' + Date.now());
}
});
});
}) })
.catch(err => console.warn('SW Registration failed:', err)); .catch(err => console.warn('SW Registration failed:', err));
}); });
// iOS PWA: erneut prüfen wenn App aus dem Hintergrund kommt // Backup: erneut prüfen wenn App aus dem Hintergrund kommt
document.addEventListener('visibilitychange', () => { document.addEventListener('visibilitychange', () => {
if (document.visibilityState === 'visible') { if (document.visibilityState === 'visible') {
navigator.serviceWorker.getRegistration().then(reg => reg?.update()); navigator.serviceWorker.getRegistration().then(reg => reg?.update());
} }
}); });
// Wenn neuer SW die Kontrolle übernimmt → Seite neu laden // Backup: controllerchange (falls updatefound nicht feuert)
navigator.serviceWorker.addEventListener('controllerchange', () => { navigator.serviceWorker.addEventListener('controllerchange', () => {
window.location.replace('/?_t=' + Date.now()); window.location.replace('/?_t=' + Date.now());
}); });

View file

@ -3,7 +3,7 @@
Router, State-Management, Navigation, Initialisierung. Router, State-Management, Navigation, Initialisierung.
============================================================ */ ============================================================ */
const APP_VER = '796'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen const APP_VER = '797'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VERSION = '1.5.0'; // ← semantische Version, wird bei make release gesetzt const APP_VERSION = '1.5.0'; // ← semantische Version, wird bei make release gesetzt
const IS_STAGING = location.hostname === 'staging.banyaro.app'; const IS_STAGING = location.hostname === 'staging.banyaro.app';
// Cache-Bust-Parameter nach Update-Reload sofort entfernen // Cache-Bust-Parameter nach Update-Reload sofort entfernen