by grab
Enables Cursor AI to read and programmatically modify Figma designs through a Model Context Protocol integration.
What is Cursor Talk To Figma about? Provides a Model Context Protocol (MCP) server that lets Cursor AI interact with Figma files—reading document information, querying selections, creating or editing nodes, handling annotations, prototype flows, and exporting assets—all via structured tool calls.
How to use Cursor Talk To Figma?
bun setup
to install the MCP package in the active Cursor project.bun socket
.~/.cursor/mcp.json
(or use the generated npx config).join_channel
tool, then issue tool calls (e.g., get_document_info
, create_text
, set_instance_overrides
) from Cursor.Key features of Cursor Talk To Figma
get_document_info
, get_selection
).set_annotation
, set_multiple_annotations
).get_reactions
, create_connections
).create_rectangle
, create_frame
, create_text
).scan_text_nodes
, set_multiple_text_contents
).export_node_as_image
).Use cases of Cursor Talk To Figma
FAQ
hostname: "0.0.0.0"
line in src/socket.ts
, then start the server.npx
as shown in the serverConfig
.This project implements a Model Context Protocol (MCP) integration between Cursor AI and Figma, allowing Cursor to communicate with Figma for reading designs and modifying them programmatically.
https://github.com/user-attachments/assets/129a14d2-ed73-470f-9a4c-2240b2a4885c
src/talk_to_figma_mcp/
- TypeScript MCP server for Figma integrationsrc/cursor_mcp_plugin/
- Figma plugin for communicating with Cursorsrc/socket.ts
- WebSocket server that facilitates communication between the MCP server and Figma plugincurl -fsSL https://bun.sh/install | bash
bun setup
bun socket
Bulk text content replacement
Thanks to @dusskapark for contributing the bulk text replacement feature. Here is the demo video.
Instance Override Propagation Another contribution from @dusskapark Propagate component instance overrides from a source instance to multiple target instances with a single command. This feature dramatically reduces repetitive design work when working with component instances that need similar customizations. Check out our demo video.
To develop, update your mcp config to direct to your local directory.
{
"mcpServers": {
"TalkToFigma": {
"command": "bun",
"args": ["/path-to-repo/src/talk_to_figma_mcp/server.ts"]
}
}
}
Add the server to your Cursor MCP configuration in ~/.cursor/mcp.json
:
{
"mcpServers": {
"TalkToFigma": {
"command": "bunx",
"args": ["cursor-talk-to-figma-mcp@latest"]
}
}
}
Start the WebSocket server:
bun socket
src/cursor_mcp_plugin/manifest.json
filepowershell -c "irm bun.sh/install.ps1|iex"
0.0.0.0
in src/socket.ts
// uncomment this to allow connections in windows wsl
hostname: "0.0.0.0",
bun socket
join_channel
The MCP server provides the following tools for interacting with Figma:
get_document_info
- Get information about the current Figma documentget_selection
- Get information about the current selectionread_my_design
- Get detailed node information about the current selection without parametersget_node_info
- Get detailed information about a specific nodeget_nodes_info
- Get detailed information about multiple nodes by providing an array of node IDsget_annotations
- Get all annotations in the current document or specific nodeset_annotation
- Create or update an annotation with markdown supportset_multiple_annotations
- Batch create/update multiple annotations efficientlyscan_nodes_by_types
- Scan for nodes with specific types (useful for finding annotation targets)get_reactions
- Get all prototype reactions from nodes with visual highlight animationset_default_connector
- Set a copied FigJam connector as the default connector style for creating connections (must be set before creating connections)create_connections
- Create FigJam connector lines between nodes, based on prototype flows or custom mappingcreate_rectangle
- Create a new rectangle with position, size, and optional namecreate_frame
- Create a new frame with position, size, and optional namecreate_text
- Create a new text node with customizable font propertiesscan_text_nodes
- Scan text nodes with intelligent chunking for large designsset_text_content
- Set the text content of a single text nodeset_multiple_text_contents
- Batch update multiple text nodes efficientlyset_layout_mode
- Set the layout mode and wrap behavior of a frame (NONE, HORIZONTAL, VERTICAL)set_padding
- Set padding values for an auto-layout frame (top, right, bottom, left)set_axis_align
- Set primary and counter axis alignment for auto-layout framesset_layout_sizing
- Set horizontal and vertical sizing modes for auto-layout frames (FIXED, HUG, FILL)set_item_spacing
- Set distance between children in an auto-layout frameset_fill_color
- Set the fill color of a node (RGBA)set_stroke_color
- Set the stroke color and weight of a nodeset_corner_radius
- Set the corner radius of a node with optional per-corner controlmove_node
- Move a node to a new positionresize_node
- Resize a node with new dimensionsdelete_node
- Delete a nodedelete_multiple_nodes
- Delete multiple nodes at once efficientlyclone_node
- Create a copy of an existing node with optional position offsetget_styles
- Get information about local stylesget_local_components
- Get information about local componentscreate_component_instance
- Create an instance of a componentget_instance_overrides
- Extract override properties from a selected component instanceset_instance_overrides
- Apply extracted overrides to target instancesexport_node_as_image
- Export a node as an image (PNG, JPG, SVG, or PDF) - limited support on image currently returning base64 as textjoin_channel
- Join a specific channel to communicate with FigmaThe MCP server includes several helper prompts to guide you through complex design tasks:
design_strategy
- Best practices for working with Figma designsread_design_strategy
- Best practices for reading Figma designstext_replacement_strategy
- Systematic approach for replacing text in Figma designsannotation_conversion_strategy
- Strategy for converting manual annotations to Figma's native annotationsswap_overrides_instances
- Strategy for transferring overrides between component instances in Figmareaction_to_connector_strategy
- Strategy for converting Figma prototype reactions to connector lines using the output of 'get_reactions', and guiding the use 'create_connections' in sequenceNavigate to the Figma plugin directory:
cd src/cursor_mcp_plugin
Edit code.js and ui.html
When working with the Figma MCP:
get_document_info
firstget_selection
before modificationscreate_frame
for containerscreate_rectangle
for basic shapescreate_text
for text elementsget_node_info
scan_text_nodes
scan_nodes_by_types
to find UI elements that annotations refer toget_annotations
set_multiple_annotations
in batchesget_reactions
to extract prototype flows,set_default_connector
,create_connections
for clear visual flow mapping.MIT
Please log in to share your review and rating for this MCP.
{ "mcpServers": { "TalkToFigma": { "command": "npx", "args": [ "-y", "cursor-talk-to-figma-mcp@latest" ], "env": {} } } }
Explore related MCPs that share similar capabilities and solve comparable challenges
by Skyvern-AI
Automates browser‑based workflows by leveraging large language models and computer‑vision techniques, turning natural‑language prompts into fully functional web interactions without writing custom scripts.
by ahujasid
Enables Claude AI to control Blender for prompt‑assisted 3D modeling, scene creation, and manipulation via a socket‑based Model Context Protocol server.
by PipedreamHQ
Connect APIs quickly with a free, hosted integration platform that enables event‑driven automations across 1,000+ services and supports custom code in Node.js, Python, Go, or Bash.
by ahujasid
Enables Claude AI to control Ableton Live in real time, allowing AI‑driven creation, editing, and playback of tracks, clips, instruments, and effects through a socket‑based server.
by leonardsellem
Provides tools and resources to enable AI assistants to manage and execute n8n workflows via natural language commands.
by GongRzhe
Provides a Model Context Protocol server that enables AI assistants to send, read, search, and organize Gmail messages, supporting attachments, label and filter management, and automatic OAuth2 authentication.
by mario-andreschak
A unified platform that manages AI models, MCP servers, and complex workflows, offering secure key storage, visual flow building, and an interactive chat UI.
by tevonsb
Provides a Model Context Protocol server that exposes Home Assistant functionality through a comprehensive REST and SSE API, enabling natural‑language control of smart‑home devices.
by taazkareem
Provides a Model Context Protocol server that lets AI agents read, create, update, and organize ClickUp tasks, lists, spaces, tags, documents, and members through a unified set of tools.