From 183cc564fcbae16c4995663f58536cec0be389c8 Mon Sep 17 00:00:00 2001 From: rene Date: Sun, 10 May 2026 08:42:06 +0200 Subject: [PATCH] =?UTF-8?q?Fix:=20Auto-Update=20wartet=20bis=20kein=20Moda?= =?UTF-8?q?l=20offen=20=E2=80=94=20kein=20Datenverlust=20bei=20Tagebuchein?= =?UTF-8?q?trag=20(SW=20by-v816)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- backend/main.py | 2 +- backend/static/index.html | 14 +++++++------- backend/static/js/app.js | 16 ++++++++++------ backend/static/sw.js | 2 +- 4 files changed, 19 insertions(+), 15 deletions(-) diff --git a/backend/main.py b/backend/main.py index 8093a75..52b8075 100644 --- a/backend/main.py +++ b/backend/main.py @@ -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 = "815" # muss mit APP_VER in app.js übereinstimmen +APP_VER = "816" # muss mit APP_VER in app.js übereinstimmen @app.get("/.well-known/assetlinks.json") async def assetlinks(): diff --git a/backend/static/index.html b/backend/static/index.html index 6161ab4..6dd6ec0 100644 --- a/backend/static/index.html +++ b/backend/static/index.html @@ -101,9 +101,9 @@ - - - + + + @@ -583,10 +583,10 @@ - - - - + + + + diff --git a/backend/static/js/app.js b/backend/static/js/app.js index 3a2267a..2cff127 100644 --- a/backend/static/js/app.js +++ b/backend/static/js/app.js @@ -3,7 +3,7 @@ Router, State-Management, Navigation, Initialisierung. ============================================================ */ -const APP_VER = '815'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen +const APP_VER = '816'; // ← 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 @@ -119,12 +119,16 @@ const App = (() => { // ---------------------------------------------------------- function navigate(pageId, pushHistory = true, params = {}) { if (!pages[pageId]) return; - // Neue Version erkannt → jetzt sicher im Hintergrund aktualisieren + // Neue Version erkannt → nur aktualisieren wenn kein Bearbeitungsfenster offen ist if (window._byUpdatePending) { - window._byUpdatePending = false; - sessionStorage.setItem('by_updated_to', window._byNewVersion || ''); - location.href = '/force-update'; - return; + const modalOpen = document.querySelector('#modal-container .modal-overlay') !== null; + if (!modalOpen) { + window._byUpdatePending = false; + sessionStorage.setItem('by_updated_to', window._byNewVersion || ''); + location.href = '/force-update'; + return; + } + // Modal offen → beim nächsten Seitenwechsel versuchen } if (window.Worlds?._visible) window.Worlds.hide(); diff --git a/backend/static/sw.js b/backend/static/sw.js index c8b62f6..4874a51 100644 --- a/backend/static/sw.js +++ b/backend/static/sw.js @@ -3,7 +3,7 @@ Offline-Cache + Push Notifications + Tile-Cache ============================================================ */ -const CACHE_VERSION = 'by-v815'; +const CACHE_VERSION = 'by-v816'; 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