Fix: Update-Button leert SW-Cache vor Reload, Fallback-Text für Desktop (Cmd+Shift+R) (SW by-v736)
This commit is contained in:
parent
98ac7fcb79
commit
11067d9ef8
4 changed files with 11 additions and 13 deletions
|
|
@ -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():
|
||||||
|
|
|
||||||
|
|
@ -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 -->
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue