I craft unique cereal names, stories, and ridiculously cute Cereal Baby images.

curseur-talk-to-figma-MCP
Curseur Parlez à Figma MCP
3 years
Works with Finder
25
Github Watches
266
Github Forks
2.8k
Github Stars
Cursor Talk to Figma MCP
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
Project Structure
-
src/talk_to_figma_mcp/
- TypeScript MCP server for Figma integration -
src/cursor_mcp_plugin/
- Figma plugin for communicating with Cursor -
src/socket.ts
- WebSocket server that facilitates communication between the MCP server and Figma plugin
Get Started
- Install Bun if you haven't already:
curl -fsSL https://bun.sh/install | bash
- Run setup, this will also install MCP in your Cursor's active project
bun setup
- Start the Websocket server
bun socket
- MCP server
bunx cursor-talk-to-figma-mcp
- Install Figma Plugin
Quick Video Tutorial
Design Automation Example
Bulk text content replacement
Thanks to @dusskapark for contributing the bulk text replacement feature. Here is the demo video.
Manual Setup and Installation
MCP Server: Integration with Cursor
Add the server to your Cursor MCP configuration in ~/.cursor/mcp.json
:
{
"mcpServers": {
"TalkToFigma": {
"command": "bunx",
"args": ["cursor-talk-to-figma-mcp@latest"]
}
}
}
WebSocket Server
Start the WebSocket server:
bun socket
Figma Plugin
- In Figma, go to Plugins > Development > New Plugin
- Choose "Link existing plugin"
- Select the
src/cursor_mcp_plugin/manifest.json
file - The plugin should now be available in your Figma development plugins
Windows + WSL Guide
- Install bun via powershell
powershell -c "irm bun.sh/install.ps1|iex"
- Uncomment the hostname
0.0.0.0
insrc/socket.ts
// uncomment this to allow connections in windows wsl
hostname: "0.0.0.0",
- Start the websocket
bun socket
Usage
- Start the WebSocket server
- Install the MCP server in Cursor
- Open Figma and run the Cursor MCP Plugin
- Connect the plugin to the WebSocket server by joining a channel using
join_channel
- Use Cursor to communicate with Figma using the MCP tools
MCP Tools
The MCP server provides the following tools for interacting with Figma:
Document & Selection
-
get_document_info
- Get information about the current Figma document -
get_selection
- Get information about the current selection -
read_my_design
- Get detailed node information about the current selection without parameters -
get_node_info
- Get detailed information about a specific node -
get_nodes_info
- Get detailed information about multiple nodes by providing an array of node IDs
Annotations
-
get_annotations
- Get all annotations in the current document or specific node -
set_annotation
- Create or update an annotation with markdown support -
set_multiple_annotations
- Batch create/update multiple annotations efficiently -
scan_nodes_by_types
- Scan for nodes with specific types (useful for finding annotation targets)
Creating Elements
-
create_rectangle
- Create a new rectangle with position, size, and optional name -
create_frame
- Create a new frame with position, size, and optional name -
create_text
- Create a new text node with customizable font properties
Modifying text content
-
scan_text_nodes
- Scan text nodes with intelligent chunking for large designs -
set_text_content
- Set the text content of a single text node -
set_multiple_text_contents
- Batch update multiple text nodes efficiently
Styling
-
set_fill_color
- Set the fill color of a node (RGBA) -
set_stroke_color
- Set the stroke color and weight of a node -
set_corner_radius
- Set the corner radius of a node with optional per-corner control
Layout & Organization
-
move_node
- Move a node to a new position -
resize_node
- Resize a node with new dimensions -
delete_node
- Delete a node -
delete_multiple_nodes
- Delete multiple nodes at once efficiently -
clone_node
- Create a copy of an existing node with optional position offset
Components & Styles
-
get_styles
- Get information about local styles -
get_local_components
- Get information about local components -
create_component_instance
- Create an instance of a component
Export & Advanced
-
export_node_as_image
- Export a node as an image (PNG, JPG, SVG, or PDF) - limited support on image currently returning base64 as text
Connection Management
-
join_channel
- Join a specific channel to communicate with Figma
Development
Building the Figma Plugin
-
Navigate to the Figma plugin directory:
cd src/cursor_mcp_plugin
-
Edit code.js and ui.html
Best Practices
When working with the Figma MCP:
- Always join a channel before sending commands
- Get document overview using
get_document_info
first - Check current selection with
get_selection
before modifications - Use appropriate creation tools based on needs:
-
create_frame
for containers -
create_rectangle
for basic shapes -
create_text
for text elements
-
- Verify changes using
get_node_info
- Use component instances when possible for consistency
- Handle errors appropriately as all commands can throw exceptions
- For large designs:
- Use chunking parameters in
scan_text_nodes
- Monitor progress through WebSocket updates
- Implement appropriate error handling
- Use chunking parameters in
- For text operations:
- Use batch operations when possible
- Consider structural relationships
- Verify changes with targeted exports
- For converting legacy annotations:
- Scan text nodes to identify numbered markers and descriptions
- Use
scan_nodes_by_types
to find UI elements that annotations refer to - Match markers with their target elements using path, name, or proximity
- Categorize annotations appropriately with
get_annotations
- Create native annotations with
set_multiple_annotations
in batches - Verify all annotations are properly linked to their targets
- Delete legacy annotation nodes after successful conversion
License
MIT
相关推荐
Confidential guide on numerology and astrology, based of GG33 Public information
Advanced software engineer GPT that excels through nailing the basics.
Japanese education, creating tailored learning experiences.
Découvrez la collection la plus complète et la plus à jour de serveurs MCP sur le marché. Ce référentiel sert de centre centralisé, offrant un vaste catalogue de serveurs MCP open-source et propriétaires, avec des fonctionnalités, des liens de documentation et des contributeurs.
Manipulation basée sur Micropython I2C de l'exposition GPIO de la série MCP, dérivée d'Adafruit_MCP230XX
本项目是一个钉钉 MCP (Protocole de connecteur de message) 服务 , 提供了与钉钉企业应用交互的 API 接口。项目基于 Go 语言开发 , 支持员工信息查询和消息发送等功能。
La communauté du curseur et de la planche à voile, recherchez des règles et des MCP
Exemple court et doux Implémentation MCP Server / Client pour les outils, les ressources et les invites.
🔥 1Panel fournit une interface Web intuitive et un serveur MCP pour gérer des sites Web, des fichiers, des conteneurs, des bases de données et des LLM sur un serveur Linux.
Reviews

user_90aHbvSs
As a dedicated user of mcp-server, I must say this tool by hiroyuki-nishi is incredibly reliable for managing and optimizing my server needs. The interface is user-friendly, and the performance is seamless. Definitely check it out at [https://mcp.so/server/mcp-server/hiroyuki-nishi](https://mcp.so/server/mcp-server/hiroyuki-nishi)! Highly recommended for anyone looking for a robust server management solution.