Perf: Freunde-Seite nutzt _preview.webp + lazy loading, SW by-v1109

Symptom: Friends-Seite lädt Avatare langsam — Original-Bilder
(z.B. 4-12MB iPhone-Fotos) statt der vorhandenen _preview.webp
Vorschauen.

Neue zentrale Helper in ui.js:
- UI.previewUrl(url): ersetzt /media/...jpg → /media/..._preview.webp
- UI.previewFallback(originalUrl): onerror-Handler der Original
  nachlädt falls _preview nicht existiert (für ältere Uploads)

friends.js 3 Stellen migriert:
- _userAvatar (Freundes-Karte + Aktivitäts-Feed)
- Activity-Avatar (dog_foto + avatar_url)
- Dog-Mini-Thumbs im Profil-Modal

Zusätzlich auf allen drei Stellen:
- loading="lazy" für off-screen Bilder
- decoding="async" damit der Hauptthread nicht blockiert

Reuse-Potential: wiki.js, dog-profile.js und andere können später
auf die zentralen Helper umgestellt werden.
This commit is contained in:
rene 2026-05-27 08:50:09 +02:00
parent f6633d65b0
commit 2f37e0ed16
7 changed files with 45 additions and 21 deletions

View file

@ -86,14 +86,14 @@
<title>Ban Yaro</title>
<!-- Theme + theme-color Statusleiste vor CSS setzen -->
<script src="/js/boot-early.js?v=1108"></script>
<script src="/js/boot-early.js?v=1109"></script>
<!-- CSS: Reihenfolge ist wichtig — ?v= zwingt Browser zur Neuladung -->
<link rel="stylesheet" href="/css/design-system.css?v=1108">
<link rel="stylesheet" href="/css/layout.css?v=1108">
<link rel="stylesheet" href="/css/components.css?v=1108">
<link rel="stylesheet" href="/css/utilities.css?v=1108">
<link rel="stylesheet" href="/css/lists.css?v=1108">
<link rel="stylesheet" href="/css/design-system.css?v=1109">
<link rel="stylesheet" href="/css/layout.css?v=1109">
<link rel="stylesheet" href="/css/components.css?v=1109">
<link rel="stylesheet" href="/css/utilities.css?v=1109">
<link rel="stylesheet" href="/css/lists.css?v=1109">
</head>
<body>
@ -617,11 +617,11 @@
<div id="modal-container"></div>
<!-- JS: Reihenfolge ist wichtig — erst Basis, dann Features -->
<script src="/js/api.js?v=1108"></script>
<script src="/js/ui.js?v=1108"></script>
<script src="/js/app.js?v=1108"></script>
<script src="/js/worlds.js?v=1108"></script>
<script src="/js/offline-indicator.js?v=1108"></script>
<script src="/js/api.js?v=1109"></script>
<script src="/js/ui.js?v=1109"></script>
<script src="/js/app.js?v=1109"></script>
<script src="/js/worlds.js?v=1109"></script>
<script src="/js/offline-indicator.js?v=1109"></script>
<!-- Feature-Seiten werden lazy geladen -->
@ -631,7 +631,7 @@
<!-- Boot: Offline-Banner + SW-Registration (extrahiert für CSP) -->
<script src="/js/boot.js?v=1108"></script>
<script src="/js/boot.js?v=1109"></script>
</body>