Fix: SW-Update Dauerschleife — controllerchange nicht auf Reload-Seiten registrieren (SW by-v888)
clients.claim() feuert asynchron nach Seitenstart → controllerchange auf der neu geladenen Seite → Reload → clients.claim() → loop. Fix: controllerchange nur registrieren wenn _t= NICHT im URL steht.
This commit is contained in:
parent
b8f70eb2cd
commit
7257c9e04f
4 changed files with 14 additions and 11 deletions
|
|
@ -406,7 +406,7 @@ async def serve_media(path: str, request: _Request):
|
||||||
raise _HE(404, "Nicht gefunden.")
|
raise _HE(404, "Nicht gefunden.")
|
||||||
return _media_response(filepath)
|
return _media_response(filepath)
|
||||||
|
|
||||||
APP_VER = "887" # muss mit APP_VER in app.js übereinstimmen
|
APP_VER = "888" # 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():
|
||||||
|
|
|
||||||
|
|
@ -660,14 +660,17 @@
|
||||||
});
|
});
|
||||||
|
|
||||||
// Backup: controllerchange (falls updatefound nicht feuert)
|
// Backup: controllerchange (falls updatefound nicht feuert)
|
||||||
// Konsumiert auch den by_skip_sw_reload-Flag (statechange prüft ihn nur)
|
// NICHT registrieren wenn diese Seite selbst durch einen SW-Reload entstand (_t= im URL)
|
||||||
navigator.serviceWorker.addEventListener('controllerchange', () => {
|
// — verhindert Dauerschleife wenn clients.claim() erst nach Seitenstart feuert
|
||||||
if (sessionStorage.getItem('by_skip_sw_reload')) {
|
if (!location.search.includes('_t=')) {
|
||||||
sessionStorage.removeItem('by_skip_sw_reload');
|
navigator.serviceWorker.addEventListener('controllerchange', () => {
|
||||||
return;
|
if (sessionStorage.getItem('by_skip_sw_reload')) {
|
||||||
}
|
sessionStorage.removeItem('by_skip_sw_reload');
|
||||||
window.location.replace('/?_t=' + Date.now());
|
return;
|
||||||
});
|
}
|
||||||
|
window.location.replace('/?_t=' + Date.now());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
navigator.serviceWorker.addEventListener('message', e => {
|
navigator.serviceWorker.addEventListener('message', e => {
|
||||||
if (e.data?.type === 'QUEUE_PROCESSED') {
|
if (e.data?.type === 'QUEUE_PROCESSED') {
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
Router, State-Management, Navigation, Initialisierung.
|
Router, State-Management, Navigation, Initialisierung.
|
||||||
============================================================ */
|
============================================================ */
|
||||||
|
|
||||||
const APP_VER = '887'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
|
const APP_VER = '888'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
|
||||||
const APP_VERSION = '1.5.1'; // ← semantische Version, wird bei make release gesetzt
|
const APP_VERSION = '1.5.1'; // ← 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
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
Offline-Cache + Push Notifications + Tile-Cache
|
Offline-Cache + Push Notifications + Tile-Cache
|
||||||
============================================================ */
|
============================================================ */
|
||||||
|
|
||||||
const CACHE_VERSION = 'by-v887';
|
const CACHE_VERSION = 'by-v888';
|
||||||
const CACHE_STATIC = `${CACHE_VERSION}-static`;
|
const CACHE_STATIC = `${CACHE_VERSION}-static`;
|
||||||
const CACHE_TILES = 'ban-yaro-tiles-v1'; // bleibt über SW-Updates erhalten
|
const CACHE_TILES = 'ban-yaro-tiles-v1'; // bleibt über SW-Updates erhalten
|
||||||
const CACHE_API = 'ban-yaro-api-v1'; // API-Response-Cache
|
const CACHE_API = 'ban-yaro-api-v1'; // API-Response-Cache
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue