| name | figma-connect-component |
| description | Generate Figma Code Connect mappings that link React components to their Figma counterparts. Use when a component exists in code and needs a Code Connect file so Figma shows real code snippets in Dev Mode. Also triggers on phrases like "connect this component to Figma", "generate Code Connect", "publish to Figma", "add figma.connect for this component", "link this to Figma Dev Mode". |
| argument-hint | <figma-url> [<component-file-path>] |
| user-invocable | true |
Generate Figma Code Connect for React Components
When to Use This Skill
User provides a Figma component URL (or component name) and wants to generate the Code Connect mapping for it.
Required Inputs
- Figma component identifier (one of):
- Full URL:
https://figma.com/design/{fileKey}/{fileName}?node-id={nodeId}
- File key + node ID:
fileKey: abc123, nodeId: 45:67
- Evidence file path:
.temp/figma-explore/{component}.json
- Component name (will search for URL in project files)
- Code component folder path (e.g.,
src/components/Button/Button.tsx)
Execution Steps
1. Gather Figma Component Data
Option A: Evidence File Provided (Preferred)
If an evidence file from figma-explore is provided (e.g., .temp/figma-explore/{component}.json):
- Read the JSON file directly
- Extract:
id (node ID), name, variants, variantProperties, componentPropertyDefinitions
- The file contains all the variant names and values needed for Code Connect
Example evidence file structure:
{
"id": "16:1234",
"name": "Button",
"type": "COMPONENT_SET",
"variants": [
{ "name": "Type=Primary, Size=Small", "id": "16:1235" },
{ "name": "Type=Primary, Size=Large", "id": "16:1236" }
],
"variantProperties": {
"Type": ["Primary", "Secondary", "Ghost"],
"Size": ["Small", "Medium", "Large"]
},
"componentPropertyDefinitions": {
"Label": { "type": "TEXT", "defaultValue": "Button" },
"Show Icon": { "type": "BOOLEAN", "defaultValue": false }
}
}
Option B: URL/Node ID Provided (MCP Fallback)
If only a Figma URL or node ID is provided:
- Search for existing evidence files in
.temp/figma-explore/ that match the component name
- If not found, use MCP tools:
- Call
mcp_figma_get_metadata with nodeId and fileKey
- Call
mcp_figma_get_design_context with nodeId and fileKey
2. Discover Figma URL (if needed)
If no URL or evidence file provided, search for it:
- Check
{ComponentFolder}/README.md for "Figma Source" section
- Check
specs/**/tasks.md for component-to-Figma mapping tables
- Check
.temp/figma-explore/figma-components-index.json for matching component names
- Check prior conversation context for file key
3. Read Code Component and Inline the Mapping Contract
- Read the specified component file — identify exports, props interface, component name
- If
.temp/design-components/{component-name}/proposed-api.md exists, read it and inline the prop-to-Figma mapping table into your working context. Do not reference this file by path during generation — the full mapping must be in active context so no property is guessed or missed.
- Cross-check: every prop in the React interface should have a corresponding Figma source in the table. Props with no Figma source (e.g.,
className, id) are omitted from Code Connect.
4. Generate Mapping
- Map Figma properties to code props using
figma.* helpers
- Build example JSX template
- Add appropriate imports
5. Write Code Connect File
- Output to:
{ComponentFolder}/{ComponentName}.figma.tsx
- Raw file content only—no markdown fences
6. Update README with Mapping Diagram
If {ComponentFolder}/README.md exists, ensure it has a Design-to-Code Mapping section with a mermaid flowchart at the top showing the Figma-to-React property relationships.
Diagram format:
flowchart LR
subgraph Figma["Figma Variants"]
FProp1["PropertyName1"]
FProp2["PropertyName2"]
end
subgraph React["React Props"]
RProp1["propName1"]
RProp2["propName2"]
end
FProp1 -->|"Value1 → 'code1'<br>Value2 → 'code2'"| RProp1
FProp2 -->|"mapping description"| RProp2
style Figma fill:#f3e8ff,stroke:#9333ea
style React fill:#dbeafe,stroke:#3b82f6
Placement: The mermaid diagram should be placed immediately after the ## Design-to-Code Mapping heading, before any tables.
Example README structure:
## Design-to-Code Mapping
```mermaid
flowchart LR
subgraph Figma["Figma Variants"]
FSize["Size"]
FType["Type"]
end
subgraph React["React Props"]
RSize["size"]
RVariant["variant"]
end
FSize -->|"Small → 'sm'<br>Medium → 'md'<br>Large → 'lg'"| RSize
FType -->|"Primary → 'primary'<br>Secondary → 'secondary'"| RVariant
style Figma fill:#f3e8ff,stroke:#9333ea
style React fill:#dbeafe,stroke:#3b82f6
` ` `
### Variant Mappings
| Figma Variant | Figma Value | React Prop | React Value |
...
Rules for the diagram:
- Include all mapped variant properties (from
figma.enum() calls)
- Include boolean properties that map to React props
- Show value transformations on the arrows (e.g.,
"Small → 'sm'")
- Use
<br> for multiple value mappings on one arrow
- Exclude pseudo-states (hover, focus, pressed) from the diagram
- Use purple styling for Figma subgraph, blue for React subgraph
Rules
Use Exact Figma Property Names
Critical: Code Connect requires the EXACT property names as they appear in Figma.
- Get exact names from evidence files (
.figma-components/*.json) or get_metadata output
- Property names like
ButtonType, Type, Size must match EXACTLY (case-sensitive)
- The
get_design_context MCP tool normalizes to camelCase - do NOT use those names
- Property names are case-sensitive:
Size ≠ size
Example from metadata:
name="ButtonType=Responsive, Type=Primary, Size=Small"
Use in Code Connect:
variant: { ButtonType: 'Responsive' },
props: {
size: figma.enum('Size', { ... }),
variant: figma.enum('Type', { ... }),
}
Only Use Real Figma Properties
Map based on what exists in Figma:
- Component properties →
figma.boolean(), figma.string(), figma.instance()
- Variant properties →
figma.enum()
- Text layers →
figma.textContent('LayerName')
- Nested instances →
figma.children('LayerName') or figma.children('*')
- Child component props →
figma.nestedProps('LayerName', { ... })
Never invent properties that don't exist in Figma.
Value Conventions
- Drop pseudo-state variants:
hover, pressed, focused, state, interaction
- Map Figma Title Case to code:
Primary → 'primary', Small → 'sm'
- Normalize boolean variants: "Yes"/"No", "True"/"False", "On"/"Off" →
true/false
Critical Constraint: No JavaScript Expressions
Code Connect snippets are strings, NOT executed code.
NEVER use:
{hasIcon && <Icon />}
{disabled ? 'disabled' : ''}
{icon || <Fallback />}
Instead, use mapping objects:
figma.boolean('Has Icon', {
true: <Icon />,
false: undefined
})
API Reference
Basic Helpers
figma.string('Label')
figma.boolean('Disabled')
figma.boolean('Has Icon', {
true: <Icon />,
false: undefined
})
figma.boolean('Has label', {
true: figma.string('Label'),
false: undefined
})
figma.enum('Size', {
'Small': 'sm',
'Medium': 'md',
'Large': 'lg'
})
figma.textContent('Button Label')
figma.instance('Icon')
figma.children('Tab')
figma.children(['Tab 1', 'Tab 2'])
figma.children('Icon*')
figma.children('*')
Advanced Helpers
figma.nestedProps('Button Shape', {
size: figma.enum('Size', { ... })
})
figma.className([
'btn-base',
figma.enum('Size', { 'Large': 'btn-large' }),
figma.boolean('Disabled', { true: 'btn-disabled', false: '' })
])
figma.instance<React.FunctionComponent>('Icon')
figma.instance<string>('Icon')
figma.instance('Icon').getProps<{ iconId: string, size: 'sm' | 'lg' }>()
figma.instance('Icon').render<{ id: string }>(props => <CustomIcon id={props.id} />)
Variant Restrictions
Only use this pattern when different Figma variants map to entirely different React components. If all variants map to the same React component with different props, use a single figma.connect():
figma.connect(PrimaryButton, 'https://...', {
variant: { Type: 'Primary' },
example: () => <PrimaryButton />
})
figma.connect(SecondaryButton, 'https://...', {
variant: { Type: 'Secondary' },
example: () => <SecondaryButton />
})
figma.connect(IconButton, 'https://...', {
variant: { 'Has Icon': true },
example: () => <IconButton />
})
figma.connect(DangerButton, 'https://...', {
variant: { Type: 'Danger', Disabled: true },
example: () => <DangerButton />
})
Complete Example
import figma from '@figma/code-connect'
import { Button } from './Button'
figma.connect(Button, 'https://figma.com/design/abc123/File?node-id=1:2', {
props: {
variant: figma.enum('Variant', {
Primary: 'primary',
Secondary: 'secondary'
}),
size: figma.enum('Size', {
Small: 'sm',
Medium: 'md',
Large: 'lg'
}),
disabled: figma.boolean('Disabled'),
label: figma.textContent('Label'),
icon: figma.boolean('Has Icon', {
true: figma.instance('Icon'),
false: undefined
})
},
example: ({ variant, size, disabled, label, icon }) => (
<Button variant={variant} size={size} disabled={disabled} icon={icon}>
{label}
</Button>
)
})
Icon Connection Patterns
Icons as JSX Elements
figma.connect('https://...icon-url...', {
example: () => <IconHeart />
})
figma.connect(Button, 'https://...button-url...', {
props: {
icon: figma.instance('Icon')
},
example: ({ icon }) => <Button>{icon}</Button>
})
Icons as React Components
figma.connect('https://...icon-url...', {
example: () => IconHeart
})
figma.connect(Button, 'https://...', {
props: {
Icon: figma.instance<React.FunctionComponent>('Icon')
},
example: ({ Icon }) => <Button Icon={Icon} />
})
Icons as String IDs
figma.connect('https://...icon-url...', {
example: () => 'icon-heart'
})
figma.connect(Button, 'https://...', {
props: {
iconId: figma.instance<string>('Icon')
},
example: ({ iconId }) => <Button iconId={iconId} />
})
What NOT to Do
These mistakes produce Code Connect files that fail silently or publish incorrect mappings:
- Don't use
get_design_context property names. MCP normalizes them to camelCase. The actual Figma property names are Title Case with spaces (e.g., Has Icon, ButtonType, Size). Use get_metadata output or the raw variant names from evidence files.
- Don't invent properties that don't exist in Figma. If
proposed-api.md lists a prop like className that has no Figma source, omit it from Code Connect entirely.
- Don't use JavaScript expressions in example templates.
{hasIcon && <Icon />} is invalid — Code Connect snippets are static strings. Use figma.boolean('Has Icon', { true: <Icon />, false: undefined }) instead.
- Don't skip the
tsc --noEmit check. Run it after writing the .figma.tsx file. A type error in the Code Connect file will break the publish step.
- Don't map pseudo-states.
hover, focus, pressed, active Figma variants have no corresponding props — exclude them from all figma.enum() and figma.boolean() calls.
- Don't reference
proposed-api.md by path during generation. The mapping contract must be inlined into your working context in Step 3. Reaching back to re-read it mid-generation means the context wasn't loaded correctly.
Output
Write raw file content only—no markdown fences, no explanations.
File location: {ComponentFolder}/{ComponentName}.figma.tsx
Example: src/components/inline-edit/EditableText/EditableText.figma.tsx
File must be immediately usable with npx @figma/code-connect connect publish.