@visx/annotation v3.12.0
@visx/annotation
SVG Annotations enable you to label points, thresholds, or regions of a visualization to provide
additional context to for your chart consumer. This package is heavily inspired by
Susie Lu's
react-annotation library.
Each annotation consists of three (optional) parts:
Subject(CircleSubject,LineSubject, more ๐) โ what part of a chart is being annotated (point, line, region)Labelโย the text component for the annotation. Handles SVG text wrapping using@visx/text, and supportstitleandsubtitlecustomization as well as vertical & horizontal anchors / alignmentConnectorโ line connecting a subject and label
The Annotation or EditableAnnotation component wrappers allow you to compose these components
and simplify their individual positioning:
<EditableAnnotation
x={subjectX}
y={subjectY}
dx={labelDx} // x offset of label from subject
dy={labelDy} // y offset of label from subject
onDragEnd={({ x, y, dx, dy }) => ...}
>
<Connector />
<CircleSubject />
<Label title="Context about this point" subtitle="More deets">
</EditableAnnotation>Components can also be used in isolation, in which case you must specify exact positions for each item:
() => (
<g>
<Connector x={subjectX} y={subjectY} dx={labelDx} dy={labelDy} />
<CircleSubject x={subjectX} y={subjectY} />
<Label x={subjectX + labelDx} y={subjectY + labelDy} title="...">
</g>
)โ ๏ธ ResizeObserver dependency
The Label component relies on ResizeObservers for auto-sizing. If you need a polyfill, you can
either polute the window object or inject it cleanly through props:
import { ResizeObserver } from 'your-favorite-polyfill';
function App() {
return <Label resizeObserverPolyfill={ResizeObserver} {...} />Installation
npm install --save @visx/annotation11 months ago
11 months ago
12 months ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago