Redesign CVMIS system 2

This commit is contained in:
2026-02-13 16:42:45 +00:00
parent 000df670a3
commit e13a073a6f
26 changed files with 24405 additions and 0 deletions
+144
View File
@@ -0,0 +1,144 @@
# Reference: Tasks 8-11 — Card Component and Top Tiles
## Task 8: Reusable Card Component
### File: `src/components/Card.tsx`
### Base Card
```typescript
interface CardProps {
children: React.ReactNode
full?: boolean // spans both grid columns
className?: string
}
```
**Styling:**
- `background: var(--surface)` (#FFFFFF)
- `border: 1px solid var(--border-light)` (#E4EDEB)
- `border-radius: var(--radius)` (8px)
- `padding: 20px`
- `box-shadow: var(--shadow-sm)` (0 1px 2px rgba(26,43,42,0.05))
- Hover: `box-shadow: var(--shadow-md)`, `border-color: var(--border)` (#D4E0DE)
- `transition: box-shadow 0.2s, border-color 0.2s`
- Full variant: `grid-column: 1 / -1`
### CardHeader Sub-component
```typescript
interface CardHeaderProps {
dotColor: 'teal' | 'amber' | 'green' | 'alert' | 'purple'
title: string
rightText?: string
}
```
**Styling:**
- `display: flex`, `align-items: center`, `gap: 8px`, `margin-bottom: 16px`
- Dot: 8px circle, `border-radius: 50%`, flex-shrink-0
- teal: `#0D6E6E`, amber: `#D97706`, green: `#059669`, alert: `#DC2626`, purple: `#7C3AED`
- Title: 12px, 600 weight, uppercase, `letter-spacing: 0.06em`, text-secondary (#5B7A78)
- Right text (optional): 10px, 400 weight, normal case, no tracking, text-tertiary, mono font, `margin-left: auto`
---
## Task 9: PatientSummary Tile
### File: `src/components/tiles/PatientSummaryTile.tsx`
**Layout:** Full-width card, first in grid.
**Content:**
- CardHeader: teal dot + "PATIENT SUMMARY"
- Body: personal statement text from `src/data/profile.ts`
- Typography: 13px, font-ui, `line-height: 1.6` (leading-relaxed), text-primary
- No interactive elements — read-only
**Data:** `import { personalStatement } from '@/data/profile'`
This is a simple tile. No expansion, no interactivity.
---
## Task 10: LatestResults Tile
### File: `src/components/tiles/LatestResultsTile.tsx`
**Layout:** Half-width card (single grid column). Sits in the LEFT column.
**Content:**
- CardHeader: teal dot + "LATEST RESULTS" + right text "Updated May 2025"
- 2×2 metric grid inside
**Metric Grid:**
- `display: grid`, `grid-template-columns: 1fr 1fr`, `gap: 12px`
**Each Metric Card:**
- `padding: 14px`, `border-radius: var(--radius-sm)` (6px)
- `border: 1px solid var(--border-light)`, `background: var(--bg)` (#F0F5F4)
- Value: 22px, 700 weight, `letter-spacing: -0.02em`, `line-height: 1.2`
- Color by variant: green=#059669, amber=#D97706, teal=#0D6E6E
- Label: 11px, text-secondary, 500 weight, `margin-top: 3px`
- Sub: 10px, text-tertiary, mono font, `margin-top: 4px`
**Data:** `import { kpis } from '@/data/kpis'`
**KPI flip prep:** Each metric card should accept a `data-kpi-id` or an `onClick` prop placeholder — Task 17 will add the flip interaction. For now, render as static display.
**Values:**
| Value | Label | Sub | Color |
|-------|-------|-----|-------|
| £220M | Budget Oversight | NHS prescribing | green |
| £14.6M | Efficiency Savings | Identified & tracked | amber |
| 9+ | Years in NHS | Since 2016 | teal |
| 12 | Team Size Led | Cross-functional | green |
---
## Task 11: CoreSkills Tile ("Repeat Medications")
### File: `src/components/tiles/CoreSkillsTile.tsx`
**Layout:** Half-width card (single grid column). Sits in the RIGHT column, next to LatestResults.
**Content:**
- CardHeader: amber dot + "REPEAT MEDICATIONS"
- Vertical list of skill items, `gap: 10px`
**Each Skill Item:**
Matches the concept's `.dev-item` pattern:
- `display: flex`, `align-items: center`, `gap: 10px`
- 12.5px font, `padding: 10px 12px`
- `background: var(--bg)` (#F0F5F4), `border-radius: var(--radius-sm)` (6px)
- `border: 1px solid var(--border-light)`
**Item structure:**
- **Icon container** (28px square, 6px radius):
- `background: var(--accent-light)`, `color: var(--accent)` (teal)
- Lucide icon inside (14px): `BarChart3` for Data Analysis, `Code2` for Python, `Database` for SQL, `PieChart` for Power BI, `FileCode2` for JS/TS
- **Text block** (flex: 1):
- Name: 600 weight, text-primary (e.g., "Data Analysis")
- Frequency + years: 11px, text-tertiary, mono font (e.g., "Twice daily · Since 2016 · 9 yrs")
- **Optional status badge**: 10px, 500 weight, pill shape (padding 3px 8px, border-radius 20px), flex-shrink-0
- Could show proficiency or "Active" status
**Medication metaphor format:**
```
[📊] Data Analysis Active
Twice daily · Since 2016 · 9 yrs
[💻] Python Active
Daily · Since 2019 · 6 yrs
[🗄️] SQL Active
Daily · Since 2018 · 7 yrs
[📈] Power BI Active
Once weekly · Since 2020 · 5 yrs
[📝] JavaScript / TypeScript Active
When required · Since 2022 · 3 yrs
```
**Data:** `import { skills } from '@/data/skills'`
**Expansion prep:** Each item should accept an onClick prop placeholder — Task 16 will add expansion to show prescribing history (from existing medications data).