diff --git a/bower.json b/bower.json index bb34af84..82d2cd6e 100644 --- a/bower.json +++ b/bower.json @@ -1,6 +1,6 @@ { "name": "dagre-d3", - "version": "0.4.8", + "version": "0.4.9", "main": [ "dist/dagre-d3.core.js" ], diff --git a/dist/dagre-d3.core.js b/dist/dagre-d3.core.js index b160bc72..751f6880 100644 --- a/dist/dagre-d3.core.js +++ b/dist/dagre-d3.core.js @@ -120,9 +120,9 @@ function createClusters(selection, g) { svgClusters.each(function(v) { var node = g.node(v), - thisGroup = d3.select(this), - labelGroup = thisGroup.append("g").attr("class", "label"); + thisGroup = d3.select(this); d3.select(this).append("rect"); + var labelGroup = thisGroup.append("g").attr("class", "label"); addLabel(labelGroup, node, node.clusterLabelPos); }); @@ -688,6 +688,7 @@ function addLabel(root, node, location) { } var labelBBox = labelSvg.node().getBBox(); + var y; switch(location) { case "top": y = (-node.height / 2); @@ -1175,8 +1176,8 @@ function applyTransition(selection, g) { } },{"./lodash":21}],28:[function(require,module,exports){ -module.exports = "0.4.8"; +module.exports = "0.4.9"; },{}]},{},[1])(1) }); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","index.js","lib/arrows.js","lib/create-clusters.js","lib/create-edge-labels.js","lib/create-edge-paths.js","lib/create-nodes.js","lib/d3.js","lib/dagre.js","lib/graphlib.js","lib/intersect/index.js","lib/intersect/intersect-circle.js","lib/intersect/intersect-ellipse.js","lib/intersect/intersect-line.js","lib/intersect/intersect-node.js","lib/intersect/intersect-polygon.js","lib/intersect/intersect-rect.js","lib/label/add-html-label.js","lib/label/add-label.js","lib/label/add-svg-label.js","lib/label/add-text-label.js","lib/lodash.js","lib/position-clusters.js","lib/position-edge-labels.js","lib/position-nodes.js","lib/render.js","lib/shapes.js","lib/util.js","lib/version.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtEA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtDA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/**\n * @license\n * Copyright (c) 2012-2013 Chris Pettitt\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nmodule.exports =  {\n  graphlib: require(\"./lib/graphlib\"),\n  dagre: require(\"./lib/dagre\"),\n  intersect: require(\"./lib/intersect\"),\n  render: require(\"./lib/render\"),\n  util: require(\"./lib/util\"),\n  version: require(\"./lib/version\")\n};\n","var util = require(\"./util\");\n\nmodule.exports = {\n  \"default\": normal,\n  \"normal\": normal,\n  \"vee\": vee,\n  \"undirected\": undirected\n};\n\nfunction normal(parent, id, edge, type) {\n  var marker = parent.append(\"marker\")\n    .attr(\"id\", id)\n    .attr(\"viewBox\", \"0 0 10 10\")\n    .attr(\"refX\", 9)\n    .attr(\"refY\", 5)\n    .attr(\"markerUnits\", \"strokeWidth\")\n    .attr(\"markerWidth\", 8)\n    .attr(\"markerHeight\", 6)\n    .attr(\"orient\", \"auto\");\n\n  var path = marker.append(\"path\")\n    .attr(\"d\", \"M 0 0 L 10 5 L 0 10 z\")\n    .style(\"stroke-width\", 1)\n    .style(\"stroke-dasharray\", \"1,0\");\n  util.applyStyle(path, edge[type + \"Style\"]);\n}\n\nfunction vee(parent, id, edge, type) {\n  var marker = parent.append(\"marker\")\n    .attr(\"id\", id)\n    .attr(\"viewBox\", \"0 0 10 10\")\n    .attr(\"refX\", 9)\n    .attr(\"refY\", 5)\n    .attr(\"markerUnits\", \"strokeWidth\")\n    .attr(\"markerWidth\", 8)\n    .attr(\"markerHeight\", 6)\n    .attr(\"orient\", \"auto\");\n\n  var path = marker.append(\"path\")\n    .attr(\"d\", \"M 0 0 L 10 5 L 0 10 L 4 5 z\")\n    .style(\"stroke-width\", 1)\n    .style(\"stroke-dasharray\", \"1,0\");\n  util.applyStyle(path, edge[type + \"Style\"]);\n}\n\nfunction undirected(parent, id, edge, type) {\n  var marker = parent.append(\"marker\")\n    .attr(\"id\", id)\n    .attr(\"viewBox\", \"0 0 10 10\")\n    .attr(\"refX\", 9)\n    .attr(\"refY\", 5)\n    .attr(\"markerUnits\", \"strokeWidth\")\n    .attr(\"markerWidth\", 8)\n    .attr(\"markerHeight\", 6)\n    .attr(\"orient\", \"auto\");\n\n  var path = marker.append(\"path\")\n    .attr(\"d\", \"M 0 5 L 10 5\")\n    .style(\"stroke-width\", 1)\n    .style(\"stroke-dasharray\", \"1,0\");\n  util.applyStyle(path, edge[type + \"Style\"]);\n}\n","var util = require(\"./util\"),\n    addLabel = require(\"./label/add-label\");\n\nmodule.exports = createClusters;\n\nfunction createClusters(selection, g) {\n  var clusters = g.nodes().filter(function(v) { return util.isSubgraph(g, v); }),\n      svgClusters = selection.selectAll(\"g.cluster\")\n        .data(clusters, function(v) { return v; });\n\n  svgClusters.selectAll(\"*\").remove();\n  svgClusters.enter()\n    .append(\"g\")\n      .attr(\"class\", \"cluster\")\n      .attr(\"id\",function(v){\n          var node = g.node(v);\n          return node.id;\n      })\n      .style(\"opacity\", 0);\n\n  util.applyTransition(svgClusters, g)\n    .style(\"opacity\", 1);\n\n  svgClusters.each(function(v) {\n    var node = g.node(v),\n        thisGroup = d3.select(this),\n        labelGroup = thisGroup.append(\"g\").attr(\"class\", \"label\");\n    d3.select(this).append(\"rect\");\n    addLabel(labelGroup, node, node.clusterLabelPos);\n  });\n\n  svgClusters.selectAll(\"rect\").each(function(c) {\n    var node = g.node(c);\n    var domCluster = d3.select(this);\n    util.applyStyle(domCluster, node.style);\n  });\n\n  util.applyTransition(svgClusters.exit(), g)\n    .style(\"opacity\", 0)\n    .remove();\n\n  return svgClusters;\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\"),\n    addLabel = require(\"./label/add-label\"),\n    util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = createEdgeLabels;\n\nfunction createEdgeLabels(selection, g) {\n  var svgEdgeLabels = selection.selectAll(\"g.edgeLabel\")\n    .data(g.edges(), function(e) { return util.edgeToId(e); })\n    .classed(\"update\", true);\n\n  svgEdgeLabels.selectAll(\"*\").remove();\n  svgEdgeLabels.enter()\n    .append(\"g\")\n      .classed(\"edgeLabel\", true)\n      .style(\"opacity\", 0);\n  svgEdgeLabels.each(function(e) {\n    var edge = g.edge(e),\n        label = addLabel(d3.select(this), g.edge(e), 0, 0).classed(\"label\", true),\n        bbox = label.node().getBBox();\n\n    if (edge.labelId) { label.attr(\"id\", edge.labelId); }\n    if (!_.has(edge, \"width\")) { edge.width = bbox.width; }\n    if (!_.has(edge, \"height\")) { edge.height = bbox.height; }\n  });\n\n  util.applyTransition(svgEdgeLabels.exit(), g)\n    .style(\"opacity\", 0)\n    .remove();\n\n  return svgEdgeLabels;\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\"),\n    intersectNode = require(\"./intersect/intersect-node\"),\n    util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = createEdgePaths;\n\nfunction createEdgePaths(selection, g, arrows) {\n  var svgPaths = selection.selectAll(\"g.edgePath\")\n    .data(g.edges(), function(e) { return util.edgeToId(e); })\n    .classed(\"update\", true);\n\n  enter(svgPaths, g);\n  exit(svgPaths, g);\n\n  util.applyTransition(svgPaths, g)\n    .style(\"opacity\", 1);\n\n  // Save DOM element in the path group, and set ID and class\n  svgPaths.each(function(e) {\n    var domEdge = d3.select(this);\n    var edge = g.edge(e);\n    edge.elem = this;\n\n    if (edge.id) {\n      domEdge.attr(\"id\", edge.id);\n    }\n\n    util.applyClass(domEdge, edge[\"class\"],\n      (domEdge.classed(\"update\") ? \"update \" : \"\") + \"edgePath\");\n  });\n\n  svgPaths.selectAll(\"path.path\")\n    .each(function(e) {\n      var edge = g.edge(e);\n      edge.arrowheadId = _.uniqueId(\"arrowhead\");\n\n      var domEdge = d3.select(this)\n        .attr(\"marker-end\", function() {\n          return \"url(#\" + edge.arrowheadId + \")\";\n        })\n        .style(\"fill\", \"none\");\n\n      util.applyTransition(domEdge, g)\n        .attr(\"d\", function(e) { return calcPoints(g, e); });\n\n      util.applyStyle(domEdge, edge.style);\n    });\n\n  svgPaths.selectAll(\"defs *\").remove();\n  svgPaths.selectAll(\"defs\")\n    .each(function(e) {\n      var edge = g.edge(e),\n          arrowhead = arrows[edge.arrowhead];\n      arrowhead(d3.select(this), edge.arrowheadId, edge, \"arrowhead\");\n    });\n\n  return svgPaths;\n}\n\nfunction calcPoints(g, e) {\n  var edge = g.edge(e),\n      tail = g.node(e.v),\n      head = g.node(e.w),\n      points = edge.points.slice(1, edge.points.length - 1);\n  points.unshift(intersectNode(tail, points[0]));\n  points.push(intersectNode(head, points[points.length - 1]));\n\n  return createLine(edge, points);\n}\n\nfunction createLine(edge, points) {\n  var line = d3.svg.line()\n    .x(function(d) { return d.x; })\n    .y(function(d) { return d.y; });\n\n  if (_.has(edge, \"lineInterpolate\")) {\n    line.interpolate(edge.lineInterpolate);\n  }\n\n  if (_.has(edge, \"lineTension\")) {\n    line.tension(Number(edge.lineTension));\n  }\n\n  return line(points);\n}\n\nfunction getCoords(elem) {\n  var bbox = elem.getBBox(),\n      matrix = elem.getTransformToElement(elem.ownerSVGElement)\n        .translate(bbox.width / 2, bbox.height / 2);\n  return { x: matrix.e, y: matrix.f };\n}\n\nfunction enter(svgPaths, g) {\n  var svgPathsEnter = svgPaths.enter()\n    .append(\"g\")\n      .attr(\"class\", \"edgePath\")\n      .style(\"opacity\", 0);\n  svgPathsEnter.append(\"path\")\n    .attr(\"class\", \"path\")\n    .attr(\"d\", function(e) {\n      var edge = g.edge(e),\n          sourceElem = g.node(e.v).elem,\n          points = _.range(edge.points.length).map(function() { return getCoords(sourceElem); });\n      return createLine(edge, points);\n    });\n  svgPathsEnter.append(\"defs\");\n}\n\nfunction exit(svgPaths, g) {\n  var svgPathExit = svgPaths.exit();\n  util.applyTransition(svgPathExit, g)\n    .style(\"opacity\", 0)\n    .remove();\n\n  util.applyTransition(svgPathExit.select(\"path.path\"), g)\n    .attr(\"d\", function(e) {\n      var source = g.node(e.v);\n\n      if (source) {\n        var points = _.range(this.pathSegList.length).map(function() { return source; });\n        return createLine({}, points);\n      } else {\n        return d3.select(this).attr(\"d\");\n      }\n    });\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\"),\n    addLabel = require(\"./label/add-label\"),\n    util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = createNodes;\n\nfunction createNodes(selection, g, shapes) {\n  var simpleNodes = g.nodes().filter(function(v) { return !util.isSubgraph(g, v); });\n  var svgNodes = selection.selectAll(\"g.node\")\n    .data(simpleNodes, function(v) { return v; })\n    .classed(\"update\", true);\n\n  svgNodes.selectAll(\"*\").remove();\n  svgNodes.enter()\n    .append(\"g\")\n      .attr(\"class\", \"node\")\n      .style(\"opacity\", 0);\n  svgNodes.each(function(v) {\n    var node = g.node(v),\n        thisGroup = d3.select(this),\n        labelGroup = thisGroup.append(\"g\").attr(\"class\", \"label\"),\n        labelDom = addLabel(labelGroup, node),\n        shape = shapes[node.shape],\n        bbox = _.pick(labelDom.node().getBBox(), \"width\", \"height\");\n\n    node.elem = this;\n\n    if (node.id) { thisGroup.attr(\"id\", node.id); }\n    if (node.labelId) { labelGroup.attr(\"id\", node.labelId); }\n    util.applyClass(thisGroup, node[\"class\"],\n      (thisGroup.classed(\"update\") ? \"update \" : \"\") + \"node\");\n\n    if (_.has(node, \"width\")) { bbox.width = node.width; }\n    if (_.has(node, \"height\")) { bbox.height = node.height; }\n\n    bbox.width += node.paddingLeft + node.paddingRight;\n    bbox.height += node.paddingTop + node.paddingBottom;\n    labelGroup.attr(\"transform\", \"translate(\" +\n      ((node.paddingLeft - node.paddingRight) / 2) + \",\" +\n      ((node.paddingTop - node.paddingBottom) / 2) + \")\");\n\n    var shapeSvg = shape(d3.select(this), bbox, node);\n    util.applyStyle(shapeSvg, node.style);\n\n    var shapeBBox = shapeSvg.node().getBBox();\n    node.width = shapeBBox.width;\n    node.height = shapeBBox.height;\n  });\n\n  util.applyTransition(svgNodes.exit(), g)\n    .style(\"opacity\", 0)\n    .remove();\n\n  return svgNodes;\n}\n","// Stub to get D3 either via NPM or from the global object\nmodule.exports = window.d3;\n","/* global window */\n\nvar dagre;\n\nif (require) {\n  try {\n    dagre = require(\"dagre\");\n  } catch (e) {}\n}\n\nif (!dagre) {\n  dagre = window.dagre;\n}\n\nmodule.exports = dagre;\n","/* global window */\n\nvar graphlib;\n\nif (require) {\n  try {\n    graphlib = require(\"graphlib\");\n  } catch (e) {}\n}\n\nif (!graphlib) {\n  graphlib = window.graphlib;\n}\n\nmodule.exports = graphlib;\n","module.exports = {\n  node: require(\"./intersect-node\"),\n  circle: require(\"./intersect-circle\"),\n  ellipse: require(\"./intersect-ellipse\"),\n  polygon: require(\"./intersect-polygon\"),\n  rect: require(\"./intersect-rect\")\n};\n","var intersectEllipse = require(\"./intersect-ellipse\");\n\nmodule.exports = intersectCircle;\n\nfunction intersectCircle(node, rx, point) {\n  return intersectEllipse(node, rx, rx, point);\n}\n","module.exports = intersectEllipse;\n\nfunction intersectEllipse(node, rx, ry, point) {\n  // Formulae from: http://mathworld.wolfram.com/Ellipse-LineIntersection.html\n\n  var cx = node.x;\n  var cy = node.y;\n\n  var px = cx - point.x;\n  var py = cy - point.y;\n\n  var det = Math.sqrt(rx * rx * py * py + ry * ry * px * px);\n\n  var dx = Math.abs(rx * ry * px / det);\n  if (point.x < cx) {\n    dx = -dx;\n  }\n  var dy = Math.abs(rx * ry * py / det);\n  if (point.y < cy) {\n    dy = -dy;\n  }\n\n  return {x: cx + dx, y: cy + dy};\n}\n\n","module.exports = intersectLine;\n\n/*\n * Returns the point at which two lines, p and q, intersect or returns\n * undefined if they do not intersect.\n */\nfunction intersectLine(p1, p2, q1, q2) {\n  // Algorithm from J. Avro, (ed.) Graphics Gems, No 2, Morgan Kaufmann, 1994,\n  // p7 and p473.\n\n  var a1, a2, b1, b2, c1, c2;\n  var r1, r2 , r3, r4;\n  var denom, offset, num;\n  var x, y;\n\n  // Compute a1, b1, c1, where line joining points 1 and 2 is F(x,y) = a1 x +\n  // b1 y + c1 = 0.\n  a1 = p2.y - p1.y;\n  b1 = p1.x - p2.x;\n  c1 = (p2.x * p1.y) - (p1.x * p2.y);\n\n  // Compute r3 and r4.\n  r3 = ((a1 * q1.x) + (b1 * q1.y) + c1);\n  r4 = ((a1 * q2.x) + (b1 * q2.y) + c1);\n\n  // Check signs of r3 and r4. If both point 3 and point 4 lie on\n  // same side of line 1, the line segments do not intersect.\n  if ((r3 !== 0) && (r4 !== 0) && sameSign(r3, r4)) {\n    return /*DONT_INTERSECT*/;\n  }\n\n  // Compute a2, b2, c2 where line joining points 3 and 4 is G(x,y) = a2 x + b2 y + c2 = 0\n  a2 = q2.y - q1.y;\n  b2 = q1.x - q2.x;\n  c2 = (q2.x * q1.y) - (q1.x * q2.y);\n\n  // Compute r1 and r2\n  r1 = (a2 * p1.x) + (b2 * p1.yy) + c2;\n  r2 = (a2 * p2.x) + (b2 * p2.y) + c2;\n\n  // Check signs of r1 and r2. If both point 1 and point 2 lie\n  // on same side of second line segment, the line segments do\n  // not intersect.\n  if ((r1 !== 0) && (r2 !== 0) && (sameSign(r1, r2))) {\n    return /*DONT_INTERSECT*/;\n  }\n\n  // Line segments intersect: compute intersection point.\n  denom = (a1 * b2) - (a2 * b1);\n  if (denom === 0) {\n    return /*COLLINEAR*/;\n  }\n\n  offset = Math.abs(denom / 2);\n\n  // The denom/2 is to get rounding instead of truncating. It\n  // is added or subtracted to the numerator, depending upon the\n  // sign of the numerator.\n  num = (b1 * c2) - (b2 * c1);\n  x = (num < 0) ? ((num - offset) / denom) : ((num + offset) / denom);\n\n  num = (a2 * c1) - (a1 * c2);\n  y = (num < 0) ? ((num - offset) / denom) : ((num + offset) / denom);\n\n  return { x: x, y: y };\n}\n\nfunction sameSign(r1, r2) {\n  return r1 * r2 > 0;\n}\n","module.exports = intersectNode;\n\nfunction intersectNode(node, point) {\n  return node.intersect(point);\n}\n","var intersectLine = require(\"./intersect-line\");\n\nmodule.exports = intersectPolygon;\n\n/*\n * Returns the point ({x, y}) at which the point argument intersects with the\n * node argument assuming that it has the shape specified by polygon.\n */\nfunction intersectPolygon(node, polyPoints, point) {\n  var x1 = node.x;\n  var y1 = node.y;\n\n  var intersections = [];\n\n  var minX = Number.POSITIVE_INFINITY,\n      minY = Number.POSITIVE_INFINITY;\n  polyPoints.forEach(function(entry) {\n    minX = Math.min(minX, entry.x);\n    minY = Math.min(minY, entry.y);\n  });\n\n  var left = x1 - node.width / 2 - minX;\n  var top =  y1 - node.height / 2 - minY;\n\n  for (var i = 0; i < polyPoints.length; i++) {\n    var p1 = polyPoints[i];\n    var p2 = polyPoints[i < polyPoints.length - 1 ? i + 1 : 0];\n    var intersect = intersectLine(node, point,\n      {x: left + p1.x, y: top + p1.y}, {x: left + p2.x, y: top + p2.y});\n    if (intersect) {\n      intersections.push(intersect);\n    }\n  }\n\n  if (!intersections.length) {\n    console.log(\"NO INTERSECTION FOUND, RETURN NODE CENTER\", node);\n    return node;\n  }\n\n  if (intersections.length > 1) {\n    // More intersections, find the one nearest to edge end point\n    intersections.sort(function(p, q) {\n      var pdx = p.x - point.x,\n          pdy = p.y - point.y,\n          distp = Math.sqrt(pdx * pdx + pdy * pdy),\n\n          qdx = q.x - point.x,\n          qdy = q.y - point.y,\n          distq = Math.sqrt(qdx * qdx + qdy * qdy);\n\n      return (distp < distq) ? -1 : (distp === distq ? 0 : 1);\n    });\n  }\n  return intersections[0];\n}\n","module.exports = intersectRect;\n\nfunction intersectRect(node, point) {\n  var x = node.x;\n  var y = node.y;\n\n  // Rectangle intersection algorithm from:\n  // http://math.stackexchange.com/questions/108113/find-edge-between-two-boxes\n  var dx = point.x - x;\n  var dy = point.y - y;\n  var w = node.width / 2;\n  var h = node.height / 2;\n\n  var sx, sy;\n  if (Math.abs(dy) * w > Math.abs(dx) * h) {\n    // Intersection is top or bottom of rect.\n    if (dy < 0) {\n      h = -h;\n    }\n    sx = dy === 0 ? 0 : h * dx / dy;\n    sy = h;\n  } else {\n    // Intersection is left or right of rect.\n    if (dx < 0) {\n      w = -w;\n    }\n    sx = w;\n    sy = dx === 0 ? 0 : w * dy / dx;\n  }\n\n  return {x: x + sx, y: y + sy};\n}\n","var util = require(\"../util\");\n\nmodule.exports = addHtmlLabel;\n\nfunction addHtmlLabel(root, node) {\n  var fo = root\n    .append(\"foreignObject\")\n      .attr(\"width\", \"100000\");\n\n  var div = fo\n    .append(\"xhtml:div\");\n\n  var label = node.label;\n  switch(typeof label) {\n    case \"function\":\n      div.insert(label);\n      break;\n    case \"object\":\n      // Currently we assume this is a DOM object.\n      div.insert(function() { return label; });\n      break;\n    default: div.html(label);\n  }\n\n  util.applyStyle(div, node.labelStyle);\n  div.style(\"display\", \"inline-block\");\n  // Fix for firefox\n  div.style(\"white-space\", \"nowrap\");\n\n  // TODO find a better way to get dimensions for foreignObjects...\n  var w, h;\n  div\n    .each(function() {\n      w = this.clientWidth;\n      h = this.clientHeight;\n    });\n\n  fo\n    .attr(\"width\", w)\n    .attr(\"height\", h);\n\n  return fo;\n}\n","var addTextLabel = require(\"./add-text-label\"),\n    addHtmlLabel = require(\"./add-html-label\"),\n    addSVGLabel  = require(\"./add-svg-label\");\n\nmodule.exports = addLabel;\n\nfunction addLabel(root, node, location) {\n  var label = node.label;\n  var labelSvg = root.append(\"g\");\n\n  // Allow the label to be a string, a function that returns a DOM element, or\n  // a DOM element itself.\n  if (node.labelType === \"svg\") {\n    addSVGLabel(labelSvg, node);\n  } else if (typeof label !== \"string\" || node.labelType === \"html\") {\n    addHtmlLabel(labelSvg, node);\n  } else {\n    addTextLabel(labelSvg, node);\n  }\n\n  var labelBBox = labelSvg.node().getBBox();\n  switch(location) {\n    case \"top\":\n      y = (-node.height / 2);\n      break;\n    case \"bottom\":\n      y = (node.height / 2) - labelBBox.height;\n      break;\n    default:\n      y = (-labelBBox.height / 2);\n  }\n  labelSvg.attr(\"transform\",\n                \"translate(\" + (-labelBBox.width / 2) + \",\" + y + \")\");\n\n  return labelSvg;\n}\n","var util = require(\"../util\");\n\nmodule.exports = addSVGLabel;\n\nfunction addSVGLabel(root, node) {\n  var domNode = root;\n\n  domNode.node().appendChild(node.label);\n\n  util.applyStyle(domNode, node.labelStyle);\n\n  return domNode;\n}\n","var util = require(\"../util\");\n\nmodule.exports = addTextLabel;\n\n/*\n * Attaches a text label to the specified root. Handles escape sequences.\n */\nfunction addTextLabel(root, node) {\n  var domNode = root.append(\"text\");\n\n  var lines = processEscapeSequences(node.label).split(\"\\n\");\n  for (var i = 0; i < lines.length; i++) {\n    domNode\n      .append(\"tspan\")\n        .attr(\"xml:space\", \"preserve\")\n        .attr(\"dy\", \"1em\")\n        .attr(\"x\", \"1\")\n        .text(lines[i]);\n  }\n\n  util.applyStyle(domNode, node.labelStyle);\n\n  return domNode;\n}\n\nfunction processEscapeSequences(text) {\n  var newText = \"\",\n      escaped = false,\n      ch;\n  for (var i = 0; i < text.length; ++i) {\n    ch = text[i];\n    if (escaped) {\n      switch(ch) {\n        case \"n\": newText += \"\\n\"; break;\n        default: newText += ch;\n      }\n      escaped = false;\n    } else if (ch === \"\\\\\") {\n      escaped = true;\n    } else {\n      newText += ch;\n    }\n  }\n  return newText;\n}\n","/* global window */\n\nvar lodash;\n\nif (require) {\n  try {\n    lodash = require(\"lodash\");\n  } catch (e) {}\n}\n\nif (!lodash) {\n  lodash = window._;\n}\n\nmodule.exports = lodash;\n","\"use strict\";\n\nvar util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = positionClusters;\n\nfunction positionClusters(selection, g) {\n  var created = selection.filter(function() { return !d3.select(this).classed(\"update\"); });\n\n  function translate(v) {\n    var node = g.node(v);\n    return \"translate(\" + node.x + \",\" + node.y + \")\";\n  }\n\n  created.attr(\"transform\", translate);\n\n  util.applyTransition(selection, g)\n      .style(\"opacity\", 1)\n      .attr(\"transform\", translate);\n\n  util.applyTransition(created.selectAll(\"rect\"), g)\n      .attr(\"width\", function(v) { return g.node(v).width; })\n      .attr(\"height\", function(v) { return g.node(v).height; })\n      .attr(\"x\", function(v) {\n        var node = g.node(v);\n        return -node.width / 2;\n      })\n      .attr(\"y\", function(v) {\n        var node = g.node(v);\n        return -node.height / 2;\n      });\n\n}\n","\"use strict\";\n\nvar util = require(\"./util\"),\n    d3 = require(\"./d3\"),\n    _ = require(\"./lodash\");\n\nmodule.exports = positionEdgeLabels;\n\nfunction positionEdgeLabels(selection, g) {\n  var created = selection.filter(function() { return !d3.select(this).classed(\"update\"); });\n\n  function translate(e) {\n    var edge = g.edge(e);\n    return _.has(edge, \"x\") ? \"translate(\" + edge.x + \",\" + edge.y + \")\" : \"\";\n  }\n\n  created.attr(\"transform\", translate);\n\n  util.applyTransition(selection, g)\n    .style(\"opacity\", 1)\n    .attr(\"transform\", translate);\n}\n","\"use strict\";\n\nvar util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = positionNodes;\n\nfunction positionNodes(selection, g) {\n  var created = selection.filter(function() { return !d3.select(this).classed(\"update\"); });\n\n  function translate(v) {\n    var node = g.node(v);\n    return \"translate(\" + node.x + \",\" + node.y + \")\";\n  }\n\n  created.attr(\"transform\", translate);\n\n  util.applyTransition(selection, g)\n    .style(\"opacity\", 1)\n    .attr(\"transform\", translate);\n}\n","var _ = require(\"./lodash\"),\n    layout = require(\"./dagre\").layout;\n\nmodule.exports = render;\n\n// This design is based on http://bost.ocks.org/mike/chart/.\nfunction render() {\n  var createNodes = require(\"./create-nodes\"),\n      createClusters = require(\"./create-clusters\"),\n      createEdgeLabels = require(\"./create-edge-labels\"),\n      createEdgePaths = require(\"./create-edge-paths\"),\n      positionNodes = require(\"./position-nodes\"),\n      positionEdgeLabels = require(\"./position-edge-labels\"),\n      positionClusters = require(\"./position-clusters\"),\n      shapes = require(\"./shapes\"),\n      arrows = require(\"./arrows\");\n\n  var fn = function(svg, g) {\n    preProcessGraph(g);\n\n    var outputGroup = createOrSelectGroup(svg, \"output\"),\n        clustersGroup = createOrSelectGroup(outputGroup, \"clusters\"),\n        edgePathsGroup = createOrSelectGroup(outputGroup, \"edgePaths\"),\n        edgeLabels = createEdgeLabels(createOrSelectGroup(outputGroup, \"edgeLabels\"), g),\n        nodes = createNodes(createOrSelectGroup(outputGroup, \"nodes\"), g, shapes);\n\n    layout(g);\n\n    positionNodes(nodes, g);\n    positionEdgeLabels(edgeLabels, g);\n    createEdgePaths(edgePathsGroup, g, arrows);\n\n    var clusters = createClusters(clustersGroup, g);\n    positionClusters(clusters, g);\n\n    postProcessGraph(g);\n  };\n\n  fn.createNodes = function(value) {\n    if (!arguments.length) return createNodes;\n    createNodes = value;\n    return fn;\n  };\n\n  fn.createClusters = function(value) {\n    if (!arguments.length) return createClusters;\n    createClusters = value;\n    return fn;\n  };\n\n  fn.createEdgeLabels = function(value) {\n    if (!arguments.length) return createEdgeLabels;\n    createEdgeLabels = value;\n    return fn;\n  };\n\n  fn.createEdgePaths = function(value) {\n    if (!arguments.length) return createEdgePaths;\n    createEdgePaths = value;\n    return fn;\n  };\n\n  fn.shapes = function(value) {\n    if (!arguments.length) return shapes;\n    shapes = value;\n    return fn;\n  };\n\n  fn.arrows = function(value) {\n    if (!arguments.length) return arrows;\n    arrows = value;\n    return fn;\n  };\n\n  return fn;\n}\n\nvar NODE_DEFAULT_ATTRS = {\n  paddingLeft: 10,\n  paddingRight: 10,\n  paddingTop: 10,\n  paddingBottom: 10,\n  rx: 0,\n  ry: 0,\n  shape: \"rect\"\n};\n\nvar EDGE_DEFAULT_ATTRS = {\n  arrowhead: \"normal\",\n  lineInterpolate: \"linear\"\n};\n\nfunction preProcessGraph(g) {\n  g.nodes().forEach(function(v) {\n    var node = g.node(v);\n    if (!_.has(node, \"label\") && !g.children(v).length) { node.label = v; }\n\n    if (_.has(node, \"paddingX\")) {\n      _.defaults(node, {\n        paddingLeft: node.paddingX,\n        paddingRight: node.paddingX\n      });\n    }\n\n    if (_.has(node, \"paddingY\")) {\n      _.defaults(node, {\n        paddingTop: node.paddingY,\n        paddingBottom: node.paddingY\n      });\n    }\n\n    if (_.has(node, \"padding\")) {\n      _.defaults(node, {\n        paddingLeft: node.padding,\n        paddingRight: node.padding,\n        paddingTop: node.padding,\n        paddingBottom: node.padding\n      });\n    }\n\n    _.defaults(node, NODE_DEFAULT_ATTRS);\n\n    _.each([\"paddingLeft\", \"paddingRight\", \"paddingTop\", \"paddingBottom\"], function(k) {\n      node[k] = Number(node[k]);\n    });\n\n    // Save dimensions for restore during post-processing\n    if (_.has(node, \"width\")) { node._prevWidth = node.width; }\n    if (_.has(node, \"height\")) { node._prevHeight = node.height; }\n  });\n\n  g.edges().forEach(function(e) {\n    var edge = g.edge(e);\n    if (!_.has(edge, \"label\")) { edge.label = \"\"; }\n    _.defaults(edge, EDGE_DEFAULT_ATTRS);\n  });\n}\n\nfunction postProcessGraph(g) {\n  _.each(g.nodes(), function(v) {\n    var node = g.node(v);\n\n    // Restore original dimensions\n    if (_.has(node, \"_prevWidth\")) {\n      node.width = node._prevWidth;\n    } else {\n      delete node.width;\n    }\n\n    if (_.has(node, \"_prevHeight\")) {\n      node.height = node._prevHeight;\n    } else {\n      delete node.height;\n    }\n\n    delete node._prevWidth;\n    delete node._prevHeight;\n  });\n}\n\nfunction createOrSelectGroup(root, name) {\n  var selection = root.select(\"g.\" + name);\n  if (selection.empty()) {\n    selection = root.append(\"g\").attr(\"class\", name);\n  }\n  return selection;\n}\n","\"use strict\";\n\nvar intersectRect = require(\"./intersect/intersect-rect\"),\n    intersectEllipse = require(\"./intersect/intersect-ellipse\"),\n    intersectCircle = require(\"./intersect/intersect-circle\"),\n    intersectPolygon = require(\"./intersect/intersect-polygon\");\n\nmodule.exports = {\n  rect: rect,\n  ellipse: ellipse,\n  circle: circle,\n  diamond: diamond\n};\n\nfunction rect(parent, bbox, node) {\n  var shapeSvg = parent.insert(\"rect\", \":first-child\")\n        .attr(\"rx\", node.rx)\n        .attr(\"ry\", node.ry)\n        .attr(\"x\", -bbox.width / 2)\n        .attr(\"y\", -bbox.height / 2)\n        .attr(\"width\", bbox.width)\n        .attr(\"height\", bbox.height);\n\n  node.intersect = function(point) {\n    return intersectRect(node, point);\n  };\n\n  return shapeSvg;\n}\n\nfunction ellipse(parent, bbox, node) {\n  var rx = bbox.width / 2,\n      ry = bbox.height / 2,\n      shapeSvg = parent.insert(\"ellipse\", \":first-child\")\n        .attr(\"x\", -bbox.width / 2)\n        .attr(\"y\", -bbox.height / 2)\n        .attr(\"rx\", rx)\n        .attr(\"ry\", ry);\n\n  node.intersect = function(point) {\n    return intersectEllipse(node, rx, ry, point);\n  };\n\n  return shapeSvg;\n}\n\nfunction circle(parent, bbox, node) {\n  var r = Math.max(bbox.width, bbox.height) / 2,\n      shapeSvg = parent.insert(\"circle\", \":first-child\")\n        .attr(\"x\", -bbox.width / 2)\n        .attr(\"y\", -bbox.height / 2)\n        .attr(\"r\", r);\n\n  node.intersect = function(point) {\n    return intersectCircle(node, r, point);\n  };\n\n  return shapeSvg;\n}\n\n// Circumscribe an ellipse for the bounding box with a diamond shape. I derived\n// the function to calculate the diamond shape from:\n// http://mathforum.org/kb/message.jspa?messageID=3750236\nfunction diamond(parent, bbox, node) {\n  var w = (bbox.width * Math.SQRT2) / 2,\n      h = (bbox.height * Math.SQRT2) / 2,\n      points = [\n        { x:  0, y: -h },\n        { x: -w, y:  0 },\n        { x:  0, y:  h },\n        { x:  w, y:  0 }\n      ],\n      shapeSvg = parent.insert(\"polygon\", \":first-child\")\n        .attr(\"points\", points.map(function(p) { return p.x + \",\" + p.y; }).join(\" \"));\n\n  node.intersect = function(p) {\n    return intersectPolygon(node, points, p);\n  };\n\n  return shapeSvg;\n}\n","var _ = require(\"./lodash\");\n\n// Public utility functions\nmodule.exports = {\n  isSubgraph: isSubgraph,\n  edgeToId: edgeToId,\n  applyStyle: applyStyle,\n  applyClass: applyClass,\n  applyTransition: applyTransition\n};\n\n/*\n * Returns true if the specified node in the graph is a subgraph node. A\n * subgraph node is one that contains other nodes.\n */\nfunction isSubgraph(g, v) {\n  return !!g.children(v).length;\n}\n\nfunction edgeToId(e) {\n  return escapeId(e.v) + \":\" + escapeId(e.w) + \":\" + escapeId(e.name);\n}\n\nvar ID_DELIM = /:/g;\nfunction escapeId(str) {\n  return str ? String(str).replace(ID_DELIM, \"\\\\:\") : \"\";\n}\n\nfunction applyStyle(dom, styleFn) {\n  if (styleFn) {\n    dom.attr(\"style\", styleFn);\n  }\n}\n\nfunction applyClass(dom, classFn, otherClasses) {\n  if (classFn) {\n    dom\n      .attr(\"class\", classFn)\n      .attr(\"class\", otherClasses + \" \" + dom.attr(\"class\"));\n  }\n}\n\nfunction applyTransition(selection, g) {\n  var graph = g.graph();\n\n  if (_.isPlainObject(graph)) {\n    var transition = graph.transition;\n    if (_.isFunction(transition)) {\n      return transition(selection);\n    }\n  }\n\n  return selection;\n}\n","module.exports = \"0.4.8\";\n"]} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","index.js","lib/arrows.js","lib/create-clusters.js","lib/create-edge-labels.js","lib/create-edge-paths.js","lib/create-nodes.js","lib/d3.js","lib/dagre.js","lib/graphlib.js","lib/intersect/index.js","lib/intersect/intersect-circle.js","lib/intersect/intersect-ellipse.js","lib/intersect/intersect-line.js","lib/intersect/intersect-node.js","lib/intersect/intersect-polygon.js","lib/intersect/intersect-rect.js","lib/label/add-html-label.js","lib/label/add-label.js","lib/label/add-svg-label.js","lib/label/add-text-label.js","lib/lodash.js","lib/position-clusters.js","lib/position-edge-labels.js","lib/position-nodes.js","lib/render.js","lib/shapes.js","lib/util.js","lib/version.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtEA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtDA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/**\n * @license\n * Copyright (c) 2012-2013 Chris Pettitt\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nmodule.exports =  {\n  graphlib: require(\"./lib/graphlib\"),\n  dagre: require(\"./lib/dagre\"),\n  intersect: require(\"./lib/intersect\"),\n  render: require(\"./lib/render\"),\n  util: require(\"./lib/util\"),\n  version: require(\"./lib/version\")\n};\n","var util = require(\"./util\");\n\nmodule.exports = {\n  \"default\": normal,\n  \"normal\": normal,\n  \"vee\": vee,\n  \"undirected\": undirected\n};\n\nfunction normal(parent, id, edge, type) {\n  var marker = parent.append(\"marker\")\n    .attr(\"id\", id)\n    .attr(\"viewBox\", \"0 0 10 10\")\n    .attr(\"refX\", 9)\n    .attr(\"refY\", 5)\n    .attr(\"markerUnits\", \"strokeWidth\")\n    .attr(\"markerWidth\", 8)\n    .attr(\"markerHeight\", 6)\n    .attr(\"orient\", \"auto\");\n\n  var path = marker.append(\"path\")\n    .attr(\"d\", \"M 0 0 L 10 5 L 0 10 z\")\n    .style(\"stroke-width\", 1)\n    .style(\"stroke-dasharray\", \"1,0\");\n  util.applyStyle(path, edge[type + \"Style\"]);\n}\n\nfunction vee(parent, id, edge, type) {\n  var marker = parent.append(\"marker\")\n    .attr(\"id\", id)\n    .attr(\"viewBox\", \"0 0 10 10\")\n    .attr(\"refX\", 9)\n    .attr(\"refY\", 5)\n    .attr(\"markerUnits\", \"strokeWidth\")\n    .attr(\"markerWidth\", 8)\n    .attr(\"markerHeight\", 6)\n    .attr(\"orient\", \"auto\");\n\n  var path = marker.append(\"path\")\n    .attr(\"d\", \"M 0 0 L 10 5 L 0 10 L 4 5 z\")\n    .style(\"stroke-width\", 1)\n    .style(\"stroke-dasharray\", \"1,0\");\n  util.applyStyle(path, edge[type + \"Style\"]);\n}\n\nfunction undirected(parent, id, edge, type) {\n  var marker = parent.append(\"marker\")\n    .attr(\"id\", id)\n    .attr(\"viewBox\", \"0 0 10 10\")\n    .attr(\"refX\", 9)\n    .attr(\"refY\", 5)\n    .attr(\"markerUnits\", \"strokeWidth\")\n    .attr(\"markerWidth\", 8)\n    .attr(\"markerHeight\", 6)\n    .attr(\"orient\", \"auto\");\n\n  var path = marker.append(\"path\")\n    .attr(\"d\", \"M 0 5 L 10 5\")\n    .style(\"stroke-width\", 1)\n    .style(\"stroke-dasharray\", \"1,0\");\n  util.applyStyle(path, edge[type + \"Style\"]);\n}\n","var util = require(\"./util\"),\n    addLabel = require(\"./label/add-label\");\n\nmodule.exports = createClusters;\n\nfunction createClusters(selection, g) {\n  var clusters = g.nodes().filter(function(v) { return util.isSubgraph(g, v); }),\n      svgClusters = selection.selectAll(\"g.cluster\")\n        .data(clusters, function(v) { return v; });\n\n  svgClusters.selectAll(\"*\").remove();\n  svgClusters.enter()\n    .append(\"g\")\n      .attr(\"class\", \"cluster\")\n      .attr(\"id\",function(v){\n          var node = g.node(v);\n          return node.id;\n      })\n      .style(\"opacity\", 0);\n\n  util.applyTransition(svgClusters, g)\n    .style(\"opacity\", 1);\n\n  svgClusters.each(function(v) {\n    var node = g.node(v),\n        thisGroup = d3.select(this);\n    d3.select(this).append(\"rect\");\n    var labelGroup = thisGroup.append(\"g\").attr(\"class\", \"label\");\n    addLabel(labelGroup, node, node.clusterLabelPos);\n  });\n\n  svgClusters.selectAll(\"rect\").each(function(c) {\n    var node = g.node(c);\n    var domCluster = d3.select(this);\n    util.applyStyle(domCluster, node.style);\n  });\n\n  util.applyTransition(svgClusters.exit(), g)\n    .style(\"opacity\", 0)\n    .remove();\n\n  return svgClusters;\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\"),\n    addLabel = require(\"./label/add-label\"),\n    util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = createEdgeLabels;\n\nfunction createEdgeLabels(selection, g) {\n  var svgEdgeLabels = selection.selectAll(\"g.edgeLabel\")\n    .data(g.edges(), function(e) { return util.edgeToId(e); })\n    .classed(\"update\", true);\n\n  svgEdgeLabels.selectAll(\"*\").remove();\n  svgEdgeLabels.enter()\n    .append(\"g\")\n      .classed(\"edgeLabel\", true)\n      .style(\"opacity\", 0);\n  svgEdgeLabels.each(function(e) {\n    var edge = g.edge(e),\n        label = addLabel(d3.select(this), g.edge(e), 0, 0).classed(\"label\", true),\n        bbox = label.node().getBBox();\n\n    if (edge.labelId) { label.attr(\"id\", edge.labelId); }\n    if (!_.has(edge, \"width\")) { edge.width = bbox.width; }\n    if (!_.has(edge, \"height\")) { edge.height = bbox.height; }\n  });\n\n  util.applyTransition(svgEdgeLabels.exit(), g)\n    .style(\"opacity\", 0)\n    .remove();\n\n  return svgEdgeLabels;\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\"),\n    intersectNode = require(\"./intersect/intersect-node\"),\n    util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = createEdgePaths;\n\nfunction createEdgePaths(selection, g, arrows) {\n  var svgPaths = selection.selectAll(\"g.edgePath\")\n    .data(g.edges(), function(e) { return util.edgeToId(e); })\n    .classed(\"update\", true);\n\n  enter(svgPaths, g);\n  exit(svgPaths, g);\n\n  util.applyTransition(svgPaths, g)\n    .style(\"opacity\", 1);\n\n  // Save DOM element in the path group, and set ID and class\n  svgPaths.each(function(e) {\n    var domEdge = d3.select(this);\n    var edge = g.edge(e);\n    edge.elem = this;\n\n    if (edge.id) {\n      domEdge.attr(\"id\", edge.id);\n    }\n\n    util.applyClass(domEdge, edge[\"class\"],\n      (domEdge.classed(\"update\") ? \"update \" : \"\") + \"edgePath\");\n  });\n\n  svgPaths.selectAll(\"path.path\")\n    .each(function(e) {\n      var edge = g.edge(e);\n      edge.arrowheadId = _.uniqueId(\"arrowhead\");\n\n      var domEdge = d3.select(this)\n        .attr(\"marker-end\", function() {\n          return \"url(#\" + edge.arrowheadId + \")\";\n        })\n        .style(\"fill\", \"none\");\n\n      util.applyTransition(domEdge, g)\n        .attr(\"d\", function(e) { return calcPoints(g, e); });\n\n      util.applyStyle(domEdge, edge.style);\n    });\n\n  svgPaths.selectAll(\"defs *\").remove();\n  svgPaths.selectAll(\"defs\")\n    .each(function(e) {\n      var edge = g.edge(e),\n          arrowhead = arrows[edge.arrowhead];\n      arrowhead(d3.select(this), edge.arrowheadId, edge, \"arrowhead\");\n    });\n\n  return svgPaths;\n}\n\nfunction calcPoints(g, e) {\n  var edge = g.edge(e),\n      tail = g.node(e.v),\n      head = g.node(e.w),\n      points = edge.points.slice(1, edge.points.length - 1);\n  points.unshift(intersectNode(tail, points[0]));\n  points.push(intersectNode(head, points[points.length - 1]));\n\n  return createLine(edge, points);\n}\n\nfunction createLine(edge, points) {\n  var line = d3.svg.line()\n    .x(function(d) { return d.x; })\n    .y(function(d) { return d.y; });\n\n  if (_.has(edge, \"lineInterpolate\")) {\n    line.interpolate(edge.lineInterpolate);\n  }\n\n  if (_.has(edge, \"lineTension\")) {\n    line.tension(Number(edge.lineTension));\n  }\n\n  return line(points);\n}\n\nfunction getCoords(elem) {\n  var bbox = elem.getBBox(),\n      matrix = elem.getTransformToElement(elem.ownerSVGElement)\n        .translate(bbox.width / 2, bbox.height / 2);\n  return { x: matrix.e, y: matrix.f };\n}\n\nfunction enter(svgPaths, g) {\n  var svgPathsEnter = svgPaths.enter()\n    .append(\"g\")\n      .attr(\"class\", \"edgePath\")\n      .style(\"opacity\", 0);\n  svgPathsEnter.append(\"path\")\n    .attr(\"class\", \"path\")\n    .attr(\"d\", function(e) {\n      var edge = g.edge(e),\n          sourceElem = g.node(e.v).elem,\n          points = _.range(edge.points.length).map(function() { return getCoords(sourceElem); });\n      return createLine(edge, points);\n    });\n  svgPathsEnter.append(\"defs\");\n}\n\nfunction exit(svgPaths, g) {\n  var svgPathExit = svgPaths.exit();\n  util.applyTransition(svgPathExit, g)\n    .style(\"opacity\", 0)\n    .remove();\n\n  util.applyTransition(svgPathExit.select(\"path.path\"), g)\n    .attr(\"d\", function(e) {\n      var source = g.node(e.v);\n\n      if (source) {\n        var points = _.range(this.pathSegList.length).map(function() { return source; });\n        return createLine({}, points);\n      } else {\n        return d3.select(this).attr(\"d\");\n      }\n    });\n}\n","\"use strict\";\n\nvar _ = require(\"./lodash\"),\n    addLabel = require(\"./label/add-label\"),\n    util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = createNodes;\n\nfunction createNodes(selection, g, shapes) {\n  var simpleNodes = g.nodes().filter(function(v) { return !util.isSubgraph(g, v); });\n  var svgNodes = selection.selectAll(\"g.node\")\n    .data(simpleNodes, function(v) { return v; })\n    .classed(\"update\", true);\n\n  svgNodes.selectAll(\"*\").remove();\n  svgNodes.enter()\n    .append(\"g\")\n      .attr(\"class\", \"node\")\n      .style(\"opacity\", 0);\n  svgNodes.each(function(v) {\n    var node = g.node(v),\n        thisGroup = d3.select(this),\n        labelGroup = thisGroup.append(\"g\").attr(\"class\", \"label\"),\n        labelDom = addLabel(labelGroup, node),\n        shape = shapes[node.shape],\n        bbox = _.pick(labelDom.node().getBBox(), \"width\", \"height\");\n\n    node.elem = this;\n\n    if (node.id) { thisGroup.attr(\"id\", node.id); }\n    if (node.labelId) { labelGroup.attr(\"id\", node.labelId); }\n    util.applyClass(thisGroup, node[\"class\"],\n      (thisGroup.classed(\"update\") ? \"update \" : \"\") + \"node\");\n\n    if (_.has(node, \"width\")) { bbox.width = node.width; }\n    if (_.has(node, \"height\")) { bbox.height = node.height; }\n\n    bbox.width += node.paddingLeft + node.paddingRight;\n    bbox.height += node.paddingTop + node.paddingBottom;\n    labelGroup.attr(\"transform\", \"translate(\" +\n      ((node.paddingLeft - node.paddingRight) / 2) + \",\" +\n      ((node.paddingTop - node.paddingBottom) / 2) + \")\");\n\n    var shapeSvg = shape(d3.select(this), bbox, node);\n    util.applyStyle(shapeSvg, node.style);\n\n    var shapeBBox = shapeSvg.node().getBBox();\n    node.width = shapeBBox.width;\n    node.height = shapeBBox.height;\n  });\n\n  util.applyTransition(svgNodes.exit(), g)\n    .style(\"opacity\", 0)\n    .remove();\n\n  return svgNodes;\n}\n","// Stub to get D3 either via NPM or from the global object\nmodule.exports = window.d3;\n","/* global window */\n\nvar dagre;\n\nif (require) {\n  try {\n    dagre = require(\"dagre\");\n  } catch (e) {}\n}\n\nif (!dagre) {\n  dagre = window.dagre;\n}\n\nmodule.exports = dagre;\n","/* global window */\n\nvar graphlib;\n\nif (require) {\n  try {\n    graphlib = require(\"graphlib\");\n  } catch (e) {}\n}\n\nif (!graphlib) {\n  graphlib = window.graphlib;\n}\n\nmodule.exports = graphlib;\n","module.exports = {\n  node: require(\"./intersect-node\"),\n  circle: require(\"./intersect-circle\"),\n  ellipse: require(\"./intersect-ellipse\"),\n  polygon: require(\"./intersect-polygon\"),\n  rect: require(\"./intersect-rect\")\n};\n","var intersectEllipse = require(\"./intersect-ellipse\");\n\nmodule.exports = intersectCircle;\n\nfunction intersectCircle(node, rx, point) {\n  return intersectEllipse(node, rx, rx, point);\n}\n","module.exports = intersectEllipse;\n\nfunction intersectEllipse(node, rx, ry, point) {\n  // Formulae from: http://mathworld.wolfram.com/Ellipse-LineIntersection.html\n\n  var cx = node.x;\n  var cy = node.y;\n\n  var px = cx - point.x;\n  var py = cy - point.y;\n\n  var det = Math.sqrt(rx * rx * py * py + ry * ry * px * px);\n\n  var dx = Math.abs(rx * ry * px / det);\n  if (point.x < cx) {\n    dx = -dx;\n  }\n  var dy = Math.abs(rx * ry * py / det);\n  if (point.y < cy) {\n    dy = -dy;\n  }\n\n  return {x: cx + dx, y: cy + dy};\n}\n\n","module.exports = intersectLine;\n\n/*\n * Returns the point at which two lines, p and q, intersect or returns\n * undefined if they do not intersect.\n */\nfunction intersectLine(p1, p2, q1, q2) {\n  // Algorithm from J. Avro, (ed.) Graphics Gems, No 2, Morgan Kaufmann, 1994,\n  // p7 and p473.\n\n  var a1, a2, b1, b2, c1, c2;\n  var r1, r2 , r3, r4;\n  var denom, offset, num;\n  var x, y;\n\n  // Compute a1, b1, c1, where line joining points 1 and 2 is F(x,y) = a1 x +\n  // b1 y + c1 = 0.\n  a1 = p2.y - p1.y;\n  b1 = p1.x - p2.x;\n  c1 = (p2.x * p1.y) - (p1.x * p2.y);\n\n  // Compute r3 and r4.\n  r3 = ((a1 * q1.x) + (b1 * q1.y) + c1);\n  r4 = ((a1 * q2.x) + (b1 * q2.y) + c1);\n\n  // Check signs of r3 and r4. If both point 3 and point 4 lie on\n  // same side of line 1, the line segments do not intersect.\n  if ((r3 !== 0) && (r4 !== 0) && sameSign(r3, r4)) {\n    return /*DONT_INTERSECT*/;\n  }\n\n  // Compute a2, b2, c2 where line joining points 3 and 4 is G(x,y) = a2 x + b2 y + c2 = 0\n  a2 = q2.y - q1.y;\n  b2 = q1.x - q2.x;\n  c2 = (q2.x * q1.y) - (q1.x * q2.y);\n\n  // Compute r1 and r2\n  r1 = (a2 * p1.x) + (b2 * p1.yy) + c2;\n  r2 = (a2 * p2.x) + (b2 * p2.y) + c2;\n\n  // Check signs of r1 and r2. If both point 1 and point 2 lie\n  // on same side of second line segment, the line segments do\n  // not intersect.\n  if ((r1 !== 0) && (r2 !== 0) && (sameSign(r1, r2))) {\n    return /*DONT_INTERSECT*/;\n  }\n\n  // Line segments intersect: compute intersection point.\n  denom = (a1 * b2) - (a2 * b1);\n  if (denom === 0) {\n    return /*COLLINEAR*/;\n  }\n\n  offset = Math.abs(denom / 2);\n\n  // The denom/2 is to get rounding instead of truncating. It\n  // is added or subtracted to the numerator, depending upon the\n  // sign of the numerator.\n  num = (b1 * c2) - (b2 * c1);\n  x = (num < 0) ? ((num - offset) / denom) : ((num + offset) / denom);\n\n  num = (a2 * c1) - (a1 * c2);\n  y = (num < 0) ? ((num - offset) / denom) : ((num + offset) / denom);\n\n  return { x: x, y: y };\n}\n\nfunction sameSign(r1, r2) {\n  return r1 * r2 > 0;\n}\n","module.exports = intersectNode;\n\nfunction intersectNode(node, point) {\n  return node.intersect(point);\n}\n","var intersectLine = require(\"./intersect-line\");\n\nmodule.exports = intersectPolygon;\n\n/*\n * Returns the point ({x, y}) at which the point argument intersects with the\n * node argument assuming that it has the shape specified by polygon.\n */\nfunction intersectPolygon(node, polyPoints, point) {\n  var x1 = node.x;\n  var y1 = node.y;\n\n  var intersections = [];\n\n  var minX = Number.POSITIVE_INFINITY,\n      minY = Number.POSITIVE_INFINITY;\n  polyPoints.forEach(function(entry) {\n    minX = Math.min(minX, entry.x);\n    minY = Math.min(minY, entry.y);\n  });\n\n  var left = x1 - node.width / 2 - minX;\n  var top =  y1 - node.height / 2 - minY;\n\n  for (var i = 0; i < polyPoints.length; i++) {\n    var p1 = polyPoints[i];\n    var p2 = polyPoints[i < polyPoints.length - 1 ? i + 1 : 0];\n    var intersect = intersectLine(node, point,\n      {x: left + p1.x, y: top + p1.y}, {x: left + p2.x, y: top + p2.y});\n    if (intersect) {\n      intersections.push(intersect);\n    }\n  }\n\n  if (!intersections.length) {\n    console.log(\"NO INTERSECTION FOUND, RETURN NODE CENTER\", node);\n    return node;\n  }\n\n  if (intersections.length > 1) {\n    // More intersections, find the one nearest to edge end point\n    intersections.sort(function(p, q) {\n      var pdx = p.x - point.x,\n          pdy = p.y - point.y,\n          distp = Math.sqrt(pdx * pdx + pdy * pdy),\n\n          qdx = q.x - point.x,\n          qdy = q.y - point.y,\n          distq = Math.sqrt(qdx * qdx + qdy * qdy);\n\n      return (distp < distq) ? -1 : (distp === distq ? 0 : 1);\n    });\n  }\n  return intersections[0];\n}\n","module.exports = intersectRect;\n\nfunction intersectRect(node, point) {\n  var x = node.x;\n  var y = node.y;\n\n  // Rectangle intersection algorithm from:\n  // http://math.stackexchange.com/questions/108113/find-edge-between-two-boxes\n  var dx = point.x - x;\n  var dy = point.y - y;\n  var w = node.width / 2;\n  var h = node.height / 2;\n\n  var sx, sy;\n  if (Math.abs(dy) * w > Math.abs(dx) * h) {\n    // Intersection is top or bottom of rect.\n    if (dy < 0) {\n      h = -h;\n    }\n    sx = dy === 0 ? 0 : h * dx / dy;\n    sy = h;\n  } else {\n    // Intersection is left or right of rect.\n    if (dx < 0) {\n      w = -w;\n    }\n    sx = w;\n    sy = dx === 0 ? 0 : w * dy / dx;\n  }\n\n  return {x: x + sx, y: y + sy};\n}\n","var util = require(\"../util\");\n\nmodule.exports = addHtmlLabel;\n\nfunction addHtmlLabel(root, node) {\n  var fo = root\n    .append(\"foreignObject\")\n      .attr(\"width\", \"100000\");\n\n  var div = fo\n    .append(\"xhtml:div\");\n\n  var label = node.label;\n  switch(typeof label) {\n    case \"function\":\n      div.insert(label);\n      break;\n    case \"object\":\n      // Currently we assume this is a DOM object.\n      div.insert(function() { return label; });\n      break;\n    default: div.html(label);\n  }\n\n  util.applyStyle(div, node.labelStyle);\n  div.style(\"display\", \"inline-block\");\n  // Fix for firefox\n  div.style(\"white-space\", \"nowrap\");\n\n  // TODO find a better way to get dimensions for foreignObjects...\n  var w, h;\n  div\n    .each(function() {\n      w = this.clientWidth;\n      h = this.clientHeight;\n    });\n\n  fo\n    .attr(\"width\", w)\n    .attr(\"height\", h);\n\n  return fo;\n}\n","var addTextLabel = require(\"./add-text-label\"),\n    addHtmlLabel = require(\"./add-html-label\"),\n    addSVGLabel  = require(\"./add-svg-label\");\n\nmodule.exports = addLabel;\n\nfunction addLabel(root, node, location) {\n  var label = node.label;\n  var labelSvg = root.append(\"g\");\n\n  // Allow the label to be a string, a function that returns a DOM element, or\n  // a DOM element itself.\n  if (node.labelType === \"svg\") {\n    addSVGLabel(labelSvg, node);\n  } else if (typeof label !== \"string\" || node.labelType === \"html\") {\n    addHtmlLabel(labelSvg, node);\n  } else {\n    addTextLabel(labelSvg, node);\n  }\n\n  var labelBBox = labelSvg.node().getBBox();\n  var y;\n  switch(location) {\n    case \"top\":\n      y = (-node.height / 2);\n      break;\n    case \"bottom\":\n      y = (node.height / 2) - labelBBox.height;\n      break;\n    default:\n      y = (-labelBBox.height / 2);\n  }\n  labelSvg.attr(\"transform\",\n                \"translate(\" + (-labelBBox.width / 2) + \",\" + y + \")\");\n\n  return labelSvg;\n}\n","var util = require(\"../util\");\n\nmodule.exports = addSVGLabel;\n\nfunction addSVGLabel(root, node) {\n  var domNode = root;\n\n  domNode.node().appendChild(node.label);\n\n  util.applyStyle(domNode, node.labelStyle);\n\n  return domNode;\n}\n","var util = require(\"../util\");\n\nmodule.exports = addTextLabel;\n\n/*\n * Attaches a text label to the specified root. Handles escape sequences.\n */\nfunction addTextLabel(root, node) {\n  var domNode = root.append(\"text\");\n\n  var lines = processEscapeSequences(node.label).split(\"\\n\");\n  for (var i = 0; i < lines.length; i++) {\n    domNode\n      .append(\"tspan\")\n        .attr(\"xml:space\", \"preserve\")\n        .attr(\"dy\", \"1em\")\n        .attr(\"x\", \"1\")\n        .text(lines[i]);\n  }\n\n  util.applyStyle(domNode, node.labelStyle);\n\n  return domNode;\n}\n\nfunction processEscapeSequences(text) {\n  var newText = \"\",\n      escaped = false,\n      ch;\n  for (var i = 0; i < text.length; ++i) {\n    ch = text[i];\n    if (escaped) {\n      switch(ch) {\n        case \"n\": newText += \"\\n\"; break;\n        default: newText += ch;\n      }\n      escaped = false;\n    } else if (ch === \"\\\\\") {\n      escaped = true;\n    } else {\n      newText += ch;\n    }\n  }\n  return newText;\n}\n","/* global window */\n\nvar lodash;\n\nif (require) {\n  try {\n    lodash = require(\"lodash\");\n  } catch (e) {}\n}\n\nif (!lodash) {\n  lodash = window._;\n}\n\nmodule.exports = lodash;\n","\"use strict\";\n\nvar util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = positionClusters;\n\nfunction positionClusters(selection, g) {\n  var created = selection.filter(function() { return !d3.select(this).classed(\"update\"); });\n\n  function translate(v) {\n    var node = g.node(v);\n    return \"translate(\" + node.x + \",\" + node.y + \")\";\n  }\n\n  created.attr(\"transform\", translate);\n\n  util.applyTransition(selection, g)\n      .style(\"opacity\", 1)\n      .attr(\"transform\", translate);\n\n  util.applyTransition(created.selectAll(\"rect\"), g)\n      .attr(\"width\", function(v) { return g.node(v).width; })\n      .attr(\"height\", function(v) { return g.node(v).height; })\n      .attr(\"x\", function(v) {\n        var node = g.node(v);\n        return -node.width / 2;\n      })\n      .attr(\"y\", function(v) {\n        var node = g.node(v);\n        return -node.height / 2;\n      });\n\n}\n","\"use strict\";\n\nvar util = require(\"./util\"),\n    d3 = require(\"./d3\"),\n    _ = require(\"./lodash\");\n\nmodule.exports = positionEdgeLabels;\n\nfunction positionEdgeLabels(selection, g) {\n  var created = selection.filter(function() { return !d3.select(this).classed(\"update\"); });\n\n  function translate(e) {\n    var edge = g.edge(e);\n    return _.has(edge, \"x\") ? \"translate(\" + edge.x + \",\" + edge.y + \")\" : \"\";\n  }\n\n  created.attr(\"transform\", translate);\n\n  util.applyTransition(selection, g)\n    .style(\"opacity\", 1)\n    .attr(\"transform\", translate);\n}\n","\"use strict\";\n\nvar util = require(\"./util\"),\n    d3 = require(\"./d3\");\n\nmodule.exports = positionNodes;\n\nfunction positionNodes(selection, g) {\n  var created = selection.filter(function() { return !d3.select(this).classed(\"update\"); });\n\n  function translate(v) {\n    var node = g.node(v);\n    return \"translate(\" + node.x + \",\" + node.y + \")\";\n  }\n\n  created.attr(\"transform\", translate);\n\n  util.applyTransition(selection, g)\n    .style(\"opacity\", 1)\n    .attr(\"transform\", translate);\n}\n","var _ = require(\"./lodash\"),\n    layout = require(\"./dagre\").layout;\n\nmodule.exports = render;\n\n// This design is based on http://bost.ocks.org/mike/chart/.\nfunction render() {\n  var createNodes = require(\"./create-nodes\"),\n      createClusters = require(\"./create-clusters\"),\n      createEdgeLabels = require(\"./create-edge-labels\"),\n      createEdgePaths = require(\"./create-edge-paths\"),\n      positionNodes = require(\"./position-nodes\"),\n      positionEdgeLabels = require(\"./position-edge-labels\"),\n      positionClusters = require(\"./position-clusters\"),\n      shapes = require(\"./shapes\"),\n      arrows = require(\"./arrows\");\n\n  var fn = function(svg, g) {\n    preProcessGraph(g);\n\n    var outputGroup = createOrSelectGroup(svg, \"output\"),\n        clustersGroup = createOrSelectGroup(outputGroup, \"clusters\"),\n        edgePathsGroup = createOrSelectGroup(outputGroup, \"edgePaths\"),\n        edgeLabels = createEdgeLabels(createOrSelectGroup(outputGroup, \"edgeLabels\"), g),\n        nodes = createNodes(createOrSelectGroup(outputGroup, \"nodes\"), g, shapes);\n\n    layout(g);\n\n    positionNodes(nodes, g);\n    positionEdgeLabels(edgeLabels, g);\n    createEdgePaths(edgePathsGroup, g, arrows);\n\n    var clusters = createClusters(clustersGroup, g);\n    positionClusters(clusters, g);\n\n    postProcessGraph(g);\n  };\n\n  fn.createNodes = function(value) {\n    if (!arguments.length) return createNodes;\n    createNodes = value;\n    return fn;\n  };\n\n  fn.createClusters = function(value) {\n    if (!arguments.length) return createClusters;\n    createClusters = value;\n    return fn;\n  };\n\n  fn.createEdgeLabels = function(value) {\n    if (!arguments.length) return createEdgeLabels;\n    createEdgeLabels = value;\n    return fn;\n  };\n\n  fn.createEdgePaths = function(value) {\n    if (!arguments.length) return createEdgePaths;\n    createEdgePaths = value;\n    return fn;\n  };\n\n  fn.shapes = function(value) {\n    if (!arguments.length) return shapes;\n    shapes = value;\n    return fn;\n  };\n\n  fn.arrows = function(value) {\n    if (!arguments.length) return arrows;\n    arrows = value;\n    return fn;\n  };\n\n  return fn;\n}\n\nvar NODE_DEFAULT_ATTRS = {\n  paddingLeft: 10,\n  paddingRight: 10,\n  paddingTop: 10,\n  paddingBottom: 10,\n  rx: 0,\n  ry: 0,\n  shape: \"rect\"\n};\n\nvar EDGE_DEFAULT_ATTRS = {\n  arrowhead: \"normal\",\n  lineInterpolate: \"linear\"\n};\n\nfunction preProcessGraph(g) {\n  g.nodes().forEach(function(v) {\n    var node = g.node(v);\n    if (!_.has(node, \"label\") && !g.children(v).length) { node.label = v; }\n\n    if (_.has(node, \"paddingX\")) {\n      _.defaults(node, {\n        paddingLeft: node.paddingX,\n        paddingRight: node.paddingX\n      });\n    }\n\n    if (_.has(node, \"paddingY\")) {\n      _.defaults(node, {\n        paddingTop: node.paddingY,\n        paddingBottom: node.paddingY\n      });\n    }\n\n    if (_.has(node, \"padding\")) {\n      _.defaults(node, {\n        paddingLeft: node.padding,\n        paddingRight: node.padding,\n        paddingTop: node.padding,\n        paddingBottom: node.padding\n      });\n    }\n\n    _.defaults(node, NODE_DEFAULT_ATTRS);\n\n    _.each([\"paddingLeft\", \"paddingRight\", \"paddingTop\", \"paddingBottom\"], function(k) {\n      node[k] = Number(node[k]);\n    });\n\n    // Save dimensions for restore during post-processing\n    if (_.has(node, \"width\")) { node._prevWidth = node.width; }\n    if (_.has(node, \"height\")) { node._prevHeight = node.height; }\n  });\n\n  g.edges().forEach(function(e) {\n    var edge = g.edge(e);\n    if (!_.has(edge, \"label\")) { edge.label = \"\"; }\n    _.defaults(edge, EDGE_DEFAULT_ATTRS);\n  });\n}\n\nfunction postProcessGraph(g) {\n  _.each(g.nodes(), function(v) {\n    var node = g.node(v);\n\n    // Restore original dimensions\n    if (_.has(node, \"_prevWidth\")) {\n      node.width = node._prevWidth;\n    } else {\n      delete node.width;\n    }\n\n    if (_.has(node, \"_prevHeight\")) {\n      node.height = node._prevHeight;\n    } else {\n      delete node.height;\n    }\n\n    delete node._prevWidth;\n    delete node._prevHeight;\n  });\n}\n\nfunction createOrSelectGroup(root, name) {\n  var selection = root.select(\"g.\" + name);\n  if (selection.empty()) {\n    selection = root.append(\"g\").attr(\"class\", name);\n  }\n  return selection;\n}\n","\"use strict\";\n\nvar intersectRect = require(\"./intersect/intersect-rect\"),\n    intersectEllipse = require(\"./intersect/intersect-ellipse\"),\n    intersectCircle = require(\"./intersect/intersect-circle\"),\n    intersectPolygon = require(\"./intersect/intersect-polygon\");\n\nmodule.exports = {\n  rect: rect,\n  ellipse: ellipse,\n  circle: circle,\n  diamond: diamond\n};\n\nfunction rect(parent, bbox, node) {\n  var shapeSvg = parent.insert(\"rect\", \":first-child\")\n        .attr(\"rx\", node.rx)\n        .attr(\"ry\", node.ry)\n        .attr(\"x\", -bbox.width / 2)\n        .attr(\"y\", -bbox.height / 2)\n        .attr(\"width\", bbox.width)\n        .attr(\"height\", bbox.height);\n\n  node.intersect = function(point) {\n    return intersectRect(node, point);\n  };\n\n  return shapeSvg;\n}\n\nfunction ellipse(parent, bbox, node) {\n  var rx = bbox.width / 2,\n      ry = bbox.height / 2,\n      shapeSvg = parent.insert(\"ellipse\", \":first-child\")\n        .attr(\"x\", -bbox.width / 2)\n        .attr(\"y\", -bbox.height / 2)\n        .attr(\"rx\", rx)\n        .attr(\"ry\", ry);\n\n  node.intersect = function(point) {\n    return intersectEllipse(node, rx, ry, point);\n  };\n\n  return shapeSvg;\n}\n\nfunction circle(parent, bbox, node) {\n  var r = Math.max(bbox.width, bbox.height) / 2,\n      shapeSvg = parent.insert(\"circle\", \":first-child\")\n        .attr(\"x\", -bbox.width / 2)\n        .attr(\"y\", -bbox.height / 2)\n        .attr(\"r\", r);\n\n  node.intersect = function(point) {\n    return intersectCircle(node, r, point);\n  };\n\n  return shapeSvg;\n}\n\n// Circumscribe an ellipse for the bounding box with a diamond shape. I derived\n// the function to calculate the diamond shape from:\n// http://mathforum.org/kb/message.jspa?messageID=3750236\nfunction diamond(parent, bbox, node) {\n  var w = (bbox.width * Math.SQRT2) / 2,\n      h = (bbox.height * Math.SQRT2) / 2,\n      points = [\n        { x:  0, y: -h },\n        { x: -w, y:  0 },\n        { x:  0, y:  h },\n        { x:  w, y:  0 }\n      ],\n      shapeSvg = parent.insert(\"polygon\", \":first-child\")\n        .attr(\"points\", points.map(function(p) { return p.x + \",\" + p.y; }).join(\" \"));\n\n  node.intersect = function(p) {\n    return intersectPolygon(node, points, p);\n  };\n\n  return shapeSvg;\n}\n","var _ = require(\"./lodash\");\n\n// Public utility functions\nmodule.exports = {\n  isSubgraph: isSubgraph,\n  edgeToId: edgeToId,\n  applyStyle: applyStyle,\n  applyClass: applyClass,\n  applyTransition: applyTransition\n};\n\n/*\n * Returns true if the specified node in the graph is a subgraph node. A\n * subgraph node is one that contains other nodes.\n */\nfunction isSubgraph(g, v) {\n  return !!g.children(v).length;\n}\n\nfunction edgeToId(e) {\n  return escapeId(e.v) + \":\" + escapeId(e.w) + \":\" + escapeId(e.name);\n}\n\nvar ID_DELIM = /:/g;\nfunction escapeId(str) {\n  return str ? String(str).replace(ID_DELIM, \"\\\\:\") : \"\";\n}\n\nfunction applyStyle(dom, styleFn) {\n  if (styleFn) {\n    dom.attr(\"style\", styleFn);\n  }\n}\n\nfunction applyClass(dom, classFn, otherClasses) {\n  if (classFn) {\n    dom\n      .attr(\"class\", classFn)\n      .attr(\"class\", otherClasses + \" \" + dom.attr(\"class\"));\n  }\n}\n\nfunction applyTransition(selection, g) {\n  var graph = g.graph();\n\n  if (_.isPlainObject(graph)) {\n    var transition = graph.transition;\n    if (_.isFunction(transition)) {\n      return transition(selection);\n    }\n  }\n\n  return selection;\n}\n","module.exports = \"0.4.9\";\n"]} diff --git a/dist/dagre-d3.core.min.js b/dist/dagre-d3.core.min.js index 87f11f6f..03d42374 100644 --- a/dist/dagre-d3.core.min.js +++ b/dist/dagre-d3.core.min.js @@ -20,5 +20,5 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ -e.exports={graphlib:t("./lib/graphlib"),dagre:t("./lib/dagre"),intersect:t("./lib/intersect"),render:t("./lib/render"),util:t("./lib/util"),version:t("./lib/version")}},{"./lib/dagre":8,"./lib/graphlib":9,"./lib/intersect":10,"./lib/render":25,"./lib/util":27,"./lib/version":28}],2:[function(t,e,r){function n(t,e,r,n){var a=t.append("marker").attr("id",e).attr("viewBox","0 0 10 10").attr("refX",9).attr("refY",5).attr("markerUnits","strokeWidth").attr("markerWidth",8).attr("markerHeight",6).attr("orient","auto"),i=a.append("path").attr("d","M 0 0 L 10 5 L 0 10 z").style("stroke-width",1).style("stroke-dasharray","1,0");l.applyStyle(i,r[n+"Style"])}function a(t,e,r,n){var a=t.append("marker").attr("id",e).attr("viewBox","0 0 10 10").attr("refX",9).attr("refY",5).attr("markerUnits","strokeWidth").attr("markerWidth",8).attr("markerHeight",6).attr("orient","auto"),i=a.append("path").attr("d","M 0 0 L 10 5 L 0 10 L 4 5 z").style("stroke-width",1).style("stroke-dasharray","1,0");l.applyStyle(i,r[n+"Style"])}function i(t,e,r,n){var a=t.append("marker").attr("id",e).attr("viewBox","0 0 10 10").attr("refX",9).attr("refY",5).attr("markerUnits","strokeWidth").attr("markerWidth",8).attr("markerHeight",6).attr("orient","auto"),i=a.append("path").attr("d","M 0 5 L 10 5").style("stroke-width",1).style("stroke-dasharray","1,0");l.applyStyle(i,r[n+"Style"])}var l=t("./util");e.exports={"default":n,normal:n,vee:a,undirected:i}},{"./util":27}],3:[function(t,e,r){function n(t,e){var r=e.nodes().filter(function(t){return a.isSubgraph(e,t)}),n=t.selectAll("g.cluster").data(r,function(t){return t});return n.selectAll("*").remove(),n.enter().append("g").attr("class","cluster").attr("id",function(t){var r=e.node(t);return r.id}).style("opacity",0),a.applyTransition(n,e).style("opacity",1),n.each(function(t){var r=e.node(t),n=d3.select(this),a=n.append("g").attr("class","label");d3.select(this).append("rect"),i(a,r,r.clusterLabelPos)}),n.selectAll("rect").each(function(t){var r=e.node(t),n=d3.select(this);a.applyStyle(n,r.style)}),a.applyTransition(n.exit(),e).style("opacity",0).remove(),n}var a=t("./util"),i=t("./label/add-label");e.exports=n},{"./label/add-label":18,"./util":27}],4:[function(t,e,r){"use strict";function n(t,e){var r=t.selectAll("g.edgeLabel").data(e.edges(),function(t){return l.edgeToId(t)}).classed("update",!0);return r.selectAll("*").remove(),r.enter().append("g").classed("edgeLabel",!0).style("opacity",0),r.each(function(t){var r=e.edge(t),n=i(s.select(this),e.edge(t),0,0).classed("label",!0),l=n.node().getBBox();r.labelId&&n.attr("id",r.labelId),a.has(r,"width")||(r.width=l.width),a.has(r,"height")||(r.height=l.height)}),l.applyTransition(r.exit(),e).style("opacity",0).remove(),r}var a=t("./lodash"),i=t("./label/add-label"),l=t("./util"),s=t("./d3");e.exports=n},{"./d3":7,"./label/add-label":18,"./lodash":21,"./util":27}],5:[function(t,e,r){"use strict";function n(t,e,r){var n=t.selectAll("g.edgePath").data(e.edges(),function(t){return u.edgeToId(t)}).classed("update",!0);return s(n,e),o(n,e),u.applyTransition(n,e).style("opacity",1),n.each(function(t){var r=p.select(this),n=e.edge(t);n.elem=this,n.id&&r.attr("id",n.id),u.applyClass(r,n["class"],(r.classed("update")?"update ":"")+"edgePath")}),n.selectAll("path.path").each(function(t){var r=e.edge(t);r.arrowheadId=d.uniqueId("arrowhead");var n=p.select(this).attr("marker-end",function(){return"url(#"+r.arrowheadId+")"}).style("fill","none");u.applyTransition(n,e).attr("d",function(t){return a(e,t)}),u.applyStyle(n,r.style)}),n.selectAll("defs *").remove(),n.selectAll("defs").each(function(t){var n=e.edge(t),a=r[n.arrowhead];a(p.select(this),n.arrowheadId,n,"arrowhead")}),n}function a(t,e){var r=t.edge(e),n=t.node(e.v),a=t.node(e.w),l=r.points.slice(1,r.points.length-1);return l.unshift(c(n,l[0])),l.push(c(a,l[l.length-1])),i(r,l)}function i(t,e){var r=p.svg.line().x(function(t){return t.x}).y(function(t){return t.y});return d.has(t,"lineInterpolate")&&r.interpolate(t.lineInterpolate),d.has(t,"lineTension")&&r.tension(Number(t.lineTension)),r(e)}function l(t){var e=t.getBBox(),r=t.getTransformToElement(t.ownerSVGElement).translate(e.width/2,e.height/2);return{x:r.e,y:r.f}}function s(t,e){var r=t.enter().append("g").attr("class","edgePath").style("opacity",0);r.append("path").attr("class","path").attr("d",function(t){var r=e.edge(t),n=e.node(t.v).elem,a=d.range(r.points.length).map(function(){return l(n)});return i(r,a)}),r.append("defs")}function o(t,e){var r=t.exit();u.applyTransition(r,e).style("opacity",0).remove(),u.applyTransition(r.select("path.path"),e).attr("d",function(t){var r=e.node(t.v);if(r){var n=d.range(this.pathSegList.length).map(function(){return r});return i({},n)}return p.select(this).attr("d")})}var d=t("./lodash"),c=t("./intersect/intersect-node"),u=t("./util"),p=t("./d3");e.exports=n},{"./d3":7,"./intersect/intersect-node":14,"./lodash":21,"./util":27}],6:[function(t,e,r){"use strict";function n(t,e,r){var n=e.nodes().filter(function(t){return!l.isSubgraph(e,t)}),o=t.selectAll("g.node").data(n,function(t){return t}).classed("update",!0);return o.selectAll("*").remove(),o.enter().append("g").attr("class","node").style("opacity",0),o.each(function(t){var n=e.node(t),o=s.select(this),d=o.append("g").attr("class","label"),c=i(d,n),u=r[n.shape],p=a.pick(c.node().getBBox(),"width","height");n.elem=this,n.id&&o.attr("id",n.id),n.labelId&&d.attr("id",n.labelId),l.applyClass(o,n["class"],(o.classed("update")?"update ":"")+"node"),a.has(n,"width")&&(p.width=n.width),a.has(n,"height")&&(p.height=n.height),p.width+=n.paddingLeft+n.paddingRight,p.height+=n.paddingTop+n.paddingBottom,d.attr("transform","translate("+(n.paddingLeft-n.paddingRight)/2+","+(n.paddingTop-n.paddingBottom)/2+")");var h=u(s.select(this),p,n);l.applyStyle(h,n.style);var f=h.node().getBBox();n.width=f.width,n.height=f.height}),l.applyTransition(o.exit(),e).style("opacity",0).remove(),o}var a=t("./lodash"),i=t("./label/add-label"),l=t("./util"),s=t("./d3");e.exports=n},{"./d3":7,"./label/add-label":18,"./lodash":21,"./util":27}],7:[function(t,e,r){e.exports=window.d3},{}],8:[function(t,e,r){var n;if(t)try{n=t("dagre")}catch(a){}n||(n=window.dagre),e.exports=n},{dagre:void 0}],9:[function(t,e,r){var n;if(t)try{n=t("graphlib")}catch(a){}n||(n=window.graphlib),e.exports=n},{graphlib:void 0}],10:[function(t,e,r){e.exports={node:t("./intersect-node"),circle:t("./intersect-circle"),ellipse:t("./intersect-ellipse"),polygon:t("./intersect-polygon"),rect:t("./intersect-rect")}},{"./intersect-circle":11,"./intersect-ellipse":12,"./intersect-node":14,"./intersect-polygon":15,"./intersect-rect":16}],11:[function(t,e,r){function n(t,e,r){return a(t,e,e,r)}var a=t("./intersect-ellipse");e.exports=n},{"./intersect-ellipse":12}],12:[function(t,e,r){function n(t,e,r,n){var a=t.x,i=t.y,l=a-n.x,s=i-n.y,o=Math.sqrt(e*e*s*s+r*r*l*l),d=Math.abs(e*r*l/o);n.xv?(v-y)/g:(v+y)/g,v=l*d-i*c,b=0>v?(v-y)/g:(v+y)/g,{x:x,y:b})}function a(t,e){return t*e>0}e.exports=n},{}],14:[function(t,e,r){function n(t,e){return t.intersect(e)}e.exports=n},{}],15:[function(t,e,r){function n(t,e,r){var n=t.x,i=t.y,l=[],s=Number.POSITIVE_INFINITY,o=Number.POSITIVE_INFINITY;e.forEach(function(t){s=Math.min(s,t.x),o=Math.min(o,t.y)});for(var d=n-t.width/2-s,c=i-t.height/2-o,u=0;u1&&l.sort(function(t,e){var n=t.x-r.x,a=t.y-r.y,i=Math.sqrt(n*n+a*a),l=e.x-r.x,s=e.y-r.y,o=Math.sqrt(l*l+s*s);return o>i?-1:i===o?0:1}),l[0]):(console.log("NO INTERSECTION FOUND, RETURN NODE CENTER",t),t)}var a=t("./intersect-line");e.exports=n},{"./intersect-line":13}],16:[function(t,e,r){function n(t,e){var r,n,a=t.x,i=t.y,l=e.x-a,s=e.y-i,o=t.width/2,d=t.height/2;return Math.abs(s)*o>Math.abs(l)*d?(0>s&&(d=-d),r=0===s?0:d*l/s,n=d):(0>l&&(o=-o),r=o,n=0===l?0:o*s/l),{x:a+r,y:i+n}}e.exports=n},{}],17:[function(t,e,r){function n(t,e){var r=t.append("foreignObject").attr("width","100000"),n=r.append("xhtml:div"),i=e.label;switch(typeof i){case"function":n.insert(i);break;case"object":n.insert(function(){return i});break;default:n.html(i)}a.applyStyle(n,e.labelStyle),n.style("display","inline-block"),n.style("white-space","nowrap");var l,s;return n.each(function(){l=this.clientWidth,s=this.clientHeight}),r.attr("width",l).attr("height",s),r}var a=t("../util");e.exports=n},{"../util":27}],18:[function(t,e,r){function n(t,e,r){var n=e.label,s=t.append("g");"svg"===e.labelType?l(s,e):"string"!=typeof n||"html"===e.labelType?i(s,e):a(s,e);var o=s.node().getBBox();switch(r){case"top":y=-e.height/2;break;case"bottom":y=e.height/2-o.height;break;default:y=-o.height/2}return s.attr("transform","translate("+-o.width/2+","+y+")"),s}var a=t("./add-text-label"),i=t("./add-html-label"),l=t("./add-svg-label");e.exports=n},{"./add-html-label":17,"./add-svg-label":19,"./add-text-label":20}],19:[function(t,e,r){function n(t,e){var r=t;return r.node().appendChild(e.label),a.applyStyle(r,e.labelStyle),r}var a=t("../util");e.exports=n},{"../util":27}],20:[function(t,e,r){function n(t,e){for(var r=t.append("text"),n=a(e.label).split("\n"),l=0;lv?(v-y)/g:(v+y)/g,v=l*d-i*c,b=0>v?(v-y)/g:(v+y)/g,{x:x,y:b})}function a(t,e){return t*e>0}e.exports=n},{}],14:[function(t,e,r){function n(t,e){return t.intersect(e)}e.exports=n},{}],15:[function(t,e,r){function n(t,e,r){var n=t.x,i=t.y,l=[],s=Number.POSITIVE_INFINITY,o=Number.POSITIVE_INFINITY;e.forEach(function(t){s=Math.min(s,t.x),o=Math.min(o,t.y)});for(var d=n-t.width/2-s,c=i-t.height/2-o,u=0;u1&&l.sort(function(t,e){var n=t.x-r.x,a=t.y-r.y,i=Math.sqrt(n*n+a*a),l=e.x-r.x,s=e.y-r.y,o=Math.sqrt(l*l+s*s);return o>i?-1:i===o?0:1}),l[0]):(console.log("NO INTERSECTION FOUND, RETURN NODE CENTER",t),t)}var a=t("./intersect-line");e.exports=n},{"./intersect-line":13}],16:[function(t,e,r){function n(t,e){var r,n,a=t.x,i=t.y,l=e.x-a,s=e.y-i,o=t.width/2,d=t.height/2;return Math.abs(s)*o>Math.abs(l)*d?(0>s&&(d=-d),r=0===s?0:d*l/s,n=d):(0>l&&(o=-o),r=o,n=0===l?0:o*s/l),{x:a+r,y:i+n}}e.exports=n},{}],17:[function(t,e,r){function n(t,e){var r=t.append("foreignObject").attr("width","100000"),n=r.append("xhtml:div"),i=e.label;switch(typeof i){case"function":n.insert(i);break;case"object":n.insert(function(){return i});break;default:n.html(i)}a.applyStyle(n,e.labelStyle),n.style("display","inline-block"),n.style("white-space","nowrap");var l,s;return n.each(function(){l=this.clientWidth,s=this.clientHeight}),r.attr("width",l).attr("height",s),r}var a=t("../util");e.exports=n},{"../util":27}],18:[function(t,e,r){function n(t,e,r){var n=e.label,s=t.append("g");"svg"===e.labelType?l(s,e):"string"!=typeof n||"html"===e.labelType?i(s,e):a(s,e);var o,d=s.node().getBBox();switch(r){case"top":o=-e.height/2;break;case"bottom":o=e.height/2-d.height;break;default:o=-d.height/2}return s.attr("transform","translate("+-d.width/2+","+o+")"),s}var a=t("./add-text-label"),i=t("./add-html-label"),l=t("./add-svg-label");e.exports=n},{"./add-html-label":17,"./add-svg-label":19,"./add-text-label":20}],19:[function(t,e,r){function n(t,e){var r=t;return r.node().appendChild(e.label),a.applyStyle(r,e.labelStyle),r}var a=t("../util");e.exports=n},{"../util":27}],20:[function(t,e,r){function n(t,e){for(var r=t.append("text"),n=a(e.label).split("\n"),l=0;ly?(y-v)/g:(y+v)/g,y=a*f-o*l,b=0>y?(y-v)/g:(y+v)/g,{x:m,y:b})}function i(n,e){return n*e>0}e.exports=r},{}],14:[function(n,e,t){function r(n,e){return n.intersect(e)}e.exports=r},{}],15:[function(n,e,t){function r(n,e,t){var r=n.x,o=n.y,a=[],u=Number.POSITIVE_INFINITY,c=Number.POSITIVE_INFINITY;e.forEach(function(n){u=Math.min(u,n.x),c=Math.min(c,n.y)});for(var f=r-n.width/2-u,l=o-n.height/2-c,s=0;s1&&a.sort(function(n,e){var r=n.x-t.x,i=n.y-t.y,o=Math.sqrt(r*r+i*i),a=e.x-t.x,u=e.y-t.y,c=Math.sqrt(a*a+u*u);return c>o?-1:o===c?0:1}),a[0]):(console.log("NO INTERSECTION FOUND, RETURN NODE CENTER",n),n)}var i=n("./intersect-line");e.exports=r},{"./intersect-line":13}],16:[function(n,e,t){function r(n,e){var t,r,i=n.x,o=n.y,a=e.x-i,u=e.y-o,c=n.width/2,f=n.height/2;return Math.abs(u)*c>Math.abs(a)*f?(0>u&&(f=-f),t=0===u?0:f*a/u,r=f):(0>a&&(c=-c),t=c,r=0===a?0:c*u/a),{x:i+t,y:o+r}}e.exports=r},{}],17:[function(n,e,t){function r(n,e){var t=n.append("foreignObject").attr("width","100000"),r=t.append("xhtml:div"),o=e.label;switch(typeof o){case"function":r.insert(o);break;case"object":r.insert(function(){return o});break;default:r.html(o)}i.applyStyle(r,e.labelStyle),r.style("display","inline-block"),r.style("white-space","nowrap");var a,u;return r.each(function(){a=this.clientWidth,u=this.clientHeight}),t.attr("width",a).attr("height",u),t}var i=n("../util");e.exports=r},{"../util":27}],18:[function(n,e,t){function r(n,e,t){var r=e.label,u=n.append("g");"svg"===e.labelType?a(u,e):"string"!=typeof r||"html"===e.labelType?o(u,e):i(u,e);var c=u.node().getBBox();switch(t){case"top":y=-e.height/2;break;case"bottom":y=e.height/2-c.height;break;default:y=-c.height/2}return u.attr("transform","translate("+-c.width/2+","+y+")"),u}var i=n("./add-text-label"),o=n("./add-html-label"),a=n("./add-svg-label");e.exports=r},{"./add-html-label":17,"./add-svg-label":19,"./add-text-label":20}],19:[function(n,e,t){function r(n,e){var t=n;return t.node().appendChild(e.label),i.applyStyle(t,e.labelStyle),t}var i=n("../util");e.exports=r},{"../util":27}],20:[function(n,e,t){function r(n,e){for(var t=n.append("text"),r=i(e.label).split("\n"),a=0;au;++u)i(n,"borderLeft","_bl",t,a,u),i(n,"borderRight","_br",t,a,u)}}o.each(n.children(),e)}function i(n,e,t,r,i,o){var u={width:0,height:0,rank:o,borderType:e},c=i[e][o-1],f=a.addDummyNode(n,"border",u,t);i[e][o]=f,n.setParent(f,r),c&&n.setEdge(c,f,{weight:1})}var o=n("./lodash"),a=n("./util");e.exports=r},{"./lodash":38,"./util":57}],32:[function(n,e,t){"use strict";function r(n){var e=n.graph().rankdir.toLowerCase();("lr"===e||"rl"===e)&&o(n)}function i(n){var e=n.graph().rankdir.toLowerCase();("bt"===e||"rl"===e)&&u(n),("lr"===e||"rl"===e)&&(f(n),o(n))}function o(n){s.each(n.nodes(),function(e){a(n.node(e))}),s.each(n.edges(),function(e){a(n.edge(e))})}function a(n){var e=n.width;n.width=n.height,n.height=e}function u(n){s.each(n.nodes(),function(e){c(n.node(e))}),s.each(n.edges(),function(e){var t=n.edge(e);s.each(t.points,c),s.has(t,"y")&&c(t)})}function c(n){n.y=-n.y}function f(n){s.each(n.nodes(),function(e){l(n.node(e))}),s.each(n.edges(),function(e){var t=n.edge(e);s.each(t.points,l),s.has(t,"x")&&l(t)})}function l(n){var e=n.x;n.x=n.y,n.y=e}var s=n("./lodash");e.exports={adjust:r,undo:i}},{"./lodash":38}],33:[function(n,e,t){function r(){var n={};n._next=n._prev=n,this._sentinel=n}function i(n){n._prev._next=n._next,n._next._prev=n._prev,delete n._next,delete n._prev}function o(n,e){return"_next"!==n&&"_prev"!==n?e:void 0}e.exports=r,r.prototype.dequeue=function(){var n=this._sentinel,e=n._prev;return e!==n?(i(e),e):void 0},r.prototype.enqueue=function(n){var e=this._sentinel;n._prev&&n._next&&i(n),n._next=e._next,e._next._prev=n,e._next=n,n._prev=e},r.prototype.toString=function(){for(var n=[],e=this._sentinel,t=e._prev;t!==e;)n.push(JSON.stringify(t,o)),t=t._prev;return"["+n.join(", ")+"]"}},{}],34:[function(n,e,t){function r(n){var e=o.buildLayerMatrix(n),t=new a({compound:!0,multigraph:!0}).setGraph({});return i.each(n.nodes(),function(e){t.setNode(e,{label:e}),t.setParent(e,"layer"+n.node(e).rank)}),i.each(n.edges(),function(n){t.setEdge(n.v,n.w,{},n.name)}),i.each(e,function(n,e){var r="layer"+e;t.setNode(r,{rank:"same"}),i.reduce(n,function(n,e){return t.setEdge(n,e,{style:"invis"}),e})}),t}var i=n("./lodash"),o=n("./util"),a=n("./graphlib").Graph;e.exports={debugOrdering:r}},{"./graphlib":35,"./lodash":38,"./util":57}],35:[function(n,e,t){e.exports=n(9)},{"/Users/cpettitt/projects/dagre-d3/lib/graphlib.js":9,graphlib:60}],36:[function(n,e,t){function r(n,e){if(n.nodeCount()<=1)return[];var t=a(n,e||s),r=i(t.graph,t.buckets,t.zeroIdx);return c.flatten(c.map(r,function(e){return n.outEdges(e.v,e.w)}),!0)}function i(n,e,t){for(var r,i=[],a=e[e.length-1],u=e[0];n.nodeCount();){for(;r=u.dequeue();)o(n,e,t,r);for(;r=a.dequeue();)o(n,e,t,r);if(n.nodeCount())for(var c=e.length-2;c>0;--c)if(r=e[c].dequeue()){i=i.concat(o(n,e,t,r,!0));break}}return i}function o(n,e,t,r,i){var o=i?[]:void 0;return c.each(n.inEdges(r.v),function(r){var a=n.edge(r),c=n.node(r.v);i&&o.push({v:r.v,w:r.w}),c.out-=a,u(e,t,c)}),c.each(n.outEdges(r.v),function(r){var i=n.edge(r),o=r.w,a=n.node(o);a["in"]-=i,u(e,t,a)}),n.removeNode(r.v),o}function a(n,e){var t=new f,r=0,i=0;c.each(n.nodes(),function(n){t.setNode(n,{v:n,"in":0,out:0})}),c.each(n.edges(),function(n){var o=t.edge(n.v,n.w)||0,a=e(n),u=o+a;t.setEdge(n.v,n.w,u),i=Math.max(i,t.node(n.v).out+=a),r=Math.max(r,t.node(n.w)["in"]+=a)});var o=c.range(i+r+3).map(function(){return new l}),a=r+1;return c.each(t.nodes(),function(n){u(o,a,t.node(n))}),{graph:t,buckets:o,zeroIdx:a}}function u(n,e,t){t.out?t["in"]?n[t.out-t["in"]+e].enqueue(t):n[n.length-1].enqueue(t):n[0].enqueue(t)}var c=n("./lodash"),f=n("./graphlib").Graph,l=n("./data/list");e.exports=r;var s=c.constant(1)},{"./data/list":33,"./graphlib":35,"./lodash":38}],37:[function(n,e,t){"use strict";function r(n,e){var t=e&&e.debugTiming?L.time:L.notime;t("layout",function(){var e=t(" buildLayoutGraph",function(){return a(n)});t(" runLayout",function(){i(e,t)}),t(" updateInputGraph",function(){o(n,e)})})}function i(n,e){e(" makeSpaceForEdgeLabels",function(){u(n)}),e(" removeSelfEdges",function(){v(n)}),e(" acyclic",function(){x.run(n)}),e(" nestingGraph.run",function(){I.run(n)}),e(" rank",function(){j(L.asNonCompoundGraph(n))}),e(" injectEdgeLabelProxies",function(){c(n)}),e(" removeEmptyRanks",function(){N(n)}),e(" nestingGraph.cleanup",function(){I.cleanup(n)}),e(" normalizeRanks",function(){E(n)}),e(" assignRankMinMax",function(){f(n)}),e(" removeEdgeLabelProxies",function(){l(n)}),e(" normalize.run",function(){k.run(n)}),e(" parentDummyChains",function(){C(n)}),e(" addBorderSegments",function(){T(n)}),e(" order",function(){R(n)}),e(" insertSelfEdges",function(){y(n)}),e(" adjustCoordinateSystem",function(){O.adjust(n)}),e(" position",function(){S(n)}),e(" positionSelfEdges",function(){m(n)}),e(" removeBorderNodes",function(){g(n)}),e(" normalize.undo",function(){k.undo(n)}),e(" fixupEdgeLabelCoords",function(){h(n)}),e(" undoCoordinateSystem",function(){O.undo(n)}),e(" translateGraph",function(){s(n)}),e(" assignNodeIntersects",function(){p(n)}),e(" reversePoints",function(){d(n)}),e(" acyclic.undo",function(){x.undo(n)})}function o(n,e){w.each(n.nodes(),function(t){var r=n.node(t),i=e.node(t);r&&(r.x=i.x,r.y=i.y,e.children(t).length&&(r.width=i.width,r.height=i.height))}),w.each(n.edges(),function(t){var r=n.edge(t),i=e.edge(t);r.points=i.points,w.has(i,"x")&&(r.x=i.x,r.y=i.y)}),n.graph().width=e.graph().width,n.graph().height=e.graph().height}function a(n){var e=new M({multigraph:!0,compound:!0}),t=_(n.graph());return e.setGraph(w.merge({},D,b(t,B),w.pick(t,F))),w.each(n.nodes(),function(t){var r=_(n.node(t));e.setNode(t,w.defaults(b(r,A),P)),e.setParent(t,n.parent(t))}),w.each(n.edges(),function(t){var r=_(n.edge(t));e.setEdge(t,w.merge({},q,b(r,U),w.pick(r,z)))}),e}function u(n){var e=n.graph();e.ranksep/=2,w.each(n.edges(),function(t){var r=n.edge(t);r.minlen*=2,"c"!==r.labelpos.toLowerCase()&&("TB"===e.rankdir||"BT"===e.rankdir?r.width+=r.labeloffset:r.height+=r.labeloffset)})}function c(n){w.each(n.edges(),function(e){var t=n.edge(e);if(t.width&&t.height){var r=n.node(e.v),i=n.node(e.w),o={rank:(i.rank-r.rank)/2+r.rank,e:e};L.addDummyNode(n,"edge-proxy",o,"_ep")}})}function f(n){var e=0;w.each(n.nodes(),function(t){var r=n.node(t);r.borderTop&&(r.minRank=n.node(r.borderTop).rank,r.maxRank=n.node(r.borderBottom).rank,e=w.max(e,r.maxRank))}),n.graph().maxRank=e}function l(n){w.each(n.nodes(),function(e){var t=n.node(e);"edge-proxy"===t.dummy&&(n.edge(t.e).labelRank=t.rank,n.removeNode(e))})}function s(n){function e(n){var e=n.x,a=n.y,u=n.width,c=n.height;t=Math.min(t,e-u/2),r=Math.max(r,e+u/2),i=Math.min(i,a-c/2),o=Math.max(o,a+c/2)}var t=Number.POSITIVE_INFINITY,r=0,i=Number.POSITIVE_INFINITY,o=0,a=n.graph(),u=a.marginx||0,c=a.marginy||0;w.each(n.nodes(),function(t){e(n.node(t))}),w.each(n.edges(),function(t){var r=n.edge(t);w.has(r,"x")&&e(r)}),t-=u,i-=c,w.each(n.nodes(),function(e){var r=n.node(e);r.x-=t,r.y-=i}),w.each(n.edges(),function(e){var r=n.edge(e);w.each(r.points,function(n){n.x-=t,n.y-=i}),w.has(r,"x")&&(r.x-=t),w.has(r,"y")&&(r.y-=i)}),a.width=r-t+u,a.height=o-i+c}function p(n){w.each(n.edges(),function(e){var t,r,i=n.edge(e),o=n.node(e.v),a=n.node(e.w);i.points?(t=i.points[0],r=i.points[i.points.length-1]):(i.points=[],t=a,r=o),i.points.unshift(L.intersectRect(o,t)),i.points.push(L.intersectRect(a,r))})}function h(n){w.each(n.edges(),function(e){var t=n.edge(e);if(w.has(t,"x"))switch(("l"===t.labelpos||"r"===t.labelpos)&&(t.width-=t.labeloffset),t.labelpos){case"l":t.x-=t.width/2+t.labeloffset;break;case"r":t.x+=t.width/2+t.labeloffset}})}function d(n){w.each(n.edges(),function(e){var t=n.edge(e);t.reversed&&t.points.reverse()})}function g(n){w.each(n.nodes(),function(e){if(n.children(e).length){var t=n.node(e),r=n.node(t.borderTop),i=n.node(t.borderBottom),o=n.node(w.last(t.borderLeft)),a=n.node(w.last(t.borderRight));t.width=Math.abs(a.x-o.x),t.height=Math.abs(i.y-r.y),t.x=o.x+t.width/2,t.y=r.y+t.height/2}}),w.each(n.nodes(),function(e){"border"===n.node(e).dummy&&n.removeNode(e)})}function v(n){w.each(n.edges(),function(e){if(e.v===e.w){var t=n.node(e.v);t.selfEdges||(t.selfEdges=[]),t.selfEdges.push({e:e,label:n.edge(e)}),n.removeEdge(e)}})}function y(n){var e=L.buildLayerMatrix(n);w.each(e,function(e){var t=0;w.each(e,function(e,r){var i=n.node(e);i.order=r+t,w.each(i.selfEdges,function(e){L.addDummyNode(n,"selfedge",{width:e.label.width,height:e.label.height,rank:i.rank,order:r+ ++t,e:e.e,label:e.label},"_se")}),delete i.selfEdges})})}function m(n){w.each(n.nodes(),function(e){var t=n.node(e);if("selfedge"===t.dummy){var r=n.node(t.e.v),i=r.x+r.width/2,o=r.y,a=t.x-i,u=r.height/2;n.setEdge(t.e,t.label),n.removeNode(e),t.label.points=[{x:i+2*a/3,y:o-u},{x:i+5*a/6,y:o-u},{x:i+a,y:o},{x:i+5*a/6,y:o+u},{x:i+2*a/3,y:o+u}],t.label.x=t.x,t.label.y=t.y}})}function b(n,e){return w.mapValues(w.pick(n,e),Number)}function _(n){var e={};return w.each(n,function(n,t){e[t.toLowerCase()]=n}),e}var w=n("./lodash"),x=n("./acyclic"),k=n("./normalize"),j=n("./rank"),E=n("./util").normalizeRanks,C=n("./parent-dummy-chains"),N=n("./util").removeEmptyRanks,I=n("./nesting-graph"),T=n("./add-border-segments"),O=n("./coordinate-system"),R=n("./order"),S=n("./position"),L=n("./util"),M=n("./graphlib").Graph;e.exports=r;var B=["nodesep","edgesep","ranksep","marginx","marginy"],D={ranksep:50,edgesep:20,nodesep:50,rankdir:"tb"},F=["acyclicer","ranker","rankdir","align"],A=["width","height"],P={width:0,height:0},U=["minlen","weight","width","height","labeloffset"],q={minlen:1,weight:1,width:0,height:0,labeloffset:10,labelpos:"r"},z=["labelpos"]},{"./acyclic":30,"./add-border-segments":31,"./coordinate-system":32,"./graphlib":35,"./lodash":38,"./nesting-graph":39,"./normalize":40,"./order":45,"./parent-dummy-chains":50,"./position":52,"./rank":54,"./util":57}],38:[function(n,e,t){arguments[4][21][0].apply(t,arguments)},{"/Users/cpettitt/projects/dagre-d3/lib/lodash.js":21,lodash:59}],39:[function(n,e,t){function r(n){var e=f.addDummyNode(n,"root",{},"_root"),t=o(n),r=c.max(t)-1,u=2*r+1;n.graph().nestingRoot=e,c.each(n.edges(),function(e){n.edge(e).minlen*=u});var l=a(n)+1;c.each(n.children(),function(o){i(n,e,u,l,r,t,o)}),n.graph().nodeRankFactor=u}function i(n,e,t,r,o,a,u){var l=n.children(u);if(!l.length)return void(u!==e&&n.setEdge(e,u,{weight:0,minlen:t}));var s=f.addBorderNode(n,"_bt"),p=f.addBorderNode(n,"_bb"),h=n.node(u);n.setParent(s,u),h.borderTop=s,n.setParent(p,u),h.borderBottom=p,c.each(l,function(c){i(n,e,t,r,o,a,c);var f=n.node(c),l=f.borderTop?f.borderTop:c,h=f.borderBottom?f.borderBottom:c,d=f.borderTop?r:2*r,g=l!==h?1:o-a[u]+1;n.setEdge(s,l,{weight:d,minlen:g,nestingEdge:!0}),n.setEdge(h,p,{weight:d,minlen:g,nestingEdge:!0})}),n.parent(u)||n.setEdge(e,s,{weight:0,minlen:o+a[u]})}function o(n){function e(r,i){var o=n.children(r);o&&o.length&&c.each(o,function(n){e(n,i+1)}),t[r]=i}var t={};return c.each(n.children(),function(n){e(n,1)}),t}function a(n){return c.reduce(n.edges(),function(e,t){return e+n.edge(t).weight},0)}function u(n){var e=n.graph();n.removeNode(e.nestingRoot),delete e.nestingRoot,c.each(n.edges(),function(e){var t=n.edge(e);t.nestingEdge&&n.removeEdge(e)})}var c=n("./lodash"),f=n("./util");e.exports={run:r,cleanup:u}},{"./lodash":38,"./util":57}],40:[function(n,e,t){"use strict";function r(n){n.graph().dummyChains=[],a.each(n.edges(),function(e){i(n,e)})}function i(n,e){var t=e.v,r=n.node(t).rank,i=e.w,o=n.node(i).rank,a=e.name,c=n.edge(e),f=c.labelRank;if(o!==r+1){n.removeEdge(e);var l,s,p;for(p=0,++r;o>r;++p,++r)c.points=[],s={width:0,height:0,edgeLabel:c,edgeObj:e,rank:r},l=u.addDummyNode(n,"edge",s,"_d"),r===f&&(s.width=c.width,s.height=c.height,s.dummy="edge-label",s.labelpos=c.labelpos),n.setEdge(t,l,{weight:c.weight},a),0===p&&n.graph().dummyChains.push(l),t=l;n.setEdge(t,i,{weight:c.weight},a)}}function o(n){a.each(n.graph().dummyChains,function(e){var t,r=n.node(e),i=r.edgeLabel;for(n.setEdge(r.edgeObj,i);r.dummy;)t=n.successors(e)[0],n.removeNode(e),i.points.push({x:r.x,y:r.y}),"edge-label"===r.dummy&&(i.x=r.x,i.y=r.y,i.width=r.width,i.height=r.height),e=t,r=n.node(e)})}var a=n("./lodash"),u=n("./util");e.exports={run:r,undo:o}},{"./lodash":38,"./util":57}],41:[function(n,e,t){function r(n,e,t){var r,o={};i.each(t,function(t){for(var i,a,u=n.parent(t);u;){if(i=n.parent(u),i?(a=o[i],o[i]=u):(a=r,r=u),a&&a!==u)return void e.setEdge(a,u);u=i}})}var i=n("../lodash");e.exports=r},{"../lodash":38}],42:[function(n,e,t){function r(n,e){return i.map(e,function(e){var t=n.inEdges(e);if(t.length){var r=i.reduce(t,function(e,t){var r=n.edge(t),i=n.node(t.v);return{sum:e.sum+r.weight*i.order,weight:e.weight+r.weight}},{sum:0,weight:0});return{v:e,barycenter:r.sum/r.weight,weight:r.weight}}return{v:e}})}var i=n("../lodash");e.exports=r},{"../lodash":38}],43:[function(n,e,t){function r(n,e,t){var r=i(n),u=new a({compound:!0}).setGraph({root:r}).setDefaultNodeLabel(function(e){return n.node(e)});return o.each(n.nodes(),function(i){var a=n.node(i),c=n.parent(i);(a.rank===e||a.minRank<=e&&e<=a.maxRank)&&(u.setNode(i),u.setParent(i,c||r),o.each(n[t](i),function(e){var t=e.v===i?e.w:e.v,r=u.edge(t,i),a=o.isUndefined(r)?0:r.weight;u.setEdge(t,i,{weight:n.edge(e).weight+a})}),o.has(a,"minRank")&&u.setNode(i,{borderLeft:a.borderLeft[e],borderRight:a.borderRight[e]}))}),u}function i(n){for(var e;n.hasNode(e=o.uniqueId("_root")););return e}var o=n("../lodash"),a=n("../graphlib").Graph;e.exports=r},{"../graphlib":35,"../lodash":38}],44:[function(n,e,t){"use strict";function r(n,e){for(var t=0,r=1;r0;)e%2&&(t+=c[e+1]),e=e-1>>1,c[e]+=n.weight;f+=n.weight*t})),f}var o=n("../lodash");e.exports=r},{"../lodash":38}],45:[function(n,e,t){"use strict";function r(n){var e=d.maxRank(n),t=i(n,u.range(1,e+1),"inEdges"),r=i(n,u.range(e-1,-1,-1),"outEdges"),l=c(n);a(n,l);for(var s,p=Number.POSITIVE_INFINITY,h=0,g=0;4>g;++h,++g){o(h%2?t:r,h%4>=2),l=d.buildLayerMatrix(n);var v=f(n,l);p>v&&(g=0,s=u.cloneDeep(l),p=v)}a(n,s)}function i(n,e,t){return u.map(e,function(e){return s(n,e,t)})}function o(n,e){var t=new h;u.each(n,function(n){var r=n.graph().root,i=l(n,r,t,e);u.each(i.vs,function(e,t){n.node(e).order=t}),p(n,t,i.vs)})}function a(n,e){u.each(e,function(e){u.each(e,function(e,t){n.node(e).order=t})})}var u=n("../lodash"),c=n("./init-order"),f=n("./cross-count"),l=n("./sort-subgraph"),s=n("./build-layer-graph"),p=n("./add-subgraph-constraints"),h=n("../graphlib").Graph,d=n("../util");e.exports=r},{"../graphlib":35,"../lodash":38,"../util":57,"./add-subgraph-constraints":41,"./build-layer-graph":43,"./cross-count":44,"./init-order":46,"./sort-subgraph":48}],46:[function(n,e,t){"use strict";function r(n){function e(r){if(!i.has(t,r)){t[r]=!0;var o=n.node(r);a[o.rank].push(r),i.each(n.successors(r),e)}}var t={},r=i.filter(n.nodes(),function(e){return!n.children(e).length}),o=i.max(i.map(r,function(e){ +e.exports={graphlib:n("./lib/graphlib"),dagre:n("./lib/dagre"),intersect:n("./lib/intersect"),render:n("./lib/render"),util:n("./lib/util"),version:n("./lib/version")}},{"./lib/dagre":8,"./lib/graphlib":9,"./lib/intersect":10,"./lib/render":25,"./lib/util":27,"./lib/version":28}],2:[function(n,e,t){function r(n,e,t,r){var i=n.append("marker").attr("id",e).attr("viewBox","0 0 10 10").attr("refX",9).attr("refY",5).attr("markerUnits","strokeWidth").attr("markerWidth",8).attr("markerHeight",6).attr("orient","auto"),o=i.append("path").attr("d","M 0 0 L 10 5 L 0 10 z").style("stroke-width",1).style("stroke-dasharray","1,0");a.applyStyle(o,t[r+"Style"])}function i(n,e,t,r){var i=n.append("marker").attr("id",e).attr("viewBox","0 0 10 10").attr("refX",9).attr("refY",5).attr("markerUnits","strokeWidth").attr("markerWidth",8).attr("markerHeight",6).attr("orient","auto"),o=i.append("path").attr("d","M 0 0 L 10 5 L 0 10 L 4 5 z").style("stroke-width",1).style("stroke-dasharray","1,0");a.applyStyle(o,t[r+"Style"])}function o(n,e,t,r){var i=n.append("marker").attr("id",e).attr("viewBox","0 0 10 10").attr("refX",9).attr("refY",5).attr("markerUnits","strokeWidth").attr("markerWidth",8).attr("markerHeight",6).attr("orient","auto"),o=i.append("path").attr("d","M 0 5 L 10 5").style("stroke-width",1).style("stroke-dasharray","1,0");a.applyStyle(o,t[r+"Style"])}var a=n("./util");e.exports={"default":r,normal:r,vee:i,undirected:o}},{"./util":27}],3:[function(n,e,t){function r(n,e){var t=e.nodes().filter(function(n){return i.isSubgraph(e,n)}),r=n.selectAll("g.cluster").data(t,function(n){return n});return r.selectAll("*").remove(),r.enter().append("g").attr("class","cluster").attr("id",function(n){var t=e.node(n);return t.id}).style("opacity",0),i.applyTransition(r,e).style("opacity",1),r.each(function(n){var t=e.node(n),r=d3.select(this);d3.select(this).append("rect");var i=r.append("g").attr("class","label");o(i,t,t.clusterLabelPos)}),r.selectAll("rect").each(function(n){var t=e.node(n),r=d3.select(this);i.applyStyle(r,t.style)}),i.applyTransition(r.exit(),e).style("opacity",0).remove(),r}var i=n("./util"),o=n("./label/add-label");e.exports=r},{"./label/add-label":18,"./util":27}],4:[function(n,e,t){"use strict";function r(n,e){var t=n.selectAll("g.edgeLabel").data(e.edges(),function(n){return a.edgeToId(n)}).classed("update",!0);return t.selectAll("*").remove(),t.enter().append("g").classed("edgeLabel",!0).style("opacity",0),t.each(function(n){var t=e.edge(n),r=o(u.select(this),e.edge(n),0,0).classed("label",!0),a=r.node().getBBox();t.labelId&&r.attr("id",t.labelId),i.has(t,"width")||(t.width=a.width),i.has(t,"height")||(t.height=a.height)}),a.applyTransition(t.exit(),e).style("opacity",0).remove(),t}var i=n("./lodash"),o=n("./label/add-label"),a=n("./util"),u=n("./d3");e.exports=r},{"./d3":7,"./label/add-label":18,"./lodash":21,"./util":27}],5:[function(n,e,t){"use strict";function r(n,e,t){var r=n.selectAll("g.edgePath").data(e.edges(),function(n){return s.edgeToId(n)}).classed("update",!0);return u(r,e),c(r,e),s.applyTransition(r,e).style("opacity",1),r.each(function(n){var t=p.select(this),r=e.edge(n);r.elem=this,r.id&&t.attr("id",r.id),s.applyClass(t,r["class"],(t.classed("update")?"update ":"")+"edgePath")}),r.selectAll("path.path").each(function(n){var t=e.edge(n);t.arrowheadId=f.uniqueId("arrowhead");var r=p.select(this).attr("marker-end",function(){return"url(#"+t.arrowheadId+")"}).style("fill","none");s.applyTransition(r,e).attr("d",function(n){return i(e,n)}),s.applyStyle(r,t.style)}),r.selectAll("defs *").remove(),r.selectAll("defs").each(function(n){var r=e.edge(n),i=t[r.arrowhead];i(p.select(this),r.arrowheadId,r,"arrowhead")}),r}function i(n,e){var t=n.edge(e),r=n.node(e.v),i=n.node(e.w),a=t.points.slice(1,t.points.length-1);return a.unshift(l(r,a[0])),a.push(l(i,a[a.length-1])),o(t,a)}function o(n,e){var t=p.svg.line().x(function(n){return n.x}).y(function(n){return n.y});return f.has(n,"lineInterpolate")&&t.interpolate(n.lineInterpolate),f.has(n,"lineTension")&&t.tension(Number(n.lineTension)),t(e)}function a(n){var e=n.getBBox(),t=n.getTransformToElement(n.ownerSVGElement).translate(e.width/2,e.height/2);return{x:t.e,y:t.f}}function u(n,e){var t=n.enter().append("g").attr("class","edgePath").style("opacity",0);t.append("path").attr("class","path").attr("d",function(n){var t=e.edge(n),r=e.node(n.v).elem,i=f.range(t.points.length).map(function(){return a(r)});return o(t,i)}),t.append("defs")}function c(n,e){var t=n.exit();s.applyTransition(t,e).style("opacity",0).remove(),s.applyTransition(t.select("path.path"),e).attr("d",function(n){var t=e.node(n.v);if(t){var r=f.range(this.pathSegList.length).map(function(){return t});return o({},r)}return p.select(this).attr("d")})}var f=n("./lodash"),l=n("./intersect/intersect-node"),s=n("./util"),p=n("./d3");e.exports=r},{"./d3":7,"./intersect/intersect-node":14,"./lodash":21,"./util":27}],6:[function(n,e,t){"use strict";function r(n,e,t){var r=e.nodes().filter(function(n){return!a.isSubgraph(e,n)}),c=n.selectAll("g.node").data(r,function(n){return n}).classed("update",!0);return c.selectAll("*").remove(),c.enter().append("g").attr("class","node").style("opacity",0),c.each(function(n){var r=e.node(n),c=u.select(this),f=c.append("g").attr("class","label"),l=o(f,r),s=t[r.shape],p=i.pick(l.node().getBBox(),"width","height");r.elem=this,r.id&&c.attr("id",r.id),r.labelId&&f.attr("id",r.labelId),a.applyClass(c,r["class"],(c.classed("update")?"update ":"")+"node"),i.has(r,"width")&&(p.width=r.width),i.has(r,"height")&&(p.height=r.height),p.width+=r.paddingLeft+r.paddingRight,p.height+=r.paddingTop+r.paddingBottom,f.attr("transform","translate("+(r.paddingLeft-r.paddingRight)/2+","+(r.paddingTop-r.paddingBottom)/2+")");var h=s(u.select(this),p,r);a.applyStyle(h,r.style);var d=h.node().getBBox();r.width=d.width,r.height=d.height}),a.applyTransition(c.exit(),e).style("opacity",0).remove(),c}var i=n("./lodash"),o=n("./label/add-label"),a=n("./util"),u=n("./d3");e.exports=r},{"./d3":7,"./label/add-label":18,"./lodash":21,"./util":27}],7:[function(n,e,t){e.exports=window.d3},{}],8:[function(n,e,t){var r;if(n)try{r=n("dagre")}catch(i){}r||(r=window.dagre),e.exports=r},{dagre:29}],9:[function(n,e,t){var r;if(n)try{r=n("graphlib")}catch(i){}r||(r=window.graphlib),e.exports=r},{graphlib:60}],10:[function(n,e,t){e.exports={node:n("./intersect-node"),circle:n("./intersect-circle"),ellipse:n("./intersect-ellipse"),polygon:n("./intersect-polygon"),rect:n("./intersect-rect")}},{"./intersect-circle":11,"./intersect-ellipse":12,"./intersect-node":14,"./intersect-polygon":15,"./intersect-rect":16}],11:[function(n,e,t){function r(n,e,t){return i(n,e,e,t)}var i=n("./intersect-ellipse");e.exports=r},{"./intersect-ellipse":12}],12:[function(n,e,t){function r(n,e,t,r){var i=n.x,o=n.y,a=i-r.x,u=o-r.y,c=Math.sqrt(e*e*u*u+t*t*a*a),f=Math.abs(e*t*a/c);r.xy?(y-v)/g:(y+v)/g,y=a*f-o*l,b=0>y?(y-v)/g:(y+v)/g,{x:m,y:b})}function i(n,e){return n*e>0}e.exports=r},{}],14:[function(n,e,t){function r(n,e){return n.intersect(e)}e.exports=r},{}],15:[function(n,e,t){function r(n,e,t){var r=n.x,o=n.y,a=[],u=Number.POSITIVE_INFINITY,c=Number.POSITIVE_INFINITY;e.forEach(function(n){u=Math.min(u,n.x),c=Math.min(c,n.y)});for(var f=r-n.width/2-u,l=o-n.height/2-c,s=0;s1&&a.sort(function(n,e){var r=n.x-t.x,i=n.y-t.y,o=Math.sqrt(r*r+i*i),a=e.x-t.x,u=e.y-t.y,c=Math.sqrt(a*a+u*u);return c>o?-1:o===c?0:1}),a[0]):(console.log("NO INTERSECTION FOUND, RETURN NODE CENTER",n),n)}var i=n("./intersect-line");e.exports=r},{"./intersect-line":13}],16:[function(n,e,t){function r(n,e){var t,r,i=n.x,o=n.y,a=e.x-i,u=e.y-o,c=n.width/2,f=n.height/2;return Math.abs(u)*c>Math.abs(a)*f?(0>u&&(f=-f),t=0===u?0:f*a/u,r=f):(0>a&&(c=-c),t=c,r=0===a?0:c*u/a),{x:i+t,y:o+r}}e.exports=r},{}],17:[function(n,e,t){function r(n,e){var t=n.append("foreignObject").attr("width","100000"),r=t.append("xhtml:div"),o=e.label;switch(typeof o){case"function":r.insert(o);break;case"object":r.insert(function(){return o});break;default:r.html(o)}i.applyStyle(r,e.labelStyle),r.style("display","inline-block"),r.style("white-space","nowrap");var a,u;return r.each(function(){a=this.clientWidth,u=this.clientHeight}),t.attr("width",a).attr("height",u),t}var i=n("../util");e.exports=r},{"../util":27}],18:[function(n,e,t){function r(n,e,t){var r=e.label,u=n.append("g");"svg"===e.labelType?a(u,e):"string"!=typeof r||"html"===e.labelType?o(u,e):i(u,e);var c,f=u.node().getBBox();switch(t){case"top":c=-e.height/2;break;case"bottom":c=e.height/2-f.height;break;default:c=-f.height/2}return u.attr("transform","translate("+-f.width/2+","+c+")"),u}var i=n("./add-text-label"),o=n("./add-html-label"),a=n("./add-svg-label");e.exports=r},{"./add-html-label":17,"./add-svg-label":19,"./add-text-label":20}],19:[function(n,e,t){function r(n,e){var t=n;return t.node().appendChild(e.label),i.applyStyle(t,e.labelStyle),t}var i=n("../util");e.exports=r},{"../util":27}],20:[function(n,e,t){function r(n,e){for(var t=n.append("text"),r=i(e.label).split("\n"),a=0;au;++u)i(n,"borderLeft","_bl",t,a,u),i(n,"borderRight","_br",t,a,u)}}o.each(n.children(),e)}function i(n,e,t,r,i,o){var u={width:0,height:0,rank:o,borderType:e},c=i[e][o-1],f=a.addDummyNode(n,"border",u,t);i[e][o]=f,n.setParent(f,r),c&&n.setEdge(c,f,{weight:1})}var o=n("./lodash"),a=n("./util");e.exports=r},{"./lodash":38,"./util":57}],32:[function(n,e,t){"use strict";function r(n){var e=n.graph().rankdir.toLowerCase();("lr"===e||"rl"===e)&&o(n)}function i(n){var e=n.graph().rankdir.toLowerCase();("bt"===e||"rl"===e)&&u(n),("lr"===e||"rl"===e)&&(f(n),o(n))}function o(n){s.each(n.nodes(),function(e){a(n.node(e))}),s.each(n.edges(),function(e){a(n.edge(e))})}function a(n){var e=n.width;n.width=n.height,n.height=e}function u(n){s.each(n.nodes(),function(e){c(n.node(e))}),s.each(n.edges(),function(e){var t=n.edge(e);s.each(t.points,c),s.has(t,"y")&&c(t)})}function c(n){n.y=-n.y}function f(n){s.each(n.nodes(),function(e){l(n.node(e))}),s.each(n.edges(),function(e){var t=n.edge(e);s.each(t.points,l),s.has(t,"x")&&l(t)})}function l(n){var e=n.x;n.x=n.y,n.y=e}var s=n("./lodash");e.exports={adjust:r,undo:i}},{"./lodash":38}],33:[function(n,e,t){function r(){var n={};n._next=n._prev=n,this._sentinel=n}function i(n){n._prev._next=n._next,n._next._prev=n._prev,delete n._next,delete n._prev}function o(n,e){return"_next"!==n&&"_prev"!==n?e:void 0}e.exports=r,r.prototype.dequeue=function(){var n=this._sentinel,e=n._prev;return e!==n?(i(e),e):void 0},r.prototype.enqueue=function(n){var e=this._sentinel;n._prev&&n._next&&i(n),n._next=e._next,e._next._prev=n,e._next=n,n._prev=e},r.prototype.toString=function(){for(var n=[],e=this._sentinel,t=e._prev;t!==e;)n.push(JSON.stringify(t,o)),t=t._prev;return"["+n.join(", ")+"]"}},{}],34:[function(n,e,t){function r(n){var e=o.buildLayerMatrix(n),t=new a({compound:!0,multigraph:!0}).setGraph({});return i.each(n.nodes(),function(e){t.setNode(e,{label:e}),t.setParent(e,"layer"+n.node(e).rank)}),i.each(n.edges(),function(n){t.setEdge(n.v,n.w,{},n.name)}),i.each(e,function(n,e){var r="layer"+e;t.setNode(r,{rank:"same"}),i.reduce(n,function(n,e){return t.setEdge(n,e,{style:"invis"}),e})}),t}var i=n("./lodash"),o=n("./util"),a=n("./graphlib").Graph;e.exports={debugOrdering:r}},{"./graphlib":35,"./lodash":38,"./util":57}],35:[function(n,e,t){e.exports=n(9)},{"/Users/cpettitt/projects/dagre-d3/lib/graphlib.js":9,graphlib:60}],36:[function(n,e,t){function r(n,e){if(n.nodeCount()<=1)return[];var t=a(n,e||s),r=i(t.graph,t.buckets,t.zeroIdx);return c.flatten(c.map(r,function(e){return n.outEdges(e.v,e.w)}),!0)}function i(n,e,t){for(var r,i=[],a=e[e.length-1],u=e[0];n.nodeCount();){for(;r=u.dequeue();)o(n,e,t,r);for(;r=a.dequeue();)o(n,e,t,r);if(n.nodeCount())for(var c=e.length-2;c>0;--c)if(r=e[c].dequeue()){i=i.concat(o(n,e,t,r,!0));break}}return i}function o(n,e,t,r,i){var o=i?[]:void 0;return c.each(n.inEdges(r.v),function(r){var a=n.edge(r),c=n.node(r.v);i&&o.push({v:r.v,w:r.w}),c.out-=a,u(e,t,c)}),c.each(n.outEdges(r.v),function(r){var i=n.edge(r),o=r.w,a=n.node(o);a["in"]-=i,u(e,t,a)}),n.removeNode(r.v),o}function a(n,e){var t=new f,r=0,i=0;c.each(n.nodes(),function(n){t.setNode(n,{v:n,"in":0,out:0})}),c.each(n.edges(),function(n){var o=t.edge(n.v,n.w)||0,a=e(n),u=o+a;t.setEdge(n.v,n.w,u),i=Math.max(i,t.node(n.v).out+=a),r=Math.max(r,t.node(n.w)["in"]+=a)});var o=c.range(i+r+3).map(function(){return new l}),a=r+1;return c.each(t.nodes(),function(n){u(o,a,t.node(n))}),{graph:t,buckets:o,zeroIdx:a}}function u(n,e,t){t.out?t["in"]?n[t.out-t["in"]+e].enqueue(t):n[n.length-1].enqueue(t):n[0].enqueue(t)}var c=n("./lodash"),f=n("./graphlib").Graph,l=n("./data/list");e.exports=r;var s=c.constant(1)},{"./data/list":33,"./graphlib":35,"./lodash":38}],37:[function(n,e,t){"use strict";function r(n,e){var t=e&&e.debugTiming?L.time:L.notime;t("layout",function(){var e=t(" buildLayoutGraph",function(){return a(n)});t(" runLayout",function(){i(e,t)}),t(" updateInputGraph",function(){o(n,e)})})}function i(n,e){e(" makeSpaceForEdgeLabels",function(){u(n)}),e(" removeSelfEdges",function(){v(n)}),e(" acyclic",function(){x.run(n)}),e(" nestingGraph.run",function(){I.run(n)}),e(" rank",function(){j(L.asNonCompoundGraph(n))}),e(" injectEdgeLabelProxies",function(){c(n)}),e(" removeEmptyRanks",function(){N(n)}),e(" nestingGraph.cleanup",function(){I.cleanup(n)}),e(" normalizeRanks",function(){E(n)}),e(" assignRankMinMax",function(){f(n)}),e(" removeEdgeLabelProxies",function(){l(n)}),e(" normalize.run",function(){k.run(n)}),e(" parentDummyChains",function(){C(n)}),e(" addBorderSegments",function(){T(n)}),e(" order",function(){R(n)}),e(" insertSelfEdges",function(){y(n)}),e(" adjustCoordinateSystem",function(){O.adjust(n)}),e(" position",function(){S(n)}),e(" positionSelfEdges",function(){m(n)}),e(" removeBorderNodes",function(){g(n)}),e(" normalize.undo",function(){k.undo(n)}),e(" fixupEdgeLabelCoords",function(){h(n)}),e(" undoCoordinateSystem",function(){O.undo(n)}),e(" translateGraph",function(){s(n)}),e(" assignNodeIntersects",function(){p(n)}),e(" reversePoints",function(){d(n)}),e(" acyclic.undo",function(){x.undo(n)})}function o(n,e){w.each(n.nodes(),function(t){var r=n.node(t),i=e.node(t);r&&(r.x=i.x,r.y=i.y,e.children(t).length&&(r.width=i.width,r.height=i.height))}),w.each(n.edges(),function(t){var r=n.edge(t),i=e.edge(t);r.points=i.points,w.has(i,"x")&&(r.x=i.x,r.y=i.y)}),n.graph().width=e.graph().width,n.graph().height=e.graph().height}function a(n){var e=new M({multigraph:!0,compound:!0}),t=_(n.graph());return e.setGraph(w.merge({},D,b(t,B),w.pick(t,F))),w.each(n.nodes(),function(t){var r=_(n.node(t));e.setNode(t,w.defaults(b(r,A),P)),e.setParent(t,n.parent(t))}),w.each(n.edges(),function(t){var r=_(n.edge(t));e.setEdge(t,w.merge({},q,b(r,U),w.pick(r,z)))}),e}function u(n){var e=n.graph();e.ranksep/=2,w.each(n.edges(),function(t){var r=n.edge(t);r.minlen*=2,"c"!==r.labelpos.toLowerCase()&&("TB"===e.rankdir||"BT"===e.rankdir?r.width+=r.labeloffset:r.height+=r.labeloffset)})}function c(n){w.each(n.edges(),function(e){var t=n.edge(e);if(t.width&&t.height){var r=n.node(e.v),i=n.node(e.w),o={rank:(i.rank-r.rank)/2+r.rank,e:e};L.addDummyNode(n,"edge-proxy",o,"_ep")}})}function f(n){var e=0;w.each(n.nodes(),function(t){var r=n.node(t);r.borderTop&&(r.minRank=n.node(r.borderTop).rank,r.maxRank=n.node(r.borderBottom).rank,e=w.max(e,r.maxRank))}),n.graph().maxRank=e}function l(n){w.each(n.nodes(),function(e){var t=n.node(e);"edge-proxy"===t.dummy&&(n.edge(t.e).labelRank=t.rank,n.removeNode(e))})}function s(n){function e(n){var e=n.x,a=n.y,u=n.width,c=n.height;t=Math.min(t,e-u/2),r=Math.max(r,e+u/2),i=Math.min(i,a-c/2),o=Math.max(o,a+c/2)}var t=Number.POSITIVE_INFINITY,r=0,i=Number.POSITIVE_INFINITY,o=0,a=n.graph(),u=a.marginx||0,c=a.marginy||0;w.each(n.nodes(),function(t){e(n.node(t))}),w.each(n.edges(),function(t){var r=n.edge(t);w.has(r,"x")&&e(r)}),t-=u,i-=c,w.each(n.nodes(),function(e){var r=n.node(e);r.x-=t,r.y-=i}),w.each(n.edges(),function(e){var r=n.edge(e);w.each(r.points,function(n){n.x-=t,n.y-=i}),w.has(r,"x")&&(r.x-=t),w.has(r,"y")&&(r.y-=i)}),a.width=r-t+u,a.height=o-i+c}function p(n){w.each(n.edges(),function(e){var t,r,i=n.edge(e),o=n.node(e.v),a=n.node(e.w);i.points?(t=i.points[0],r=i.points[i.points.length-1]):(i.points=[],t=a,r=o),i.points.unshift(L.intersectRect(o,t)),i.points.push(L.intersectRect(a,r))})}function h(n){w.each(n.edges(),function(e){var t=n.edge(e);if(w.has(t,"x"))switch(("l"===t.labelpos||"r"===t.labelpos)&&(t.width-=t.labeloffset),t.labelpos){case"l":t.x-=t.width/2+t.labeloffset;break;case"r":t.x+=t.width/2+t.labeloffset}})}function d(n){w.each(n.edges(),function(e){var t=n.edge(e);t.reversed&&t.points.reverse()})}function g(n){w.each(n.nodes(),function(e){if(n.children(e).length){var t=n.node(e),r=n.node(t.borderTop),i=n.node(t.borderBottom),o=n.node(w.last(t.borderLeft)),a=n.node(w.last(t.borderRight));t.width=Math.abs(a.x-o.x),t.height=Math.abs(i.y-r.y),t.x=o.x+t.width/2,t.y=r.y+t.height/2}}),w.each(n.nodes(),function(e){"border"===n.node(e).dummy&&n.removeNode(e)})}function v(n){w.each(n.edges(),function(e){if(e.v===e.w){var t=n.node(e.v);t.selfEdges||(t.selfEdges=[]),t.selfEdges.push({e:e,label:n.edge(e)}),n.removeEdge(e)}})}function y(n){var e=L.buildLayerMatrix(n);w.each(e,function(e){var t=0;w.each(e,function(e,r){var i=n.node(e);i.order=r+t,w.each(i.selfEdges,function(e){L.addDummyNode(n,"selfedge",{width:e.label.width,height:e.label.height,rank:i.rank,order:r+ ++t,e:e.e,label:e.label},"_se")}),delete i.selfEdges})})}function m(n){w.each(n.nodes(),function(e){var t=n.node(e);if("selfedge"===t.dummy){var r=n.node(t.e.v),i=r.x+r.width/2,o=r.y,a=t.x-i,u=r.height/2;n.setEdge(t.e,t.label),n.removeNode(e),t.label.points=[{x:i+2*a/3,y:o-u},{x:i+5*a/6,y:o-u},{x:i+a,y:o},{x:i+5*a/6,y:o+u},{x:i+2*a/3,y:o+u}],t.label.x=t.x,t.label.y=t.y}})}function b(n,e){return w.mapValues(w.pick(n,e),Number)}function _(n){var e={};return w.each(n,function(n,t){e[t.toLowerCase()]=n}),e}var w=n("./lodash"),x=n("./acyclic"),k=n("./normalize"),j=n("./rank"),E=n("./util").normalizeRanks,C=n("./parent-dummy-chains"),N=n("./util").removeEmptyRanks,I=n("./nesting-graph"),T=n("./add-border-segments"),O=n("./coordinate-system"),R=n("./order"),S=n("./position"),L=n("./util"),M=n("./graphlib").Graph;e.exports=r;var B=["nodesep","edgesep","ranksep","marginx","marginy"],D={ranksep:50,edgesep:20,nodesep:50,rankdir:"tb"},F=["acyclicer","ranker","rankdir","align"],A=["width","height"],P={width:0,height:0},U=["minlen","weight","width","height","labeloffset"],q={minlen:1,weight:1,width:0,height:0,labeloffset:10,labelpos:"r"},z=["labelpos"]},{"./acyclic":30,"./add-border-segments":31,"./coordinate-system":32,"./graphlib":35,"./lodash":38,"./nesting-graph":39,"./normalize":40,"./order":45,"./parent-dummy-chains":50,"./position":52,"./rank":54,"./util":57}],38:[function(n,e,t){arguments[4][21][0].apply(t,arguments)},{"/Users/cpettitt/projects/dagre-d3/lib/lodash.js":21,lodash:59}],39:[function(n,e,t){function r(n){var e=f.addDummyNode(n,"root",{},"_root"),t=o(n),r=c.max(t)-1,u=2*r+1;n.graph().nestingRoot=e,c.each(n.edges(),function(e){n.edge(e).minlen*=u});var l=a(n)+1;c.each(n.children(),function(o){i(n,e,u,l,r,t,o)}),n.graph().nodeRankFactor=u}function i(n,e,t,r,o,a,u){var l=n.children(u);if(!l.length)return void(u!==e&&n.setEdge(e,u,{weight:0,minlen:t}));var s=f.addBorderNode(n,"_bt"),p=f.addBorderNode(n,"_bb"),h=n.node(u);n.setParent(s,u),h.borderTop=s,n.setParent(p,u),h.borderBottom=p,c.each(l,function(c){i(n,e,t,r,o,a,c);var f=n.node(c),l=f.borderTop?f.borderTop:c,h=f.borderBottom?f.borderBottom:c,d=f.borderTop?r:2*r,g=l!==h?1:o-a[u]+1;n.setEdge(s,l,{weight:d,minlen:g,nestingEdge:!0}),n.setEdge(h,p,{weight:d,minlen:g,nestingEdge:!0})}),n.parent(u)||n.setEdge(e,s,{weight:0,minlen:o+a[u]})}function o(n){function e(r,i){var o=n.children(r);o&&o.length&&c.each(o,function(n){e(n,i+1)}),t[r]=i}var t={};return c.each(n.children(),function(n){e(n,1)}),t}function a(n){return c.reduce(n.edges(),function(e,t){return e+n.edge(t).weight},0)}function u(n){var e=n.graph();n.removeNode(e.nestingRoot),delete e.nestingRoot,c.each(n.edges(),function(e){var t=n.edge(e);t.nestingEdge&&n.removeEdge(e)})}var c=n("./lodash"),f=n("./util");e.exports={run:r,cleanup:u}},{"./lodash":38,"./util":57}],40:[function(n,e,t){"use strict";function r(n){n.graph().dummyChains=[],a.each(n.edges(),function(e){i(n,e)})}function i(n,e){var t=e.v,r=n.node(t).rank,i=e.w,o=n.node(i).rank,a=e.name,c=n.edge(e),f=c.labelRank;if(o!==r+1){n.removeEdge(e);var l,s,p;for(p=0,++r;o>r;++p,++r)c.points=[],s={width:0,height:0,edgeLabel:c,edgeObj:e,rank:r},l=u.addDummyNode(n,"edge",s,"_d"),r===f&&(s.width=c.width,s.height=c.height,s.dummy="edge-label",s.labelpos=c.labelpos),n.setEdge(t,l,{weight:c.weight},a),0===p&&n.graph().dummyChains.push(l),t=l;n.setEdge(t,i,{weight:c.weight},a)}}function o(n){a.each(n.graph().dummyChains,function(e){var t,r=n.node(e),i=r.edgeLabel;for(n.setEdge(r.edgeObj,i);r.dummy;)t=n.successors(e)[0],n.removeNode(e),i.points.push({x:r.x,y:r.y}),"edge-label"===r.dummy&&(i.x=r.x,i.y=r.y,i.width=r.width,i.height=r.height),e=t,r=n.node(e)})}var a=n("./lodash"),u=n("./util");e.exports={run:r,undo:o}},{"./lodash":38,"./util":57}],41:[function(n,e,t){function r(n,e,t){var r,o={};i.each(t,function(t){for(var i,a,u=n.parent(t);u;){if(i=n.parent(u),i?(a=o[i],o[i]=u):(a=r,r=u),a&&a!==u)return void e.setEdge(a,u);u=i}})}var i=n("../lodash");e.exports=r},{"../lodash":38}],42:[function(n,e,t){function r(n,e){return i.map(e,function(e){var t=n.inEdges(e);if(t.length){var r=i.reduce(t,function(e,t){var r=n.edge(t),i=n.node(t.v);return{sum:e.sum+r.weight*i.order,weight:e.weight+r.weight}},{sum:0,weight:0});return{v:e,barycenter:r.sum/r.weight,weight:r.weight}}return{v:e}})}var i=n("../lodash");e.exports=r},{"../lodash":38}],43:[function(n,e,t){function r(n,e,t){var r=i(n),u=new a({compound:!0}).setGraph({root:r}).setDefaultNodeLabel(function(e){return n.node(e)});return o.each(n.nodes(),function(i){var a=n.node(i),c=n.parent(i);(a.rank===e||a.minRank<=e&&e<=a.maxRank)&&(u.setNode(i),u.setParent(i,c||r),o.each(n[t](i),function(e){var t=e.v===i?e.w:e.v,r=u.edge(t,i),a=o.isUndefined(r)?0:r.weight;u.setEdge(t,i,{weight:n.edge(e).weight+a})}),o.has(a,"minRank")&&u.setNode(i,{borderLeft:a.borderLeft[e],borderRight:a.borderRight[e]}))}),u}function i(n){for(var e;n.hasNode(e=o.uniqueId("_root")););return e}var o=n("../lodash"),a=n("../graphlib").Graph;e.exports=r},{"../graphlib":35,"../lodash":38}],44:[function(n,e,t){"use strict";function r(n,e){for(var t=0,r=1;r0;)e%2&&(t+=c[e+1]),e=e-1>>1,c[e]+=n.weight;f+=n.weight*t})),f}var o=n("../lodash");e.exports=r},{"../lodash":38}],45:[function(n,e,t){"use strict";function r(n){var e=d.maxRank(n),t=i(n,u.range(1,e+1),"inEdges"),r=i(n,u.range(e-1,-1,-1),"outEdges"),l=c(n);a(n,l);for(var s,p=Number.POSITIVE_INFINITY,h=0,g=0;4>g;++h,++g){o(h%2?t:r,h%4>=2),l=d.buildLayerMatrix(n);var v=f(n,l);p>v&&(g=0,s=u.cloneDeep(l),p=v)}a(n,s)}function i(n,e,t){return u.map(e,function(e){return s(n,e,t)})}function o(n,e){var t=new h;u.each(n,function(n){var r=n.graph().root,i=l(n,r,t,e);u.each(i.vs,function(e,t){n.node(e).order=t}),p(n,t,i.vs)})}function a(n,e){u.each(e,function(e){u.each(e,function(e,t){n.node(e).order=t})})}var u=n("../lodash"),c=n("./init-order"),f=n("./cross-count"),l=n("./sort-subgraph"),s=n("./build-layer-graph"),p=n("./add-subgraph-constraints"),h=n("../graphlib").Graph,d=n("../util");e.exports=r},{"../graphlib":35,"../lodash":38,"../util":57,"./add-subgraph-constraints":41,"./build-layer-graph":43,"./cross-count":44,"./init-order":46,"./sort-subgraph":48}],46:[function(n,e,t){"use strict";function r(n){function e(r){if(!i.has(t,r)){t[r]=!0;var o=n.node(r);a[o.rank].push(r),i.each(n.successors(r),e)}}var t={},r=i.filter(n.nodes(),function(e){return!n.children(e).length}),o=i.max(i.map(r,function(e){ return n.node(e).rank})),a=i.map(i.range(o+1),function(){return[]}),u=i.sortBy(r,function(e){return n.node(e).rank});return i.each(u,e),a}var i=n("../lodash");e.exports=r},{"../lodash":38}],47:[function(n,e,t){"use strict";function r(n,e){var t={};a.each(n,function(n,e){var r=t[n.v]={indegree:0,"in":[],out:[],vs:[n.v],i:e};a.isUndefined(n.barycenter)||(r.barycenter=n.barycenter,r.weight=n.weight)}),a.each(e.edges(),function(n){var e=t[n.v],r=t[n.w];a.isUndefined(e)||a.isUndefined(r)||(r.indegree++,e.out.push(t[n.w]))});var r=a.filter(t,function(n){return!n.indegree});return i(r)}function i(n){function e(n){return function(e){e.merged||(a.isUndefined(e.barycenter)||a.isUndefined(n.barycenter)||e.barycenter>=n.barycenter)&&o(n,e)}}function t(e){return function(t){t["in"].push(e),0===--t.indegree&&n.push(t)}}for(var r=[];n.length;){var i=n.pop();r.push(i),a.each(i["in"].reverse(),e(i)),a.each(i.out,t(i))}return a.chain(r).filter(function(n){return!n.merged}).map(function(n){return a.pick(n,["vs","i","barycenter","weight"])}).value()}function o(n,e){var t=0,r=0;n.weight&&(t+=n.barycenter*n.weight,r+=n.weight),e.weight&&(t+=e.barycenter*e.weight,r+=e.weight),n.vs=e.vs.concat(n.vs),n.barycenter=t/r,n.weight=r,n.i=Math.min(e.i,n.i),e.merged=!0}var a=n("../lodash");e.exports=r},{"../lodash":38}],48:[function(n,e,t){function r(n,e,t,l){var s=n.children(e),p=n.node(e),h=p?p.borderLeft:void 0,d=p?p.borderRight:void 0,g={};h&&(s=a.filter(s,function(n){return n!==h&&n!==d}));var v=u(n,s);a.each(v,function(e){if(n.children(e.v).length){var i=r(n,e.v,t,l);g[e.v]=i,a.has(i,"barycenter")&&o(e,i)}});var y=c(v,t);i(y,g);var m=f(y,l);if(h&&(m.vs=a.flatten([h,m.vs,d],!0),n.predecessors(h).length)){var b=n.node(n.predecessors(h)[0]),_=n.node(n.predecessors(d)[0]);a.has(m,"barycenter")||(m.barycenter=0,m.weight=0),m.barycenter=(m.barycenter*m.weight+b.order+_.order)/(m.weight+2),m.weight+=2}return m}function i(n,e){a.each(n,function(n){n.vs=a.flatten(n.vs.map(function(n){return e[n]?e[n].vs:n}),!0)})}function o(n,e){a.isUndefined(n.barycenter)?(n.barycenter=e.barycenter,n.weight=e.weight):(n.barycenter=(n.barycenter*n.weight+e.barycenter*e.weight)/(n.weight+e.weight),n.weight+=e.weight)}var a=n("../lodash"),u=n("./barycenter"),c=n("./resolve-conflicts"),f=n("./sort");e.exports=r},{"../lodash":38,"./barycenter":42,"./resolve-conflicts":47,"./sort":49}],49:[function(n,e,t){function r(n,e){var t=u.partition(n,function(n){return a.has(n,"barycenter")}),r=t.lhs,c=a.sortBy(t.rhs,function(n){return-n.i}),f=[],l=0,s=0,p=0;r.sort(o(!!e)),p=i(f,c,p),a.each(r,function(n){p+=n.vs.length,f.push(n.vs),l+=n.barycenter*n.weight,s+=n.weight,p=i(f,c,p)});var h={vs:a.flatten(f,!0)};return s&&(h.barycenter=l/s,h.weight=s),h}function i(n,e,t){for(var r;e.length&&(r=a.last(e)).i<=t;)e.pop(),n.push(r.vs),t++;return t}function o(n){return function(e,t){return e.barycentert.barycenter?1:n?t.i-e.i:e.i-t.i}}var a=n("../lodash"),u=n("../util");e.exports=r},{"../lodash":38,"../util":57}],50:[function(n,e,t){function r(n){var e=o(n);a.each(n.graph().dummyChains,function(t){for(var r=n.node(t),o=r.edgeObj,a=i(n,e,o.v,o.w),u=a.path,c=a.lca,f=0,l=u[f],s=!0;t!==o.w;){if(r=n.node(t),s){for(;(l=u[f])!==c&&n.node(l).maxRankc||f>e[i].lim));for(o=i,i=r;(i=n.parent(i))!==o;)u.push(i);return{path:a.concat(u.reverse()),lca:o}}function o(n){function e(i){var o=r;a.each(n.children(i),e),t[i]={low:o,lim:r++}}var t={},r=0;return a.each(n.children(),e),t}var a=n("./lodash");e.exports=r},{"./lodash":38}],51:[function(n,e,t){"use strict";function r(n,e){function t(e,t){var i=0,u=0,c=e.length,f=y.last(t);return y.each(t,function(e,l){var s=o(n,e),p=s?n.node(s).order:c;(s||e===f)&&(y.each(t.slice(u,l+1),function(e){y.each(n.predecessors(e),function(t){var o=n.node(t),u=o.order;!(i>u||u>p)||o.dummy&&n.node(e).dummy||a(r,t,e)})}),u=l+1,i=p)}),t}var r={};return y.reduce(e,t),r}function i(n,e){function t(e,t,r,o,u){var c;y.each(y.range(t,r),function(t){c=e[t],n.node(c).dummy&&y.each(n.predecessors(c),function(e){var t=n.node(e);t.dummy&&(t.orderu)&&a(i,e,c)})})}function r(e,r){var i,o=-1,a=0;return y.each(r,function(u,c){if("border"===n.node(u).dummy){var f=n.predecessors(u);f.length&&(i=n.node(f[0]).order,t(r,a,c,o,i),a=c,o=i)}t(r,a,r.length,i,e.length)}),r}var i={};return y.reduce(e,r),i}function o(n,e){return n.node(e).dummy?y.find(n.predecessors(e),function(e){return n.node(e).dummy}):void 0}function a(n,e,t){if(e>t){var r=e;e=t,t=r}var i=n[e];i||(n[e]=i={}),i[t]=!0}function u(n,e,t){if(e>t){var r=e;e=t,t=r}return y.has(n[e],t)}function c(n,e,t,r){var i={},o={},a={};return y.each(e,function(n){y.each(n,function(n,e){i[n]=n,o[n]=n,a[n]=e})}),y.each(e,function(n){var e=-1;y.each(n,function(n){var c=r(n);if(c.length){c=y.sortBy(c,function(n){return a[n]});for(var f=(c.length-1)/2,l=Math.floor(f),s=Math.ceil(f);s>=l;++l){var p=c[l];o[n]===n&&ea.lim&&(u=a,c=!0);var f=g.filter(e.edges(),function(e){return c===d(n,n.node(e.v),u)&&c!==d(n,n.node(e.w),u)});return g.min(f,function(n){return y(e,n)})}function s(n,e,t,r){var o=t.v,a=t.w;n.removeEdge(o,a),n.setEdge(r.v,r.w,{}),u(n),i(n,e),p(n,e)}function p(n,e){var t=g.find(n.nodes(),function(n){return!e.node(n).parent}),r=b(n,t);r=r.slice(1),g.each(r,function(t){var r=n.node(t).parent,i=e.edge(t,r),o=!1;i||(i=e.edge(r,t),o=!0),e.node(t).rank=e.node(r).rank+(o?i.minlen:-i.minlen)})}function h(n,e,t){return n.hasEdge(e,t)}function d(n,e,t){return t.low<=e.lim&&e.lim<=t.lim}var g=n("../lodash"),v=n("./feasible-tree"),y=n("./util").slack,m=n("./util").longestPath,b=n("../graphlib").alg.preorder,_=n("../graphlib").alg.postorder,w=n("../util").simplify;e.exports=r,r.initLowLimValues=u,r.initCutValues=i,r.calcCutValue=a,r.leaveEdge=f,r.enterEdge=l,r.exchangeEdges=s},{"../graphlib":35,"../lodash":38,"../util":57,"./feasible-tree":53,"./util":56}],56:[function(n,e,t){"use strict";function r(n){function e(r){var i=n.node(r);if(o.has(t,r))return i.rank;t[r]=!0;var a=o.min(o.map(n.outEdges(r),function(t){return e(t.w)-n.edge(t).minlen}));return a===Number.POSITIVE_INFINITY&&(a=0),i.rank=a}var t={};o.each(n.sources(),e)}function i(n,e){return n.node(e.w).rank-n.node(e.v).rank-n.edge(e).minlen}var o=n("../lodash");e.exports={longestPath:r,slack:i}},{"../lodash":38}],57:[function(n,e,t){"use strict";function r(n,e,t,r){var i;do i=y.uniqueId(r);while(n.hasNode(i));return t.dummy=e,n.setNode(i,t),i}function i(n){var e=(new m).setGraph(n.graph());return y.each(n.nodes(),function(t){e.setNode(t,n.node(t))}),y.each(n.edges(),function(t){var r=e.edge(t.v,t.w)||{weight:0,minlen:1},i=n.edge(t);e.setEdge(t.v,t.w,{weight:r.weight+i.weight,minlen:Math.max(r.minlen,i.minlen)})}),e}function o(n){var e=new m({multigraph:n.isMultigraph()}).setGraph(n.graph());return y.each(n.nodes(),function(t){n.children(t).length||e.setNode(t,n.node(t))}),y.each(n.edges(),function(t){e.setEdge(t,n.edge(t))}),e}function a(n){var e=y.map(n.nodes(),function(e){var t={};return y.each(n.outEdges(e),function(e){t[e.w]=(t[e.w]||0)+n.edge(e).weight}),t});return y.zipObject(n.nodes(),e)}function u(n){var e=y.map(n.nodes(),function(e){var t={};return y.each(n.inEdges(e),function(e){t[e.v]=(t[e.v]||0)+n.edge(e).weight}),t});return y.zipObject(n.nodes(),e)}function c(n,e){var t=n.x,r=n.y,i=e.x-t,o=e.y-r,a=n.width/2,u=n.height/2;if(!i&&!o)throw new Error("Not possible to find intersection inside of the rectangle");var c,f;return Math.abs(o)*a>Math.abs(i)*u?(0>o&&(u=-u),c=u*i/o,f=u):(0>i&&(a=-a),c=a,f=a*o/i),{x:t+c,y:r+f}}function f(n){var e=y.map(y.range(h(n)+1),function(){return[]});return y.each(n.nodes(),function(t){var r=n.node(t),i=r.rank;y.isUndefined(i)||(e[i][r.order]=t)}),e}function l(n){var e=y.min(y.map(n.nodes(),function(e){return n.node(e).rank}));y.each(n.nodes(),function(t){var r=n.node(t);y.has(r,"rank")&&(r.rank-=e)})}function s(n){var e=y.min(y.map(n.nodes(),function(e){return n.node(e).rank})),t=[];y.each(n.nodes(),function(r){var i=n.node(r).rank-e;y.has(t,i)||(t[i]=[]),t[i].push(r)});var r=0,i=n.graph().nodeRankFactor;y.each(t,function(e,t){y.isUndefined(e)&&t%i!==0?--r:r&&y.each(e,function(e){n.node(e).rank+=r})})}function p(n,e,t,i){var o={width:0,height:0};return arguments.length>=4&&(o.rank=t,o.order=i),r(n,"border",o,e)}function h(n){return y.max(y.map(n.nodes(),function(e){var t=n.node(e).rank;return y.isUndefined(t)?void 0:t}))}function d(n,e){var t={lhs:[],rhs:[]};return y.each(n,function(n){e(n)?t.lhs.push(n):t.rhs.push(n)}),t}function g(n,e){var t=y.now();try{return e()}finally{console.log(n+" time: "+(y.now()-t)+"ms")}}function v(n,e){return e()}var y=n("./lodash"),m=n("./graphlib").Graph;e.exports={addDummyNode:r,simplify:i,asNonCompoundGraph:o,successorWeights:a,predecessorWeights:u,intersectRect:c,buildLayerMatrix:f,normalizeRanks:l,removeEmptyRanks:s,addBorderNode:p,maxRank:h,partition:d,time:g,notime:v}},{"./graphlib":35,"./lodash":38}],58:[function(n,e,t){e.exports="0.7.2"},{}],59:[function(e,t,r){(function(e){(function(){function i(n,e,t){for(var r=(t||0)-1,i=n?n.length:0;++r-1?0:-1:n?0:-1}function a(n){var e=this.cache,t=typeof n;if("boolean"==t||null==n)e[n]=!0;else{"number"!=t&&"string"!=t&&(t="object");var r="number"==t?n:w+n,i=e[t]||(e[t]={});"object"==t?(i[r]||(i[r]=[])).push(n):i[r]=!0}}function u(n){return n.charCodeAt(0)}function c(n,e){for(var t=n.criteria,r=e.criteria,i=-1,o=t.length;++iu||"undefined"==typeof a)return 1;if(u>a||"undefined"==typeof u)return-1}}return n.index-e.index}function f(n){var e=-1,t=n.length,r=n[0],i=n[t/2|0],o=n[t-1];if(r&&"object"==typeof r&&i&&"object"==typeof i&&o&&"object"==typeof o)return!1;var u=p();u["false"]=u["null"]=u["true"]=u.undefined=!1;var c=p();for(c.array=n,c.cache=u,c.push=a;++ei?0:i);++r=x&&r===i,c=[];if(u){var l=f(e);l?(r=o,e=l):u=!1}for(;++t-1:void 0});return i.pop(),o.pop(),m&&(h(i),h(o)),a}function en(n,e,t,r,i){(Jt(e)?Qn:cr)(e,function(e,o){var a,u,c=e,f=n[o];if(e&&((u=Jt(e))||fr(e))){for(var l=r.length;l--;)if(a=r[l]==e){f=i[l];break}if(!a){var s;t&&(c=t(f,e),(s="undefined"!=typeof c)&&(f=c)),s||(f=u?Jt(f)?f:[]:fr(f)?f:{}),r.push(e),i.push(f),s||en(f,e,t,r,i)}}else t&&(c=t(f,e),"undefined"==typeof c&&(c=e)),"undefined"!=typeof c&&(f=c);n[o]=f})}function tn(n,e){return n+Rt(Kt()*(e-n+1))}function on(n,e,t){var r=-1,a=fn(),u=n?n.length:0,c=[],l=!e&&u>=x&&a===i,p=t||l?s():c;if(l){var g=f(p);a=o,p=g}for(;++r3&&"function"==typeof e[t-2])var r=b(e[--t-1],e[t--],2);else t>2&&"function"==typeof e[t-1]&&(r=e[--t]);for(var i=g(arguments,1,t),o=-1,a=s(),u=s();++ot?Gt(0,o+t):t)||0,Jt(n)?a=i(n,e,t)>-1:"number"==typeof o?a=(Dn(n)?n.indexOf(e,t):i(n,e,t))>-1:cr(n,function(n){return++r>=t?!(a=n===e):void 0}),a}function Yn(n,t,r){var i=!0;t=e.createCallback(t,r,3);var o=-1,a=n?n.length:0;if("number"==typeof a)for(;++oo&&(o=f)}else t=null==t&&Dn(n)?u:e.createCallback(t,r,3),Qn(n,function(n,e,r){var a=t(n,e,r);a>i&&(i=a,o=n)});return o}function te(n,t,r){var i=1/0,o=i;if("function"!=typeof t&&r&&r[t]===n&&(t=null),null==t&&Jt(n))for(var a=-1,c=n.length;++af&&(o=f)}else t=null==t&&Dn(n)?u:e.createCallback(t,r,3),Qn(n,function(n,e,r){var a=t(n,e,r);i>a&&(i=a,o=n)});return o}function re(n,t,r,i){if(!n)return r;var o=arguments.length<3;t=e.createCallback(t,i,4);var a=-1,u=n.length;if("number"==typeof u)for(o&&(r=n[++a]);++at?Gt(0,r+t):t||0}else if(t){var o=Ne(n,e);return n[o]===e?o:-1}return i(n,e,t)}function be(n,t,r){var i=0,o=n?n.length:0;if("number"!=typeof t&&null!=t){var a=o;for(t=e.createCallback(t,r,3);a--&&t(n[a],a,n);)i++}else i=null==t||r?1:t||i;return g(n,0,Vt(Gt(0,o-i),o))}function _e(){for(var n=[],e=-1,t=arguments.length,r=s(),a=fn(),u=a===i,c=s();++e=x&&f(e?n[e]:c)))}var p=n[0],g=-1,v=p?p.length:0,y=[];n:for(;++gt?Gt(0,r+t):Vt(t,r-1))+1);r--;)if(n[r]===e)return r;return-1}function ke(n){for(var e=arguments,t=0,r=e.length,i=n?n.length:0;++to;){var u=o+a>>>1;r(n[u])1?arguments:arguments[0],e=-1,t=n?ee(hr(n,"length")):0,r=dt(0>t?0:t);++e2?un(n,17,g(arguments,2),null,e):un(n,1,null,null,e)}function De(n){for(var e=arguments.length>1?Z(arguments,!0,!1,1):wn(n),t=-1,r=e.length;++t2?un(e,19,g(arguments,2),null,n):un(e,3,null,null,n)}function Ae(){for(var n=arguments,e=n.length;e--;)if(!On(n[e]))throw new kt;return function(){for(var e=arguments,t=n.length;t--;)e=[n[t].apply(this,e)];return e[0]}}function Pe(n,e){return e="number"==typeof e?e:+e||n.length,un(n,4,null,null,null,e)}function Ue(n,e,t){var r,i,o,a,u,c,f,l=0,s=!1,p=!0;if(!On(n))throw new kt;if(e=Gt(0,e)||0,t===!0){var h=!0;p=!1}else Rn(t)&&(h=t.leading,s="maxWait"in t&&(Gt(e,t.maxWait)||0),p="trailing"in t?t.trailing:p);var d=function(){var t=e-(gr()-a);if(0>=t){i&&Ot(i);var s=f;i=c=f=y,s&&(l=gr(),o=n.apply(u,r),c||i||(r=u=null))}else c=Dt(d,t)},g=function(){c&&Ot(c),i=c=f=y, (p||s!==e)&&(l=gr(),o=n.apply(u,r),c||i||(r=u=null))};return function(){if(r=arguments,a=gr(),u=this,f=p&&(c||!h),s===!1)var t=h&&!c;else{i||h||(l=a);var v=s-(a-l),y=0>=v;y?(i&&(i=Ot(i)),l=a,o=n.apply(u,r)):i||(i=Dt(g,v))}return y&&c?c=Ot(c):c||e===s||(c=Dt(d,e)),t&&(y=!0,o=n.apply(u,r)),!y||c||i||(r=u=null),o}}function qe(n){if(!On(n))throw new kt;var e=g(arguments,1);return Dt(function(){n.apply(y,e)},1)}function ze(n,e){if(!On(n))throw new kt;var t=g(arguments,2);return Dt(function(){n.apply(y,t)},e)}function We(n,e){if(!On(n))throw new kt;var t=function(){var r=t.cache,i=e?e.apply(this,arguments):w+arguments[0];return Mt.call(r,i)?r[i]:r[i]=n.apply(this,arguments)};return t.cache={},t}function $e(n){var e,t;if(!On(n))throw new kt;return function(){return e?t:(e=!0,t=n.apply(this,arguments),n=null,t)}}function Ge(n){return un(n,16,g(arguments,1))}function Ve(n){return un(n,32,null,g(arguments,1))}function Ye(n,e,t){var r=!0,i=!0;if(!On(n))throw new kt;return t===!1?r=!1:Rn(t)&&(r="leading"in t?t.leading:r,i="trailing"in t?t.trailing:i),K.leading=r,K.maxWait=e,K.trailing=i,Ue(n,e,K)}function Ke(n,e){return un(e,16,[n])}function He(n){return function(){return n}}function Xe(n,e,t){var r=typeof n;if(null==n||"function"==r)return b(n,e,t);if("object"!=r)return tt(n);var i=nr(n),o=i[0],a=n[o];return 1!=i.length||a!==a||Rn(a)?function(e){for(var t=i.length,r=!1;t--&&(r=nn(e[i[t]],n[i[t]],null,!0)););return r}:function(n){var e=n[o];return a===e&&(0!==a||1/a==1/e)}}function Qe(n){return null==n?"":xt(n).replace(ir,cn)}function Je(n){return n}function Ze(n,r,i){var o=!0,a=r&&wn(r);r&&(i||a.length)||(null==i&&(i=r),u=t,r=n,n=e,a=wn(r)),i===!1?o=!1:Rn(i)&&"chain"in i&&(o=i.chain);var u=n,c=On(u);Qn(a,function(e){var t=n[e]=r[e];c&&(u.prototype[e]=function(){var e=this.__chain__,r=this.__wrapped__,i=[r];Bt.apply(i,arguments);var a=t.apply(n,i);if(o||e){if(r===a&&Rn(a))return this;a=new u(a),a.__chain__=e}return a})})}function nt(){return n._=Ct,this}function et(){}function tt(n){return function(e){return e[n]}}function rt(n,e,t){var r=null==n,i=null==e;if(null==t&&("boolean"==typeof n&&i?(t=n,n=1):i||"boolean"!=typeof e||(t=e,i=!0)),r&&i&&(e=1),n=+n||0,i?(e=n,n=0):e=+e||0,t||n%1||e%1){var o=Kt();return Vt(n+o*(e-n+parseFloat("1e-"+((o+"").length-1))),e)}return tn(n,e)}function it(n,e){if(n){var t=n[e];return On(t)?n[e]():t}}function ot(n,t,r){var i=e.templateSettings;n=xt(n||""),r=ar({},r,i);var o,a=ar({},r.imports,i.imports),u=nr(a),c=$n(a),f=0,s=r.interpolate||L,p="__p += '",h=wt((r.escape||L).source+"|"+s.source+"|"+(s===R?I:L).source+"|"+(r.evaluate||L).source+"|$","g");n.replace(h,function(e,t,r,i,a,u){return r||(r=i),p+=n.slice(f,u).replace(B,l),t&&(p+="' +\n__e("+t+") +\n'"),a&&(o=!0,p+="';\n"+a+";\n__p += '"),r&&(p+="' +\n((__t = ("+r+")) == null ? '' : __t) +\n'"),f=u+e.length,e}),p+="';\n";var d=r.variable,g=d;g||(d="obj",p="with ("+d+") {\n"+p+"\n}\n"),p=(o?p.replace(E,""):p).replace(C,"$1").replace(N,"$1;"),p="function("+d+") {\n"+(g?"":d+" || ("+d+" = {});\n")+"var __t, __p = '', __e = _.escape"+(o?", __j = Array.prototype.join;\nfunction print() { __p += __j.call(arguments, '') }\n":";\n")+p+"return __p\n}";var v="\n/*\n//# sourceURL="+(r.sourceURL||"/lodash/template/source["+F++ +"]")+"\n*/";try{var m=yt(u,"return "+p+v).apply(y,c)}catch(b){throw b.source=p,b}return t?m(t):(m.source=p,m)}function at(n,e,t){n=(n=+n)>-1?n:0;var r=-1,i=dt(n);for(e=b(e,t,1);++r/g,evaluate:/<%([\s\S]+?)%>/g,interpolate:R,variable:"",imports:{_:e}},Ut||(m=function(){function e(){}return function(t){if(Rn(t)){e.prototype=t;var r=new e;e.prototype=null}return r||n.Object()}}());var Qt=Pt?function(n,e){H.value=e,Pt(n,"__bindData__",H),H.value=null}:et,Jt=qt||function(n){return n&&"object"==typeof n&&"number"==typeof n.length&&Nt.call(n)==P||!1},Zt=function(n){var e,t=n,r=[];if(!t)return r;if(!X[typeof n])return r;for(e in t)Mt.call(t,e)&&r.push(e);return r},nr=$t?function(n){return Rn(n)?$t(n):[]}:Zt,er={"&":"&","<":"<",">":">",'"':""","'":"'"},tr=kn(er),rr=wt("("+nr(tr).join("|")+")","g"),ir=wt("["+nr(er).join("")+"]","g"),or=function(n,e,t){var r,i=n,o=i;if(!i)return o;var a=arguments,u=0,c="number"==typeof t?2:a.length;if(c>3&&"function"==typeof a[c-2])var f=b(a[--c-1],a[c--],2);else c>2&&"function"==typeof a[c-1]&&(f=a[--c]);for(;++u/g,S=RegExp("^["+j+"]*0+(?=.$)"),L=/($^)/,M=/\bthis\b/,B=/['\n\r\t\u2028\u2029\\]/g,D=["Array","Boolean","Date","Function","Math","Number","Object","RegExp","String","_","attachEvent","clearTimeout","isFinite","isNaN","parseInt","setTimeout"],F=0,A="[object Arguments]",P="[object Array]",U="[object Boolean]",q="[object Date]",z="[object Function]",W="[object Number]",$="[object Object]",G="[object RegExp]",V="[object String]",Y={};Y[z]=!1,Y[A]=Y[P]=Y[U]=Y[q]=Y[W]=Y[$]=Y[G]=Y[V]=!0;var K={leading:!1,maxWait:0,trailing:!1},H={configurable:!1,enumerable:!1,value:null,writable:!1},X={"boolean":!1,"function":!0,object:!0,number:!1,string:!1,undefined:!1},Q={"\\":"\\","'":"'","\n":"n","\r":"r"," ":"t","\u2028":"u2028","\u2029":"u2029"},J=X[typeof window]&&window||this,Z=X[typeof r]&&r&&!r.nodeType&&r,nn=X[typeof t]&&t&&!t.nodeType&&t,en=nn&&nn.exports===Z&&Z,tn=X[typeof e]&&e;!tn||tn.global!==tn&&tn.window!==tn||(J=tn);var rn=v();"function"==typeof n&&"object"==typeof n.amd&&n.amd?(J._=rn,n(function(){return rn})):Z&&nn?en?(nn.exports=rn)._=rn:Z._=rn:J._=rn}).call(this)}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{}],60:[function(n,e,t){var r=n("./lib");e.exports={Graph:r.Graph,json:n("./lib/json"),alg:n("./lib/alg"),version:r.version}},{"./lib":76,"./lib/alg":67,"./lib/json":77}],61:[function(n,e,t){function r(n){function e(o){i.has(r,o)||(r[o]=!0,t.push(o),i.each(n.successors(o),e),i.each(n.predecessors(o),e))}var t,r={},o=[];return i.each(n.nodes(),function(n){t=[],e(n),t.length&&o.push(t)}),o}var i=n("../lodash");e.exports=r},{"../lodash":78}],62:[function(n,e,t){function r(n,e,t){o.isArray(e)||(e=[e]);var r=[],a={};return o.each(e,function(e){if(!n.hasNode(e))throw new Error("Graph does not have node: "+e);i(n,e,"post"===t,a,r)}),r}function i(n,e,t,r,a){o.has(r,e)||(r[e]=!0,t||a.push(e),o.each(n.neighbors(e),function(e){i(n,e,t,r,a)}),t&&a.push(e))}var o=n("../lodash");e.exports=r},{"../lodash":78}],63:[function(n,e,t){function r(n,e,t){return o.transform(n.nodes(),function(r,o){r[o]=i(n,o,e,t)},{})}var i=n("./dijkstra"),o=n("../lodash");e.exports=r},{"../lodash":78,"./dijkstra":64}],64:[function(n,e,t){function r(n,e,t,r){return i(n,String(e),t||u,r||function(e){return n.outEdges(e)})}function i(n,e,t,r){var i,o,u={},c=new a,f=function(n){var e=n.v!==i?n.v:n.w,r=u[e],a=t(n),f=o.distance+a;if(0>a)throw new Error("dijkstra does not allow negative edge weights. Bad edge: "+n+" Weight: "+a);f0&&(i=c.removeMin(),o=u[i],o.distance!==Number.POSITIVE_INFINITY);)r(i).forEach(f);return u}var o=n("../lodash"),a=n("../data/priority-queue");e.exports=r;var u=o.constant(1)},{"../data/priority-queue":74,"../lodash":78}],65:[function(n,e,t){function r(n){return i.filter(o(n),function(n){return n.length>1})}var i=n("../lodash"),o=n("./tarjan");e.exports=r},{"../lodash":78,"./tarjan":72}],66:[function(n,e,t){function r(n,e,t){return i(n,e||a,t||function(e){return n.outEdges(e)})}function i(n,e,t){var r={},i=n.nodes();return i.forEach(function(n){r[n]={},r[n][n]={distance:0},i.forEach(function(e){n!==e&&(r[n][e]={distance:Number.POSITIVE_INFINITY})}),t(n).forEach(function(t){var i=t.v===n?t.w:t.v,o=e(t);r[n][i]={distance:o,predecessor:n}})}),i.forEach(function(n){var e=r[n];i.forEach(function(t){var o=r[t];i.forEach(function(t){var r=o[n],i=e[t],a=o[t],u=r.distance+i.distance;uo&&(c[t]=r,f.decrease(t,o))}}var r,u=new o,c={},f=new a;if(0===n.nodeCount())return u;i.each(n.nodes(),function(n){f.add(n,Number.POSITIVE_INFINITY),u.setNode(n)}),f.decrease(n.nodes()[0],0);for(var l=!1;f.size()>0;){if(r=f.removeMin(),i.has(c,r))u.setEdge(r,c[r]);else{if(l)throw new Error("Input graph is not connected: "+n);l=!0}n.nodeEdges(r).forEach(t)}return u}var i=n("../lodash"),o=n("../graph"),a=n("../data/priority-queue");e.exports=r},{"../data/priority-queue":74,"../graph":75,"../lodash":78}],72:[function(n,e,t){function r(n){function e(u){var c=o[u]={onStack:!0,lowlink:t,index:t++};if(r.push(u),n.successors(u).forEach(function(n){i.has(o,n)?o[n].onStack&&(c.lowlink=Math.min(c.lowlink,o[n].index)):(e(n),c.lowlink=Math.min(c.lowlink,o[n].lowlink))}),c.lowlink===c.index){var f,l=[];do f=r.pop(),o[f].onStack=!1,l.push(f);while(u!==f);a.push(l)}}var t=0,r=[],o={},a=[];return n.nodes().forEach(function(n){i.has(o,n)||e(n)}),a}var i=n("../lodash");e.exports=r},{"../lodash":78}],73:[function(n,e,t){function r(n){function e(u){if(o.has(r,u))throw new i;o.has(t,u)||(r[u]=!0,t[u]=!0,o.each(n.predecessors(u),e),delete r[u],a.push(u))}var t={},r={},a=[];if(o.each(n.sinks(),e),o.size(t)!==n.nodeCount())throw new i;return a}function i(){}var o=n("../lodash");e.exports=r,r.CycleException=i},{"../lodash":78}],74:[function(n,e,t){function r(){this._arr=[],this._keyIndices={}}var i=n("../lodash");e.exports=r,r.prototype.size=function(){return this._arr.length},r.prototype.keys=function(){return this._arr.map(function(n){return n.key})},r.prototype.has=function(n){return i.has(this._keyIndices,n)},r.prototype.priority=function(n){var e=this._keyIndices[n];return void 0!==e?this._arr[e].priority:void 0},r.prototype.min=function(){if(0===this.size())throw new Error("Queue underflow");return this._arr[0].key},r.prototype.add=function(n,e){var t=this._keyIndices;if(n=String(n),!i.has(t,n)){var r=this._arr,o=r.length;return t[n]=o,r.push({key:n,priority:e}),this._decrease(o),!0}return!1},r.prototype.removeMin=function(){this._swap(0,this._arr.length-1);var n=this._arr.pop();return delete this._keyIndices[n.key],this._heapify(0),n.key},r.prototype.decrease=function(n,e){var t=this._keyIndices[n];if(e>this._arr[t].priority)throw new Error("New priority is greater than current priority. Key: "+n+" Old: "+this._arr[t].priority+" New: "+e);this._arr[t].priority=e,this._decrease(t)},r.prototype._heapify=function(n){var e=this._arr,t=2*n,r=t+1,i=n;t>1,!(t[e].priorityt){var i=e;e=t,t=i}return e+p+t+p+(f.isUndefined(r)?l:r)}function u(n,e,t,r){if(!n&&e>t){var i=e;e=t,t=i}var o={v:e,w:t};return r&&(o.name=r),o}function c(n,e){return a(n,e.v,e.w,e.name)}var f=n("./lodash");e.exports=r;var l="\x00",s="\x00",p="";r.prototype._nodeCount=0,r.prototype._edgeCount=0,r.prototype.isDirected=function(){return this._isDirected},r.prototype.isMultigraph=function(){return this._isMultigraph},r.prototype.isCompound=function(){return this._isCompound},r.prototype.setGraph=function(n){return this._label=n,this},r.prototype.graph=function(){return this._label},r.prototype.setDefaultNodeLabel=function(n){return f.isFunction(n)||(n=f.constant(n)),this._defaultNodeLabelFn=n,this},r.prototype.nodeCount=function(){return this._nodeCount},r.prototype.nodes=function(){return f.keys(this._nodes)},r.prototype.sources=function(){return f.filter(this.nodes(),function(n){return f.isEmpty(this._in[n])},this)},r.prototype.sinks=function(){return f.filter(this.nodes(),function(n){return f.isEmpty(this._out[n])},this)},r.prototype.setNodes=function(n,e){var t=arguments;return f.each(n,function(n){t.length>1?this.setNode(n,e):this.setNode(n)},this),this},r.prototype.setNode=function(n,e){return f.has(this._nodes,n)?(arguments.length>1&&(this._nodes[n]=e),this):(this._nodes[n]=arguments.length>1?e:this._defaultNodeLabelFn(n),this._isCompound&&(this._parent[n]=s,this._children[n]={},this._children[s][n]=!0),this._in[n]={},this._preds[n]={},this._out[n]={},this._sucs[n]={},++this._nodeCount,this)},r.prototype.node=function(n){return this._nodes[n]},r.prototype.hasNode=function(n){return f.has(this._nodes,n)},r.prototype.removeNode=function(n){var e=this;if(f.has(this._nodes,n)){var t=function(n){e.removeEdge(e._edgeObjs[n])};delete this._nodes[n],this._isCompound&&(this._removeFromParentsChildList(n),delete this._parent[n],f.each(this.children(n),function(n){this.setParent(n)},this),delete this._children[n]),f.each(f.keys(this._in[n]),t),delete this._in[n],delete this._preds[n],f.each(f.keys(this._out[n]),t),delete this._out[n],delete this._sucs[n],--this._nodeCount}return this},r.prototype.setParent=function(n,e){if(!this._isCompound)throw new Error("Cannot set parent in a non-compound graph");if(f.isUndefined(e))e=s;else{e+="";for(var t=e;!f.isUndefined(t);t=this.parent(t))if(t===n)throw new Error("Setting "+e+" as parent of "+n+" would create create a cycle");this.setNode(e)}return this.setNode(n),this._removeFromParentsChildList(n),this._parent[n]=e,this._children[e][n]=!0,this},r.prototype._removeFromParentsChildList=function(n){delete this._children[this._parent[n]][n]},r.prototype.parent=function(n){if(this._isCompound){var e=this._parent[n];if(e!==s)return e}},r.prototype.children=function(n){if(f.isUndefined(n)&&(n=s),this._isCompound){var e=this._children[n];if(e)return f.keys(e)}else{if(n===s)return this.nodes();if(this.hasNode(n))return[]}},r.prototype.predecessors=function(n){var e=this._preds[n];return e?f.keys(e):void 0},r.prototype.successors=function(n){var e=this._sucs[n];return e?f.keys(e):void 0},r.prototype.neighbors=function(n){var e=this.predecessors(n);return e?f.union(e,this.successors(n)):void 0},r.prototype.setDefaultEdgeLabel=function(n){return f.isFunction(n)||(n=f.constant(n)),this._defaultEdgeLabelFn=n,this},r.prototype.edgeCount=function(){return this._edgeCount},r.prototype.edges=function(){return f.values(this._edgeObjs)},r.prototype.setPath=function(n,e){var t=this,r=arguments;return f.reduce(n,function(n,i){return r.length>1?t.setEdge(n,i,e):t.setEdge(n,i),i}),this},r.prototype.setEdge=function(){var n,e,t,r,o=!1;f.isPlainObject(arguments[0])?(n=arguments[0].v,e=arguments[0].w,t=arguments[0].name,2===arguments.length&&(r=arguments[1],o=!0)):(n=arguments[0],e=arguments[1],t=arguments[3],arguments.length>2&&(r=arguments[2],o=!0)),n=""+n,e=""+e,f.isUndefined(t)||(t=""+t);var c=a(this._isDirected,n,e,t);if(f.has(this._edgeLabels,c))return o&&(this._edgeLabels[c]=r),this;if(!f.isUndefined(t)&&!this._isMultigraph)throw new Error("Cannot set a named edge when isMultigraph = false");this.setNode(n),this.setNode(e),this._edgeLabels[c]=o?r:this._defaultEdgeLabelFn(n,e,t);var l=u(this._isDirected,n,e,t);return n=l.v,e=l.w,Object.freeze(l),this._edgeObjs[c]=l,i(this._preds[e],n),i(this._sucs[n],e),this._in[e][c]=l,this._out[n][c]=l,this._edgeCount++,this},r.prototype.edge=function(n,e,t){var r=1===arguments.length?c(this._isDirected,arguments[0]):a(this._isDirected,n,e,t);return this._edgeLabels[r]},r.prototype.hasEdge=function(n,e,t){var r=1===arguments.length?c(this._isDirected,arguments[0]):a(this._isDirected,n,e,t);return f.has(this._edgeLabels,r)},r.prototype.removeEdge=function(n,e,t){var r=1===arguments.length?c(this._isDirected,arguments[0]):a(this._isDirected,n,e,t),i=this._edgeObjs[r];return i&&(n=i.v,e=i.w,delete this._edgeLabels[r],delete this._edgeObjs[r],o(this._preds[e],n),o(this._sucs[n],e),delete this._in[e][r],delete this._out[n][r],this._edgeCount--),this},r.prototype.inEdges=function(n,e){var t=this._in[n];if(t){var r=f.values(t);return e?f.filter(r,function(n){return n.v===e}):r}},r.prototype.outEdges=function(n,e){var t=this._out[n];if(t){var r=f.values(t);return e?f.filter(r,function(n){return n.w===e}):r}},r.prototype.nodeEdges=function(n,e){var t=this.inEdges(n,e);return t?t.concat(this.outEdges(n,e)):void 0}},{"./lodash":78}],76:[function(n,e,t){e.exports={Graph:n("./graph"),version:n("./version")}},{"./graph":75,"./version":79}],77:[function(n,e,t){function r(n){var e={options:{directed:n.isDirected(),multigraph:n.isMultigraph(),compound:n.isCompound()},nodes:i(n),edges:o(n)};return u.isUndefined(n.graph())||(e.value=u.clone(n.graph())),e}function i(n){return u.map(n.nodes(),function(e){var t=n.node(e),r=n.parent(e),i={v:e};return u.isUndefined(t)||(i.value=t),u.isUndefined(r)||(i.parent=r),i})}function o(n){return u.map(n.edges(),function(e){var t=n.edge(e),r={v:e.v,w:e.w};return u.isUndefined(e.name)||(r.name=e.name),u.isUndefined(t)||(r.value=t),r})}function a(n){var e=new c(n.options).setGraph(n.value);return u.each(n.nodes,function(n){e.setNode(n.v,n.value),n.parent&&e.setParent(n.v,n.parent)}),u.each(n.edges,function(n){e.setEdge({v:n.v,w:n.w,name:n.name},n.value)}),e}var u=n("./lodash"),c=n("./graph");e.exports={write:r,read:a}},{"./graph":75,"./lodash":78}],78:[function(n,e,t){var r;if("function"==typeof n)try{r=n("lodash")}catch(i){}r||(r=window._),e.exports=r},{lodash:80}],79:[function(n,e,t){e.exports="1.0.3"},{}],80:[function(e,t,r){(function(e){(function(){function i(n,e,t){for(var r=(t||0)-1,i=n?n.length:0;++r-1?0:-1:n?0:-1}function a(n){var e=this.cache,t=typeof n;if("boolean"==t||null==n)e[n]=!0;else{"number"!=t&&"string"!=t&&(t="object");var r="number"==t?n:w+n,i=e[t]||(e[t]={});"object"==t?(i[r]||(i[r]=[])).push(n):i[r]=!0}}function u(n){return n.charCodeAt(0)}function c(n,e){for(var t=n.criteria,r=e.criteria,i=-1,o=t.length;++iu||"undefined"==typeof a)return 1;if(u>a||"undefined"==typeof u)return-1}}return n.index-e.index}function f(n){var e=-1,t=n.length,r=n[0],i=n[t/2|0],o=n[t-1];if(r&&"object"==typeof r&&i&&"object"==typeof i&&o&&"object"==typeof o)return!1;var u=p();u["false"]=u["null"]=u["true"]=u.undefined=!1;var c=p();for(c.array=n,c.cache=u,c.push=a;++ei?0:i);++r=x&&r===i,c=[];if(u){var l=f(e);l?(r=o,e=l):u=!1}for(;++t-1:void 0});return i.pop(),o.pop(),m&&(h(i),h(o)),a}function en(n,e,t,r,i){(Jt(e)?Qn:cr)(e,function(e,o){var a,u,c=e,f=n[o];if(e&&((u=Jt(e))||fr(e))){for(var l=r.length;l--;)if(a=r[l]==e){f=i[l];break}if(!a){var s;t&&(c=t(f,e),(s="undefined"!=typeof c)&&(f=c)),s||(f=u?Jt(f)?f:[]:fr(f)?f:{}),r.push(e),i.push(f),s||en(f,e,t,r,i)}}else t&&(c=t(f,e),"undefined"==typeof c&&(c=e)),"undefined"!=typeof c&&(f=c);n[o]=f})}function tn(n,e){return n+Rt(Kt()*(e-n+1))}function on(n,e,t){var r=-1,a=fn(),u=n?n.length:0,c=[],l=!e&&u>=x&&a===i,p=t||l?s():c;if(l){var g=f(p);a=o,p=g}for(;++r", "keywords": [ @@ -54,4 +54,4 @@ "url": "https://github.com/cpettitt/dagre-d3.git" }, "license": "MIT" -} \ No newline at end of file +}