penpot/docs/mcp/design-file-structure-best-practices.md
andrés gonzález 38bf6c3603
📚 Add MCP docs (#8772)
2026-03-25 15:32:24 +01:00

77 lines
3.4 KiB
Markdown

---
title: Design file structure and best practices
order: 4
desc: Organize Penpot pages, components, and libraries so humans and MCP-connected agents can navigate your files reliably.
---
# Design file structure and best practices
## 1. General file structure
### 1.1 Organization into boards
* One board per functional area or feature, not per screen. Example: "Onboarding," "Dashboard," "Settings."
* Use the canvas as a logical map: group frames horizontally or vertically according to flow or hierarchy (e.g., left -> wireframes, right -> final design).
* Avoid "chaotic infinite canvas": every board must have a clear purpose and a visual entry point.
## 2. Design system and tokens
### 2.1 Token hierarchy
* **Tier 1 - Global tokens:** The system base. E.g.: `color.base.neutral.100`, `spacing.base.8`.
* **Tier 2 - Semantic tokens:** Assign meaning to the global tokens. E.g.: `color.bg.default`, `color.text.primary`.
* **Tier 3 - Component tokens:** Specific to a component or pattern. E.g.: `color.button.primary.bg`.
* Maintain the relationships between tiers documented in the design system: specify which tokens can be inherited or modified.
* Use local and global variables with hierarchical names (e.g., `color.text.primary`, `radius.button.sm`).
* Avoid "hard" (manual) values for colors, typography, or spacing. Everything must originate from tokens.
## 3. Components and variants
### 3.1 Organization
* Group components by functional categories, not visual ones: Button, FormField, Card.
* Maintain semantic and consistent naming: `button/primary/default`, `button/primary/hover`, `form/input/text/focus`.
* Use variants only when the differences are part of the same pattern (do not mix distinct components under one variant).
### 3.2 Composition
* Avoid excessive nesting of frames. Maintain a visual depth of 3-4 levels maximum.
* Use layout (Flex or Grid) logically:
* Flex for linear stacks (buttons, lists, forms).
* Grid for predictable structures (cards, galleries, dashboards).
* Define clear constraints or stretch behaviors for every component.
## 4. Naming and semantics
### 4.1 Layers
* Name layers by function, not appearance: ❌ `rectangle 23` -> ✅ `background`, `icon`, `title`.
* Avoid duplicating context in names. If the component is named `button`, its internal layers should not start with `button-...`.
### 4.2 Hierarchy
* Use hierarchical names with `/` to group components: `form/input/text`, `form/input/checkbox`.
## 5. Layout and visual structure
### 5.1 Responsive layout
* Apply layout to the majority of containers.
* Adjust padding, spacing, and alignment from the layout panel, not with invisible rectangles.
* Avoid fixed boards except for graphic or decorative elements.
### 5.2 Grid and spacing
* Define a base spacing unit (for example, 8px) and derive all margins and paddings from it.
* Use column grids on complex pages, but flex layout for internal structures.
## 6. Accessibility and consistency
* Maintain sufficient contrast between text and background (WCAG AA minimum).
* Use typography in predefined scales (8, 10, 12, 14, 16, 20...).
* Avoid the arbitrary use of color to communicate status without textual support.
## 7. Export and collaboration
* Prepare boards with consistent names for handoff (`/screens/login`, `/components/button`).
* Use component and variable names that make sense to developers.
* Avoid duplicates: establish a single source of truth per component or style.