A modern ESM module for interactive SVG visualization of Graphviz graphs. This is a modernized rewrite of jquery.graphviz.svg.
graphvizsvg.mp4
- π― Interactive SVG visualization of Graphviz graphs
- π Node and edge highlighting with automatic color transitions
- π·οΈ Tooltips for nodes and edges
- π¨ Automatic color handling and transitions
- π Node scaling options
- π Bi-directional graph traversal
- πͺ Strong TypeScript support
- π¦ Modern ESM packaging
- β Comprehensive test coverage
npm install graphvizsvg
See demo.html for a complete example.
Run python -m http.server
in the project root and open http://localhost:8000/demo.html
in your browser.
Or see the example below:
import GraphvizSvg from 'graphvizsvg';
// Initialize with SVG content
const container = document.getElementById('graph');
const graphviz = new GraphvizSvg(container, {
svg: svgContent,
shrink: '0.125pt',
tooltips: {
init($graph) {
// Your tooltip initialization
},
show() {
// Show tooltip
},
hide() {
// Hide tooltip
},
},
ready() {
// Called when the graph is ready
}
});
// Interact with nodes
graphviz.nodes().click(function() {
const $set = $();
$set.push(this);
$set = $set.add(graphviz.linkedFrom(this, true));
$set = $set.add(graphviz.linkedTo(this, true));
graphviz.highlight($set, true);
});
svg
: SVG content stringurl
: URL to load SVG fromshrink
: Node shrinking amount (string or object with x/y values)tooltips
: Tooltip configuration objectready
: Callback function when graph is ready
nodes()
: Get all nodesedges()
: Get all edgeshighlight($elements, tooltips)
: Highlight elementslinkedTo(node, includeEdges)
: Get nodes linked tolinkedFrom(node, includeEdges)
: Get nodes linked fromlinked(node, includeEdges)
: Get all linked nodestooltip($elements, show)
: Show/hide tooltipsbringToFront($elements)
: Bring elements to frontsendToBack($elements)
: Send elements to back
- jQuery 3.7+
- Bootstrap 4.6+ (for tooltips)
Contributions are welcome! Please feel free to submit a Pull Request.
MIT
Based on the original work by mountainstorm. This project should have feature parity with the original except for the zooming feature, which has been removed. Modernized and maintained by the pipefunc team.