Fix: Update-Zielseite nach Reload wiederherstellen, Toast nach 800ms (SW by-v817)

This commit is contained in:
rene 2026-05-10 08:50:29 +02:00
parent 183cc564fc
commit b4fec76644
4 changed files with 18 additions and 12 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 = "816" # muss mit APP_VER in app.js übereinstimmen
APP_VER = "817" # muss mit APP_VER in app.js übereinstimmen
@app.get("/.well-known/assetlinks.json")
async def assetlinks():

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=816">
<link rel="stylesheet" href="/css/layout.css?v=816">
<link rel="stylesheet" href="/css/components.css?v=816">
<link rel="stylesheet" href="/css/design-system.css?v=817">
<link rel="stylesheet" href="/css/layout.css?v=817">
<link rel="stylesheet" href="/css/components.css?v=817">
</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=816"></script>
<script src="/js/ui.js?v=816"></script>
<script src="/js/app.js?v=816"></script>
<script src="/js/worlds.js?v=816"></script>
<script src="/js/api.js?v=817"></script>
<script src="/js/ui.js?v=817"></script>
<script src="/js/app.js?v=817"></script>
<script src="/js/worlds.js?v=817"></script>
<!-- Feature-Seiten werden lazy geladen -->

View file

@ -3,7 +3,7 @@
Router, State-Management, Navigation, Initialisierung.
============================================================ */
const APP_VER = '816'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VER = '817'; // ← 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
@ -125,6 +125,7 @@ const App = (() => {
if (!modalOpen) {
window._byUpdatePending = false;
sessionStorage.setItem('by_updated_to', window._byNewVersion || '');
sessionStorage.setItem('by_update_target', pageId); // Zielseite nach Update
location.href = '/force-update';
return;
}
@ -912,11 +913,16 @@ const App = (() => {
_bindNavigation();
// Nach stillem Update: Toast anzeigen
// Nach stillem Update: Toast + zur ursprünglichen Zielseite navigieren
const updatedTo = sessionStorage.getItem('by_updated_to');
if (updatedTo) {
sessionStorage.removeItem('by_updated_to');
setTimeout(() => UI.toast?.success(`App automatisch auf v${updatedTo} aktualisiert`), 1500);
const target = sessionStorage.getItem('by_update_target');
sessionStorage.removeItem('by_update_target');
setTimeout(() => {
UI.toast?.success(`App auf v${updatedTo} aktualisiert`);
if (target && pages[target]) navigate(target, false);
}, 800);
}
try { localStorage.removeItem('by_wissen_open'); } catch (_) {}

View file

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