Fix: Auto-Update wartet bis kein Modal offen — kein Datenverlust bei Tagebucheintrag (SW by-v816)

This commit is contained in:
rene 2026-05-10 08:42:06 +02:00
parent effdf5ba5b
commit 183cc564fc
4 changed files with 19 additions and 15 deletions

View file

@ -341,7 +341,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 = "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") @app.get("/.well-known/assetlinks.json")
async def assetlinks(): async def assetlinks():

View file

@ -101,9 +101,9 @@
</script> </script>
<!-- CSS: Reihenfolge ist wichtig — ?v= zwingt Browser zur Neuladung --> <!-- CSS: Reihenfolge ist wichtig — ?v= zwingt Browser zur Neuladung -->
<link rel="stylesheet" href="/css/design-system.css?v=815"> <link rel="stylesheet" href="/css/design-system.css?v=816">
<link rel="stylesheet" href="/css/layout.css?v=815"> <link rel="stylesheet" href="/css/layout.css?v=816">
<link rel="stylesheet" href="/css/components.css?v=815"> <link rel="stylesheet" href="/css/components.css?v=816">
</head> </head>
<body> <body>
@ -583,10 +583,10 @@
<div id="modal-container"></div> <div id="modal-container"></div>
<!-- JS: Reihenfolge ist wichtig — erst Basis, dann Features --> <!-- JS: Reihenfolge ist wichtig — erst Basis, dann Features -->
<script src="/js/api.js?v=815"></script> <script src="/js/api.js?v=816"></script>
<script src="/js/ui.js?v=815"></script> <script src="/js/ui.js?v=816"></script>
<script src="/js/app.js?v=815"></script> <script src="/js/app.js?v=816"></script>
<script src="/js/worlds.js?v=815"></script> <script src="/js/worlds.js?v=816"></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 = '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 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 // Cache-Bust-Parameter nach Update-Reload sofort entfernen
@ -119,12 +119,16 @@ const App = (() => {
// ---------------------------------------------------------- // ----------------------------------------------------------
function navigate(pageId, pushHistory = true, params = {}) { function navigate(pageId, pushHistory = true, params = {}) {
if (!pages[pageId]) return; 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) { if (window._byUpdatePending) {
window._byUpdatePending = false; const modalOpen = document.querySelector('#modal-container .modal-overlay') !== null;
sessionStorage.setItem('by_updated_to', window._byNewVersion || ''); if (!modalOpen) {
location.href = '/force-update'; window._byUpdatePending = false;
return; 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(); if (window.Worlds?._visible) window.Worlds.hide();

View file

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