--- name: pencil-to-code description: | Export .pen design to React/Tailwind code. Does ONE thing well. Input: .pen frame ID or file path Output: React component code + Tailwind config Use when: design-exploration or user needs implementation code from a finalized Pencil design. --- # Pencil to Code Export Pencil .pen designs to production React/Tailwind code. ## Interface **Input:** - Frame ID to export (or entire document) - Target framework: React (default), Vue, HTML - Optional: Component name, output path **Output:** - React component(s) with Tailwind classes - Tailwind theme configuration (from .pen variables) - Optional: Screenshot comparison for validation ## Workflow ### 1. Read Design Structure ```javascript // Get full frame tree mcp__pencil__batch_get({ filePath: ".pen", nodeIds: ["frameId"], readDepth: 10, resolveInstances: true, resolveVariables: true }) // Get design variables/theme mcp__pencil__get_variables({ filePath: ".pen" }) ``` ### 2. Extract Design Tokens Transform .pen variables → Tailwind theme: ```css /* From .pen variables */ @theme { --color-primary: [from variables.colors.primary]; --color-background: [from variables.colors.background]; --font-sans: [from variables.fonts.body]; /* ... */ } ``` Reference: `references/token-extraction.md` ### 3. Map Nodes to Components | .pen Node Type | React Output | |---------------|--------------| | `frame` with layout | `
` | | `frame` with children | Component with children | | `text` | `

`, ``, or `` | | `ref` (instance) | Reusable component | | `rectangle` | `

` with fill | | `ellipse` | `
` | | `image` | `` or `fill: url()` | Reference: `references/node-mapping.md` ### 4. Generate Code **Component structure:** ```tsx // components/[ComponentName].tsx import { cn } from "@/lib/utils" interface [ComponentName]Props { className?: string // Extracted props from design } export function [ComponentName]({ className, ...props }: [ComponentName]Props) { return (
{/* Nested structure */}
) } ``` **Tailwind mapping:** ``` .pen property → Tailwind class -------------------------------- fill: #000 → bg-black layout: horizontal → flex flex-row gap: 16 → gap-4 padding: [16,24,16,24] → py-4 px-6 fontSize: 24 → text-2xl fontWeight: 700 → font-bold cornerRadius: [8,8,8,8] → rounded-lg ``` ### 5. Validate (Optional) ```javascript // Screenshot the .pen frame mcp__pencil__get_screenshot({ nodeId: "frameId" }) // Compare visually with rendered React // (Manual step or browser automation) ``` ### 6. Output ```markdown ## Generated Components ### [ComponentName] - File: `components/[ComponentName].tsx` - Props: [list extracted props] ### Theme Configuration - File: `app/globals.css` (additions) ## Verification Screenshot comparison: [attached] ``` ## Translation Rules ### Layout System ``` .pen Tailwind -------------------------------------- layout: "vertical" → flex flex-col layout: "horizontal" → flex flex-row layout: "grid" → grid alignItems: "center" → items-center justifyContent: "center" → justify-center gap: 8 → gap-2 gap: 16 → gap-4 gap: 24 → gap-6 width: "fill_container" → w-full height: "fill_container" → h-full ``` ### Spacing (8-point grid) ``` .pen padding Tailwind ---------------------------------------- [8,8,8,8] → p-2 [16,16,16,16] → p-4 [16,24,16,24] → py-4 px-6 [24,32,24,32] → py-6 px-8 ``` ### Typography ``` .pen Tailwind ---------------------------------------- fontSize: 12 → text-xs fontSize: 14 → text-sm fontSize: 16 → text-base fontSize: 20 → text-xl fontSize: 24 → text-2xl fontSize: 32 → text-3xl fontSize: 48 → text-5xl fontWeight: 400 → font-normal fontWeight: 500 → font-medium fontWeight: 600 → font-semibold fontWeight: 700 → font-bold ``` ### Colors ``` .pen Tailwind ---------------------------------------- fill: "#FFFFFF" → bg-white fill: "#000000" → bg-black fill: variable → bg-[var(--color-name)] textColor: "#6B7280" → text-gray-500 stroke: "#E5E5E5" → border-gray-200 ``` ### Border Radius ``` .pen cornerRadius Tailwind ---------------------------------------- [0,0,0,0] → rounded-none [4,4,4,4] → rounded [8,8,8,8] → rounded-lg [16,16,16,16] → rounded-2xl [9999,9999,9999,9999] → rounded-full ``` ## Constraints - **Single concern**: Export → code. No design modifications. - **Tailwind 4 @theme**: CSS-first token system - **React + TypeScript**: Default output target - **Semantic HTML**: Choose appropriate elements - **Accessibility**: Include aria attributes where detectable ## References - `references/node-mapping.md` — Complete node → component mapping - `references/token-extraction.md` — Variable → theme extraction - `design-tokens/` — Token system conventions ## Integration **Called by:** - `design-exploration` orchestrator (after direction selection) - Direct user invocation **Composes:** - `design-tokens` (for theme structure)