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 graphvizsvgSee 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 string
- url: URL to load SVG from
- shrink: Node shrinking amount (string or object with x/y values)
- tooltips: Tooltip configuration object
- ready: Callback function when graph is ready
- nodes(): Get all nodes
- edges(): Get all edges
- highlight($elements, tooltips): Highlight elements
- linkedTo(node, includeEdges): Get nodes linked to
- linkedFrom(node, includeEdges): Get nodes linked from
- linked(node, includeEdges): Get all linked nodes
- tooltip($elements, show): Show/hide tooltips
- bringToFront($elements): Bring elements to front
- sendToBack($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.