Admin-Panel: große Stat-Zahlen passen jetzt in die Chips (v1304)

Stat-Zahlen wurden bei vielen Stellen (z.B. OSM-Marker '3.063.735') durch
.card overflow:hidden abgeschnitten. _statCard() staffelt die Schriftgröße
jetzt nach Zeichenlänge (>=9 -> text-lg, >=7 -> text-xl, sonst text-2xl)
via neue .adm-stat-num-Klassen; white-space:nowrap gegen Umbruch. Volle
Praezision bleibt erhalten. Nebenbei verwaisten LOST-DOG-Kommentar geschlossen.
This commit is contained in:
rene 2026-06-18 20:46:23 +02:00
parent ac0814e687
commit e2219fb8ba
7 changed files with 38 additions and 20 deletions

View file

@ -6707,6 +6707,20 @@ html.modal-open {
@media (min-width: 768px) {
.adm-stats-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
}
/* Stat-Zahl in den Chips Größe nach Zeichenlänge staffeln, damit auch
große Zahlen (z.B. "3.063.735") in die Karte passen statt abgeschnitten
zu werden. Klassen werden in _statCard() je nach Länge gesetzt. */
.adm-stat-num {
font-size: var(--text-2xl);
font-weight: var(--weight-bold);
color: var(--c-text);
line-height: 1.15;
white-space: nowrap;
}
.adm-stat-num--sm { font-size: var(--text-xl); } /* 78 Zeichen, z.B. "139.0 MB" */
.adm-stat-num--xs { font-size: var(--text-lg); } /* 9+ Zeichen, z.B. "3.063.735" */
/* ============================================================
LOST DOG
============================================================ */

View file

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

View file

@ -3,7 +3,7 @@
Router, State-Management, Navigation, Initialisierung.
============================================================ */
const APP_VER = '1303'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VER = '1304'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VERSION = '1.6.0'; // ← semantische Version, wird bei make release gesetzt
window.APP_VER = APP_VER; // global verfügbar für andere Module (z.B. offline-indicator)
window.APP_VERSION = APP_VERSION;

View file

@ -767,15 +767,19 @@ window.Page_admin = (() => {
function _statCard(icon, label, value, color, tab = null) {
const clickable = tab ? `data-adm-tab="${tab}" style="padding:var(--space-4);text-align:center;cursor:pointer"` : `style="padding:var(--space-4);text-align:center"`;
// Lange Zahlen (z.B. "3.063.735") sprengen sonst die Chip-Breite und werden
// durch overflow:hidden abgeschnitten → Schriftgröße nach Länge staffeln.
const txt = (value ?? '—') + '';
const sizeCls = txt.length >= 9 ? ' adm-stat-num--xs'
: txt.length >= 7 ? ' adm-stat-num--sm'
: '';
return `
<div class="card" ${clickable}>
<svg class="ph-icon" style="width:24px;height:24px;color:${color};margin-bottom:var(--space-2)"
aria-hidden="true">
<use href="/icons/phosphor.svg#${icon}"></use>
</svg>
<div style="font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--c-text)">
${value ?? '—'}
</div>
<div class="adm-stat-num${sizeCls}">${value ?? '—'}</div>
<div style="font-size:var(--text-xs);color:var(--c-text-secondary);margin-top:2px">${label}</div>
</div>
`;

View file

@ -4,7 +4,7 @@
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="color-scheme" content="light dark">
<script src="/js/landing-init.js?v=1303"></script>
<script src="/js/landing-init.js?v=1304"></script>
<title>Ban Yaro — Die Hunde-App für Deutschland, Österreich & Schweiz</title>
<meta name="description" content="Ban Yaro: Die kostenlose All-in-One Hunde-App für DACH. Tagebuch, Giftköder-Alarm, Training mit KI, Forum, Wurfbörse, Stammbaum, Inzucht-Check — DSGVO-konform, offline-fähig, direkt im Browser oder als native iPhone-App (Ban Yaro Go).">
<meta name="keywords" content="Hunde App, Hunde Community, Wurfbörse, Züchter, Welpen kaufen, Stammbaum Hund, Inzuchtkoeffizient, Hundezucht, Impfpass Hund, Giftköder Alarm, Gassi Community, Hundetraining App, Hunde Forum, Hunde KI, Hundefilm Datenbank, Welpen Marktplatz">

View file

@ -4,7 +4,7 @@
============================================================ */
// ← EINZIGE Stelle für die Version — STATIC_ASSETS und CACHE_VERSION leiten sich ab
const VER = '1303';
const VER = '1304';
const CACHE_VERSION = `by-v${VER}`;
const CACHE_STATIC = `${CACHE_VERSION}-static`;
const CACHE_TILES = 'ban-yaro-tiles-v1'; // bleibt über SW-Updates erhalten