feat(repo): expand lab results workflows across backend and frontend

This commit is contained in:
Piotr Oleszczyk 2026-03-05 12:46:49 +01:00
parent f1b104909d
commit 0a4ccefe28
19 changed files with 1330 additions and 170 deletions

View file

@ -240,6 +240,8 @@ body {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
width: 100%;
justify-content: flex-start;
}
.editorial-filter-row {
@ -389,6 +391,108 @@ body {
color: hsl(28 55% 30%);
}
.lab-results-meta-strip {
margin-top: 0.9rem;
display: flex;
flex-wrap: wrap;
gap: 0.45rem;
}
.lab-results-meta-pill {
border: 1px solid hsl(36 22% 74% / 0.9);
border-radius: 999px;
background: hsl(44 32% 93%);
padding: 0.2rem 0.62rem;
color: var(--editorial-muted);
font-size: 0.73rem;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
}
.lab-results-meta-pill--alert {
border-color: hsl(12 56% 69%);
background: hsl(10 66% 90%);
color: hsl(10 63% 30%);
min-width: 2.25rem;
justify-content: center;
}
.lab-results-filter-panel {
border-color: color-mix(in srgb, var(--page-accent) 24%, var(--border));
background:
linear-gradient(180deg, hsl(44 36% 96%), hsl(42 29% 93%)),
repeating-linear-gradient(90deg, hsl(0 0% 100% / 0), hsl(0 0% 100% / 0) 18px, hsl(36 24% 70% / 0.1) 18px, hsl(36 24% 70% / 0.1) 19px);
}
.lab-results-filter-banner {
border-style: dashed;
border-color: color-mix(in srgb, var(--page-accent) 48%, var(--border));
background: color-mix(in srgb, var(--page-accent-soft) 52%, white);
}
.lab-results-pager {
border-color: color-mix(in srgb, var(--page-accent) 26%, var(--border));
}
.lab-results-table table {
border-collapse: separate;
border-spacing: 0;
}
.lab-results-row td {
vertical-align: middle;
}
.lab-results-row-actions {
opacity: 0.62;
transition: opacity 120ms ease;
}
.lab-results-row:hover .lab-results-row-actions,
.lab-results-row:focus-within .lab-results-row-actions {
opacity: 1;
}
.lab-results-code-link {
border-radius: 0.32rem;
text-decoration: none;
transition: color 120ms ease, background-color 120ms ease;
}
.lab-results-code-link:hover {
color: var(--page-accent);
text-decoration: underline;
text-underline-offset: 3px;
}
.lab-results-code-link:focus-visible {
outline: 2px solid var(--page-accent);
outline-offset: 2px;
}
.lab-results-value-cell {
font-variant-numeric: tabular-nums;
font-feature-settings: 'tnum';
}
.lab-results-mobile-grid .products-section-title {
margin-top: 0.15rem;
}
.lab-results-mobile-card {
gap: 0.45rem;
background: linear-gradient(170deg, hsl(44 34% 96%), hsl(42 30% 94%));
}
.lab-results-mobile-value {
justify-content: space-between;
}
.lab-results-mobile-actions {
margin-top: 0.1rem;
}
[data-slot='card'] {
border-color: hsl(35 22% 75% / 0.8);
background: linear-gradient(170deg, hsl(44 34% 97%), hsl(41 30% 95%));
@ -416,6 +520,37 @@ body {
.app-main {
padding: 2rem;
}
.editorial-hero {
display: grid;
grid-template-columns: minmax(0, 1fr) auto;
grid-template-areas:
'kicker actions'
'title actions'
'subtitle actions';
column-gap: 1rem;
align-items: start;
}
.editorial-kicker {
grid-area: kicker;
}
.editorial-title {
grid-area: title;
}
.editorial-subtitle {
grid-area: subtitle;
}
.editorial-toolbar {
grid-area: actions;
margin-top: 0;
width: auto;
justify-content: flex-end;
align-self: start;
}
}
.editorial-dashboard {
@ -487,6 +622,7 @@ body {
}
.hero-strip {
grid-column: 1 / -1;
margin-top: 1.3rem;
display: flex;
flex-wrap: wrap;
@ -807,6 +943,19 @@ body {
.routine-pill {
letter-spacing: 0.08em;
}
.lab-results-meta-strip {
margin-top: 0.75rem;
}
.lab-results-meta-pill {
letter-spacing: 0.06em;
}
.lab-results-filter-banner {
align-items: flex-start;
flex-direction: column;
}
}
@media (prefers-reduced-motion: reduce) {