1.2.0 • Published 8 months ago
graphvizsvg v1.2.0
graphvizsvg
A modern ESM module for interactive SVG visualization of Graphviz graphs. This is a modernized rewrite of jquery.graphviz.svg.
https://github.com/user-attachments/assets/7371d1e6-a195-4e73-8670-3e5f8965ae53
Features
- 🎯 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
Installation
npm install graphvizsvg
Usage
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);
});
API
Constructor Options
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
Methods
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
Dependencies
- jQuery 3.7+
- Bootstrap 4.6+ (for tooltips)
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
MIT
Credits
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.