Fix: kein zweiter SW-Reload nach force-update (by_skip_sw_reload Flag), Tagebuch bleibt offen (SW by-v819)

This commit is contained in:
rene 2026-05-10 09:04:12 +02:00
parent 9139e33492
commit 25417364d2
4 changed files with 17 additions and 10 deletions

View file

@ -341,7 +341,7 @@ MEDIA_DIR = os.getenv("MEDIA_DIR", "/data/media")
os.makedirs(MEDIA_DIR, exist_ok=True)
app.mount("/media", StaticFiles(directory=MEDIA_DIR), name="media")
APP_VER = "818" # muss mit APP_VER in app.js übereinstimmen
APP_VER = "819" # muss mit APP_VER in app.js übereinstimmen
@app.get("/.well-known/assetlinks.json")
async def assetlinks():
@ -1624,6 +1624,8 @@ p{color:#94a3b8;font-size:14px}</style></head>
<div> Aktualisiere Ban Yaro</div>
<p id="s">Service Worker wird entfernt</p>
<script>
// Zweiten Reload durch SW-updatefound verhindern
sessionStorage.setItem('by_skip_sw_reload','1');
// Fire-and-forget kein await, Reload nach spätestens 1.5s
try{
navigator.serviceWorker?.getRegistrations().then(r=>r.forEach(s=>s.unregister())).catch(()=>{});

View file

@ -101,9 +101,9 @@
</script>
<!-- CSS: Reihenfolge ist wichtig — ?v= zwingt Browser zur Neuladung -->
<link rel="stylesheet" href="/css/design-system.css?v=818">
<link rel="stylesheet" href="/css/layout.css?v=818">
<link rel="stylesheet" href="/css/components.css?v=818">
<link rel="stylesheet" href="/css/design-system.css?v=819">
<link rel="stylesheet" href="/css/layout.css?v=819">
<link rel="stylesheet" href="/css/components.css?v=819">
</head>
<body>
@ -583,10 +583,10 @@
<div id="modal-container"></div>
<!-- JS: Reihenfolge ist wichtig — erst Basis, dann Features -->
<script src="/js/api.js?v=818"></script>
<script src="/js/ui.js?v=818"></script>
<script src="/js/app.js?v=818"></script>
<script src="/js/worlds.js?v=818"></script>
<script src="/js/api.js?v=819"></script>
<script src="/js/ui.js?v=819"></script>
<script src="/js/app.js?v=819"></script>
<script src="/js/worlds.js?v=819"></script>
<!-- Feature-Seiten werden lazy geladen -->
@ -637,6 +637,11 @@
if (!sw) return;
sw.addEventListener('statechange', () => {
if (sw.state === 'activated') {
// Kein zweiter Reload nach force-update
if (sessionStorage.getItem('by_skip_sw_reload')) {
sessionStorage.removeItem('by_skip_sw_reload');
return;
}
window.location.replace('/?_t=' + Date.now());
}
});

View file

@ -3,7 +3,7 @@
Router, State-Management, Navigation, Initialisierung.
============================================================ */
const APP_VER = '818'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VER = '819'; // ← 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

View file

@ -3,7 +3,7 @@
Offline-Cache + Push Notifications + Tile-Cache
============================================================ */
const CACHE_VERSION = 'by-v818';
const CACHE_VERSION = 'by-v819';
const CACHE_STATIC = `${CACHE_VERSION}-static`;
const CACHE_TILES = 'ban-yaro-tiles-v1'; // bleibt über SW-Updates erhalten
const CACHE_API = 'ban-yaro-api-v1'; // API-Response-Cache