<< All versions
Skill v1.0.0
Trusted Publisher100/100openai/plugins/grammar-of-graphics-and-declarative-visualization
──Details
PublishedMay 27, 2026 at 03:29 AM
Content Hashsha256:bb60ebbe82bd3a80...
Git SHA
──Files
Files (1 file, 3.3 KB)
SKILL.md3.3 KBactive
SKILL.md · 58 lines · 3.3 KB
version: "1.0.0" name: grammar-of-graphics-and-declarative-visualization description: Build data visualizations with declarative grammars. Use when the user needs Vega-Lite, Vega, Observable Plot, or grammar-of-graphics reasoning, especially for tabular charts that do not require bespoke rendering.
Grammar of Graphics and Declarative Visualization
Overview
Use this skill as the default implementation path for many tabular charts. Declarative grammars are often the fastest, clearest, and most maintainable route when the chart can be expressed as data plus marks plus encodings plus transforms.
This skill covers Vega-Lite, Vega, and Observable Plot. Default to the highest-level tool that cleanly expresses the needed chart and interaction.
Selection Rules
- Use Observable Plot for fast exploratory and explanatory charts in JavaScript when concise code is valuable.
- Use Vega-Lite for portable, declarative specs, multi-view composition, transforms, and embed-friendly chart definitions.
- Use Vega when the user needs lower-level control that still benefits from a declarative runtime.
- Leave this skill and route to D3, Canvas, or the Three.js/WebGL skill only when the chart requires bespoke layout, extreme density, GPU-scale rendering, particles, true 3D, or rendering control that the grammar no longer expresses cleanly.
Working Pattern
- Normalize the table shape.
- Name the mark, encodings, transforms, faceting, and interaction model explicitly.
- Choose the highest-level grammar that supports the chart without contortions.
- Keep specs readable and portable.
- Check whether the declarative approach still fits the expected number of simultaneous chart instances on the page.
- Check mobile portrait and optional landscape behavior: responsive spec, label/tick reduction, hover replacement, touch target policy, and whether the grammar can keep the main visualization visible around controls.
- Use declarative composition before custom code.
Output Expectations
- Explain why the chosen grammar fits better than bespoke rendering.
- Keep the spec readable enough to be reused, embedded, or translated across stacks.
- Call out when the declarative path is reaching its limits and a lower-level skill should take over.
- Call out whether the grammar can support the mobile concept contract or whether D3, Canvas, WebGL, or framework-owned layout should take over.
- For new work, include a technical design section covering instance-count assumptions, performance implications, and the maintenance upside of staying declarative.
References
- Shared theory:
../../references/foundations/task-abstraction-and-chart-selection.md../../references/foundations/perception-color-and-encoding.md../../references/foundations/mobile-first-responsive-visualization.md../../references/foundations/implementation-design-and-tradeoffs.md- Skill references:
./references/vega-lite-and-vega.md./references/observable-plot.md./references/when-to-stay-declarative.md
Representative Prompts
- "Write a Vega-Lite spec for this dataset."
- "Should I use Plot, Vega-Lite, or D3 for this chart?"
- "Build a layered declarative chart with faceting and tooltips."
- "Tell me when this declarative approach stops being a good fit."