Compare commits

...

2 commits

5 changed files with 18 additions and 21 deletions

View file

@ -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 = "777" # muss mit APP_VER in app.js übereinstimmen APP_VER = "779" # 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

@ -575,10 +575,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=94"></script> <script src="/js/api.js?v=779"></script>
<script src="/js/ui.js?v=94"></script> <script src="/js/ui.js?v=779"></script>
<script src="/js/app.js?v=94"></script> <script src="/js/app.js?v=779"></script>
<script src="/js/worlds.js?v=777"></script> <script src="/js/worlds.js?v=779"></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 = '777'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen const APP_VER = '779'; // ← 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

View file

@ -640,18 +640,14 @@ window.Worlds = (() => {
} }
function _chipsForWorld(world) { function _chipsForWorld(world) {
const pages = _getConfig()[world] || _DEFAULT_CONFIG[world]; const cfg = _getConfig();
// Alle Chips filtern — _chipAllowed entscheidet ob angezeigt const pages = cfg[world] || _DEFAULT_CONFIG[world];
const chips = pages.map(_chipMeta).filter(c => c && _chipAllowed(c)); // Deduplizieren + filtern — _chipAllowed entscheidet ob angezeigt
// Sicherheitsnetz: Rolle-gebundene Chips aus Default einfügen wenn berechtigt const seen = new Set();
// (aber noch nicht in persönlicher Config) — _chipAllowed() entscheidet für alle const chips = pages
const alreadyIn = new Set(chips.map(c => c.page)); .filter(p => { if (seen.has(p)) return false; seen.add(p); return true; })
for (const page of (_DEFAULT_CONFIG[world] || [])) { .map(_chipMeta)
if (alreadyIn.has(page)) continue; .filter(c => c && _chipAllowed(c));
const meta = _chipMeta(page);
if (!meta?.role) continue; // nur role-gebundene Chips
if (_chipAllowed(meta)) { chips.push(meta); alreadyIn.add(page); }
}
return chips; return chips;
} }

View file

@ -3,7 +3,7 @@
Offline-Cache + Push Notifications + Tile-Cache Offline-Cache + Push Notifications + Tile-Cache
============================================================ */ ============================================================ */
const CACHE_VERSION = 'by-v777'; const CACHE_VERSION = 'by-v779';
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
@ -280,9 +280,10 @@ self.addEventListener('fetch', event => {
return; return;
} }
// CSS, app.js + Seiten-Module: immer Network-First — damit iOS nie veraltete Versionen cached // CSS, Core-JS + Seiten-Module: immer Network-First — damit iOS nie veraltete Versionen cached
if (url.pathname.startsWith('/css/') || url.pathname.startsWith('/js/pages/') if (url.pathname.startsWith('/css/') || url.pathname.startsWith('/js/pages/')
|| url.pathname === '/js/app.js' || url.pathname === '/js/ui.js' || url.pathname === '/js/api.js') { || url.pathname.startsWith('/js/app.js') || url.pathname.startsWith('/js/ui.js')
|| url.pathname.startsWith('/js/api.js') || url.pathname.startsWith('/js/worlds.js')) {
event.respondWith( event.respondWith(
fetch(event.request) fetch(event.request)
.then(response => { .then(response => {