chore: initial monorepo scaffold + WDS Phase 1+2 artifacts

- 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>
This commit is contained in:
2026-05-27 14:34:20 +00:00
commit 17c08e6392
3631 changed files with 855518 additions and 0 deletions

View File

@@ -0,0 +1,314 @@
<!--
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})
![{Page Name}](Sketches/{page-number}-{page-name}.jpg)
**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_

View File

@@ -0,0 +1,159 @@
# {scenario-number}-{scenario-name}
**Project:** {project-name}
**Created:** {date}
**Method:** Whiteport Design Studio (WDS)
---
## Scenario Overview
**User Journey:** {High-level description of what users accomplish in this scenario}
**Entry Point:** {Where users begin this scenario}
**Success Exit:** {Where users end after successful completion}
**Alternative Exits:** {Other possible endpoints - errors, cancellations, etc.}
**Target Personas:** {Which personas from Trigger Map use this scenario}
---
## Pages in This Scenario
| Page # | Page Name | Status | Purpose |
| ------ | ----------- | ---------------- | --------------- |
| {n}.1 | {page-name} | {draft/complete} | {Brief purpose} |
| {n}.2 | {page-name} | {draft/complete} | {Brief purpose} |
| {n}.3 | {page-name} | {draft/complete} | {Brief purpose} |
---
## User Flow
```mermaid
flowchart TD
A[{Entry Point}] --> B[{Page n.1}]
B --> C[{Page n.2}]
C --> D{{Decision Point?}}
D -->|Yes| E[{Page n.3}]
D -->|No| F[{Alternative Path}]
E --> G[{Success Exit}]
F --> G
```
---
## Scenario Steps
### Step 1: {Step Name}
**Page:** {n.1-Page-Name}
**User Action:** {What the user does}
**System Response:** {How the system responds}
**Success Criteria:** {What defines success for this step}
### Step 2: {Step Name}
**Page:** {n.2-Page-Name}
**User Action:** {What the user does}
**System Response:** {How the system responds}
**Success Criteria:** {What defines success for this step}
{Repeat for all steps}
---
## Trigger Map Connections
### Positive Drivers Addressed
From Trigger Map analysis, this scenario serves these user goals:
- ✅ {Positive goal from Trigger Map}
- ✅ {Positive goal from Trigger Map}
### Negative Drivers Avoided
This scenario helps users avoid:
- ❌ {Negative outcome from Trigger Map}
- ❌ {Negative outcome from Trigger Map}
---
## Success Metrics
**Primary Metric:** {Main measure of scenario success}
**Secondary Metrics:**
- {Metric 1}
- {Metric 2}
**User Satisfaction Indicators:**
- {What indicates good user experience}
---
## Edge Cases & Error Handling
| Edge Case | How Handled | Page(s) Affected |
| ----------------------- | ------------------- | ----------------- |
| {edge-case-description} | {handling-approach} | {page-references} |
---
## Technical Requirements
### Data Flow
```
{Entry} → [Fetch Data] → {Display} → [User Action] → [Validate] → [API Call] → {Success}
```
### API Endpoints Used
| Endpoint | Page(s) | Purpose |
| --------------- | ----------- | -------------- |
| {endpoint-path} | {page-refs} | {what-it-does} |
### State Management
{How state is managed across pages in this scenario}
---
## Design Assets
**Scenario Folder:** `C-UX-Scenarios/{scenario-number}-{scenario-name}/`
**Page Specifications:**
- {n}.1-{page-name}/{page-name}.md
- {n}.2-{page-name}/{page-name}.md
- {n}.3-{page-name}/{page-name}.md
**Prototypes:**
- {n}.1-{page-name}/Prototype/
- {n}.2-{page-name}/Prototype/
- {n}.3-{page-name}/Prototype/
---
## Development Notes
{Any scenario-level technical considerations, performance requirements, security notes, etc.}
---
## Revision History
| Date | Changes | Author |
| ------ | ------------------------ | -------- |
| {date} | Initial scenario created | {author} |
---
_Created using Whiteport Design Studio (WDS) methodology_