plotly-mcp-cursor
Allows integration with Mapbox for generating geographic map visualizations such as scattermapbox, choroplethmapbox, and densitymapbox.
Enables creation of interactive Plotly charts and visualizations, supporting a wide range of trace types including scatter, bar, line, pie, histogram, 3D, geographic, and more.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@plotly-mcp-cursorcreate a bar chart of revenue by quarter"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
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
Related MCP server: RapidChart MCP Server
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 syncWith pip:
pip install -r requirements.txt2. Run the MCP Server
cd src
python server.py3. 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
create_scatter_plot - Scatter plots with markers, lines, or both
create_bar_chart - Vertical/horizontal bar charts with text labels
create_line_chart - Line charts with styling and fill options
create_pie_chart - Pie/donut charts with custom colors
create_histogram - Histograms with binning and normalization
Utility Tools
create_multi_trace_figure - Initialize figures for multiple traces
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 fileComplete 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:
Create trace builder in
src/traces/{category}/Add tool decorator in
src/server.pyTest with sample data
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
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/arshlibruh/plotly-mcp-cursor'
If you have feedback or need assistance with the MCP directory API, please join our Discord server