A port of Graphviz to WASM.
Note: this is currently just a light wrapper around @hpcc-js/wasm
, you might want to consider just using that directly. The plan is to eventually generate custom bindings to graphviz, optimized for speed and size, and depending on your use case you'd import the right one.
npm install --save graphviz-wasm
This is how you'd use the library:
import graphviz from 'graphviz-wasm';
await graphviz.loadWASM (); // First of all you need to load the WASM instance and wait for it
const dot = `
strict graph {
a -- b
a -- b
b -- a [color=blue]
}
`;
const svg = graphviz.layout ( dot );
This is the interface of the layout
method:
type Engine = 'circo' | 'dot' | 'fdp' | 'neato' | 'osage' | 'patchwork' | 'sfdp' | 'twopi';
type Format = 'dot_json' | 'dot' | 'json' | 'plain-ext' | 'plain' | 'svg' | 'xdot_json';
type layout = ( source: string, format: Format = 'svg', engine: Engine = 'dot' ) => string;
- Graphviz: EPL © Graphviz.
- WASM Port: Apache © hpcc-js-wasm.
- Rest: MIT © Fabio Spampinato.