This page covers everything you need to go from zero to your first generated spec.Documentation Index
Fetch the complete documentation index at: https://docs.uspec.design/llms.txt
Use this file to discover all available pages before exploring further.
uSpec supports two rendering paths. This page sets up the Figma-native path (annotations rendered into Figma). The Component Markdown path (single
.md spec via the uSpec Extract plugin) has its own walkthrough on the Component Markdown page.Setup instructions
Install your AI agent, connect Figma, and configure your template library.
Create your first spec
Prompt format, available skills, and tips for better output.
Setup instructions
uSpec connects an AI coding agent to Figma through an MCP (Model Context Protocol) server. Setup depends on which rendering path you plan to use. Figma-native path (this walkthrough). Annotations are rendered back into your Figma file. You need three pieces:- AI agent host: the coding environment that runs uSpec skills (Cursor, Claude Code, or Codex)
- Figma MCP: the bridge that connects your agent to Figma files (either Figma Console MCP or native Figma MCP)
- Template library: the Figma file containing documentation templates
.md spec is written to disk. You need two pieces:
- AI agent host (same as above)
- uSpec Extract Figma plugin: replaces the MCP + template library requirement. Either install from Figma Community, or — if you prefer the latest source — clone the uSpec repo and build it locally from
figma-plugin/. The Component Markdown install guide walks through both options.
You only need to complete this setup once. After that, you can generate specs anytime by opening the project in your agent host.
1. Set up your agent host
- Cursor
- Claude Code
- Codex
Cursor is an AI code editor. All uSpec skills run inside Cursor’s chat.
Download Cursor
Go to cursor.com and download the app for your platform.
Open your project in Cursor
uSpec installs into your existing project — you do not need to clone the uSpec repo. Open any folder where you want to use uSpec.
Install uSpec
In the project’s terminal, run:Choose Cursor when prompted. The CLI installs all skills into
.cursor/skills/ and references into ./references/, then writes uspecs.config.json.Verify skills are available by typing
@create-voice or @create-component-md in Cursor’s chat. Either should autocomplete to the skill file.2. Set up Figma MCP
uSpec supports two Figma MCP providers. Choose one based on your setup:MCP providers update their setup instructions frequently. The configuration examples below are a starting point — always check the provider’s documentation for the latest installation steps and options:
- Figma Console MCP: docs.figma-console-mcp.southleft.com
- Native Figma MCP: github.com/figma/figma-mcp
- Figma Console MCP
- Figma MCP (Native)
The Figma Console MCP (by Southleft) connects your agent to Figma Desktop via a Desktop Bridge plugin, giving it access to component data, variables, styles, and screenshots.
Get a Figma personal access token
Go to the Figma API settings
Configure the MCP in your agent
- Cursor
- Claude Code
- Codex
Add the Figma Console MCP to your Cursor MCP configuration:Add this to your Cursor MCP settings (global or project-level
.cursor/mcp.json).Connect to Figma Desktop
The Desktop Bridge plugin provides real-time access to your Figma file data. It comes bundled with the Figma Console MCP.Install the Desktop Bridge plugin
The Desktop Bridge plugin is included in the
figma-console-mcp npm package. After running npx figma-console-mcp@latest, find the plugin at node_modules/figma-console-mcp/figma-desktop-bridge/manifest.json. In Figma Desktop, go to Plugins → Development → Import plugin from manifest… and select this file.Run the plugin
Open the Desktop Bridge plugin in your Figma file. It auto-connects via WebSocket. No special launch flags needed.
When the connection is active, your agent can read Figma file data, take screenshots, and access variables and styles.
3. Run firstrun
Thefirstrun skill configures your Figma template library. Platform selection and skill installation are handled by npx uspec-skills init (Step 1) — firstrun only handles the Figma side.
You only need to run
firstrun once per project. It reads your platform and MCP choice from uspecs.config.json and uses them to extract template keys from your Figma library.Get the template file
uSpec renders documentation using Figma component templates. You need to add the templates to your Figma organization before runningfirstrun.
Uber designers can skip this — the internal template library is already configured. When
firstrun asks for a library link, type “skip”.Open the Community file
Go to the uSpec Template on Figma Community.
Run the firstrun skill
Confirm your Figma MCP is connected
If using Figma Console MCP: Open the Desktop Bridge plugin in Figma Desktop for your template library file. If using Figma MCP (Native): Ensure the MCP server is running and your access token is configured.
Answer the library prompt
The agent asks one question:Library link — Paste the link to your Figma template library (Uber designers can type “skip”).Your Figma MCP and platform were already configured by
npx uspec-skills init, so the agent reads them from uspecs.config.json instead of asking again.When you see “Setup complete! You are now ready to use uSpec”, your environment and template library are configured.
Create your first spec
Before running a skill, confirm your setup is complete for the path you want to use. Figma-native path:- Your agent host is open in the project where you ran
npx uspec-skills initand skills are available - Your Figma MCP is connected (Desktop Bridge plugin for Console MCP, or native MCP server running)
- You’ve run
firstrun. The template library is configured (uspecs.config.jsonhas your template keys and MCP provider)
- Your agent host is open in the project where you ran
npx uspec-skills initand skills are available - The uSpec Extract Figma plugin is installed (from Figma Community or via local dev install)
- You have a
_base.jsonfile produced by running the plugin on a component
Example prompt: Figma-native path
Reference a skill, paste a Figma link, and describe anything the agent can’t infer from the design: states, variants, behavior, or interaction details.
- Cursor
- Claude Code
- Codex
Example prompt: Component Markdown path
Reference the skill and point it at the_base.json produced by the plugin. No Figma link is required.
- Cursor
- Claude Code
- Codex
Available skills
The skills split into two groups based on where the documentation is delivered. Component Markdown (output is a single.md file):
| Skill | What it generates |
|---|---|
create-component-md | Single self-contained .md covering API, structure, color tokens, and screen-reader behavior. Ships with the uSpec Extract Figma plugin. Full guide → |
| Skill | What it generates |
|---|---|
create-anatomy | Numbered markers on a component with an attribute table |
create-property | Variant axis and boolean toggle exhibits with instance previews |
create-voice | Screen reader specs for VoiceOver, TalkBack, and ARIA |
create-color | Color token annotations for all elements and states |
create-api | Property tables with values, defaults, and examples |
create-structure | Dimensional specs for spacing, padding, and sizing |
create-motion | Animation timeline and easing spec from After Effects data |
create-component-md has its own setup path. Instead of a Figma link, it takes a _base.json produced by the uSpec Extract Figma plugin. See the Component Markdown guide for the plugin install and usage walkthrough.What happens when you run a skill
The pipeline differs depending on the path.- Figma-native
- Component Markdown
If a documentation frame appears in your Figma file, your setup is working correctly.
Tips for better output
- Be specific about states: Mention all states (selected, disabled, expanded) in your prompt. The agent cannot infer states that aren’t visible in the current Figma frame.
- Describe the parts: For complex components, describe the interactive elements (e.g., “This is a tooltip. The bell icon triggers it, and the bubble appears on hover and focus.”)
Best practices
Do (both paths)
- Start a new agent session for every prompt. Each skill consumes significant context. A fresh session ensures the model has full capacity and avoids degraded output.
- Run on a high-capacity model. Figma-native skills work on OpenAI GPT 5.4 High or Opus 4.6 High.
create-component-mduses parallel subagents and needs Opus 4.7 High or better.
Do (Figma-native only)
- Confirm the MCP connection before running a skill. For Console MCP, run the Desktop Bridge plugin in Figma. For native MCP, ensure the server is running. Verify the connection in your agent before starting. If the agent can’t reach Figma, the skill will fail.
- Run one agent per Figma file at a time. The MCP supports multiple connections, but all agents share one active page and file context. Finish one skill before starting the next.
Don’t (Figma-native only)
- Interact with the Figma frame while a skill is running. The agent writes to the frame in multiple steps. Clicking, selecting, or editing mid-generation can break node references and corrupt the output.
- Run multiple agents on the same file simultaneously. They override each other’s page navigation and produce corrupted specs. If you need parallel generation, use separate Figma files.
Don’t (both paths)
- Reuse a long chat session for multiple skills. Accumulated history reduces available context and degrades output quality. Start fresh each time.
The Component Markdown path does not write to Figma, so the Figma-interaction caveats above do not apply. You can run multiple
create-component-md skills in parallel against different components safely.Setup issues
Skills not loading
Skills not loading
Run
npx uspec-skills doctor from your project root. It reports any missing skills, missing references, or broken links.- Cursor
- Claude Code
- Codex
- Confirm the project folder is open in Cursor (not a parent directory)
- Check that
.cursor/skills/contains the skill folders. If empty, re-runnpx uspec-skills install --platform cursor. - Restart Cursor after running
npx uspec-skills initso it picks up the new skills.
Figma MCP not connecting
Figma MCP not connecting
Figma Console MCP:
- Confirm Figma Desktop is running (not the web version)
- Close and reopen the Desktop Bridge plugin in Figma
- Make sure only one instance of Figma Desktop is running
- Check that your Figma access token is configured correctly in your agent’s MCP settings
- Confirm the MCP server is running (check your terminal or agent MCP panel)
- Verify your
FIGMA_API_KEYis set correctly in your MCP configuration - Test with a simple command like “List pages in my file” with a Figma link
For issues with skills or Figma connection, see the Troubleshooting guide.