plotly-mcp-cursor

plotly-mcp-cursor

Enables creating Plotly charts from natural language in Cursor, supporting a wide variety of trace types with full customization.

Category
Visit Server

README

Plotly MCP Server - Implementation Plan

Project Overview

Goal: Graph Objects-only Plotly MCP server for Cursor
Output: HTML visualizations from natural language
Control: Minute-level customization of all chart elements
Scope: Complete coverage of 50+ Plotly trace types

Phase 1 Status ✅

Foundation Complete:

  • ✅ MCP server with FastMCP framework (SDK 1.2.0+)
  • ✅ Project structure for 49 trace types
  • ✅ 5 basic trace builders (scatter, bar, line, pie, histogram)
  • ✅ Figure assembly system
  • ✅ Layout controllers (axes, styling)
  • ✅ Sample data generation for testing
  • ✅ Cursor integration ready

Quick Start

1. Install Dependencies

With UV (recommended):

# Install UV if you havent already
curl -LsSf https://astral.sh/uv/install.sh | sh

# Setup project
cd /Users/arshad/Desktop/personal/code/plotly-mcp-claude
uv sync

With pip:

pip install -r requirements.txt

2. Run the MCP Server

cd src
python server.py

3. Add to Cursor MCP Settings

Add this to your Cursor MCP configuration:

{
  "mcpServers": {
    "plotly-mcp": {
      "command": "python",
      "args": ["/Users/arshad/Desktop/personal/code/plotly-mcp-claude/src/server.py"]
    }
  }
}

Available Tools (Phase 1)

Basic Trace Builders

  1. create_scatter_plot - Scatter plots with markers, lines, or both
  2. create_bar_chart - Vertical/horizontal bar charts with text labels
  3. create_line_chart - Line charts with styling and fill options
  4. create_pie_chart - Pie/donut charts with custom colors
  5. create_histogram - Histograms with binning and normalization

Utility Tools

  1. create_multi_trace_figure - Initialize figures for multiple traces
  2. generate_sample_data - Create test data (linear, sine, random, categories)

Usage Examples

Scatter Plot

create_scatter_plot(
    x_data=[1, 2, 3, 4, 5],
    y_data=[2, 4, 1, 5, 3],
    colors="red",
    sizes=15,
    mode="markers+lines",
    name="My Data"
)

Bar Chart

create_bar_chart(
    x_data=["A", "B", "C", "D"],
    y_data=[20, 14, 23, 25],
    colors="blue",
    orientation="v",
    text=["20", "14", "23", "25"],
    name="Sales Data"
)

Pie Chart

create_pie_chart(
    labels=["Apple", "Orange", "Banana"],
    values=[30, 25, 45],
    hole=0.3,  # Donut chart
    textinfo="label+percent"
)

Generate Test Data

generate_sample_data(
    data_type="sine",
    size=100,
    noise=0.1
)

Architecture

plotly-mcp-claude/
├── src/
│   ├── server.py              # Main MCP server (FastMCP)
│   ├── traces/                # All trace builders (5/49 complete)
│   │   └── basic/            # Phase 1: scatter, bar, line, pie, histogram
│   ├── layouts/              # Layout controllers
│   │   ├── axes.py           # X/Y/Z axis configuration
│   │   └── styling.py        # Colors, fonts, margins, legends
│   ├── assembly/             # Figure building
│   │   └── builder.py        # Combine traces + layout
│   └── [themes/, nlp/]       # Future phases
├── data/                     # Sample datasets (future)
├── examples/                 # Usage examples (future)
├── tests/                    # Unit tests (future)
├── requirements.txt          # Python dependencies
├── pyproject.toml           # Project configuration
└── README.md                # This file

Complete Plotly Trace Types (Planned)

Phase 1 ✅ (5/49)

  • Basic Charts: scatter ✅, bar ✅, line ✅, pie ✅, histogram ✅

Phase 2 📋 (15 more types)

  • Statistical Charts: box, violin, heatmap, contour, splom, parcoords, parcats, histogram2d
  • 3D Charts: scatter3d, surface, mesh3d, volume, isosurface, cone, streamtube

Phase 3 📋 (15 more types)

  • Geographic Charts: choropleth, choroplethmap, choroplethmapbox, scattergeo, scattermap, scattermapbox, densitymap, densitymapbox
  • Financial Charts: candlestick, ohlc, waterfall
  • Hierarchical Charts: treemap, sunburst, icicle, sankey

Phase 4 📋 (14 more types)

  • Polar & Coordinates: scatterpolar, scatterpolargl, scattersmith, scatterternary, carpet, scattercarpet
  • Specialized Charts: funnel, funnelarea, indicator, image, table
  • Additional: barpolar, histogram2dcontour, contourcarpet

Total: 49 trace builders planned

Implementation Timeline

  • Phase 1 ✅ Foundation (5 basic traces) - COMPLETE
  • Phase 2 🚧 Statistical & 3D traces (15 more types)
  • Phase 3 📋 Geographic & Financial traces (15 more types)
  • Phase 4 📋 Remaining traces & complete layout (14 more types)
  • Phase 5 📋 Theming system (sci-fi, corporate, dark themes)
  • Phase 6 📋 Natural language interface

Technical Details

MCP Server Features

  • Built with MCP Python SDK 1.2.0+
  • FastMCP framework for easy tool definition
  • Async/await pattern throughout
  • Type hints for all parameters
  • Error handling with detailed messages
  • Logging for debugging

Chart Features

  • HTML output with embedded Plotly.js
  • Interactive charts (zoom, pan, hover)
  • Responsive design (800x600 default)
  • Professional styling (plotly_white theme)
  • Full customization of all visual elements

Testing

Each trace type returns complete HTML that can be:

  • Viewed directly in browser
  • Embedded in applications
  • Displayed in Cursor/Claude interface

Next Steps for Phase 2

Ready to add Statistical & 3D traces:

  • Box plots - quartile visualization
  • Violin plots - distribution shape
  • Heatmaps - 2D data correlation
  • 3D scatter - three-dimensional points
  • Surface plots - 3D mathematical functions

Contributing

The modular architecture makes it easy to add new trace types:

  1. Create trace builder in src/traces/{category}/
  2. Add tool decorator in src/server.py
  3. Test with sample data
  4. Update documentation

Requirements

  • Python 3.10+
  • MCP Python SDK 1.2.0+
  • Plotly 5.0+
  • Modern browser for viewing charts

Phase 1 Complete - 5/49 trace types implemented Ready for Phase 2: Statistical & 3D visualization

Built with ❤️ for the Claude ecosystem

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured