Skip to content

Bubble API

Gravity-clustered circles sized by value, each optionally split into a realized core and an untapped ring - see the Bubble demo.

Import

ts
import "@michi-vz/wc/bubble-chart";
// <michi-vz-bubble-chart> is now defined
ts
import { mountBubbleChart } from "@michi-vz/core";

const chart = mountBubbleChart(el, props);

Props

PropTypeDefaultDescription
dataSet*BubbleDataItem[]Array of bubbles; each value sets the circle area (bubbles are gravity-packed into a cluster)
titlestringOptional chart title rendered above the plot
gravitynumber0.09Strength of the pull toward the centre in [0,1] (default 0.09) — higher = tighter cluster ("suck together").
chargeStrengthnumber0Many-body charge: negative repels, positive attracts (default 0).
paddingnumber2Gap between packed circles in px (default 2).
fillRationumber0.62Fraction of the plot area the bubbles should fill, in (0,1] (default 0.62).
splitLabels[string, string]["Realized", "Untapped"]Names of the two split parts (default ["Realized","Untapped"]).
splitOpacitynumber0.35Apparent colour strength of the untapped veil in [0,1] (default 0.35); rendered as solid colour under a white veil so it reads as a lighter tint of the same hue on any background.
showSplitbooleanRender the realized/untapped split. Defaults to auto-on when any item has `partial`.
showLegendbooleanfalseRender a 2-swatch split legend (uses splitLabels).
showLabelsbooleantrueDraw the label inside each bubble when it is large enough (default true).
filter{ limit: number; sortingDir: "asc" | "desc" }Keep only the top-N bubbles by value.
valueFormatter(n: number) => stringFormats a numeric value for labels and tooltips
tooltipFormatter(bubble: BubbleContext) => stringReturns custom tooltip HTML for a hovered datum/mark (sanitized before it is inserted)
onHighlightItem(labels: string[]) => voidCalled when the hovered/highlighted label(s) change
Common props — shared by every chart (14)
PropTypeDefaultDescription
widthnumber700Chart width in pixels
heightnumber500Chart height in pixels
marginMargin{ top: 36, right: 8, bottom: 8, left: 8 }Inner margins (top/right/bottom/left, in px) reserved for axes, titles, and labels
colorsstring[]Categorical palette for series/labels without an explicit colour or colorsMapping entry
colorsMappingRecord<string, string>Explicit label -> colour map; takes precedence over the palette and per-item colours
highlightItemsstring[]Labels to emphasise; all other marks dim
disabledItemsstring[]Labels to hide and exclude from scales/stacks
renderer"svg" | "canvas""svg"Render as inline SVG (default) or to a canvas (faster for large datasets); getContext() is identical either way
localestringBCP-47 locale used for number and date formatting
skipColorMappingDispatchbooleanfalseExternal-CSS mode: unmapped labels resolve to transparent and onColorMappingGenerated is not emitted, so mark colours come from your CSS via the data-label-safe contract
enableTransitionsbooleantrueAnimate updates with CSS transitions (default true)
onColorMappingGenerated(mapping: Record<string, string>) => voidCalled with the resolved label -> colour map after the chart assigns colours
onChartDataProcessed(context: ChartContext) => voidCalled with the renderer-agnostic ChartContext whenever the data is (re)processed
onDataWarning(warnings: DataWarning[]) => voidCalled with any non-fatal data warnings (duplicate labels, non-finite values, gaps, ...)

Events

The web component dispatches these bubbling CustomEvents (the engine exposes the same via the on* callbacks in the table above):

EventDetailFires when
michi-vz:highlightstring[]hover highlight changes
michi-vz:colormappingRecord<string, string>a color mapping is generated
michi-vz:dataprocessedChartContextdata is (re)processed
michi-vz:datawarningDataWarning[]input warnings are detected

getContext()

mountBubbleChart(el, props).getContext() returns a renderer-agnostic BubbleChartContext: the flat bubbles (value / partial / remainder / percent), splitLabels, summary stats (bubble count, total, totals per part, largest bubble, largest remainder), a deterministic natural-language summary, and an a11y table. See LLM context.

Source

Props are typed as BubbleChartProps in @michi-vz/core.

Free and open source. MIT licensed.