ui: compact pill layout for detail items; red availability warning
- Detail items (Size, Progress, Speed, ETA, Seeds, Peers, Availability, Completed) now render as inline pill badges with background + border- radius that wrap naturally on any screen width - Remove mobile @media override that forced flex-direction:column, which was causing one-per-line centred layout on small screens - Availability < 100%: value text shown in red (--danger) bold, both on card creation and on live SSE update via classList.toggle - Also ensures updateDownloadCard keeps availability-warning in sync
This commit is contained in:
@@ -359,9 +359,10 @@ function updateDownloadCard(card, download) {
|
|||||||
peersEl.textContent = download.peers;
|
peersEl.textContent = download.peers;
|
||||||
}
|
}
|
||||||
|
|
||||||
const availabilityEl = card.querySelector('.detail-item[data-label="Availability"] .detail-value');
|
const availabilityItem = card.querySelector('.detail-item[data-label="Availability"]');
|
||||||
if (availabilityEl && download.availability !== undefined) {
|
if (availabilityItem && download.availability !== undefined) {
|
||||||
availabilityEl.textContent = `${download.availability}%`;
|
availabilityItem.querySelector('.detail-value').textContent = `${download.availability}%`;
|
||||||
|
availabilityItem.classList.toggle('availability-warning', parseFloat(download.availability) < 100);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -558,6 +559,7 @@ function createDownloadCard(download) {
|
|||||||
|
|
||||||
if (download.availability !== undefined) {
|
if (download.availability !== undefined) {
|
||||||
const availability = createDetailItem('Availability', `${download.availability}%`);
|
const availability = createDetailItem('Availability', `${download.availability}%`);
|
||||||
|
if (parseFloat(download.availability) < 100) availability.classList.add('availability-warning');
|
||||||
details.appendChild(availability);
|
details.appendChild(availability);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -462,17 +462,26 @@ body {
|
|||||||
.download-details {
|
.download-details {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
gap: 4px 14px;
|
gap: 4px 6px;
|
||||||
padding-top: 6px;
|
padding-top: 6px;
|
||||||
border-top: 1px solid var(--border);
|
border-top: 1px solid var(--border);
|
||||||
align-items: center;
|
align-items: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.detail-item {
|
.detail-item {
|
||||||
display: flex;
|
display: inline-flex;
|
||||||
align-items: baseline;
|
align-items: baseline;
|
||||||
gap: 4px;
|
gap: 3px;
|
||||||
font-size: 0.78rem;
|
font-size: 0.78rem;
|
||||||
|
background: var(--bg-secondary, rgba(0,0,0,0.04));
|
||||||
|
border-radius: 4px;
|
||||||
|
padding: 2px 6px;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
.detail-item.availability-warning .detail-value {
|
||||||
|
color: var(--danger, #e53e3e);
|
||||||
|
font-weight: 700;
|
||||||
}
|
}
|
||||||
|
|
||||||
.detail-label {
|
.detail-label {
|
||||||
@@ -1021,11 +1030,6 @@ body {
|
|||||||
width: 40px;
|
width: 40px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.download-details {
|
|
||||||
flex-direction: column;
|
|
||||||
gap: 2px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.progress-container {
|
.progress-container {
|
||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user