Fix: Update-Button leert SW-Cache vor Reload, Fallback-Text für Desktop (Cmd+Shift+R) (SW by-v736)

This commit is contained in:
rene 2026-05-06 18:50:54 +02:00
parent 98ac7fcb79
commit 11067d9ef8
4 changed files with 11 additions and 13 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 = "735" # muss mit APP_VER in app.js übereinstimmen APP_VER = "736" # muss mit APP_VER in app.js übereinstimmen
@app.get("/api/version") @app.get("/api/version")
async def app_version(): async def app_version():

View file

@ -578,7 +578,7 @@
<script src="/js/api.js?v=94"></script> <script src="/js/api.js?v=94"></script>
<script src="/js/ui.js?v=94"></script> <script src="/js/ui.js?v=94"></script>
<script src="/js/app.js?v=94"></script> <script src="/js/app.js?v=94"></script>
<script src="/js/worlds.js?v=735"></script> <script src="/js/worlds.js?v=736"></script>
<!-- Feature-Seiten werden lazy geladen --> <!-- Feature-Seiten werden lazy geladen -->

View file

@ -3,7 +3,7 @@
Router, State-Management, Navigation, Initialisierung. Router, State-Management, Navigation, Initialisierung.
============================================================ */ ============================================================ */
const APP_VER = '735'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen const APP_VER = '736'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VERSION = '1.4.0'; // ← semantische Version, wird bei make release gesetzt const APP_VERSION = '1.4.0'; // ← semantische Version, wird bei make release gesetzt
const IS_STAGING = location.hostname === 'staging.banyaro.app'; const IS_STAGING = location.hostname === 'staging.banyaro.app';
@ -978,8 +978,8 @@ const App = (() => {
<strong>1.</strong> Drücke lange auf das App-Icon am Homescreen<br> <strong>1.</strong> Drücke lange auf das App-Icon am Homescreen<br>
<strong>2.</strong> Wähle App entfernen" (nur das Symbol, keine Daten)<br> <strong>2.</strong> Wähle App entfernen" (nur das Symbol, keine Daten)<br>
<strong>3.</strong> Öffne banyaro.app in Safari und füge die App erneut hinzu` <strong>3.</strong> Öffne banyaro.app in Safari und füge die App erneut hinzu`
: `Falls die App nicht aktualisiert:<br> : `Falls die Seite noch die alte Version zeigt:<br>
Öffne banyaro.app im Browser und füge sie erneut zum Startbildschirm hinzu.`} Drücke <strong>Cmd+Shift+R</strong> (Mac) bzw. <strong>Ctrl+Shift+R</strong> (Windows/Android Chrome) für einen harten Reload.`}
</div> </div>
`; `;
@ -991,18 +991,16 @@ const App = (() => {
const btn = banner.querySelector('#upd-btn-reload'); const btn = banner.querySelector('#upd-btn-reload');
btn.textContent = 'Lädt…'; btn.textContent = 'Lädt…';
btn.disabled = true; btn.disabled = true;
// SW-Update anstoßen sessionStorage.setItem('by_update_reload', APP_VER);
try { try {
// SW aktivieren + alle Caches leeren für sauberen Reload
const reg = await navigator.serviceWorker?.getRegistration(); const reg = await navigator.serviceWorker?.getRegistration();
if (reg?.waiting) reg.waiting.postMessage({ type: 'SKIP_WAITING' }); if (reg?.waiting) reg.waiting.postMessage({ type: 'SKIP_WAITING' });
await reg?.update(); await reg?.update();
const keys = await caches.keys();
await Promise.all(keys.map(k => caches.delete(k)));
} catch { /* ignorieren */ } } catch { /* ignorieren */ }
// Kurz warten, dann hard reload setTimeout(() => location.reload(), 600);
setTimeout(() => {
location.reload();
}, 800);
// Nach Reload: wenn Version immer noch alt, iOS-Hinweis anzeigen
sessionStorage.setItem('by_update_reload', APP_VER);
}); });
} }

View file

@ -3,7 +3,7 @@
Offline-Cache + Push Notifications + Tile-Cache Offline-Cache + Push Notifications + Tile-Cache
============================================================ */ ============================================================ */
const CACHE_VERSION = 'by-v735'; const CACHE_VERSION = 'by-v736';
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