mermaid/src/mermaid.js
2014-11-09 18:08:05 +01:00

154 lines
4.7 KiB
JavaScript

/**
* Created by knut on 14-11-06.
*/
// Now we're ready to require JointJS and write our application code.
define(['parser/graph','parser/mermaid'],function(graph,parser){
var addVertices = function(vert,g){
var keys = Object.keys(vert);
keys.forEach(function(id){
var vertice = vert[id];
var verticeText;
//console.log(vertice);
if(vertice.text === undefined){
verticeText = vertice.id;
}
else{
verticeText = vertice.text;
}
console.log('g.setNode("'+vertice.id+'", { label: "'+verticeText+'" });');
if(vertice.type==='round'){
g.setNode(vertice.id, { label: verticeText,rx:5,ry:5 });
}else{
if(vertice.type==='diamond'){
g.setNode(vertice.id, {shape: "house", label: verticeText,rx:0,ry:0 });
}else{
g.setNode(vertice.id, { label: verticeText,rx:0,ry:0 });
}
}
});
};
var addEdges = function(edges,g){
edges.forEach(function(edge){
var edgeText;
//console.log(vertice);
if(edge.text === undefined){
g.setEdge(edge.start,edge.end);
}
else{
g.setEdge(edge.start,edge.end,{ label: edge.text });
}
console.log('g.setEdge("'+edge.start+'","'+edge.end+'")');
});
};
var drawChart = function(text,id){
console.log('drawing char with id:'+id);
console.log(text);
graph.clear();
parser.yy = graph;
var err = function(){
console.log('Syntax error!!!');
};
parser.parse(text);
var vert = graph.getVertices();
var edges = graph.getEdges();
var keys = Object.keys(vert);
// Create the input graph
var g = new dagreD3.graphlib.Graph()
.setGraph({
//rankdir: "LR",
marginx: 20,
marginy: 20
})
.setDefaultEdgeLabel(function() { return {}; });
console.log(g);
addVertices(vert,g);
addEdges(edges,g);
/*g.nodes().forEach(function(v) {
var node = g.node(v);
// Round the corners of the nodes
node.rx = node.ry = 5;
});
*/
// Create the renderer
var render = new dagreD3.render();
// Add our custom shape (a house)
render.shapes().house = function(parent, bbox, node) {
var w = bbox.width,
h = bbox.height*3,
points = [
{ x: w/2, y: 0 },
{ x: w, y: -h/2 },
{ x: w/2, y: -h },
{ x: 0, y: -h /2 }
];
shapeSvg = parent.insert("polygon", ":first-child")
.attr("points", points.map(function(d) { return d.x + "," + d.y; }).join(" "))
.style("fill", "#fff")
.style("stroke", "#333")
.attr("transform", "translate(" + (-w/2) + "," + (h * 2/4) + ")");
node.intersect = function(point) {
return dagreD3.intersect.polygon(node, points, point);
};
return shapeSvg;
};
// Set up an SVG group so that we can translate the final graph.
var svg = d3.select("#"+id);
svgGroup = d3.select("#"+id+" g");
// Run the renderer. This is what draws the final graph.
render(d3.select("#"+id+" g"), g);
// Center the graph
var xCenterOffset = (svg.attr("width") - g.graph().width) / 2;
//svgGroup.attr("transform", "translate(" + xCenterOffset + ", 20)");
svg.attr("height", g.graph().height + 40);
};
var mermaid = {
init:function(){
console.log('Init');
var arr = document.querySelectorAll('.mermaid');
console.log(typeof arr);
var cnt = 0;
for(i=0;i<arr.length;i++){
var element = arr[i];
var id;
//if(element.id.length === 0){
id='mermaidChart'+cnt;
//arr[i].id = id;
cnt++;
//}
//else{
// id=element.id;
//}
var chartText = element.textContent.trim();
console.log(element);
element.innerHTML = '<svg id="' + id + '" width="100%">'+
'<g />'+
'</svg>';
drawChart(chartText,id);
};
}
};
return mermaid;
});