Fix: iOS bfcache — ?_t=timestamp bei Update-Reload, wird sofort aus URL entfernt (SW by-v770)

This commit is contained in:
rene 2026-05-08 11:27:06 +02:00
parent 572fbf642f
commit a1e5364f25
5 changed files with 11 additions and 10 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 = "769" # muss mit APP_VER in app.js übereinstimmen APP_VER = "770" # 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=769"></script> <script src="/js/worlds.js?v=770"></script>
<!-- Feature-Seiten werden lazy geladen --> <!-- Feature-Seiten werden lazy geladen -->
@ -640,8 +640,7 @@
// Wenn neuer SW die Kontrolle übernimmt → Seite neu laden // Wenn neuer SW die Kontrolle übernimmt → Seite neu laden
navigator.serviceWorker.addEventListener('controllerchange', () => { navigator.serviceWorker.addEventListener('controllerchange', () => {
// location.replace statt reload() — bypassed iOS bfcache window.location.replace('/?_t=' + Date.now());
window.location.replace(window.location.href);
}); });
navigator.serviceWorker.addEventListener('message', e => { navigator.serviceWorker.addEventListener('message', e => {

View file

@ -3,9 +3,11 @@
Router, State-Management, Navigation, Initialisierung. Router, State-Management, Navigation, Initialisierung.
============================================================ */ ============================================================ */
const APP_VER = '769'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen const APP_VER = '770'; // ← 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
if (location.search.includes('_t=')) history.replaceState(null, '', '/');
const App = (() => { const App = (() => {
@ -1037,8 +1039,8 @@ const App = (() => {
btn.textContent = 'Lädt…'; btn.textContent = 'Lädt…';
btn.disabled = true; btn.disabled = true;
sessionStorage.setItem('by_update_reload', APP_VER); sessionStorage.setItem('by_update_reload', APP_VER);
// Immer zur Root — location.href enthält ggf. Hash der App in alten Zustand navigiert // ?_t= Timestamp zwingt iOS bfcache zur Aufgabe — wird beim Start sofort entfernt
setTimeout(() => location.replace('/'), 800); setTimeout(() => location.replace('/?_t=' + Date.now()), 800);
try { try {
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' });

View file

@ -764,11 +764,11 @@ window.Page_settings = (() => {
if (serverVersion && serverVersion !== localVersion) { if (serverVersion && serverVersion !== localVersion) {
if (reg?.waiting) reg.waiting.postMessage({ type: 'SKIP_WAITING' }); if (reg?.waiting) reg.waiting.postMessage({ type: 'SKIP_WAITING' });
UI.toast.info(`Update auf v${serverVersion} — Seite wird neu geladen…`); UI.toast.info(`Update auf v${serverVersion} — Seite wird neu geladen…`);
setTimeout(() => location.replace('/'), 1500); setTimeout(() => location.replace('/?_t=' + Date.now()), 1500);
} else if (reg?.waiting) { } else if (reg?.waiting) {
reg.waiting.postMessage({ type: 'SKIP_WAITING' }); reg.waiting.postMessage({ type: 'SKIP_WAITING' });
UI.toast.success('Update wird installiert…'); UI.toast.success('Update wird installiert…');
setTimeout(() => location.replace('/'), 1500); setTimeout(() => location.replace('/?_t=' + Date.now()), 1500);
} else { } else {
UI.toast.success(`Ban Yaro ist aktuell — Build ${localVersion}`); UI.toast.success(`Ban Yaro ist aktuell — Build ${localVersion}`);
} }

View file

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