Sprint 18: Lost-Dog CSS, Freunde-Aktivitäts-Feed, Events-Karte
This commit is contained in:
parent
cfdb3fbc19
commit
10d30bf565
8 changed files with 595 additions and 41 deletions
|
|
@ -2486,8 +2486,10 @@ textarea.form-control {
|
|||
gap: var(--space-2);
|
||||
}
|
||||
.events-map {
|
||||
flex: 1;
|
||||
position: relative;
|
||||
flex: 1;
|
||||
position: relative;
|
||||
min-height: 400px;
|
||||
max-height: calc(100vh - 200px);
|
||||
}
|
||||
.events-month-label {
|
||||
font-size: var(--text-sm);
|
||||
|
|
@ -4793,13 +4795,252 @@ textarea.form-control {
|
|||
|
||||
.adm-stats-grid {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(2, 1fr);
|
||||
grid-template-columns: repeat(2, minmax(0, 1fr));
|
||||
gap: var(--space-3);
|
||||
margin-bottom: var(--space-5);
|
||||
width: 100%;
|
||||
min-width: 0;
|
||||
}
|
||||
@media (min-width: 480px) {
|
||||
.adm-stats-grid { grid-template-columns: repeat(3, 1fr); }
|
||||
.adm-stats-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
|
||||
}
|
||||
@media (min-width: 768px) {
|
||||
.adm-stats-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
|
||||
.adm-stats-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
|
||||
}
|
||||
LOST DOG
|
||||
============================================================ */
|
||||
|
||||
/* Karte für einen vermissten Hund */
|
||||
.lost-card {
|
||||
display: flex;
|
||||
gap: var(--space-3);
|
||||
align-items: flex-start;
|
||||
background: var(--c-surface);
|
||||
border: 1px solid var(--c-border);
|
||||
border-left: 4px solid var(--c-danger, #e74c3c);
|
||||
border-radius: var(--radius-md);
|
||||
padding: var(--space-3);
|
||||
margin-bottom: var(--space-3);
|
||||
cursor: pointer;
|
||||
transition: background var(--transition-fast), box-shadow var(--transition-fast);
|
||||
}
|
||||
.lost-card:hover {
|
||||
background: var(--c-surface-2);
|
||||
box-shadow: var(--shadow-sm);
|
||||
}
|
||||
|
||||
/* Foto links in der Karte */
|
||||
.lost-card-foto {
|
||||
width: 72px;
|
||||
height: 72px;
|
||||
border-radius: var(--radius-md);
|
||||
object-fit: cover;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
/* Platzhalter wenn kein Foto */
|
||||
.lost-card-foto-placeholder {
|
||||
width: 72px;
|
||||
height: 72px;
|
||||
border-radius: var(--radius-md);
|
||||
background: var(--c-surface-2);
|
||||
flex-shrink: 0;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
font-size: 2rem;
|
||||
}
|
||||
|
||||
/* Text-Block rechts neben dem Foto */
|
||||
.lost-card-body {
|
||||
flex: 1;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
/* Name des vermissten Hundes */
|
||||
.lost-card-name {
|
||||
font-weight: var(--weight-semibold);
|
||||
font-size: var(--text-base);
|
||||
margin-bottom: var(--space-1);
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: var(--space-2);
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
/* Kurzbeschreibung */
|
||||
.lost-card-desc {
|
||||
font-size: var(--text-sm);
|
||||
color: var(--c-text);
|
||||
margin: 0 0 var(--space-1);
|
||||
overflow: hidden;
|
||||
display: -webkit-box;
|
||||
-webkit-line-clamp: 2;
|
||||
-webkit-box-orient: vertical;
|
||||
}
|
||||
|
||||
/* Metadaten-Zeile (Datum, Entfernung) */
|
||||
.lost-card-meta {
|
||||
font-size: var(--text-xs);
|
||||
color: var(--c-text-secondary);
|
||||
}
|
||||
|
||||
/* Badge "Gefunden!" — grüner Überlagerungsstreifen */
|
||||
.lost-badge-gefunden {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: var(--space-1);
|
||||
background: var(--c-success, #27ae60);
|
||||
color: #fff;
|
||||
font-size: var(--text-xs);
|
||||
font-weight: var(--weight-semibold);
|
||||
padding: 2px var(--space-2);
|
||||
border-radius: var(--radius-full);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: .04em;
|
||||
}
|
||||
|
||||
/* Badge "Meine Meldung" */
|
||||
.lost-badge-own {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
background: var(--c-warning-subtle, #fff3cd);
|
||||
color: var(--c-warning-dark, #856404);
|
||||
font-size: var(--text-xs);
|
||||
font-weight: var(--weight-medium);
|
||||
padding: 2px var(--space-2);
|
||||
border-radius: var(--radius-full);
|
||||
}
|
||||
|
||||
/* Entfernungs-Pill */
|
||||
.lost-dist-pill {
|
||||
margin-left: auto;
|
||||
white-space: nowrap;
|
||||
font-size: var(--text-sm);
|
||||
color: var(--c-text-secondary);
|
||||
}
|
||||
|
||||
/* Karten-Wrapper auf der Lost-Seite */
|
||||
.lost-map-wrap {
|
||||
height: 280px;
|
||||
border-radius: var(--radius-md);
|
||||
overflow: hidden;
|
||||
background: var(--c-surface-2);
|
||||
margin-bottom: 2px;
|
||||
}
|
||||
|
||||
/* OSM-Attribution unter der Karte */
|
||||
.lost-map-attribution {
|
||||
font-size: 10px;
|
||||
color: var(--c-text-secondary);
|
||||
text-align: right;
|
||||
padding: 2px var(--space-2) 0;
|
||||
margin-bottom: var(--space-4);
|
||||
}
|
||||
|
||||
/* Info-Zeile über der Liste ("X vermisste Hunde …") */
|
||||
.lost-info-text {
|
||||
font-size: var(--text-sm);
|
||||
color: var(--c-text-secondary);
|
||||
margin-bottom: var(--space-3);
|
||||
}
|
||||
FRIENDS ACTIVITY FEED
|
||||
============================================================ */
|
||||
.fr-activity-timeline {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: var(--space-2);
|
||||
}
|
||||
|
||||
.fr-activity-item {
|
||||
display: flex;
|
||||
gap: var(--space-3);
|
||||
align-items: flex-start;
|
||||
padding: var(--space-3) var(--space-4);
|
||||
background: var(--c-surface);
|
||||
border-radius: var(--radius-lg);
|
||||
border: 1px solid var(--c-border);
|
||||
}
|
||||
|
||||
.fr-activity-avatar-wrap {
|
||||
position: relative;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.fr-activity-avatar {
|
||||
width: 40px;
|
||||
height: 40px;
|
||||
border-radius: 50%;
|
||||
object-fit: cover;
|
||||
border: 2px solid var(--c-primary);
|
||||
display: block;
|
||||
}
|
||||
|
||||
.fr-activity-avatar--initial {
|
||||
background: var(--c-primary-subtle);
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
font-weight: var(--weight-bold);
|
||||
color: var(--c-primary);
|
||||
font-size: var(--text-sm);
|
||||
}
|
||||
|
||||
.fr-activity-icon-badge {
|
||||
position: absolute;
|
||||
bottom: -3px;
|
||||
right: -3px;
|
||||
width: 18px;
|
||||
height: 18px;
|
||||
border-radius: 50%;
|
||||
background: var(--c-primary);
|
||||
color: #fff;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
border: 2px solid var(--c-surface);
|
||||
}
|
||||
|
||||
.fr-activity-body {
|
||||
flex: 1;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
.fr-activity-meta {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
align-items: baseline;
|
||||
gap: var(--space-1);
|
||||
margin-bottom: 2px;
|
||||
}
|
||||
|
||||
.fr-activity-user {
|
||||
font-size: var(--text-sm);
|
||||
font-weight: var(--weight-semibold);
|
||||
color: var(--c-text);
|
||||
}
|
||||
|
||||
.fr-activity-dog {
|
||||
font-size: var(--text-xs);
|
||||
padding: 1px 6px;
|
||||
border-radius: var(--radius-full);
|
||||
background: var(--c-surface-2);
|
||||
color: var(--c-text-secondary);
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.fr-activity-text {
|
||||
font-size: var(--text-sm);
|
||||
color: var(--c-text-secondary);
|
||||
line-height: 1.4;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
white-space: nowrap;
|
||||
max-width: 100%;
|
||||
}
|
||||
|
||||
.fr-activity-time {
|
||||
font-size: var(--text-xs);
|
||||
color: var(--c-text-muted);
|
||||
margin-top: 2px;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue