GLips/Figma-Context-MCP
MCP server to provide Figma layout information to AI coding agents like Cursor
Installation
Claude Desktop
Installation Command
Configuration
{
  "mcpServers": {
    "figma-developer-mcp": {
      "command": "npx",
      "args": ["-y", "figma-developer-mcp", "--stdio"],
      "env": {
        "FIGMA_API_KEY": "<your-figma-api-key>"
      }
    }
  }
}README
Figma MCP Server
Give Cursor, Windsurf, Cline, and other AI-powered coding tools access to your Figma files with this Model Context Protocol server.
When Cursor has access to Figma design data, it's way better at one-shotting designs accurately than alternative approaches like pasting screenshots.
Get started quickly, see Configuration for more details:
npx figma-developer-mcp --figma-api-key=<your-figma-api-key>
Demo Video
Watch a demo of building a UI in Cursor with Figma design data
How it works
- Open Cursor's composer in agent mode.
- Paste a link to a Figma file, frame, or group.
- Ask Cursor to do something with the Figma file—e.g. implement a design.
- Cursor will fetch the relevant metadata from Figma and use it to write your code.
This MCP server is specifically designed for use with Cursor. Before responding with context from the Figma API, it simplifies and translates the response so only the most relevant layout and styling information is provided to the model.
Reducing the amount of context provided to the model helps make the AI more accurate and the responses more relevant.
Installation
Running the server quickly with NPM
You can run the server quickly without installing or building the repo using NPM:
npx figma-developer-mcp --figma-api-key=<your-figma-api-key>
# or
pnpx figma-developer-mcp --figma-api-key=<your-figma-api-key>
# or
yarn dlx figma-developer-mcp --figma-api-key=<your-figma-api-key>
# or
bunx figma-developer-mcp --figma-api-key=<your-figma-api-key>
Instructions on how to create a Figma API access token can be found here.
JSON config for tools that use configuration files
Many tools like Windsurf, Cline, and Claude Desktop use a configuration file to start the server.
The figma-developer-mcp server can be configured by adding the following to your configuration file:
{
  "mcpServers": {
    "figma-developer-mcp": {
      "command": "npx",
      "args": ["-y", "figma-developer-mcp", "--stdio"],
      "env": {
        "FIGMA_API_KEY": "<your-figma-api-key>"
      }
    }
  }
}
Running the server from local source
- Clone the repository
- Install dependencies with pnpm install
- Copy .env.exampleto.envand fill in your Figma API access token. Only read access is required.
- Run the server with pnpm run dev, along with any of the flags from the Command-line Arguments section.
Configuration
The server can be configured using either environment variables (via .env file) or command-line arguments. Command-line arguments take precedence over environment variables.
Environment Variables
- FIGMA_API_KEY: Your Figma API access token (required)
- PORT: The port to run the server on (default: 3333)
Command-line Arguments
- --version: Show version number
- --figma-api-key: Your Figma API access token
- --port: The port to run the server on
- --stdio: Run the server in command mode, instead of default HTTP/SSE
- --help: Show help menu
Connecting to Cursor
Start the server
> npx figma-developer-mcp --figma-api-key=<your-figma-api-key>
# Initializing Figma MCP Server in HTTP mode on port 3333...
# HTTP server listening on port 3333
# SSE endpoint available at http://localhost:3333/sse
# Message endpoint available at http://localhost:3333/messages
Connect Cursor to the MCP server
Once the server is running, connect Cursor to the MCP server in Cursor's settings, under the features tab.
Start using Composer with your Figma designs
Once the MCP server is connected, you can start using the tools in Cursor's composer, as long as the composer is in agent mode.
Dropping a link to a Figma file in the composer and asking Cursor to do something with it should automatically trigger the get_file tool.
Inspect Responses
To inspect responses from the MCP server more easily, you can run the inspect command, which launches the @modelcontextprotocol/inspector web UI for triggering tool calls and reviewing responses:
pnpm inspect
# > figma-mcp@0.1.8 inspect
# > pnpx @modelcontextprotocol/inspector
#
# Starting MCP inspector...
# Proxy server listening on port 3333
#
# 🔍 MCP Inspector is up and running at http://localhost:5173 🚀
Available Tools
The server provides the following MCP tools:
get_figma_data
Fetches information about a Figma file or a specific node within a file.
Parameters:
- fileKey(string, required): The key of the Figma file to fetch, often found in a provided URL like- figma.com/(file|design)/<fileKey>/...
- nodeId(string, optional, highly recommended): The ID of the node to fetch, often found as URL parameter node-id=
- depth(number, optional): How many levels deep to traverse the node tree, only used if explicitly requested by you via chat
download_figma_images (work in progress)
Download SVG and PNG images used in a Figma file based on the IDs of image or icon nodes.
Parameters:
- 
fileKey(string, required): The key of the Figma file containing the node
- 
nodes(array, required): The nodes to fetch as images- nodeId(string, required): The ID of the Figma image node to fetch, formatted as 1234:5678
- imageRef(string, optional): If a node has an imageRef fill, you must include this variable. Leave blank when downloading Vector SVG images.
- fileName(string, required): The local name for saving the fetched file
 
- 
localPath(string, required): The absolute path to the directory where images are stored in the project. Automatically creates directories if needed.
About
MCP server to provide Figma layout information to AI coding agents like Cursor
Topics
typescript ai mcp cursor figma