Compare commits
2 commits
9fd146440f
...
af7fe7813e
| Author | SHA1 | Date | |
|---|---|---|---|
| af7fe7813e | |||
| 5664616a2a |
5 changed files with 18 additions and 21 deletions
|
|
@ -327,7 +327,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 = "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")
|
||||
async def assetlinks():
|
||||
|
|
|
|||
|
|
@ -575,10 +575,10 @@
|
|||
<div id="modal-container"></div>
|
||||
|
||||
<!-- JS: Reihenfolge ist wichtig — erst Basis, dann Features -->
|
||||
<script src="/js/api.js?v=94"></script>
|
||||
<script src="/js/ui.js?v=94"></script>
|
||||
<script src="/js/app.js?v=94"></script>
|
||||
<script src="/js/worlds.js?v=777"></script>
|
||||
<script src="/js/api.js?v=779"></script>
|
||||
<script src="/js/ui.js?v=779"></script>
|
||||
<script src="/js/app.js?v=779"></script>
|
||||
<script src="/js/worlds.js?v=779"></script>
|
||||
|
||||
<!-- Feature-Seiten werden lazy geladen -->
|
||||
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@
|
|||
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 IS_STAGING = location.hostname === 'staging.banyaro.app';
|
||||
// Cache-Bust-Parameter nach Update-Reload sofort entfernen
|
||||
|
|
|
|||
|
|
@ -640,18 +640,14 @@ window.Worlds = (() => {
|
|||
}
|
||||
|
||||
function _chipsForWorld(world) {
|
||||
const pages = _getConfig()[world] || _DEFAULT_CONFIG[world];
|
||||
// Alle Chips filtern — _chipAllowed entscheidet ob angezeigt
|
||||
const chips = pages.map(_chipMeta).filter(c => c && _chipAllowed(c));
|
||||
// Sicherheitsnetz: Rolle-gebundene Chips aus Default einfügen wenn berechtigt
|
||||
// (aber noch nicht in persönlicher Config) — _chipAllowed() entscheidet für alle
|
||||
const alreadyIn = new Set(chips.map(c => c.page));
|
||||
for (const page of (_DEFAULT_CONFIG[world] || [])) {
|
||||
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); }
|
||||
}
|
||||
const cfg = _getConfig();
|
||||
const pages = cfg[world] || _DEFAULT_CONFIG[world];
|
||||
// Deduplizieren + filtern — _chipAllowed entscheidet ob angezeigt
|
||||
const seen = new Set();
|
||||
const chips = pages
|
||||
.filter(p => { if (seen.has(p)) return false; seen.add(p); return true; })
|
||||
.map(_chipMeta)
|
||||
.filter(c => c && _chipAllowed(c));
|
||||
return chips;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@
|
|||
Offline-Cache + Push Notifications + Tile-Cache
|
||||
============================================================ */
|
||||
|
||||
const CACHE_VERSION = 'by-v777';
|
||||
const CACHE_VERSION = 'by-v779';
|
||||
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
|
||||
|
|
@ -280,9 +280,10 @@ self.addEventListener('fetch', event => {
|
|||
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/')
|
||||
|| 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(
|
||||
fetch(event.request)
|
||||
.then(response => {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue