- Nx 22.7 monorepo (pnpm 11.1, TypeScript 5.9, Node 24) - apps/api: NestJS 11 (CJS conforme CODING-RULES.md PGD-DB-004) - apps/web: React 19 + Vite 8 (ESM) - libs/shared/api-interface: Zod contract base - Docker Compose dev: Postgres 18, Valkey 8, MinIO, Mailpit - WDS artifacts: - design-artifacts/A-Product-Brief/ (5 docs canônicos + 16 dialogs) - design-artifacts/B-Trigger-Map/ (hub + 4 personas + feature impact) - Stack canon: STACK.md v2.2 + CODING-RULES.md v2.0 + brand.md - AGENTS.md + README.md como entrada para devs/agentes Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
315 lines
8.9 KiB
Markdown
315 lines
8.9 KiB
Markdown
<!--
|
|
NAVIGATION BEST PRACTICE: Navigation links appear in THREE places:
|
|
1. Above the sketch (top)
|
|
2. Below the sketch (still in header area)
|
|
3. At document bottom
|
|
This is intentional for long specifications - users should not need to
|
|
scroll the entire document to navigate between pages.
|
|
-->
|
|
|
|
### {page-number}-{page-name}
|
|
|
|
**Previous Step:** ← [{previous-page-name}]({previous-page-path})
|
|
**Next Step:** → [{next-page-name}]({next-page-path})
|
|
|
|

