0.1.2 • Published 4 years ago
mxgraphdata v0.1.2
mxGraph Draw.IO File Parser and JSON Data Model
Parses Draw.io or diagrams.net file that may be compressed into pure JSON.
Also provides simple Typescript interfaces and an indexing data model for searching the graph model.
Draw.io essentially encapsulates a 2D canvas API for drawing stencils and graphs, so graphics commands and command serialization is a significant part of the Draw.io XML serialization.
Order is important for graphics commands therefore it is import that the JSON translation maintains the XML element order.
You must include Pako
/**
* Externals:
* You must add these to your application.
*/
global.pako = require("pako");
var mxd = require( "../dist/mxgraphd");
var fs = require("fs");
var fname = "./data/cisco1.drawio";
var drawfile = fs.readFileSync(fname, {encoding:"utf-8", flag : "r" });
mxd.parseDrawIO(drawfile).then( (mxfile) => {
console.log("MXFile name:", fname );
console.log("MXFile version:", mxfile._version );
console.log("Diagram name:", mxfile.diagram._name );
});
Usage:
node ./examples/parse_compressed.js
MXFile name: ./data/cisco1.drawio
MXFile version: 13.6.0
Diagram name: Page-1