skills/charting/SKILL.md
Full-stack data visualization and charting intelligence. This skill should be used when the user asks to "create a chart", "visualize this data", "build a dashboard", "plot this", "graph these metrics", "show me a chart of", "make a bar chart", "create a line graph", "build a heatmap", or needs help choosing the right chart type, selecting a charting library, or engineering the data pipeline from raw database state to rendered visualization. Covers chart selection, data transformation, library choice by scale, performance optimization, and accessibility.
npx skillsauth add b-open-io/prompts chartingInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Enable any agent to (1) instantly identify the exact chart needed from raw data, (2) generate the precise path of queries/transforms to materialize that chart, and (3) evaluate and choose the optimal charting library/stack based on performance, scale, and interactivity requirements.
This is not "just call a library" — it is full-stack visualization strategy.
Before any code runs, answer these questions in order:
| Goal | Chart Type | |------|-----------| | Compare values | Bar/Column (grouped or stacked) | | Show trend over time | Line or Area | | Show distribution / spread | Histogram, Box Plot, Violin | | Show relationship / correlation | Scatter, Bubble, Heatmap | | Show composition / parts-of-whole | Stacked Bar or Area (never pie if >5 slices) | | Show hierarchy / flow | Treemap, Sunburst, Sankey | | Show geographic pattern | Choropleth or Symbol Map |
| Variables | Chart | |-----------|-------| | 1 numeric, unordered | Histogram / Density | | 1 numeric + time | Line | | 1 categorical + 1 numeric | Bar | | 2 numeric | Scatter | | 1 categorical + time series | Grouped or Stacked Line/Area | | Many-to-many relationships | Heatmap or Parallel Coordinates |
| Audience | Approach | |----------|----------| | Executive dashboard | Big numbers + simple bars/lines, zero clutter | | Analyst/explorer | Interactive tooltips, zoom, hover details, multiple linked views | | Mobile | Horizontal bars, large text, minimal colors | | Accessibility | High contrast, patterns instead of color-only, alt-text descriptions |
| Data Situation | Best Chart (first choice) | Avoid | |---------------|--------------------------|-------| | >5 categories | Bar (horizontal) | Pie | | Time series >20 points | Line | Column | | Correlation between 2 measures | Scatter | Line (unless ordered) | | Parts of whole >5 slices | Stacked Bar or Treemap | Pie/Donut | | Outliers or distribution shape | Box + Violin | Bar | | Flow between stages | Sankey | Anything else |
Most databases do NOT have the exact aggregation ready. Auto-generate the full pipeline:
Auto-generate SQL or pandas code for:
| Scale | Strategy | |-------|----------| | One-off (<10k rows) | Run query on-the-fly | | Medium | Create materialized view or cached table | | Large/Real-time | Pre-aggregate in Spark/DuckDB, incremental refresh | | Extreme | Stream + windowed aggregates (Flink/Kafka) |
User says "show monthly revenue by product category":
"I need: LEFT JOIN orders -> products -> categories; GROUP BY month, category; SUM(revenue). No view exists -> I will create temp table or run inline. Chart type: Stacked Area. Library recommendation below."
Always output the performance trade-off and recommended stack.
| Scale / Requirement | Recommended Library | Why | Fallback | |--------------------|-------------------|-----|----------| | <10k points, simple web dashboard | Chart.js or Recharts | <10 ms render, ~60 KB bundle | N/A | | 10k-500k points, interactive | Apache ECharts or Plotly.js | Canvas + WebGL, 60 fps on 100k points | D3 (slower) | | 500k-10M+ points, real-time | LightningChart or Highcharts Stock + WebGL | GPU accelerated, <50 ms at 5M points | Anything SVG-based fails | | Python backend + web | Plotly Dash or Bokeh | Server-side render + client streaming | Matplotlib (static only) | | Python notebook exploration | Seaborn + Plotly | Instant, beautiful defaults | -- | | Extremely large / streaming | DuckDB + Observable Plot or Perspective | In-memory columnar, sub-second on billions | -- | | No JavaScript (PDF reports) | Matplotlib + WeasyPrint or ReportLab | Pure Python, vector output | -- |
development
This skill should be used when the user asks to "design a business card", "make a printable PDF", "render HTML to PDF", "generate a postcard", "build print collateral", "set up an HTML print pipeline", or needs help with bleed, safe areas, font embedding, or QR generation for print. Provides a Playwright-based pipeline with multiple bundled templates and theme variants for business cards (minimal, watercolor light, watercolor dark) and instructions for adding new templates.
tools
Get recent tweets from an X/Twitter user. Use when user asks "what has @username posted", "recent tweets from", "user's X posts", "show timeline for", "what is @user saying". Requires X_BEARER_TOKEN.
data-ai
Get X/Twitter user profile by username. Use when user asks "who is @username", "get X profile", "lookup Twitter user", "find X account", "user details", "follower count for". Requires X_BEARER_TOKEN.
data-ai
Search recent X/Twitter posts by query. Returns RAW TWEETS (last 7 days). Use when user asks "search X for", "find tweets about", "what are people saying about", "Twitter search", "raw tweets about". For AI summaries/sentiment, use x-research instead. Requires X_BEARER_TOKEN.