|
|
|
|
**Previous Step:** ← [{previous-page-name}]({previous-page-path})
|
|
**Next Step:** → [{next-page-name}]({next-page-path})
|
|
|
|
---
|
|
|
|
# {page-number}-{page-name}
|
|
|
|
## Page Metadata
|
|
|
|
| Property | Value |
|
|
|----------|-------|
|
|
| **Scenario** | {scenario-name} |
|
|
| **Page Number** | {page-number} |
|
|
| **Platform** | {Mobile web / Desktop / PWA / Native} |
|
|
| **Page Type** | {Full Page / Modal / Drawer / Popup} |
|
|
| **Viewport** | {Mobile-first / Desktop-first} |
|
|
| **Interaction** | {Touch-first / Mouse+keyboard} |
|
|
| **Visibility** | {Public / Authenticated / Admin} |
|
|
|
|
---
|
|
|
|
## Overview
|
|
|
|
**Page Purpose:** {What job must this page accomplish?}
|
|
|
|
**User Situation:** {What brings the user here?}
|
|
|
|
**Success Criteria:** {How will we know this page succeeded?}
|
|
|
|
**Entry Points:**
|
|
- {How users arrive}
|
|
|
|
**Exit Points:**
|
|
- {Where users go next}
|
|
|
|
---
|
|
|
|
## Reference Materials
|
|
|
|
**Strategic Foundation:**
|
|
- [Product Brief]({path}) - {brief description}
|
|
- [Trigger Map]({path}) - {brief description}
|
|
|
|
**Related Pages:**
|
|
- [{Related Page}]({path})
|
|
|
|
**Design System:**
|
|
- [{Component}]({path})
|
|
|
|
---
|
|
|
|
## Layout Structure
|
|
|
|
{High-level description of page layout}
|
|
|
|
```
|
|
[ASCII layout diagram]
|
|
+------------------+
|
|
| Header |
|
|
+------------------+
|
|
| Main Content |
|
|
+------------------+
|
|
| Footer |
|
|
+------------------+
|
|
```
|
|
|
|
---
|
|
|
|
## Spacing
|
|
|
|
<!--
|
|
All spacing values MUST use token names from the project's spacing scale.
|
|
The scale is defined in D-Design-System/00-design-system.md → Spacing Scale.
|
|
This can be the WDS default scale, Tailwind classes, Material tokens, or any system.
|
|
Do NOT use arbitrary pixel values. If unsure, check the scale.
|
|
-->
|
|
|
|
**Scale:** [Spacing Scale](../../D-Design-System/00-design-system.md#spacing-scale)
|
|
|
|
| Property | Token |
|
|
|----------|-------|
|
|
| Page padding (horizontal) | {e.g., space-md mobile / space-lg desktop} |
|
|
| Section gap | {e.g., space-xl} |
|
|
| Element gap (default within sections) | {e.g., space-md} |
|
|
| Component gap (within groups) | {e.g., space-sm} |
|
|
|
|
---
|
|
|
|
## Typography
|
|
|
|
<!--
|
|
Text sizes use token names from the project's type scale.
|
|
The scale is defined in D-Design-System/00-design-system.md → Type Scale.
|
|
|
|
IMPORTANT: Semantic level (H1, H2, p) signals document structure — for accessibility and SEO.
|
|
Visual styling (size, weight, typeface) signals visual hierarchy — how it looks.
|
|
They are related but NOT locked together. An H2 can be text-sm. A <p> can be text-2xl.
|
|
Headings can have different typefaces and styles on different pages — that's fine.
|
|
-->
|
|
|
|
**Scale:** [Type Scale](../../D-Design-System/00-design-system.md#type-scale)
|
|
|
|
| Element | Semantic | Size | Weight | Typeface |
|
|
|---------|----------|------|--------|----------|
|
|
| {Page title} | H1 | {e.g., text-2xl} | {e.g., bold} | {e.g., display / default} |
|
|
| {Section heading} | H2 | {e.g., text-xl} | {e.g., semibold} | {default} |
|
|
| {Body text} | p | text-md | normal | {default} |
|
|
| {Caption/helper} | p | {e.g., text-xs} | normal | {default} |
|
|
|
|
---
|
|
|
|
## Page Sections
|
|
|
|
### Section: {Section Name}
|
|
|
|
**OBJECT ID:** `{page-name}-{section-name}`
|
|
|
|
| Property | Value |
|
|
|----------|-------|
|
|
| Purpose | {What this section does} |
|
|
| Component | [{Design System Component}]({path}) |
|
|
| Padding | {e.g., space-lg space-md} |
|
|
| Element gap | {e.g., space-md — or "default" if same as page-level} |
|
|
|
|
---
|
|
|
|
#### {Object Name}
|
|
|
|
**OBJECT ID:** `{page-name}-{object-name}`
|
|
|
|
| Property | Value |
|
|
|----------|-------|
|
|
| Component | [{Component}]({path}) |
|
|
| Translation Key | `{translation.key}` |
|
|
| SE | "{Swedish text}" |
|
|
| EN | "{English text}" |
|
|
| Behavior | {onClick / onChange / etc.} |
|
|
|
|
#### ↕ `{page}-{v|h}-{type}-{size}` — {reason}
|
|
|
|
<!--
|
|
Spacing objects sit between content objects. They have IDs and are first-class.
|
|
|
|
NAMING: {page}-{v|h}-{type}-{size}
|
|
- v = vertical, h = horizontal
|
|
- type = space, separator, line
|
|
- size = the token name (zero, sm, md, lg, xl, 2xl, 3xl, flex)
|
|
The ID describes WHAT the spacing IS, not which objects it sits between.
|
|
|
|
RULES:
|
|
- Default element spacing (from the Spacing section above) is implicit — no spacing object needed.
|
|
- Non-default spacing MUST be an explicit spacing object with an ID.
|
|
- Zero spacing (overlap / flush) MUST be documented: ↕ `id` — space-zero (reason)
|
|
- Same spacing shared by all items in a group → define on the group, not between each item.
|
|
- Spacing objects flow into D-Design-System/00-design-system.md → Patterns.
|
|
|
|
FORMAT: #### ↕ `{id}` — {reason}
|
|
|
|
EXAMPLES:
|
|
#### ↕ `hem-v-space-zero` — header and service menu form one continuous nav unit
|
|
#### ↕ `hem-v-separator-2xl` — gray line, space-2xl above and below. Separates about from trust cards.
|
|
#### ↕ `hem-v-space-3xl` — major section boundary between seasons and footer
|
|
-->
|
|
|
|
---
|
|
|
|
#### {Object Name 2}
|
|
|
|
**OBJECT ID:** `{page-name}-{object-name-2}`
|
|
|
|
| Property | Value |
|
|
|----------|-------|
|
|
| Component | [{Component}]({path}) |
|
|
| Translation Key | `{translation.key}` |
|
|
| SE | "{Swedish text}" |
|
|
| EN | "{English text}" |
|
|
|
|
---
|
|
|
|
#### {Group Name} (Container)
|
|
|
|
**OBJECT ID:** `{page-name}-{group-name}`
|
|
|
|
| Property | Value |
|
|
|----------|-------|
|
|
| Component | [{Container Component}]({path}) |
|
|
| Purpose | {Groups related objects} |
|
|
| Layout | {Horizontal / Vertical / Grid} |
|
|
|
|
##### {Object in Group}
|
|
|
|
**OBJECT ID:** `{page-name}-{group-name}-{object}`
|
|
|
|
| Property | Value |
|
|
|----------|-------|
|
|
| Component | [{Component}]({path}) |
|
|
| Translation Key | `{translation.key}` |
|
|
| SE | "{Swedish text}" |
|
|
| EN | "{English text}" |
|
|
|
|
##### ↕ `{page-name}-{group-name}-{obj1}-{obj2}-gap` — {spacing token}
|
|
|
|
##### {Object in Group 2}
|
|
|
|
**OBJECT ID:** `{page-name}-{group-name}-{object-2}`
|
|
|
|
| Property | Value |
|
|
|----------|-------|
|
|
| Component | [{Component}]({path}) |
|
|
| Translation Key | `{translation.key}` |
|
|
| SE | "{Swedish text}" |
|
|
| EN | "{English text}" |
|
|
|
|
---
|
|
|
|
## Page States
|
|
|
|
| State | When | Appearance | Actions |
|
|
|-------|------|------------|---------|
|
|
| Default | {condition} | {description} | {available actions} |
|
|
| Loading | {condition} | {description} | {available actions} |
|
|
| Empty | {condition} | {description} | {available actions} |
|
|
| Error | {condition} | {description} | {recovery actions} |
|
|
| Success | {condition} | {description} | {next steps} |
|
|
|
|
---
|
|
|
|
## Conditional Sections
|
|
|
|
Include these micro-instructions when applicable:
|
|
|
|
| Condition | Include |
|
|
|-----------|---------|
|
|
| Public page (SEO needed) | → [meta-content.instructions.md](instructions/meta-content.instructions.md) |
|
|
| Public page (SEO needed) | → [seo-content.instructions.md](instructions/seo-content.instructions.md) |
|
|
| Has forms/inputs | → [form-validation.instructions.md](instructions/form-validation.instructions.md) |
|
|
| Needs API data | → [data-api.instructions.md](instructions/data-api.instructions.md) |
|
|
| Multiple breakpoints | → [responsive.instructions.md](instructions/responsive.instructions.md) |
|
|
| Final review | → [accessibility.instructions.md](instructions/accessibility.instructions.md) |
|
|
| Multiple sketches | → [storyboard-specification.template.md](storyboard-specification.template.md) |
|
|
| **Always (spec creation/audit)** | → [open-questions.instructions.md](instructions/open-questions.instructions.md) |
|
|
|
|
---
|
|
|
|
## Technical Notes
|
|
|
|
{Any constraints, performance requirements, or implementation notes}
|
|
|
|
---
|
|
|
|
## Open Questions
|
|
|
|
<!--
|
|
This section captures decisions needed before development.
|
|
During spec creation or audits, auto-populate questions based on:
|
|
→ instructions/open-questions.instructions.md
|
|
|
|
Categories to check:
|
|
- Responsive breakpoints (if multiple viewports)
|
|
- Loading/Error/Empty states (if API data)
|
|
- SEO meta content (if public page)
|
|
- Accessibility requirements
|
|
- User permissions/roles
|
|
- Time-sensitive behaviors
|
|
- Form validation rules
|
|
- Navigation/back behavior
|
|
-->
|
|
|
|
_No open questions at this time._
|
|
|
|
<!-- When questions exist, use this format:
|
|
| # | Question | Context | Status |
|
|
|---|----------|---------|--------|
|
|
| 1 | {What needs to be decided?} | {Why it matters} | 🔴 Open |
|
|
| 2 | {Question} | {Context} | 🟢 Resolved: {answer} |
|
|
|
|
**Status Legend:** 🔴 Open | 🟡 In Discussion | 🟢 Resolved
|
|
-->
|
|
|
|
---
|
|
|
|
## Checklist
|
|
|
|
- [ ] Page purpose clear
|
|
- [ ] All Object IDs assigned
|
|
- [ ] Components reference design system
|
|
- [ ] Translations complete (SE/EN)
|
|
- [ ] States documented
|
|
- [ ] Conditional sections included where needed
|
|
|
|
---
|
|
|
|
**Previous Step:** ← [{previous-page-name}]({previous-page-path})
|
|
**Next Step:** → [{next-page-name}]({next-page-path})
|
|
|
|
---
|
|
|
|
_Created using Whiteport Design Studio (WDS) methodology_
|