Build custom Splunk visualizations using Canvas 2D — with an AI-powered Claude Code skill that handles scaffolding, rendering logic, and best practices for you.
Splunk's built-in charts cover the basics, but sometimes your data deserves something more. Custom visualizations let you render search results exactly the way you want — gauges, heatmaps, status boards, network graphs, or anything you can draw on a canvas. This repo gives you everything you need to get started.
.claude/skills/splunk-viz/ Claude Code skill for generating custom vizs
examples/
arcade_leaderboard/ Retro arcade-style scrolling leaderboard
bet_flow_map/ Betting flow Sankey-style map
bet_radar/ Radar chart for betting metrics
component_status_board/ NOC-style component health grid
custom_single_value/ Configurable single value display
data_pipeline/ Data pipeline flow visualization
f1_ers/ F1 energy recovery system gauge
f1_track_info/ F1 track information display
forwarder_heatmap/ Health: forwarder staleness heatmap grid
gauge/ Multi-mode gauge (arc, donut, bar, status)
goal_timeline/ Goal timeline for match events
index_storage/ Health: layered glass tanks showing index capacity
index_universe/ Index universe explorer
indexing_pipeline_flow/ Health: animated glass-tube pipeline queue monitor
liability_gauge/ Liability exposure gauge
license_gauge/ Health: arc gauge for daily license usage vs quota
line_trend_chart/ Sparkline trend chart
live_ticker/ Scrolling live ticker tape
market_donut/ Market share donut chart
match_heatmap/ Match event heatmap
network_topology/ Network topology graph
odds_ticker/ Live odds ticker display
radar_chart/ Multi-axis radar/spider chart
resource_gauge/ Health: triple-arc CPU/Memory/Swap gauge
scheduler_health/ Health: horizontal tube vital signs for scheduler
search_activity/ Health: stacked glass tank for search slot utilization
splunk_status_board/ Health: glass-themed component health tiles
wc_bracket/ World Cup tournament bracket
worldcup_bets/ World Cup betting dashboard
splunk_health/ Bundled app: all 8 health vizzes + Dashboard Studio dashboard
build.sh Build, merge, and package into a single .tar.gz
build.sh Build and package any standalone viz
test-harness.html Browser-based testing without Splunk deployment
harness-manifest.json Registry of vizs for the test harness
INSTRUCTIONS.md Step-by-step setup and usage guide
TEST-HARNESS.md Test harness documentation
-
Clone this repo and open it in your editor
-
Install Claude Code if you haven't already
-
Ask Claude to build a viz e.g.:
Using /splunk-viz, create a custom visualization that shows a donut chart with a center label. It should accept "label" and "value" columns. -
Build and install:
./build.sh my_viz_name $SPLUNK_HOME/bin/splunk install app dist/my_viz_name-1.0.0.tar.gz
See INSTRUCTIONS.md for the full setup guide.
Try the test harness live: GitHub Pages Demo
The .claude/skills/splunk-viz/ directory contains a Claude Code skill that knows how to:
- Scaffold a complete Splunk viz app (config files, formatter UI, webpack, build script)
- Scaffold a Dashboard Studio app with a
vizs/build pipeline for bundling multiple custom vizs - Generate Canvas 2D rendering code following Splunk's AMD module pattern
- Handle HiDPI displays, real-time data, responsive sizing, and font embedding
- Smooth real-time numeric values with a client-side tween so gauges, bars, and motion elements don't snap between SPL samples
- Apply 32 battle-tested rules learned from building production visualizations
The skill is automatically available when you use Claude Code in this repo. Just describe what you want to visualize and it will generate the full app. You can also ask it to scaffold a full Dashboard Studio app — it generates the app skeleton, build script, test harness, and the vizs/ directory structure for managing multiple visualizations.
The splunk_health/ directory is a ready-to-deploy Splunk app that bundles eight glass-themed health monitoring visualizations into a single Dashboard Studio dashboard. All vizzes share the same design language — glass tubes, liquid fills, animated particles, and progressive glow effects.
| Visualization | Panel | What it shows |
|---|---|---|
| Splunk Status Board | Component tiles | Health of Splunk components (Indexer, Search Head, KV Store, etc.) via | rest /services/server/health |
| License Gauge | Arc gauge | Daily license consumption vs quota via | rest /services/licenser/pools |
| Resource Gauge | Triple arc | CPU, Memory, and Swap utilization via index=_introspection |
| Indexing Pipeline Flow | Glass tubes | Queue fill levels for parsing → merging → typing → indexing via index=_internal group=queue |
| Forwarder Heatmap | Cell grid | Forwarder staleness — green (recent) → yellow (stale) → red (missing) via index=_internal group=tcpin_connections |
| Search Activity | Stacked glass tank | Search slot utilization by type (scheduled/ad-hoc/other) vs max concurrent via | rest /services/server/status |
| Scheduler Health | Horizontal tubes | Success rate, skip rate, and avg runtime — vital signs for the search scheduler via index=_internal sourcetype=scheduler |
| Index Storage | Layered glass tanks | Per-index capacity usage with hot/warm/cold data temperature layers via | rest /services/data/indexes |
Each visualization includes three colour themes (default, dark, neon), configurable warning/critical thresholds, and animated effects that intensify as conditions worsen.
./splunk_health/build.shThis builds all eight vizzes from examples/, rewrites namespaces, merges configs, and packages dist/splunk_health.tar.gz. Upload via Apps → Manage Apps → Install app from file.
The dashboard auto-refreshes every 60 seconds. All searches include appendpipe fallbacks so panels show "Awaiting data" messages instead of blank placeholders.
Each visualization also exists as a standalone app in examples/:
examples/indexing_pipeline_flow/examples/splunk_status_board/examples/license_gauge/examples/forwarder_heatmap/examples/resource_gauge/examples/search_activity/examples/scheduler_health/examples/index_storage/
Build any one individually with ./build.sh <name>.
The examples/custom_single_value/ directory is a complete, working visualization you can install immediately. It displays any search field with configurable:
- Text colour and glow effect
- Bold or regular weight
- Horizontal and vertical alignment
- Optional label with left, centre, or right alignment
| makeresults | eval value="Hello Splunk!"
The examples/component_status_board/ directory is a NOC-style status board that shows Splunk component health from the _internal index. Features:
- Responsive grid of colour-coded tiles (green/amber/red)
- Critical tiles glow and sort to the top; healthy tiles fade back
- Error and warning count badges on each tile
- Click any tile to drilldown to that component's logs
- Theme-aware — works on both light and dark dashboards
index=_internal sourcetype=splunkd log_level=* component=*
| stats count(eval(log_level="ERROR")) as errors
count(eval(log_level="WARN")) as warns by component
| eval status=if(errors>0,"critical",if(warns>0,"warning","ok"))
The examples/gauge/ directory is a multi-mode gauge visualization with four display modes and eight colour schemes. Features:
- Arc — full 270-degree segmented gauge with needle, tick marks, and centre readout
- Donut — compact ring gauge with centre value
- Bar — horizontal segmented bar with label and value
- Status — on/off pill indicator for binary states
- Eight colour schemes (teal-red, green-red, blue-red, severity, and more)
- Optional LED indicator row above the arc
- Configurable glow effect on the leading edge
- Auto-scaling text and layout
| makeresults | eval value=75
Works with any numeric field — CPU usage, memory, disk, response times, queue depth, or any metric you want to visualise as a gauge.
Iterate on your visualizations in the browser without deploying to Splunk:
python3 -m http.server 8080Open http://localhost:8080/test-harness.html — select a viz, adjust sliders and settings, see the canvas update in real-time. Test the no-data state, resize the panel, and tweak formatter options — all without a Splunk instance.
Each viz includes a harness.json that defines interactive controls and sample data. The harness HTML is fully generic — no viz-specific code. See TEST-HARNESS.md for full documentation.
- Splunk Enterprise 10.2+ or Splunk Cloud
- Node.js 18+ (for building the webpack bundle)
- Claude Code (for using the AI skill)
Each visualization is a standalone Splunk app:
visualization_source.js— AMD module that extendsSplunkVisualizationBase, receives search results, and draws on a<canvas>elementformatter.html— Splunk form components that expose settings in the dashboard Format panel- Config files —
app.conf,visualizations.conf,savedsearches.confregister the viz with Splunk - webpack — Bundles the source into a single
visualization.jsthat Splunk loads
The build script handles npm install, webpack bundling, and tarball packaging — excluding dev files from the final package.
Each viz is a standalone app by default, but you can also embed visualizations into an existing Splunk app — either manually or by scaffolding a Dashboard Studio app with an automated build pipeline (see EMBEDDING.md).
- Create your viz in
examples/your_viz_name/following the directory structure - Add a
harness.jsonfor browser testing and register it inharness-manifest.json - Use
./build.sh your_viz_nameto build and package - Test locally with the harness, then in Splunk, then submit a PR
Apache 2.0 — see LICENSE.



