Compare commits

..

No commits in common. "af7fe7813e466c359cb4c5c4d9d5ef097c529b1b" and "9fd146440f1db1ff5f52e29475783aa963f59472" have entirely different histories.

5 changed files with 21 additions and 18 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 = "779" # muss mit APP_VER in app.js übereinstimmen APP_VER = "777" # 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=779"></script> <script src="/js/api.js?v=94"></script>
<script src="/js/ui.js?v=779"></script> <script src="/js/ui.js?v=94"></script>
<script src="/js/app.js?v=779"></script> <script src="/js/app.js?v=94"></script>
<script src="/js/worlds.js?v=779"></script> <script src="/js/worlds.js?v=777"></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 = '779'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen const APP_VER = '777'; // ← 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,14 +640,18 @@ window.Worlds = (() => {
} }
function _chipsForWorld(world) { function _chipsForWorld(world) {
const cfg = _getConfig(); const pages = _getConfig()[world] || _DEFAULT_CONFIG[world];
const pages = cfg[world] || _DEFAULT_CONFIG[world]; // Alle Chips filtern — _chipAllowed entscheidet ob angezeigt
// Deduplizieren + filtern — _chipAllowed entscheidet ob angezeigt const chips = pages.map(_chipMeta).filter(c => c && _chipAllowed(c));
const seen = new Set(); // Sicherheitsnetz: Rolle-gebundene Chips aus Default einfügen wenn berechtigt
const chips = pages // (aber noch nicht in persönlicher Config) — _chipAllowed() entscheidet für alle
.filter(p => { if (seen.has(p)) return false; seen.add(p); return true; }) const alreadyIn = new Set(chips.map(c => c.page));
.map(_chipMeta) for (const page of (_DEFAULT_CONFIG[world] || [])) {
.filter(c => c && _chipAllowed(c)); if (alreadyIn.has(page)) continue;
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-v779'; const CACHE_VERSION = 'by-v777';
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,10 +280,9 @@ self.addEventListener('fetch', event => {
return; return;
} }
// CSS, Core-JS + Seiten-Module: immer Network-First — damit iOS nie veraltete Versionen cached // CSS, app.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.startsWith('/js/app.js') || url.pathname.startsWith('/js/ui.js') || url.pathname === '/js/app.js' || url.pathname === '/js/ui.js' || url.pathname === '/js/api.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 => {