Fix: Update-Zielseite nach Reload wiederherstellen, Toast nach 800ms (SW by-v817)
This commit is contained in:
parent
183cc564fc
commit
b4fec76644
4 changed files with 18 additions and 12 deletions
|
|
@ -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 = "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")
|
@app.get("/.well-known/assetlinks.json")
|
||||||
async def assetlinks():
|
async def assetlinks():
|
||||||
|
|
|
||||||
|
|
@ -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=816">
|
<link rel="stylesheet" href="/css/design-system.css?v=817">
|
||||||
<link rel="stylesheet" href="/css/layout.css?v=816">
|
<link rel="stylesheet" href="/css/layout.css?v=817">
|
||||||
<link rel="stylesheet" href="/css/components.css?v=816">
|
<link rel="stylesheet" href="/css/components.css?v=817">
|
||||||
</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=816"></script>
|
<script src="/js/api.js?v=817"></script>
|
||||||
<script src="/js/ui.js?v=816"></script>
|
<script src="/js/ui.js?v=817"></script>
|
||||||
<script src="/js/app.js?v=816"></script>
|
<script src="/js/app.js?v=817"></script>
|
||||||
<script src="/js/worlds.js?v=816"></script>
|
<script src="/js/worlds.js?v=817"></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 = '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 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
|
||||||
|
|
@ -125,6 +125,7 @@ const App = (() => {
|
||||||
if (!modalOpen) {
|
if (!modalOpen) {
|
||||||
window._byUpdatePending = false;
|
window._byUpdatePending = false;
|
||||||
sessionStorage.setItem('by_updated_to', window._byNewVersion || '');
|
sessionStorage.setItem('by_updated_to', window._byNewVersion || '');
|
||||||
|
sessionStorage.setItem('by_update_target', pageId); // Zielseite nach Update
|
||||||
location.href = '/force-update';
|
location.href = '/force-update';
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -912,11 +913,16 @@ const App = (() => {
|
||||||
|
|
||||||
_bindNavigation();
|
_bindNavigation();
|
||||||
|
|
||||||
// Nach stillem Update: Toast anzeigen
|
// Nach stillem Update: Toast + zur ursprünglichen Zielseite navigieren
|
||||||
const updatedTo = sessionStorage.getItem('by_updated_to');
|
const updatedTo = sessionStorage.getItem('by_updated_to');
|
||||||
if (updatedTo) {
|
if (updatedTo) {
|
||||||
sessionStorage.removeItem('by_updated_to');
|
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 (_) {}
|
try { localStorage.removeItem('by_wissen_open'); } catch (_) {}
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
Offline-Cache + Push Notifications + Tile-Cache
|
Offline-Cache + Push Notifications + Tile-Cache
|
||||||
============================================================ */
|
============================================================ */
|
||||||
|
|
||||||
const CACHE_VERSION = 'by-v816';
|
const CACHE_VERSION = 'by-v817';
|
||||||
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