home / skills / thebushidocollective / han / figma-generate-component

This skill converts Figma frames into production-ready React, Vue, or HTML/CSS components using MCP mappings and design tokens.

npx playbooks add skill thebushidocollective/han --skill figma-generate-component

Review the files below or copy the command above to add this skill to your agents.

Files (1)
SKILL.md
3.9 KB
---
name: figma-generate-component
description: Generate production-ready code from a Figma component or frame using the Figma MCP server
---

# Generate Component from Figma

## Name

figma:figma-generate-component - Generate production-ready code from Figma designs

## Synopsis

Convert Figma frames and components into production code (React, Vue, HTML/CSS) using the Figma Desktop MCP server with support for Code Connect mappings and design tokens.

## Description

You are tasked with generating production-ready code from a Figma design using the Figma MCP server. This command bridges the design-to-code workflow by analyzing Figma frames and converting them into semantic, accessible, framework-specific components.

## Implementation

Uses the Figma Desktop MCP server (HTTP transport at `http://127.0.0.1:3845/mcp`) to access selected frames or node IDs from Figma URLs. Leverages Code Connect mappings when available to prefer design system components over generating code from scratch.

## Input Methods

The user can provide Figma context in two ways:

1. **Selection-based**: User has selected a frame in Figma desktop app
2. **Link-based**: User provides a Figma URL with node ID

## Your Task

1. **Understand the Context**:
   - If the user selected a frame in Figma, access it via MCP
   - If the user provided a URL, extract the node ID and access the design
   - If neither is provided, ask the user to either:
     - Select a frame in Figma and try again, OR
     - Provide a Figma URL with a node ID

2. **Analyze the Design**:
   - Use Figma MCP tools to extract the frame structure
   - Identify components, layout, styling, and content
   - Note any design tokens or variables used
   - Check for Code Connect mappings if available

3. **Generate Code**:
   - Ask the user what framework/language they want (React, Vue, HTML/CSS, etc.)
   - Generate clean, production-ready code that matches the design
   - Use semantic HTML and accessible markup
   - Apply proper component patterns for the target framework
   - Use design system components if Code Connect mappings exist
   - Include comments explaining key decisions

4. **Provide Context**:
   - Explain the component structure
   - Note any design tokens that should be added to the design system
   - Suggest any improvements or accessibility enhancements
   - Mention responsive behavior considerations

## Best Practices

- **Semantic HTML**: Use appropriate HTML elements (nav, main, article, etc.)
- **Accessibility**: Include ARIA labels, proper heading hierarchy, keyboard navigation
- **Design Tokens**: Use variables for colors, spacing, typography when possible
- **Component Composition**: Break complex UIs into smaller, reusable components
- **Responsive Design**: Consider mobile, tablet, desktop breakpoints
- **Code Connect**: Prefer mapped components over generating from scratch

## Example Output Format

When generating a React component, structure it like:

```tsx
// ComponentName.tsx
import React from 'react';
import { DesignSystemButton } from '@/components/Button'; // Using Code Connect mapping

interface ComponentNameProps {
  // Props based on Figma variants
}

/**
 * ComponentName - Brief description
 *
 * Figma: [Link to Figma frame]
 * Design tokens used: --color-primary, --spacing-md, --font-heading
 */
export const ComponentName: React.FC<ComponentNameProps> = ({ ...props }) => {
  return (
    // JSX matching Figma layout
  );
};
```

## Validation

Before finishing:

1. Verify the code compiles/is valid syntax
2. Check that layout matches Figma design
3. Ensure all interactive elements are accessible
4. Confirm design tokens are properly referenced
5. Note any missing assets or resources needed

## Notes

- If the Figma MCP server is not connected, provide setup instructions
- If the frame is very complex, offer to break it into multiple components
- Always respect the user's framework preference
- Suggest testing in different viewports/screen sizes

Overview

This skill generates production-ready UI code from a Figma component or frame using a local Figma MCP (Desktop) server. It converts selected frames or node IDs into semantic, accessible components for frameworks like React, Vue, or plain HTML/CSS. The output favors design system mappings (Code Connect) and extracts design tokens to keep results consistent with your system.

How this skill works

The skill connects to the Figma MCP server (http://127.0.0.1:3845/mcp) to read the selected frame or a node referenced in a Figma URL. It analyzes the frame hierarchy, styles, layout, and any Code Connect mappings, then generates framework-specific component code with comments and design-token references. If MCP is unavailable or no node is provided, it guides the user to select a frame or supply a Figma link.

When to use it

  • You need a production-ready component from an existing Figma frame.
  • Migrating Figma designs into a design system or codebase while preserving tokens.
  • Prototyping accessible, semantic components quickly for React, Vue, or HTML/CSS.
  • When Code Connect mappings exist and you want mapped design system components instead of raw element generation.
  • Breaking large designs into reusable, framework-friendly components.

Best practices

  • Always request the target framework and preferred folder/namespace before generating code.
  • Prefer Code Connect mapped components to reuse your design system rather than generating primitives.
  • Use design tokens (variables) for colors, spacing, and typography instead of hard-coded values.
  • Verify MCP server connectivity; provide setup instructions if the server is not running.
  • Split very complex frames into smaller components to improve maintainability and testability.

Example use cases

  • Generate a React component from a selected Figma frame, with props derived from Figma variants and accessible markup.
  • Convert a Figma header/footer frame into reusable Vue components using Code Connect mappings for navigation items.
  • Produce HTML/CSS prototypes for handoff to backend teams, including responsive breakpoints and token references.
  • Extract a dialog/modal component from Figma and generate accessible markup with ARIA attributes and keyboard handling notes.
  • Identify design tokens used in a card component and output token suggestions for your design system.

FAQ

What if the MCP server is not running?

If MCP is unavailable the skill will provide step-by-step setup instructions to run the Figma Desktop MCP server locally and retry the request.

How do I tell the skill which framework to use?

Before code generation the skill prompts for the target framework (React, Vue, HTML/CSS, etc.) and any preferences such as TypeScript vs JavaScript or folder structure.

Can it use existing design system components?

Yes. When Code Connect mappings are present the generator prefers mapped design system components instead of creating low-level primitives.