UX: Privater-Bereich-Header auf Zuchtkartei, Wurfverwaltung, Läufigkeit (SW by-v909)

This commit is contained in:
rene 2026-05-13 19:44:25 +02:00
parent 7fb4177dbd
commit a577e6d8d9
7 changed files with 81 additions and 9 deletions

View file

@ -406,7 +406,7 @@ async def serve_media(path: str, request: _Request):
raise _HE(404, "Nicht gefunden.") raise _HE(404, "Nicht gefunden.")
return _media_response(filepath) return _media_response(filepath)
APP_VER = "908" # muss mit APP_VER in app.js übereinstimmen APP_VER = "909" # 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

@ -591,10 +591,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=908"></script> <script src="/js/api.js?v=909"></script>
<script src="/js/ui.js?v=908"></script> <script src="/js/ui.js?v=909"></script>
<script src="/js/app.js?v=908"></script> <script src="/js/app.js?v=909"></script>
<script src="/js/worlds.js?v=908"></script> <script src="/js/worlds.js?v=909"></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 = '908'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen const APP_VER = '909'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VERSION = '1.5.1'; // ← semantische Version, wird bei make release gesetzt const APP_VERSION = '1.5.1'; // ← 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

@ -26,9 +26,32 @@ window.Page_laeufi = (() => {
// ---------------------------------------------------------- // ----------------------------------------------------------
// Grundstruktur // Grundstruktur
// ---------------------------------------------------------- // ----------------------------------------------------------
function _privateHeader() {
return `
<div style="background:linear-gradient(135deg,#1a1208,#2d1f0e);
border-bottom:1px solid rgba(196,132,58,.25);
padding:var(--space-3) var(--space-4);
display:flex;align-items:center;gap:var(--space-3)">
<div style="background:rgba(196,132,58,.15);border:1px solid rgba(196,132,58,.3);
border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);
display:flex;align-items:center;gap:var(--space-2);flex-shrink:0">
<svg style="width:14px;height:14px;color:var(--c-primary)" viewBox="0 0 256 256">
<use href="/icons/phosphor.svg#lock-key"></use>
</svg>
<span style="font-size:var(--text-xs);font-weight:700;color:var(--c-primary);white-space:nowrap">
Privater Bereich
</span>
</div>
<div style="font-size:var(--text-xs);color:rgba(196,132,58,.6)">
Nur du siehst das nicht öffentlich
</div>
</div>`;
}
function _render() { function _render() {
_container.innerHTML = ` _container.innerHTML = `
<div style="max-width:860px"> <div style="max-width:860px">
${_privateHeader()}
<div class="by-toolbar" style="margin-bottom:var(--space-4)"> <div class="by-toolbar" style="margin-bottom:var(--space-4)">
<h2 style="margin:0;font-size:var(--text-lg);font-weight:var(--weight-semibold)"> <h2 style="margin:0;font-size:var(--text-lg);font-weight:var(--weight-semibold)">
${UI.icon('thermometer')} Läufigkeit & Trächtigkeit ${UI.icon('thermometer')} Läufigkeit & Trächtigkeit

View file

@ -90,12 +90,38 @@ window.Page_litters = (() => {
// ---------------------------------------------------------- // ----------------------------------------------------------
// Grundstruktur rendern // Grundstruktur rendern
// ---------------------------------------------------------- // ----------------------------------------------------------
function _privateHeader(icon, title) {
const zwinger = _appState?.user?.name || '';
return `
<div style="background:linear-gradient(135deg,#1a1208,#2d1f0e);
border-bottom:1px solid rgba(196,132,58,.25);
padding:var(--space-3) var(--space-4);
display:flex;align-items:center;gap:var(--space-3)">
<div style="background:rgba(196,132,58,.15);border:1px solid rgba(196,132,58,.3);
border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);
display:flex;align-items:center;gap:var(--space-2);flex-shrink:0">
<svg style="width:14px;height:14px;color:var(--c-primary)" viewBox="0 0 256 256">
<use href="/icons/phosphor.svg#lock-key"></use>
</svg>
<span style="font-size:var(--text-xs);font-weight:700;color:var(--c-primary);white-space:nowrap">
Privater Bereich
</span>
</div>
<div style="min-width:0">
<div style="font-size:var(--text-xs);color:rgba(196,132,58,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis">
Nur du siehst das nicht öffentlich
</div>
</div>
</div>`;
}
function _render() { function _render() {
_container.innerHTML = ` _container.innerHTML = `
<div class="litters-layout"> <div class="litters-layout">
<div class="by-toolbar"> ${_privateHeader()}
<div class="by-toolbar" style="flex-wrap:wrap">
<h2 style="margin:0;font-size:var(--text-lg);font-weight:var(--weight-semibold)"> <h2 style="margin:0;font-size:var(--text-lg);font-weight:var(--weight-semibold)">
${UI.icon('dog')} Meine Würfe ${UI.icon('certificate')} Meine Würfe
</h2> </h2>
<button class="btn btn-primary btn-sm" id="litters-new-btn"> <button class="btn btn-primary btn-sm" id="litters-new-btn">
${UI.icon('plus')} Neuer Wurf ${UI.icon('plus')} Neuer Wurf

View file

@ -98,9 +98,32 @@ window.Page_zuchthunde = (() => {
// ---------------------------------------------------------- // ----------------------------------------------------------
// Grundstruktur // Grundstruktur
// ---------------------------------------------------------- // ----------------------------------------------------------
function _privateHeader() {
return `
<div style="background:linear-gradient(135deg,#1a1208,#2d1f0e);
border-bottom:1px solid rgba(196,132,58,.25);
padding:var(--space-3) var(--space-4);
display:flex;align-items:center;gap:var(--space-3)">
<div style="background:rgba(196,132,58,.15);border:1px solid rgba(196,132,58,.3);
border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);
display:flex;align-items:center;gap:var(--space-2);flex-shrink:0">
<svg style="width:14px;height:14px;color:var(--c-primary)" viewBox="0 0 256 256">
<use href="/icons/phosphor.svg#lock-key"></use>
</svg>
<span style="font-size:var(--text-xs);font-weight:700;color:var(--c-primary);white-space:nowrap">
Privater Bereich
</span>
</div>
<div style="font-size:var(--text-xs);color:rgba(196,132,58,.6)">
Nur du siehst das nicht öffentlich
</div>
</div>`;
}
function _render() { function _render() {
_container.innerHTML = ` _container.innerHTML = `
<div class="zh-layout"> <div class="zh-layout">
${_privateHeader()}
<div class="by-toolbar" style="flex-wrap:wrap"> <div class="by-toolbar" style="flex-wrap:wrap">
<h2 style="margin:0;font-size:var(--text-lg);font-weight:var(--weight-semibold);flex-shrink:0;white-space:nowrap"> <h2 style="margin:0;font-size:var(--text-lg);font-weight:var(--weight-semibold);flex-shrink:0;white-space:nowrap">
${UI.icon('dog')} Zuchtkartei ${UI.icon('dog')} Zuchtkartei

View file

@ -3,7 +3,7 @@
Offline-Cache + Push Notifications + Tile-Cache Offline-Cache + Push Notifications + Tile-Cache
============================================================ */ ============================================================ */
const CACHE_VERSION = 'by-v908'; const CACHE_VERSION = 'by-v909';
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