docs: update all documentation and add AI tooling configs
- Rewrite README.md with current architecture, features and stack - Update docs/API.md with all current endpoints (corporate, BI, client 360) - Update docs/ARCHITECTURE.md with cache, modular queries, services, ETL - Update docs/GUIA-USUARIO.md for all roles (admin, corporate, agente) - Add docs/INDEX.md documentation index - Add PROJETO.md comprehensive project reference - Add BI-CCC-Implementation-Guide.md - Include AI agent configs (.claude, .agents, .gemini, _bmad) - Add netbird VPN configuration - Add status report Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -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})
|
||||
|
||||

|
||||
|
||||
**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_
|
||||
Reference in New Issue
Block a user