From d9eb635b55279f2ce59ba62eb6fe464620d6703a Mon Sep 17 00:00:00 2001 From: alihanokka Date: Tue, 2 Apr 2019 15:25:52 +0300 Subject: [PATCH] Code polishing before release * Altered demo file * Re-packed the code to eliminate redundant dependencies (webpack version failure) --- cytoscape-avsdf.js | 4838 +----------------------- demo.html | 125 +- src/layout/AVSDF.js | 22 +- src/layout/continuous-base/defaults.js | 5 +- src/layout/continuous-base/index.js | 26 +- src/layout/continuous-base/make-bb.js | 2 +- src/layout/continuous-base/tick.js | 3 +- 7 files changed, 147 insertions(+), 4874 deletions(-) diff --git a/cytoscape-avsdf.js b/cytoscape-avsdf.js index 8bfa2d62..66f6e53e 100644 --- a/cytoscape-avsdf.js +++ b/cytoscape-avsdf.js @@ -1,13 +1,13 @@ (function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') - module.exports = factory(); + module.exports = factory(require("avsdf-base")); else if(typeof define === 'function' && define.amd) - define([], factory); + define(["avsdf-base"], factory); else if(typeof exports === 'object') - exports["cytoscapeAvsdf"] = factory(); + exports["cytoscapeAvsdf"] = factory(require("avsdf-base")); else - root["cytoscapeAvsdf"] = factory(); -})(this, function() { + root["cytoscapeAvsdf"] = factory(root["avsdfBase"]); +})(this, function(__WEBPACK_EXTERNAL_MODULE_0__) { return /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; @@ -78,4772 +78,9 @@ return /******/ (function(modules) { // webpackBootstrap /************************************************************************/ /******/ ([ /* 0 */ -/***/ (function(module, exports, __webpack_require__) { - -(function webpackUniversalModuleDefinition(root, factory) { - if(true) - module.exports = factory(); - else if(typeof define === 'function' && define.amd) - define([], factory); - else if(typeof exports === 'object') - exports["avsdfBase"] = factory(); - else - root["avsdfBase"] = factory(); -})(window, function() { -return /******/ (function(modules) { // webpackBootstrap -/******/ // The module cache -/******/ var installedModules = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ -/******/ // Check if module is in cache -/******/ if(installedModules[moduleId]) { -/******/ return installedModules[moduleId].exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = installedModules[moduleId] = { -/******/ i: moduleId, -/******/ l: false, -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); -/******/ -/******/ // Flag the module as loaded -/******/ module.l = true; -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/******/ -/******/ // expose the modules object (__webpack_modules__) -/******/ __webpack_require__.m = modules; -/******/ -/******/ // expose the module cache -/******/ __webpack_require__.c = installedModules; -/******/ -/******/ // define getter function for harmony exports -/******/ __webpack_require__.d = function(exports, name, getter) { -/******/ if(!__webpack_require__.o(exports, name)) { -/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); -/******/ } -/******/ }; -/******/ -/******/ // define __esModule on exports -/******/ __webpack_require__.r = function(exports) { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ -/******/ // create a fake namespace object -/******/ // mode & 1: value is a module id, require it -/******/ // mode & 2: merge all properties of value into the ns -/******/ // mode & 4: return value when already ns object -/******/ // mode & 8|1: behave like require -/******/ __webpack_require__.t = function(value, mode) { -/******/ if(mode & 1) value = __webpack_require__(value); -/******/ if(mode & 8) return value; -/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; -/******/ var ns = Object.create(null); -/******/ __webpack_require__.r(ns); -/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); -/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); -/******/ return ns; -/******/ }; -/******/ -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = function(module) { -/******/ var getter = module && module.__esModule ? -/******/ function getDefault() { return module['default']; } : -/******/ function getModuleExports() { return module; }; -/******/ __webpack_require__.d(getter, 'a', getter); -/******/ return getter; -/******/ }; -/******/ -/******/ // Object.prototype.hasOwnProperty.call -/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; -/******/ -/******/ // __webpack_public_path__ -/******/ __webpack_require__.p = ""; -/******/ -/******/ -/******/ // Load entry module and return exports -/******/ return __webpack_require__(__webpack_require__.s = 0); -/******/ }) -/************************************************************************/ -/******/ ([ -/* 0 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -let avsdfBase = {}; - -avsdfBase.layoutBase = __webpack_require__(1); -avsdfBase.AVSDFConstants = __webpack_require__(2); -avsdfBase.AVSDFEdge = __webpack_require__(3); -avsdfBase.AVSDFCircle = __webpack_require__(4); -avsdfBase.AVSDFLayout = __webpack_require__(5); -avsdfBase.AVSDFNode = __webpack_require__(6); - -module.exports = avsdfBase; - -/***/ }), -/* 1 */ -/***/ (function(module, exports, __webpack_require__) { - -(function webpackUniversalModuleDefinition(root, factory) { - if(true) - module.exports = factory(); - else {} -})(window, function() { -return /******/ (function(modules) { // webpackBootstrap -/******/ // The module cache -/******/ var installedModules = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ -/******/ // Check if module is in cache -/******/ if(installedModules[moduleId]) { -/******/ return installedModules[moduleId].exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = installedModules[moduleId] = { -/******/ i: moduleId, -/******/ l: false, -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); -/******/ -/******/ // Flag the module as loaded -/******/ module.l = true; -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/******/ -/******/ // expose the modules object (__webpack_modules__) -/******/ __webpack_require__.m = modules; -/******/ -/******/ // expose the module cache -/******/ __webpack_require__.c = installedModules; -/******/ -/******/ // define getter function for harmony exports -/******/ __webpack_require__.d = function(exports, name, getter) { -/******/ if(!__webpack_require__.o(exports, name)) { -/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); -/******/ } -/******/ }; -/******/ -/******/ // define __esModule on exports -/******/ __webpack_require__.r = function(exports) { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ -/******/ // create a fake namespace object -/******/ // mode & 1: value is a module id, require it -/******/ // mode & 2: merge all properties of value into the ns -/******/ // mode & 4: return value when already ns object -/******/ // mode & 8|1: behave like require -/******/ __webpack_require__.t = function(value, mode) { -/******/ if(mode & 1) value = __webpack_require__(value); -/******/ if(mode & 8) return value; -/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; -/******/ var ns = Object.create(null); -/******/ __webpack_require__.r(ns); -/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); -/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); -/******/ return ns; -/******/ }; -/******/ -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = function(module) { -/******/ var getter = module && module.__esModule ? -/******/ function getDefault() { return module['default']; } : -/******/ function getModuleExports() { return module; }; -/******/ __webpack_require__.d(getter, 'a', getter); -/******/ return getter; -/******/ }; -/******/ -/******/ // Object.prototype.hasOwnProperty.call -/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; -/******/ -/******/ // __webpack_public_path__ -/******/ __webpack_require__.p = ""; -/******/ -/******/ -/******/ // Load entry module and return exports -/******/ return __webpack_require__(__webpack_require__.s = 0); -/******/ }) -/************************************************************************/ -/******/ ([ -/* 0 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -let layoutBase = function () { - return; -}; - -layoutBase.FDLayout = __webpack_require__(1); -layoutBase.FDLayoutConstants = __webpack_require__(22); -layoutBase.FDLayoutEdge = __webpack_require__(23); -layoutBase.FDLayoutNode = __webpack_require__(24); -layoutBase.DimensionD = __webpack_require__(25); -layoutBase.HashMap = __webpack_require__(4); -layoutBase.HashSet = __webpack_require__(17); -layoutBase.IGeometry = __webpack_require__(9); -layoutBase.IMath = __webpack_require__(10); -layoutBase.Integer = __webpack_require__(12); -layoutBase.Point = __webpack_require__(18); -layoutBase.PointD = __webpack_require__(16); -layoutBase.RandomSeed = __webpack_require__(15); -layoutBase.RectangleD = __webpack_require__(14); -layoutBase.Transform = __webpack_require__(20); -layoutBase.UniqueIDGeneretor = __webpack_require__(5); -layoutBase.Quicksort = __webpack_require__(26); -layoutBase.LinkedList = __webpack_require__(19); -layoutBase.LGraphObject = __webpack_require__(8); -layoutBase.LGraph = __webpack_require__(11); -layoutBase.LEdge = __webpack_require__(7); -layoutBase.LGraphManager = __webpack_require__(6); -layoutBase.LNode = __webpack_require__(13); -layoutBase.Layout = __webpack_require__(2); -layoutBase.LayoutConstants = __webpack_require__(3); - -module.exports = layoutBase; - -/***/ }), -/* 1 */ -/***/ (function(module, exports, __webpack_require__) { - -var Layout = __webpack_require__(2); -var FDLayoutConstants = __webpack_require__(22); -var LayoutConstants = __webpack_require__(3); -var IGeometry = __webpack_require__(9); -var IMath = __webpack_require__(10); - -function FDLayout() { - Layout.call(this); - - this.useSmartIdealEdgeLengthCalculation = FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION; - this.idealEdgeLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH; - this.springConstant = FDLayoutConstants.DEFAULT_SPRING_STRENGTH; - this.repulsionConstant = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH; - this.gravityConstant = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH; - this.compoundGravityConstant = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH; - this.gravityRangeFactor = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR; - this.compoundGravityRangeFactor = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR; - this.displacementThresholdPerNode = 3.0 * FDLayoutConstants.DEFAULT_EDGE_LENGTH / 100; - this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL; - this.initialCoolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL; - this.totalDisplacement = 0.0; - this.oldTotalDisplacement = 0.0; - this.maxIterations = FDLayoutConstants.MAX_ITERATIONS; -} - -FDLayout.prototype = Object.create(Layout.prototype); - -for (var prop in Layout) { - FDLayout[prop] = Layout[prop]; -} - -FDLayout.prototype.initParameters = function () { - Layout.prototype.initParameters.call(this, arguments); - - if (this.layoutQuality == LayoutConstants.DRAFT_QUALITY) { - this.displacementThresholdPerNode += 0.30; - this.maxIterations *= 0.8; - } else if (this.layoutQuality == LayoutConstants.PROOF_QUALITY) { - this.displacementThresholdPerNode -= 0.30; - this.maxIterations *= 1.2; - } - - this.totalIterations = 0; - this.notAnimatedIterations = 0; - - this.useFRGridVariant = FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION; - - this.grid = []; -}; - -FDLayout.prototype.calcIdealEdgeLengths = function () { - var edge; - var lcaDepth; - var source; - var target; - var sizeOfSourceInLca; - var sizeOfTargetInLca; - - var allEdges = this.getGraphManager().getAllEdges(); - for (var i = 0; i < allEdges.length; i++) { - edge = allEdges[i]; - - edge.idealLength = this.idealEdgeLength; - - if (edge.isInterGraph) { - source = edge.getSource(); - target = edge.getTarget(); - - sizeOfSourceInLca = edge.getSourceInLca().getEstimatedSize(); - sizeOfTargetInLca = edge.getTargetInLca().getEstimatedSize(); - - if (this.useSmartIdealEdgeLengthCalculation) { - edge.idealLength += sizeOfSourceInLca + sizeOfTargetInLca - 2 * LayoutConstants.SIMPLE_NODE_SIZE; - } - - lcaDepth = edge.getLca().getInclusionTreeDepth(); - - edge.idealLength += FDLayoutConstants.DEFAULT_EDGE_LENGTH * FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR * (source.getInclusionTreeDepth() + target.getInclusionTreeDepth() - 2 * lcaDepth); - } - } -}; - -FDLayout.prototype.initSpringEmbedder = function () { - - if (this.incremental) { - this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL; - } else { - this.coolingFactor = 1.0; - this.initialCoolingFactor = 1.0; - this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT; - } - - this.maxIterations = Math.max(this.getAllNodes().length * 5, this.maxIterations); - - this.totalDisplacementThreshold = this.displacementThresholdPerNode * this.getAllNodes().length; - - this.repulsionRange = this.calcRepulsionRange(); -}; - -FDLayout.prototype.calcSpringForces = function () { - var lEdges = this.getAllEdges(); - var edge; - - for (var i = 0; i < lEdges.length; i++) { - edge = lEdges[i]; - - this.calcSpringForce(edge, edge.idealLength); - } -}; - -FDLayout.prototype.calcRepulsionForces = function (gridUpdateAllowed = true, forceToNodeSurroundingUpdate = false) { - var i, j; - var nodeA, nodeB; - var lNodes = this.getAllNodes(); - var processedNodeSet; - - if (this.useFRGridVariant) { - if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed) { - this.updateGrid(); - } - - processedNodeSet = new Set(); - - // calculate repulsion forces between each nodes and its surrounding - for (i = 0; i < lNodes.length; i++) { - nodeA = lNodes[i]; - this.calculateRepulsionForceOfANode(nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate); - processedNodeSet.add(nodeA); - } - } else { - for (i = 0; i < lNodes.length; i++) { - nodeA = lNodes[i]; - - for (j = i + 1; j < lNodes.length; j++) { - nodeB = lNodes[j]; - - // If both nodes are not members of the same graph, skip. - if (nodeA.getOwner() != nodeB.getOwner()) { - continue; - } - - this.calcRepulsionForce(nodeA, nodeB); - } - } - } -}; - -FDLayout.prototype.calcGravitationalForces = function () { - var node; - var lNodes = this.getAllNodesToApplyGravitation(); - - for (var i = 0; i < lNodes.length; i++) { - node = lNodes[i]; - this.calcGravitationalForce(node); - } -}; - -FDLayout.prototype.moveNodes = function () { - var lNodes = this.getAllNodes(); - var node; - - for (var i = 0; i < lNodes.length; i++) { - node = lNodes[i]; - node.move(); - } -}; - -FDLayout.prototype.calcSpringForce = function (edge, idealLength) { - var sourceNode = edge.getSource(); - var targetNode = edge.getTarget(); - - var length; - var springForce; - var springForceX; - var springForceY; - - // Update edge length - if (this.uniformLeafNodeSizes && sourceNode.getChild() == null && targetNode.getChild() == null) { - edge.updateLengthSimple(); - } else { - edge.updateLength(); - - if (edge.isOverlapingSourceAndTarget) { - return; - } - } - - length = edge.getLength(); - - // Calculate spring forces - springForce = this.springConstant * (length - idealLength); - - // Project force onto x and y axes - springForceX = springForce * (edge.lengthX / length); - springForceY = springForce * (edge.lengthY / length); - - // Apply forces on the end nodes - sourceNode.springForceX += springForceX; - sourceNode.springForceY += springForceY; - targetNode.springForceX -= springForceX; - targetNode.springForceY -= springForceY; -}; - -FDLayout.prototype.calcRepulsionForce = function (nodeA, nodeB) { - var rectA = nodeA.getRect(); - var rectB = nodeB.getRect(); - var overlapAmount = new Array(2); - var clipPoints = new Array(4); - var distanceX; - var distanceY; - var distanceSquared; - var distance; - var repulsionForce; - var repulsionForceX; - var repulsionForceY; - - if (rectA.intersects(rectB)) // two nodes overlap - { - // calculate separation amount in x and y directions - IGeometry.calcSeparationAmount(rectA, rectB, overlapAmount, FDLayoutConstants.DEFAULT_EDGE_LENGTH / 2.0); - - repulsionForceX = 2 * overlapAmount[0]; - repulsionForceY = 2 * overlapAmount[1]; - - var childrenConstant = nodeA.noOfChildren * nodeB.noOfChildren / (nodeA.noOfChildren + nodeB.noOfChildren); - - // Apply forces on the two nodes - nodeA.repulsionForceX -= childrenConstant * repulsionForceX; - nodeA.repulsionForceY -= childrenConstant * repulsionForceY; - nodeB.repulsionForceX += childrenConstant * repulsionForceX; - nodeB.repulsionForceY += childrenConstant * repulsionForceY; - } else // no overlap - { - // calculate distance - - if (this.uniformLeafNodeSizes && nodeA.getChild() == null && nodeB.getChild() == null) // simply base repulsion on distance of node centers - { - distanceX = rectB.getCenterX() - rectA.getCenterX(); - distanceY = rectB.getCenterY() - rectA.getCenterY(); - } else // use clipping points - { - IGeometry.getIntersection(rectA, rectB, clipPoints); - - distanceX = clipPoints[2] - clipPoints[0]; - distanceY = clipPoints[3] - clipPoints[1]; - } - - // No repulsion range. FR grid variant should take care of this. - if (Math.abs(distanceX) < FDLayoutConstants.MIN_REPULSION_DIST) { - distanceX = IMath.sign(distanceX) * FDLayoutConstants.MIN_REPULSION_DIST; - } - - if (Math.abs(distanceY) < FDLayoutConstants.MIN_REPULSION_DIST) { - distanceY = IMath.sign(distanceY) * FDLayoutConstants.MIN_REPULSION_DIST; - } - - distanceSquared = distanceX * distanceX + distanceY * distanceY; - distance = Math.sqrt(distanceSquared); - - repulsionForce = this.repulsionConstant * nodeA.noOfChildren * nodeB.noOfChildren / distanceSquared; - - // Project force onto x and y axes - repulsionForceX = repulsionForce * distanceX / distance; - repulsionForceY = repulsionForce * distanceY / distance; - - // Apply forces on the two nodes - nodeA.repulsionForceX -= repulsionForceX; - nodeA.repulsionForceY -= repulsionForceY; - nodeB.repulsionForceX += repulsionForceX; - nodeB.repulsionForceY += repulsionForceY; - } -}; - -FDLayout.prototype.calcGravitationalForce = function (node) { - var ownerGraph; - var ownerCenterX; - var ownerCenterY; - var distanceX; - var distanceY; - var absDistanceX; - var absDistanceY; - var estimatedSize; - ownerGraph = node.getOwner(); - - ownerCenterX = (ownerGraph.getRight() + ownerGraph.getLeft()) / 2; - ownerCenterY = (ownerGraph.getTop() + ownerGraph.getBottom()) / 2; - distanceX = node.getCenterX() - ownerCenterX; - distanceY = node.getCenterY() - ownerCenterY; - absDistanceX = Math.abs(distanceX) + node.getWidth() / 2; - absDistanceY = Math.abs(distanceY) + node.getHeight() / 2; - - if (node.getOwner() == this.graphManager.getRoot()) // in the root graph - { - estimatedSize = ownerGraph.getEstimatedSize() * this.gravityRangeFactor; - - if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) { - node.gravitationForceX = -this.gravityConstant * distanceX; - node.gravitationForceY = -this.gravityConstant * distanceY; - } - } else // inside a compound - { - estimatedSize = ownerGraph.getEstimatedSize() * this.compoundGravityRangeFactor; - - if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) { - node.gravitationForceX = -this.gravityConstant * distanceX * this.compoundGravityConstant; - node.gravitationForceY = -this.gravityConstant * distanceY * this.compoundGravityConstant; - } - } -}; - -FDLayout.prototype.isConverged = function () { - var converged; - var oscilating = false; - - if (this.totalIterations > this.maxIterations / 3) { - oscilating = Math.abs(this.totalDisplacement - this.oldTotalDisplacement) < 2; - } - - converged = this.totalDisplacement < this.totalDisplacementThreshold; - - this.oldTotalDisplacement = this.totalDisplacement; - - return converged || oscilating; -}; - -FDLayout.prototype.animate = function () { - if (this.animationDuringLayout && !this.isSubLayout) { - if (this.notAnimatedIterations == this.animationPeriod) { - this.update(); - this.notAnimatedIterations = 0; - } else { - this.notAnimatedIterations++; - } - } -}; - -//This method calculates the number of children (weight) for all nodes -FDLayout.prototype.calcNoOfChildrenForAllNodes = function () { - var node; - var allNodes = this.graphManager.getAllNodes(); - - for (var i = 0; i < allNodes.length; i++) { - node = allNodes[i]; - node.noOfChildren = node.getNoOfChildren(); - } -}; - -// ----------------------------------------------------------------------------- -// Section: FR-Grid Variant Repulsion Force Calculation -// ----------------------------------------------------------------------------- - -FDLayout.prototype.calcGrid = function (graph) { - - var sizeX = 0; - var sizeY = 0; - - sizeX = parseInt(Math.ceil((graph.getRight() - graph.getLeft()) / this.repulsionRange)); - sizeY = parseInt(Math.ceil((graph.getBottom() - graph.getTop()) / this.repulsionRange)); - - var grid = new Array(sizeX); - - for (var i = 0; i < sizeX; i++) { - grid[i] = new Array(sizeY); - } - - for (var i = 0; i < sizeX; i++) { - for (var j = 0; j < sizeY; j++) { - grid[i][j] = new Array(); - } - } - - return grid; -}; - -FDLayout.prototype.addNodeToGrid = function (v, left, top) { - - var startX = 0; - var finishX = 0; - var startY = 0; - var finishY = 0; - - startX = parseInt(Math.floor((v.getRect().x - left) / this.repulsionRange)); - finishX = parseInt(Math.floor((v.getRect().width + v.getRect().x - left) / this.repulsionRange)); - startY = parseInt(Math.floor((v.getRect().y - top) / this.repulsionRange)); - finishY = parseInt(Math.floor((v.getRect().height + v.getRect().y - top) / this.repulsionRange)); - - for (var i = startX; i <= finishX; i++) { - for (var j = startY; j <= finishY; j++) { - this.grid[i][j].push(v); - v.setGridCoordinates(startX, finishX, startY, finishY); - } - } -}; - -FDLayout.prototype.updateGrid = function () { - var i; - var nodeA; - var lNodes = this.getAllNodes(); - - this.grid = this.calcGrid(this.graphManager.getRoot()); - - // put all nodes to proper grid cells - for (i = 0; i < lNodes.length; i++) { - nodeA = lNodes[i]; - this.addNodeToGrid(nodeA, this.graphManager.getRoot().getLeft(), this.graphManager.getRoot().getTop()); - } -}; - -FDLayout.prototype.calculateRepulsionForceOfANode = function (nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate) { - - if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed || forceToNodeSurroundingUpdate) { - var surrounding = new Set(); - nodeA.surrounding = new Array(); - var nodeB; - var grid = this.grid; - - for (var i = nodeA.startX - 1; i < nodeA.finishX + 2; i++) { - for (var j = nodeA.startY - 1; j < nodeA.finishY + 2; j++) { - if (!(i < 0 || j < 0 || i >= grid.length || j >= grid[0].length)) { - for (var k = 0; k < grid[i][j].length; k++) { - nodeB = grid[i][j][k]; - - // If both nodes are not members of the same graph, - // or both nodes are the same, skip. - if (nodeA.getOwner() != nodeB.getOwner() || nodeA == nodeB) { - continue; - } - - // check if the repulsion force between - // nodeA and nodeB has already been calculated - if (!processedNodeSet.has(nodeB) && !surrounding.has(nodeB)) { - var distanceX = Math.abs(nodeA.getCenterX() - nodeB.getCenterX()) - (nodeA.getWidth() / 2 + nodeB.getWidth() / 2); - var distanceY = Math.abs(nodeA.getCenterY() - nodeB.getCenterY()) - (nodeA.getHeight() / 2 + nodeB.getHeight() / 2); - - // if the distance between nodeA and nodeB - // is less then calculation range - if (distanceX <= this.repulsionRange && distanceY <= this.repulsionRange) { - //then add nodeB to surrounding of nodeA - surrounding.add(nodeB); - } - } - } - } - } - } - - nodeA.surrounding = [...surrounding]; - } - for (i = 0; i < nodeA.surrounding.length; i++) { - this.calcRepulsionForce(nodeA, nodeA.surrounding[i]); - } -}; - -FDLayout.prototype.calcRepulsionRange = function () { - return 0.0; -}; - -module.exports = FDLayout; - -/***/ }), -/* 2 */ -/***/ (function(module, exports, __webpack_require__) { - -var LayoutConstants = __webpack_require__(3); -var HashMap = __webpack_require__(4); -var LGraphManager = __webpack_require__(6); -var LNode = __webpack_require__(13); -var LEdge = __webpack_require__(7); -var LGraph = __webpack_require__(11); -var PointD = __webpack_require__(16); -var Transform = __webpack_require__(20); -var Emitter = __webpack_require__(21); -var HashSet = __webpack_require__(17); - -function Layout(isRemoteUse) { - Emitter.call(this); - - //Layout Quality: 0:proof, 1:default, 2:draft - this.layoutQuality = LayoutConstants.DEFAULT_QUALITY; - //Whether layout should create bendpoints as needed or not - this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED; - //Whether layout should be incremental or not - this.incremental = LayoutConstants.DEFAULT_INCREMENTAL; - //Whether we animate from before to after layout node positions - this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT; - //Whether we animate the layout process or not - this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT; - //Number iterations that should be done between two successive animations - this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD; - /** - * Whether or not leaf nodes (non-compound nodes) are of uniform sizes. When - * they are, both spring and repulsion forces between two leaf nodes can be - * calculated without the expensive clipping point calculations, resulting - * in major speed-up. - */ - this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES; - /** - * This is used for creation of bendpoints by using dummy nodes and edges. - * Maps an LEdge to its dummy bendpoint path. - */ - this.edgeToDummyNodes = new HashMap(); - this.graphManager = new LGraphManager(this); - this.isLayoutFinished = false; - this.isSubLayout = false; - this.isRemoteUse = false; - - if (isRemoteUse != null) { - this.isRemoteUse = isRemoteUse; - } -} - -Layout.RANDOM_SEED = 1; - -Layout.prototype = Object.create(Emitter.prototype); - -Layout.prototype.getGraphManager = function () { - return this.graphManager; -}; - -Layout.prototype.getAllNodes = function () { - return this.graphManager.getAllNodes(); -}; - -Layout.prototype.getAllEdges = function () { - return this.graphManager.getAllEdges(); -}; - -Layout.prototype.getAllNodesToApplyGravitation = function () { - return this.graphManager.getAllNodesToApplyGravitation(); -}; - -Layout.prototype.newGraphManager = function () { - var gm = new LGraphManager(this); - this.graphManager = gm; - return gm; -}; - -Layout.prototype.newGraph = function (vGraph) { - return new LGraph(null, this.graphManager, vGraph); -}; - -Layout.prototype.newNode = function (vNode) { - return new LNode(this.graphManager, vNode); -}; - -Layout.prototype.newEdge = function (vEdge) { - return new LEdge(null, null, vEdge); -}; - -Layout.prototype.checkLayoutSuccess = function () { - return this.graphManager.getRoot() == null || this.graphManager.getRoot().getNodes().length == 0 || this.graphManager.includesInvalidEdge(); -}; - -Layout.prototype.runLayout = function () { - this.isLayoutFinished = false; - - if (this.tilingPreLayout) { - this.tilingPreLayout(); - } - - this.initParameters(); - var isLayoutSuccessfull; - - if (this.checkLayoutSuccess()) { - isLayoutSuccessfull = false; - } else { - isLayoutSuccessfull = this.layout(); - } - - if (LayoutConstants.ANIMATE === 'during') { - // If this is a 'during' layout animation. Layout is not finished yet. - // We need to perform these in index.js when layout is really finished. - return false; - } - - if (isLayoutSuccessfull) { - if (!this.isSubLayout) { - this.doPostLayout(); - } - } - - if (this.tilingPostLayout) { - this.tilingPostLayout(); - } - - this.isLayoutFinished = true; - - return isLayoutSuccessfull; -}; - -/** - * This method performs the operations required after layout. - */ -Layout.prototype.doPostLayout = function () { - //assert !isSubLayout : "Should not be called on sub-layout!"; - // Propagate geometric changes to v-level objects - if (!this.incremental) { - this.transform(); - } - this.update(); -}; - -/** - * This method updates the geometry of the target graph according to - * calculated layout. - */ -Layout.prototype.update2 = function () { - // update bend points - if (this.createBendsAsNeeded) { - this.createBendpointsFromDummyNodes(); - - // reset all edges, since the topology has changed - this.graphManager.resetAllEdges(); - } - - // perform edge, node and root updates if layout is not called - // remotely - if (!this.isRemoteUse) { - // update all edges - var edge; - var allEdges = this.graphManager.getAllEdges(); - for (var i = 0; i < allEdges.length; i++) { - edge = allEdges[i]; - // this.update(edge); - } - - // recursively update nodes - var node; - var nodes = this.graphManager.getRoot().getNodes(); - for (var i = 0; i < nodes.length; i++) { - node = nodes[i]; - // this.update(node); - } - - // update root graph - this.update(this.graphManager.getRoot()); - } -}; - -Layout.prototype.update = function (obj) { - if (obj == null) { - this.update2(); - } else if (obj instanceof LNode) { - var node = obj; - if (node.getChild() != null) { - // since node is compound, recursively update child nodes - var nodes = node.getChild().getNodes(); - for (var i = 0; i < nodes.length; i++) { - update(nodes[i]); - } - } - - // if the l-level node is associated with a v-level graph object, - // then it is assumed that the v-level node implements the - // interface Updatable. - if (node.vGraphObject != null) { - // cast to Updatable without any type check - var vNode = node.vGraphObject; - - // call the update method of the interface - vNode.update(node); - } - } else if (obj instanceof LEdge) { - var edge = obj; - // if the l-level edge is associated with a v-level graph object, - // then it is assumed that the v-level edge implements the - // interface Updatable. - - if (edge.vGraphObject != null) { - // cast to Updatable without any type check - var vEdge = edge.vGraphObject; - - // call the update method of the interface - vEdge.update(edge); - } - } else if (obj instanceof LGraph) { - var graph = obj; - // if the l-level graph is associated with a v-level graph object, - // then it is assumed that the v-level object implements the - // interface Updatable. - - if (graph.vGraphObject != null) { - // cast to Updatable without any type check - var vGraph = graph.vGraphObject; - - // call the update method of the interface - vGraph.update(graph); - } - } -}; - -/** - * This method is used to set all layout parameters to default values - * determined at compile time. - */ -Layout.prototype.initParameters = function () { - if (!this.isSubLayout) { - this.layoutQuality = LayoutConstants.DEFAULT_QUALITY; - this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT; - this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD; - this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT; - this.incremental = LayoutConstants.DEFAULT_INCREMENTAL; - this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED; - this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES; - } - - if (this.animationDuringLayout) { - this.animationOnLayout = false; - } -}; - -Layout.prototype.transform = function (newLeftTop) { - if (newLeftTop == undefined) { - this.transform(new PointD(0, 0)); - } else { - // create a transformation object (from Eclipse to layout). When an - // inverse transform is applied, we get upper-left coordinate of the - // drawing or the root graph at given input coordinate (some margins - // already included in calculation of left-top). - - var trans = new Transform(); - var leftTop = this.graphManager.getRoot().updateLeftTop(); - - if (leftTop != null) { - trans.setWorldOrgX(newLeftTop.x); - trans.setWorldOrgY(newLeftTop.y); - - trans.setDeviceOrgX(leftTop.x); - trans.setDeviceOrgY(leftTop.y); - - var nodes = this.getAllNodes(); - var node; - - for (var i = 0; i < nodes.length; i++) { - node = nodes[i]; - node.transform(trans); - } - } - } -}; - -Layout.prototype.positionNodesRandomly = function (graph) { - - if (graph == undefined) { - //assert !this.incremental; - this.positionNodesRandomly(this.getGraphManager().getRoot()); - this.getGraphManager().getRoot().updateBounds(true); - } else { - var lNode; - var childGraph; - - var nodes = graph.getNodes(); - for (var i = 0; i < nodes.length; i++) { - lNode = nodes[i]; - childGraph = lNode.getChild(); - - if (childGraph == null) { - lNode.scatter(); - } else if (childGraph.getNodes().length == 0) { - lNode.scatter(); - } else { - this.positionNodesRandomly(childGraph); - lNode.updateBounds(); - } - } - } -}; - -/** - * This method returns a list of trees where each tree is represented as a - * list of l-nodes. The method returns a list of size 0 when: - * - The graph is not flat or - * - One of the component(s) of the graph is not a tree. - */ -Layout.prototype.getFlatForest = function () { - var flatForest = []; - var isForest = true; - - // Quick reference for all nodes in the graph manager associated with - // this layout. The list should not be changed. - var allNodes = this.graphManager.getRoot().getNodes(); - - // First be sure that the graph is flat - var isFlat = true; - - for (var i = 0; i < allNodes.length; i++) { - if (allNodes[i].getChild() != null) { - isFlat = false; - } - } - - // Return empty forest if the graph is not flat. - if (!isFlat) { - return flatForest; - } - - // Run BFS for each component of the graph. - - var visited = new HashSet(); - var toBeVisited = []; - var parents = new HashMap(); - var unProcessedNodes = []; - - unProcessedNodes = unProcessedNodes.concat(allNodes); - - // Each iteration of this loop finds a component of the graph and - // decides whether it is a tree or not. If it is a tree, adds it to the - // forest and continued with the next component. - - while (unProcessedNodes.length > 0 && isForest) { - toBeVisited.push(unProcessedNodes[0]); - - // Start the BFS. Each iteration of this loop visits a node in a - // BFS manner. - while (toBeVisited.length > 0 && isForest) { - //pool operation - var currentNode = toBeVisited[0]; - toBeVisited.splice(0, 1); - visited.add(currentNode); - - // Traverse all neighbors of this node - var neighborEdges = currentNode.getEdges(); - - for (var i = 0; i < neighborEdges.length; i++) { - var currentNeighbor = neighborEdges[i].getOtherEnd(currentNode); - - // If BFS is not growing from this neighbor. - if (parents.get(currentNode) != currentNeighbor) { - // We haven't previously visited this neighbor. - if (!visited.contains(currentNeighbor)) { - toBeVisited.push(currentNeighbor); - parents.put(currentNeighbor, currentNode); - } - // Since we have previously visited this neighbor and - // this neighbor is not parent of currentNode, given - // graph contains a component that is not tree, hence - // it is not a forest. - else { - isForest = false; - break; - } - } - } - } - - // The graph contains a component that is not a tree. Empty - // previously found trees. The method will end. - if (!isForest) { - flatForest = []; - } - // Save currently visited nodes as a tree in our forest. Reset - // visited and parents lists. Continue with the next component of - // the graph, if any. - else { - var temp = []; - visited.addAllTo(temp); - flatForest.push(temp); - //flatForest = flatForest.concat(temp); - //unProcessedNodes.removeAll(visited); - for (var i = 0; i < temp.length; i++) { - var value = temp[i]; - var index = unProcessedNodes.indexOf(value); - if (index > -1) { - unProcessedNodes.splice(index, 1); - } - } - visited = new HashSet(); - parents = new HashMap(); - } - } - - return flatForest; -}; - -/** - * This method creates dummy nodes (an l-level node with minimal dimensions) - * for the given edge (one per bendpoint). The existing l-level structure - * is updated accordingly. - */ -Layout.prototype.createDummyNodesForBendpoints = function (edge) { - var dummyNodes = []; - var prev = edge.source; - - var graph = this.graphManager.calcLowestCommonAncestor(edge.source, edge.target); - - for (var i = 0; i < edge.bendpoints.length; i++) { - // create new dummy node - var dummyNode = this.newNode(null); - dummyNode.setRect(new Point(0, 0), new Dimension(1, 1)); - - graph.add(dummyNode); - - // create new dummy edge between prev and dummy node - var dummyEdge = this.newEdge(null); - this.graphManager.add(dummyEdge, prev, dummyNode); - - dummyNodes.add(dummyNode); - prev = dummyNode; - } - - var dummyEdge = this.newEdge(null); - this.graphManager.add(dummyEdge, prev, edge.target); - - this.edgeToDummyNodes.put(edge, dummyNodes); - - // remove real edge from graph manager if it is inter-graph - if (edge.isInterGraph()) { - this.graphManager.remove(edge); - } - // else, remove the edge from the current graph - else { - graph.remove(edge); - } - - return dummyNodes; -}; - -/** - * This method creates bendpoints for edges from the dummy nodes - * at l-level. - */ -Layout.prototype.createBendpointsFromDummyNodes = function () { - var edges = []; - edges = edges.concat(this.graphManager.getAllEdges()); - edges = this.edgeToDummyNodes.keySet().concat(edges); - - for (var k = 0; k < edges.length; k++) { - var lEdge = edges[k]; - - if (lEdge.bendpoints.length > 0) { - var path = this.edgeToDummyNodes.get(lEdge); - - for (var i = 0; i < path.length; i++) { - var dummyNode = path[i]; - var p = new PointD(dummyNode.getCenterX(), dummyNode.getCenterY()); - - // update bendpoint's location according to dummy node - var ebp = lEdge.bendpoints.get(i); - ebp.x = p.x; - ebp.y = p.y; - - // remove the dummy node, dummy edges incident with this - // dummy node is also removed (within the remove method) - dummyNode.getOwner().remove(dummyNode); - } - - // add the real edge to graph - this.graphManager.add(lEdge, lEdge.source, lEdge.target); - } - } -}; - -Layout.transform = function (sliderValue, defaultValue, minDiv, maxMul) { - if (minDiv != undefined && maxMul != undefined) { - var value = defaultValue; - - if (sliderValue <= 50) { - var minValue = defaultValue / minDiv; - value -= (defaultValue - minValue) / 50 * (50 - sliderValue); - } else { - var maxValue = defaultValue * maxMul; - value += (maxValue - defaultValue) / 50 * (sliderValue - 50); - } - - return value; - } else { - var a, b; - - if (sliderValue <= 50) { - a = 9.0 * defaultValue / 500.0; - b = defaultValue / 10.0; - } else { - a = 9.0 * defaultValue / 50.0; - b = -8 * defaultValue; - } - - return a * sliderValue + b; - } -}; - -/** - * This method finds and returns the center of the given nodes, assuming - * that the given nodes form a tree in themselves. - */ -Layout.findCenterOfTree = function (nodes) { - var list = []; - list = list.concat(nodes); - - var removedNodes = []; - var remainingDegrees = new HashMap(); - var foundCenter = false; - var centerNode = null; - - if (list.length == 1 || list.length == 2) { - foundCenter = true; - centerNode = list[0]; - } - - for (var i = 0; i < list.length; i++) { - var node = list[i]; - var degree = node.getNeighborsList().size(); - remainingDegrees.put(node, node.getNeighborsList().size()); - - if (degree == 1) { - removedNodes.push(node); - } - } - - var tempList = []; - tempList = tempList.concat(removedNodes); - - while (!foundCenter) { - var tempList2 = []; - tempList2 = tempList2.concat(tempList); - tempList = []; - - for (var i = 0; i < list.length; i++) { - var node = list[i]; - - var index = list.indexOf(node); - if (index >= 0) { - list.splice(index, 1); - } - - var neighbours = node.getNeighborsList(); - - Object.keys(neighbours.set).forEach(function (j) { - var neighbour = neighbours.set[j]; - if (removedNodes.indexOf(neighbour) < 0) { - var otherDegree = remainingDegrees.get(neighbour); - var newDegree = otherDegree - 1; - - if (newDegree == 1) { - tempList.push(neighbour); - } - - remainingDegrees.put(neighbour, newDegree); - } - }); - } - - removedNodes = removedNodes.concat(tempList); - - if (list.length == 1 || list.length == 2) { - foundCenter = true; - centerNode = list[0]; - } - } - - return centerNode; -}; - -/** - * During the coarsening process, this layout may be referenced by two graph managers - * this setter function grants access to change the currently being used graph manager - */ -Layout.prototype.setGraphManager = function (gm) { - this.graphManager = gm; -}; - -module.exports = Layout; - -/***/ }), -/* 3 */ -/***/ (function(module, exports) { - -function LayoutConstants() {} - -/** - * Layout Quality - */ -LayoutConstants.PROOF_QUALITY = 0; -LayoutConstants.DEFAULT_QUALITY = 1; -LayoutConstants.DRAFT_QUALITY = 2; - -/** - * Default parameters - */ -LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED = false; -//LayoutConstants.DEFAULT_INCREMENTAL = true; -LayoutConstants.DEFAULT_INCREMENTAL = false; -LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT = true; -LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT = false; -LayoutConstants.DEFAULT_ANIMATION_PERIOD = 50; -LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES = false; - -// ----------------------------------------------------------------------------- -// Section: General other constants -// ----------------------------------------------------------------------------- -/* - * Margins of a graph to be applied on bouding rectangle of its contents. We - * assume margins on all four sides to be uniform. - */ -LayoutConstants.DEFAULT_GRAPH_MARGIN = 15; - -/* - * Whether to consider labels in node dimensions or not - */ -LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = false; - -/* - * Default dimension of a non-compound node. - */ -LayoutConstants.SIMPLE_NODE_SIZE = 40; - -/* - * Default dimension of a non-compound node. - */ -LayoutConstants.SIMPLE_NODE_HALF_SIZE = LayoutConstants.SIMPLE_NODE_SIZE / 2; - -/* - * Empty compound node size. When a compound node is empty, its both - * dimensions should be of this value. - */ -LayoutConstants.EMPTY_COMPOUND_NODE_SIZE = 40; - -/* - * Minimum length that an edge should take during layout - */ -LayoutConstants.MIN_EDGE_LENGTH = 1; - -/* - * World boundaries that layout operates on - */ -LayoutConstants.WORLD_BOUNDARY = 1000000; - -/* - * World boundaries that random positioning can be performed with - */ -LayoutConstants.INITIAL_WORLD_BOUNDARY = LayoutConstants.WORLD_BOUNDARY / 1000; - -/* - * Coordinates of the world center - */ -LayoutConstants.WORLD_CENTER_X = 1200; -LayoutConstants.WORLD_CENTER_Y = 900; - -module.exports = LayoutConstants; - -/***/ }), -/* 4 */ -/***/ (function(module, exports, __webpack_require__) { - -var UniqueIDGeneretor = __webpack_require__(5); - -function HashMap() { - this.map = {}; - this.keys = []; -} - -HashMap.prototype.put = function (key, value) { - var theId = UniqueIDGeneretor.createID(key); - if (!this.contains(theId)) { - this.map[theId] = value; - this.keys.push(key); - } -}; - -HashMap.prototype.contains = function (key) { - var theId = UniqueIDGeneretor.createID(key); - return this.map[key] != null; -}; - -HashMap.prototype.get = function (key) { - var theId = UniqueIDGeneretor.createID(key); - return this.map[theId]; -}; - -HashMap.prototype.keySet = function () { - return this.keys; -}; - -module.exports = HashMap; - -/***/ }), -/* 5 */ -/***/ (function(module, exports) { - -function UniqueIDGeneretor() {} - -UniqueIDGeneretor.lastID = 0; - -UniqueIDGeneretor.createID = function (obj) { - if (UniqueIDGeneretor.isPrimitive(obj)) { - return obj; - } - if (obj.uniqueID != null) { - return obj.uniqueID; - } - obj.uniqueID = UniqueIDGeneretor.getString(); - UniqueIDGeneretor.lastID++; - return obj.uniqueID; -}; - -UniqueIDGeneretor.getString = function (id) { - if (id == null) id = UniqueIDGeneretor.lastID; - return "Object#" + id + ""; -}; - -UniqueIDGeneretor.isPrimitive = function (arg) { - var type = typeof arg; - return arg == null || type != "object" && type != "function"; -}; - -module.exports = UniqueIDGeneretor; - -/***/ }), -/* 6 */ -/***/ (function(module, exports, __webpack_require__) { - -var LGraph; -var LEdge = __webpack_require__(7); - -function LGraphManager(layout) { - LGraph = __webpack_require__(11); // It may be better to initilize this out of this function but it gives an error (Right-hand side of 'instanceof' is not callable) now. - this.layout = layout; - - this.graphs = []; - this.edges = []; -} - -LGraphManager.prototype.addRoot = function () { - var ngraph = this.layout.newGraph(); - var nnode = this.layout.newNode(null); - var root = this.add(ngraph, nnode); - this.setRootGraph(root); - return this.rootGraph; -}; - -LGraphManager.prototype.add = function (newGraph, parentNode, newEdge, sourceNode, targetNode) { - //there are just 2 parameters are passed then it adds an LGraph else it adds an LEdge - if (newEdge == null && sourceNode == null && targetNode == null) { - if (newGraph == null) { - throw "Graph is null!"; - } - if (parentNode == null) { - throw "Parent node is null!"; - } - if (this.graphs.indexOf(newGraph) > -1) { - throw "Graph already in this graph mgr!"; - } - - this.graphs.push(newGraph); - - if (newGraph.parent != null) { - throw "Already has a parent!"; - } - if (parentNode.child != null) { - throw "Already has a child!"; - } - - newGraph.parent = parentNode; - parentNode.child = newGraph; - - return newGraph; - } else { - //change the order of the parameters - targetNode = newEdge; - sourceNode = parentNode; - newEdge = newGraph; - var sourceGraph = sourceNode.getOwner(); - var targetGraph = targetNode.getOwner(); - - if (!(sourceGraph != null && sourceGraph.getGraphManager() == this)) { - throw "Source not in this graph mgr!"; - } - if (!(targetGraph != null && targetGraph.getGraphManager() == this)) { - throw "Target not in this graph mgr!"; - } - - if (sourceGraph == targetGraph) { - newEdge.isInterGraph = false; - return sourceGraph.add(newEdge, sourceNode, targetNode); - } else { - newEdge.isInterGraph = true; - - // set source and target - newEdge.source = sourceNode; - newEdge.target = targetNode; - - // add edge to inter-graph edge list - if (this.edges.indexOf(newEdge) > -1) { - throw "Edge already in inter-graph edge list!"; - } - - this.edges.push(newEdge); - - // add edge to source and target incidency lists - if (!(newEdge.source != null && newEdge.target != null)) { - throw "Edge source and/or target is null!"; - } - - if (!(newEdge.source.edges.indexOf(newEdge) == -1 && newEdge.target.edges.indexOf(newEdge) == -1)) { - throw "Edge already in source and/or target incidency list!"; - } - - newEdge.source.edges.push(newEdge); - newEdge.target.edges.push(newEdge); - - return newEdge; - } - } -}; - -LGraphManager.prototype.remove = function (lObj) { - if (lObj instanceof LGraph) { - var graph = lObj; - if (graph.getGraphManager() != this) { - throw "Graph not in this graph mgr"; - } - if (!(graph == this.rootGraph || graph.parent != null && graph.parent.graphManager == this)) { - throw "Invalid parent node!"; - } - - // first the edges (make a copy to do it safely) - var edgesToBeRemoved = []; - - edgesToBeRemoved = edgesToBeRemoved.concat(graph.getEdges()); - - var edge; - var s = edgesToBeRemoved.length; - for (var i = 0; i < s; i++) { - edge = edgesToBeRemoved[i]; - graph.remove(edge); - } - - // then the nodes (make a copy to do it safely) - var nodesToBeRemoved = []; - - nodesToBeRemoved = nodesToBeRemoved.concat(graph.getNodes()); - - var node; - s = nodesToBeRemoved.length; - for (var i = 0; i < s; i++) { - node = nodesToBeRemoved[i]; - graph.remove(node); - } - - // check if graph is the root - if (graph == this.rootGraph) { - this.setRootGraph(null); - } - - // now remove the graph itself - var index = this.graphs.indexOf(graph); - this.graphs.splice(index, 1); - - // also reset the parent of the graph - graph.parent = null; - } else if (lObj instanceof LEdge) { - edge = lObj; - if (edge == null) { - throw "Edge is null!"; - } - if (!edge.isInterGraph) { - throw "Not an inter-graph edge!"; - } - if (!(edge.source != null && edge.target != null)) { - throw "Source and/or target is null!"; - } - - // remove edge from source and target nodes' incidency lists - - if (!(edge.source.edges.indexOf(edge) != -1 && edge.target.edges.indexOf(edge) != -1)) { - throw "Source and/or target doesn't know this edge!"; - } - - var index = edge.source.edges.indexOf(edge); - edge.source.edges.splice(index, 1); - index = edge.target.edges.indexOf(edge); - edge.target.edges.splice(index, 1); - - // remove edge from owner graph manager's inter-graph edge list - - if (!(edge.source.owner != null && edge.source.owner.getGraphManager() != null)) { - throw "Edge owner graph or owner graph manager is null!"; - } - if (edge.source.owner.getGraphManager().edges.indexOf(edge) == -1) { - throw "Not in owner graph manager's edge list!"; - } - - var index = edge.source.owner.getGraphManager().edges.indexOf(edge); - edge.source.owner.getGraphManager().edges.splice(index, 1); - } -}; - -LGraphManager.prototype.updateBounds = function () { - this.rootGraph.updateBounds(true); -}; - -LGraphManager.prototype.getGraphs = function () { - return this.graphs; -}; - -LGraphManager.prototype.getAllNodes = function () { - if (this.allNodes == null) { - var nodeList = []; - var graphs = this.getGraphs(); - var s = graphs.length; - for (var i = 0; i < s; i++) { - nodeList = nodeList.concat(graphs[i].getNodes()); - } - this.allNodes = nodeList; - } - return this.allNodes; -}; - -LGraphManager.prototype.resetAllNodes = function () { - this.allNodes = null; -}; - -LGraphManager.prototype.resetAllEdges = function () { - this.allEdges = null; -}; - -LGraphManager.prototype.resetAllNodesToApplyGravitation = function () { - this.allNodesToApplyGravitation = null; -}; - -LGraphManager.prototype.getAllEdges = function () { - if (this.allEdges == null) { - var edgeList = []; - var graphs = this.getGraphs(); - var s = graphs.length; - for (var i = 0; i < graphs.length; i++) { - edgeList = edgeList.concat(graphs[i].getEdges()); - } - - edgeList = edgeList.concat(this.edges); - - this.allEdges = edgeList; - } - return this.allEdges; -}; - -LGraphManager.prototype.getAllNodesToApplyGravitation = function () { - return this.allNodesToApplyGravitation; -}; - -LGraphManager.prototype.setAllNodesToApplyGravitation = function (nodeList) { - if (this.allNodesToApplyGravitation != null) { - throw "assert failed"; - } - - this.allNodesToApplyGravitation = nodeList; -}; - -LGraphManager.prototype.getRoot = function () { - return this.rootGraph; -}; - -LGraphManager.prototype.setRootGraph = function (graph) { - if (graph.getGraphManager() != this) { - throw "Root not in this graph mgr!"; - } - - this.rootGraph = graph; - // root graph must have a root node associated with it for convenience - if (graph.parent == null) { - graph.parent = this.layout.newNode("Root node"); - } -}; - -LGraphManager.prototype.getLayout = function () { - return this.layout; -}; - -LGraphManager.prototype.isOneAncestorOfOther = function (firstNode, secondNode) { - if (!(firstNode != null && secondNode != null)) { - throw "assert failed"; - } - - if (firstNode == secondNode) { - return true; - } - // Is second node an ancestor of the first one? - var ownerGraph = firstNode.getOwner(); - var parentNode; - - do { - parentNode = ownerGraph.getParent(); - - if (parentNode == null) { - break; - } - - if (parentNode == secondNode) { - return true; - } - - ownerGraph = parentNode.getOwner(); - if (ownerGraph == null) { - break; - } - } while (true); - // Is first node an ancestor of the second one? - ownerGraph = secondNode.getOwner(); - - do { - parentNode = ownerGraph.getParent(); - - if (parentNode == null) { - break; - } - - if (parentNode == firstNode) { - return true; - } - - ownerGraph = parentNode.getOwner(); - if (ownerGraph == null) { - break; - } - } while (true); - - return false; -}; - -LGraphManager.prototype.calcLowestCommonAncestors = function () { - var edge; - var sourceNode; - var targetNode; - var sourceAncestorGraph; - var targetAncestorGraph; - - var edges = this.getAllEdges(); - var s = edges.length; - for (var i = 0; i < s; i++) { - edge = edges[i]; - - sourceNode = edge.source; - targetNode = edge.target; - edge.lca = null; - edge.sourceInLca = sourceNode; - edge.targetInLca = targetNode; - - if (sourceNode == targetNode) { - edge.lca = sourceNode.getOwner(); - continue; - } - - sourceAncestorGraph = sourceNode.getOwner(); - - while (edge.lca == null) { - edge.targetInLca = targetNode; - targetAncestorGraph = targetNode.getOwner(); - - while (edge.lca == null) { - if (targetAncestorGraph == sourceAncestorGraph) { - edge.lca = targetAncestorGraph; - break; - } - - if (targetAncestorGraph == this.rootGraph) { - break; - } - - if (edge.lca != null) { - throw "assert failed"; - } - edge.targetInLca = targetAncestorGraph.getParent(); - targetAncestorGraph = edge.targetInLca.getOwner(); - } - - if (sourceAncestorGraph == this.rootGraph) { - break; - } - - if (edge.lca == null) { - edge.sourceInLca = sourceAncestorGraph.getParent(); - sourceAncestorGraph = edge.sourceInLca.getOwner(); - } - } - - if (edge.lca == null) { - throw "assert failed"; - } - } -}; - -LGraphManager.prototype.calcLowestCommonAncestor = function (firstNode, secondNode) { - if (firstNode == secondNode) { - return firstNode.getOwner(); - } - var firstOwnerGraph = firstNode.getOwner(); - - do { - if (firstOwnerGraph == null) { - break; - } - var secondOwnerGraph = secondNode.getOwner(); - - do { - if (secondOwnerGraph == null) { - break; - } - - if (secondOwnerGraph == firstOwnerGraph) { - return secondOwnerGraph; - } - secondOwnerGraph = secondOwnerGraph.getParent().getOwner(); - } while (true); - - firstOwnerGraph = firstOwnerGraph.getParent().getOwner(); - } while (true); - - return firstOwnerGraph; -}; - -LGraphManager.prototype.calcInclusionTreeDepths = function (graph, depth) { - if (graph == null && depth == null) { - graph = this.rootGraph; - depth = 1; - } - var node; - - var nodes = graph.getNodes(); - var s = nodes.length; - for (var i = 0; i < s; i++) { - node = nodes[i]; - node.inclusionTreeDepth = depth; - - if (node.child != null) { - this.calcInclusionTreeDepths(node.child, depth + 1); - } - } -}; - -LGraphManager.prototype.includesInvalidEdge = function () { - var edge; - - var s = this.edges.length; - for (var i = 0; i < s; i++) { - edge = this.edges[i]; - - if (this.isOneAncestorOfOther(edge.source, edge.target)) { - return true; - } - } - return false; -}; - -module.exports = LGraphManager; - -/***/ }), -/* 7 */ -/***/ (function(module, exports, __webpack_require__) { - -var LGraphObject = __webpack_require__(8); -var IGeometry = __webpack_require__(9); -var IMath = __webpack_require__(10); - -function LEdge(source, target, vEdge) { - LGraphObject.call(this, vEdge); - - this.isOverlapingSourceAndTarget = false; - this.vGraphObject = vEdge; - this.bendpoints = []; - this.source = source; - this.target = target; -} - -LEdge.prototype = Object.create(LGraphObject.prototype); - -for (var prop in LGraphObject) { - LEdge[prop] = LGraphObject[prop]; -} - -LEdge.prototype.getSource = function () { - return this.source; -}; - -LEdge.prototype.getTarget = function () { - return this.target; -}; - -LEdge.prototype.isInterGraph = function () { - return this.isInterGraph; -}; - -LEdge.prototype.getLength = function () { - return this.length; -}; - -LEdge.prototype.isOverlapingSourceAndTarget = function () { - return this.isOverlapingSourceAndTarget; -}; - -LEdge.prototype.getBendpoints = function () { - return this.bendpoints; -}; - -LEdge.prototype.getLca = function () { - return this.lca; -}; - -LEdge.prototype.getSourceInLca = function () { - return this.sourceInLca; -}; - -LEdge.prototype.getTargetInLca = function () { - return this.targetInLca; -}; - -LEdge.prototype.getOtherEnd = function (node) { - if (this.source === node) { - return this.target; - } else if (this.target === node) { - return this.source; - } else { - throw "Node is not incident with this edge"; - } -}; - -LEdge.prototype.getOtherEndInGraph = function (node, graph) { - var otherEnd = this.getOtherEnd(node); - var root = graph.getGraphManager().getRoot(); - - while (true) { - if (otherEnd.getOwner() == graph) { - return otherEnd; - } - - if (otherEnd.getOwner() == root) { - break; - } - - otherEnd = otherEnd.getOwner().getParent(); - } - - return null; -}; - -LEdge.prototype.updateLength = function () { - var clipPointCoordinates = new Array(4); - - this.isOverlapingSourceAndTarget = IGeometry.getIntersection(this.target.getRect(), this.source.getRect(), clipPointCoordinates); - - if (!this.isOverlapingSourceAndTarget) { - this.lengthX = clipPointCoordinates[0] - clipPointCoordinates[2]; - this.lengthY = clipPointCoordinates[1] - clipPointCoordinates[3]; - - if (Math.abs(this.lengthX) < 1.0) { - this.lengthX = IMath.sign(this.lengthX); - } - - if (Math.abs(this.lengthY) < 1.0) { - this.lengthY = IMath.sign(this.lengthY); - } - - this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY); - } -}; - -LEdge.prototype.updateLengthSimple = function () { - this.lengthX = this.target.getCenterX() - this.source.getCenterX(); - this.lengthY = this.target.getCenterY() - this.source.getCenterY(); - - if (Math.abs(this.lengthX) < 1.0) { - this.lengthX = IMath.sign(this.lengthX); - } - - if (Math.abs(this.lengthY) < 1.0) { - this.lengthY = IMath.sign(this.lengthY); - } - - this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY); -}; - -module.exports = LEdge; - -/***/ }), -/* 8 */ -/***/ (function(module, exports) { - -function LGraphObject(vGraphObject) { - this.vGraphObject = vGraphObject; -} - -module.exports = LGraphObject; - -/***/ }), -/* 9 */ -/***/ (function(module, exports) { - -function IGeometry() {} - -IGeometry.calcSeparationAmount = function (rectA, rectB, overlapAmount, separationBuffer) { - if (!rectA.intersects(rectB)) { - throw "assert failed"; - } - var directions = new Array(2); - IGeometry.decideDirectionsForOverlappingNodes(rectA, rectB, directions); - overlapAmount[0] = Math.min(rectA.getRight(), rectB.getRight()) - Math.max(rectA.x, rectB.x); - overlapAmount[1] = Math.min(rectA.getBottom(), rectB.getBottom()) - Math.max(rectA.y, rectB.y); - // update the overlapping amounts for the following cases: - if (rectA.getX() <= rectB.getX() && rectA.getRight() >= rectB.getRight()) { - overlapAmount[0] += Math.min(rectB.getX() - rectA.getX(), rectA.getRight() - rectB.getRight()); - } else if (rectB.getX() <= rectA.getX() && rectB.getRight() >= rectA.getRight()) { - overlapAmount[0] += Math.min(rectA.getX() - rectB.getX(), rectB.getRight() - rectA.getRight()); - } - if (rectA.getY() <= rectB.getY() && rectA.getBottom() >= rectB.getBottom()) { - overlapAmount[1] += Math.min(rectB.getY() - rectA.getY(), rectA.getBottom() - rectB.getBottom()); - } else if (rectB.getY() <= rectA.getY() && rectB.getBottom() >= rectA.getBottom()) { - overlapAmount[1] += Math.min(rectA.getY() - rectB.getY(), rectB.getBottom() - rectA.getBottom()); - } - - // find slope of the line passes two centers - var slope = Math.abs((rectB.getCenterY() - rectA.getCenterY()) / (rectB.getCenterX() - rectA.getCenterX())); - // if centers are overlapped - if (rectB.getCenterY() == rectA.getCenterY() && rectB.getCenterX() == rectA.getCenterX()) { - // assume the slope is 1 (45 degree) - slope = 1.0; - } - - var moveByY = slope * overlapAmount[0]; - var moveByX = overlapAmount[1] / slope; - if (overlapAmount[0] < moveByX) { - moveByX = overlapAmount[0]; - } else { - moveByY = overlapAmount[1]; - } - // return half the amount so that if each rectangle is moved by these - // amounts in opposite directions, overlap will be resolved - overlapAmount[0] = -1 * directions[0] * (moveByX / 2 + separationBuffer); - overlapAmount[1] = -1 * directions[1] * (moveByY / 2 + separationBuffer); -}; - -IGeometry.decideDirectionsForOverlappingNodes = function (rectA, rectB, directions) { - if (rectA.getCenterX() < rectB.getCenterX()) { - directions[0] = -1; - } else { - directions[0] = 1; - } - - if (rectA.getCenterY() < rectB.getCenterY()) { - directions[1] = -1; - } else { - directions[1] = 1; - } -}; - -IGeometry.getIntersection2 = function (rectA, rectB, result) { - //result[0-1] will contain clipPoint of rectA, result[2-3] will contain clipPoint of rectB - var p1x = rectA.getCenterX(); - var p1y = rectA.getCenterY(); - var p2x = rectB.getCenterX(); - var p2y = rectB.getCenterY(); - - //if two rectangles intersect, then clipping points are centers - if (rectA.intersects(rectB)) { - result[0] = p1x; - result[1] = p1y; - result[2] = p2x; - result[3] = p2y; - return true; - } - //variables for rectA - var topLeftAx = rectA.getX(); - var topLeftAy = rectA.getY(); - var topRightAx = rectA.getRight(); - var bottomLeftAx = rectA.getX(); - var bottomLeftAy = rectA.getBottom(); - var bottomRightAx = rectA.getRight(); - var halfWidthA = rectA.getWidthHalf(); - var halfHeightA = rectA.getHeightHalf(); - //variables for rectB - var topLeftBx = rectB.getX(); - var topLeftBy = rectB.getY(); - var topRightBx = rectB.getRight(); - var bottomLeftBx = rectB.getX(); - var bottomLeftBy = rectB.getBottom(); - var bottomRightBx = rectB.getRight(); - var halfWidthB = rectB.getWidthHalf(); - var halfHeightB = rectB.getHeightHalf(); - //flag whether clipping points are found - var clipPointAFound = false; - var clipPointBFound = false; - - // line is vertical - if (p1x == p2x) { - if (p1y > p2y) { - result[0] = p1x; - result[1] = topLeftAy; - result[2] = p2x; - result[3] = bottomLeftBy; - return false; - } else if (p1y < p2y) { - result[0] = p1x; - result[1] = bottomLeftAy; - result[2] = p2x; - result[3] = topLeftBy; - return false; - } else { - //not line, return null; - } - } - // line is horizontal - else if (p1y == p2y) { - if (p1x > p2x) { - result[0] = topLeftAx; - result[1] = p1y; - result[2] = topRightBx; - result[3] = p2y; - return false; - } else if (p1x < p2x) { - result[0] = topRightAx; - result[1] = p1y; - result[2] = topLeftBx; - result[3] = p2y; - return false; - } else { - //not valid line, return null; - } - } else { - //slopes of rectA's and rectB's diagonals - var slopeA = rectA.height / rectA.width; - var slopeB = rectB.height / rectB.width; - - //slope of line between center of rectA and center of rectB - var slopePrime = (p2y - p1y) / (p2x - p1x); - var cardinalDirectionA; - var cardinalDirectionB; - var tempPointAx; - var tempPointAy; - var tempPointBx; - var tempPointBy; - - //determine whether clipping point is the corner of nodeA - if (-slopeA == slopePrime) { - if (p1x > p2x) { - result[0] = bottomLeftAx; - result[1] = bottomLeftAy; - clipPointAFound = true; - } else { - result[0] = topRightAx; - result[1] = topLeftAy; - clipPointAFound = true; - } - } else if (slopeA == slopePrime) { - if (p1x > p2x) { - result[0] = topLeftAx; - result[1] = topLeftAy; - clipPointAFound = true; - } else { - result[0] = bottomRightAx; - result[1] = bottomLeftAy; - clipPointAFound = true; - } - } - - //determine whether clipping point is the corner of nodeB - if (-slopeB == slopePrime) { - if (p2x > p1x) { - result[2] = bottomLeftBx; - result[3] = bottomLeftBy; - clipPointBFound = true; - } else { - result[2] = topRightBx; - result[3] = topLeftBy; - clipPointBFound = true; - } - } else if (slopeB == slopePrime) { - if (p2x > p1x) { - result[2] = topLeftBx; - result[3] = topLeftBy; - clipPointBFound = true; - } else { - result[2] = bottomRightBx; - result[3] = bottomLeftBy; - clipPointBFound = true; - } - } - - //if both clipping points are corners - if (clipPointAFound && clipPointBFound) { - return false; - } - - //determine Cardinal Direction of rectangles - if (p1x > p2x) { - if (p1y > p2y) { - cardinalDirectionA = IGeometry.getCardinalDirection(slopeA, slopePrime, 4); - cardinalDirectionB = IGeometry.getCardinalDirection(slopeB, slopePrime, 2); - } else { - cardinalDirectionA = IGeometry.getCardinalDirection(-slopeA, slopePrime, 3); - cardinalDirectionB = IGeometry.getCardinalDirection(-slopeB, slopePrime, 1); - } - } else { - if (p1y > p2y) { - cardinalDirectionA = IGeometry.getCardinalDirection(-slopeA, slopePrime, 1); - cardinalDirectionB = IGeometry.getCardinalDirection(-slopeB, slopePrime, 3); - } else { - cardinalDirectionA = IGeometry.getCardinalDirection(slopeA, slopePrime, 2); - cardinalDirectionB = IGeometry.getCardinalDirection(slopeB, slopePrime, 4); - } - } - //calculate clipping Point if it is not found before - if (!clipPointAFound) { - switch (cardinalDirectionA) { - case 1: - tempPointAy = topLeftAy; - tempPointAx = p1x + -halfHeightA / slopePrime; - result[0] = tempPointAx; - result[1] = tempPointAy; - break; - case 2: - tempPointAx = bottomRightAx; - tempPointAy = p1y + halfWidthA * slopePrime; - result[0] = tempPointAx; - result[1] = tempPointAy; - break; - case 3: - tempPointAy = bottomLeftAy; - tempPointAx = p1x + halfHeightA / slopePrime; - result[0] = tempPointAx; - result[1] = tempPointAy; - break; - case 4: - tempPointAx = bottomLeftAx; - tempPointAy = p1y + -halfWidthA * slopePrime; - result[0] = tempPointAx; - result[1] = tempPointAy; - break; - } - } - if (!clipPointBFound) { - switch (cardinalDirectionB) { - case 1: - tempPointBy = topLeftBy; - tempPointBx = p2x + -halfHeightB / slopePrime; - result[2] = tempPointBx; - result[3] = tempPointBy; - break; - case 2: - tempPointBx = bottomRightBx; - tempPointBy = p2y + halfWidthB * slopePrime; - result[2] = tempPointBx; - result[3] = tempPointBy; - break; - case 3: - tempPointBy = bottomLeftBy; - tempPointBx = p2x + halfHeightB / slopePrime; - result[2] = tempPointBx; - result[3] = tempPointBy; - break; - case 4: - tempPointBx = bottomLeftBx; - tempPointBy = p2y + -halfWidthB * slopePrime; - result[2] = tempPointBx; - result[3] = tempPointBy; - break; - } - } - } - return false; -}; - -IGeometry.getCardinalDirection = function (slope, slopePrime, line) { - if (slope > slopePrime) { - return line; - } else { - return 1 + line % 4; - } -}; - -IGeometry.getIntersection = function (s1, s2, f1, f2) { - if (f2 == null) { - return IGeometry.getIntersection2(s1, s2, f1); - } - var x1 = s1.x; - var y1 = s1.y; - var x2 = s2.x; - var y2 = s2.y; - var x3 = f1.x; - var y3 = f1.y; - var x4 = f2.x; - var y4 = f2.y; - var x, y; // intersection point - var a1, a2, b1, b2, c1, c2; // coefficients of line eqns. - var denom; - - a1 = y2 - y1; - b1 = x1 - x2; - c1 = x2 * y1 - x1 * y2; // { a1*x + b1*y + c1 = 0 is line 1 } - - a2 = y4 - y3; - b2 = x3 - x4; - c2 = x4 * y3 - x3 * y4; // { a2*x + b2*y + c2 = 0 is line 2 } - - denom = a1 * b2 - a2 * b1; - - if (denom == 0) { - return null; - } - - x = (b1 * c2 - b2 * c1) / denom; - y = (a2 * c1 - a1 * c2) / denom; - - return new Point(x, y); -}; - -// ----------------------------------------------------------------------------- -// Section: Class Constants -// ----------------------------------------------------------------------------- -/** - * Some useful pre-calculated constants - */ -IGeometry.HALF_PI = 0.5 * Math.PI; -IGeometry.ONE_AND_HALF_PI = 1.5 * Math.PI; -IGeometry.TWO_PI = 2.0 * Math.PI; -IGeometry.THREE_PI = 3.0 * Math.PI; - -module.exports = IGeometry; - -/***/ }), -/* 10 */ -/***/ (function(module, exports) { - -function IMath() {} - -/** - * This method returns the sign of the input value. - */ -IMath.sign = function (value) { - if (value > 0) { - return 1; - } else if (value < 0) { - return -1; - } else { - return 0; - } -}; - -IMath.floor = function (value) { - return value < 0 ? Math.ceil(value) : Math.floor(value); -}; - -IMath.ceil = function (value) { - return value < 0 ? Math.floor(value) : Math.ceil(value); -}; - -module.exports = IMath; - -/***/ }), -/* 11 */ -/***/ (function(module, exports, __webpack_require__) { - -var LGraphObject = __webpack_require__(8); -var Integer = __webpack_require__(12); -var LayoutConstants = __webpack_require__(3); -var LGraphManager = __webpack_require__(6); -var LNode = __webpack_require__(13); -var LEdge = __webpack_require__(7); -var RectangleD = __webpack_require__(14); -var Point = __webpack_require__(18); -var LinkedList = __webpack_require__(19); - -function LGraph(parent, obj2, vGraph) { - LGraphObject.call(this, vGraph); - this.estimatedSize = Integer.MIN_VALUE; - this.margin = LayoutConstants.DEFAULT_GRAPH_MARGIN; - this.edges = []; - this.nodes = []; - this.isConnected = false; - this.parent = parent; - - if (obj2 != null && obj2 instanceof LGraphManager) { - this.graphManager = obj2; - } else if (obj2 != null && obj2 instanceof Layout) { - this.graphManager = obj2.graphManager; - } -} - -LGraph.prototype = Object.create(LGraphObject.prototype); -for (var prop in LGraphObject) { - LGraph[prop] = LGraphObject[prop]; -} - -LGraph.prototype.getNodes = function () { - return this.nodes; -}; - -LGraph.prototype.getEdges = function () { - return this.edges; -}; - -LGraph.prototype.getGraphManager = function () { - return this.graphManager; -}; - -LGraph.prototype.getParent = function () { - return this.parent; -}; - -LGraph.prototype.getLeft = function () { - return this.left; -}; - -LGraph.prototype.getRight = function () { - return this.right; -}; - -LGraph.prototype.getTop = function () { - return this.top; -}; - -LGraph.prototype.getBottom = function () { - return this.bottom; -}; - -LGraph.prototype.isConnected = function () { - return this.isConnected; -}; - -LGraph.prototype.add = function (obj1, sourceNode, targetNode) { - if (sourceNode == null && targetNode == null) { - var newNode = obj1; - if (this.graphManager == null) { - throw "Graph has no graph mgr!"; - } - if (this.getNodes().indexOf(newNode) > -1) { - throw "Node already in graph!"; - } - newNode.owner = this; - this.getNodes().push(newNode); - - return newNode; - } else { - var newEdge = obj1; - if (!(this.getNodes().indexOf(sourceNode) > -1 && this.getNodes().indexOf(targetNode) > -1)) { - throw "Source or target not in graph!"; - } - - if (!(sourceNode.owner == targetNode.owner && sourceNode.owner == this)) { - throw "Both owners must be this graph!"; - } - - if (sourceNode.owner != targetNode.owner) { - return null; - } - - // set source and target - newEdge.source = sourceNode; - newEdge.target = targetNode; - - // set as intra-graph edge - newEdge.isInterGraph = false; - - // add to graph edge list - this.getEdges().push(newEdge); - - // add to incidency lists - sourceNode.edges.push(newEdge); - - if (targetNode != sourceNode) { - targetNode.edges.push(newEdge); - } - - return newEdge; - } -}; - -LGraph.prototype.remove = function (obj) { - var node = obj; - if (obj instanceof LNode) { - if (node == null) { - throw "Node is null!"; - } - if (!(node.owner != null && node.owner == this)) { - throw "Owner graph is invalid!"; - } - if (this.graphManager == null) { - throw "Owner graph manager is invalid!"; - } - // remove incident edges first (make a copy to do it safely) - var edgesToBeRemoved = node.edges.slice(); - var edge; - var s = edgesToBeRemoved.length; - for (var i = 0; i < s; i++) { - edge = edgesToBeRemoved[i]; - - if (edge.isInterGraph) { - this.graphManager.remove(edge); - } else { - edge.source.owner.remove(edge); - } - } - - // now the node itself - var index = this.nodes.indexOf(node); - if (index == -1) { - throw "Node not in owner node list!"; - } - - this.nodes.splice(index, 1); - } else if (obj instanceof LEdge) { - var edge = obj; - if (edge == null) { - throw "Edge is null!"; - } - if (!(edge.source != null && edge.target != null)) { - throw "Source and/or target is null!"; - } - if (!(edge.source.owner != null && edge.target.owner != null && edge.source.owner == this && edge.target.owner == this)) { - throw "Source and/or target owner is invalid!"; - } - - var sourceIndex = edge.source.edges.indexOf(edge); - var targetIndex = edge.target.edges.indexOf(edge); - if (!(sourceIndex > -1 && targetIndex > -1)) { - throw "Source and/or target doesn't know this edge!"; - } - - edge.source.edges.splice(sourceIndex, 1); - - if (edge.target != edge.source) { - edge.target.edges.splice(targetIndex, 1); - } - - var index = edge.source.owner.getEdges().indexOf(edge); - if (index == -1) { - throw "Not in owner's edge list!"; - } - - edge.source.owner.getEdges().splice(index, 1); - } -}; - -LGraph.prototype.updateLeftTop = function () { - var top = Integer.MAX_VALUE; - var left = Integer.MAX_VALUE; - var nodeTop; - var nodeLeft; - var margin; - - var nodes = this.getNodes(); - var s = nodes.length; - - for (var i = 0; i < s; i++) { - var lNode = nodes[i]; - nodeTop = lNode.getTop(); - nodeLeft = lNode.getLeft(); - - if (top > nodeTop) { - top = nodeTop; - } - - if (left > nodeLeft) { - left = nodeLeft; - } - } - - // Do we have any nodes in this graph? - if (top == Integer.MAX_VALUE) { - return null; - } - - if (nodes[0].getParent().paddingLeft != undefined) { - margin = nodes[0].getParent().paddingLeft; - } else { - margin = this.margin; - } - - this.left = left - margin; - this.top = top - margin; - - // Apply the margins and return the result - return new Point(this.left, this.top); -}; - -LGraph.prototype.updateBounds = function (recursive) { - // calculate bounds - var left = Integer.MAX_VALUE; - var right = -Integer.MAX_VALUE; - var top = Integer.MAX_VALUE; - var bottom = -Integer.MAX_VALUE; - var nodeLeft; - var nodeRight; - var nodeTop; - var nodeBottom; - var margin; - - var nodes = this.nodes; - var s = nodes.length; - for (var i = 0; i < s; i++) { - var lNode = nodes[i]; - - if (recursive && lNode.child != null) { - lNode.updateBounds(); - } - nodeLeft = lNode.getLeft(); - nodeRight = lNode.getRight(); - nodeTop = lNode.getTop(); - nodeBottom = lNode.getBottom(); - - if (left > nodeLeft) { - left = nodeLeft; - } - - if (right < nodeRight) { - right = nodeRight; - } - - if (top > nodeTop) { - top = nodeTop; - } - - if (bottom < nodeBottom) { - bottom = nodeBottom; - } - } - - var boundingRect = new RectangleD(left, top, right - left, bottom - top); - if (left == Integer.MAX_VALUE) { - this.left = this.parent.getLeft(); - this.right = this.parent.getRight(); - this.top = this.parent.getTop(); - this.bottom = this.parent.getBottom(); - } - - if (nodes[0].getParent().paddingLeft != undefined) { - margin = nodes[0].getParent().paddingLeft; - } else { - margin = this.margin; - } - - this.left = boundingRect.x - margin; - this.right = boundingRect.x + boundingRect.width + margin; - this.top = boundingRect.y - margin; - this.bottom = boundingRect.y + boundingRect.height + margin; -}; - -LGraph.calculateBounds = function (nodes) { - var left = Integer.MAX_VALUE; - var right = -Integer.MAX_VALUE; - var top = Integer.MAX_VALUE; - var bottom = -Integer.MAX_VALUE; - var nodeLeft; - var nodeRight; - var nodeTop; - var nodeBottom; - - var s = nodes.length; - - for (var i = 0; i < s; i++) { - var lNode = nodes[i]; - nodeLeft = lNode.getLeft(); - nodeRight = lNode.getRight(); - nodeTop = lNode.getTop(); - nodeBottom = lNode.getBottom(); - - if (left > nodeLeft) { - left = nodeLeft; - } - - if (right < nodeRight) { - right = nodeRight; - } - - if (top > nodeTop) { - top = nodeTop; - } - - if (bottom < nodeBottom) { - bottom = nodeBottom; - } - } - - var boundingRect = new RectangleD(left, top, right - left, bottom - top); - - return boundingRect; -}; - -LGraph.prototype.getInclusionTreeDepth = function () { - if (this == this.graphManager.getRoot()) { - return 1; - } else { - return this.parent.getInclusionTreeDepth(); - } -}; - -LGraph.prototype.getEstimatedSize = function () { - if (this.estimatedSize == Integer.MIN_VALUE) { - throw "assert failed"; - } - return this.estimatedSize; -}; - -LGraph.prototype.calcEstimatedSize = function () { - var size = 0; - var nodes = this.nodes; - var s = nodes.length; - - for (var i = 0; i < s; i++) { - var lNode = nodes[i]; - size += lNode.calcEstimatedSize(); - } - - if (size == 0) { - this.estimatedSize = LayoutConstants.EMPTY_COMPOUND_NODE_SIZE; - } else { - this.estimatedSize = size / Math.sqrt(this.nodes.length); - } - - return this.estimatedSize; -}; - -LGraph.prototype.updateConnected = function () { - var self = this; - if (this.nodes.length == 0) { - this.isConnected = true; - return; - } - - var queue = new LinkedList(); - var visited = new Set(); - var currentNode = this.nodes[0]; - var neighborEdges; - var currentNeighbor; - var childrenOfNode = currentNode.withChildren(); - childrenOfNode.forEach(function (node) { - queue.push(node); - visited.add(node); - }); - - while (queue.length !== 0) { - currentNode = queue.shift(); - - // Traverse all neighbors of this node - neighborEdges = currentNode.getEdges(); - var size = neighborEdges.length; - for (var i = 0; i < size; i++) { - var neighborEdge = neighborEdges[i]; - currentNeighbor = neighborEdge.getOtherEndInGraph(currentNode, this); - - // Add unvisited neighbors to the list to visit - if (currentNeighbor != null && !visited.has(currentNeighbor)) { - var childrenOfNeighbor = currentNeighbor.withChildren(); - - childrenOfNeighbor.forEach(function (node) { - queue.push(node); - visited.add(node); - }); - } - } - } - - this.isConnected = false; - - if (visited.size >= this.nodes.length) { - var noOfVisitedInThisGraph = 0; - - visited.forEach(function (visitedNode) { - if (visitedNode.owner == self) { - noOfVisitedInThisGraph++; - } - }); - - if (noOfVisitedInThisGraph == this.nodes.length) { - this.isConnected = true; - } - } -}; - -module.exports = LGraph; - -/***/ }), -/* 12 */ -/***/ (function(module, exports) { - -function Integer() {} - -Integer.MAX_VALUE = 2147483647; -Integer.MIN_VALUE = -2147483648; - -module.exports = Integer; - -/***/ }), -/* 13 */ -/***/ (function(module, exports, __webpack_require__) { - -var LGraphObject = __webpack_require__(8); -var Integer = __webpack_require__(12); -var RectangleD = __webpack_require__(14); -var LayoutConstants = __webpack_require__(3); -var RandomSeed = __webpack_require__(15); -var PointD = __webpack_require__(16); -var HashSet = __webpack_require__(17); - -function LNode(gm, loc, size, vNode) { - //Alternative constructor 1 : LNode(LGraphManager gm, Point loc, Dimension size, Object vNode) - if (size == null && vNode == null) { - vNode = loc; - } - - LGraphObject.call(this, vNode); - - //Alternative constructor 2 : LNode(Layout layout, Object vNode) - if (gm.graphManager != null) gm = gm.graphManager; - - this.estimatedSize = Integer.MIN_VALUE; - this.inclusionTreeDepth = Integer.MAX_VALUE; - this.vGraphObject = vNode; - this.edges = []; - this.graphManager = gm; - - if (size != null && loc != null) this.rect = new RectangleD(loc.x, loc.y, size.width, size.height);else this.rect = new RectangleD(); -} - -LNode.prototype = Object.create(LGraphObject.prototype); -for (var prop in LGraphObject) { - LNode[prop] = LGraphObject[prop]; -} - -LNode.prototype.getEdges = function () { - return this.edges; -}; - -LNode.prototype.getChild = function () { - return this.child; -}; - -LNode.prototype.getOwner = function () { - // if (this.owner != null) { - // if (!(this.owner == null || this.owner.getNodes().indexOf(this) > -1)) { - // throw "assert failed"; - // } - // } - - return this.owner; -}; - -LNode.prototype.getWidth = function () { - return this.rect.width; -}; - -LNode.prototype.setWidth = function (width) { - this.rect.width = width; -}; - -LNode.prototype.getHeight = function () { - return this.rect.height; -}; - -LNode.prototype.setHeight = function (height) { - this.rect.height = height; -}; - -LNode.prototype.getCenterX = function () { - return this.rect.x + this.rect.width / 2; -}; - -LNode.prototype.getCenterY = function () { - return this.rect.y + this.rect.height / 2; -}; - -LNode.prototype.getCenter = function () { - return new PointD(this.rect.x + this.rect.width / 2, this.rect.y + this.rect.height / 2); -}; - -LNode.prototype.getLocation = function () { - return new PointD(this.rect.x, this.rect.y); -}; - -LNode.prototype.getRect = function () { - return this.rect; -}; - -LNode.prototype.getDiagonal = function () { - return Math.sqrt(this.rect.width * this.rect.width + this.rect.height * this.rect.height); -}; - -LNode.prototype.setRect = function (upperLeft, dimension) { - this.rect.x = upperLeft.x; - this.rect.y = upperLeft.y; - this.rect.width = dimension.width; - this.rect.height = dimension.height; -}; - -LNode.prototype.setCenter = function (cx, cy) { - this.rect.x = cx - this.rect.width / 2; - this.rect.y = cy - this.rect.height / 2; -}; - -LNode.prototype.setLocation = function (x, y) { - this.rect.x = x; - this.rect.y = y; -}; - -LNode.prototype.moveBy = function (dx, dy) { - this.rect.x += dx; - this.rect.y += dy; -}; - -LNode.prototype.getEdgeListToNode = function (to) { - var edgeList = []; - var edge; - var self = this; - - self.edges.forEach(function (edge) { - - if (edge.target == to) { - if (edge.source != self) throw "Incorrect edge source!"; - - edgeList.push(edge); - } - }); - - return edgeList; -}; - -LNode.prototype.getEdgesBetween = function (other) { - var edgeList = []; - var edge; - - var self = this; - self.edges.forEach(function (edge) { - - if (!(edge.source == self || edge.target == self)) throw "Incorrect edge source and/or target"; - - if (edge.target == other || edge.source == other) { - edgeList.push(edge); - } - }); - - return edgeList; -}; - -LNode.prototype.getNeighborsList = function () { - var neighbors = new HashSet(); - var edge; - - var self = this; - self.edges.forEach(function (edge) { - - if (edge.source == self) { - neighbors.add(edge.target); - } else { - if (edge.target != self) { - throw "Incorrect incidency!"; - } - - neighbors.add(edge.source); - } - }); - - return neighbors; -}; - -LNode.prototype.withChildren = function () { - var withNeighborsList = new Set(); - var childNode; - var children; - - withNeighborsList.add(this); - - if (this.child != null) { - var nodes = this.child.getNodes(); - for (var i = 0; i < nodes.length; i++) { - childNode = nodes[i]; - children = childNode.withChildren(); - children.forEach(function (node) { - withNeighborsList.add(node); - }); - } - } - - return withNeighborsList; -}; - -LNode.prototype.getNoOfChildren = function () { - var noOfChildren = 0; - var childNode; - - if (this.child == null) { - noOfChildren = 1; - } else { - var nodes = this.child.getNodes(); - for (var i = 0; i < nodes.length; i++) { - childNode = nodes[i]; - - noOfChildren += childNode.getNoOfChildren(); - } - } - - if (noOfChildren == 0) { - noOfChildren = 1; - } - return noOfChildren; -}; - -LNode.prototype.getEstimatedSize = function () { - if (this.estimatedSize == Integer.MIN_VALUE) { - throw "assert failed"; - } - return this.estimatedSize; -}; - -LNode.prototype.calcEstimatedSize = function () { - if (this.child == null) { - return this.estimatedSize = (this.rect.width + this.rect.height) / 2; - } else { - this.estimatedSize = this.child.calcEstimatedSize(); - this.rect.width = this.estimatedSize; - this.rect.height = this.estimatedSize; - - return this.estimatedSize; - } -}; - -LNode.prototype.scatter = function () { - var randomCenterX; - var randomCenterY; - - var minX = -LayoutConstants.INITIAL_WORLD_BOUNDARY; - var maxX = LayoutConstants.INITIAL_WORLD_BOUNDARY; - randomCenterX = LayoutConstants.WORLD_CENTER_X + RandomSeed.nextDouble() * (maxX - minX) + minX; - - var minY = -LayoutConstants.INITIAL_WORLD_BOUNDARY; - var maxY = LayoutConstants.INITIAL_WORLD_BOUNDARY; - randomCenterY = LayoutConstants.WORLD_CENTER_Y + RandomSeed.nextDouble() * (maxY - minY) + minY; - - this.rect.x = randomCenterX; - this.rect.y = randomCenterY; -}; - -LNode.prototype.updateBounds = function () { - if (this.getChild() == null) { - throw "assert failed"; - } - if (this.getChild().getNodes().length != 0) { - // wrap the children nodes by re-arranging the boundaries - var childGraph = this.getChild(); - childGraph.updateBounds(true); - - this.rect.x = childGraph.getLeft(); - this.rect.y = childGraph.getTop(); - - this.setWidth(childGraph.getRight() - childGraph.getLeft()); - this.setHeight(childGraph.getBottom() - childGraph.getTop()); - - // Update compound bounds considering its label properties - if (LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS) { - - var width = childGraph.getRight() - childGraph.getLeft(); - var height = childGraph.getBottom() - childGraph.getTop(); - - if (this.labelWidth > width) { - this.rect.x -= (this.labelWidth - width) / 2; - this.setWidth(this.labelWidth); - } - - if (this.labelHeight > height) { - if (this.labelPos == "center") { - this.rect.y -= (this.labelHeight - height) / 2; - } else if (this.labelPos == "top") { - this.rect.y -= this.labelHeight - height; - } - this.setHeight(this.labelHeight); - } - } - } -}; - -LNode.prototype.getInclusionTreeDepth = function () { - if (this.inclusionTreeDepth == Integer.MAX_VALUE) { - throw "assert failed"; - } - return this.inclusionTreeDepth; -}; - -LNode.prototype.transform = function (trans) { - var left = this.rect.x; - - if (left > LayoutConstants.WORLD_BOUNDARY) { - left = LayoutConstants.WORLD_BOUNDARY; - } else if (left < -LayoutConstants.WORLD_BOUNDARY) { - left = -LayoutConstants.WORLD_BOUNDARY; - } - - var top = this.rect.y; - - if (top > LayoutConstants.WORLD_BOUNDARY) { - top = LayoutConstants.WORLD_BOUNDARY; - } else if (top < -LayoutConstants.WORLD_BOUNDARY) { - top = -LayoutConstants.WORLD_BOUNDARY; - } - - var leftTop = new PointD(left, top); - var vLeftTop = trans.inverseTransformPoint(leftTop); - - this.setLocation(vLeftTop.x, vLeftTop.y); -}; - -LNode.prototype.getLeft = function () { - return this.rect.x; -}; - -LNode.prototype.getRight = function () { - return this.rect.x + this.rect.width; -}; - -LNode.prototype.getTop = function () { - return this.rect.y; -}; - -LNode.prototype.getBottom = function () { - return this.rect.y + this.rect.height; -}; - -LNode.prototype.getParent = function () { - if (this.owner == null) { - return null; - } - - return this.owner.getParent(); -}; - -module.exports = LNode; - -/***/ }), -/* 14 */ -/***/ (function(module, exports) { - -function RectangleD(x, y, width, height) { - this.x = 0; - this.y = 0; - this.width = 0; - this.height = 0; - - if (x != null && y != null && width != null && height != null) { - this.x = x; - this.y = y; - this.width = width; - this.height = height; - } -} - -RectangleD.prototype.getX = function () { - return this.x; -}; - -RectangleD.prototype.setX = function (x) { - this.x = x; -}; - -RectangleD.prototype.getY = function () { - return this.y; -}; - -RectangleD.prototype.setY = function (y) { - this.y = y; -}; - -RectangleD.prototype.getWidth = function () { - return this.width; -}; - -RectangleD.prototype.setWidth = function (width) { - this.width = width; -}; - -RectangleD.prototype.getHeight = function () { - return this.height; -}; - -RectangleD.prototype.setHeight = function (height) { - this.height = height; -}; - -RectangleD.prototype.getRight = function () { - return this.x + this.width; -}; - -RectangleD.prototype.getBottom = function () { - return this.y + this.height; -}; - -RectangleD.prototype.intersects = function (a) { - if (this.getRight() < a.x) { - return false; - } - - if (this.getBottom() < a.y) { - return false; - } - - if (a.getRight() < this.x) { - return false; - } - - if (a.getBottom() < this.y) { - return false; - } - - return true; -}; - -RectangleD.prototype.getCenterX = function () { - return this.x + this.width / 2; -}; - -RectangleD.prototype.getMinX = function () { - return this.getX(); -}; - -RectangleD.prototype.getMaxX = function () { - return this.getX() + this.width; -}; - -RectangleD.prototype.getCenterY = function () { - return this.y + this.height / 2; -}; - -RectangleD.prototype.getMinY = function () { - return this.getY(); -}; - -RectangleD.prototype.getMaxY = function () { - return this.getY() + this.height; -}; - -RectangleD.prototype.getWidthHalf = function () { - return this.width / 2; -}; - -RectangleD.prototype.getHeightHalf = function () { - return this.height / 2; -}; - -module.exports = RectangleD; - -/***/ }), -/* 15 */ -/***/ (function(module, exports) { - -function RandomSeed() {} -RandomSeed.seed = 1; -RandomSeed.x = 0; - -RandomSeed.nextDouble = function () { - RandomSeed.x = Math.sin(RandomSeed.seed++) * 10000; - return RandomSeed.x - Math.floor(RandomSeed.x); -}; - -module.exports = RandomSeed; - -/***/ }), -/* 16 */ -/***/ (function(module, exports) { - -function PointD(x, y) { - if (x == null && y == null) { - this.x = 0; - this.y = 0; - } else { - this.x = x; - this.y = y; - } -} - -PointD.prototype.getX = function () { - return this.x; -}; - -PointD.prototype.getY = function () { - return this.y; -}; - -PointD.prototype.setX = function (x) { - this.x = x; -}; - -PointD.prototype.setY = function (y) { - this.y = y; -}; - -PointD.prototype.getDifference = function (pt) { - return new DimensionD(this.x - pt.x, this.y - pt.y); -}; - -PointD.prototype.getCopy = function () { - return new PointD(this.x, this.y); -}; - -PointD.prototype.translate = function (dim) { - this.x += dim.width; - this.y += dim.height; - return this; -}; - -module.exports = PointD; - -/***/ }), -/* 17 */ -/***/ (function(module, exports, __webpack_require__) { - -var UniqueIDGeneretor = __webpack_require__(5); - -function HashSet() { - this.set = {}; -} -; - -HashSet.prototype.add = function (obj) { - var theId = UniqueIDGeneretor.createID(obj); - if (!this.contains(theId)) this.set[theId] = obj; -}; - -HashSet.prototype.remove = function (obj) { - delete this.set[UniqueIDGeneretor.createID(obj)]; -}; - -HashSet.prototype.clear = function () { - this.set = {}; -}; - -HashSet.prototype.contains = function (obj) { - return this.set[UniqueIDGeneretor.createID(obj)] == obj; -}; - -HashSet.prototype.isEmpty = function () { - return this.size() === 0; -}; - -HashSet.prototype.size = function () { - return Object.keys(this.set).length; -}; - -//concats this.set to the given list -HashSet.prototype.addAllTo = function (list) { - var keys = Object.keys(this.set); - var length = keys.length; - for (var i = 0; i < length; i++) { - list.push(this.set[keys[i]]); - } -}; - -HashSet.prototype.size = function () { - return Object.keys(this.set).length; -}; - -HashSet.prototype.addAll = function (list) { - var s = list.length; - for (var i = 0; i < s; i++) { - var v = list[i]; - this.add(v); - } -}; - -module.exports = HashSet; - -/***/ }), -/* 18 */ -/***/ (function(module, exports) { - -/* - *This class is the javascript implementation of the Point.java class in jdk - */ -function Point(x, y, p) { - this.x = null; - this.y = null; - if (x == null && y == null && p == null) { - this.x = 0; - this.y = 0; - } else if (typeof x == 'number' && typeof y == 'number' && p == null) { - this.x = x; - this.y = y; - } else if (x.constructor.name == 'Point' && y == null && p == null) { - p = x; - this.x = p.x; - this.y = p.y; - } -} - -Point.prototype.getX = function () { - return this.x; -}; - -Point.prototype.getY = function () { - return this.y; -}; - -Point.prototype.getLocation = function () { - return new Point(this.x, this.y); -}; - -Point.prototype.setLocation = function (x, y, p) { - if (x.constructor.name == 'Point' && y == null && p == null) { - p = x; - this.setLocation(p.x, p.y); - } else if (typeof x == 'number' && typeof y == 'number' && p == null) { - //if both parameters are integer just move (x,y) location - if (parseInt(x) == x && parseInt(y) == y) { - this.move(x, y); - } else { - this.x = Math.floor(x + 0.5); - this.y = Math.floor(y + 0.5); - } - } -}; - -Point.prototype.move = function (x, y) { - this.x = x; - this.y = y; -}; - -Point.prototype.translate = function (dx, dy) { - this.x += dx; - this.y += dy; -}; - -Point.prototype.equals = function (obj) { - if (obj.constructor.name == "Point") { - var pt = obj; - return this.x == pt.x && this.y == pt.y; - } - return this == obj; -}; - -Point.prototype.toString = function () { - return new Point().constructor.name + "[x=" + this.x + ",y=" + this.y + "]"; -}; - -module.exports = Point; - -/***/ }), -/* 19 */ -/***/ (function(module, exports) { - -const nodeFrom = value => ({ value, next: null, prev: null }); - -const add = (prev, node, next, list) => { - if (prev !== null) { - prev.next = node; - } else { - list.head = node; - } - - if (next !== null) { - next.prev = node; - } else { - list.tail = node; - } - - node.prev = prev; - node.next = next; - - list.length++; - - return node; -}; - -const remove = (node, list) => { - let { prev, next } = node; - - if (prev !== null) { - prev.next = next; - } else { - list.head = next; - } - - if (next !== null) { - next.prev = prev; - } else { - list.tail = prev; - } - - node.prev = node.next = null; - - list.length--; - - return node; -}; - -class LinkedList { - constructor(vals) { - this.length = 0; - this.head = null; - this.tail = null; - - if (vals != null) { - vals.forEach(v => this.push(v)); - } - } - - size() { - return this.length; - } - - insertBefore(val, otherNode) { - return add(otherNode.prev, nodeFrom(val), otherNode, this); - } - - insertAfter(val, otherNode) { - return add(otherNode, nodeFrom(val), otherNode.next, this); - } - - insertNodeBefore(newNode, otherNode) { - return add(otherNode.prev, newNode, otherNode, this); - } - - insertNodeAfter(newNode, otherNode) { - return add(otherNode, newNode, otherNode.next, this); - } - - push(val) { - return add(this.tail, nodeFrom(val), null, this); - } - - unshift(val) { - return add(null, nodeFrom(val), this.head, this); - } - - remove(node) { - return remove(node, this); - } - - pop() { - return remove(this.tail, this).value; - } - - popNode() { - return remove(this.tail, this); - } - - shift() { - return remove(this.head, this).value; - } - - shiftNode() { - return remove(this.head, this); - } - - get_object_at(index) { - if (index <= this.length()) { - var i = 1; - var current = this.head; - while (i < index) { - current = current.next; - i++; - } - return current.value; - } - } - - set_object_at(index, value) { - if (index <= this.length()) { - var i = 1; - var current = this.head; - while (i < index) { - current = current.next; - i++; - } - current.value = value; - } - } -} - -module.exports = LinkedList; - -/***/ }), -/* 20 */ -/***/ (function(module, exports, __webpack_require__) { - -var PointD = __webpack_require__(16); - -function Transform(x, y) { - this.lworldOrgX = 0.0; - this.lworldOrgY = 0.0; - this.ldeviceOrgX = 0.0; - this.ldeviceOrgY = 0.0; - this.lworldExtX = 1.0; - this.lworldExtY = 1.0; - this.ldeviceExtX = 1.0; - this.ldeviceExtY = 1.0; -} - -Transform.prototype.getWorldOrgX = function () { - return this.lworldOrgX; -}; - -Transform.prototype.setWorldOrgX = function (wox) { - this.lworldOrgX = wox; -}; - -Transform.prototype.getWorldOrgY = function () { - return this.lworldOrgY; -}; - -Transform.prototype.setWorldOrgY = function (woy) { - this.lworldOrgY = woy; -}; - -Transform.prototype.getWorldExtX = function () { - return this.lworldExtX; -}; - -Transform.prototype.setWorldExtX = function (wex) { - this.lworldExtX = wex; -}; - -Transform.prototype.getWorldExtY = function () { - return this.lworldExtY; -}; - -Transform.prototype.setWorldExtY = function (wey) { - this.lworldExtY = wey; -}; - -/* Device related */ - -Transform.prototype.getDeviceOrgX = function () { - return this.ldeviceOrgX; -}; - -Transform.prototype.setDeviceOrgX = function (dox) { - this.ldeviceOrgX = dox; -}; - -Transform.prototype.getDeviceOrgY = function () { - return this.ldeviceOrgY; -}; - -Transform.prototype.setDeviceOrgY = function (doy) { - this.ldeviceOrgY = doy; -}; - -Transform.prototype.getDeviceExtX = function () { - return this.ldeviceExtX; -}; - -Transform.prototype.setDeviceExtX = function (dex) { - this.ldeviceExtX = dex; -}; - -Transform.prototype.getDeviceExtY = function () { - return this.ldeviceExtY; -}; - -Transform.prototype.setDeviceExtY = function (dey) { - this.ldeviceExtY = dey; -}; - -Transform.prototype.transformX = function (x) { - var xDevice = 0.0; - var worldExtX = this.lworldExtX; - if (worldExtX != 0.0) { - xDevice = this.ldeviceOrgX + (x - this.lworldOrgX) * this.ldeviceExtX / worldExtX; - } - - return xDevice; -}; - -Transform.prototype.transformY = function (y) { - var yDevice = 0.0; - var worldExtY = this.lworldExtY; - if (worldExtY != 0.0) { - yDevice = this.ldeviceOrgY + (y - this.lworldOrgY) * this.ldeviceExtY / worldExtY; - } - - return yDevice; -}; - -Transform.prototype.inverseTransformX = function (x) { - var xWorld = 0.0; - var deviceExtX = this.ldeviceExtX; - if (deviceExtX != 0.0) { - xWorld = this.lworldOrgX + (x - this.ldeviceOrgX) * this.lworldExtX / deviceExtX; - } - - return xWorld; -}; - -Transform.prototype.inverseTransformY = function (y) { - var yWorld = 0.0; - var deviceExtY = this.ldeviceExtY; - if (deviceExtY != 0.0) { - yWorld = this.lworldOrgY + (y - this.ldeviceOrgY) * this.lworldExtY / deviceExtY; - } - return yWorld; -}; - -Transform.prototype.inverseTransformPoint = function (inPoint) { - var outPoint = new PointD(this.inverseTransformX(inPoint.x), this.inverseTransformY(inPoint.y)); - return outPoint; -}; - -module.exports = Transform; - -/***/ }), -/* 21 */ -/***/ (function(module, exports) { - -function Emitter() { - this.listeners = []; -} - -var p = Emitter.prototype; - -p.addListener = function (event, callback) { - this.listeners.push({ - event: event, - callback: callback - }); -}; - -p.removeListener = function (event, callback) { - for (var i = this.listeners.length; i >= 0; i--) { - var l = this.listeners[i]; - - if (l.event === event && l.callback === callback) { - this.listeners.splice(i, 1); - } - } -}; - -p.emit = function (event, data) { - for (var i = 0; i < this.listeners.length; i++) { - var l = this.listeners[i]; - - if (event === l.event) { - l.callback(data); - } - } -}; - -module.exports = Emitter; - -/***/ }), -/* 22 */ -/***/ (function(module, exports, __webpack_require__) { - -var LayoutConstants = __webpack_require__(3); - -function FDLayoutConstants() {} - -//FDLayoutConstants inherits static props in LayoutConstants -for (var prop in LayoutConstants) { - FDLayoutConstants[prop] = LayoutConstants[prop]; -} - -FDLayoutConstants.MAX_ITERATIONS = 2500; - -FDLayoutConstants.DEFAULT_EDGE_LENGTH = 50; -FDLayoutConstants.DEFAULT_SPRING_STRENGTH = 0.45; -FDLayoutConstants.DEFAULT_REPULSION_STRENGTH = 4500.0; -FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH = 0.4; -FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = 1.0; -FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR = 3.8; -FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = 1.5; -FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION = true; -FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION = true; -FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = 0.5; -FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL = 100.0; -FDLayoutConstants.MAX_NODE_DISPLACEMENT = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL * 3; -FDLayoutConstants.MIN_REPULSION_DIST = FDLayoutConstants.DEFAULT_EDGE_LENGTH / 10.0; -FDLayoutConstants.CONVERGENCE_CHECK_PERIOD = 100; -FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = 0.1; -FDLayoutConstants.MIN_EDGE_LENGTH = 1; -FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD = 10; - -module.exports = FDLayoutConstants; - -/***/ }), -/* 23 */ -/***/ (function(module, exports, __webpack_require__) { - -var LEdge = __webpack_require__(7); -var FDLayoutConstants = __webpack_require__(22); - -function FDLayoutEdge(source, target, vEdge) { - LEdge.call(this, source, target, vEdge); - this.idealLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH; -} - -FDLayoutEdge.prototype = Object.create(LEdge.prototype); - -for (var prop in LEdge) { - FDLayoutEdge[prop] = LEdge[prop]; -} - -module.exports = FDLayoutEdge; - -/***/ }), -/* 24 */ -/***/ (function(module, exports, __webpack_require__) { - -var LNode = __webpack_require__(13); - -function FDLayoutNode(gm, loc, size, vNode) { - // alternative constructor is handled inside LNode - LNode.call(this, gm, loc, size, vNode); - //Spring, repulsion and gravitational forces acting on this node - this.springForceX = 0; - this.springForceY = 0; - this.repulsionForceX = 0; - this.repulsionForceY = 0; - this.gravitationForceX = 0; - this.gravitationForceY = 0; - //Amount by which this node is to be moved in this iteration - this.displacementX = 0; - this.displacementY = 0; - - //Start and finish grid coordinates that this node is fallen into - this.startX = 0; - this.finishX = 0; - this.startY = 0; - this.finishY = 0; - - //Geometric neighbors of this node - this.surrounding = []; -} - -FDLayoutNode.prototype = Object.create(LNode.prototype); - -for (var prop in LNode) { - FDLayoutNode[prop] = LNode[prop]; -} - -FDLayoutNode.prototype.setGridCoordinates = function (_startX, _finishX, _startY, _finishY) { - this.startX = _startX; - this.finishX = _finishX; - this.startY = _startY; - this.finishY = _finishY; -}; - -module.exports = FDLayoutNode; - -/***/ }), -/* 25 */ -/***/ (function(module, exports) { - -function DimensionD(width, height) { - this.width = 0; - this.height = 0; - if (width !== null && height !== null) { - this.height = height; - this.width = width; - } -} - -DimensionD.prototype.getWidth = function () { - return this.width; -}; - -DimensionD.prototype.setWidth = function (width) { - this.width = width; -}; - -DimensionD.prototype.getHeight = function () { - return this.height; -}; - -DimensionD.prototype.setHeight = function (height) { - this.height = height; -}; - -module.exports = DimensionD; - -/***/ }), -/* 26 */ -/***/ (function(module, exports, __webpack_require__) { - -const LinkedList = __webpack_require__(19); - -function Quicksort() {} - -Quicksort.get_object_at = function (list, i) { - if (list instanceof Array) { - return list[i]; - } else if (list instanceof LinkedList) { - return list.get_object_at(i); - } -}; - -Quicksort.set_object_at = function (list, i, value) { - if (list instanceof Array) { - list[i] = value; - } else if (list instanceof LinkedList) { - list.set_object_at(i, value); - } -}; - -Quicksort.quicksort = function (list, comparison_fn) { - - // input must be an instance of LinkedList class or must be an array in order to sort - if (!(list instanceof LinkedList || list instanceof Array)) { - return; - } - - var comparison_function = comparison_fn; - - if (comparison_function === undefined) { - comparison_function = Quicksort.compare; - } - var end_index; - - if (list instanceof LinkedList) { - end_index = list.size(); - } else if (list instanceof Array) { - end_index = list.length - 1; - } - - // Prevent empty lists or arrays. - if (end_index >= 0) { - Quicksort.quicksort_between_indices(list, 0, end_index, comparison_function); - } -}; - -Quicksort.quicksort_between_indices = function (list, low, high, comparison_fn) { - - // input must be an instance of LinkedList class or must be an array in order to sort - if (!(list instanceof LinkedList || list instanceof Array)) { - return; - } - - if (comparison_fn === undefined) { - comparison_fn = Quicksort.compare; - } - - var i = low; - var j = high; - var middleIndex = Math.floor((i + j) / 2); - var middle = Quicksort.get_object_at(list, middleIndex); - - do { - - while (comparison_fn(Quicksort.get_object_at(list, i), middle)) { - - i++; - } - - while (comparison_fn(middle, Quicksort.get_object_at(list, j))) { - - j--; - } - - if (i <= j) { - - var temp = Quicksort.get_object_at(list, i); - Quicksort.set_object_at(list, i, Quicksort.get_object_at(list, j)); - Quicksort.set_object_at(list, j, temp); - i++; - j--; - } - } while (i <= j); - - if (low < j) { - - Quicksort.quicksort_between_indices(list, low, j, comparison_fn); - } - - if (high > i) { - - Quicksort.quicksort_between_indices(list, i, high, comparison_fn); - } -}; - -// this function must be overriden for sorting different data types(e.g. string, integer etc.) -Quicksort.compare = function (a, b) { - return b > a; -}; - -module.exports = Quicksort; - -/***/ }) -/******/ ]); -}); - -/***/ }), -/* 2 */ -/***/ (function(module, exports, __webpack_require__) { - -var LayoutConstants = __webpack_require__(1).LayoutConstants; - -function AVSDFConstants() {} - -// AVSDFConstants inherits properties in LayoutConstants -for (var prop in LayoutConstants) { - AVSDFConstants[prop] = LayoutConstants[prop]; -} - -AVSDFConstants.DEFAULT_NODE_SEPARATION = 60; - -module.exports = AVSDFConstants; - -/***/ }), -/* 3 */ -/***/ (function(module, exports, __webpack_require__) { - -/** - * This class implements data and functionality required for AVSDF layout per - * edge. - * - - * Copyright: i-Vis Research Group, Bilkent University, 2007 - present - */ - -let LEdge = __webpack_require__(1).LEdge; - -// ----------------------------------------------------------------------------- -// Section: Initializations -// ----------------------------------------------------------------------------- - -function AVSDFEdge(source, target, vEdge) { - LEdge.call(this, source, target, vEdge); -} - -AVSDFEdge.prototype = Object.create(LEdge.prototype); - -for (let properties in LEdge) { - AVSDFEdge[properties] = LEdge[properties]; -} - -// ----------------------------------------------------------------------------- -// Section: Accessor Functions -// ----------------------------------------------------------------------------- - -// The function getOtherEnd returns the other end of this edge. -AVSDFEdge.prototype.getOtherEnd = function (node) { - return LEdge.prototype.getOtherEnd(node); -}; - -// ----------------------------------------------------------------------------- -// Section: Remaining Functions -// ----------------------------------------------------------------------------- - -// This function checks whether this edge crosses with the input edge. It -// returns false, if any of the vertices those edges are incident to are not -// yet placed on the circle. -AVSDFEdge.prototype.crossesWithEdge = function (otherEdge) { - let self = this; - let sourcePos = self.getSource().getIndex(); - let targetPos = self.getTarget().getIndex(); - let otherSourcePos = otherEdge.getSource().getIndex(); - let otherTargetPos = otherEdge.getTarget().getIndex(); - - // if any of the vertices those two edges are not yet placed - if (sourcePos === -1 || targetPos === -1 || otherSourcePos === -1 || otherTargetPos === -1) { - return false; - } - - let otherSourceDist = otherEdge.getSource().getCircDistWithTheNode(self.getSource()); - let otherTargetDist = otherEdge.getTarget().getCircDistWithTheNode(self.getSource()); - let thisTargetDist = self.getTarget().getCircDistWithTheNode(self.getSource()); - - if (thisTargetDist < Math.max(otherSourceDist, otherTargetDist) && thisTargetDist > Math.min(otherSourceDist, otherTargetDist) && otherTargetDist !== 0 && otherSourceDist !== 0) { - return true; - } - - return false; -}; - -// This function returns 1 if this edge crosses with the input edge, 0 -// otherwise. -AVSDFEdge.prototype.crossingWithEdge = function (otherEdge) { - let self = this; - let result = self.crossesWithEdge(otherEdge); - - return result ? 1 : 0; -}; - -// This function calculates the total number of crossings of this edge with -// all the edges given in the input list. -AVSDFEdge.prototype.calculateTotalCrossingWithList = function (edgeList) { - let self = this; - let totalCrossing = 0; - - edgeList.forEach(edge => totalCrossing += self.crossingWithEdge(edge)); - - return totalCrossing; -}; - -module.exports = AVSDFEdge; - -/***/ }), -/* 4 */ -/***/ (function(module, exports, __webpack_require__) { - -/** - * This class implements data and functionality required for AVSDF layout per - * circle. - * - * - * Copyright: i-Vis Research Group, Bilkent University, 2007 - present - */ - -let LGraph = __webpack_require__(1).LGraph; - -// ----------------------------------------------------------------------------- -// Section: Initializations -// ----------------------------------------------------------------------------- - -function AVSDFCircle(parent, graphMgr, vObject) { - LGraph.call(this, parent, graphMgr, vObject); - this.inOrder = undefined; - this.currentIndex = 0; - this.nodeSeparation = undefined; - this.stack = []; - this.perimeter = 0; - this.centerX = 0; - this.centerY = 0; - this.radius = 0; -} - -AVSDFCircle.prototype = Object.create(LGraph.prototype); - -for (let property in LGraph) { - AVSDFCircle[property] = LGraph[property]; -} - -AVSDFCircle.prototype.initOrdering = function () { - this.inOrder = []; -}; - -// ----------------------------------------------------------------------------- -// Section: Accessor Functions -// ----------------------------------------------------------------------------- - -// This function returns the array in which the nodes of this circle are kept in order. -AVSDFCircle.prototype.getOrder = function () { - return this.inOrder; -}; - -// This function returns the x-coordinate of the center of this circle. -AVSDFCircle.prototype.getCenterX = function () { - return this.centerX; -}; - -// This function returns the y-coordinate of the center of this circle. -AVSDFCircle.prototype.getCenterY = function () { - return this.centerY; -}; - -// This function returns the radius of this circle. -AVSDFCircle.prototype.getRadius = function () { - return this.radius; -}; - -// This function returns the total number of vertices of this circle. -AVSDFCircle.prototype.getSize = function () { - return this.getNodes().length; -}; - -// This function calculates and returns the total number of crossings in this -// circle by adding up the crossing number of individual nodes on it. -AVSDFCircle.prototype.getTotalCrossingOfCircle = function () { - let self = this; - let crossingNumber = 0; - - for (let node in self.inOrder) { - let nodeCrossing = node.getTotalCrossingOfEdges(); - if (nodeCrossing === -1) { - return -1; - } - crossingNumber += nodeCrossing; - } - - return crossingNumber / 4; -}; - -// This function checks whether or not all of the vertices of this circle are -// assigned an index on the circle. -AVSDFCircle.prototype.hasFinishedOrdering = function () { - return this.currentIndex === this.getNodes().length; -}; - -// This function returns the node separation of this circle. -AVSDFCircle.prototype.getNodeSeparation = function () { - return this.nodeSeparation; -}; - -// This function sets the node separation of this circle. -AVSDFCircle.prototype.setNodeSeparation = function (nodeSeparation) { - this.nodeSeparation = nodeSeparation; -}; - -// ----------------------------------------------------------------------------- -// Section: Remaining Functions -// ----------------------------------------------------------------------------- - -// This function traverses the vertices of this circle and corrects the angle -// of the vertices with respect to their circle indices. -AVSDFCircle.prototype.correctAngles = function () { - let self = this; - self.currentIndex = 0; - - self.inOrder.forEach(node => self.putInOrder(node)); -}; - -// This function puts the given node on the circle in the current order and -// sets its angle appropriately. -AVSDFCircle.prototype.putInOrder = function (node) { - let self = this; - - let nodes = self.getNodes(); - - // Note that id attribute of a node is added before - // AVSDFLayout is called - let found = false; - for (let i = 0; i < nodes.length; i++) { - if (nodes[i].id == node.id) { - found = true; - break; - } - } - - if (!found) { - throw "The node must be a member of LGraph"; - } - - self.inOrder[self.currentIndex] = node; - node.setIndex(self.currentIndex); - - if (self.currentIndex === 0) { - node.setAngle(0.0); - } else { - node.setAngle(self.inOrder[self.currentIndex - 1].getAngle() + 2 * Math.PI * (node.getDiagonal() / 2 + self.nodeSeparation + self.inOrder[self.currentIndex - 1].getDiagonal() / 2) / self.perimeter); - } - - self.currentIndex++; -}; - -// This function returns the next node to be placed on this circle with -// respect to the AVSDF algorithm. -AVSDFCircle.prototype.findNodeToPlace = function () { - let self = this; - let sDegreeNode = undefined; - - // Find the smallest degree vertex if the stack is empty - if (self.stack.length === 0) { - sDegreeNode = self.findUnorderedSmallestDegreeNode(); - } - // Find the first vertex in the stack not yet placed - else { - let foundUnorderNode = false; - - while (!foundUnorderNode && !(self.stack.length === 0)) { - sDegreeNode = self.stack.pop(); - foundUnorderNode = !sDegreeNode.isOrdered(); - } - - if (!foundUnorderNode) { - sDegreeNode = undefined; - } - } - - // If no unordered vertex is found in the stack, find one - // from the remaining ones - if (sDegreeNode === undefined) { - sDegreeNode = self.findUnorderedSmallestDegreeNode(); - } - - // Add the unordered neighbors of this node to the stack - if (sDegreeNode !== undefined) { - let neighbors = sDegreeNode.getNeighborsSortedByDegree(); - - for (let i = neighbors.length - 1; i >= 0; i--) { - let neighbor = neighbors[i]; - - if (!neighbor.isOrdered()) // Check here for possible error - { - self.stack.push(neighbor); - } - } - } - - return sDegreeNode; -}; - -// This function calculates the radius of this circle with respect to the sizes -// of the vertices and the node separation parameter. -AVSDFCircle.prototype.calculateRadius = function () { - let self = this; - let totalDiagonal = 0; - - self.getNodes().forEach(node => totalDiagonal += Math.sqrt(node.getWidth() * node.getWidth() + node.getHeight() * node.getHeight())); - - self.perimeter = totalDiagonal + self.getNodes().length * self.nodeSeparation; - let radius = self.perimeter / (2 * Math.PI); - - // Check here for possible error - - self.getParent().setWidth(2 * radius); - self.getParent().setHeight(2 * radius); - self.getParent().setCenter(self.getParent().getWidth(), self.getParent().getHeight()); - - self.centerX = self.getParent().getCenterX(); - self.centerY = self.getParent().getCenterY(); - self.radius = self.getParent().getHeight() / 2; -}; - -// This function calculates the total number of crossings of all vertices of -// this circle. -AVSDFCircle.prototype.calculateEdgeCrossingsOfNodes = function () { - this.getNodes().forEach(node => node.calculateTotalCrossing()); -}; - -// This function sets the index of each vertex to its position in inOrder -// array. Note that index of a node can be different from its place in the -// array due to crossing reduction phase of the AVSDF algorithm. It loads -// old index values to vertices due to an increase in the number of -// crossings with the new indices. -AVSDFCircle.prototype.loadOldIndicesOfNodes = function () { - //this.inOrder.forEach( (node,index) => node.setIndex(index)); - var self = this; - for (let i = 0; i < this.inOrder.length; i++) { - self.inOrder[i].setIndex(i); - } -}; - -// This function sets the position of each node in inOrder array to its index. -// Note that index of a node can be different from its place in the inOrder -// array due to crossing reduction phase of the AVSDF algorithm. This function -// puts the nodes to their new index values in inOrder array due to a -// decrease in the number of crossings with the new indices. -AVSDFCircle.prototype.reOrderVertices = function () { - var self = this; - this.getNodes().forEach(node => self.inOrder[node.getIndex()] = node); -}; - -// This function finds and returns the unordered smallest degree vertex on -// this circle. -AVSDFCircle.prototype.findUnorderedSmallestDegreeNode = function () { - let minDegree = Number.MAX_SAFE_INTEGER; - let sDegreeNode; - - this.getNodes().forEach(function (node) { - if (node.getDegree() < minDegree && !node.isOrdered()) { - minDegree = node.getDegree(); - sDegreeNode = node; - } - }); - - return sDegreeNode; -}; - -module.exports = AVSDFCircle; - -/***/ }), -/* 5 */ -/***/ (function(module, exports, __webpack_require__) { - -/** - * This class implements the overall layout process for the AVSDF algorithm - * (Circular Drawing Algorithm by He and Sykora). - * - * - * Copyright: i-Vis Research Group, Bilkent University, 2007 - present - */ - -let Layout = __webpack_require__(1).Layout; -let AVSDFConstants = __webpack_require__(2); -let AVSDFCircle = __webpack_require__(4); -let AVSDFNode = __webpack_require__(6); -let AVSDFEdge = __webpack_require__(3); - -// ----------------------------------------------------------------------------- -// Section: Initializations -// ----------------------------------------------------------------------------- - -// Constructor -function AVSDFLayout() { - Layout.call(this); - this.nodeSeparation = AVSDFConstants.DEFAULT_NODE_SEPARATION; -} - -AVSDFLayout.prototype = Object.create(Layout.prototype); - -for (let property in Layout) { - AVSDFLayout[property] = Layout[property]; -} - -AVSDFLayout.prototype.newGraph = function (vObject) { - this.avsdfCircle = new AVSDFCircle(null, this.graphManager, vObject); - - return this.avsdfCircle; -}; - -AVSDFLayout.prototype.newNode = function (vNode) { - return new AVSDFNode(this.graphManager, vNode); -}; - -AVSDFLayout.prototype.newEdge = function (vEdge) { - return new AVSDFEdge(null, null, vEdge); -}; - -// ----------------------------------------------------------------------------- -// Section: Accessor Functions -// ----------------------------------------------------------------------------- - -// This function returns the position data for all nodes -AVSDFLayout.prototype.getPositionsData = function () { - var allNodes = this.graphManager.getAllNodes(); - var pData = {}; - - for (var i = 0; i < allNodes.length; i++) { - var rect = allNodes[i].rect; - var id = allNodes[i].id; - - pData[id] = { - id: id, - x: rect.getCenterX(), - y: rect.getCenterY(), - w: rect.width, - h: rect.height - }; - } - - return pData; -}; - -// ----------------------------------------------------------------------------- -// Section: Layout Related -// ----------------------------------------------------------------------------- - -/** - * This function performs layout on constructed l-level graph. - * It returns true on success, false otherwise. - * Important!: If you want to see the results of this function then, after this function is called, you have to calculate - * and set the positions of every node. To do this call updateNodeCoordinates. However, updateNodeAngles on the other - * hand is not needed (redundant) for this function. - */ -AVSDFLayout.prototype.layout = function () { - let self = this; - - // Check if graph contains any compound structures - if (self.graphManager.getGraphs().length > 1) { - return false; - } - - let clusterGraph = this.avsdfCircle; // Fixed reference, but now it is a bit redundant - - clusterGraph.setNodeSeparation(this.nodeSeparation); - clusterGraph.calculateRadius(); - clusterGraph.initOrdering(); - - while (!clusterGraph.hasFinishedOrdering()) { - let node = clusterGraph.findNodeToPlace(); - clusterGraph.putInOrder(node); - } - - return true; -}; - -// This function updates the angle (in radians) property of AVSDFNode elements in the circle -AVSDFLayout.prototype.updateNodeAngles = function () { - this.graphManager.getRoot().correctAngles(); //AVSDFCircle object -}; - -// This function traverses the vertices of the graph and sets their correct coordinates with respect to the owner circle. -AVSDFLayout.prototype.updateNodeCoordinates = function () { - let clusterGraph = this.graphManager.getRoot(); - - clusterGraph.getNodes().forEach(function (node) { - node.setCenter(clusterGraph.getCenterX() + clusterGraph.getRadius() * Math.cos(node.getAngle()), clusterGraph.getCenterY() + clusterGraph.getRadius() * Math.sin(node.getAngle())); - }); -}; - -// ----------------------------------------------------------------------------- -// Section: Post Processing -// ----------------------------------------------------------------------------- - -/** - * This method implements the post processing step of the algorithm, which - * tries to minimize the number of edges further with respect to the local - * adjusting algorithm described by He and Sykora. - */ -AVSDFLayout.prototype.initPostProcess = function () { - this.avsdfCircle.calculateEdgeCrossingsOfNodes(); - - let list = this.avsdfCircle.getNodes(); - - list.sort(function (a, b) { - return b.getTotalCrossingOfEdges() - a.getTotalCrossingOfEdges(); - }); - - return list; -}; - -AVSDFLayout.prototype.oneStepPostProcess = function (node) { - let self = this; - - let currentCrossingNumber = node.getTotalCrossingOfEdges(); - let newCrossingNumber; - - let neighbours = []; - node.getNeighborsList().addAllTo(neighbours); - - for (let j = 0; j < neighbours.length; j++) { - let neighbour = neighbours[j]; - - let oldIndex = node.getIndex(); - let newIndex = (neighbour.getIndex() + 1) % self.avsdfCircle.getSize(); - - if (oldIndex !== newIndex) { - node.setIndex(newIndex); - - if (oldIndex < node.getIndex()) { - oldIndex += self.avsdfCircle.getSize(); - } - - let index = node.getIndex(); - - while (index < oldIndex) { - let temp = self.avsdfCircle.getOrder()[index % self.avsdfCircle.getSize()]; - temp.setIndex((temp.getIndex() + 1) % self.avsdfCircle.getSize()); - index += 1; - } - - node.calculateTotalCrossing(); - newCrossingNumber = node.getTotalCrossingOfEdges(); - - if (newCrossingNumber >= currentCrossingNumber) { - self.avsdfCircle.loadOldIndicesOfNodes(); - } else { - self.avsdfCircle.reOrderVertices(); - currentCrossingNumber = newCrossingNumber; - } - } - } -}; - -module.exports = AVSDFLayout; - -/***/ }), -/* 6 */ -/***/ (function(module, exports, __webpack_require__) { - -/** - * This class implements data and functionality required for AVSDF layout per - * node. - * - * - * Copyright: i-Vis Research Group, Bilkent University, 2007 - present - */ - -let LNode = __webpack_require__(1).LNode; -let Quicksort = __webpack_require__(1).Quicksort; - -// ----------------------------------------------------------------------------- -// Section: Initializations -// ----------------------------------------------------------------------------- - -function AVSDFNode(gm, vNode, loc, size) { - // Constructor 1: AVSDFNode(gm, vNode, loc, size) - if (loc !== undefined && size !== undefined) { - LNode.call(this, gm, vNode, loc, size); - } - // Constructor 2: AVSDFNode(gm, vNode) - else { - LNode.call(this, gm, vNode); - } - - // Angle of this node on the owner circle in radians - this.angle = 0; - - // Index of this node on the owner circle - this.circleIndex = -1; - - // Total number of crossings of the edges this node is incident to - this.totalCrossingOfEdges = -1; - - // Whether the current edge crossing number is valid or it needs to be - // recalculated - this.isCrossingNumberValid = false; -} - -AVSDFNode.prototype = Object.create(LNode.prototype); -for (let properties in LNode) { - AVSDFNode[properties] = LNode[properties]; -} - -// ----------------------------------------------------------------------------- -// Section: Accessor Functions -// ----------------------------------------------------------------------------- - -// This function returns the circle this node is owned by. -AVSDFNode.prototype.getCircle = function () { - return this.getOwner(); -}; - -// This function sets the index of this node on the circle, and sets the -// crossing number invalid. Due to the index change of the node; it needs to -// be recalculated. -AVSDFNode.prototype.setIndex = function (index) { - this.circleIndex = index; - this.isCrossingNumberValid = false; -}; - -// This function returns the index of this node in the ordering of its owner -// circle. Here -1 means that the vertex is not yet placed on its owner -//circle. -AVSDFNode.prototype.getIndex = function () { - return this.circleIndex; -}; - -// This function returns the array of the neigbors of this node sorted in -// ascending order. -AVSDFNode.prototype.getNeighborsSortedByDegree = function () { - let self = this; - - let neighborsList = []; - self.getNeighborsList().addAllTo(neighborsList); - let result = neighborsList.filter(node => node.getIndex() === -1); - - result.sort(function (a, b) { - return a.getDegree() - b.getDegree(); - }); - - return result; -}; - -// This function returns the degree of this node. -AVSDFNode.prototype.getDegree = function () { - return this.getEdges().length; -}; - -// This function returns whether or not this node is currently placed on its -// owner circle. -AVSDFNode.prototype.isOrdered = function () { - return this.getIndex() > -1; -}; - -// This function sets the angle of this node w.r.t. its owner circle. Here -// the angle value is in radian. -AVSDFNode.prototype.setAngle = function (angle) { - this.angle = angle; -}; - -// This function returns the angle of this node w.r.t. its owner circle. Here -// the angle value is in radian. -AVSDFNode.prototype.getAngle = function () { - return this.angle; -}; - -// This function returns the index difference of this node with the input -// node. Note that the index difference cannot be negative if both nodes are -// placed on the circle. Here -1 means at least one of the nodes are not yet -// placed on the circle. -AVSDFNode.prototype.getCircDistWithTheNode = function (refNode) { - let self = this; - let otherIndex = refNode.getIndex(); - - if (otherIndex === -1 || self.getIndex() === -1) { - return -1; - } - - let diff = self.getIndex() - otherIndex; - - if (diff < 0) { - diff += self.getCircle().getSize(); - } - - return diff; -}; - -// This function finds the number of edge crossings between the edges of -// this node and the edges of the input one. -AVSDFNode.prototype.getCrossingNumberWithNode = function (otherNode) { - let self = this; - let totalCrossing = 0; - - self.getEdges().forEach(function (edge) { - otherNode.getEdges().forEach(function (otherEdge) { - totalCrossing += edge.crossingWithEdge(otherEdge); - }); - }); - - return totalCrossing; -}; - -// This function returns the total number of edge crossings. If the previously -// calculated value is not valid due to an index change on the circle, then -// a recalculation is performed. -AVSDFNode.prototype.getTotalCrossingOfEdges = function () { - let self = this; - - if (!self.isCrossingNumberValid) { - self.calculateTotalCrossing(); - self.isCrossingNumberValid = true; - } - - return self.totalCrossingOfEdges; -}; - -// ----------------------------------------------------------------------------- -// Section: Remaining Functions -// ----------------------------------------------------------------------------- - -// This function calculates the total number of crossings the edges of this -// node cause. -AVSDFNode.prototype.calculateTotalCrossing = function () { - let self = this; - let temp_crossing_count = 0; - let temp_edge_list = []; - temp_edge_list.push.apply(temp_edge_list, self.getCircle().getEdges()); - temp_edge_list = temp_edge_list.filter(ele => self.getEdges().indexOf(ele) < 0); - - self.getEdges().forEach(edge => temp_crossing_count += edge.calculateTotalCrossingWithList(temp_edge_list)); - - self.totalCrossingOfEdges = temp_crossing_count; -}; - -module.exports = AVSDFNode; +/***/ (function(module, exports) { -/***/ }) -/******/ ]); -}); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://avsdfBase/webpack/universalModuleDefinition","webpack://avsdfBase/webpack/bootstrap","webpack://avsdfBase/./index.js","webpack://avsdfBase/./node_modules/layout-base/layout-base.js","webpack://avsdfBase/./src/AVSDFConstants.js","webpack://avsdfBase/./src/AVSDFEdge.js","webpack://avsdfBase/./src/AVSDFCircle.js","webpack://avsdfBase/./src/AVSDFLayout.js","webpack://avsdfBase/./src/AVSDFNode.js"],"names":["avsdfBase","layoutBase","require","AVSDFConstants","AVSDFEdge","AVSDFCircle","AVSDFLayout","AVSDFNode","module","exports","LayoutConstants","prop","DEFAULT_NODE_SEPARATION","LEdge","source","target","vEdge","call","prototype","Object","create","properties","getOtherEnd","node","crossesWithEdge","otherEdge","self","sourcePos","getSource","getIndex","targetPos","getTarget","otherSourcePos","otherTargetPos","otherSourceDist","getCircDistWithTheNode","otherTargetDist","thisTargetDist","Math","max","min","crossingWithEdge","result","calculateTotalCrossingWithList","edgeList","totalCrossing","forEach","edge","LGraph","parent","graphMgr","vObject","inOrder","undefined","currentIndex","nodeSeparation","stack","perimeter","centerX","centerY","radius","property","initOrdering","getOrder","getCenterX","getCenterY","getRadius","getSize","getNodes","length","getTotalCrossingOfCircle","crossingNumber","nodeCrossing","getTotalCrossingOfEdges","hasFinishedOrdering","getNodeSeparation","setNodeSeparation","correctAngles","putInOrder","nodes","found","i","id","setIndex","setAngle","getAngle","PI","getDiagonal","findNodeToPlace","sDegreeNode","findUnorderedSmallestDegreeNode","foundUnorderNode","pop","isOrdered","neighbors","getNeighborsSortedByDegree","neighbor","push","calculateRadius","totalDiagonal","sqrt","getWidth","getHeight","getParent","setWidth","setHeight","setCenter","calculateEdgeCrossingsOfNodes","calculateTotalCrossing","loadOldIndicesOfNodes","reOrderVertices","minDegree","Number","MAX_SAFE_INTEGER","getDegree","Layout","newGraph","avsdfCircle","graphManager","newNode","vNode","newEdge","getPositionsData","allNodes","getAllNodes","pData","rect","x","y","w","width","h","height","layout","getGraphs","clusterGraph","updateNodeAngles","getRoot","updateNodeCoordinates","cos","sin","initPostProcess","list","sort","a","b","oneStepPostProcess","currentCrossingNumber","newCrossingNumber","neighbours","getNeighborsList","addAllTo","j","neighbour","oldIndex","newIndex","index","temp","LNode","Quicksort","gm","loc","size","angle","circleIndex","totalCrossingOfEdges","isCrossingNumberValid","getCircle","getOwner","neighborsList","filter","getEdges","refNode","otherIndex","diff","getCrossingNumberWithNode","otherNode","temp_crossing_count","temp_edge_list","apply","ele","indexOf"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;AClFa;;AAEb,IAAIA,YAAY,EAAhB;;AAEAA,UAAUC,UAAV,GAAuBC,mBAAOA,CAAC,CAAR,CAAvB;AACAF,UAAUG,cAAV,GAA2BD,mBAAOA,CAAC,CAAR,CAA3B;AACAF,UAAUI,SAAV,GAAsBF,mBAAOA,CAAC,CAAR,CAAtB;AACAF,UAAUK,WAAV,GAAwBH,mBAAOA,CAAC,CAAR,CAAxB;AACAF,UAAUM,WAAV,GAAwBJ,mBAAOA,CAAC,CAAR,CAAxB;AACAF,UAAUO,SAAV,GAAsBL,mBAAOA,CAAC,CAAR,CAAtB;;AAEAM,OAAOC,OAAP,GAAiBT,SAAjB,C;;;;;;ACXA;AACA,IAAI,IAAyD;AAC7D;AACA,MAAM,EAK2B;AACjC,CAAC;AACD,oCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,gCAAgC;AAClF;AACA;AACA;AACA;AACA;AACA;AACA,gEAAgE,kBAAkB;AAClF;AACA,yDAAyD,cAAc;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,iCAAiC;AAClF,wHAAwH,mBAAmB,EAAE;AAC7I;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,0BAA0B,EAAE;AAC/D,yCAAyC,eAAe;AACxD;AACA;AACA;AACA;AACA;AACA,8DAA8D,+DAA+D;AAC7H;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,qBAAqB;AACtC;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,eAAe,mBAAmB;AAClC;AACA;AACA;AACA;AACA,GAAG;AACH,eAAe,mBAAmB;AAClC;;AAEA,qBAAqB,mBAAmB;AACxC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,qBAAqB;AACtC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,iBAAiB,WAAW;AAC5B;AACA;;AAEA,iBAAiB,WAAW;AAC5B,mBAAmB,WAAW;AAC9B;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,sBAAsB,cAAc;AACpC,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,aAAa,mBAAmB;AAChC;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,uBAAuB;AACzD,oCAAoC,uBAAuB;AAC3D;AACA,yBAAyB,uBAAuB;AAChD;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,aAAa,8BAA8B;AAC3C;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,qBAAqB;AACxC;AACA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,qBAAqB,kBAAkB;AACvC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,qBAAqB,kBAAkB;AACvC;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA,mBAAmB,kBAAkB;AACrC;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,iBAAiB,qBAAqB;AACtC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,qBAAqB,0BAA0B;AAC/C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,iBAAiB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,iBAAiB,4BAA4B;AAC7C;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,iBAAiB,kBAAkB;AACnC;;AAEA;AACA;;AAEA,qBAAqB,iBAAiB;AACtC;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,iBAAiB;AAClC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,mBAAmB,iBAAiB;AACpC;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA,mCAAmC;AACnC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,6BAA6B;AAC7B;;AAEA;AACA;AACA,yBAAyB,KAAK;;AAE9B;AACA;AACA,yBAAyB,KAAK;;AAE9B;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,OAAO;AAC1B;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,UAAU;AAC7B;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,qGAAqG;AACrG;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA,mBAAmB,kBAAkB;AACrC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB,YAAY;AAC7B;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA,4BAA4B,gCAAgC;;AAE5D;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,OAAO,aAAa;;AAEpB;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA,qCAAqC,QAAQ;AAC7C;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,2BAA2B;AAC5C;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,CAAC,E;;;;;;ACp0HD,IAAIU,kBAAkBR,mBAAOA,CAAC,CAAR,EAAuBQ,eAA7C;;AAEA,SAASP,cAAT,GAAyB,CAAE;;AAE3B;AACA,KAAI,IAAIQ,IAAR,IAAgBD,eAAhB,EAAgC;AAC5BP,mBAAeQ,IAAf,IAAuBD,gBAAgBC,IAAhB,CAAvB;AACH;;AAEDR,eAAeS,uBAAf,GAAyC,EAAzC;;AAE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","file":"avsdf-base.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"avsdfBase\"] = factory();\n\telse\n\t\troot[\"avsdfBase\"] = factory();\n})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","'use strict';\n\nlet avsdfBase = {};\n\navsdfBase.layoutBase = require('layout-base');\navsdfBase.AVSDFConstants = require('./src/AVSDFConstants');\navsdfBase.AVSDFEdge = require('./src/AVSDFEdge');\navsdfBase.AVSDFCircle = require('./src/AVSDFCircle');\navsdfBase.AVSDFLayout = require('./src/AVSDFLayout');\navsdfBase.AVSDFNode = require('./src/AVSDFNode');\n\nmodule.exports = avsdfBase;","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"layoutBase\"] = factory();\n\telse\n\t\troot[\"layoutBase\"] = factory();\n})(window, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nlet layoutBase = function () {\n  return;\n};\n\nlayoutBase.FDLayout = __webpack_require__(1);\nlayoutBase.FDLayoutConstants = __webpack_require__(22);\nlayoutBase.FDLayoutEdge = __webpack_require__(23);\nlayoutBase.FDLayoutNode = __webpack_require__(24);\nlayoutBase.DimensionD = __webpack_require__(25);\nlayoutBase.HashMap = __webpack_require__(4);\nlayoutBase.HashSet = __webpack_require__(17);\nlayoutBase.IGeometry = __webpack_require__(9);\nlayoutBase.IMath = __webpack_require__(10);\nlayoutBase.Integer = __webpack_require__(12);\nlayoutBase.Point = __webpack_require__(18);\nlayoutBase.PointD = __webpack_require__(16);\nlayoutBase.RandomSeed = __webpack_require__(15);\nlayoutBase.RectangleD = __webpack_require__(14);\nlayoutBase.Transform = __webpack_require__(20);\nlayoutBase.UniqueIDGeneretor = __webpack_require__(5);\nlayoutBase.Quicksort = __webpack_require__(26);\nlayoutBase.LinkedList = __webpack_require__(19);\nlayoutBase.LGraphObject = __webpack_require__(8);\nlayoutBase.LGraph = __webpack_require__(11);\nlayoutBase.LEdge = __webpack_require__(7);\nlayoutBase.LGraphManager = __webpack_require__(6);\nlayoutBase.LNode = __webpack_require__(13);\nlayoutBase.Layout = __webpack_require__(2);\nlayoutBase.LayoutConstants = __webpack_require__(3);\n\nmodule.exports = layoutBase;\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar Layout = __webpack_require__(2);\nvar FDLayoutConstants = __webpack_require__(22);\nvar LayoutConstants = __webpack_require__(3);\nvar IGeometry = __webpack_require__(9);\nvar IMath = __webpack_require__(10);\n\nfunction FDLayout() {\n  Layout.call(this);\n\n  this.useSmartIdealEdgeLengthCalculation = FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION;\n  this.idealEdgeLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH;\n  this.springConstant = FDLayoutConstants.DEFAULT_SPRING_STRENGTH;\n  this.repulsionConstant = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH;\n  this.gravityConstant = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH;\n  this.compoundGravityConstant = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH;\n  this.gravityRangeFactor = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR;\n  this.compoundGravityRangeFactor = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR;\n  this.displacementThresholdPerNode = 3.0 * FDLayoutConstants.DEFAULT_EDGE_LENGTH / 100;\n  this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL;\n  this.initialCoolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL;\n  this.totalDisplacement = 0.0;\n  this.oldTotalDisplacement = 0.0;\n  this.maxIterations = FDLayoutConstants.MAX_ITERATIONS;\n}\n\nFDLayout.prototype = Object.create(Layout.prototype);\n\nfor (var prop in Layout) {\n  FDLayout[prop] = Layout[prop];\n}\n\nFDLayout.prototype.initParameters = function () {\n  Layout.prototype.initParameters.call(this, arguments);\n\n  if (this.layoutQuality == LayoutConstants.DRAFT_QUALITY) {\n    this.displacementThresholdPerNode += 0.30;\n    this.maxIterations *= 0.8;\n  } else if (this.layoutQuality == LayoutConstants.PROOF_QUALITY) {\n    this.displacementThresholdPerNode -= 0.30;\n    this.maxIterations *= 1.2;\n  }\n\n  this.totalIterations = 0;\n  this.notAnimatedIterations = 0;\n\n  this.useFRGridVariant = FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION;\n\n  this.grid = [];\n};\n\nFDLayout.prototype.calcIdealEdgeLengths = function () {\n  var edge;\n  var lcaDepth;\n  var source;\n  var target;\n  var sizeOfSourceInLca;\n  var sizeOfTargetInLca;\n\n  var allEdges = this.getGraphManager().getAllEdges();\n  for (var i = 0; i < allEdges.length; i++) {\n    edge = allEdges[i];\n\n    edge.idealLength = this.idealEdgeLength;\n\n    if (edge.isInterGraph) {\n      source = edge.getSource();\n      target = edge.getTarget();\n\n      sizeOfSourceInLca = edge.getSourceInLca().getEstimatedSize();\n      sizeOfTargetInLca = edge.getTargetInLca().getEstimatedSize();\n\n      if (this.useSmartIdealEdgeLengthCalculation) {\n        edge.idealLength += sizeOfSourceInLca + sizeOfTargetInLca - 2 * LayoutConstants.SIMPLE_NODE_SIZE;\n      }\n\n      lcaDepth = edge.getLca().getInclusionTreeDepth();\n\n      edge.idealLength += FDLayoutConstants.DEFAULT_EDGE_LENGTH * FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR * (source.getInclusionTreeDepth() + target.getInclusionTreeDepth() - 2 * lcaDepth);\n    }\n  }\n};\n\nFDLayout.prototype.initSpringEmbedder = function () {\n\n  if (this.incremental) {\n    this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL;\n  } else {\n    this.coolingFactor = 1.0;\n    this.initialCoolingFactor = 1.0;\n    this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT;\n  }\n\n  this.maxIterations = Math.max(this.getAllNodes().length * 5, this.maxIterations);\n\n  this.totalDisplacementThreshold = this.displacementThresholdPerNode * this.getAllNodes().length;\n\n  this.repulsionRange = this.calcRepulsionRange();\n};\n\nFDLayout.prototype.calcSpringForces = function () {\n  var lEdges = this.getAllEdges();\n  var edge;\n\n  for (var i = 0; i < lEdges.length; i++) {\n    edge = lEdges[i];\n\n    this.calcSpringForce(edge, edge.idealLength);\n  }\n};\n\nFDLayout.prototype.calcRepulsionForces = function (gridUpdateAllowed = true, forceToNodeSurroundingUpdate = false) {\n  var i, j;\n  var nodeA, nodeB;\n  var lNodes = this.getAllNodes();\n  var processedNodeSet;\n\n  if (this.useFRGridVariant) {\n    if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed) {\n      this.updateGrid();\n    }\n\n    processedNodeSet = new Set();\n\n    // calculate repulsion forces between each nodes and its surrounding\n    for (i = 0; i < lNodes.length; i++) {\n      nodeA = lNodes[i];\n      this.calculateRepulsionForceOfANode(nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate);\n      processedNodeSet.add(nodeA);\n    }\n  } else {\n    for (i = 0; i < lNodes.length; i++) {\n      nodeA = lNodes[i];\n\n      for (j = i + 1; j < lNodes.length; j++) {\n        nodeB = lNodes[j];\n\n        // If both nodes are not members of the same graph, skip.\n        if (nodeA.getOwner() != nodeB.getOwner()) {\n          continue;\n        }\n\n        this.calcRepulsionForce(nodeA, nodeB);\n      }\n    }\n  }\n};\n\nFDLayout.prototype.calcGravitationalForces = function () {\n  var node;\n  var lNodes = this.getAllNodesToApplyGravitation();\n\n  for (var i = 0; i < lNodes.length; i++) {\n    node = lNodes[i];\n    this.calcGravitationalForce(node);\n  }\n};\n\nFDLayout.prototype.moveNodes = function () {\n  var lNodes = this.getAllNodes();\n  var node;\n\n  for (var i = 0; i < lNodes.length; i++) {\n    node = lNodes[i];\n    node.move();\n  }\n};\n\nFDLayout.prototype.calcSpringForce = function (edge, idealLength) {\n  var sourceNode = edge.getSource();\n  var targetNode = edge.getTarget();\n\n  var length;\n  var springForce;\n  var springForceX;\n  var springForceY;\n\n  // Update edge length\n  if (this.uniformLeafNodeSizes && sourceNode.getChild() == null && targetNode.getChild() == null) {\n    edge.updateLengthSimple();\n  } else {\n    edge.updateLength();\n\n    if (edge.isOverlapingSourceAndTarget) {\n      return;\n    }\n  }\n\n  length = edge.getLength();\n\n  // Calculate spring forces\n  springForce = this.springConstant * (length - idealLength);\n\n  // Project force onto x and y axes\n  springForceX = springForce * (edge.lengthX / length);\n  springForceY = springForce * (edge.lengthY / length);\n\n  // Apply forces on the end nodes\n  sourceNode.springForceX += springForceX;\n  sourceNode.springForceY += springForceY;\n  targetNode.springForceX -= springForceX;\n  targetNode.springForceY -= springForceY;\n};\n\nFDLayout.prototype.calcRepulsionForce = function (nodeA, nodeB) {\n  var rectA = nodeA.getRect();\n  var rectB = nodeB.getRect();\n  var overlapAmount = new Array(2);\n  var clipPoints = new Array(4);\n  var distanceX;\n  var distanceY;\n  var distanceSquared;\n  var distance;\n  var repulsionForce;\n  var repulsionForceX;\n  var repulsionForceY;\n\n  if (rectA.intersects(rectB)) // two nodes overlap\n    {\n      // calculate separation amount in x and y directions\n      IGeometry.calcSeparationAmount(rectA, rectB, overlapAmount, FDLayoutConstants.DEFAULT_EDGE_LENGTH / 2.0);\n\n      repulsionForceX = 2 * overlapAmount[0];\n      repulsionForceY = 2 * overlapAmount[1];\n\n      var childrenConstant = nodeA.noOfChildren * nodeB.noOfChildren / (nodeA.noOfChildren + nodeB.noOfChildren);\n\n      // Apply forces on the two nodes\n      nodeA.repulsionForceX -= childrenConstant * repulsionForceX;\n      nodeA.repulsionForceY -= childrenConstant * repulsionForceY;\n      nodeB.repulsionForceX += childrenConstant * repulsionForceX;\n      nodeB.repulsionForceY += childrenConstant * repulsionForceY;\n    } else // no overlap\n    {\n      // calculate distance\n\n      if (this.uniformLeafNodeSizes && nodeA.getChild() == null && nodeB.getChild() == null) // simply base repulsion on distance of node centers\n        {\n          distanceX = rectB.getCenterX() - rectA.getCenterX();\n          distanceY = rectB.getCenterY() - rectA.getCenterY();\n        } else // use clipping points\n        {\n          IGeometry.getIntersection(rectA, rectB, clipPoints);\n\n          distanceX = clipPoints[2] - clipPoints[0];\n          distanceY = clipPoints[3] - clipPoints[1];\n        }\n\n      // No repulsion range. FR grid variant should take care of this.\n      if (Math.abs(distanceX) < FDLayoutConstants.MIN_REPULSION_DIST) {\n        distanceX = IMath.sign(distanceX) * FDLayoutConstants.MIN_REPULSION_DIST;\n      }\n\n      if (Math.abs(distanceY) < FDLayoutConstants.MIN_REPULSION_DIST) {\n        distanceY = IMath.sign(distanceY) * FDLayoutConstants.MIN_REPULSION_DIST;\n      }\n\n      distanceSquared = distanceX * distanceX + distanceY * distanceY;\n      distance = Math.sqrt(distanceSquared);\n\n      repulsionForce = this.repulsionConstant * nodeA.noOfChildren * nodeB.noOfChildren / distanceSquared;\n\n      // Project force onto x and y axes\n      repulsionForceX = repulsionForce * distanceX / distance;\n      repulsionForceY = repulsionForce * distanceY / distance;\n\n      // Apply forces on the two nodes    \n      nodeA.repulsionForceX -= repulsionForceX;\n      nodeA.repulsionForceY -= repulsionForceY;\n      nodeB.repulsionForceX += repulsionForceX;\n      nodeB.repulsionForceY += repulsionForceY;\n    }\n};\n\nFDLayout.prototype.calcGravitationalForce = function (node) {\n  var ownerGraph;\n  var ownerCenterX;\n  var ownerCenterY;\n  var distanceX;\n  var distanceY;\n  var absDistanceX;\n  var absDistanceY;\n  var estimatedSize;\n  ownerGraph = node.getOwner();\n\n  ownerCenterX = (ownerGraph.getRight() + ownerGraph.getLeft()) / 2;\n  ownerCenterY = (ownerGraph.getTop() + ownerGraph.getBottom()) / 2;\n  distanceX = node.getCenterX() - ownerCenterX;\n  distanceY = node.getCenterY() - ownerCenterY;\n  absDistanceX = Math.abs(distanceX) + node.getWidth() / 2;\n  absDistanceY = Math.abs(distanceY) + node.getHeight() / 2;\n\n  if (node.getOwner() == this.graphManager.getRoot()) // in the root graph\n    {\n      estimatedSize = ownerGraph.getEstimatedSize() * this.gravityRangeFactor;\n\n      if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) {\n        node.gravitationForceX = -this.gravityConstant * distanceX;\n        node.gravitationForceY = -this.gravityConstant * distanceY;\n      }\n    } else // inside a compound\n    {\n      estimatedSize = ownerGraph.getEstimatedSize() * this.compoundGravityRangeFactor;\n\n      if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) {\n        node.gravitationForceX = -this.gravityConstant * distanceX * this.compoundGravityConstant;\n        node.gravitationForceY = -this.gravityConstant * distanceY * this.compoundGravityConstant;\n      }\n    }\n};\n\nFDLayout.prototype.isConverged = function () {\n  var converged;\n  var oscilating = false;\n\n  if (this.totalIterations > this.maxIterations / 3) {\n    oscilating = Math.abs(this.totalDisplacement - this.oldTotalDisplacement) < 2;\n  }\n\n  converged = this.totalDisplacement < this.totalDisplacementThreshold;\n\n  this.oldTotalDisplacement = this.totalDisplacement;\n\n  return converged || oscilating;\n};\n\nFDLayout.prototype.animate = function () {\n  if (this.animationDuringLayout && !this.isSubLayout) {\n    if (this.notAnimatedIterations == this.animationPeriod) {\n      this.update();\n      this.notAnimatedIterations = 0;\n    } else {\n      this.notAnimatedIterations++;\n    }\n  }\n};\n\n//This method calculates the number of children (weight) for all nodes\nFDLayout.prototype.calcNoOfChildrenForAllNodes = function () {\n  var node;\n  var allNodes = this.graphManager.getAllNodes();\n\n  for (var i = 0; i < allNodes.length; i++) {\n    node = allNodes[i];\n    node.noOfChildren = node.getNoOfChildren();\n  }\n};\n\n// -----------------------------------------------------------------------------\n// Section: FR-Grid Variant Repulsion Force Calculation\n// -----------------------------------------------------------------------------\n\nFDLayout.prototype.calcGrid = function (graph) {\n\n  var sizeX = 0;\n  var sizeY = 0;\n\n  sizeX = parseInt(Math.ceil((graph.getRight() - graph.getLeft()) / this.repulsionRange));\n  sizeY = parseInt(Math.ceil((graph.getBottom() - graph.getTop()) / this.repulsionRange));\n\n  var grid = new Array(sizeX);\n\n  for (var i = 0; i < sizeX; i++) {\n    grid[i] = new Array(sizeY);\n  }\n\n  for (var i = 0; i < sizeX; i++) {\n    for (var j = 0; j < sizeY; j++) {\n      grid[i][j] = new Array();\n    }\n  }\n\n  return grid;\n};\n\nFDLayout.prototype.addNodeToGrid = function (v, left, top) {\n\n  var startX = 0;\n  var finishX = 0;\n  var startY = 0;\n  var finishY = 0;\n\n  startX = parseInt(Math.floor((v.getRect().x - left) / this.repulsionRange));\n  finishX = parseInt(Math.floor((v.getRect().width + v.getRect().x - left) / this.repulsionRange));\n  startY = parseInt(Math.floor((v.getRect().y - top) / this.repulsionRange));\n  finishY = parseInt(Math.floor((v.getRect().height + v.getRect().y - top) / this.repulsionRange));\n\n  for (var i = startX; i <= finishX; i++) {\n    for (var j = startY; j <= finishY; j++) {\n      this.grid[i][j].push(v);\n      v.setGridCoordinates(startX, finishX, startY, finishY);\n    }\n  }\n};\n\nFDLayout.prototype.updateGrid = function () {\n  var i;\n  var nodeA;\n  var lNodes = this.getAllNodes();\n\n  this.grid = this.calcGrid(this.graphManager.getRoot());\n\n  // put all nodes to proper grid cells\n  for (i = 0; i < lNodes.length; i++) {\n    nodeA = lNodes[i];\n    this.addNodeToGrid(nodeA, this.graphManager.getRoot().getLeft(), this.graphManager.getRoot().getTop());\n  }\n};\n\nFDLayout.prototype.calculateRepulsionForceOfANode = function (nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate) {\n\n  if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed || forceToNodeSurroundingUpdate) {\n    var surrounding = new Set();\n    nodeA.surrounding = new Array();\n    var nodeB;\n    var grid = this.grid;\n\n    for (var i = nodeA.startX - 1; i < nodeA.finishX + 2; i++) {\n      for (var j = nodeA.startY - 1; j < nodeA.finishY + 2; j++) {\n        if (!(i < 0 || j < 0 || i >= grid.length || j >= grid[0].length)) {\n          for (var k = 0; k < grid[i][j].length; k++) {\n            nodeB = grid[i][j][k];\n\n            // If both nodes are not members of the same graph, \n            // or both nodes are the same, skip.\n            if (nodeA.getOwner() != nodeB.getOwner() || nodeA == nodeB) {\n              continue;\n            }\n\n            // check if the repulsion force between\n            // nodeA and nodeB has already been calculated\n            if (!processedNodeSet.has(nodeB) && !surrounding.has(nodeB)) {\n              var distanceX = Math.abs(nodeA.getCenterX() - nodeB.getCenterX()) - (nodeA.getWidth() / 2 + nodeB.getWidth() / 2);\n              var distanceY = Math.abs(nodeA.getCenterY() - nodeB.getCenterY()) - (nodeA.getHeight() / 2 + nodeB.getHeight() / 2);\n\n              // if the distance between nodeA and nodeB \n              // is less then calculation range\n              if (distanceX <= this.repulsionRange && distanceY <= this.repulsionRange) {\n                //then add nodeB to surrounding of nodeA\n                surrounding.add(nodeB);\n              }\n            }\n          }\n        }\n      }\n    }\n\n    nodeA.surrounding = [...surrounding];\n  }\n  for (i = 0; i < nodeA.surrounding.length; i++) {\n    this.calcRepulsionForce(nodeA, nodeA.surrounding[i]);\n  }\n};\n\nFDLayout.prototype.calcRepulsionRange = function () {\n  return 0.0;\n};\n\nmodule.exports = FDLayout;\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LayoutConstants = __webpack_require__(3);\nvar HashMap = __webpack_require__(4);\nvar LGraphManager = __webpack_require__(6);\nvar LNode = __webpack_require__(13);\nvar LEdge = __webpack_require__(7);\nvar LGraph = __webpack_require__(11);\nvar PointD = __webpack_require__(16);\nvar Transform = __webpack_require__(20);\nvar Emitter = __webpack_require__(21);\nvar HashSet = __webpack_require__(17);\n\nfunction Layout(isRemoteUse) {\n  Emitter.call(this);\n\n  //Layout Quality: 0:proof, 1:default, 2:draft\n  this.layoutQuality = LayoutConstants.DEFAULT_QUALITY;\n  //Whether layout should create bendpoints as needed or not\n  this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED;\n  //Whether layout should be incremental or not\n  this.incremental = LayoutConstants.DEFAULT_INCREMENTAL;\n  //Whether we animate from before to after layout node positions\n  this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT;\n  //Whether we animate the layout process or not\n  this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT;\n  //Number iterations that should be done between two successive animations\n  this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD;\n  /**\r\n   * Whether or not leaf nodes (non-compound nodes) are of uniform sizes. When\r\n   * they are, both spring and repulsion forces between two leaf nodes can be\r\n   * calculated without the expensive clipping point calculations, resulting\r\n   * in major speed-up.\r\n   */\n  this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES;\n  /**\r\n   * This is used for creation of bendpoints by using dummy nodes and edges.\r\n   * Maps an LEdge to its dummy bendpoint path.\r\n   */\n  this.edgeToDummyNodes = new HashMap();\n  this.graphManager = new LGraphManager(this);\n  this.isLayoutFinished = false;\n  this.isSubLayout = false;\n  this.isRemoteUse = false;\n\n  if (isRemoteUse != null) {\n    this.isRemoteUse = isRemoteUse;\n  }\n}\n\nLayout.RANDOM_SEED = 1;\n\nLayout.prototype = Object.create(Emitter.prototype);\n\nLayout.prototype.getGraphManager = function () {\n  return this.graphManager;\n};\n\nLayout.prototype.getAllNodes = function () {\n  return this.graphManager.getAllNodes();\n};\n\nLayout.prototype.getAllEdges = function () {\n  return this.graphManager.getAllEdges();\n};\n\nLayout.prototype.getAllNodesToApplyGravitation = function () {\n  return this.graphManager.getAllNodesToApplyGravitation();\n};\n\nLayout.prototype.newGraphManager = function () {\n  var gm = new LGraphManager(this);\n  this.graphManager = gm;\n  return gm;\n};\n\nLayout.prototype.newGraph = function (vGraph) {\n  return new LGraph(null, this.graphManager, vGraph);\n};\n\nLayout.prototype.newNode = function (vNode) {\n  return new LNode(this.graphManager, vNode);\n};\n\nLayout.prototype.newEdge = function (vEdge) {\n  return new LEdge(null, null, vEdge);\n};\n\nLayout.prototype.checkLayoutSuccess = function () {\n  return this.graphManager.getRoot() == null || this.graphManager.getRoot().getNodes().length == 0 || this.graphManager.includesInvalidEdge();\n};\n\nLayout.prototype.runLayout = function () {\n  this.isLayoutFinished = false;\n\n  if (this.tilingPreLayout) {\n    this.tilingPreLayout();\n  }\n\n  this.initParameters();\n  var isLayoutSuccessfull;\n\n  if (this.checkLayoutSuccess()) {\n    isLayoutSuccessfull = false;\n  } else {\n    isLayoutSuccessfull = this.layout();\n  }\n\n  if (LayoutConstants.ANIMATE === 'during') {\n    // If this is a 'during' layout animation. Layout is not finished yet. \n    // We need to perform these in index.js when layout is really finished.\n    return false;\n  }\n\n  if (isLayoutSuccessfull) {\n    if (!this.isSubLayout) {\n      this.doPostLayout();\n    }\n  }\n\n  if (this.tilingPostLayout) {\n    this.tilingPostLayout();\n  }\n\n  this.isLayoutFinished = true;\n\n  return isLayoutSuccessfull;\n};\n\n/**\r\n * This method performs the operations required after layout.\r\n */\nLayout.prototype.doPostLayout = function () {\n  //assert !isSubLayout : \"Should not be called on sub-layout!\";\n  // Propagate geometric changes to v-level objects\n  if (!this.incremental) {\n    this.transform();\n  }\n  this.update();\n};\n\n/**\r\n * This method updates the geometry of the target graph according to\r\n * calculated layout.\r\n */\nLayout.prototype.update2 = function () {\n  // update bend points\n  if (this.createBendsAsNeeded) {\n    this.createBendpointsFromDummyNodes();\n\n    // reset all edges, since the topology has changed\n    this.graphManager.resetAllEdges();\n  }\n\n  // perform edge, node and root updates if layout is not called\n  // remotely\n  if (!this.isRemoteUse) {\n    // update all edges\n    var edge;\n    var allEdges = this.graphManager.getAllEdges();\n    for (var i = 0; i < allEdges.length; i++) {\n      edge = allEdges[i];\n      //      this.update(edge);\n    }\n\n    // recursively update nodes\n    var node;\n    var nodes = this.graphManager.getRoot().getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      node = nodes[i];\n      //      this.update(node);\n    }\n\n    // update root graph\n    this.update(this.graphManager.getRoot());\n  }\n};\n\nLayout.prototype.update = function (obj) {\n  if (obj == null) {\n    this.update2();\n  } else if (obj instanceof LNode) {\n    var node = obj;\n    if (node.getChild() != null) {\n      // since node is compound, recursively update child nodes\n      var nodes = node.getChild().getNodes();\n      for (var i = 0; i < nodes.length; i++) {\n        update(nodes[i]);\n      }\n    }\n\n    // if the l-level node is associated with a v-level graph object,\n    // then it is assumed that the v-level node implements the\n    // interface Updatable.\n    if (node.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vNode = node.vGraphObject;\n\n      // call the update method of the interface\n      vNode.update(node);\n    }\n  } else if (obj instanceof LEdge) {\n    var edge = obj;\n    // if the l-level edge is associated with a v-level graph object,\n    // then it is assumed that the v-level edge implements the\n    // interface Updatable.\n\n    if (edge.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vEdge = edge.vGraphObject;\n\n      // call the update method of the interface\n      vEdge.update(edge);\n    }\n  } else if (obj instanceof LGraph) {\n    var graph = obj;\n    // if the l-level graph is associated with a v-level graph object,\n    // then it is assumed that the v-level object implements the\n    // interface Updatable.\n\n    if (graph.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vGraph = graph.vGraphObject;\n\n      // call the update method of the interface\n      vGraph.update(graph);\n    }\n  }\n};\n\n/**\r\n * This method is used to set all layout parameters to default values\r\n * determined at compile time.\r\n */\nLayout.prototype.initParameters = function () {\n  if (!this.isSubLayout) {\n    this.layoutQuality = LayoutConstants.DEFAULT_QUALITY;\n    this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT;\n    this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD;\n    this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT;\n    this.incremental = LayoutConstants.DEFAULT_INCREMENTAL;\n    this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED;\n    this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES;\n  }\n\n  if (this.animationDuringLayout) {\n    this.animationOnLayout = false;\n  }\n};\n\nLayout.prototype.transform = function (newLeftTop) {\n  if (newLeftTop == undefined) {\n    this.transform(new PointD(0, 0));\n  } else {\n    // create a transformation object (from Eclipse to layout). When an\n    // inverse transform is applied, we get upper-left coordinate of the\n    // drawing or the root graph at given input coordinate (some margins\n    // already included in calculation of left-top).\n\n    var trans = new Transform();\n    var leftTop = this.graphManager.getRoot().updateLeftTop();\n\n    if (leftTop != null) {\n      trans.setWorldOrgX(newLeftTop.x);\n      trans.setWorldOrgY(newLeftTop.y);\n\n      trans.setDeviceOrgX(leftTop.x);\n      trans.setDeviceOrgY(leftTop.y);\n\n      var nodes = this.getAllNodes();\n      var node;\n\n      for (var i = 0; i < nodes.length; i++) {\n        node = nodes[i];\n        node.transform(trans);\n      }\n    }\n  }\n};\n\nLayout.prototype.positionNodesRandomly = function (graph) {\n\n  if (graph == undefined) {\n    //assert !this.incremental;\n    this.positionNodesRandomly(this.getGraphManager().getRoot());\n    this.getGraphManager().getRoot().updateBounds(true);\n  } else {\n    var lNode;\n    var childGraph;\n\n    var nodes = graph.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      lNode = nodes[i];\n      childGraph = lNode.getChild();\n\n      if (childGraph == null) {\n        lNode.scatter();\n      } else if (childGraph.getNodes().length == 0) {\n        lNode.scatter();\n      } else {\n        this.positionNodesRandomly(childGraph);\n        lNode.updateBounds();\n      }\n    }\n  }\n};\n\n/**\r\n * This method returns a list of trees where each tree is represented as a\r\n * list of l-nodes. The method returns a list of size 0 when:\r\n * - The graph is not flat or\r\n * - One of the component(s) of the graph is not a tree.\r\n */\nLayout.prototype.getFlatForest = function () {\n  var flatForest = [];\n  var isForest = true;\n\n  // Quick reference for all nodes in the graph manager associated with\n  // this layout. The list should not be changed.\n  var allNodes = this.graphManager.getRoot().getNodes();\n\n  // First be sure that the graph is flat\n  var isFlat = true;\n\n  for (var i = 0; i < allNodes.length; i++) {\n    if (allNodes[i].getChild() != null) {\n      isFlat = false;\n    }\n  }\n\n  // Return empty forest if the graph is not flat.\n  if (!isFlat) {\n    return flatForest;\n  }\n\n  // Run BFS for each component of the graph.\n\n  var visited = new HashSet();\n  var toBeVisited = [];\n  var parents = new HashMap();\n  var unProcessedNodes = [];\n\n  unProcessedNodes = unProcessedNodes.concat(allNodes);\n\n  // Each iteration of this loop finds a component of the graph and\n  // decides whether it is a tree or not. If it is a tree, adds it to the\n  // forest and continued with the next component.\n\n  while (unProcessedNodes.length > 0 && isForest) {\n    toBeVisited.push(unProcessedNodes[0]);\n\n    // Start the BFS. Each iteration of this loop visits a node in a\n    // BFS manner.\n    while (toBeVisited.length > 0 && isForest) {\n      //pool operation\n      var currentNode = toBeVisited[0];\n      toBeVisited.splice(0, 1);\n      visited.add(currentNode);\n\n      // Traverse all neighbors of this node\n      var neighborEdges = currentNode.getEdges();\n\n      for (var i = 0; i < neighborEdges.length; i++) {\n        var currentNeighbor = neighborEdges[i].getOtherEnd(currentNode);\n\n        // If BFS is not growing from this neighbor.\n        if (parents.get(currentNode) != currentNeighbor) {\n          // We haven't previously visited this neighbor.\n          if (!visited.contains(currentNeighbor)) {\n            toBeVisited.push(currentNeighbor);\n            parents.put(currentNeighbor, currentNode);\n          }\n          // Since we have previously visited this neighbor and\n          // this neighbor is not parent of currentNode, given\n          // graph contains a component that is not tree, hence\n          // it is not a forest.\n          else {\n              isForest = false;\n              break;\n            }\n        }\n      }\n    }\n\n    // The graph contains a component that is not a tree. Empty\n    // previously found trees. The method will end.\n    if (!isForest) {\n      flatForest = [];\n    }\n    // Save currently visited nodes as a tree in our forest. Reset\n    // visited and parents lists. Continue with the next component of\n    // the graph, if any.\n    else {\n        var temp = [];\n        visited.addAllTo(temp);\n        flatForest.push(temp);\n        //flatForest = flatForest.concat(temp);\n        //unProcessedNodes.removeAll(visited);\n        for (var i = 0; i < temp.length; i++) {\n          var value = temp[i];\n          var index = unProcessedNodes.indexOf(value);\n          if (index > -1) {\n            unProcessedNodes.splice(index, 1);\n          }\n        }\n        visited = new HashSet();\n        parents = new HashMap();\n      }\n  }\n\n  return flatForest;\n};\n\n/**\r\n * This method creates dummy nodes (an l-level node with minimal dimensions)\r\n * for the given edge (one per bendpoint). The existing l-level structure\r\n * is updated accordingly.\r\n */\nLayout.prototype.createDummyNodesForBendpoints = function (edge) {\n  var dummyNodes = [];\n  var prev = edge.source;\n\n  var graph = this.graphManager.calcLowestCommonAncestor(edge.source, edge.target);\n\n  for (var i = 0; i < edge.bendpoints.length; i++) {\n    // create new dummy node\n    var dummyNode = this.newNode(null);\n    dummyNode.setRect(new Point(0, 0), new Dimension(1, 1));\n\n    graph.add(dummyNode);\n\n    // create new dummy edge between prev and dummy node\n    var dummyEdge = this.newEdge(null);\n    this.graphManager.add(dummyEdge, prev, dummyNode);\n\n    dummyNodes.add(dummyNode);\n    prev = dummyNode;\n  }\n\n  var dummyEdge = this.newEdge(null);\n  this.graphManager.add(dummyEdge, prev, edge.target);\n\n  this.edgeToDummyNodes.put(edge, dummyNodes);\n\n  // remove real edge from graph manager if it is inter-graph\n  if (edge.isInterGraph()) {\n    this.graphManager.remove(edge);\n  }\n  // else, remove the edge from the current graph\n  else {\n      graph.remove(edge);\n    }\n\n  return dummyNodes;\n};\n\n/**\r\n * This method creates bendpoints for edges from the dummy nodes\r\n * at l-level.\r\n */\nLayout.prototype.createBendpointsFromDummyNodes = function () {\n  var edges = [];\n  edges = edges.concat(this.graphManager.getAllEdges());\n  edges = this.edgeToDummyNodes.keySet().concat(edges);\n\n  for (var k = 0; k < edges.length; k++) {\n    var lEdge = edges[k];\n\n    if (lEdge.bendpoints.length > 0) {\n      var path = this.edgeToDummyNodes.get(lEdge);\n\n      for (var i = 0; i < path.length; i++) {\n        var dummyNode = path[i];\n        var p = new PointD(dummyNode.getCenterX(), dummyNode.getCenterY());\n\n        // update bendpoint's location according to dummy node\n        var ebp = lEdge.bendpoints.get(i);\n        ebp.x = p.x;\n        ebp.y = p.y;\n\n        // remove the dummy node, dummy edges incident with this\n        // dummy node is also removed (within the remove method)\n        dummyNode.getOwner().remove(dummyNode);\n      }\n\n      // add the real edge to graph\n      this.graphManager.add(lEdge, lEdge.source, lEdge.target);\n    }\n  }\n};\n\nLayout.transform = function (sliderValue, defaultValue, minDiv, maxMul) {\n  if (minDiv != undefined && maxMul != undefined) {\n    var value = defaultValue;\n\n    if (sliderValue <= 50) {\n      var minValue = defaultValue / minDiv;\n      value -= (defaultValue - minValue) / 50 * (50 - sliderValue);\n    } else {\n      var maxValue = defaultValue * maxMul;\n      value += (maxValue - defaultValue) / 50 * (sliderValue - 50);\n    }\n\n    return value;\n  } else {\n    var a, b;\n\n    if (sliderValue <= 50) {\n      a = 9.0 * defaultValue / 500.0;\n      b = defaultValue / 10.0;\n    } else {\n      a = 9.0 * defaultValue / 50.0;\n      b = -8 * defaultValue;\n    }\n\n    return a * sliderValue + b;\n  }\n};\n\n/**\r\n * This method finds and returns the center of the given nodes, assuming\r\n * that the given nodes form a tree in themselves.\r\n */\nLayout.findCenterOfTree = function (nodes) {\n  var list = [];\n  list = list.concat(nodes);\n\n  var removedNodes = [];\n  var remainingDegrees = new HashMap();\n  var foundCenter = false;\n  var centerNode = null;\n\n  if (list.length == 1 || list.length == 2) {\n    foundCenter = true;\n    centerNode = list[0];\n  }\n\n  for (var i = 0; i < list.length; i++) {\n    var node = list[i];\n    var degree = node.getNeighborsList().size();\n    remainingDegrees.put(node, node.getNeighborsList().size());\n\n    if (degree == 1) {\n      removedNodes.push(node);\n    }\n  }\n\n  var tempList = [];\n  tempList = tempList.concat(removedNodes);\n\n  while (!foundCenter) {\n    var tempList2 = [];\n    tempList2 = tempList2.concat(tempList);\n    tempList = [];\n\n    for (var i = 0; i < list.length; i++) {\n      var node = list[i];\n\n      var index = list.indexOf(node);\n      if (index >= 0) {\n        list.splice(index, 1);\n      }\n\n      var neighbours = node.getNeighborsList();\n\n      Object.keys(neighbours.set).forEach(function (j) {\n        var neighbour = neighbours.set[j];\n        if (removedNodes.indexOf(neighbour) < 0) {\n          var otherDegree = remainingDegrees.get(neighbour);\n          var newDegree = otherDegree - 1;\n\n          if (newDegree == 1) {\n            tempList.push(neighbour);\n          }\n\n          remainingDegrees.put(neighbour, newDegree);\n        }\n      });\n    }\n\n    removedNodes = removedNodes.concat(tempList);\n\n    if (list.length == 1 || list.length == 2) {\n      foundCenter = true;\n      centerNode = list[0];\n    }\n  }\n\n  return centerNode;\n};\n\n/**\r\n * During the coarsening process, this layout may be referenced by two graph managers\r\n * this setter function grants access to change the currently being used graph manager\r\n */\nLayout.prototype.setGraphManager = function (gm) {\n  this.graphManager = gm;\n};\n\nmodule.exports = Layout;\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports) {\n\nfunction LayoutConstants() {}\n\n/**\r\n * Layout Quality\r\n */\nLayoutConstants.PROOF_QUALITY = 0;\nLayoutConstants.DEFAULT_QUALITY = 1;\nLayoutConstants.DRAFT_QUALITY = 2;\n\n/**\r\n * Default parameters\r\n */\nLayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED = false;\n//LayoutConstants.DEFAULT_INCREMENTAL = true;\nLayoutConstants.DEFAULT_INCREMENTAL = false;\nLayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT = true;\nLayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT = false;\nLayoutConstants.DEFAULT_ANIMATION_PERIOD = 50;\nLayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES = false;\n\n// -----------------------------------------------------------------------------\n// Section: General other constants\n// -----------------------------------------------------------------------------\n/*\r\n * Margins of a graph to be applied on bouding rectangle of its contents. We\r\n * assume margins on all four sides to be uniform.\r\n */\nLayoutConstants.DEFAULT_GRAPH_MARGIN = 15;\n\n/*\r\n * Whether to consider labels in node dimensions or not\r\n */\nLayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = false;\n\n/*\r\n * Default dimension of a non-compound node.\r\n */\nLayoutConstants.SIMPLE_NODE_SIZE = 40;\n\n/*\r\n * Default dimension of a non-compound node.\r\n */\nLayoutConstants.SIMPLE_NODE_HALF_SIZE = LayoutConstants.SIMPLE_NODE_SIZE / 2;\n\n/*\r\n * Empty compound node size. When a compound node is empty, its both\r\n * dimensions should be of this value.\r\n */\nLayoutConstants.EMPTY_COMPOUND_NODE_SIZE = 40;\n\n/*\r\n * Minimum length that an edge should take during layout\r\n */\nLayoutConstants.MIN_EDGE_LENGTH = 1;\n\n/*\r\n * World boundaries that layout operates on\r\n */\nLayoutConstants.WORLD_BOUNDARY = 1000000;\n\n/*\r\n * World boundaries that random positioning can be performed with\r\n */\nLayoutConstants.INITIAL_WORLD_BOUNDARY = LayoutConstants.WORLD_BOUNDARY / 1000;\n\n/*\r\n * Coordinates of the world center\r\n */\nLayoutConstants.WORLD_CENTER_X = 1200;\nLayoutConstants.WORLD_CENTER_Y = 900;\n\nmodule.exports = LayoutConstants;\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar UniqueIDGeneretor = __webpack_require__(5);\n\nfunction HashMap() {\n  this.map = {};\n  this.keys = [];\n}\n\nHashMap.prototype.put = function (key, value) {\n  var theId = UniqueIDGeneretor.createID(key);\n  if (!this.contains(theId)) {\n    this.map[theId] = value;\n    this.keys.push(key);\n  }\n};\n\nHashMap.prototype.contains = function (key) {\n  var theId = UniqueIDGeneretor.createID(key);\n  return this.map[key] != null;\n};\n\nHashMap.prototype.get = function (key) {\n  var theId = UniqueIDGeneretor.createID(key);\n  return this.map[theId];\n};\n\nHashMap.prototype.keySet = function () {\n  return this.keys;\n};\n\nmodule.exports = HashMap;\n\n/***/ }),\n/* 5 */\n/***/ (function(module, exports) {\n\nfunction UniqueIDGeneretor() {}\n\nUniqueIDGeneretor.lastID = 0;\n\nUniqueIDGeneretor.createID = function (obj) {\n  if (UniqueIDGeneretor.isPrimitive(obj)) {\n    return obj;\n  }\n  if (obj.uniqueID != null) {\n    return obj.uniqueID;\n  }\n  obj.uniqueID = UniqueIDGeneretor.getString();\n  UniqueIDGeneretor.lastID++;\n  return obj.uniqueID;\n};\n\nUniqueIDGeneretor.getString = function (id) {\n  if (id == null) id = UniqueIDGeneretor.lastID;\n  return \"Object#\" + id + \"\";\n};\n\nUniqueIDGeneretor.isPrimitive = function (arg) {\n  var type = typeof arg;\n  return arg == null || type != \"object\" && type != \"function\";\n};\n\nmodule.exports = UniqueIDGeneretor;\n\n/***/ }),\n/* 6 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraph;\nvar LEdge = __webpack_require__(7);\n\nfunction LGraphManager(layout) {\n  LGraph = __webpack_require__(11); // It may be better to initilize this out of this function but it gives an error (Right-hand side of 'instanceof' is not callable) now.\n  this.layout = layout;\n\n  this.graphs = [];\n  this.edges = [];\n}\n\nLGraphManager.prototype.addRoot = function () {\n  var ngraph = this.layout.newGraph();\n  var nnode = this.layout.newNode(null);\n  var root = this.add(ngraph, nnode);\n  this.setRootGraph(root);\n  return this.rootGraph;\n};\n\nLGraphManager.prototype.add = function (newGraph, parentNode, newEdge, sourceNode, targetNode) {\n  //there are just 2 parameters are passed then it adds an LGraph else it adds an LEdge\n  if (newEdge == null && sourceNode == null && targetNode == null) {\n    if (newGraph == null) {\n      throw \"Graph is null!\";\n    }\n    if (parentNode == null) {\n      throw \"Parent node is null!\";\n    }\n    if (this.graphs.indexOf(newGraph) > -1) {\n      throw \"Graph already in this graph mgr!\";\n    }\n\n    this.graphs.push(newGraph);\n\n    if (newGraph.parent != null) {\n      throw \"Already has a parent!\";\n    }\n    if (parentNode.child != null) {\n      throw \"Already has a child!\";\n    }\n\n    newGraph.parent = parentNode;\n    parentNode.child = newGraph;\n\n    return newGraph;\n  } else {\n    //change the order of the parameters\n    targetNode = newEdge;\n    sourceNode = parentNode;\n    newEdge = newGraph;\n    var sourceGraph = sourceNode.getOwner();\n    var targetGraph = targetNode.getOwner();\n\n    if (!(sourceGraph != null && sourceGraph.getGraphManager() == this)) {\n      throw \"Source not in this graph mgr!\";\n    }\n    if (!(targetGraph != null && targetGraph.getGraphManager() == this)) {\n      throw \"Target not in this graph mgr!\";\n    }\n\n    if (sourceGraph == targetGraph) {\n      newEdge.isInterGraph = false;\n      return sourceGraph.add(newEdge, sourceNode, targetNode);\n    } else {\n      newEdge.isInterGraph = true;\n\n      // set source and target\n      newEdge.source = sourceNode;\n      newEdge.target = targetNode;\n\n      // add edge to inter-graph edge list\n      if (this.edges.indexOf(newEdge) > -1) {\n        throw \"Edge already in inter-graph edge list!\";\n      }\n\n      this.edges.push(newEdge);\n\n      // add edge to source and target incidency lists\n      if (!(newEdge.source != null && newEdge.target != null)) {\n        throw \"Edge source and/or target is null!\";\n      }\n\n      if (!(newEdge.source.edges.indexOf(newEdge) == -1 && newEdge.target.edges.indexOf(newEdge) == -1)) {\n        throw \"Edge already in source and/or target incidency list!\";\n      }\n\n      newEdge.source.edges.push(newEdge);\n      newEdge.target.edges.push(newEdge);\n\n      return newEdge;\n    }\n  }\n};\n\nLGraphManager.prototype.remove = function (lObj) {\n  if (lObj instanceof LGraph) {\n    var graph = lObj;\n    if (graph.getGraphManager() != this) {\n      throw \"Graph not in this graph mgr\";\n    }\n    if (!(graph == this.rootGraph || graph.parent != null && graph.parent.graphManager == this)) {\n      throw \"Invalid parent node!\";\n    }\n\n    // first the edges (make a copy to do it safely)\n    var edgesToBeRemoved = [];\n\n    edgesToBeRemoved = edgesToBeRemoved.concat(graph.getEdges());\n\n    var edge;\n    var s = edgesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      edge = edgesToBeRemoved[i];\n      graph.remove(edge);\n    }\n\n    // then the nodes (make a copy to do it safely)\n    var nodesToBeRemoved = [];\n\n    nodesToBeRemoved = nodesToBeRemoved.concat(graph.getNodes());\n\n    var node;\n    s = nodesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      node = nodesToBeRemoved[i];\n      graph.remove(node);\n    }\n\n    // check if graph is the root\n    if (graph == this.rootGraph) {\n      this.setRootGraph(null);\n    }\n\n    // now remove the graph itself\n    var index = this.graphs.indexOf(graph);\n    this.graphs.splice(index, 1);\n\n    // also reset the parent of the graph\n    graph.parent = null;\n  } else if (lObj instanceof LEdge) {\n    edge = lObj;\n    if (edge == null) {\n      throw \"Edge is null!\";\n    }\n    if (!edge.isInterGraph) {\n      throw \"Not an inter-graph edge!\";\n    }\n    if (!(edge.source != null && edge.target != null)) {\n      throw \"Source and/or target is null!\";\n    }\n\n    // remove edge from source and target nodes' incidency lists\n\n    if (!(edge.source.edges.indexOf(edge) != -1 && edge.target.edges.indexOf(edge) != -1)) {\n      throw \"Source and/or target doesn't know this edge!\";\n    }\n\n    var index = edge.source.edges.indexOf(edge);\n    edge.source.edges.splice(index, 1);\n    index = edge.target.edges.indexOf(edge);\n    edge.target.edges.splice(index, 1);\n\n    // remove edge from owner graph manager's inter-graph edge list\n\n    if (!(edge.source.owner != null && edge.source.owner.getGraphManager() != null)) {\n      throw \"Edge owner graph or owner graph manager is null!\";\n    }\n    if (edge.source.owner.getGraphManager().edges.indexOf(edge) == -1) {\n      throw \"Not in owner graph manager's edge list!\";\n    }\n\n    var index = edge.source.owner.getGraphManager().edges.indexOf(edge);\n    edge.source.owner.getGraphManager().edges.splice(index, 1);\n  }\n};\n\nLGraphManager.prototype.updateBounds = function () {\n  this.rootGraph.updateBounds(true);\n};\n\nLGraphManager.prototype.getGraphs = function () {\n  return this.graphs;\n};\n\nLGraphManager.prototype.getAllNodes = function () {\n  if (this.allNodes == null) {\n    var nodeList = [];\n    var graphs = this.getGraphs();\n    var s = graphs.length;\n    for (var i = 0; i < s; i++) {\n      nodeList = nodeList.concat(graphs[i].getNodes());\n    }\n    this.allNodes = nodeList;\n  }\n  return this.allNodes;\n};\n\nLGraphManager.prototype.resetAllNodes = function () {\n  this.allNodes = null;\n};\n\nLGraphManager.prototype.resetAllEdges = function () {\n  this.allEdges = null;\n};\n\nLGraphManager.prototype.resetAllNodesToApplyGravitation = function () {\n  this.allNodesToApplyGravitation = null;\n};\n\nLGraphManager.prototype.getAllEdges = function () {\n  if (this.allEdges == null) {\n    var edgeList = [];\n    var graphs = this.getGraphs();\n    var s = graphs.length;\n    for (var i = 0; i < graphs.length; i++) {\n      edgeList = edgeList.concat(graphs[i].getEdges());\n    }\n\n    edgeList = edgeList.concat(this.edges);\n\n    this.allEdges = edgeList;\n  }\n  return this.allEdges;\n};\n\nLGraphManager.prototype.getAllNodesToApplyGravitation = function () {\n  return this.allNodesToApplyGravitation;\n};\n\nLGraphManager.prototype.setAllNodesToApplyGravitation = function (nodeList) {\n  if (this.allNodesToApplyGravitation != null) {\n    throw \"assert failed\";\n  }\n\n  this.allNodesToApplyGravitation = nodeList;\n};\n\nLGraphManager.prototype.getRoot = function () {\n  return this.rootGraph;\n};\n\nLGraphManager.prototype.setRootGraph = function (graph) {\n  if (graph.getGraphManager() != this) {\n    throw \"Root not in this graph mgr!\";\n  }\n\n  this.rootGraph = graph;\n  // root graph must have a root node associated with it for convenience\n  if (graph.parent == null) {\n    graph.parent = this.layout.newNode(\"Root node\");\n  }\n};\n\nLGraphManager.prototype.getLayout = function () {\n  return this.layout;\n};\n\nLGraphManager.prototype.isOneAncestorOfOther = function (firstNode, secondNode) {\n  if (!(firstNode != null && secondNode != null)) {\n    throw \"assert failed\";\n  }\n\n  if (firstNode == secondNode) {\n    return true;\n  }\n  // Is second node an ancestor of the first one?\n  var ownerGraph = firstNode.getOwner();\n  var parentNode;\n\n  do {\n    parentNode = ownerGraph.getParent();\n\n    if (parentNode == null) {\n      break;\n    }\n\n    if (parentNode == secondNode) {\n      return true;\n    }\n\n    ownerGraph = parentNode.getOwner();\n    if (ownerGraph == null) {\n      break;\n    }\n  } while (true);\n  // Is first node an ancestor of the second one?\n  ownerGraph = secondNode.getOwner();\n\n  do {\n    parentNode = ownerGraph.getParent();\n\n    if (parentNode == null) {\n      break;\n    }\n\n    if (parentNode == firstNode) {\n      return true;\n    }\n\n    ownerGraph = parentNode.getOwner();\n    if (ownerGraph == null) {\n      break;\n    }\n  } while (true);\n\n  return false;\n};\n\nLGraphManager.prototype.calcLowestCommonAncestors = function () {\n  var edge;\n  var sourceNode;\n  var targetNode;\n  var sourceAncestorGraph;\n  var targetAncestorGraph;\n\n  var edges = this.getAllEdges();\n  var s = edges.length;\n  for (var i = 0; i < s; i++) {\n    edge = edges[i];\n\n    sourceNode = edge.source;\n    targetNode = edge.target;\n    edge.lca = null;\n    edge.sourceInLca = sourceNode;\n    edge.targetInLca = targetNode;\n\n    if (sourceNode == targetNode) {\n      edge.lca = sourceNode.getOwner();\n      continue;\n    }\n\n    sourceAncestorGraph = sourceNode.getOwner();\n\n    while (edge.lca == null) {\n      edge.targetInLca = targetNode;\n      targetAncestorGraph = targetNode.getOwner();\n\n      while (edge.lca == null) {\n        if (targetAncestorGraph == sourceAncestorGraph) {\n          edge.lca = targetAncestorGraph;\n          break;\n        }\n\n        if (targetAncestorGraph == this.rootGraph) {\n          break;\n        }\n\n        if (edge.lca != null) {\n          throw \"assert failed\";\n        }\n        edge.targetInLca = targetAncestorGraph.getParent();\n        targetAncestorGraph = edge.targetInLca.getOwner();\n      }\n\n      if (sourceAncestorGraph == this.rootGraph) {\n        break;\n      }\n\n      if (edge.lca == null) {\n        edge.sourceInLca = sourceAncestorGraph.getParent();\n        sourceAncestorGraph = edge.sourceInLca.getOwner();\n      }\n    }\n\n    if (edge.lca == null) {\n      throw \"assert failed\";\n    }\n  }\n};\n\nLGraphManager.prototype.calcLowestCommonAncestor = function (firstNode, secondNode) {\n  if (firstNode == secondNode) {\n    return firstNode.getOwner();\n  }\n  var firstOwnerGraph = firstNode.getOwner();\n\n  do {\n    if (firstOwnerGraph == null) {\n      break;\n    }\n    var secondOwnerGraph = secondNode.getOwner();\n\n    do {\n      if (secondOwnerGraph == null) {\n        break;\n      }\n\n      if (secondOwnerGraph == firstOwnerGraph) {\n        return secondOwnerGraph;\n      }\n      secondOwnerGraph = secondOwnerGraph.getParent().getOwner();\n    } while (true);\n\n    firstOwnerGraph = firstOwnerGraph.getParent().getOwner();\n  } while (true);\n\n  return firstOwnerGraph;\n};\n\nLGraphManager.prototype.calcInclusionTreeDepths = function (graph, depth) {\n  if (graph == null && depth == null) {\n    graph = this.rootGraph;\n    depth = 1;\n  }\n  var node;\n\n  var nodes = graph.getNodes();\n  var s = nodes.length;\n  for (var i = 0; i < s; i++) {\n    node = nodes[i];\n    node.inclusionTreeDepth = depth;\n\n    if (node.child != null) {\n      this.calcInclusionTreeDepths(node.child, depth + 1);\n    }\n  }\n};\n\nLGraphManager.prototype.includesInvalidEdge = function () {\n  var edge;\n\n  var s = this.edges.length;\n  for (var i = 0; i < s; i++) {\n    edge = this.edges[i];\n\n    if (this.isOneAncestorOfOther(edge.source, edge.target)) {\n      return true;\n    }\n  }\n  return false;\n};\n\nmodule.exports = LGraphManager;\n\n/***/ }),\n/* 7 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar IGeometry = __webpack_require__(9);\nvar IMath = __webpack_require__(10);\n\nfunction LEdge(source, target, vEdge) {\n  LGraphObject.call(this, vEdge);\n\n  this.isOverlapingSourceAndTarget = false;\n  this.vGraphObject = vEdge;\n  this.bendpoints = [];\n  this.source = source;\n  this.target = target;\n}\n\nLEdge.prototype = Object.create(LGraphObject.prototype);\n\nfor (var prop in LGraphObject) {\n  LEdge[prop] = LGraphObject[prop];\n}\n\nLEdge.prototype.getSource = function () {\n  return this.source;\n};\n\nLEdge.prototype.getTarget = function () {\n  return this.target;\n};\n\nLEdge.prototype.isInterGraph = function () {\n  return this.isInterGraph;\n};\n\nLEdge.prototype.getLength = function () {\n  return this.length;\n};\n\nLEdge.prototype.isOverlapingSourceAndTarget = function () {\n  return this.isOverlapingSourceAndTarget;\n};\n\nLEdge.prototype.getBendpoints = function () {\n  return this.bendpoints;\n};\n\nLEdge.prototype.getLca = function () {\n  return this.lca;\n};\n\nLEdge.prototype.getSourceInLca = function () {\n  return this.sourceInLca;\n};\n\nLEdge.prototype.getTargetInLca = function () {\n  return this.targetInLca;\n};\n\nLEdge.prototype.getOtherEnd = function (node) {\n  if (this.source === node) {\n    return this.target;\n  } else if (this.target === node) {\n    return this.source;\n  } else {\n    throw \"Node is not incident with this edge\";\n  }\n};\n\nLEdge.prototype.getOtherEndInGraph = function (node, graph) {\n  var otherEnd = this.getOtherEnd(node);\n  var root = graph.getGraphManager().getRoot();\n\n  while (true) {\n    if (otherEnd.getOwner() == graph) {\n      return otherEnd;\n    }\n\n    if (otherEnd.getOwner() == root) {\n      break;\n    }\n\n    otherEnd = otherEnd.getOwner().getParent();\n  }\n\n  return null;\n};\n\nLEdge.prototype.updateLength = function () {\n  var clipPointCoordinates = new Array(4);\n\n  this.isOverlapingSourceAndTarget = IGeometry.getIntersection(this.target.getRect(), this.source.getRect(), clipPointCoordinates);\n\n  if (!this.isOverlapingSourceAndTarget) {\n    this.lengthX = clipPointCoordinates[0] - clipPointCoordinates[2];\n    this.lengthY = clipPointCoordinates[1] - clipPointCoordinates[3];\n\n    if (Math.abs(this.lengthX) < 1.0) {\n      this.lengthX = IMath.sign(this.lengthX);\n    }\n\n    if (Math.abs(this.lengthY) < 1.0) {\n      this.lengthY = IMath.sign(this.lengthY);\n    }\n\n    this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY);\n  }\n};\n\nLEdge.prototype.updateLengthSimple = function () {\n  this.lengthX = this.target.getCenterX() - this.source.getCenterX();\n  this.lengthY = this.target.getCenterY() - this.source.getCenterY();\n\n  if (Math.abs(this.lengthX) < 1.0) {\n    this.lengthX = IMath.sign(this.lengthX);\n  }\n\n  if (Math.abs(this.lengthY) < 1.0) {\n    this.lengthY = IMath.sign(this.lengthY);\n  }\n\n  this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY);\n};\n\nmodule.exports = LEdge;\n\n/***/ }),\n/* 8 */\n/***/ (function(module, exports) {\n\nfunction LGraphObject(vGraphObject) {\n  this.vGraphObject = vGraphObject;\n}\n\nmodule.exports = LGraphObject;\n\n/***/ }),\n/* 9 */\n/***/ (function(module, exports) {\n\nfunction IGeometry() {}\n\nIGeometry.calcSeparationAmount = function (rectA, rectB, overlapAmount, separationBuffer) {\n  if (!rectA.intersects(rectB)) {\n    throw \"assert failed\";\n  }\n  var directions = new Array(2);\n  IGeometry.decideDirectionsForOverlappingNodes(rectA, rectB, directions);\n  overlapAmount[0] = Math.min(rectA.getRight(), rectB.getRight()) - Math.max(rectA.x, rectB.x);\n  overlapAmount[1] = Math.min(rectA.getBottom(), rectB.getBottom()) - Math.max(rectA.y, rectB.y);\n  // update the overlapping amounts for the following cases:\n  if (rectA.getX() <= rectB.getX() && rectA.getRight() >= rectB.getRight()) {\n    overlapAmount[0] += Math.min(rectB.getX() - rectA.getX(), rectA.getRight() - rectB.getRight());\n  } else if (rectB.getX() <= rectA.getX() && rectB.getRight() >= rectA.getRight()) {\n    overlapAmount[0] += Math.min(rectA.getX() - rectB.getX(), rectB.getRight() - rectA.getRight());\n  }\n  if (rectA.getY() <= rectB.getY() && rectA.getBottom() >= rectB.getBottom()) {\n    overlapAmount[1] += Math.min(rectB.getY() - rectA.getY(), rectA.getBottom() - rectB.getBottom());\n  } else if (rectB.getY() <= rectA.getY() && rectB.getBottom() >= rectA.getBottom()) {\n    overlapAmount[1] += Math.min(rectA.getY() - rectB.getY(), rectB.getBottom() - rectA.getBottom());\n  }\n\n  // find slope of the line passes two centers\n  var slope = Math.abs((rectB.getCenterY() - rectA.getCenterY()) / (rectB.getCenterX() - rectA.getCenterX()));\n  // if centers are overlapped\n  if (rectB.getCenterY() == rectA.getCenterY() && rectB.getCenterX() == rectA.getCenterX()) {\n    // assume the slope is 1 (45 degree)\n    slope = 1.0;\n  }\n\n  var moveByY = slope * overlapAmount[0];\n  var moveByX = overlapAmount[1] / slope;\n  if (overlapAmount[0] < moveByX) {\n    moveByX = overlapAmount[0];\n  } else {\n    moveByY = overlapAmount[1];\n  }\n  // return half the amount so that if each rectangle is moved by these\n  // amounts in opposite directions, overlap will be resolved\n  overlapAmount[0] = -1 * directions[0] * (moveByX / 2 + separationBuffer);\n  overlapAmount[1] = -1 * directions[1] * (moveByY / 2 + separationBuffer);\n};\n\nIGeometry.decideDirectionsForOverlappingNodes = function (rectA, rectB, directions) {\n  if (rectA.getCenterX() < rectB.getCenterX()) {\n    directions[0] = -1;\n  } else {\n    directions[0] = 1;\n  }\n\n  if (rectA.getCenterY() < rectB.getCenterY()) {\n    directions[1] = -1;\n  } else {\n    directions[1] = 1;\n  }\n};\n\nIGeometry.getIntersection2 = function (rectA, rectB, result) {\n  //result[0-1] will contain clipPoint of rectA, result[2-3] will contain clipPoint of rectB\n  var p1x = rectA.getCenterX();\n  var p1y = rectA.getCenterY();\n  var p2x = rectB.getCenterX();\n  var p2y = rectB.getCenterY();\n\n  //if two rectangles intersect, then clipping points are centers\n  if (rectA.intersects(rectB)) {\n    result[0] = p1x;\n    result[1] = p1y;\n    result[2] = p2x;\n    result[3] = p2y;\n    return true;\n  }\n  //variables for rectA\n  var topLeftAx = rectA.getX();\n  var topLeftAy = rectA.getY();\n  var topRightAx = rectA.getRight();\n  var bottomLeftAx = rectA.getX();\n  var bottomLeftAy = rectA.getBottom();\n  var bottomRightAx = rectA.getRight();\n  var halfWidthA = rectA.getWidthHalf();\n  var halfHeightA = rectA.getHeightHalf();\n  //variables for rectB\n  var topLeftBx = rectB.getX();\n  var topLeftBy = rectB.getY();\n  var topRightBx = rectB.getRight();\n  var bottomLeftBx = rectB.getX();\n  var bottomLeftBy = rectB.getBottom();\n  var bottomRightBx = rectB.getRight();\n  var halfWidthB = rectB.getWidthHalf();\n  var halfHeightB = rectB.getHeightHalf();\n  //flag whether clipping points are found\n  var clipPointAFound = false;\n  var clipPointBFound = false;\n\n  // line is vertical\n  if (p1x == p2x) {\n    if (p1y > p2y) {\n      result[0] = p1x;\n      result[1] = topLeftAy;\n      result[2] = p2x;\n      result[3] = bottomLeftBy;\n      return false;\n    } else if (p1y < p2y) {\n      result[0] = p1x;\n      result[1] = bottomLeftAy;\n      result[2] = p2x;\n      result[3] = topLeftBy;\n      return false;\n    } else {\n      //not line, return null;\n    }\n  }\n  // line is horizontal\n  else if (p1y == p2y) {\n      if (p1x > p2x) {\n        result[0] = topLeftAx;\n        result[1] = p1y;\n        result[2] = topRightBx;\n        result[3] = p2y;\n        return false;\n      } else if (p1x < p2x) {\n        result[0] = topRightAx;\n        result[1] = p1y;\n        result[2] = topLeftBx;\n        result[3] = p2y;\n        return false;\n      } else {\n        //not valid line, return null;\n      }\n    } else {\n      //slopes of rectA's and rectB's diagonals\n      var slopeA = rectA.height / rectA.width;\n      var slopeB = rectB.height / rectB.width;\n\n      //slope of line between center of rectA and center of rectB\n      var slopePrime = (p2y - p1y) / (p2x - p1x);\n      var cardinalDirectionA;\n      var cardinalDirectionB;\n      var tempPointAx;\n      var tempPointAy;\n      var tempPointBx;\n      var tempPointBy;\n\n      //determine whether clipping point is the corner of nodeA\n      if (-slopeA == slopePrime) {\n        if (p1x > p2x) {\n          result[0] = bottomLeftAx;\n          result[1] = bottomLeftAy;\n          clipPointAFound = true;\n        } else {\n          result[0] = topRightAx;\n          result[1] = topLeftAy;\n          clipPointAFound = true;\n        }\n      } else if (slopeA == slopePrime) {\n        if (p1x > p2x) {\n          result[0] = topLeftAx;\n          result[1] = topLeftAy;\n          clipPointAFound = true;\n        } else {\n          result[0] = bottomRightAx;\n          result[1] = bottomLeftAy;\n          clipPointAFound = true;\n        }\n      }\n\n      //determine whether clipping point is the corner of nodeB\n      if (-slopeB == slopePrime) {\n        if (p2x > p1x) {\n          result[2] = bottomLeftBx;\n          result[3] = bottomLeftBy;\n          clipPointBFound = true;\n        } else {\n          result[2] = topRightBx;\n          result[3] = topLeftBy;\n          clipPointBFound = true;\n        }\n      } else if (slopeB == slopePrime) {\n        if (p2x > p1x) {\n          result[2] = topLeftBx;\n          result[3] = topLeftBy;\n          clipPointBFound = true;\n        } else {\n          result[2] = bottomRightBx;\n          result[3] = bottomLeftBy;\n          clipPointBFound = true;\n        }\n      }\n\n      //if both clipping points are corners\n      if (clipPointAFound && clipPointBFound) {\n        return false;\n      }\n\n      //determine Cardinal Direction of rectangles\n      if (p1x > p2x) {\n        if (p1y > p2y) {\n          cardinalDirectionA = IGeometry.getCardinalDirection(slopeA, slopePrime, 4);\n          cardinalDirectionB = IGeometry.getCardinalDirection(slopeB, slopePrime, 2);\n        } else {\n          cardinalDirectionA = IGeometry.getCardinalDirection(-slopeA, slopePrime, 3);\n          cardinalDirectionB = IGeometry.getCardinalDirection(-slopeB, slopePrime, 1);\n        }\n      } else {\n        if (p1y > p2y) {\n          cardinalDirectionA = IGeometry.getCardinalDirection(-slopeA, slopePrime, 1);\n          cardinalDirectionB = IGeometry.getCardinalDirection(-slopeB, slopePrime, 3);\n        } else {\n          cardinalDirectionA = IGeometry.getCardinalDirection(slopeA, slopePrime, 2);\n          cardinalDirectionB = IGeometry.getCardinalDirection(slopeB, slopePrime, 4);\n        }\n      }\n      //calculate clipping Point if it is not found before\n      if (!clipPointAFound) {\n        switch (cardinalDirectionA) {\n          case 1:\n            tempPointAy = topLeftAy;\n            tempPointAx = p1x + -halfHeightA / slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 2:\n            tempPointAx = bottomRightAx;\n            tempPointAy = p1y + halfWidthA * slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 3:\n            tempPointAy = bottomLeftAy;\n            tempPointAx = p1x + halfHeightA / slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 4:\n            tempPointAx = bottomLeftAx;\n            tempPointAy = p1y + -halfWidthA * slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n        }\n      }\n      if (!clipPointBFound) {\n        switch (cardinalDirectionB) {\n          case 1:\n            tempPointBy = topLeftBy;\n            tempPointBx = p2x + -halfHeightB / slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 2:\n            tempPointBx = bottomRightBx;\n            tempPointBy = p2y + halfWidthB * slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 3:\n            tempPointBy = bottomLeftBy;\n            tempPointBx = p2x + halfHeightB / slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 4:\n            tempPointBx = bottomLeftBx;\n            tempPointBy = p2y + -halfWidthB * slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n        }\n      }\n    }\n  return false;\n};\n\nIGeometry.getCardinalDirection = function (slope, slopePrime, line) {\n  if (slope > slopePrime) {\n    return line;\n  } else {\n    return 1 + line % 4;\n  }\n};\n\nIGeometry.getIntersection = function (s1, s2, f1, f2) {\n  if (f2 == null) {\n    return IGeometry.getIntersection2(s1, s2, f1);\n  }\n  var x1 = s1.x;\n  var y1 = s1.y;\n  var x2 = s2.x;\n  var y2 = s2.y;\n  var x3 = f1.x;\n  var y3 = f1.y;\n  var x4 = f2.x;\n  var y4 = f2.y;\n  var x, y; // intersection point\n  var a1, a2, b1, b2, c1, c2; // coefficients of line eqns.\n  var denom;\n\n  a1 = y2 - y1;\n  b1 = x1 - x2;\n  c1 = x2 * y1 - x1 * y2; // { a1*x + b1*y + c1 = 0 is line 1 }\n\n  a2 = y4 - y3;\n  b2 = x3 - x4;\n  c2 = x4 * y3 - x3 * y4; // { a2*x + b2*y + c2 = 0 is line 2 }\n\n  denom = a1 * b2 - a2 * b1;\n\n  if (denom == 0) {\n    return null;\n  }\n\n  x = (b1 * c2 - b2 * c1) / denom;\n  y = (a2 * c1 - a1 * c2) / denom;\n\n  return new Point(x, y);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Class Constants\n// -----------------------------------------------------------------------------\n/**\r\n * Some useful pre-calculated constants\r\n */\nIGeometry.HALF_PI = 0.5 * Math.PI;\nIGeometry.ONE_AND_HALF_PI = 1.5 * Math.PI;\nIGeometry.TWO_PI = 2.0 * Math.PI;\nIGeometry.THREE_PI = 3.0 * Math.PI;\n\nmodule.exports = IGeometry;\n\n/***/ }),\n/* 10 */\n/***/ (function(module, exports) {\n\nfunction IMath() {}\n\n/**\r\n * This method returns the sign of the input value.\r\n */\nIMath.sign = function (value) {\n  if (value > 0) {\n    return 1;\n  } else if (value < 0) {\n    return -1;\n  } else {\n    return 0;\n  }\n};\n\nIMath.floor = function (value) {\n  return value < 0 ? Math.ceil(value) : Math.floor(value);\n};\n\nIMath.ceil = function (value) {\n  return value < 0 ? Math.floor(value) : Math.ceil(value);\n};\n\nmodule.exports = IMath;\n\n/***/ }),\n/* 11 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar Integer = __webpack_require__(12);\nvar LayoutConstants = __webpack_require__(3);\nvar LGraphManager = __webpack_require__(6);\nvar LNode = __webpack_require__(13);\nvar LEdge = __webpack_require__(7);\nvar RectangleD = __webpack_require__(14);\nvar Point = __webpack_require__(18);\nvar LinkedList = __webpack_require__(19);\n\nfunction LGraph(parent, obj2, vGraph) {\n  LGraphObject.call(this, vGraph);\n  this.estimatedSize = Integer.MIN_VALUE;\n  this.margin = LayoutConstants.DEFAULT_GRAPH_MARGIN;\n  this.edges = [];\n  this.nodes = [];\n  this.isConnected = false;\n  this.parent = parent;\n\n  if (obj2 != null && obj2 instanceof LGraphManager) {\n    this.graphManager = obj2;\n  } else if (obj2 != null && obj2 instanceof Layout) {\n    this.graphManager = obj2.graphManager;\n  }\n}\n\nLGraph.prototype = Object.create(LGraphObject.prototype);\nfor (var prop in LGraphObject) {\n  LGraph[prop] = LGraphObject[prop];\n}\n\nLGraph.prototype.getNodes = function () {\n  return this.nodes;\n};\n\nLGraph.prototype.getEdges = function () {\n  return this.edges;\n};\n\nLGraph.prototype.getGraphManager = function () {\n  return this.graphManager;\n};\n\nLGraph.prototype.getParent = function () {\n  return this.parent;\n};\n\nLGraph.prototype.getLeft = function () {\n  return this.left;\n};\n\nLGraph.prototype.getRight = function () {\n  return this.right;\n};\n\nLGraph.prototype.getTop = function () {\n  return this.top;\n};\n\nLGraph.prototype.getBottom = function () {\n  return this.bottom;\n};\n\nLGraph.prototype.isConnected = function () {\n  return this.isConnected;\n};\n\nLGraph.prototype.add = function (obj1, sourceNode, targetNode) {\n  if (sourceNode == null && targetNode == null) {\n    var newNode = obj1;\n    if (this.graphManager == null) {\n      throw \"Graph has no graph mgr!\";\n    }\n    if (this.getNodes().indexOf(newNode) > -1) {\n      throw \"Node already in graph!\";\n    }\n    newNode.owner = this;\n    this.getNodes().push(newNode);\n\n    return newNode;\n  } else {\n    var newEdge = obj1;\n    if (!(this.getNodes().indexOf(sourceNode) > -1 && this.getNodes().indexOf(targetNode) > -1)) {\n      throw \"Source or target not in graph!\";\n    }\n\n    if (!(sourceNode.owner == targetNode.owner && sourceNode.owner == this)) {\n      throw \"Both owners must be this graph!\";\n    }\n\n    if (sourceNode.owner != targetNode.owner) {\n      return null;\n    }\n\n    // set source and target\n    newEdge.source = sourceNode;\n    newEdge.target = targetNode;\n\n    // set as intra-graph edge\n    newEdge.isInterGraph = false;\n\n    // add to graph edge list\n    this.getEdges().push(newEdge);\n\n    // add to incidency lists\n    sourceNode.edges.push(newEdge);\n\n    if (targetNode != sourceNode) {\n      targetNode.edges.push(newEdge);\n    }\n\n    return newEdge;\n  }\n};\n\nLGraph.prototype.remove = function (obj) {\n  var node = obj;\n  if (obj instanceof LNode) {\n    if (node == null) {\n      throw \"Node is null!\";\n    }\n    if (!(node.owner != null && node.owner == this)) {\n      throw \"Owner graph is invalid!\";\n    }\n    if (this.graphManager == null) {\n      throw \"Owner graph manager is invalid!\";\n    }\n    // remove incident edges first (make a copy to do it safely)\n    var edgesToBeRemoved = node.edges.slice();\n    var edge;\n    var s = edgesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      edge = edgesToBeRemoved[i];\n\n      if (edge.isInterGraph) {\n        this.graphManager.remove(edge);\n      } else {\n        edge.source.owner.remove(edge);\n      }\n    }\n\n    // now the node itself\n    var index = this.nodes.indexOf(node);\n    if (index == -1) {\n      throw \"Node not in owner node list!\";\n    }\n\n    this.nodes.splice(index, 1);\n  } else if (obj instanceof LEdge) {\n    var edge = obj;\n    if (edge == null) {\n      throw \"Edge is null!\";\n    }\n    if (!(edge.source != null && edge.target != null)) {\n      throw \"Source and/or target is null!\";\n    }\n    if (!(edge.source.owner != null && edge.target.owner != null && edge.source.owner == this && edge.target.owner == this)) {\n      throw \"Source and/or target owner is invalid!\";\n    }\n\n    var sourceIndex = edge.source.edges.indexOf(edge);\n    var targetIndex = edge.target.edges.indexOf(edge);\n    if (!(sourceIndex > -1 && targetIndex > -1)) {\n      throw \"Source and/or target doesn't know this edge!\";\n    }\n\n    edge.source.edges.splice(sourceIndex, 1);\n\n    if (edge.target != edge.source) {\n      edge.target.edges.splice(targetIndex, 1);\n    }\n\n    var index = edge.source.owner.getEdges().indexOf(edge);\n    if (index == -1) {\n      throw \"Not in owner's edge list!\";\n    }\n\n    edge.source.owner.getEdges().splice(index, 1);\n  }\n};\n\nLGraph.prototype.updateLeftTop = function () {\n  var top = Integer.MAX_VALUE;\n  var left = Integer.MAX_VALUE;\n  var nodeTop;\n  var nodeLeft;\n  var margin;\n\n  var nodes = this.getNodes();\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    nodeTop = lNode.getTop();\n    nodeLeft = lNode.getLeft();\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n  }\n\n  // Do we have any nodes in this graph?\n  if (top == Integer.MAX_VALUE) {\n    return null;\n  }\n\n  if (nodes[0].getParent().paddingLeft != undefined) {\n    margin = nodes[0].getParent().paddingLeft;\n  } else {\n    margin = this.margin;\n  }\n\n  this.left = left - margin;\n  this.top = top - margin;\n\n  // Apply the margins and return the result\n  return new Point(this.left, this.top);\n};\n\nLGraph.prototype.updateBounds = function (recursive) {\n  // calculate bounds\n  var left = Integer.MAX_VALUE;\n  var right = -Integer.MAX_VALUE;\n  var top = Integer.MAX_VALUE;\n  var bottom = -Integer.MAX_VALUE;\n  var nodeLeft;\n  var nodeRight;\n  var nodeTop;\n  var nodeBottom;\n  var margin;\n\n  var nodes = this.nodes;\n  var s = nodes.length;\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n\n    if (recursive && lNode.child != null) {\n      lNode.updateBounds();\n    }\n    nodeLeft = lNode.getLeft();\n    nodeRight = lNode.getRight();\n    nodeTop = lNode.getTop();\n    nodeBottom = lNode.getBottom();\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n\n    if (right < nodeRight) {\n      right = nodeRight;\n    }\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (bottom < nodeBottom) {\n      bottom = nodeBottom;\n    }\n  }\n\n  var boundingRect = new RectangleD(left, top, right - left, bottom - top);\n  if (left == Integer.MAX_VALUE) {\n    this.left = this.parent.getLeft();\n    this.right = this.parent.getRight();\n    this.top = this.parent.getTop();\n    this.bottom = this.parent.getBottom();\n  }\n\n  if (nodes[0].getParent().paddingLeft != undefined) {\n    margin = nodes[0].getParent().paddingLeft;\n  } else {\n    margin = this.margin;\n  }\n\n  this.left = boundingRect.x - margin;\n  this.right = boundingRect.x + boundingRect.width + margin;\n  this.top = boundingRect.y - margin;\n  this.bottom = boundingRect.y + boundingRect.height + margin;\n};\n\nLGraph.calculateBounds = function (nodes) {\n  var left = Integer.MAX_VALUE;\n  var right = -Integer.MAX_VALUE;\n  var top = Integer.MAX_VALUE;\n  var bottom = -Integer.MAX_VALUE;\n  var nodeLeft;\n  var nodeRight;\n  var nodeTop;\n  var nodeBottom;\n\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    nodeLeft = lNode.getLeft();\n    nodeRight = lNode.getRight();\n    nodeTop = lNode.getTop();\n    nodeBottom = lNode.getBottom();\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n\n    if (right < nodeRight) {\n      right = nodeRight;\n    }\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (bottom < nodeBottom) {\n      bottom = nodeBottom;\n    }\n  }\n\n  var boundingRect = new RectangleD(left, top, right - left, bottom - top);\n\n  return boundingRect;\n};\n\nLGraph.prototype.getInclusionTreeDepth = function () {\n  if (this == this.graphManager.getRoot()) {\n    return 1;\n  } else {\n    return this.parent.getInclusionTreeDepth();\n  }\n};\n\nLGraph.prototype.getEstimatedSize = function () {\n  if (this.estimatedSize == Integer.MIN_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.estimatedSize;\n};\n\nLGraph.prototype.calcEstimatedSize = function () {\n  var size = 0;\n  var nodes = this.nodes;\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    size += lNode.calcEstimatedSize();\n  }\n\n  if (size == 0) {\n    this.estimatedSize = LayoutConstants.EMPTY_COMPOUND_NODE_SIZE;\n  } else {\n    this.estimatedSize = size / Math.sqrt(this.nodes.length);\n  }\n\n  return this.estimatedSize;\n};\n\nLGraph.prototype.updateConnected = function () {\n  var self = this;\n  if (this.nodes.length == 0) {\n    this.isConnected = true;\n    return;\n  }\n\n  var queue = new LinkedList();\n  var visited = new Set();\n  var currentNode = this.nodes[0];\n  var neighborEdges;\n  var currentNeighbor;\n  var childrenOfNode = currentNode.withChildren();\n  childrenOfNode.forEach(function (node) {\n    queue.push(node);\n    visited.add(node);\n  });\n\n  while (queue.length !== 0) {\n    currentNode = queue.shift();\n\n    // Traverse all neighbors of this node\n    neighborEdges = currentNode.getEdges();\n    var size = neighborEdges.length;\n    for (var i = 0; i < size; i++) {\n      var neighborEdge = neighborEdges[i];\n      currentNeighbor = neighborEdge.getOtherEndInGraph(currentNode, this);\n\n      // Add unvisited neighbors to the list to visit\n      if (currentNeighbor != null && !visited.has(currentNeighbor)) {\n        var childrenOfNeighbor = currentNeighbor.withChildren();\n\n        childrenOfNeighbor.forEach(function (node) {\n          queue.push(node);\n          visited.add(node);\n        });\n      }\n    }\n  }\n\n  this.isConnected = false;\n\n  if (visited.size >= this.nodes.length) {\n    var noOfVisitedInThisGraph = 0;\n\n    visited.forEach(function (visitedNode) {\n      if (visitedNode.owner == self) {\n        noOfVisitedInThisGraph++;\n      }\n    });\n\n    if (noOfVisitedInThisGraph == this.nodes.length) {\n      this.isConnected = true;\n    }\n  }\n};\n\nmodule.exports = LGraph;\n\n/***/ }),\n/* 12 */\n/***/ (function(module, exports) {\n\nfunction Integer() {}\n\nInteger.MAX_VALUE = 2147483647;\nInteger.MIN_VALUE = -2147483648;\n\nmodule.exports = Integer;\n\n/***/ }),\n/* 13 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar Integer = __webpack_require__(12);\nvar RectangleD = __webpack_require__(14);\nvar LayoutConstants = __webpack_require__(3);\nvar RandomSeed = __webpack_require__(15);\nvar PointD = __webpack_require__(16);\nvar HashSet = __webpack_require__(17);\n\nfunction LNode(gm, loc, size, vNode) {\n  //Alternative constructor 1 : LNode(LGraphManager gm, Point loc, Dimension size, Object vNode)\n  if (size == null && vNode == null) {\n    vNode = loc;\n  }\n\n  LGraphObject.call(this, vNode);\n\n  //Alternative constructor 2 : LNode(Layout layout, Object vNode)\n  if (gm.graphManager != null) gm = gm.graphManager;\n\n  this.estimatedSize = Integer.MIN_VALUE;\n  this.inclusionTreeDepth = Integer.MAX_VALUE;\n  this.vGraphObject = vNode;\n  this.edges = [];\n  this.graphManager = gm;\n\n  if (size != null && loc != null) this.rect = new RectangleD(loc.x, loc.y, size.width, size.height);else this.rect = new RectangleD();\n}\n\nLNode.prototype = Object.create(LGraphObject.prototype);\nfor (var prop in LGraphObject) {\n  LNode[prop] = LGraphObject[prop];\n}\n\nLNode.prototype.getEdges = function () {\n  return this.edges;\n};\n\nLNode.prototype.getChild = function () {\n  return this.child;\n};\n\nLNode.prototype.getOwner = function () {\n  //  if (this.owner != null) {\n  //    if (!(this.owner == null || this.owner.getNodes().indexOf(this) > -1)) {\n  //      throw \"assert failed\";\n  //    }\n  //  }\n\n  return this.owner;\n};\n\nLNode.prototype.getWidth = function () {\n  return this.rect.width;\n};\n\nLNode.prototype.setWidth = function (width) {\n  this.rect.width = width;\n};\n\nLNode.prototype.getHeight = function () {\n  return this.rect.height;\n};\n\nLNode.prototype.setHeight = function (height) {\n  this.rect.height = height;\n};\n\nLNode.prototype.getCenterX = function () {\n  return this.rect.x + this.rect.width / 2;\n};\n\nLNode.prototype.getCenterY = function () {\n  return this.rect.y + this.rect.height / 2;\n};\n\nLNode.prototype.getCenter = function () {\n  return new PointD(this.rect.x + this.rect.width / 2, this.rect.y + this.rect.height / 2);\n};\n\nLNode.prototype.getLocation = function () {\n  return new PointD(this.rect.x, this.rect.y);\n};\n\nLNode.prototype.getRect = function () {\n  return this.rect;\n};\n\nLNode.prototype.getDiagonal = function () {\n  return Math.sqrt(this.rect.width * this.rect.width + this.rect.height * this.rect.height);\n};\n\nLNode.prototype.setRect = function (upperLeft, dimension) {\n  this.rect.x = upperLeft.x;\n  this.rect.y = upperLeft.y;\n  this.rect.width = dimension.width;\n  this.rect.height = dimension.height;\n};\n\nLNode.prototype.setCenter = function (cx, cy) {\n  this.rect.x = cx - this.rect.width / 2;\n  this.rect.y = cy - this.rect.height / 2;\n};\n\nLNode.prototype.setLocation = function (x, y) {\n  this.rect.x = x;\n  this.rect.y = y;\n};\n\nLNode.prototype.moveBy = function (dx, dy) {\n  this.rect.x += dx;\n  this.rect.y += dy;\n};\n\nLNode.prototype.getEdgeListToNode = function (to) {\n  var edgeList = [];\n  var edge;\n  var self = this;\n\n  self.edges.forEach(function (edge) {\n\n    if (edge.target == to) {\n      if (edge.source != self) throw \"Incorrect edge source!\";\n\n      edgeList.push(edge);\n    }\n  });\n\n  return edgeList;\n};\n\nLNode.prototype.getEdgesBetween = function (other) {\n  var edgeList = [];\n  var edge;\n\n  var self = this;\n  self.edges.forEach(function (edge) {\n\n    if (!(edge.source == self || edge.target == self)) throw \"Incorrect edge source and/or target\";\n\n    if (edge.target == other || edge.source == other) {\n      edgeList.push(edge);\n    }\n  });\n\n  return edgeList;\n};\n\nLNode.prototype.getNeighborsList = function () {\n  var neighbors = new HashSet();\n  var edge;\n\n  var self = this;\n  self.edges.forEach(function (edge) {\n\n    if (edge.source == self) {\n      neighbors.add(edge.target);\n    } else {\n      if (edge.target != self) {\n        throw \"Incorrect incidency!\";\n      }\n\n      neighbors.add(edge.source);\n    }\n  });\n\n  return neighbors;\n};\n\nLNode.prototype.withChildren = function () {\n  var withNeighborsList = new Set();\n  var childNode;\n  var children;\n\n  withNeighborsList.add(this);\n\n  if (this.child != null) {\n    var nodes = this.child.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      childNode = nodes[i];\n      children = childNode.withChildren();\n      children.forEach(function (node) {\n        withNeighborsList.add(node);\n      });\n    }\n  }\n\n  return withNeighborsList;\n};\n\nLNode.prototype.getNoOfChildren = function () {\n  var noOfChildren = 0;\n  var childNode;\n\n  if (this.child == null) {\n    noOfChildren = 1;\n  } else {\n    var nodes = this.child.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      childNode = nodes[i];\n\n      noOfChildren += childNode.getNoOfChildren();\n    }\n  }\n\n  if (noOfChildren == 0) {\n    noOfChildren = 1;\n  }\n  return noOfChildren;\n};\n\nLNode.prototype.getEstimatedSize = function () {\n  if (this.estimatedSize == Integer.MIN_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.estimatedSize;\n};\n\nLNode.prototype.calcEstimatedSize = function () {\n  if (this.child == null) {\n    return this.estimatedSize = (this.rect.width + this.rect.height) / 2;\n  } else {\n    this.estimatedSize = this.child.calcEstimatedSize();\n    this.rect.width = this.estimatedSize;\n    this.rect.height = this.estimatedSize;\n\n    return this.estimatedSize;\n  }\n};\n\nLNode.prototype.scatter = function () {\n  var randomCenterX;\n  var randomCenterY;\n\n  var minX = -LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  var maxX = LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  randomCenterX = LayoutConstants.WORLD_CENTER_X + RandomSeed.nextDouble() * (maxX - minX) + minX;\n\n  var minY = -LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  var maxY = LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  randomCenterY = LayoutConstants.WORLD_CENTER_Y + RandomSeed.nextDouble() * (maxY - minY) + minY;\n\n  this.rect.x = randomCenterX;\n  this.rect.y = randomCenterY;\n};\n\nLNode.prototype.updateBounds = function () {\n  if (this.getChild() == null) {\n    throw \"assert failed\";\n  }\n  if (this.getChild().getNodes().length != 0) {\n    // wrap the children nodes by re-arranging the boundaries\n    var childGraph = this.getChild();\n    childGraph.updateBounds(true);\n\n    this.rect.x = childGraph.getLeft();\n    this.rect.y = childGraph.getTop();\n\n    this.setWidth(childGraph.getRight() - childGraph.getLeft());\n    this.setHeight(childGraph.getBottom() - childGraph.getTop());\n\n    // Update compound bounds considering its label properties    \n    if (LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS) {\n\n      var width = childGraph.getRight() - childGraph.getLeft();\n      var height = childGraph.getBottom() - childGraph.getTop();\n\n      if (this.labelWidth > width) {\n        this.rect.x -= (this.labelWidth - width) / 2;\n        this.setWidth(this.labelWidth);\n      }\n\n      if (this.labelHeight > height) {\n        if (this.labelPos == \"center\") {\n          this.rect.y -= (this.labelHeight - height) / 2;\n        } else if (this.labelPos == \"top\") {\n          this.rect.y -= this.labelHeight - height;\n        }\n        this.setHeight(this.labelHeight);\n      }\n    }\n  }\n};\n\nLNode.prototype.getInclusionTreeDepth = function () {\n  if (this.inclusionTreeDepth == Integer.MAX_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.inclusionTreeDepth;\n};\n\nLNode.prototype.transform = function (trans) {\n  var left = this.rect.x;\n\n  if (left > LayoutConstants.WORLD_BOUNDARY) {\n    left = LayoutConstants.WORLD_BOUNDARY;\n  } else if (left < -LayoutConstants.WORLD_BOUNDARY) {\n    left = -LayoutConstants.WORLD_BOUNDARY;\n  }\n\n  var top = this.rect.y;\n\n  if (top > LayoutConstants.WORLD_BOUNDARY) {\n    top = LayoutConstants.WORLD_BOUNDARY;\n  } else if (top < -LayoutConstants.WORLD_BOUNDARY) {\n    top = -LayoutConstants.WORLD_BOUNDARY;\n  }\n\n  var leftTop = new PointD(left, top);\n  var vLeftTop = trans.inverseTransformPoint(leftTop);\n\n  this.setLocation(vLeftTop.x, vLeftTop.y);\n};\n\nLNode.prototype.getLeft = function () {\n  return this.rect.x;\n};\n\nLNode.prototype.getRight = function () {\n  return this.rect.x + this.rect.width;\n};\n\nLNode.prototype.getTop = function () {\n  return this.rect.y;\n};\n\nLNode.prototype.getBottom = function () {\n  return this.rect.y + this.rect.height;\n};\n\nLNode.prototype.getParent = function () {\n  if (this.owner == null) {\n    return null;\n  }\n\n  return this.owner.getParent();\n};\n\nmodule.exports = LNode;\n\n/***/ }),\n/* 14 */\n/***/ (function(module, exports) {\n\nfunction RectangleD(x, y, width, height) {\n  this.x = 0;\n  this.y = 0;\n  this.width = 0;\n  this.height = 0;\n\n  if (x != null && y != null && width != null && height != null) {\n    this.x = x;\n    this.y = y;\n    this.width = width;\n    this.height = height;\n  }\n}\n\nRectangleD.prototype.getX = function () {\n  return this.x;\n};\n\nRectangleD.prototype.setX = function (x) {\n  this.x = x;\n};\n\nRectangleD.prototype.getY = function () {\n  return this.y;\n};\n\nRectangleD.prototype.setY = function (y) {\n  this.y = y;\n};\n\nRectangleD.prototype.getWidth = function () {\n  return this.width;\n};\n\nRectangleD.prototype.setWidth = function (width) {\n  this.width = width;\n};\n\nRectangleD.prototype.getHeight = function () {\n  return this.height;\n};\n\nRectangleD.prototype.setHeight = function (height) {\n  this.height = height;\n};\n\nRectangleD.prototype.getRight = function () {\n  return this.x + this.width;\n};\n\nRectangleD.prototype.getBottom = function () {\n  return this.y + this.height;\n};\n\nRectangleD.prototype.intersects = function (a) {\n  if (this.getRight() < a.x) {\n    return false;\n  }\n\n  if (this.getBottom() < a.y) {\n    return false;\n  }\n\n  if (a.getRight() < this.x) {\n    return false;\n  }\n\n  if (a.getBottom() < this.y) {\n    return false;\n  }\n\n  return true;\n};\n\nRectangleD.prototype.getCenterX = function () {\n  return this.x + this.width / 2;\n};\n\nRectangleD.prototype.getMinX = function () {\n  return this.getX();\n};\n\nRectangleD.prototype.getMaxX = function () {\n  return this.getX() + this.width;\n};\n\nRectangleD.prototype.getCenterY = function () {\n  return this.y + this.height / 2;\n};\n\nRectangleD.prototype.getMinY = function () {\n  return this.getY();\n};\n\nRectangleD.prototype.getMaxY = function () {\n  return this.getY() + this.height;\n};\n\nRectangleD.prototype.getWidthHalf = function () {\n  return this.width / 2;\n};\n\nRectangleD.prototype.getHeightHalf = function () {\n  return this.height / 2;\n};\n\nmodule.exports = RectangleD;\n\n/***/ }),\n/* 15 */\n/***/ (function(module, exports) {\n\nfunction RandomSeed() {}\nRandomSeed.seed = 1;\nRandomSeed.x = 0;\n\nRandomSeed.nextDouble = function () {\n  RandomSeed.x = Math.sin(RandomSeed.seed++) * 10000;\n  return RandomSeed.x - Math.floor(RandomSeed.x);\n};\n\nmodule.exports = RandomSeed;\n\n/***/ }),\n/* 16 */\n/***/ (function(module, exports) {\n\nfunction PointD(x, y) {\n  if (x == null && y == null) {\n    this.x = 0;\n    this.y = 0;\n  } else {\n    this.x = x;\n    this.y = y;\n  }\n}\n\nPointD.prototype.getX = function () {\n  return this.x;\n};\n\nPointD.prototype.getY = function () {\n  return this.y;\n};\n\nPointD.prototype.setX = function (x) {\n  this.x = x;\n};\n\nPointD.prototype.setY = function (y) {\n  this.y = y;\n};\n\nPointD.prototype.getDifference = function (pt) {\n  return new DimensionD(this.x - pt.x, this.y - pt.y);\n};\n\nPointD.prototype.getCopy = function () {\n  return new PointD(this.x, this.y);\n};\n\nPointD.prototype.translate = function (dim) {\n  this.x += dim.width;\n  this.y += dim.height;\n  return this;\n};\n\nmodule.exports = PointD;\n\n/***/ }),\n/* 17 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar UniqueIDGeneretor = __webpack_require__(5);\n\nfunction HashSet() {\n  this.set = {};\n}\n;\n\nHashSet.prototype.add = function (obj) {\n  var theId = UniqueIDGeneretor.createID(obj);\n  if (!this.contains(theId)) this.set[theId] = obj;\n};\n\nHashSet.prototype.remove = function (obj) {\n  delete this.set[UniqueIDGeneretor.createID(obj)];\n};\n\nHashSet.prototype.clear = function () {\n  this.set = {};\n};\n\nHashSet.prototype.contains = function (obj) {\n  return this.set[UniqueIDGeneretor.createID(obj)] == obj;\n};\n\nHashSet.prototype.isEmpty = function () {\n  return this.size() === 0;\n};\n\nHashSet.prototype.size = function () {\n  return Object.keys(this.set).length;\n};\n\n//concats this.set to the given list\nHashSet.prototype.addAllTo = function (list) {\n  var keys = Object.keys(this.set);\n  var length = keys.length;\n  for (var i = 0; i < length; i++) {\n    list.push(this.set[keys[i]]);\n  }\n};\n\nHashSet.prototype.size = function () {\n  return Object.keys(this.set).length;\n};\n\nHashSet.prototype.addAll = function (list) {\n  var s = list.length;\n  for (var i = 0; i < s; i++) {\n    var v = list[i];\n    this.add(v);\n  }\n};\n\nmodule.exports = HashSet;\n\n/***/ }),\n/* 18 */\n/***/ (function(module, exports) {\n\n/*\r\n *This class is the javascript implementation of the Point.java class in jdk\r\n */\nfunction Point(x, y, p) {\n  this.x = null;\n  this.y = null;\n  if (x == null && y == null && p == null) {\n    this.x = 0;\n    this.y = 0;\n  } else if (typeof x == 'number' && typeof y == 'number' && p == null) {\n    this.x = x;\n    this.y = y;\n  } else if (x.constructor.name == 'Point' && y == null && p == null) {\n    p = x;\n    this.x = p.x;\n    this.y = p.y;\n  }\n}\n\nPoint.prototype.getX = function () {\n  return this.x;\n};\n\nPoint.prototype.getY = function () {\n  return this.y;\n};\n\nPoint.prototype.getLocation = function () {\n  return new Point(this.x, this.y);\n};\n\nPoint.prototype.setLocation = function (x, y, p) {\n  if (x.constructor.name == 'Point' && y == null && p == null) {\n    p = x;\n    this.setLocation(p.x, p.y);\n  } else if (typeof x == 'number' && typeof y == 'number' && p == null) {\n    //if both parameters are integer just move (x,y) location\n    if (parseInt(x) == x && parseInt(y) == y) {\n      this.move(x, y);\n    } else {\n      this.x = Math.floor(x + 0.5);\n      this.y = Math.floor(y + 0.5);\n    }\n  }\n};\n\nPoint.prototype.move = function (x, y) {\n  this.x = x;\n  this.y = y;\n};\n\nPoint.prototype.translate = function (dx, dy) {\n  this.x += dx;\n  this.y += dy;\n};\n\nPoint.prototype.equals = function (obj) {\n  if (obj.constructor.name == \"Point\") {\n    var pt = obj;\n    return this.x == pt.x && this.y == pt.y;\n  }\n  return this == obj;\n};\n\nPoint.prototype.toString = function () {\n  return new Point().constructor.name + \"[x=\" + this.x + \",y=\" + this.y + \"]\";\n};\n\nmodule.exports = Point;\n\n/***/ }),\n/* 19 */\n/***/ (function(module, exports) {\n\nconst nodeFrom = value => ({ value, next: null, prev: null });\n\nconst add = (prev, node, next, list) => {\n  if (prev !== null) {\n    prev.next = node;\n  } else {\n    list.head = node;\n  }\n\n  if (next !== null) {\n    next.prev = node;\n  } else {\n    list.tail = node;\n  }\n\n  node.prev = prev;\n  node.next = next;\n\n  list.length++;\n\n  return node;\n};\n\nconst remove = (node, list) => {\n  let { prev, next } = node;\n\n  if (prev !== null) {\n    prev.next = next;\n  } else {\n    list.head = next;\n  }\n\n  if (next !== null) {\n    next.prev = prev;\n  } else {\n    list.tail = prev;\n  }\n\n  node.prev = node.next = null;\n\n  list.length--;\n\n  return node;\n};\n\nclass LinkedList {\n  constructor(vals) {\n    this.length = 0;\n    this.head = null;\n    this.tail = null;\n\n    if (vals != null) {\n      vals.forEach(v => this.push(v));\n    }\n  }\n\n  size() {\n    return this.length;\n  }\n\n  insertBefore(val, otherNode) {\n    return add(otherNode.prev, nodeFrom(val), otherNode, this);\n  }\n\n  insertAfter(val, otherNode) {\n    return add(otherNode, nodeFrom(val), otherNode.next, this);\n  }\n\n  insertNodeBefore(newNode, otherNode) {\n    return add(otherNode.prev, newNode, otherNode, this);\n  }\n\n  insertNodeAfter(newNode, otherNode) {\n    return add(otherNode, newNode, otherNode.next, this);\n  }\n\n  push(val) {\n    return add(this.tail, nodeFrom(val), null, this);\n  }\n\n  unshift(val) {\n    return add(null, nodeFrom(val), this.head, this);\n  }\n\n  remove(node) {\n    return remove(node, this);\n  }\n\n  pop() {\n    return remove(this.tail, this).value;\n  }\n\n  popNode() {\n    return remove(this.tail, this);\n  }\n\n  shift() {\n    return remove(this.head, this).value;\n  }\n\n  shiftNode() {\n    return remove(this.head, this);\n  }\n\n  get_object_at(index) {\n    if (index <= this.length()) {\n      var i = 1;\n      var current = this.head;\n      while (i < index) {\n        current = current.next;\n        i++;\n      }\n      return current.value;\n    }\n  }\n\n  set_object_at(index, value) {\n    if (index <= this.length()) {\n      var i = 1;\n      var current = this.head;\n      while (i < index) {\n        current = current.next;\n        i++;\n      }\n      current.value = value;\n    }\n  }\n}\n\nmodule.exports = LinkedList;\n\n/***/ }),\n/* 20 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar PointD = __webpack_require__(16);\n\nfunction Transform(x, y) {\n  this.lworldOrgX = 0.0;\n  this.lworldOrgY = 0.0;\n  this.ldeviceOrgX = 0.0;\n  this.ldeviceOrgY = 0.0;\n  this.lworldExtX = 1.0;\n  this.lworldExtY = 1.0;\n  this.ldeviceExtX = 1.0;\n  this.ldeviceExtY = 1.0;\n}\n\nTransform.prototype.getWorldOrgX = function () {\n  return this.lworldOrgX;\n};\n\nTransform.prototype.setWorldOrgX = function (wox) {\n  this.lworldOrgX = wox;\n};\n\nTransform.prototype.getWorldOrgY = function () {\n  return this.lworldOrgY;\n};\n\nTransform.prototype.setWorldOrgY = function (woy) {\n  this.lworldOrgY = woy;\n};\n\nTransform.prototype.getWorldExtX = function () {\n  return this.lworldExtX;\n};\n\nTransform.prototype.setWorldExtX = function (wex) {\n  this.lworldExtX = wex;\n};\n\nTransform.prototype.getWorldExtY = function () {\n  return this.lworldExtY;\n};\n\nTransform.prototype.setWorldExtY = function (wey) {\n  this.lworldExtY = wey;\n};\n\n/* Device related */\n\nTransform.prototype.getDeviceOrgX = function () {\n  return this.ldeviceOrgX;\n};\n\nTransform.prototype.setDeviceOrgX = function (dox) {\n  this.ldeviceOrgX = dox;\n};\n\nTransform.prototype.getDeviceOrgY = function () {\n  return this.ldeviceOrgY;\n};\n\nTransform.prototype.setDeviceOrgY = function (doy) {\n  this.ldeviceOrgY = doy;\n};\n\nTransform.prototype.getDeviceExtX = function () {\n  return this.ldeviceExtX;\n};\n\nTransform.prototype.setDeviceExtX = function (dex) {\n  this.ldeviceExtX = dex;\n};\n\nTransform.prototype.getDeviceExtY = function () {\n  return this.ldeviceExtY;\n};\n\nTransform.prototype.setDeviceExtY = function (dey) {\n  this.ldeviceExtY = dey;\n};\n\nTransform.prototype.transformX = function (x) {\n  var xDevice = 0.0;\n  var worldExtX = this.lworldExtX;\n  if (worldExtX != 0.0) {\n    xDevice = this.ldeviceOrgX + (x - this.lworldOrgX) * this.ldeviceExtX / worldExtX;\n  }\n\n  return xDevice;\n};\n\nTransform.prototype.transformY = function (y) {\n  var yDevice = 0.0;\n  var worldExtY = this.lworldExtY;\n  if (worldExtY != 0.0) {\n    yDevice = this.ldeviceOrgY + (y - this.lworldOrgY) * this.ldeviceExtY / worldExtY;\n  }\n\n  return yDevice;\n};\n\nTransform.prototype.inverseTransformX = function (x) {\n  var xWorld = 0.0;\n  var deviceExtX = this.ldeviceExtX;\n  if (deviceExtX != 0.0) {\n    xWorld = this.lworldOrgX + (x - this.ldeviceOrgX) * this.lworldExtX / deviceExtX;\n  }\n\n  return xWorld;\n};\n\nTransform.prototype.inverseTransformY = function (y) {\n  var yWorld = 0.0;\n  var deviceExtY = this.ldeviceExtY;\n  if (deviceExtY != 0.0) {\n    yWorld = this.lworldOrgY + (y - this.ldeviceOrgY) * this.lworldExtY / deviceExtY;\n  }\n  return yWorld;\n};\n\nTransform.prototype.inverseTransformPoint = function (inPoint) {\n  var outPoint = new PointD(this.inverseTransformX(inPoint.x), this.inverseTransformY(inPoint.y));\n  return outPoint;\n};\n\nmodule.exports = Transform;\n\n/***/ }),\n/* 21 */\n/***/ (function(module, exports) {\n\nfunction Emitter() {\n  this.listeners = [];\n}\n\nvar p = Emitter.prototype;\n\np.addListener = function (event, callback) {\n  this.listeners.push({\n    event: event,\n    callback: callback\n  });\n};\n\np.removeListener = function (event, callback) {\n  for (var i = this.listeners.length; i >= 0; i--) {\n    var l = this.listeners[i];\n\n    if (l.event === event && l.callback === callback) {\n      this.listeners.splice(i, 1);\n    }\n  }\n};\n\np.emit = function (event, data) {\n  for (var i = 0; i < this.listeners.length; i++) {\n    var l = this.listeners[i];\n\n    if (event === l.event) {\n      l.callback(data);\n    }\n  }\n};\n\nmodule.exports = Emitter;\n\n/***/ }),\n/* 22 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LayoutConstants = __webpack_require__(3);\n\nfunction FDLayoutConstants() {}\n\n//FDLayoutConstants inherits static props in LayoutConstants\nfor (var prop in LayoutConstants) {\n  FDLayoutConstants[prop] = LayoutConstants[prop];\n}\n\nFDLayoutConstants.MAX_ITERATIONS = 2500;\n\nFDLayoutConstants.DEFAULT_EDGE_LENGTH = 50;\nFDLayoutConstants.DEFAULT_SPRING_STRENGTH = 0.45;\nFDLayoutConstants.DEFAULT_REPULSION_STRENGTH = 4500.0;\nFDLayoutConstants.DEFAULT_GRAVITY_STRENGTH = 0.4;\nFDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = 1.0;\nFDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR = 3.8;\nFDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = 1.5;\nFDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION = true;\nFDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION = true;\nFDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = 0.5;\nFDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL = 100.0;\nFDLayoutConstants.MAX_NODE_DISPLACEMENT = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL * 3;\nFDLayoutConstants.MIN_REPULSION_DIST = FDLayoutConstants.DEFAULT_EDGE_LENGTH / 10.0;\nFDLayoutConstants.CONVERGENCE_CHECK_PERIOD = 100;\nFDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = 0.1;\nFDLayoutConstants.MIN_EDGE_LENGTH = 1;\nFDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD = 10;\n\nmodule.exports = FDLayoutConstants;\n\n/***/ }),\n/* 23 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LEdge = __webpack_require__(7);\nvar FDLayoutConstants = __webpack_require__(22);\n\nfunction FDLayoutEdge(source, target, vEdge) {\n  LEdge.call(this, source, target, vEdge);\n  this.idealLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH;\n}\n\nFDLayoutEdge.prototype = Object.create(LEdge.prototype);\n\nfor (var prop in LEdge) {\n  FDLayoutEdge[prop] = LEdge[prop];\n}\n\nmodule.exports = FDLayoutEdge;\n\n/***/ }),\n/* 24 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LNode = __webpack_require__(13);\n\nfunction FDLayoutNode(gm, loc, size, vNode) {\n  // alternative constructor is handled inside LNode\n  LNode.call(this, gm, loc, size, vNode);\n  //Spring, repulsion and gravitational forces acting on this node\n  this.springForceX = 0;\n  this.springForceY = 0;\n  this.repulsionForceX = 0;\n  this.repulsionForceY = 0;\n  this.gravitationForceX = 0;\n  this.gravitationForceY = 0;\n  //Amount by which this node is to be moved in this iteration\n  this.displacementX = 0;\n  this.displacementY = 0;\n\n  //Start and finish grid coordinates that this node is fallen into\n  this.startX = 0;\n  this.finishX = 0;\n  this.startY = 0;\n  this.finishY = 0;\n\n  //Geometric neighbors of this node\n  this.surrounding = [];\n}\n\nFDLayoutNode.prototype = Object.create(LNode.prototype);\n\nfor (var prop in LNode) {\n  FDLayoutNode[prop] = LNode[prop];\n}\n\nFDLayoutNode.prototype.setGridCoordinates = function (_startX, _finishX, _startY, _finishY) {\n  this.startX = _startX;\n  this.finishX = _finishX;\n  this.startY = _startY;\n  this.finishY = _finishY;\n};\n\nmodule.exports = FDLayoutNode;\n\n/***/ }),\n/* 25 */\n/***/ (function(module, exports) {\n\nfunction DimensionD(width, height) {\n  this.width = 0;\n  this.height = 0;\n  if (width !== null && height !== null) {\n    this.height = height;\n    this.width = width;\n  }\n}\n\nDimensionD.prototype.getWidth = function () {\n  return this.width;\n};\n\nDimensionD.prototype.setWidth = function (width) {\n  this.width = width;\n};\n\nDimensionD.prototype.getHeight = function () {\n  return this.height;\n};\n\nDimensionD.prototype.setHeight = function (height) {\n  this.height = height;\n};\n\nmodule.exports = DimensionD;\n\n/***/ }),\n/* 26 */\n/***/ (function(module, exports, __webpack_require__) {\n\nconst LinkedList = __webpack_require__(19);\n\nfunction Quicksort() {}\n\nQuicksort.get_object_at = function (list, i) {\n    if (list instanceof Array) {\n        return list[i];\n    } else if (list instanceof LinkedList) {\n        return list.get_object_at(i);\n    }\n};\n\nQuicksort.set_object_at = function (list, i, value) {\n    if (list instanceof Array) {\n        list[i] = value;\n    } else if (list instanceof LinkedList) {\n        list.set_object_at(i, value);\n    }\n};\n\nQuicksort.quicksort = function (list, comparison_fn) {\n\n    // input must be an instance of LinkedList class or must be an array in order to sort\n    if (!(list instanceof LinkedList || list instanceof Array)) {\n        return;\n    }\n\n    var comparison_function = comparison_fn;\n\n    if (comparison_function === undefined) {\n        comparison_function = Quicksort.compare;\n    }\n    var end_index;\n\n    if (list instanceof LinkedList) {\n        end_index = list.size();\n    } else if (list instanceof Array) {\n        end_index = list.length - 1;\n    }\n\n    // Prevent empty lists or arrays.\n    if (end_index >= 0) {\n        Quicksort.quicksort_between_indices(list, 0, end_index, comparison_function);\n    }\n};\n\nQuicksort.quicksort_between_indices = function (list, low, high, comparison_fn) {\n\n    // input must be an instance of LinkedList class or must be an array in order to sort\n    if (!(list instanceof LinkedList || list instanceof Array)) {\n        return;\n    }\n\n    if (comparison_fn === undefined) {\n        comparison_fn = Quicksort.compare;\n    }\n\n    var i = low;\n    var j = high;\n    var middleIndex = Math.floor((i + j) / 2);\n    var middle = Quicksort.get_object_at(list, middleIndex);\n\n    do {\n\n        while (comparison_fn(Quicksort.get_object_at(list, i), middle)) {\n\n            i++;\n        }\n\n        while (comparison_fn(middle, Quicksort.get_object_at(list, j))) {\n\n            j--;\n        }\n\n        if (i <= j) {\n\n            var temp = Quicksort.get_object_at(list, i);\n            Quicksort.set_object_at(list, i, Quicksort.get_object_at(list, j));\n            Quicksort.set_object_at(list, j, temp);\n            i++;\n            j--;\n        }\n    } while (i <= j);\n\n    if (low < j) {\n\n        Quicksort.quicksort_between_indices(list, low, j, comparison_fn);\n    }\n\n    if (high > i) {\n\n        Quicksort.quicksort_between_indices(list, i, high, comparison_fn);\n    }\n};\n\n// this function must be overriden for sorting different data types(e.g. string, integer etc.)\nQuicksort.compare = function (a, b) {\n    return b > a;\n};\n\nmodule.exports = Quicksort;\n\n/***/ })\n/******/ ]);\n});","var LayoutConstants = require('layout-base').LayoutConstants;\n\nfunction AVSDFConstants(){}\n\n// AVSDFConstants inherits properties in LayoutConstants\nfor(var prop in LayoutConstants){\n    AVSDFConstants[prop] = LayoutConstants[prop];\n}\n\nAVSDFConstants.DEFAULT_NODE_SEPARATION = 60;\n\nmodule.exports = AVSDFConstants;","/**\n * This class implements data and functionality required for AVSDF layout per\n * edge.\n *\n\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LEdge = require('layout-base').LEdge;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFEdge(source, target, vEdge)\n{\n    LEdge.call(this, source,target, vEdge);\n}\n\nAVSDFEdge.prototype = Object.create(LEdge.prototype);\n\nfor (let properties in LEdge)\n{\n    AVSDFEdge[properties] = LEdge[properties];\n}\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// The function getOtherEnd returns the other end of this edge.\nAVSDFEdge.prototype.getOtherEnd = function(node)\n{\n    return LEdge.prototype.getOtherEnd(node);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function checks whether this edge crosses with the input edge. It\n// returns false, if any of the vertices those edges are incident to are not\n// yet placed on the circle.\nAVSDFEdge.prototype.crossesWithEdge = function(otherEdge)\n{\n    let self = this;\n    let sourcePos = self.getSource().getIndex();\n    let targetPos = self.getTarget().getIndex();\n    let otherSourcePos = otherEdge.getSource().getIndex();\n    let otherTargetPos = otherEdge.getTarget().getIndex();\n    \n    // if any of the vertices those two edges are not yet placed\n    if(sourcePos === -1 || targetPos === -1 || otherSourcePos === -1 || otherTargetPos === -1)\n    {\n        return false;\n    }\n\n    let otherSourceDist = otherEdge.getSource().getCircDistWithTheNode(self.getSource());\n    let otherTargetDist = otherEdge.getTarget().getCircDistWithTheNode(self.getSource());\n    let thisTargetDist = self.getTarget().getCircDistWithTheNode(self.getSource());\n\n    if (thisTargetDist < Math.max(otherSourceDist, otherTargetDist) &&\n            thisTargetDist > Math.min(otherSourceDist, otherTargetDist) &&\n                otherTargetDist !== 0 && otherSourceDist !== 0)\n    {\n        return true;\n    }\n\n    return false;\n};\n\n// This function returns 1 if this edge crosses with the input edge, 0\n// otherwise.\nAVSDFEdge.prototype.crossingWithEdge = function(otherEdge)\n{\n    let self = this;\n    let result = self.crossesWithEdge(otherEdge);\n\n    return  result ? 1 : 0;\n};\n\n// This function calculates the total number of crossings of this edge with\n// all the edges given in the input list.\nAVSDFEdge.prototype.calculateTotalCrossingWithList = function(edgeList)\n{\n    let self = this;\n    let totalCrossing = 0;\n\n    edgeList.forEach(\n        (edge) => totalCrossing += self.crossingWithEdge(edge)\n    );\n\n    return totalCrossing;\n};\n\nmodule.exports = AVSDFEdge;","/**\n * This class implements data and functionality required for AVSDF layout per\n * circle.\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LGraph = require('layout-base').LGraph;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFCircle(parent, graphMgr, vObject)\n{\n    LGraph.call(this, parent, graphMgr, vObject);\n    this.inOrder = undefined;\n    this.currentIndex = 0;\n    this.nodeSeparation = undefined;\n    this.stack = [];\n    this.perimeter = 0;\n    this.centerX = 0;\n    this.centerY = 0;\n    this.radius = 0;\n}\n\nAVSDFCircle.prototype = Object.create(LGraph.prototype);\n\nfor(let property in LGraph)\n{\n    AVSDFCircle[property] = LGraph[property];\n}\n\nAVSDFCircle.prototype.initOrdering = function()\n{\n    this.inOrder = [];\n};\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the array in which the nodes of this circle are kept in order.\nAVSDFCircle.prototype.getOrder = function()\n{\n    return this.inOrder;\n};\n\n// This function returns the x-coordinate of the center of this circle.\nAVSDFCircle.prototype.getCenterX = function()\n{\n    return this.centerX;\n};\n\n// This function returns the y-coordinate of the center of this circle.\nAVSDFCircle.prototype.getCenterY = function()\n{\n    return this.centerY;\n};\n\n// This function returns the radius of this circle.\nAVSDFCircle.prototype.getRadius = function()\n{\n    return this.radius;\n};\n\n// This function returns the total number of vertices of this circle.\nAVSDFCircle.prototype.getSize = function()\n{\n    return this.getNodes().length;\n};\n\n// This function calculates and returns the total number of crossings in this\n// circle by adding up the crossing number of individual nodes on it.\nAVSDFCircle.prototype.getTotalCrossingOfCircle = function()\n{\n    let self = this;\n    let crossingNumber = 0;\n    \n    for(let node in self.inOrder)\n    {\n        let nodeCrossing = node.getTotalCrossingOfEdges();\n        if(nodeCrossing === -1)\n        {\n            return -1;\n        }\n        crossingNumber += nodeCrossing;\n    }\n\n    return crossingNumber / 4;\n};\n\n// This function checks whether or not all of the vertices of this circle are\n// assigned an index on the circle.\nAVSDFCircle.prototype.hasFinishedOrdering = function()\n{\n    return this.currentIndex === this.getNodes().length;\n};\n\n// This function returns the node separation of this circle.\nAVSDFCircle.prototype.getNodeSeparation = function()\n{\n    return this.nodeSeparation;\n};\n\n// This function sets the node separation of this circle.\nAVSDFCircle.prototype.setNodeSeparation = function(nodeSeparation)\n{\n    this.nodeSeparation = nodeSeparation;\n};\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function traverses the vertices of this circle and corrects the angle\n// of the vertices with respect to their circle indices.\nAVSDFCircle.prototype.correctAngles = function()\n{\n    let self = this;\n    self.currentIndex = 0;\n\n    self.inOrder.forEach(\n        (node) =>  self.putInOrder(node)\n    );\n};\n\n\n// This function puts the given node on the circle in the current order and\n// sets its angle appropriately.\nAVSDFCircle.prototype.putInOrder = function(node)\n{\n    let self = this;\n\n    let nodes = self.getNodes();\n\n    // Note that id attribute of a node is added before\n    // AVSDFLayout is called\n    let found = false;\n    for(let i = 0; i < nodes.length; i++) {\n        if (nodes[i].id == node.id) {\n            found = true;\n            break;\n        }\n    }\n\n    if(!found)\n    {\n        throw \"The node must be a member of LGraph\";\n    }\n\n    self.inOrder[self.currentIndex] = node;\n    node.setIndex(self.currentIndex);\n\n    if(self.currentIndex === 0)\n    {\n        node.setAngle(0.0);\n    }\n    else\n    {\n        node.setAngle(self.inOrder[self.currentIndex - 1].getAngle() + 2 * Math.PI *\n            (node.getDiagonal() / 2 + self.nodeSeparation +\n                self.inOrder[self.currentIndex - 1].getDiagonal() / 2)\n            / self.perimeter);\n    }\n\n    self.currentIndex++;\n};\n\n// This function returns the next node to be placed on this circle with\n// respect to the AVSDF algorithm.\nAVSDFCircle.prototype.findNodeToPlace = function()\n{\n    let self = this;\n    let sDegreeNode = undefined;\n\n    // Find the smallest degree vertex if the stack is empty\n    if(self.stack.length === 0)\n    {\n        sDegreeNode = self.findUnorderedSmallestDegreeNode();\n    }\n    // Find the first vertex in the stack not yet placed\n    else\n    {\n        let foundUnorderNode = false;\n\n        while (!foundUnorderNode && !(self.stack.length === 0))\n        {\n            sDegreeNode = self.stack.pop();\n            foundUnorderNode = !sDegreeNode.isOrdered();\n        }\n\n        if (!foundUnorderNode)\n        {\n            sDegreeNode = undefined;\n        }\n    }\n\n    // If no unordered vertex is found in the stack, find one\n    // from the remaining ones\n    if(sDegreeNode === undefined)\n    {\n        sDegreeNode = self.findUnorderedSmallestDegreeNode();\n    }\n\n    // Add the unordered neighbors of this node to the stack\n    if( sDegreeNode !== undefined)\n    {\n        let neighbors = sDegreeNode.getNeighborsSortedByDegree();\n\n        for(let i = neighbors.length - 1; i >= 0 ; i--)\n        {\n            let neighbor = neighbors[i];\n\n            if(!neighbor.isOrdered()) // Check here for possible error\n            {\n                self.stack.push(neighbor);\n            }\n        }\n    }\n\n    return sDegreeNode;\n};\n\n// This function calculates the radius of this circle with respect to the sizes\n// of the vertices and the node separation parameter.\nAVSDFCircle.prototype.calculateRadius = function()\n{\n    let self = this;\n    let totalDiagonal = 0;\n\n    self.getNodes().forEach(\n        (node) => totalDiagonal += Math.sqrt(node.getWidth() * node.getWidth() + node.getHeight() * node.getHeight())\n    );\n\n    self.perimeter = totalDiagonal + self.getNodes().length * self.nodeSeparation;\n    let radius = self.perimeter / ( 2 * Math.PI);\n\n    // Check here for possible error\n\n    self.getParent().setWidth( 2 * radius );\n    self.getParent().setHeight( 2 * radius );\n    self.getParent().setCenter( self.getParent().getWidth(), self.getParent().getHeight() );\n\n    self.centerX = self.getParent().getCenterX();\n    self.centerY = self.getParent().getCenterY();\n    self.radius = self.getParent().getHeight() / 2;\n};\n\n// This function calculates the total number of crossings of all vertices of\n// this circle.\nAVSDFCircle.prototype.calculateEdgeCrossingsOfNodes = function()\n{\n    this.getNodes().forEach( (node) => node.calculateTotalCrossing());\n};\n\n\n// This function sets the index of each vertex to its position in inOrder\n// array. Note that index of a node can be different from its place in the\n// array due to crossing reduction phase of the AVSDF algorithm. It loads\n// old index values to vertices due to an increase in the number of\n// crossings with the new indices.\nAVSDFCircle.prototype.loadOldIndicesOfNodes = function()\n{\n    //this.inOrder.forEach( (node,index) => node.setIndex(index));\n    var self = this;\n    for (let i = 0; i < this.inOrder.length; i++){\n        self.inOrder[i].setIndex(i);\n    }\n};\n\n// This function sets the position of each node in inOrder array to its index.\n// Note that index of a node can be different from its place in the inOrder\n// array due to crossing reduction phase of the AVSDF algorithm. This function\n// puts the nodes to their new index values in inOrder array due to a\n// decrease in the number of crossings with the new indices.\nAVSDFCircle.prototype.reOrderVertices = function()\n{\n    var self = this;\n    this.getNodes().forEach( (node) => self.inOrder[node.getIndex()] = node );\n};\n\n\n// This function finds and returns the unordered smallest degree vertex on\n// this circle.\nAVSDFCircle.prototype.findUnorderedSmallestDegreeNode = function()\n{\n    let minDegree = Number.MAX_SAFE_INTEGER;\n    let sDegreeNode;\n    \n    this.getNodes().forEach(\n        function(node){\n            if(node.getDegree() < minDegree && !node.isOrdered())\n            {\n                minDegree = node.getDegree();\n                sDegreeNode = node;\n            }\n        }\n    );\n\n    return sDegreeNode;\n};\n\n\nmodule.exports = AVSDFCircle;","/**\n * This class implements the overall layout process for the AVSDF algorithm\n * (Circular Drawing Algorithm by He and Sykora).\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet Layout = require('layout-base').Layout;\nlet AVSDFConstants = require('./AVSDFConstants.js');\nlet AVSDFCircle = require('./AVSDFCircle.js');\nlet AVSDFNode = require('./AVSDFNode.js');\nlet AVSDFEdge = require('./AVSDFEdge.js');\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\n// Constructor\nfunction AVSDFLayout()\n{\n    Layout.call(this);\n    this.nodeSeparation = AVSDFConstants.DEFAULT_NODE_SEPARATION;\n}\n\nAVSDFLayout.prototype = Object.create(Layout.prototype);\n\nfor (let property in Layout)\n{\n    AVSDFLayout[property] = Layout[property];\n}\n\nAVSDFLayout.prototype.newGraph = function (vObject)\n{\n    this.avsdfCircle = new AVSDFCircle(null, this.graphManager, vObject);\n\n    return this.avsdfCircle;\n};\n\nAVSDFLayout.prototype.newNode = function (vNode)\n{\n    return new AVSDFNode(this.graphManager, vNode);\n};\n\nAVSDFLayout.prototype.newEdge = function (vEdge)\n{\n    return new AVSDFEdge(null, null, vEdge);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the position data for all nodes\nAVSDFLayout.prototype.getPositionsData = function()\n{\n    var allNodes = this.graphManager.getAllNodes();\n    var pData = {};\n\n    for (var i = 0; i < allNodes.length; i++)\n    {\n        var rect = allNodes[i].rect;\n        var id = allNodes[i].id;\n\n        pData[id] = {\n            id: id,\n            x: rect.getCenterX(),\n            y: rect.getCenterY(),\n            w: rect.width,\n            h: rect.height\n        };\n    }\n\n    return pData;\n};\n\n// -----------------------------------------------------------------------------\n// Section: Layout Related\n// -----------------------------------------------------------------------------\n\n/**\n * This function performs layout on constructed l-level graph.\n * It returns true on success, false otherwise.\n * Important!: If you want to see the results of this function then, after this function is called, you have to calculate\n * and set the positions of every node. To do this call updateNodeCoordinates. However, updateNodeAngles on the other\n * hand is not needed (redundant) for this function.\n */\nAVSDFLayout.prototype.layout = function ()\n{\n    let self = this;\n\n    // Check if graph contains any compound structures\n    if (self.graphManager.getGraphs().length > 1)\n    {\n        return false;\n    }\n\n    let clusterGraph = this.avsdfCircle; // Fixed reference, but now it is a bit redundant\n\n    clusterGraph.setNodeSeparation(this.nodeSeparation);\n    clusterGraph.calculateRadius();\n    clusterGraph.initOrdering();\n\n    while (!clusterGraph.hasFinishedOrdering())\n    {\n        let node = clusterGraph.findNodeToPlace();\n        clusterGraph.putInOrder(node);\n    }\n\n    return true;\n};\n\n// This function updates the angle (in radians) property of AVSDFNode elements in the circle\nAVSDFLayout.prototype.updateNodeAngles = function (){\n    this.graphManager.getRoot().correctAngles(); //AVSDFCircle object\n};\n\n// This function traverses the vertices of the graph and sets their correct coordinates with respect to the owner circle.\nAVSDFLayout.prototype.updateNodeCoordinates = function (){\n    let clusterGraph = this.graphManager.getRoot();\n\n    clusterGraph.getNodes().forEach(function(node) {\n        node.setCenter(clusterGraph.getCenterX() + clusterGraph.getRadius() * Math.cos(node.getAngle()), clusterGraph.getCenterY() +\n            clusterGraph.getRadius() * Math.sin(node.getAngle()));\n    });\n};\n\n// -----------------------------------------------------------------------------\n// Section: Post Processing\n// -----------------------------------------------------------------------------\n\n/**\n * This method implements the post processing step of the algorithm, which\n * tries to minimize the number of edges further with respect to the local\n * adjusting algorithm described by He and Sykora.\n */\nAVSDFLayout.prototype.initPostProcess = function ()\n{\n    this.avsdfCircle.calculateEdgeCrossingsOfNodes();\n\n    let list = this.avsdfCircle.getNodes();\n\n    list.sort(function(a,b){\n        return b.getTotalCrossingOfEdges() - a.getTotalCrossingOfEdges();\n    });\n\n    return list;\n};\n\nAVSDFLayout.prototype.oneStepPostProcess = function (node)\n{\n    let self = this;\n\n    let currentCrossingNumber = node.getTotalCrossingOfEdges();\n    let newCrossingNumber;\n\n    let neighbours = [];\n    node.getNeighborsList().addAllTo(neighbours);\n\n    for (let j = 0; j < neighbours.length; j++)\n    {\n        let neighbour = neighbours[j];\n\n        let oldIndex = node.getIndex();\n        let newIndex = (neighbour.getIndex() + 1) % self.avsdfCircle.getSize();\n\n        if (oldIndex !== newIndex)\n        {\n            node.setIndex(newIndex);\n\n            if (oldIndex < node.getIndex())\n            {\n                oldIndex += self.avsdfCircle.getSize();\n            }\n\n            let index = node.getIndex();\n\n            while (index < oldIndex)\n            {\n                let temp = self.avsdfCircle.getOrder()[index % self.avsdfCircle.getSize()];\n                temp.setIndex((temp.getIndex() + 1) % self.avsdfCircle.getSize());\n                index += 1;\n            }\n\n            node.calculateTotalCrossing();\n            newCrossingNumber = node.getTotalCrossingOfEdges();\n\n            if (newCrossingNumber >= currentCrossingNumber)\n            {\n                self.avsdfCircle.loadOldIndicesOfNodes();\n            }\n            else\n            {\n                self.avsdfCircle.reOrderVertices();\n                currentCrossingNumber = newCrossingNumber;\n            }\n        }\n    }\n};\n\nmodule.exports = AVSDFLayout;","/**\n * This class implements data and functionality required for AVSDF layout per\n * node.\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LNode = require('layout-base').LNode;\nlet Quicksort = require('layout-base').Quicksort;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFNode(gm, vNode, loc, size)\n{\n    // Constructor 1: AVSDFNode(gm, vNode, loc, size)\n    if(loc !== undefined && size !== undefined)\n    {\n        LNode.call(this, gm, vNode, loc, size);\n    }\n    // Constructor 2: AVSDFNode(gm, vNode)\n    else\n    {\n        LNode.call(this, gm, vNode);\n    }\n\n\t// Angle of this node on the owner circle in radians\n    this.angle = 0;\n\n    // Index of this node on the owner circle\n    this.circleIndex = -1;\n\n    // Total number of crossings of the edges this node is incident to\n    this.totalCrossingOfEdges = -1;\n\n    // Whether the current edge crossing number is valid or it needs to be\n    // recalculated\n    this.isCrossingNumberValid = false;\n\n}\n\nAVSDFNode.prototype = Object.create(LNode.prototype);\nfor (let properties in LNode)\n{\n    AVSDFNode[properties] = LNode[properties];\n}\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the circle this node is owned by.\nAVSDFNode.prototype.getCircle = function()\n{\n    return this.getOwner();\n};\n\n// This function sets the index of this node on the circle, and sets the\n// crossing number invalid. Due to the index change of the node; it needs to\n// be recalculated.\nAVSDFNode.prototype.setIndex = function(index)\n{\n    this.circleIndex = index;\n    this.isCrossingNumberValid = false;\n};\n\n// This function returns the index of this node in the ordering of its owner\n// circle. Here -1 means that the vertex is not yet placed on its owner\n//circle.\nAVSDFNode.prototype.getIndex = function()\n{\n    return this.circleIndex;\n};\n\n// This function returns the array of the neigbors of this node sorted in\n// ascending order.\nAVSDFNode.prototype.getNeighborsSortedByDegree = function()\n{\n    let  self = this;\n\n    let neighborsList = [];\n    self.getNeighborsList().addAllTo(neighborsList);\n    let result = neighborsList.filter( node => ( node.getIndex() === -1 ) );\n\n    result.sort(function(a,b){\n        return a.getDegree() - b.getDegree();\n    });\n\n    return result;\n};\n\n// This function returns the degree of this node.\nAVSDFNode.prototype.getDegree = function()\n{\n    return this.getEdges().length;\n};\n\n// This function returns whether or not this node is currently placed on its\n// owner circle.\nAVSDFNode.prototype.isOrdered =  function()\n{\n    return (this.getIndex() > -1);\n};\n\n// This function sets the angle of this node w.r.t. its owner circle. Here\n// the angle value is in radian.\nAVSDFNode.prototype.setAngle = function(angle)\n{\n    this.angle = angle;\n};\n\n// This function returns the angle of this node w.r.t. its owner circle. Here\n// the angle value is in radian.\nAVSDFNode.prototype.getAngle = function()\n{\n    return this.angle;\n};\n\n// This function returns the index difference of this node with the input\n// node. Note that the index difference cannot be negative if both nodes are\n// placed on the circle. Here -1 means at least one of the nodes are not yet\n// placed on the circle.\nAVSDFNode.prototype.getCircDistWithTheNode =  function(refNode)\n{\n    let self = this;\n    let otherIndex = refNode.getIndex();\n    \n    if(otherIndex === -1 || self.getIndex() === -1)\n    {\n        return -1;\n    }\n\n    let diff = self.getIndex() - otherIndex;\n\n    if(diff < 0)\n    {\n        diff += self.getCircle().getSize();\n    }\n\n    return diff;\n};\n\n// This function finds the number of edge crossings between the edges of\n// this node and the edges of the input one.\nAVSDFNode.prototype.getCrossingNumberWithNode =  function(otherNode)\n{\n    let self = this;\n    let totalCrossing = 0;\n\n    self.getEdges().forEach(\n        function(edge)\n        {\n            otherNode.getEdges().forEach(\n                function(otherEdge)\n                {\n                    totalCrossing += edge.crossingWithEdge(otherEdge);\n                }\n            );\n        }\n    );\n\n    return totalCrossing;\n};\n\n// This function returns the total number of edge crossings. If the previously\n// calculated value is not valid due to an index change on the circle, then\n// a recalculation is performed.\nAVSDFNode.prototype.getTotalCrossingOfEdges = function()\n{\n    let self = this;\n    \n    if(!self.isCrossingNumberValid)\n    {\n        self.calculateTotalCrossing();\n        self.isCrossingNumberValid = true;\n\n    }\n\n    return self.totalCrossingOfEdges;\n};\n\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function calculates the total number of crossings the edges of this\n// node cause.\nAVSDFNode.prototype.calculateTotalCrossing = function()\n{\n    let self = this;\n    let temp_crossing_count = 0;\n    let temp_edge_list = [];\n    temp_edge_list.push.apply(temp_edge_list, self.getCircle().getEdges());\n    temp_edge_list = temp_edge_list.filter( (ele) => self.getEdges().indexOf(ele) < 0);\n\n    self.getEdges().forEach(\n        (edge) => temp_crossing_count += edge.calculateTotalCrossingWithList(temp_edge_list)\n    );\n\n    self.totalCrossingOfEdges = temp_crossing_count;\n};\n\nmodule.exports = AVSDFNode;"],"sourceRoot":""} +module.exports = __WEBPACK_EXTERNAL_MODULE_0__; /***/ }), /* 1 */ @@ -5045,23 +282,20 @@ var AVSDF = function (_ContinuousLayout) { }, { key: 'tick', value: function tick() { + var _this2 = this; + var state = this.state; + var self = this; // This function is used for getting coordinates from AVSDF elements and passing it to cytoscape var positions = this.avsdfLayout.getPositionsData(); - var getPositions = function getPositions(ele, i) { - if (typeof ele === "number") { - ele = i; - } - - var lNode = positions[ele.data('id')]; + state.nodes.forEach(function (n) { + var s = _this2.getScratch(n); - return { - x: lNode.x, - y: lNode.y - }; - }; - this.options.eles.nodes().layoutPositions(this, this.options, getPositions); + // example : put node at random position + s.x = positions[n.data('id')].x; + s.y = positions[n.data('id')].y; + }); if (state.tickIndex >= state.nodes.size()) return true; @@ -5152,6 +386,7 @@ module.exports = AVSDF; module.exports = Object.freeze({ animate: true, // whether to show the layout as it's running; special 'end' value makes the layout animate like a discrete layout refresh: 10, // number of ticks per frame; higher is faster but more jerky + maxIterations: 1000, // max iterations before the layout will bail out ungrabifyWhileSimulating: false, // so you can't drag nodes during layout fit: true, // on every layout reposition of nodes, fit the viewport padding: 30, // padding around the simulation @@ -5180,8 +415,8 @@ var _createClass = function () { function defineProperties(target, props) { for function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } /** -A generic continuous layout class -*/ + A generic continuous layout class + */ var assign = __webpack_require__(1); var defaults = __webpack_require__(5); @@ -5195,9 +430,9 @@ var _require = __webpack_require__(8), var _require2 = __webpack_require__(9), multitick = _require2.multitick; -var ContinuousLayout = function () { - function ContinuousLayout(options) { - _classCallCheck(this, ContinuousLayout); +var Layout = function () { + function Layout(options) { + _classCallCheck(this, Layout); var o = this.options = assign({}, defaults, options); @@ -5213,7 +448,7 @@ var ContinuousLayout = function () { s.animateContinuously = o.animate && !s.animateEnd; } - _createClass(ContinuousLayout, [{ + _createClass(Layout, [{ key: 'getScratch', value: function getScratch(el) { var name = this.state.name; @@ -5235,7 +470,7 @@ var ContinuousLayout = function () { s.tickIndex = 0; s.firstUpdate = true; - + s.startTime = Date.now(); s.running = true; s.currentBoundingBox = makeBoundingBox(s.boundingBox, s.cy); @@ -5343,8 +578,6 @@ var ContinuousLayout = function () { l.emit('layoutstop'); }; - s.startTime = Date.now(); - l.emit('layoutstart'); s.nodes.forEach(function (n) { @@ -5354,10 +587,20 @@ var ContinuousLayout = function () { _frame(); // kick off } else { - multitick(s); + var done = false; + var _onNotDone = function _onNotDone() {}; + var _onDone2 = function _onDone2() { + return done = true; + }; + + while (!done) { + multitick(s, _onNotDone, _onDone2); + } s.eles.layoutPositions(this, s, function (node) { - return getNodePositionData(node, s); + var pd = getNodePositionData(node, s); + + return { x: pd.x, y: pd.y }; }); } @@ -5388,10 +631,10 @@ var ContinuousLayout = function () { } }]); - return ContinuousLayout; + return Layout; }(); -module.exports = ContinuousLayout; +module.exports = Layout; /***/ }), /* 7 */ @@ -5497,7 +740,7 @@ var tick = function tick(state) { s.tickIndex++; - var duration = s.startTime - Date.now(); + var duration = Date.now() - s.startTime; return !s.infinite && tickIndicatesDone; }; @@ -5528,5 +771,4 @@ module.exports = { tick: tick, multitick: multitick }; /***/ }) /******/ ]); -}); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 1628472d8d92f903fc4d","webpack:///./~/avsdf-base/avsdf-base.js","webpack:///./src/assign.js","webpack:///./src/layout/index.js","webpack:///./src/index.js","webpack:///./src/layout/AVSDF.js","webpack:///./src/layout/continuous-base/defaults.js","webpack:///./src/layout/continuous-base/index.js","webpack:///./src/layout/continuous-base/make-bb.js","webpack:///./src/layout/continuous-base/position.js","webpack:///./src/layout/continuous-base/tick.js"],"names":["module","exports","Object","assign","bind","tgt","srcs","forEach","keys","src","k","require","impl","register","cytoscape","AVSDFLayout","AVSDFNode","AVSDFConstants","PointD","layoutBase","DimensionD","ContinuousLayout","isFn","fn","optFn","opt","ele","defaults","ready","stop","refresh","fit","padding","randomize","animate","animationDuration","nodeSeparation","AVSDF","options","DEFAULT_NODE_SEPARATION","state","avsdfLayout","graphManager","newGraphManager","root","addRoot","nodes","edges","idToLNode","processChildrenList","i","length","edge","sourceNode","data","targetNode","getEdgesBetween","e1","add","newEdge","id","layout","updateNodeCoordinates","sortedByDegreeList","initPostProcess","positions","getPositionsData","getPositions","lNode","x","y","eles","layoutPositions","tickIndex","size","oneStepPostProcess","updateNodeAngles","parent","children","theChild","theNode","dimensions","layoutDimensions","nodeDimensionsIncludeLabels","outerWidth","outerHeight","position","w","h","parseFloat","paddingLeft","parseInt","css","paddingTop","paddingRight","paddingBottom","isNaN","rect","freeze","ungrabifyWhileSimulating","boundingBox","undefined","infinite","makeBoundingBox","setInitialPositionState","refreshPositions","getNodePositionData","multitick","o","s","firstUpdate","animateEnd","animateContinuously","el","name","scratch","l","running","currentBoundingBox","cy","one","n","prerun","ungrabify","grabbable","node","regrabify","grabify","updateGrabState","grabbed","onGrab","target","onFree","onDrag","p","tp","listenToGrab","on","unlistenToGrab","removeListener","onNotDone","requestAnimationFrame","frame","onDone","emit","startTime","Date","now","postrun","bb","x1","y1","width","height","x2","y2","Math","round","random","locked","nop","tick","tickIndicatesDone","duration","done"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA,mDAA2C,cAAc;;AAEzD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAK;AACL;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;AAEA;AACA;;;;;;;AChEA;AACA,IAAI,IAAyD;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,oCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,gCAAgC;AAClF;AACA;AACA;AACA;AACA;AACA;AACA,gEAAgE,kBAAkB;AAClF;AACA,yDAAyD,cAAc;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,iCAAiC;AAClF,wHAAwH,mBAAmB,EAAE;AAC7I;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,0BAA0B,EAAE;AAC/D,yCAAyC,eAAe;AACxD;AACA;AACA;AACA;AACA;AACA,8DAA8D,+DAA+D;AAC7H;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;;;AAGA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA,CAAC;AACD,oCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,gCAAgC;AAClF;AACA;AACA;AACA;AACA;AACA;AACA,gEAAgE,kBAAkB;AAClF;AACA,yDAAyD,cAAc;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,iCAAiC;AAClF,wHAAwH,mBAAmB,EAAE;AAC7I;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,0BAA0B,EAAE;AAC/D,yCAAyC,eAAe;AACxD;AACA;AACA;AACA;AACA;AACA,8DAA8D,+DAA+D;AAC7H;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,qBAAqB;AACtC;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,eAAe,mBAAmB;AAClC;AACA;AACA;AACA;AACA,GAAG;AACH,eAAe,mBAAmB;AAClC;;AAEA,qBAAqB,mBAAmB;AACxC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,qBAAqB;AACtC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,iBAAiB,WAAW;AAC5B;AACA;;AAEA,iBAAiB,WAAW;AAC5B,mBAAmB,WAAW;AAC9B;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,sBAAsB,cAAc;AACpC,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,aAAa,mBAAmB;AAChC;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,uBAAuB;AACzD,oCAAoC,uBAAuB;AAC3D;AACA,yBAAyB,uBAAuB;AAChD;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,aAAa,8BAA8B;AAC3C;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,qBAAqB;AACxC;AACA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,qBAAqB,kBAAkB;AACvC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,qBAAqB,kBAAkB;AACvC;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA,mBAAmB,kBAAkB;AACrC;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,iBAAiB,qBAAqB;AACtC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,qBAAqB,0BAA0B;AAC/C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,iBAAiB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,iBAAiB,4BAA4B;AAC7C;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,iBAAiB,kBAAkB;AACnC;;AAEA;AACA;;AAEA,qBAAqB,iBAAiB;AACtC;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,iBAAiB;AAClC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,mBAAmB,iBAAiB;AACpC;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA,mCAAmC;AACnC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,6BAA6B;AAC7B;;AAEA;AACA;AACA,yBAAyB,KAAK;;AAE9B;AACA;AACA,yBAAyB,KAAK;;AAE9B;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,OAAO;AAC1B;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,UAAU;AAC7B;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,qGAAqG;AACrG;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA,mBAAmB,kBAAkB;AACrC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB,YAAY;AAC7B;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA,4BAA4B,gCAAgC;;AAE5D;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,OAAO,aAAa;;AAEpB;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA,qCAAqC,QAAQ;AAC7C;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,2BAA2B;AAC5C;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,CAAC;;AAED,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,0CAA0C,QAAQ;AAClD;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,yBAAyB;AAC5C;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,mBAAmB,qBAAqB;AACxC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,wCAAwC;;AAExC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,gDAAgD;AAChD;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,mBAAmB,uBAAuB;AAC1C;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,gEAAgE;AAChE;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,CAAC;AACD,2CAA2C,cAAc,ungO;;;;;;;;;AC3pJzD;;AAEAA,OAAOC,OAAP,GAAiBC,OAAOC,MAAP,IAAiB,IAAjB,GAAwBD,OAAOC,MAAP,CAAcC,IAAd,CAAoBF,MAApB,CAAxB,GAAuD,UAAUG,GAAV,EAAwB;AAAA,oCAANC,IAAM;AAANA,QAAM;AAAA;;AAC9FA,OAAKC,OAAL,CAAc,eAAO;AACnBL,WAAOM,IAAP,CAAaC,GAAb,EAAmBF,OAAnB,CAA4B;AAAA,aAAKF,IAAIK,CAAJ,IAASD,IAAIC,CAAJ,CAAd;AAAA,KAA5B;AACD,GAFD;;AAIA,SAAOL,GAAP;AACD,CAND,C;;;;;;;;;ACFA;;;;;;;;;;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","file":"cytoscape-avsdf.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"cytoscapeAvsdf\"] = factory();\n\telse\n\t\troot[\"cytoscapeAvsdf\"] = factory();\n})(this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 3);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 1628472d8d92f903fc4d","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"avsdfBase\"] = factory();\n\telse\n\t\troot[\"avsdfBase\"] = factory();\n})(window, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nlet avsdfBase = {};\n\navsdfBase.layoutBase = __webpack_require__(1);\navsdfBase.AVSDFConstants = __webpack_require__(2);\navsdfBase.AVSDFEdge = __webpack_require__(3);\navsdfBase.AVSDFCircle = __webpack_require__(4);\navsdfBase.AVSDFLayout = __webpack_require__(5);\navsdfBase.AVSDFNode = __webpack_require__(6);\n\nmodule.exports = avsdfBase;\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports, __webpack_require__) {\n\n(function webpackUniversalModuleDefinition(root, factory) {\n\tif(true)\n\t\tmodule.exports = factory();\n\telse {}\n})(window, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nlet layoutBase = function () {\n  return;\n};\n\nlayoutBase.FDLayout = __webpack_require__(1);\nlayoutBase.FDLayoutConstants = __webpack_require__(22);\nlayoutBase.FDLayoutEdge = __webpack_require__(23);\nlayoutBase.FDLayoutNode = __webpack_require__(24);\nlayoutBase.DimensionD = __webpack_require__(25);\nlayoutBase.HashMap = __webpack_require__(4);\nlayoutBase.HashSet = __webpack_require__(17);\nlayoutBase.IGeometry = __webpack_require__(9);\nlayoutBase.IMath = __webpack_require__(10);\nlayoutBase.Integer = __webpack_require__(12);\nlayoutBase.Point = __webpack_require__(18);\nlayoutBase.PointD = __webpack_require__(16);\nlayoutBase.RandomSeed = __webpack_require__(15);\nlayoutBase.RectangleD = __webpack_require__(14);\nlayoutBase.Transform = __webpack_require__(20);\nlayoutBase.UniqueIDGeneretor = __webpack_require__(5);\nlayoutBase.Quicksort = __webpack_require__(26);\nlayoutBase.LinkedList = __webpack_require__(19);\nlayoutBase.LGraphObject = __webpack_require__(8);\nlayoutBase.LGraph = __webpack_require__(11);\nlayoutBase.LEdge = __webpack_require__(7);\nlayoutBase.LGraphManager = __webpack_require__(6);\nlayoutBase.LNode = __webpack_require__(13);\nlayoutBase.Layout = __webpack_require__(2);\nlayoutBase.LayoutConstants = __webpack_require__(3);\n\nmodule.exports = layoutBase;\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar Layout = __webpack_require__(2);\nvar FDLayoutConstants = __webpack_require__(22);\nvar LayoutConstants = __webpack_require__(3);\nvar IGeometry = __webpack_require__(9);\nvar IMath = __webpack_require__(10);\n\nfunction FDLayout() {\n  Layout.call(this);\n\n  this.useSmartIdealEdgeLengthCalculation = FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION;\n  this.idealEdgeLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH;\n  this.springConstant = FDLayoutConstants.DEFAULT_SPRING_STRENGTH;\n  this.repulsionConstant = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH;\n  this.gravityConstant = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH;\n  this.compoundGravityConstant = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH;\n  this.gravityRangeFactor = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR;\n  this.compoundGravityRangeFactor = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR;\n  this.displacementThresholdPerNode = 3.0 * FDLayoutConstants.DEFAULT_EDGE_LENGTH / 100;\n  this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL;\n  this.initialCoolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL;\n  this.totalDisplacement = 0.0;\n  this.oldTotalDisplacement = 0.0;\n  this.maxIterations = FDLayoutConstants.MAX_ITERATIONS;\n}\n\nFDLayout.prototype = Object.create(Layout.prototype);\n\nfor (var prop in Layout) {\n  FDLayout[prop] = Layout[prop];\n}\n\nFDLayout.prototype.initParameters = function () {\n  Layout.prototype.initParameters.call(this, arguments);\n\n  if (this.layoutQuality == LayoutConstants.DRAFT_QUALITY) {\n    this.displacementThresholdPerNode += 0.30;\n    this.maxIterations *= 0.8;\n  } else if (this.layoutQuality == LayoutConstants.PROOF_QUALITY) {\n    this.displacementThresholdPerNode -= 0.30;\n    this.maxIterations *= 1.2;\n  }\n\n  this.totalIterations = 0;\n  this.notAnimatedIterations = 0;\n\n  this.useFRGridVariant = FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION;\n\n  this.grid = [];\n};\n\nFDLayout.prototype.calcIdealEdgeLengths = function () {\n  var edge;\n  var lcaDepth;\n  var source;\n  var target;\n  var sizeOfSourceInLca;\n  var sizeOfTargetInLca;\n\n  var allEdges = this.getGraphManager().getAllEdges();\n  for (var i = 0; i < allEdges.length; i++) {\n    edge = allEdges[i];\n\n    edge.idealLength = this.idealEdgeLength;\n\n    if (edge.isInterGraph) {\n      source = edge.getSource();\n      target = edge.getTarget();\n\n      sizeOfSourceInLca = edge.getSourceInLca().getEstimatedSize();\n      sizeOfTargetInLca = edge.getTargetInLca().getEstimatedSize();\n\n      if (this.useSmartIdealEdgeLengthCalculation) {\n        edge.idealLength += sizeOfSourceInLca + sizeOfTargetInLca - 2 * LayoutConstants.SIMPLE_NODE_SIZE;\n      }\n\n      lcaDepth = edge.getLca().getInclusionTreeDepth();\n\n      edge.idealLength += FDLayoutConstants.DEFAULT_EDGE_LENGTH * FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR * (source.getInclusionTreeDepth() + target.getInclusionTreeDepth() - 2 * lcaDepth);\n    }\n  }\n};\n\nFDLayout.prototype.initSpringEmbedder = function () {\n\n  if (this.incremental) {\n    this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL;\n  } else {\n    this.coolingFactor = 1.0;\n    this.initialCoolingFactor = 1.0;\n    this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT;\n  }\n\n  this.maxIterations = Math.max(this.getAllNodes().length * 5, this.maxIterations);\n\n  this.totalDisplacementThreshold = this.displacementThresholdPerNode * this.getAllNodes().length;\n\n  this.repulsionRange = this.calcRepulsionRange();\n};\n\nFDLayout.prototype.calcSpringForces = function () {\n  var lEdges = this.getAllEdges();\n  var edge;\n\n  for (var i = 0; i < lEdges.length; i++) {\n    edge = lEdges[i];\n\n    this.calcSpringForce(edge, edge.idealLength);\n  }\n};\n\nFDLayout.prototype.calcRepulsionForces = function (gridUpdateAllowed = true, forceToNodeSurroundingUpdate = false) {\n  var i, j;\n  var nodeA, nodeB;\n  var lNodes = this.getAllNodes();\n  var processedNodeSet;\n\n  if (this.useFRGridVariant) {\n    if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed) {\n      this.updateGrid();\n    }\n\n    processedNodeSet = new Set();\n\n    // calculate repulsion forces between each nodes and its surrounding\n    for (i = 0; i < lNodes.length; i++) {\n      nodeA = lNodes[i];\n      this.calculateRepulsionForceOfANode(nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate);\n      processedNodeSet.add(nodeA);\n    }\n  } else {\n    for (i = 0; i < lNodes.length; i++) {\n      nodeA = lNodes[i];\n\n      for (j = i + 1; j < lNodes.length; j++) {\n        nodeB = lNodes[j];\n\n        // If both nodes are not members of the same graph, skip.\n        if (nodeA.getOwner() != nodeB.getOwner()) {\n          continue;\n        }\n\n        this.calcRepulsionForce(nodeA, nodeB);\n      }\n    }\n  }\n};\n\nFDLayout.prototype.calcGravitationalForces = function () {\n  var node;\n  var lNodes = this.getAllNodesToApplyGravitation();\n\n  for (var i = 0; i < lNodes.length; i++) {\n    node = lNodes[i];\n    this.calcGravitationalForce(node);\n  }\n};\n\nFDLayout.prototype.moveNodes = function () {\n  var lNodes = this.getAllNodes();\n  var node;\n\n  for (var i = 0; i < lNodes.length; i++) {\n    node = lNodes[i];\n    node.move();\n  }\n};\n\nFDLayout.prototype.calcSpringForce = function (edge, idealLength) {\n  var sourceNode = edge.getSource();\n  var targetNode = edge.getTarget();\n\n  var length;\n  var springForce;\n  var springForceX;\n  var springForceY;\n\n  // Update edge length\n  if (this.uniformLeafNodeSizes && sourceNode.getChild() == null && targetNode.getChild() == null) {\n    edge.updateLengthSimple();\n  } else {\n    edge.updateLength();\n\n    if (edge.isOverlapingSourceAndTarget) {\n      return;\n    }\n  }\n\n  length = edge.getLength();\n\n  // Calculate spring forces\n  springForce = this.springConstant * (length - idealLength);\n\n  // Project force onto x and y axes\n  springForceX = springForce * (edge.lengthX / length);\n  springForceY = springForce * (edge.lengthY / length);\n\n  // Apply forces on the end nodes\n  sourceNode.springForceX += springForceX;\n  sourceNode.springForceY += springForceY;\n  targetNode.springForceX -= springForceX;\n  targetNode.springForceY -= springForceY;\n};\n\nFDLayout.prototype.calcRepulsionForce = function (nodeA, nodeB) {\n  var rectA = nodeA.getRect();\n  var rectB = nodeB.getRect();\n  var overlapAmount = new Array(2);\n  var clipPoints = new Array(4);\n  var distanceX;\n  var distanceY;\n  var distanceSquared;\n  var distance;\n  var repulsionForce;\n  var repulsionForceX;\n  var repulsionForceY;\n\n  if (rectA.intersects(rectB)) // two nodes overlap\n    {\n      // calculate separation amount in x and y directions\n      IGeometry.calcSeparationAmount(rectA, rectB, overlapAmount, FDLayoutConstants.DEFAULT_EDGE_LENGTH / 2.0);\n\n      repulsionForceX = 2 * overlapAmount[0];\n      repulsionForceY = 2 * overlapAmount[1];\n\n      var childrenConstant = nodeA.noOfChildren * nodeB.noOfChildren / (nodeA.noOfChildren + nodeB.noOfChildren);\n\n      // Apply forces on the two nodes\n      nodeA.repulsionForceX -= childrenConstant * repulsionForceX;\n      nodeA.repulsionForceY -= childrenConstant * repulsionForceY;\n      nodeB.repulsionForceX += childrenConstant * repulsionForceX;\n      nodeB.repulsionForceY += childrenConstant * repulsionForceY;\n    } else // no overlap\n    {\n      // calculate distance\n\n      if (this.uniformLeafNodeSizes && nodeA.getChild() == null && nodeB.getChild() == null) // simply base repulsion on distance of node centers\n        {\n          distanceX = rectB.getCenterX() - rectA.getCenterX();\n          distanceY = rectB.getCenterY() - rectA.getCenterY();\n        } else // use clipping points\n        {\n          IGeometry.getIntersection(rectA, rectB, clipPoints);\n\n          distanceX = clipPoints[2] - clipPoints[0];\n          distanceY = clipPoints[3] - clipPoints[1];\n        }\n\n      // No repulsion range. FR grid variant should take care of this.\n      if (Math.abs(distanceX) < FDLayoutConstants.MIN_REPULSION_DIST) {\n        distanceX = IMath.sign(distanceX) * FDLayoutConstants.MIN_REPULSION_DIST;\n      }\n\n      if (Math.abs(distanceY) < FDLayoutConstants.MIN_REPULSION_DIST) {\n        distanceY = IMath.sign(distanceY) * FDLayoutConstants.MIN_REPULSION_DIST;\n      }\n\n      distanceSquared = distanceX * distanceX + distanceY * distanceY;\n      distance = Math.sqrt(distanceSquared);\n\n      repulsionForce = this.repulsionConstant * nodeA.noOfChildren * nodeB.noOfChildren / distanceSquared;\n\n      // Project force onto x and y axes\n      repulsionForceX = repulsionForce * distanceX / distance;\n      repulsionForceY = repulsionForce * distanceY / distance;\n\n      // Apply forces on the two nodes    \n      nodeA.repulsionForceX -= repulsionForceX;\n      nodeA.repulsionForceY -= repulsionForceY;\n      nodeB.repulsionForceX += repulsionForceX;\n      nodeB.repulsionForceY += repulsionForceY;\n    }\n};\n\nFDLayout.prototype.calcGravitationalForce = function (node) {\n  var ownerGraph;\n  var ownerCenterX;\n  var ownerCenterY;\n  var distanceX;\n  var distanceY;\n  var absDistanceX;\n  var absDistanceY;\n  var estimatedSize;\n  ownerGraph = node.getOwner();\n\n  ownerCenterX = (ownerGraph.getRight() + ownerGraph.getLeft()) / 2;\n  ownerCenterY = (ownerGraph.getTop() + ownerGraph.getBottom()) / 2;\n  distanceX = node.getCenterX() - ownerCenterX;\n  distanceY = node.getCenterY() - ownerCenterY;\n  absDistanceX = Math.abs(distanceX) + node.getWidth() / 2;\n  absDistanceY = Math.abs(distanceY) + node.getHeight() / 2;\n\n  if (node.getOwner() == this.graphManager.getRoot()) // in the root graph\n    {\n      estimatedSize = ownerGraph.getEstimatedSize() * this.gravityRangeFactor;\n\n      if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) {\n        node.gravitationForceX = -this.gravityConstant * distanceX;\n        node.gravitationForceY = -this.gravityConstant * distanceY;\n      }\n    } else // inside a compound\n    {\n      estimatedSize = ownerGraph.getEstimatedSize() * this.compoundGravityRangeFactor;\n\n      if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) {\n        node.gravitationForceX = -this.gravityConstant * distanceX * this.compoundGravityConstant;\n        node.gravitationForceY = -this.gravityConstant * distanceY * this.compoundGravityConstant;\n      }\n    }\n};\n\nFDLayout.prototype.isConverged = function () {\n  var converged;\n  var oscilating = false;\n\n  if (this.totalIterations > this.maxIterations / 3) {\n    oscilating = Math.abs(this.totalDisplacement - this.oldTotalDisplacement) < 2;\n  }\n\n  converged = this.totalDisplacement < this.totalDisplacementThreshold;\n\n  this.oldTotalDisplacement = this.totalDisplacement;\n\n  return converged || oscilating;\n};\n\nFDLayout.prototype.animate = function () {\n  if (this.animationDuringLayout && !this.isSubLayout) {\n    if (this.notAnimatedIterations == this.animationPeriod) {\n      this.update();\n      this.notAnimatedIterations = 0;\n    } else {\n      this.notAnimatedIterations++;\n    }\n  }\n};\n\n//This method calculates the number of children (weight) for all nodes\nFDLayout.prototype.calcNoOfChildrenForAllNodes = function () {\n  var node;\n  var allNodes = this.graphManager.getAllNodes();\n\n  for (var i = 0; i < allNodes.length; i++) {\n    node = allNodes[i];\n    node.noOfChildren = node.getNoOfChildren();\n  }\n};\n\n// -----------------------------------------------------------------------------\n// Section: FR-Grid Variant Repulsion Force Calculation\n// -----------------------------------------------------------------------------\n\nFDLayout.prototype.calcGrid = function (graph) {\n\n  var sizeX = 0;\n  var sizeY = 0;\n\n  sizeX = parseInt(Math.ceil((graph.getRight() - graph.getLeft()) / this.repulsionRange));\n  sizeY = parseInt(Math.ceil((graph.getBottom() - graph.getTop()) / this.repulsionRange));\n\n  var grid = new Array(sizeX);\n\n  for (var i = 0; i < sizeX; i++) {\n    grid[i] = new Array(sizeY);\n  }\n\n  for (var i = 0; i < sizeX; i++) {\n    for (var j = 0; j < sizeY; j++) {\n      grid[i][j] = new Array();\n    }\n  }\n\n  return grid;\n};\n\nFDLayout.prototype.addNodeToGrid = function (v, left, top) {\n\n  var startX = 0;\n  var finishX = 0;\n  var startY = 0;\n  var finishY = 0;\n\n  startX = parseInt(Math.floor((v.getRect().x - left) / this.repulsionRange));\n  finishX = parseInt(Math.floor((v.getRect().width + v.getRect().x - left) / this.repulsionRange));\n  startY = parseInt(Math.floor((v.getRect().y - top) / this.repulsionRange));\n  finishY = parseInt(Math.floor((v.getRect().height + v.getRect().y - top) / this.repulsionRange));\n\n  for (var i = startX; i <= finishX; i++) {\n    for (var j = startY; j <= finishY; j++) {\n      this.grid[i][j].push(v);\n      v.setGridCoordinates(startX, finishX, startY, finishY);\n    }\n  }\n};\n\nFDLayout.prototype.updateGrid = function () {\n  var i;\n  var nodeA;\n  var lNodes = this.getAllNodes();\n\n  this.grid = this.calcGrid(this.graphManager.getRoot());\n\n  // put all nodes to proper grid cells\n  for (i = 0; i < lNodes.length; i++) {\n    nodeA = lNodes[i];\n    this.addNodeToGrid(nodeA, this.graphManager.getRoot().getLeft(), this.graphManager.getRoot().getTop());\n  }\n};\n\nFDLayout.prototype.calculateRepulsionForceOfANode = function (nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate) {\n\n  if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed || forceToNodeSurroundingUpdate) {\n    var surrounding = new Set();\n    nodeA.surrounding = new Array();\n    var nodeB;\n    var grid = this.grid;\n\n    for (var i = nodeA.startX - 1; i < nodeA.finishX + 2; i++) {\n      for (var j = nodeA.startY - 1; j < nodeA.finishY + 2; j++) {\n        if (!(i < 0 || j < 0 || i >= grid.length || j >= grid[0].length)) {\n          for (var k = 0; k < grid[i][j].length; k++) {\n            nodeB = grid[i][j][k];\n\n            // If both nodes are not members of the same graph, \n            // or both nodes are the same, skip.\n            if (nodeA.getOwner() != nodeB.getOwner() || nodeA == nodeB) {\n              continue;\n            }\n\n            // check if the repulsion force between\n            // nodeA and nodeB has already been calculated\n            if (!processedNodeSet.has(nodeB) && !surrounding.has(nodeB)) {\n              var distanceX = Math.abs(nodeA.getCenterX() - nodeB.getCenterX()) - (nodeA.getWidth() / 2 + nodeB.getWidth() / 2);\n              var distanceY = Math.abs(nodeA.getCenterY() - nodeB.getCenterY()) - (nodeA.getHeight() / 2 + nodeB.getHeight() / 2);\n\n              // if the distance between nodeA and nodeB \n              // is less then calculation range\n              if (distanceX <= this.repulsionRange && distanceY <= this.repulsionRange) {\n                //then add nodeB to surrounding of nodeA\n                surrounding.add(nodeB);\n              }\n            }\n          }\n        }\n      }\n    }\n\n    nodeA.surrounding = [...surrounding];\n  }\n  for (i = 0; i < nodeA.surrounding.length; i++) {\n    this.calcRepulsionForce(nodeA, nodeA.surrounding[i]);\n  }\n};\n\nFDLayout.prototype.calcRepulsionRange = function () {\n  return 0.0;\n};\n\nmodule.exports = FDLayout;\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LayoutConstants = __webpack_require__(3);\nvar HashMap = __webpack_require__(4);\nvar LGraphManager = __webpack_require__(6);\nvar LNode = __webpack_require__(13);\nvar LEdge = __webpack_require__(7);\nvar LGraph = __webpack_require__(11);\nvar PointD = __webpack_require__(16);\nvar Transform = __webpack_require__(20);\nvar Emitter = __webpack_require__(21);\nvar HashSet = __webpack_require__(17);\n\nfunction Layout(isRemoteUse) {\n  Emitter.call(this);\n\n  //Layout Quality: 0:proof, 1:default, 2:draft\n  this.layoutQuality = LayoutConstants.DEFAULT_QUALITY;\n  //Whether layout should create bendpoints as needed or not\n  this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED;\n  //Whether layout should be incremental or not\n  this.incremental = LayoutConstants.DEFAULT_INCREMENTAL;\n  //Whether we animate from before to after layout node positions\n  this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT;\n  //Whether we animate the layout process or not\n  this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT;\n  //Number iterations that should be done between two successive animations\n  this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD;\n  /**\r\n   * Whether or not leaf nodes (non-compound nodes) are of uniform sizes. When\r\n   * they are, both spring and repulsion forces between two leaf nodes can be\r\n   * calculated without the expensive clipping point calculations, resulting\r\n   * in major speed-up.\r\n   */\n  this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES;\n  /**\r\n   * This is used for creation of bendpoints by using dummy nodes and edges.\r\n   * Maps an LEdge to its dummy bendpoint path.\r\n   */\n  this.edgeToDummyNodes = new HashMap();\n  this.graphManager = new LGraphManager(this);\n  this.isLayoutFinished = false;\n  this.isSubLayout = false;\n  this.isRemoteUse = false;\n\n  if (isRemoteUse != null) {\n    this.isRemoteUse = isRemoteUse;\n  }\n}\n\nLayout.RANDOM_SEED = 1;\n\nLayout.prototype = Object.create(Emitter.prototype);\n\nLayout.prototype.getGraphManager = function () {\n  return this.graphManager;\n};\n\nLayout.prototype.getAllNodes = function () {\n  return this.graphManager.getAllNodes();\n};\n\nLayout.prototype.getAllEdges = function () {\n  return this.graphManager.getAllEdges();\n};\n\nLayout.prototype.getAllNodesToApplyGravitation = function () {\n  return this.graphManager.getAllNodesToApplyGravitation();\n};\n\nLayout.prototype.newGraphManager = function () {\n  var gm = new LGraphManager(this);\n  this.graphManager = gm;\n  return gm;\n};\n\nLayout.prototype.newGraph = function (vGraph) {\n  return new LGraph(null, this.graphManager, vGraph);\n};\n\nLayout.prototype.newNode = function (vNode) {\n  return new LNode(this.graphManager, vNode);\n};\n\nLayout.prototype.newEdge = function (vEdge) {\n  return new LEdge(null, null, vEdge);\n};\n\nLayout.prototype.checkLayoutSuccess = function () {\n  return this.graphManager.getRoot() == null || this.graphManager.getRoot().getNodes().length == 0 || this.graphManager.includesInvalidEdge();\n};\n\nLayout.prototype.runLayout = function () {\n  this.isLayoutFinished = false;\n\n  if (this.tilingPreLayout) {\n    this.tilingPreLayout();\n  }\n\n  this.initParameters();\n  var isLayoutSuccessfull;\n\n  if (this.checkLayoutSuccess()) {\n    isLayoutSuccessfull = false;\n  } else {\n    isLayoutSuccessfull = this.layout();\n  }\n\n  if (LayoutConstants.ANIMATE === 'during') {\n    // If this is a 'during' layout animation. Layout is not finished yet. \n    // We need to perform these in index.js when layout is really finished.\n    return false;\n  }\n\n  if (isLayoutSuccessfull) {\n    if (!this.isSubLayout) {\n      this.doPostLayout();\n    }\n  }\n\n  if (this.tilingPostLayout) {\n    this.tilingPostLayout();\n  }\n\n  this.isLayoutFinished = true;\n\n  return isLayoutSuccessfull;\n};\n\n/**\r\n * This method performs the operations required after layout.\r\n */\nLayout.prototype.doPostLayout = function () {\n  //assert !isSubLayout : \"Should not be called on sub-layout!\";\n  // Propagate geometric changes to v-level objects\n  if (!this.incremental) {\n    this.transform();\n  }\n  this.update();\n};\n\n/**\r\n * This method updates the geometry of the target graph according to\r\n * calculated layout.\r\n */\nLayout.prototype.update2 = function () {\n  // update bend points\n  if (this.createBendsAsNeeded) {\n    this.createBendpointsFromDummyNodes();\n\n    // reset all edges, since the topology has changed\n    this.graphManager.resetAllEdges();\n  }\n\n  // perform edge, node and root updates if layout is not called\n  // remotely\n  if (!this.isRemoteUse) {\n    // update all edges\n    var edge;\n    var allEdges = this.graphManager.getAllEdges();\n    for (var i = 0; i < allEdges.length; i++) {\n      edge = allEdges[i];\n      //      this.update(edge);\n    }\n\n    // recursively update nodes\n    var node;\n    var nodes = this.graphManager.getRoot().getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      node = nodes[i];\n      //      this.update(node);\n    }\n\n    // update root graph\n    this.update(this.graphManager.getRoot());\n  }\n};\n\nLayout.prototype.update = function (obj) {\n  if (obj == null) {\n    this.update2();\n  } else if (obj instanceof LNode) {\n    var node = obj;\n    if (node.getChild() != null) {\n      // since node is compound, recursively update child nodes\n      var nodes = node.getChild().getNodes();\n      for (var i = 0; i < nodes.length; i++) {\n        update(nodes[i]);\n      }\n    }\n\n    // if the l-level node is associated with a v-level graph object,\n    // then it is assumed that the v-level node implements the\n    // interface Updatable.\n    if (node.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vNode = node.vGraphObject;\n\n      // call the update method of the interface\n      vNode.update(node);\n    }\n  } else if (obj instanceof LEdge) {\n    var edge = obj;\n    // if the l-level edge is associated with a v-level graph object,\n    // then it is assumed that the v-level edge implements the\n    // interface Updatable.\n\n    if (edge.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vEdge = edge.vGraphObject;\n\n      // call the update method of the interface\n      vEdge.update(edge);\n    }\n  } else if (obj instanceof LGraph) {\n    var graph = obj;\n    // if the l-level graph is associated with a v-level graph object,\n    // then it is assumed that the v-level object implements the\n    // interface Updatable.\n\n    if (graph.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vGraph = graph.vGraphObject;\n\n      // call the update method of the interface\n      vGraph.update(graph);\n    }\n  }\n};\n\n/**\r\n * This method is used to set all layout parameters to default values\r\n * determined at compile time.\r\n */\nLayout.prototype.initParameters = function () {\n  if (!this.isSubLayout) {\n    this.layoutQuality = LayoutConstants.DEFAULT_QUALITY;\n    this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT;\n    this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD;\n    this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT;\n    this.incremental = LayoutConstants.DEFAULT_INCREMENTAL;\n    this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED;\n    this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES;\n  }\n\n  if (this.animationDuringLayout) {\n    this.animationOnLayout = false;\n  }\n};\n\nLayout.prototype.transform = function (newLeftTop) {\n  if (newLeftTop == undefined) {\n    this.transform(new PointD(0, 0));\n  } else {\n    // create a transformation object (from Eclipse to layout). When an\n    // inverse transform is applied, we get upper-left coordinate of the\n    // drawing or the root graph at given input coordinate (some margins\n    // already included in calculation of left-top).\n\n    var trans = new Transform();\n    var leftTop = this.graphManager.getRoot().updateLeftTop();\n\n    if (leftTop != null) {\n      trans.setWorldOrgX(newLeftTop.x);\n      trans.setWorldOrgY(newLeftTop.y);\n\n      trans.setDeviceOrgX(leftTop.x);\n      trans.setDeviceOrgY(leftTop.y);\n\n      var nodes = this.getAllNodes();\n      var node;\n\n      for (var i = 0; i < nodes.length; i++) {\n        node = nodes[i];\n        node.transform(trans);\n      }\n    }\n  }\n};\n\nLayout.prototype.positionNodesRandomly = function (graph) {\n\n  if (graph == undefined) {\n    //assert !this.incremental;\n    this.positionNodesRandomly(this.getGraphManager().getRoot());\n    this.getGraphManager().getRoot().updateBounds(true);\n  } else {\n    var lNode;\n    var childGraph;\n\n    var nodes = graph.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      lNode = nodes[i];\n      childGraph = lNode.getChild();\n\n      if (childGraph == null) {\n        lNode.scatter();\n      } else if (childGraph.getNodes().length == 0) {\n        lNode.scatter();\n      } else {\n        this.positionNodesRandomly(childGraph);\n        lNode.updateBounds();\n      }\n    }\n  }\n};\n\n/**\r\n * This method returns a list of trees where each tree is represented as a\r\n * list of l-nodes. The method returns a list of size 0 when:\r\n * - The graph is not flat or\r\n * - One of the component(s) of the graph is not a tree.\r\n */\nLayout.prototype.getFlatForest = function () {\n  var flatForest = [];\n  var isForest = true;\n\n  // Quick reference for all nodes in the graph manager associated with\n  // this layout. The list should not be changed.\n  var allNodes = this.graphManager.getRoot().getNodes();\n\n  // First be sure that the graph is flat\n  var isFlat = true;\n\n  for (var i = 0; i < allNodes.length; i++) {\n    if (allNodes[i].getChild() != null) {\n      isFlat = false;\n    }\n  }\n\n  // Return empty forest if the graph is not flat.\n  if (!isFlat) {\n    return flatForest;\n  }\n\n  // Run BFS for each component of the graph.\n\n  var visited = new HashSet();\n  var toBeVisited = [];\n  var parents = new HashMap();\n  var unProcessedNodes = [];\n\n  unProcessedNodes = unProcessedNodes.concat(allNodes);\n\n  // Each iteration of this loop finds a component of the graph and\n  // decides whether it is a tree or not. If it is a tree, adds it to the\n  // forest and continued with the next component.\n\n  while (unProcessedNodes.length > 0 && isForest) {\n    toBeVisited.push(unProcessedNodes[0]);\n\n    // Start the BFS. Each iteration of this loop visits a node in a\n    // BFS manner.\n    while (toBeVisited.length > 0 && isForest) {\n      //pool operation\n      var currentNode = toBeVisited[0];\n      toBeVisited.splice(0, 1);\n      visited.add(currentNode);\n\n      // Traverse all neighbors of this node\n      var neighborEdges = currentNode.getEdges();\n\n      for (var i = 0; i < neighborEdges.length; i++) {\n        var currentNeighbor = neighborEdges[i].getOtherEnd(currentNode);\n\n        // If BFS is not growing from this neighbor.\n        if (parents.get(currentNode) != currentNeighbor) {\n          // We haven't previously visited this neighbor.\n          if (!visited.contains(currentNeighbor)) {\n            toBeVisited.push(currentNeighbor);\n            parents.put(currentNeighbor, currentNode);\n          }\n          // Since we have previously visited this neighbor and\n          // this neighbor is not parent of currentNode, given\n          // graph contains a component that is not tree, hence\n          // it is not a forest.\n          else {\n              isForest = false;\n              break;\n            }\n        }\n      }\n    }\n\n    // The graph contains a component that is not a tree. Empty\n    // previously found trees. The method will end.\n    if (!isForest) {\n      flatForest = [];\n    }\n    // Save currently visited nodes as a tree in our forest. Reset\n    // visited and parents lists. Continue with the next component of\n    // the graph, if any.\n    else {\n        var temp = [];\n        visited.addAllTo(temp);\n        flatForest.push(temp);\n        //flatForest = flatForest.concat(temp);\n        //unProcessedNodes.removeAll(visited);\n        for (var i = 0; i < temp.length; i++) {\n          var value = temp[i];\n          var index = unProcessedNodes.indexOf(value);\n          if (index > -1) {\n            unProcessedNodes.splice(index, 1);\n          }\n        }\n        visited = new HashSet();\n        parents = new HashMap();\n      }\n  }\n\n  return flatForest;\n};\n\n/**\r\n * This method creates dummy nodes (an l-level node with minimal dimensions)\r\n * for the given edge (one per bendpoint). The existing l-level structure\r\n * is updated accordingly.\r\n */\nLayout.prototype.createDummyNodesForBendpoints = function (edge) {\n  var dummyNodes = [];\n  var prev = edge.source;\n\n  var graph = this.graphManager.calcLowestCommonAncestor(edge.source, edge.target);\n\n  for (var i = 0; i < edge.bendpoints.length; i++) {\n    // create new dummy node\n    var dummyNode = this.newNode(null);\n    dummyNode.setRect(new Point(0, 0), new Dimension(1, 1));\n\n    graph.add(dummyNode);\n\n    // create new dummy edge between prev and dummy node\n    var dummyEdge = this.newEdge(null);\n    this.graphManager.add(dummyEdge, prev, dummyNode);\n\n    dummyNodes.add(dummyNode);\n    prev = dummyNode;\n  }\n\n  var dummyEdge = this.newEdge(null);\n  this.graphManager.add(dummyEdge, prev, edge.target);\n\n  this.edgeToDummyNodes.put(edge, dummyNodes);\n\n  // remove real edge from graph manager if it is inter-graph\n  if (edge.isInterGraph()) {\n    this.graphManager.remove(edge);\n  }\n  // else, remove the edge from the current graph\n  else {\n      graph.remove(edge);\n    }\n\n  return dummyNodes;\n};\n\n/**\r\n * This method creates bendpoints for edges from the dummy nodes\r\n * at l-level.\r\n */\nLayout.prototype.createBendpointsFromDummyNodes = function () {\n  var edges = [];\n  edges = edges.concat(this.graphManager.getAllEdges());\n  edges = this.edgeToDummyNodes.keySet().concat(edges);\n\n  for (var k = 0; k < edges.length; k++) {\n    var lEdge = edges[k];\n\n    if (lEdge.bendpoints.length > 0) {\n      var path = this.edgeToDummyNodes.get(lEdge);\n\n      for (var i = 0; i < path.length; i++) {\n        var dummyNode = path[i];\n        var p = new PointD(dummyNode.getCenterX(), dummyNode.getCenterY());\n\n        // update bendpoint's location according to dummy node\n        var ebp = lEdge.bendpoints.get(i);\n        ebp.x = p.x;\n        ebp.y = p.y;\n\n        // remove the dummy node, dummy edges incident with this\n        // dummy node is also removed (within the remove method)\n        dummyNode.getOwner().remove(dummyNode);\n      }\n\n      // add the real edge to graph\n      this.graphManager.add(lEdge, lEdge.source, lEdge.target);\n    }\n  }\n};\n\nLayout.transform = function (sliderValue, defaultValue, minDiv, maxMul) {\n  if (minDiv != undefined && maxMul != undefined) {\n    var value = defaultValue;\n\n    if (sliderValue <= 50) {\n      var minValue = defaultValue / minDiv;\n      value -= (defaultValue - minValue) / 50 * (50 - sliderValue);\n    } else {\n      var maxValue = defaultValue * maxMul;\n      value += (maxValue - defaultValue) / 50 * (sliderValue - 50);\n    }\n\n    return value;\n  } else {\n    var a, b;\n\n    if (sliderValue <= 50) {\n      a = 9.0 * defaultValue / 500.0;\n      b = defaultValue / 10.0;\n    } else {\n      a = 9.0 * defaultValue / 50.0;\n      b = -8 * defaultValue;\n    }\n\n    return a * sliderValue + b;\n  }\n};\n\n/**\r\n * This method finds and returns the center of the given nodes, assuming\r\n * that the given nodes form a tree in themselves.\r\n */\nLayout.findCenterOfTree = function (nodes) {\n  var list = [];\n  list = list.concat(nodes);\n\n  var removedNodes = [];\n  var remainingDegrees = new HashMap();\n  var foundCenter = false;\n  var centerNode = null;\n\n  if (list.length == 1 || list.length == 2) {\n    foundCenter = true;\n    centerNode = list[0];\n  }\n\n  for (var i = 0; i < list.length; i++) {\n    var node = list[i];\n    var degree = node.getNeighborsList().size();\n    remainingDegrees.put(node, node.getNeighborsList().size());\n\n    if (degree == 1) {\n      removedNodes.push(node);\n    }\n  }\n\n  var tempList = [];\n  tempList = tempList.concat(removedNodes);\n\n  while (!foundCenter) {\n    var tempList2 = [];\n    tempList2 = tempList2.concat(tempList);\n    tempList = [];\n\n    for (var i = 0; i < list.length; i++) {\n      var node = list[i];\n\n      var index = list.indexOf(node);\n      if (index >= 0) {\n        list.splice(index, 1);\n      }\n\n      var neighbours = node.getNeighborsList();\n\n      Object.keys(neighbours.set).forEach(function (j) {\n        var neighbour = neighbours.set[j];\n        if (removedNodes.indexOf(neighbour) < 0) {\n          var otherDegree = remainingDegrees.get(neighbour);\n          var newDegree = otherDegree - 1;\n\n          if (newDegree == 1) {\n            tempList.push(neighbour);\n          }\n\n          remainingDegrees.put(neighbour, newDegree);\n        }\n      });\n    }\n\n    removedNodes = removedNodes.concat(tempList);\n\n    if (list.length == 1 || list.length == 2) {\n      foundCenter = true;\n      centerNode = list[0];\n    }\n  }\n\n  return centerNode;\n};\n\n/**\r\n * During the coarsening process, this layout may be referenced by two graph managers\r\n * this setter function grants access to change the currently being used graph manager\r\n */\nLayout.prototype.setGraphManager = function (gm) {\n  this.graphManager = gm;\n};\n\nmodule.exports = Layout;\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports) {\n\nfunction LayoutConstants() {}\n\n/**\r\n * Layout Quality\r\n */\nLayoutConstants.PROOF_QUALITY = 0;\nLayoutConstants.DEFAULT_QUALITY = 1;\nLayoutConstants.DRAFT_QUALITY = 2;\n\n/**\r\n * Default parameters\r\n */\nLayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED = false;\n//LayoutConstants.DEFAULT_INCREMENTAL = true;\nLayoutConstants.DEFAULT_INCREMENTAL = false;\nLayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT = true;\nLayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT = false;\nLayoutConstants.DEFAULT_ANIMATION_PERIOD = 50;\nLayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES = false;\n\n// -----------------------------------------------------------------------------\n// Section: General other constants\n// -----------------------------------------------------------------------------\n/*\r\n * Margins of a graph to be applied on bouding rectangle of its contents. We\r\n * assume margins on all four sides to be uniform.\r\n */\nLayoutConstants.DEFAULT_GRAPH_MARGIN = 15;\n\n/*\r\n * Whether to consider labels in node dimensions or not\r\n */\nLayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = false;\n\n/*\r\n * Default dimension of a non-compound node.\r\n */\nLayoutConstants.SIMPLE_NODE_SIZE = 40;\n\n/*\r\n * Default dimension of a non-compound node.\r\n */\nLayoutConstants.SIMPLE_NODE_HALF_SIZE = LayoutConstants.SIMPLE_NODE_SIZE / 2;\n\n/*\r\n * Empty compound node size. When a compound node is empty, its both\r\n * dimensions should be of this value.\r\n */\nLayoutConstants.EMPTY_COMPOUND_NODE_SIZE = 40;\n\n/*\r\n * Minimum length that an edge should take during layout\r\n */\nLayoutConstants.MIN_EDGE_LENGTH = 1;\n\n/*\r\n * World boundaries that layout operates on\r\n */\nLayoutConstants.WORLD_BOUNDARY = 1000000;\n\n/*\r\n * World boundaries that random positioning can be performed with\r\n */\nLayoutConstants.INITIAL_WORLD_BOUNDARY = LayoutConstants.WORLD_BOUNDARY / 1000;\n\n/*\r\n * Coordinates of the world center\r\n */\nLayoutConstants.WORLD_CENTER_X = 1200;\nLayoutConstants.WORLD_CENTER_Y = 900;\n\nmodule.exports = LayoutConstants;\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar UniqueIDGeneretor = __webpack_require__(5);\n\nfunction HashMap() {\n  this.map = {};\n  this.keys = [];\n}\n\nHashMap.prototype.put = function (key, value) {\n  var theId = UniqueIDGeneretor.createID(key);\n  if (!this.contains(theId)) {\n    this.map[theId] = value;\n    this.keys.push(key);\n  }\n};\n\nHashMap.prototype.contains = function (key) {\n  var theId = UniqueIDGeneretor.createID(key);\n  return this.map[key] != null;\n};\n\nHashMap.prototype.get = function (key) {\n  var theId = UniqueIDGeneretor.createID(key);\n  return this.map[theId];\n};\n\nHashMap.prototype.keySet = function () {\n  return this.keys;\n};\n\nmodule.exports = HashMap;\n\n/***/ }),\n/* 5 */\n/***/ (function(module, exports) {\n\nfunction UniqueIDGeneretor() {}\n\nUniqueIDGeneretor.lastID = 0;\n\nUniqueIDGeneretor.createID = function (obj) {\n  if (UniqueIDGeneretor.isPrimitive(obj)) {\n    return obj;\n  }\n  if (obj.uniqueID != null) {\n    return obj.uniqueID;\n  }\n  obj.uniqueID = UniqueIDGeneretor.getString();\n  UniqueIDGeneretor.lastID++;\n  return obj.uniqueID;\n};\n\nUniqueIDGeneretor.getString = function (id) {\n  if (id == null) id = UniqueIDGeneretor.lastID;\n  return \"Object#\" + id + \"\";\n};\n\nUniqueIDGeneretor.isPrimitive = function (arg) {\n  var type = typeof arg;\n  return arg == null || type != \"object\" && type != \"function\";\n};\n\nmodule.exports = UniqueIDGeneretor;\n\n/***/ }),\n/* 6 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraph;\nvar LEdge = __webpack_require__(7);\n\nfunction LGraphManager(layout) {\n  LGraph = __webpack_require__(11); // It may be better to initilize this out of this function but it gives an error (Right-hand side of 'instanceof' is not callable) now.\n  this.layout = layout;\n\n  this.graphs = [];\n  this.edges = [];\n}\n\nLGraphManager.prototype.addRoot = function () {\n  var ngraph = this.layout.newGraph();\n  var nnode = this.layout.newNode(null);\n  var root = this.add(ngraph, nnode);\n  this.setRootGraph(root);\n  return this.rootGraph;\n};\n\nLGraphManager.prototype.add = function (newGraph, parentNode, newEdge, sourceNode, targetNode) {\n  //there are just 2 parameters are passed then it adds an LGraph else it adds an LEdge\n  if (newEdge == null && sourceNode == null && targetNode == null) {\n    if (newGraph == null) {\n      throw \"Graph is null!\";\n    }\n    if (parentNode == null) {\n      throw \"Parent node is null!\";\n    }\n    if (this.graphs.indexOf(newGraph) > -1) {\n      throw \"Graph already in this graph mgr!\";\n    }\n\n    this.graphs.push(newGraph);\n\n    if (newGraph.parent != null) {\n      throw \"Already has a parent!\";\n    }\n    if (parentNode.child != null) {\n      throw \"Already has a child!\";\n    }\n\n    newGraph.parent = parentNode;\n    parentNode.child = newGraph;\n\n    return newGraph;\n  } else {\n    //change the order of the parameters\n    targetNode = newEdge;\n    sourceNode = parentNode;\n    newEdge = newGraph;\n    var sourceGraph = sourceNode.getOwner();\n    var targetGraph = targetNode.getOwner();\n\n    if (!(sourceGraph != null && sourceGraph.getGraphManager() == this)) {\n      throw \"Source not in this graph mgr!\";\n    }\n    if (!(targetGraph != null && targetGraph.getGraphManager() == this)) {\n      throw \"Target not in this graph mgr!\";\n    }\n\n    if (sourceGraph == targetGraph) {\n      newEdge.isInterGraph = false;\n      return sourceGraph.add(newEdge, sourceNode, targetNode);\n    } else {\n      newEdge.isInterGraph = true;\n\n      // set source and target\n      newEdge.source = sourceNode;\n      newEdge.target = targetNode;\n\n      // add edge to inter-graph edge list\n      if (this.edges.indexOf(newEdge) > -1) {\n        throw \"Edge already in inter-graph edge list!\";\n      }\n\n      this.edges.push(newEdge);\n\n      // add edge to source and target incidency lists\n      if (!(newEdge.source != null && newEdge.target != null)) {\n        throw \"Edge source and/or target is null!\";\n      }\n\n      if (!(newEdge.source.edges.indexOf(newEdge) == -1 && newEdge.target.edges.indexOf(newEdge) == -1)) {\n        throw \"Edge already in source and/or target incidency list!\";\n      }\n\n      newEdge.source.edges.push(newEdge);\n      newEdge.target.edges.push(newEdge);\n\n      return newEdge;\n    }\n  }\n};\n\nLGraphManager.prototype.remove = function (lObj) {\n  if (lObj instanceof LGraph) {\n    var graph = lObj;\n    if (graph.getGraphManager() != this) {\n      throw \"Graph not in this graph mgr\";\n    }\n    if (!(graph == this.rootGraph || graph.parent != null && graph.parent.graphManager == this)) {\n      throw \"Invalid parent node!\";\n    }\n\n    // first the edges (make a copy to do it safely)\n    var edgesToBeRemoved = [];\n\n    edgesToBeRemoved = edgesToBeRemoved.concat(graph.getEdges());\n\n    var edge;\n    var s = edgesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      edge = edgesToBeRemoved[i];\n      graph.remove(edge);\n    }\n\n    // then the nodes (make a copy to do it safely)\n    var nodesToBeRemoved = [];\n\n    nodesToBeRemoved = nodesToBeRemoved.concat(graph.getNodes());\n\n    var node;\n    s = nodesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      node = nodesToBeRemoved[i];\n      graph.remove(node);\n    }\n\n    // check if graph is the root\n    if (graph == this.rootGraph) {\n      this.setRootGraph(null);\n    }\n\n    // now remove the graph itself\n    var index = this.graphs.indexOf(graph);\n    this.graphs.splice(index, 1);\n\n    // also reset the parent of the graph\n    graph.parent = null;\n  } else if (lObj instanceof LEdge) {\n    edge = lObj;\n    if (edge == null) {\n      throw \"Edge is null!\";\n    }\n    if (!edge.isInterGraph) {\n      throw \"Not an inter-graph edge!\";\n    }\n    if (!(edge.source != null && edge.target != null)) {\n      throw \"Source and/or target is null!\";\n    }\n\n    // remove edge from source and target nodes' incidency lists\n\n    if (!(edge.source.edges.indexOf(edge) != -1 && edge.target.edges.indexOf(edge) != -1)) {\n      throw \"Source and/or target doesn't know this edge!\";\n    }\n\n    var index = edge.source.edges.indexOf(edge);\n    edge.source.edges.splice(index, 1);\n    index = edge.target.edges.indexOf(edge);\n    edge.target.edges.splice(index, 1);\n\n    // remove edge from owner graph manager's inter-graph edge list\n\n    if (!(edge.source.owner != null && edge.source.owner.getGraphManager() != null)) {\n      throw \"Edge owner graph or owner graph manager is null!\";\n    }\n    if (edge.source.owner.getGraphManager().edges.indexOf(edge) == -1) {\n      throw \"Not in owner graph manager's edge list!\";\n    }\n\n    var index = edge.source.owner.getGraphManager().edges.indexOf(edge);\n    edge.source.owner.getGraphManager().edges.splice(index, 1);\n  }\n};\n\nLGraphManager.prototype.updateBounds = function () {\n  this.rootGraph.updateBounds(true);\n};\n\nLGraphManager.prototype.getGraphs = function () {\n  return this.graphs;\n};\n\nLGraphManager.prototype.getAllNodes = function () {\n  if (this.allNodes == null) {\n    var nodeList = [];\n    var graphs = this.getGraphs();\n    var s = graphs.length;\n    for (var i = 0; i < s; i++) {\n      nodeList = nodeList.concat(graphs[i].getNodes());\n    }\n    this.allNodes = nodeList;\n  }\n  return this.allNodes;\n};\n\nLGraphManager.prototype.resetAllNodes = function () {\n  this.allNodes = null;\n};\n\nLGraphManager.prototype.resetAllEdges = function () {\n  this.allEdges = null;\n};\n\nLGraphManager.prototype.resetAllNodesToApplyGravitation = function () {\n  this.allNodesToApplyGravitation = null;\n};\n\nLGraphManager.prototype.getAllEdges = function () {\n  if (this.allEdges == null) {\n    var edgeList = [];\n    var graphs = this.getGraphs();\n    var s = graphs.length;\n    for (var i = 0; i < graphs.length; i++) {\n      edgeList = edgeList.concat(graphs[i].getEdges());\n    }\n\n    edgeList = edgeList.concat(this.edges);\n\n    this.allEdges = edgeList;\n  }\n  return this.allEdges;\n};\n\nLGraphManager.prototype.getAllNodesToApplyGravitation = function () {\n  return this.allNodesToApplyGravitation;\n};\n\nLGraphManager.prototype.setAllNodesToApplyGravitation = function (nodeList) {\n  if (this.allNodesToApplyGravitation != null) {\n    throw \"assert failed\";\n  }\n\n  this.allNodesToApplyGravitation = nodeList;\n};\n\nLGraphManager.prototype.getRoot = function () {\n  return this.rootGraph;\n};\n\nLGraphManager.prototype.setRootGraph = function (graph) {\n  if (graph.getGraphManager() != this) {\n    throw \"Root not in this graph mgr!\";\n  }\n\n  this.rootGraph = graph;\n  // root graph must have a root node associated with it for convenience\n  if (graph.parent == null) {\n    graph.parent = this.layout.newNode(\"Root node\");\n  }\n};\n\nLGraphManager.prototype.getLayout = function () {\n  return this.layout;\n};\n\nLGraphManager.prototype.isOneAncestorOfOther = function (firstNode, secondNode) {\n  if (!(firstNode != null && secondNode != null)) {\n    throw \"assert failed\";\n  }\n\n  if (firstNode == secondNode) {\n    return true;\n  }\n  // Is second node an ancestor of the first one?\n  var ownerGraph = firstNode.getOwner();\n  var parentNode;\n\n  do {\n    parentNode = ownerGraph.getParent();\n\n    if (parentNode == null) {\n      break;\n    }\n\n    if (parentNode == secondNode) {\n      return true;\n    }\n\n    ownerGraph = parentNode.getOwner();\n    if (ownerGraph == null) {\n      break;\n    }\n  } while (true);\n  // Is first node an ancestor of the second one?\n  ownerGraph = secondNode.getOwner();\n\n  do {\n    parentNode = ownerGraph.getParent();\n\n    if (parentNode == null) {\n      break;\n    }\n\n    if (parentNode == firstNode) {\n      return true;\n    }\n\n    ownerGraph = parentNode.getOwner();\n    if (ownerGraph == null) {\n      break;\n    }\n  } while (true);\n\n  return false;\n};\n\nLGraphManager.prototype.calcLowestCommonAncestors = function () {\n  var edge;\n  var sourceNode;\n  var targetNode;\n  var sourceAncestorGraph;\n  var targetAncestorGraph;\n\n  var edges = this.getAllEdges();\n  var s = edges.length;\n  for (var i = 0; i < s; i++) {\n    edge = edges[i];\n\n    sourceNode = edge.source;\n    targetNode = edge.target;\n    edge.lca = null;\n    edge.sourceInLca = sourceNode;\n    edge.targetInLca = targetNode;\n\n    if (sourceNode == targetNode) {\n      edge.lca = sourceNode.getOwner();\n      continue;\n    }\n\n    sourceAncestorGraph = sourceNode.getOwner();\n\n    while (edge.lca == null) {\n      edge.targetInLca = targetNode;\n      targetAncestorGraph = targetNode.getOwner();\n\n      while (edge.lca == null) {\n        if (targetAncestorGraph == sourceAncestorGraph) {\n          edge.lca = targetAncestorGraph;\n          break;\n        }\n\n        if (targetAncestorGraph == this.rootGraph) {\n          break;\n        }\n\n        if (edge.lca != null) {\n          throw \"assert failed\";\n        }\n        edge.targetInLca = targetAncestorGraph.getParent();\n        targetAncestorGraph = edge.targetInLca.getOwner();\n      }\n\n      if (sourceAncestorGraph == this.rootGraph) {\n        break;\n      }\n\n      if (edge.lca == null) {\n        edge.sourceInLca = sourceAncestorGraph.getParent();\n        sourceAncestorGraph = edge.sourceInLca.getOwner();\n      }\n    }\n\n    if (edge.lca == null) {\n      throw \"assert failed\";\n    }\n  }\n};\n\nLGraphManager.prototype.calcLowestCommonAncestor = function (firstNode, secondNode) {\n  if (firstNode == secondNode) {\n    return firstNode.getOwner();\n  }\n  var firstOwnerGraph = firstNode.getOwner();\n\n  do {\n    if (firstOwnerGraph == null) {\n      break;\n    }\n    var secondOwnerGraph = secondNode.getOwner();\n\n    do {\n      if (secondOwnerGraph == null) {\n        break;\n      }\n\n      if (secondOwnerGraph == firstOwnerGraph) {\n        return secondOwnerGraph;\n      }\n      secondOwnerGraph = secondOwnerGraph.getParent().getOwner();\n    } while (true);\n\n    firstOwnerGraph = firstOwnerGraph.getParent().getOwner();\n  } while (true);\n\n  return firstOwnerGraph;\n};\n\nLGraphManager.prototype.calcInclusionTreeDepths = function (graph, depth) {\n  if (graph == null && depth == null) {\n    graph = this.rootGraph;\n    depth = 1;\n  }\n  var node;\n\n  var nodes = graph.getNodes();\n  var s = nodes.length;\n  for (var i = 0; i < s; i++) {\n    node = nodes[i];\n    node.inclusionTreeDepth = depth;\n\n    if (node.child != null) {\n      this.calcInclusionTreeDepths(node.child, depth + 1);\n    }\n  }\n};\n\nLGraphManager.prototype.includesInvalidEdge = function () {\n  var edge;\n\n  var s = this.edges.length;\n  for (var i = 0; i < s; i++) {\n    edge = this.edges[i];\n\n    if (this.isOneAncestorOfOther(edge.source, edge.target)) {\n      return true;\n    }\n  }\n  return false;\n};\n\nmodule.exports = LGraphManager;\n\n/***/ }),\n/* 7 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar IGeometry = __webpack_require__(9);\nvar IMath = __webpack_require__(10);\n\nfunction LEdge(source, target, vEdge) {\n  LGraphObject.call(this, vEdge);\n\n  this.isOverlapingSourceAndTarget = false;\n  this.vGraphObject = vEdge;\n  this.bendpoints = [];\n  this.source = source;\n  this.target = target;\n}\n\nLEdge.prototype = Object.create(LGraphObject.prototype);\n\nfor (var prop in LGraphObject) {\n  LEdge[prop] = LGraphObject[prop];\n}\n\nLEdge.prototype.getSource = function () {\n  return this.source;\n};\n\nLEdge.prototype.getTarget = function () {\n  return this.target;\n};\n\nLEdge.prototype.isInterGraph = function () {\n  return this.isInterGraph;\n};\n\nLEdge.prototype.getLength = function () {\n  return this.length;\n};\n\nLEdge.prototype.isOverlapingSourceAndTarget = function () {\n  return this.isOverlapingSourceAndTarget;\n};\n\nLEdge.prototype.getBendpoints = function () {\n  return this.bendpoints;\n};\n\nLEdge.prototype.getLca = function () {\n  return this.lca;\n};\n\nLEdge.prototype.getSourceInLca = function () {\n  return this.sourceInLca;\n};\n\nLEdge.prototype.getTargetInLca = function () {\n  return this.targetInLca;\n};\n\nLEdge.prototype.getOtherEnd = function (node) {\n  if (this.source === node) {\n    return this.target;\n  } else if (this.target === node) {\n    return this.source;\n  } else {\n    throw \"Node is not incident with this edge\";\n  }\n};\n\nLEdge.prototype.getOtherEndInGraph = function (node, graph) {\n  var otherEnd = this.getOtherEnd(node);\n  var root = graph.getGraphManager().getRoot();\n\n  while (true) {\n    if (otherEnd.getOwner() == graph) {\n      return otherEnd;\n    }\n\n    if (otherEnd.getOwner() == root) {\n      break;\n    }\n\n    otherEnd = otherEnd.getOwner().getParent();\n  }\n\n  return null;\n};\n\nLEdge.prototype.updateLength = function () {\n  var clipPointCoordinates = new Array(4);\n\n  this.isOverlapingSourceAndTarget = IGeometry.getIntersection(this.target.getRect(), this.source.getRect(), clipPointCoordinates);\n\n  if (!this.isOverlapingSourceAndTarget) {\n    this.lengthX = clipPointCoordinates[0] - clipPointCoordinates[2];\n    this.lengthY = clipPointCoordinates[1] - clipPointCoordinates[3];\n\n    if (Math.abs(this.lengthX) < 1.0) {\n      this.lengthX = IMath.sign(this.lengthX);\n    }\n\n    if (Math.abs(this.lengthY) < 1.0) {\n      this.lengthY = IMath.sign(this.lengthY);\n    }\n\n    this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY);\n  }\n};\n\nLEdge.prototype.updateLengthSimple = function () {\n  this.lengthX = this.target.getCenterX() - this.source.getCenterX();\n  this.lengthY = this.target.getCenterY() - this.source.getCenterY();\n\n  if (Math.abs(this.lengthX) < 1.0) {\n    this.lengthX = IMath.sign(this.lengthX);\n  }\n\n  if (Math.abs(this.lengthY) < 1.0) {\n    this.lengthY = IMath.sign(this.lengthY);\n  }\n\n  this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY);\n};\n\nmodule.exports = LEdge;\n\n/***/ }),\n/* 8 */\n/***/ (function(module, exports) {\n\nfunction LGraphObject(vGraphObject) {\n  this.vGraphObject = vGraphObject;\n}\n\nmodule.exports = LGraphObject;\n\n/***/ }),\n/* 9 */\n/***/ (function(module, exports) {\n\nfunction IGeometry() {}\n\nIGeometry.calcSeparationAmount = function (rectA, rectB, overlapAmount, separationBuffer) {\n  if (!rectA.intersects(rectB)) {\n    throw \"assert failed\";\n  }\n  var directions = new Array(2);\n  IGeometry.decideDirectionsForOverlappingNodes(rectA, rectB, directions);\n  overlapAmount[0] = Math.min(rectA.getRight(), rectB.getRight()) - Math.max(rectA.x, rectB.x);\n  overlapAmount[1] = Math.min(rectA.getBottom(), rectB.getBottom()) - Math.max(rectA.y, rectB.y);\n  // update the overlapping amounts for the following cases:\n  if (rectA.getX() <= rectB.getX() && rectA.getRight() >= rectB.getRight()) {\n    overlapAmount[0] += Math.min(rectB.getX() - rectA.getX(), rectA.getRight() - rectB.getRight());\n  } else if (rectB.getX() <= rectA.getX() && rectB.getRight() >= rectA.getRight()) {\n    overlapAmount[0] += Math.min(rectA.getX() - rectB.getX(), rectB.getRight() - rectA.getRight());\n  }\n  if (rectA.getY() <= rectB.getY() && rectA.getBottom() >= rectB.getBottom()) {\n    overlapAmount[1] += Math.min(rectB.getY() - rectA.getY(), rectA.getBottom() - rectB.getBottom());\n  } else if (rectB.getY() <= rectA.getY() && rectB.getBottom() >= rectA.getBottom()) {\n    overlapAmount[1] += Math.min(rectA.getY() - rectB.getY(), rectB.getBottom() - rectA.getBottom());\n  }\n\n  // find slope of the line passes two centers\n  var slope = Math.abs((rectB.getCenterY() - rectA.getCenterY()) / (rectB.getCenterX() - rectA.getCenterX()));\n  // if centers are overlapped\n  if (rectB.getCenterY() == rectA.getCenterY() && rectB.getCenterX() == rectA.getCenterX()) {\n    // assume the slope is 1 (45 degree)\n    slope = 1.0;\n  }\n\n  var moveByY = slope * overlapAmount[0];\n  var moveByX = overlapAmount[1] / slope;\n  if (overlapAmount[0] < moveByX) {\n    moveByX = overlapAmount[0];\n  } else {\n    moveByY = overlapAmount[1];\n  }\n  // return half the amount so that if each rectangle is moved by these\n  // amounts in opposite directions, overlap will be resolved\n  overlapAmount[0] = -1 * directions[0] * (moveByX / 2 + separationBuffer);\n  overlapAmount[1] = -1 * directions[1] * (moveByY / 2 + separationBuffer);\n};\n\nIGeometry.decideDirectionsForOverlappingNodes = function (rectA, rectB, directions) {\n  if (rectA.getCenterX() < rectB.getCenterX()) {\n    directions[0] = -1;\n  } else {\n    directions[0] = 1;\n  }\n\n  if (rectA.getCenterY() < rectB.getCenterY()) {\n    directions[1] = -1;\n  } else {\n    directions[1] = 1;\n  }\n};\n\nIGeometry.getIntersection2 = function (rectA, rectB, result) {\n  //result[0-1] will contain clipPoint of rectA, result[2-3] will contain clipPoint of rectB\n  var p1x = rectA.getCenterX();\n  var p1y = rectA.getCenterY();\n  var p2x = rectB.getCenterX();\n  var p2y = rectB.getCenterY();\n\n  //if two rectangles intersect, then clipping points are centers\n  if (rectA.intersects(rectB)) {\n    result[0] = p1x;\n    result[1] = p1y;\n    result[2] = p2x;\n    result[3] = p2y;\n    return true;\n  }\n  //variables for rectA\n  var topLeftAx = rectA.getX();\n  var topLeftAy = rectA.getY();\n  var topRightAx = rectA.getRight();\n  var bottomLeftAx = rectA.getX();\n  var bottomLeftAy = rectA.getBottom();\n  var bottomRightAx = rectA.getRight();\n  var halfWidthA = rectA.getWidthHalf();\n  var halfHeightA = rectA.getHeightHalf();\n  //variables for rectB\n  var topLeftBx = rectB.getX();\n  var topLeftBy = rectB.getY();\n  var topRightBx = rectB.getRight();\n  var bottomLeftBx = rectB.getX();\n  var bottomLeftBy = rectB.getBottom();\n  var bottomRightBx = rectB.getRight();\n  var halfWidthB = rectB.getWidthHalf();\n  var halfHeightB = rectB.getHeightHalf();\n  //flag whether clipping points are found\n  var clipPointAFound = false;\n  var clipPointBFound = false;\n\n  // line is vertical\n  if (p1x == p2x) {\n    if (p1y > p2y) {\n      result[0] = p1x;\n      result[1] = topLeftAy;\n      result[2] = p2x;\n      result[3] = bottomLeftBy;\n      return false;\n    } else if (p1y < p2y) {\n      result[0] = p1x;\n      result[1] = bottomLeftAy;\n      result[2] = p2x;\n      result[3] = topLeftBy;\n      return false;\n    } else {\n      //not line, return null;\n    }\n  }\n  // line is horizontal\n  else if (p1y == p2y) {\n      if (p1x > p2x) {\n        result[0] = topLeftAx;\n        result[1] = p1y;\n        result[2] = topRightBx;\n        result[3] = p2y;\n        return false;\n      } else if (p1x < p2x) {\n        result[0] = topRightAx;\n        result[1] = p1y;\n        result[2] = topLeftBx;\n        result[3] = p2y;\n        return false;\n      } else {\n        //not valid line, return null;\n      }\n    } else {\n      //slopes of rectA's and rectB's diagonals\n      var slopeA = rectA.height / rectA.width;\n      var slopeB = rectB.height / rectB.width;\n\n      //slope of line between center of rectA and center of rectB\n      var slopePrime = (p2y - p1y) / (p2x - p1x);\n      var cardinalDirectionA;\n      var cardinalDirectionB;\n      var tempPointAx;\n      var tempPointAy;\n      var tempPointBx;\n      var tempPointBy;\n\n      //determine whether clipping point is the corner of nodeA\n      if (-slopeA == slopePrime) {\n        if (p1x > p2x) {\n          result[0] = bottomLeftAx;\n          result[1] = bottomLeftAy;\n          clipPointAFound = true;\n        } else {\n          result[0] = topRightAx;\n          result[1] = topLeftAy;\n          clipPointAFound = true;\n        }\n      } else if (slopeA == slopePrime) {\n        if (p1x > p2x) {\n          result[0] = topLeftAx;\n          result[1] = topLeftAy;\n          clipPointAFound = true;\n        } else {\n          result[0] = bottomRightAx;\n          result[1] = bottomLeftAy;\n          clipPointAFound = true;\n        }\n      }\n\n      //determine whether clipping point is the corner of nodeB\n      if (-slopeB == slopePrime) {\n        if (p2x > p1x) {\n          result[2] = bottomLeftBx;\n          result[3] = bottomLeftBy;\n          clipPointBFound = true;\n        } else {\n          result[2] = topRightBx;\n          result[3] = topLeftBy;\n          clipPointBFound = true;\n        }\n      } else if (slopeB == slopePrime) {\n        if (p2x > p1x) {\n          result[2] = topLeftBx;\n          result[3] = topLeftBy;\n          clipPointBFound = true;\n        } else {\n          result[2] = bottomRightBx;\n          result[3] = bottomLeftBy;\n          clipPointBFound = true;\n        }\n      }\n\n      //if both clipping points are corners\n      if (clipPointAFound && clipPointBFound) {\n        return false;\n      }\n\n      //determine Cardinal Direction of rectangles\n      if (p1x > p2x) {\n        if (p1y > p2y) {\n          cardinalDirectionA = IGeometry.getCardinalDirection(slopeA, slopePrime, 4);\n          cardinalDirectionB = IGeometry.getCardinalDirection(slopeB, slopePrime, 2);\n        } else {\n          cardinalDirectionA = IGeometry.getCardinalDirection(-slopeA, slopePrime, 3);\n          cardinalDirectionB = IGeometry.getCardinalDirection(-slopeB, slopePrime, 1);\n        }\n      } else {\n        if (p1y > p2y) {\n          cardinalDirectionA = IGeometry.getCardinalDirection(-slopeA, slopePrime, 1);\n          cardinalDirectionB = IGeometry.getCardinalDirection(-slopeB, slopePrime, 3);\n        } else {\n          cardinalDirectionA = IGeometry.getCardinalDirection(slopeA, slopePrime, 2);\n          cardinalDirectionB = IGeometry.getCardinalDirection(slopeB, slopePrime, 4);\n        }\n      }\n      //calculate clipping Point if it is not found before\n      if (!clipPointAFound) {\n        switch (cardinalDirectionA) {\n          case 1:\n            tempPointAy = topLeftAy;\n            tempPointAx = p1x + -halfHeightA / slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 2:\n            tempPointAx = bottomRightAx;\n            tempPointAy = p1y + halfWidthA * slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 3:\n            tempPointAy = bottomLeftAy;\n            tempPointAx = p1x + halfHeightA / slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 4:\n            tempPointAx = bottomLeftAx;\n            tempPointAy = p1y + -halfWidthA * slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n        }\n      }\n      if (!clipPointBFound) {\n        switch (cardinalDirectionB) {\n          case 1:\n            tempPointBy = topLeftBy;\n            tempPointBx = p2x + -halfHeightB / slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 2:\n            tempPointBx = bottomRightBx;\n            tempPointBy = p2y + halfWidthB * slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 3:\n            tempPointBy = bottomLeftBy;\n            tempPointBx = p2x + halfHeightB / slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 4:\n            tempPointBx = bottomLeftBx;\n            tempPointBy = p2y + -halfWidthB * slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n        }\n      }\n    }\n  return false;\n};\n\nIGeometry.getCardinalDirection = function (slope, slopePrime, line) {\n  if (slope > slopePrime) {\n    return line;\n  } else {\n    return 1 + line % 4;\n  }\n};\n\nIGeometry.getIntersection = function (s1, s2, f1, f2) {\n  if (f2 == null) {\n    return IGeometry.getIntersection2(s1, s2, f1);\n  }\n  var x1 = s1.x;\n  var y1 = s1.y;\n  var x2 = s2.x;\n  var y2 = s2.y;\n  var x3 = f1.x;\n  var y3 = f1.y;\n  var x4 = f2.x;\n  var y4 = f2.y;\n  var x, y; // intersection point\n  var a1, a2, b1, b2, c1, c2; // coefficients of line eqns.\n  var denom;\n\n  a1 = y2 - y1;\n  b1 = x1 - x2;\n  c1 = x2 * y1 - x1 * y2; // { a1*x + b1*y + c1 = 0 is line 1 }\n\n  a2 = y4 - y3;\n  b2 = x3 - x4;\n  c2 = x4 * y3 - x3 * y4; // { a2*x + b2*y + c2 = 0 is line 2 }\n\n  denom = a1 * b2 - a2 * b1;\n\n  if (denom == 0) {\n    return null;\n  }\n\n  x = (b1 * c2 - b2 * c1) / denom;\n  y = (a2 * c1 - a1 * c2) / denom;\n\n  return new Point(x, y);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Class Constants\n// -----------------------------------------------------------------------------\n/**\r\n * Some useful pre-calculated constants\r\n */\nIGeometry.HALF_PI = 0.5 * Math.PI;\nIGeometry.ONE_AND_HALF_PI = 1.5 * Math.PI;\nIGeometry.TWO_PI = 2.0 * Math.PI;\nIGeometry.THREE_PI = 3.0 * Math.PI;\n\nmodule.exports = IGeometry;\n\n/***/ }),\n/* 10 */\n/***/ (function(module, exports) {\n\nfunction IMath() {}\n\n/**\r\n * This method returns the sign of the input value.\r\n */\nIMath.sign = function (value) {\n  if (value > 0) {\n    return 1;\n  } else if (value < 0) {\n    return -1;\n  } else {\n    return 0;\n  }\n};\n\nIMath.floor = function (value) {\n  return value < 0 ? Math.ceil(value) : Math.floor(value);\n};\n\nIMath.ceil = function (value) {\n  return value < 0 ? Math.floor(value) : Math.ceil(value);\n};\n\nmodule.exports = IMath;\n\n/***/ }),\n/* 11 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar Integer = __webpack_require__(12);\nvar LayoutConstants = __webpack_require__(3);\nvar LGraphManager = __webpack_require__(6);\nvar LNode = __webpack_require__(13);\nvar LEdge = __webpack_require__(7);\nvar RectangleD = __webpack_require__(14);\nvar Point = __webpack_require__(18);\nvar LinkedList = __webpack_require__(19);\n\nfunction LGraph(parent, obj2, vGraph) {\n  LGraphObject.call(this, vGraph);\n  this.estimatedSize = Integer.MIN_VALUE;\n  this.margin = LayoutConstants.DEFAULT_GRAPH_MARGIN;\n  this.edges = [];\n  this.nodes = [];\n  this.isConnected = false;\n  this.parent = parent;\n\n  if (obj2 != null && obj2 instanceof LGraphManager) {\n    this.graphManager = obj2;\n  } else if (obj2 != null && obj2 instanceof Layout) {\n    this.graphManager = obj2.graphManager;\n  }\n}\n\nLGraph.prototype = Object.create(LGraphObject.prototype);\nfor (var prop in LGraphObject) {\n  LGraph[prop] = LGraphObject[prop];\n}\n\nLGraph.prototype.getNodes = function () {\n  return this.nodes;\n};\n\nLGraph.prototype.getEdges = function () {\n  return this.edges;\n};\n\nLGraph.prototype.getGraphManager = function () {\n  return this.graphManager;\n};\n\nLGraph.prototype.getParent = function () {\n  return this.parent;\n};\n\nLGraph.prototype.getLeft = function () {\n  return this.left;\n};\n\nLGraph.prototype.getRight = function () {\n  return this.right;\n};\n\nLGraph.prototype.getTop = function () {\n  return this.top;\n};\n\nLGraph.prototype.getBottom = function () {\n  return this.bottom;\n};\n\nLGraph.prototype.isConnected = function () {\n  return this.isConnected;\n};\n\nLGraph.prototype.add = function (obj1, sourceNode, targetNode) {\n  if (sourceNode == null && targetNode == null) {\n    var newNode = obj1;\n    if (this.graphManager == null) {\n      throw \"Graph has no graph mgr!\";\n    }\n    if (this.getNodes().indexOf(newNode) > -1) {\n      throw \"Node already in graph!\";\n    }\n    newNode.owner = this;\n    this.getNodes().push(newNode);\n\n    return newNode;\n  } else {\n    var newEdge = obj1;\n    if (!(this.getNodes().indexOf(sourceNode) > -1 && this.getNodes().indexOf(targetNode) > -1)) {\n      throw \"Source or target not in graph!\";\n    }\n\n    if (!(sourceNode.owner == targetNode.owner && sourceNode.owner == this)) {\n      throw \"Both owners must be this graph!\";\n    }\n\n    if (sourceNode.owner != targetNode.owner) {\n      return null;\n    }\n\n    // set source and target\n    newEdge.source = sourceNode;\n    newEdge.target = targetNode;\n\n    // set as intra-graph edge\n    newEdge.isInterGraph = false;\n\n    // add to graph edge list\n    this.getEdges().push(newEdge);\n\n    // add to incidency lists\n    sourceNode.edges.push(newEdge);\n\n    if (targetNode != sourceNode) {\n      targetNode.edges.push(newEdge);\n    }\n\n    return newEdge;\n  }\n};\n\nLGraph.prototype.remove = function (obj) {\n  var node = obj;\n  if (obj instanceof LNode) {\n    if (node == null) {\n      throw \"Node is null!\";\n    }\n    if (!(node.owner != null && node.owner == this)) {\n      throw \"Owner graph is invalid!\";\n    }\n    if (this.graphManager == null) {\n      throw \"Owner graph manager is invalid!\";\n    }\n    // remove incident edges first (make a copy to do it safely)\n    var edgesToBeRemoved = node.edges.slice();\n    var edge;\n    var s = edgesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      edge = edgesToBeRemoved[i];\n\n      if (edge.isInterGraph) {\n        this.graphManager.remove(edge);\n      } else {\n        edge.source.owner.remove(edge);\n      }\n    }\n\n    // now the node itself\n    var index = this.nodes.indexOf(node);\n    if (index == -1) {\n      throw \"Node not in owner node list!\";\n    }\n\n    this.nodes.splice(index, 1);\n  } else if (obj instanceof LEdge) {\n    var edge = obj;\n    if (edge == null) {\n      throw \"Edge is null!\";\n    }\n    if (!(edge.source != null && edge.target != null)) {\n      throw \"Source and/or target is null!\";\n    }\n    if (!(edge.source.owner != null && edge.target.owner != null && edge.source.owner == this && edge.target.owner == this)) {\n      throw \"Source and/or target owner is invalid!\";\n    }\n\n    var sourceIndex = edge.source.edges.indexOf(edge);\n    var targetIndex = edge.target.edges.indexOf(edge);\n    if (!(sourceIndex > -1 && targetIndex > -1)) {\n      throw \"Source and/or target doesn't know this edge!\";\n    }\n\n    edge.source.edges.splice(sourceIndex, 1);\n\n    if (edge.target != edge.source) {\n      edge.target.edges.splice(targetIndex, 1);\n    }\n\n    var index = edge.source.owner.getEdges().indexOf(edge);\n    if (index == -1) {\n      throw \"Not in owner's edge list!\";\n    }\n\n    edge.source.owner.getEdges().splice(index, 1);\n  }\n};\n\nLGraph.prototype.updateLeftTop = function () {\n  var top = Integer.MAX_VALUE;\n  var left = Integer.MAX_VALUE;\n  var nodeTop;\n  var nodeLeft;\n  var margin;\n\n  var nodes = this.getNodes();\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    nodeTop = lNode.getTop();\n    nodeLeft = lNode.getLeft();\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n  }\n\n  // Do we have any nodes in this graph?\n  if (top == Integer.MAX_VALUE) {\n    return null;\n  }\n\n  if (nodes[0].getParent().paddingLeft != undefined) {\n    margin = nodes[0].getParent().paddingLeft;\n  } else {\n    margin = this.margin;\n  }\n\n  this.left = left - margin;\n  this.top = top - margin;\n\n  // Apply the margins and return the result\n  return new Point(this.left, this.top);\n};\n\nLGraph.prototype.updateBounds = function (recursive) {\n  // calculate bounds\n  var left = Integer.MAX_VALUE;\n  var right = -Integer.MAX_VALUE;\n  var top = Integer.MAX_VALUE;\n  var bottom = -Integer.MAX_VALUE;\n  var nodeLeft;\n  var nodeRight;\n  var nodeTop;\n  var nodeBottom;\n  var margin;\n\n  var nodes = this.nodes;\n  var s = nodes.length;\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n\n    if (recursive && lNode.child != null) {\n      lNode.updateBounds();\n    }\n    nodeLeft = lNode.getLeft();\n    nodeRight = lNode.getRight();\n    nodeTop = lNode.getTop();\n    nodeBottom = lNode.getBottom();\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n\n    if (right < nodeRight) {\n      right = nodeRight;\n    }\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (bottom < nodeBottom) {\n      bottom = nodeBottom;\n    }\n  }\n\n  var boundingRect = new RectangleD(left, top, right - left, bottom - top);\n  if (left == Integer.MAX_VALUE) {\n    this.left = this.parent.getLeft();\n    this.right = this.parent.getRight();\n    this.top = this.parent.getTop();\n    this.bottom = this.parent.getBottom();\n  }\n\n  if (nodes[0].getParent().paddingLeft != undefined) {\n    margin = nodes[0].getParent().paddingLeft;\n  } else {\n    margin = this.margin;\n  }\n\n  this.left = boundingRect.x - margin;\n  this.right = boundingRect.x + boundingRect.width + margin;\n  this.top = boundingRect.y - margin;\n  this.bottom = boundingRect.y + boundingRect.height + margin;\n};\n\nLGraph.calculateBounds = function (nodes) {\n  var left = Integer.MAX_VALUE;\n  var right = -Integer.MAX_VALUE;\n  var top = Integer.MAX_VALUE;\n  var bottom = -Integer.MAX_VALUE;\n  var nodeLeft;\n  var nodeRight;\n  var nodeTop;\n  var nodeBottom;\n\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    nodeLeft = lNode.getLeft();\n    nodeRight = lNode.getRight();\n    nodeTop = lNode.getTop();\n    nodeBottom = lNode.getBottom();\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n\n    if (right < nodeRight) {\n      right = nodeRight;\n    }\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (bottom < nodeBottom) {\n      bottom = nodeBottom;\n    }\n  }\n\n  var boundingRect = new RectangleD(left, top, right - left, bottom - top);\n\n  return boundingRect;\n};\n\nLGraph.prototype.getInclusionTreeDepth = function () {\n  if (this == this.graphManager.getRoot()) {\n    return 1;\n  } else {\n    return this.parent.getInclusionTreeDepth();\n  }\n};\n\nLGraph.prototype.getEstimatedSize = function () {\n  if (this.estimatedSize == Integer.MIN_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.estimatedSize;\n};\n\nLGraph.prototype.calcEstimatedSize = function () {\n  var size = 0;\n  var nodes = this.nodes;\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    size += lNode.calcEstimatedSize();\n  }\n\n  if (size == 0) {\n    this.estimatedSize = LayoutConstants.EMPTY_COMPOUND_NODE_SIZE;\n  } else {\n    this.estimatedSize = size / Math.sqrt(this.nodes.length);\n  }\n\n  return this.estimatedSize;\n};\n\nLGraph.prototype.updateConnected = function () {\n  var self = this;\n  if (this.nodes.length == 0) {\n    this.isConnected = true;\n    return;\n  }\n\n  var queue = new LinkedList();\n  var visited = new Set();\n  var currentNode = this.nodes[0];\n  var neighborEdges;\n  var currentNeighbor;\n  var childrenOfNode = currentNode.withChildren();\n  childrenOfNode.forEach(function (node) {\n    queue.push(node);\n    visited.add(node);\n  });\n\n  while (queue.length !== 0) {\n    currentNode = queue.shift();\n\n    // Traverse all neighbors of this node\n    neighborEdges = currentNode.getEdges();\n    var size = neighborEdges.length;\n    for (var i = 0; i < size; i++) {\n      var neighborEdge = neighborEdges[i];\n      currentNeighbor = neighborEdge.getOtherEndInGraph(currentNode, this);\n\n      // Add unvisited neighbors to the list to visit\n      if (currentNeighbor != null && !visited.has(currentNeighbor)) {\n        var childrenOfNeighbor = currentNeighbor.withChildren();\n\n        childrenOfNeighbor.forEach(function (node) {\n          queue.push(node);\n          visited.add(node);\n        });\n      }\n    }\n  }\n\n  this.isConnected = false;\n\n  if (visited.size >= this.nodes.length) {\n    var noOfVisitedInThisGraph = 0;\n\n    visited.forEach(function (visitedNode) {\n      if (visitedNode.owner == self) {\n        noOfVisitedInThisGraph++;\n      }\n    });\n\n    if (noOfVisitedInThisGraph == this.nodes.length) {\n      this.isConnected = true;\n    }\n  }\n};\n\nmodule.exports = LGraph;\n\n/***/ }),\n/* 12 */\n/***/ (function(module, exports) {\n\nfunction Integer() {}\n\nInteger.MAX_VALUE = 2147483647;\nInteger.MIN_VALUE = -2147483648;\n\nmodule.exports = Integer;\n\n/***/ }),\n/* 13 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar Integer = __webpack_require__(12);\nvar RectangleD = __webpack_require__(14);\nvar LayoutConstants = __webpack_require__(3);\nvar RandomSeed = __webpack_require__(15);\nvar PointD = __webpack_require__(16);\nvar HashSet = __webpack_require__(17);\n\nfunction LNode(gm, loc, size, vNode) {\n  //Alternative constructor 1 : LNode(LGraphManager gm, Point loc, Dimension size, Object vNode)\n  if (size == null && vNode == null) {\n    vNode = loc;\n  }\n\n  LGraphObject.call(this, vNode);\n\n  //Alternative constructor 2 : LNode(Layout layout, Object vNode)\n  if (gm.graphManager != null) gm = gm.graphManager;\n\n  this.estimatedSize = Integer.MIN_VALUE;\n  this.inclusionTreeDepth = Integer.MAX_VALUE;\n  this.vGraphObject = vNode;\n  this.edges = [];\n  this.graphManager = gm;\n\n  if (size != null && loc != null) this.rect = new RectangleD(loc.x, loc.y, size.width, size.height);else this.rect = new RectangleD();\n}\n\nLNode.prototype = Object.create(LGraphObject.prototype);\nfor (var prop in LGraphObject) {\n  LNode[prop] = LGraphObject[prop];\n}\n\nLNode.prototype.getEdges = function () {\n  return this.edges;\n};\n\nLNode.prototype.getChild = function () {\n  return this.child;\n};\n\nLNode.prototype.getOwner = function () {\n  //  if (this.owner != null) {\n  //    if (!(this.owner == null || this.owner.getNodes().indexOf(this) > -1)) {\n  //      throw \"assert failed\";\n  //    }\n  //  }\n\n  return this.owner;\n};\n\nLNode.prototype.getWidth = function () {\n  return this.rect.width;\n};\n\nLNode.prototype.setWidth = function (width) {\n  this.rect.width = width;\n};\n\nLNode.prototype.getHeight = function () {\n  return this.rect.height;\n};\n\nLNode.prototype.setHeight = function (height) {\n  this.rect.height = height;\n};\n\nLNode.prototype.getCenterX = function () {\n  return this.rect.x + this.rect.width / 2;\n};\n\nLNode.prototype.getCenterY = function () {\n  return this.rect.y + this.rect.height / 2;\n};\n\nLNode.prototype.getCenter = function () {\n  return new PointD(this.rect.x + this.rect.width / 2, this.rect.y + this.rect.height / 2);\n};\n\nLNode.prototype.getLocation = function () {\n  return new PointD(this.rect.x, this.rect.y);\n};\n\nLNode.prototype.getRect = function () {\n  return this.rect;\n};\n\nLNode.prototype.getDiagonal = function () {\n  return Math.sqrt(this.rect.width * this.rect.width + this.rect.height * this.rect.height);\n};\n\nLNode.prototype.setRect = function (upperLeft, dimension) {\n  this.rect.x = upperLeft.x;\n  this.rect.y = upperLeft.y;\n  this.rect.width = dimension.width;\n  this.rect.height = dimension.height;\n};\n\nLNode.prototype.setCenter = function (cx, cy) {\n  this.rect.x = cx - this.rect.width / 2;\n  this.rect.y = cy - this.rect.height / 2;\n};\n\nLNode.prototype.setLocation = function (x, y) {\n  this.rect.x = x;\n  this.rect.y = y;\n};\n\nLNode.prototype.moveBy = function (dx, dy) {\n  this.rect.x += dx;\n  this.rect.y += dy;\n};\n\nLNode.prototype.getEdgeListToNode = function (to) {\n  var edgeList = [];\n  var edge;\n  var self = this;\n\n  self.edges.forEach(function (edge) {\n\n    if (edge.target == to) {\n      if (edge.source != self) throw \"Incorrect edge source!\";\n\n      edgeList.push(edge);\n    }\n  });\n\n  return edgeList;\n};\n\nLNode.prototype.getEdgesBetween = function (other) {\n  var edgeList = [];\n  var edge;\n\n  var self = this;\n  self.edges.forEach(function (edge) {\n\n    if (!(edge.source == self || edge.target == self)) throw \"Incorrect edge source and/or target\";\n\n    if (edge.target == other || edge.source == other) {\n      edgeList.push(edge);\n    }\n  });\n\n  return edgeList;\n};\n\nLNode.prototype.getNeighborsList = function () {\n  var neighbors = new HashSet();\n  var edge;\n\n  var self = this;\n  self.edges.forEach(function (edge) {\n\n    if (edge.source == self) {\n      neighbors.add(edge.target);\n    } else {\n      if (edge.target != self) {\n        throw \"Incorrect incidency!\";\n      }\n\n      neighbors.add(edge.source);\n    }\n  });\n\n  return neighbors;\n};\n\nLNode.prototype.withChildren = function () {\n  var withNeighborsList = new Set();\n  var childNode;\n  var children;\n\n  withNeighborsList.add(this);\n\n  if (this.child != null) {\n    var nodes = this.child.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      childNode = nodes[i];\n      children = childNode.withChildren();\n      children.forEach(function (node) {\n        withNeighborsList.add(node);\n      });\n    }\n  }\n\n  return withNeighborsList;\n};\n\nLNode.prototype.getNoOfChildren = function () {\n  var noOfChildren = 0;\n  var childNode;\n\n  if (this.child == null) {\n    noOfChildren = 1;\n  } else {\n    var nodes = this.child.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      childNode = nodes[i];\n\n      noOfChildren += childNode.getNoOfChildren();\n    }\n  }\n\n  if (noOfChildren == 0) {\n    noOfChildren = 1;\n  }\n  return noOfChildren;\n};\n\nLNode.prototype.getEstimatedSize = function () {\n  if (this.estimatedSize == Integer.MIN_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.estimatedSize;\n};\n\nLNode.prototype.calcEstimatedSize = function () {\n  if (this.child == null) {\n    return this.estimatedSize = (this.rect.width + this.rect.height) / 2;\n  } else {\n    this.estimatedSize = this.child.calcEstimatedSize();\n    this.rect.width = this.estimatedSize;\n    this.rect.height = this.estimatedSize;\n\n    return this.estimatedSize;\n  }\n};\n\nLNode.prototype.scatter = function () {\n  var randomCenterX;\n  var randomCenterY;\n\n  var minX = -LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  var maxX = LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  randomCenterX = LayoutConstants.WORLD_CENTER_X + RandomSeed.nextDouble() * (maxX - minX) + minX;\n\n  var minY = -LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  var maxY = LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  randomCenterY = LayoutConstants.WORLD_CENTER_Y + RandomSeed.nextDouble() * (maxY - minY) + minY;\n\n  this.rect.x = randomCenterX;\n  this.rect.y = randomCenterY;\n};\n\nLNode.prototype.updateBounds = function () {\n  if (this.getChild() == null) {\n    throw \"assert failed\";\n  }\n  if (this.getChild().getNodes().length != 0) {\n    // wrap the children nodes by re-arranging the boundaries\n    var childGraph = this.getChild();\n    childGraph.updateBounds(true);\n\n    this.rect.x = childGraph.getLeft();\n    this.rect.y = childGraph.getTop();\n\n    this.setWidth(childGraph.getRight() - childGraph.getLeft());\n    this.setHeight(childGraph.getBottom() - childGraph.getTop());\n\n    // Update compound bounds considering its label properties    \n    if (LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS) {\n\n      var width = childGraph.getRight() - childGraph.getLeft();\n      var height = childGraph.getBottom() - childGraph.getTop();\n\n      if (this.labelWidth > width) {\n        this.rect.x -= (this.labelWidth - width) / 2;\n        this.setWidth(this.labelWidth);\n      }\n\n      if (this.labelHeight > height) {\n        if (this.labelPos == \"center\") {\n          this.rect.y -= (this.labelHeight - height) / 2;\n        } else if (this.labelPos == \"top\") {\n          this.rect.y -= this.labelHeight - height;\n        }\n        this.setHeight(this.labelHeight);\n      }\n    }\n  }\n};\n\nLNode.prototype.getInclusionTreeDepth = function () {\n  if (this.inclusionTreeDepth == Integer.MAX_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.inclusionTreeDepth;\n};\n\nLNode.prototype.transform = function (trans) {\n  var left = this.rect.x;\n\n  if (left > LayoutConstants.WORLD_BOUNDARY) {\n    left = LayoutConstants.WORLD_BOUNDARY;\n  } else if (left < -LayoutConstants.WORLD_BOUNDARY) {\n    left = -LayoutConstants.WORLD_BOUNDARY;\n  }\n\n  var top = this.rect.y;\n\n  if (top > LayoutConstants.WORLD_BOUNDARY) {\n    top = LayoutConstants.WORLD_BOUNDARY;\n  } else if (top < -LayoutConstants.WORLD_BOUNDARY) {\n    top = -LayoutConstants.WORLD_BOUNDARY;\n  }\n\n  var leftTop = new PointD(left, top);\n  var vLeftTop = trans.inverseTransformPoint(leftTop);\n\n  this.setLocation(vLeftTop.x, vLeftTop.y);\n};\n\nLNode.prototype.getLeft = function () {\n  return this.rect.x;\n};\n\nLNode.prototype.getRight = function () {\n  return this.rect.x + this.rect.width;\n};\n\nLNode.prototype.getTop = function () {\n  return this.rect.y;\n};\n\nLNode.prototype.getBottom = function () {\n  return this.rect.y + this.rect.height;\n};\n\nLNode.prototype.getParent = function () {\n  if (this.owner == null) {\n    return null;\n  }\n\n  return this.owner.getParent();\n};\n\nmodule.exports = LNode;\n\n/***/ }),\n/* 14 */\n/***/ (function(module, exports) {\n\nfunction RectangleD(x, y, width, height) {\n  this.x = 0;\n  this.y = 0;\n  this.width = 0;\n  this.height = 0;\n\n  if (x != null && y != null && width != null && height != null) {\n    this.x = x;\n    this.y = y;\n    this.width = width;\n    this.height = height;\n  }\n}\n\nRectangleD.prototype.getX = function () {\n  return this.x;\n};\n\nRectangleD.prototype.setX = function (x) {\n  this.x = x;\n};\n\nRectangleD.prototype.getY = function () {\n  return this.y;\n};\n\nRectangleD.prototype.setY = function (y) {\n  this.y = y;\n};\n\nRectangleD.prototype.getWidth = function () {\n  return this.width;\n};\n\nRectangleD.prototype.setWidth = function (width) {\n  this.width = width;\n};\n\nRectangleD.prototype.getHeight = function () {\n  return this.height;\n};\n\nRectangleD.prototype.setHeight = function (height) {\n  this.height = height;\n};\n\nRectangleD.prototype.getRight = function () {\n  return this.x + this.width;\n};\n\nRectangleD.prototype.getBottom = function () {\n  return this.y + this.height;\n};\n\nRectangleD.prototype.intersects = function (a) {\n  if (this.getRight() < a.x) {\n    return false;\n  }\n\n  if (this.getBottom() < a.y) {\n    return false;\n  }\n\n  if (a.getRight() < this.x) {\n    return false;\n  }\n\n  if (a.getBottom() < this.y) {\n    return false;\n  }\n\n  return true;\n};\n\nRectangleD.prototype.getCenterX = function () {\n  return this.x + this.width / 2;\n};\n\nRectangleD.prototype.getMinX = function () {\n  return this.getX();\n};\n\nRectangleD.prototype.getMaxX = function () {\n  return this.getX() + this.width;\n};\n\nRectangleD.prototype.getCenterY = function () {\n  return this.y + this.height / 2;\n};\n\nRectangleD.prototype.getMinY = function () {\n  return this.getY();\n};\n\nRectangleD.prototype.getMaxY = function () {\n  return this.getY() + this.height;\n};\n\nRectangleD.prototype.getWidthHalf = function () {\n  return this.width / 2;\n};\n\nRectangleD.prototype.getHeightHalf = function () {\n  return this.height / 2;\n};\n\nmodule.exports = RectangleD;\n\n/***/ }),\n/* 15 */\n/***/ (function(module, exports) {\n\nfunction RandomSeed() {}\nRandomSeed.seed = 1;\nRandomSeed.x = 0;\n\nRandomSeed.nextDouble = function () {\n  RandomSeed.x = Math.sin(RandomSeed.seed++) * 10000;\n  return RandomSeed.x - Math.floor(RandomSeed.x);\n};\n\nmodule.exports = RandomSeed;\n\n/***/ }),\n/* 16 */\n/***/ (function(module, exports) {\n\nfunction PointD(x, y) {\n  if (x == null && y == null) {\n    this.x = 0;\n    this.y = 0;\n  } else {\n    this.x = x;\n    this.y = y;\n  }\n}\n\nPointD.prototype.getX = function () {\n  return this.x;\n};\n\nPointD.prototype.getY = function () {\n  return this.y;\n};\n\nPointD.prototype.setX = function (x) {\n  this.x = x;\n};\n\nPointD.prototype.setY = function (y) {\n  this.y = y;\n};\n\nPointD.prototype.getDifference = function (pt) {\n  return new DimensionD(this.x - pt.x, this.y - pt.y);\n};\n\nPointD.prototype.getCopy = function () {\n  return new PointD(this.x, this.y);\n};\n\nPointD.prototype.translate = function (dim) {\n  this.x += dim.width;\n  this.y += dim.height;\n  return this;\n};\n\nmodule.exports = PointD;\n\n/***/ }),\n/* 17 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar UniqueIDGeneretor = __webpack_require__(5);\n\nfunction HashSet() {\n  this.set = {};\n}\n;\n\nHashSet.prototype.add = function (obj) {\n  var theId = UniqueIDGeneretor.createID(obj);\n  if (!this.contains(theId)) this.set[theId] = obj;\n};\n\nHashSet.prototype.remove = function (obj) {\n  delete this.set[UniqueIDGeneretor.createID(obj)];\n};\n\nHashSet.prototype.clear = function () {\n  this.set = {};\n};\n\nHashSet.prototype.contains = function (obj) {\n  return this.set[UniqueIDGeneretor.createID(obj)] == obj;\n};\n\nHashSet.prototype.isEmpty = function () {\n  return this.size() === 0;\n};\n\nHashSet.prototype.size = function () {\n  return Object.keys(this.set).length;\n};\n\n//concats this.set to the given list\nHashSet.prototype.addAllTo = function (list) {\n  var keys = Object.keys(this.set);\n  var length = keys.length;\n  for (var i = 0; i < length; i++) {\n    list.push(this.set[keys[i]]);\n  }\n};\n\nHashSet.prototype.size = function () {\n  return Object.keys(this.set).length;\n};\n\nHashSet.prototype.addAll = function (list) {\n  var s = list.length;\n  for (var i = 0; i < s; i++) {\n    var v = list[i];\n    this.add(v);\n  }\n};\n\nmodule.exports = HashSet;\n\n/***/ }),\n/* 18 */\n/***/ (function(module, exports) {\n\n/*\r\n *This class is the javascript implementation of the Point.java class in jdk\r\n */\nfunction Point(x, y, p) {\n  this.x = null;\n  this.y = null;\n  if (x == null && y == null && p == null) {\n    this.x = 0;\n    this.y = 0;\n  } else if (typeof x == 'number' && typeof y == 'number' && p == null) {\n    this.x = x;\n    this.y = y;\n  } else if (x.constructor.name == 'Point' && y == null && p == null) {\n    p = x;\n    this.x = p.x;\n    this.y = p.y;\n  }\n}\n\nPoint.prototype.getX = function () {\n  return this.x;\n};\n\nPoint.prototype.getY = function () {\n  return this.y;\n};\n\nPoint.prototype.getLocation = function () {\n  return new Point(this.x, this.y);\n};\n\nPoint.prototype.setLocation = function (x, y, p) {\n  if (x.constructor.name == 'Point' && y == null && p == null) {\n    p = x;\n    this.setLocation(p.x, p.y);\n  } else if (typeof x == 'number' && typeof y == 'number' && p == null) {\n    //if both parameters are integer just move (x,y) location\n    if (parseInt(x) == x && parseInt(y) == y) {\n      this.move(x, y);\n    } else {\n      this.x = Math.floor(x + 0.5);\n      this.y = Math.floor(y + 0.5);\n    }\n  }\n};\n\nPoint.prototype.move = function (x, y) {\n  this.x = x;\n  this.y = y;\n};\n\nPoint.prototype.translate = function (dx, dy) {\n  this.x += dx;\n  this.y += dy;\n};\n\nPoint.prototype.equals = function (obj) {\n  if (obj.constructor.name == \"Point\") {\n    var pt = obj;\n    return this.x == pt.x && this.y == pt.y;\n  }\n  return this == obj;\n};\n\nPoint.prototype.toString = function () {\n  return new Point().constructor.name + \"[x=\" + this.x + \",y=\" + this.y + \"]\";\n};\n\nmodule.exports = Point;\n\n/***/ }),\n/* 19 */\n/***/ (function(module, exports) {\n\nconst nodeFrom = value => ({ value, next: null, prev: null });\n\nconst add = (prev, node, next, list) => {\n  if (prev !== null) {\n    prev.next = node;\n  } else {\n    list.head = node;\n  }\n\n  if (next !== null) {\n    next.prev = node;\n  } else {\n    list.tail = node;\n  }\n\n  node.prev = prev;\n  node.next = next;\n\n  list.length++;\n\n  return node;\n};\n\nconst remove = (node, list) => {\n  let { prev, next } = node;\n\n  if (prev !== null) {\n    prev.next = next;\n  } else {\n    list.head = next;\n  }\n\n  if (next !== null) {\n    next.prev = prev;\n  } else {\n    list.tail = prev;\n  }\n\n  node.prev = node.next = null;\n\n  list.length--;\n\n  return node;\n};\n\nclass LinkedList {\n  constructor(vals) {\n    this.length = 0;\n    this.head = null;\n    this.tail = null;\n\n    if (vals != null) {\n      vals.forEach(v => this.push(v));\n    }\n  }\n\n  size() {\n    return this.length;\n  }\n\n  insertBefore(val, otherNode) {\n    return add(otherNode.prev, nodeFrom(val), otherNode, this);\n  }\n\n  insertAfter(val, otherNode) {\n    return add(otherNode, nodeFrom(val), otherNode.next, this);\n  }\n\n  insertNodeBefore(newNode, otherNode) {\n    return add(otherNode.prev, newNode, otherNode, this);\n  }\n\n  insertNodeAfter(newNode, otherNode) {\n    return add(otherNode, newNode, otherNode.next, this);\n  }\n\n  push(val) {\n    return add(this.tail, nodeFrom(val), null, this);\n  }\n\n  unshift(val) {\n    return add(null, nodeFrom(val), this.head, this);\n  }\n\n  remove(node) {\n    return remove(node, this);\n  }\n\n  pop() {\n    return remove(this.tail, this).value;\n  }\n\n  popNode() {\n    return remove(this.tail, this);\n  }\n\n  shift() {\n    return remove(this.head, this).value;\n  }\n\n  shiftNode() {\n    return remove(this.head, this);\n  }\n\n  get_object_at(index) {\n    if (index <= this.length()) {\n      var i = 1;\n      var current = this.head;\n      while (i < index) {\n        current = current.next;\n        i++;\n      }\n      return current.value;\n    }\n  }\n\n  set_object_at(index, value) {\n    if (index <= this.length()) {\n      var i = 1;\n      var current = this.head;\n      while (i < index) {\n        current = current.next;\n        i++;\n      }\n      current.value = value;\n    }\n  }\n}\n\nmodule.exports = LinkedList;\n\n/***/ }),\n/* 20 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar PointD = __webpack_require__(16);\n\nfunction Transform(x, y) {\n  this.lworldOrgX = 0.0;\n  this.lworldOrgY = 0.0;\n  this.ldeviceOrgX = 0.0;\n  this.ldeviceOrgY = 0.0;\n  this.lworldExtX = 1.0;\n  this.lworldExtY = 1.0;\n  this.ldeviceExtX = 1.0;\n  this.ldeviceExtY = 1.0;\n}\n\nTransform.prototype.getWorldOrgX = function () {\n  return this.lworldOrgX;\n};\n\nTransform.prototype.setWorldOrgX = function (wox) {\n  this.lworldOrgX = wox;\n};\n\nTransform.prototype.getWorldOrgY = function () {\n  return this.lworldOrgY;\n};\n\nTransform.prototype.setWorldOrgY = function (woy) {\n  this.lworldOrgY = woy;\n};\n\nTransform.prototype.getWorldExtX = function () {\n  return this.lworldExtX;\n};\n\nTransform.prototype.setWorldExtX = function (wex) {\n  this.lworldExtX = wex;\n};\n\nTransform.prototype.getWorldExtY = function () {\n  return this.lworldExtY;\n};\n\nTransform.prototype.setWorldExtY = function (wey) {\n  this.lworldExtY = wey;\n};\n\n/* Device related */\n\nTransform.prototype.getDeviceOrgX = function () {\n  return this.ldeviceOrgX;\n};\n\nTransform.prototype.setDeviceOrgX = function (dox) {\n  this.ldeviceOrgX = dox;\n};\n\nTransform.prototype.getDeviceOrgY = function () {\n  return this.ldeviceOrgY;\n};\n\nTransform.prototype.setDeviceOrgY = function (doy) {\n  this.ldeviceOrgY = doy;\n};\n\nTransform.prototype.getDeviceExtX = function () {\n  return this.ldeviceExtX;\n};\n\nTransform.prototype.setDeviceExtX = function (dex) {\n  this.ldeviceExtX = dex;\n};\n\nTransform.prototype.getDeviceExtY = function () {\n  return this.ldeviceExtY;\n};\n\nTransform.prototype.setDeviceExtY = function (dey) {\n  this.ldeviceExtY = dey;\n};\n\nTransform.prototype.transformX = function (x) {\n  var xDevice = 0.0;\n  var worldExtX = this.lworldExtX;\n  if (worldExtX != 0.0) {\n    xDevice = this.ldeviceOrgX + (x - this.lworldOrgX) * this.ldeviceExtX / worldExtX;\n  }\n\n  return xDevice;\n};\n\nTransform.prototype.transformY = function (y) {\n  var yDevice = 0.0;\n  var worldExtY = this.lworldExtY;\n  if (worldExtY != 0.0) {\n    yDevice = this.ldeviceOrgY + (y - this.lworldOrgY) * this.ldeviceExtY / worldExtY;\n  }\n\n  return yDevice;\n};\n\nTransform.prototype.inverseTransformX = function (x) {\n  var xWorld = 0.0;\n  var deviceExtX = this.ldeviceExtX;\n  if (deviceExtX != 0.0) {\n    xWorld = this.lworldOrgX + (x - this.ldeviceOrgX) * this.lworldExtX / deviceExtX;\n  }\n\n  return xWorld;\n};\n\nTransform.prototype.inverseTransformY = function (y) {\n  var yWorld = 0.0;\n  var deviceExtY = this.ldeviceExtY;\n  if (deviceExtY != 0.0) {\n    yWorld = this.lworldOrgY + (y - this.ldeviceOrgY) * this.lworldExtY / deviceExtY;\n  }\n  return yWorld;\n};\n\nTransform.prototype.inverseTransformPoint = function (inPoint) {\n  var outPoint = new PointD(this.inverseTransformX(inPoint.x), this.inverseTransformY(inPoint.y));\n  return outPoint;\n};\n\nmodule.exports = Transform;\n\n/***/ }),\n/* 21 */\n/***/ (function(module, exports) {\n\nfunction Emitter() {\n  this.listeners = [];\n}\n\nvar p = Emitter.prototype;\n\np.addListener = function (event, callback) {\n  this.listeners.push({\n    event: event,\n    callback: callback\n  });\n};\n\np.removeListener = function (event, callback) {\n  for (var i = this.listeners.length; i >= 0; i--) {\n    var l = this.listeners[i];\n\n    if (l.event === event && l.callback === callback) {\n      this.listeners.splice(i, 1);\n    }\n  }\n};\n\np.emit = function (event, data) {\n  for (var i = 0; i < this.listeners.length; i++) {\n    var l = this.listeners[i];\n\n    if (event === l.event) {\n      l.callback(data);\n    }\n  }\n};\n\nmodule.exports = Emitter;\n\n/***/ }),\n/* 22 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LayoutConstants = __webpack_require__(3);\n\nfunction FDLayoutConstants() {}\n\n//FDLayoutConstants inherits static props in LayoutConstants\nfor (var prop in LayoutConstants) {\n  FDLayoutConstants[prop] = LayoutConstants[prop];\n}\n\nFDLayoutConstants.MAX_ITERATIONS = 2500;\n\nFDLayoutConstants.DEFAULT_EDGE_LENGTH = 50;\nFDLayoutConstants.DEFAULT_SPRING_STRENGTH = 0.45;\nFDLayoutConstants.DEFAULT_REPULSION_STRENGTH = 4500.0;\nFDLayoutConstants.DEFAULT_GRAVITY_STRENGTH = 0.4;\nFDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = 1.0;\nFDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR = 3.8;\nFDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = 1.5;\nFDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION = true;\nFDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION = true;\nFDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = 0.5;\nFDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL = 100.0;\nFDLayoutConstants.MAX_NODE_DISPLACEMENT = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL * 3;\nFDLayoutConstants.MIN_REPULSION_DIST = FDLayoutConstants.DEFAULT_EDGE_LENGTH / 10.0;\nFDLayoutConstants.CONVERGENCE_CHECK_PERIOD = 100;\nFDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = 0.1;\nFDLayoutConstants.MIN_EDGE_LENGTH = 1;\nFDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD = 10;\n\nmodule.exports = FDLayoutConstants;\n\n/***/ }),\n/* 23 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LEdge = __webpack_require__(7);\nvar FDLayoutConstants = __webpack_require__(22);\n\nfunction FDLayoutEdge(source, target, vEdge) {\n  LEdge.call(this, source, target, vEdge);\n  this.idealLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH;\n}\n\nFDLayoutEdge.prototype = Object.create(LEdge.prototype);\n\nfor (var prop in LEdge) {\n  FDLayoutEdge[prop] = LEdge[prop];\n}\n\nmodule.exports = FDLayoutEdge;\n\n/***/ }),\n/* 24 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LNode = __webpack_require__(13);\n\nfunction FDLayoutNode(gm, loc, size, vNode) {\n  // alternative constructor is handled inside LNode\n  LNode.call(this, gm, loc, size, vNode);\n  //Spring, repulsion and gravitational forces acting on this node\n  this.springForceX = 0;\n  this.springForceY = 0;\n  this.repulsionForceX = 0;\n  this.repulsionForceY = 0;\n  this.gravitationForceX = 0;\n  this.gravitationForceY = 0;\n  //Amount by which this node is to be moved in this iteration\n  this.displacementX = 0;\n  this.displacementY = 0;\n\n  //Start and finish grid coordinates that this node is fallen into\n  this.startX = 0;\n  this.finishX = 0;\n  this.startY = 0;\n  this.finishY = 0;\n\n  //Geometric neighbors of this node\n  this.surrounding = [];\n}\n\nFDLayoutNode.prototype = Object.create(LNode.prototype);\n\nfor (var prop in LNode) {\n  FDLayoutNode[prop] = LNode[prop];\n}\n\nFDLayoutNode.prototype.setGridCoordinates = function (_startX, _finishX, _startY, _finishY) {\n  this.startX = _startX;\n  this.finishX = _finishX;\n  this.startY = _startY;\n  this.finishY = _finishY;\n};\n\nmodule.exports = FDLayoutNode;\n\n/***/ }),\n/* 25 */\n/***/ (function(module, exports) {\n\nfunction DimensionD(width, height) {\n  this.width = 0;\n  this.height = 0;\n  if (width !== null && height !== null) {\n    this.height = height;\n    this.width = width;\n  }\n}\n\nDimensionD.prototype.getWidth = function () {\n  return this.width;\n};\n\nDimensionD.prototype.setWidth = function (width) {\n  this.width = width;\n};\n\nDimensionD.prototype.getHeight = function () {\n  return this.height;\n};\n\nDimensionD.prototype.setHeight = function (height) {\n  this.height = height;\n};\n\nmodule.exports = DimensionD;\n\n/***/ }),\n/* 26 */\n/***/ (function(module, exports, __webpack_require__) {\n\nconst LinkedList = __webpack_require__(19);\n\nfunction Quicksort() {}\n\nQuicksort.get_object_at = function (list, i) {\n    if (list instanceof Array) {\n        return list[i];\n    } else if (list instanceof LinkedList) {\n        return list.get_object_at(i);\n    }\n};\n\nQuicksort.set_object_at = function (list, i, value) {\n    if (list instanceof Array) {\n        list[i] = value;\n    } else if (list instanceof LinkedList) {\n        list.set_object_at(i, value);\n    }\n};\n\nQuicksort.quicksort = function (list, comparison_fn) {\n\n    // input must be an instance of LinkedList class or must be an array in order to sort\n    if (!(list instanceof LinkedList || list instanceof Array)) {\n        return;\n    }\n\n    var comparison_function = comparison_fn;\n\n    if (comparison_function === undefined) {\n        comparison_function = Quicksort.compare;\n    }\n    var end_index;\n\n    if (list instanceof LinkedList) {\n        end_index = list.size();\n    } else if (list instanceof Array) {\n        end_index = list.length - 1;\n    }\n\n    // Prevent empty lists or arrays.\n    if (end_index >= 0) {\n        Quicksort.quicksort_between_indices(list, 0, end_index, comparison_function);\n    }\n};\n\nQuicksort.quicksort_between_indices = function (list, low, high, comparison_fn) {\n\n    // input must be an instance of LinkedList class or must be an array in order to sort\n    if (!(list instanceof LinkedList || list instanceof Array)) {\n        return;\n    }\n\n    if (comparison_fn === undefined) {\n        comparison_fn = Quicksort.compare;\n    }\n\n    var i = low;\n    var j = high;\n    var middleIndex = Math.floor((i + j) / 2);\n    var middle = Quicksort.get_object_at(list, middleIndex);\n\n    do {\n\n        while (comparison_fn(Quicksort.get_object_at(list, i), middle)) {\n\n            i++;\n        }\n\n        while (comparison_fn(middle, Quicksort.get_object_at(list, j))) {\n\n            j--;\n        }\n\n        if (i <= j) {\n\n            var temp = Quicksort.get_object_at(list, i);\n            Quicksort.set_object_at(list, i, Quicksort.get_object_at(list, j));\n            Quicksort.set_object_at(list, j, temp);\n            i++;\n            j--;\n        }\n    } while (i <= j);\n\n    if (low < j) {\n\n        Quicksort.quicksort_between_indices(list, low, j, comparison_fn);\n    }\n\n    if (high > i) {\n\n        Quicksort.quicksort_between_indices(list, i, high, comparison_fn);\n    }\n};\n\n// this function must be overriden for sorting different data types(e.g. string, integer etc.)\nQuicksort.compare = function (a, b) {\n    return b > a;\n};\n\nmodule.exports = Quicksort;\n\n/***/ })\n/******/ ]);\n});\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LayoutConstants = __webpack_require__(1).LayoutConstants;\n\nfunction AVSDFConstants() {}\n\n// AVSDFConstants inherits properties in LayoutConstants\nfor (var prop in LayoutConstants) {\n    AVSDFConstants[prop] = LayoutConstants[prop];\n}\n\nAVSDFConstants.DEFAULT_NODE_SEPARATION = 60;\n\nmodule.exports = AVSDFConstants;\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports, __webpack_require__) {\n\n/**\n * This class implements data and functionality required for AVSDF layout per\n * edge.\n *\n\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LEdge = __webpack_require__(1).LEdge;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFEdge(source, target, vEdge) {\n    LEdge.call(this, source, target, vEdge);\n}\n\nAVSDFEdge.prototype = Object.create(LEdge.prototype);\n\nfor (let properties in LEdge) {\n    AVSDFEdge[properties] = LEdge[properties];\n}\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// The function getOtherEnd returns the other end of this edge.\nAVSDFEdge.prototype.getOtherEnd = function (node) {\n    return LEdge.prototype.getOtherEnd(node);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function checks whether this edge crosses with the input edge. It\n// returns false, if any of the vertices those edges are incident to are not\n// yet placed on the circle.\nAVSDFEdge.prototype.crossesWithEdge = function (otherEdge) {\n    let self = this;\n    let sourcePos = self.getSource().getIndex();\n    let targetPos = self.getTarget().getIndex();\n    let otherSourcePos = otherEdge.getSource().getIndex();\n    let otherTargetPos = otherEdge.getTarget().getIndex();\n\n    // if any of the vertices those two edges are not yet placed\n    if (sourcePos === -1 || targetPos === -1 || otherSourcePos === -1 || otherTargetPos === -1) {\n        return false;\n    }\n\n    let otherSourceDist = otherEdge.getSource().getCircDistWithTheNode(self.getSource());\n    let otherTargetDist = otherEdge.getTarget().getCircDistWithTheNode(self.getSource());\n    let thisTargetDist = self.getTarget().getCircDistWithTheNode(self.getSource());\n\n    if (thisTargetDist < Math.max(otherSourceDist, otherTargetDist) && thisTargetDist > Math.min(otherSourceDist, otherTargetDist) && otherTargetDist !== 0 && otherSourceDist !== 0) {\n        return true;\n    }\n\n    return false;\n};\n\n// This function returns 1 if this edge crosses with the input edge, 0\n// otherwise.\nAVSDFEdge.prototype.crossingWithEdge = function (otherEdge) {\n    let self = this;\n    let result = self.crossesWithEdge(otherEdge);\n\n    return result ? 1 : 0;\n};\n\n// This function calculates the total number of crossings of this edge with\n// all the edges given in the input list.\nAVSDFEdge.prototype.calculateTotalCrossingWithList = function (edgeList) {\n    let self = this;\n    let totalCrossing = 0;\n\n    edgeList.forEach(edge => totalCrossing += self.crossingWithEdge(edge));\n\n    return totalCrossing;\n};\n\nmodule.exports = AVSDFEdge;\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports, __webpack_require__) {\n\n/**\n * This class implements data and functionality required for AVSDF layout per\n * circle.\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LGraph = __webpack_require__(1).LGraph;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFCircle(parent, graphMgr, vObject) {\n    LGraph.call(this, parent, graphMgr, vObject);\n    this.inOrder = undefined;\n    this.currentIndex = 0;\n    this.nodeSeparation = undefined;\n    this.stack = [];\n    this.perimeter = 0;\n    this.centerX = 0;\n    this.centerY = 0;\n    this.radius = 0;\n}\n\nAVSDFCircle.prototype = Object.create(LGraph.prototype);\n\nfor (let property in LGraph) {\n    AVSDFCircle[property] = LGraph[property];\n}\n\nAVSDFCircle.prototype.initOrdering = function () {\n    this.inOrder = [];\n};\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the array in which the nodes of this circle are kept in order.\nAVSDFCircle.prototype.getOrder = function () {\n    return this.inOrder;\n};\n\n// This function returns the x-coordinate of the center of this circle.\nAVSDFCircle.prototype.getCenterX = function () {\n    return this.centerX;\n};\n\n// This function returns the y-coordinate of the center of this circle.\nAVSDFCircle.prototype.getCenterY = function () {\n    return this.centerY;\n};\n\n// This function returns the radius of this circle.\nAVSDFCircle.prototype.getRadius = function () {\n    return this.radius;\n};\n\n// This function returns the total number of vertices of this circle.\nAVSDFCircle.prototype.getSize = function () {\n    return this.getNodes().length;\n};\n\n// This function calculates and returns the total number of crossings in this\n// circle by adding up the crossing number of individual nodes on it.\nAVSDFCircle.prototype.getTotalCrossingOfCircle = function () {\n    let self = this;\n    let crossingNumber = 0;\n\n    for (let node in self.inOrder) {\n        let nodeCrossing = node.getTotalCrossingOfEdges();\n        if (nodeCrossing === -1) {\n            return -1;\n        }\n        crossingNumber += nodeCrossing;\n    }\n\n    return crossingNumber / 4;\n};\n\n// This function checks whether or not all of the vertices of this circle are\n// assigned an index on the circle.\nAVSDFCircle.prototype.hasFinishedOrdering = function () {\n    return this.currentIndex === this.getNodes().length;\n};\n\n// This function returns the node separation of this circle.\nAVSDFCircle.prototype.getNodeSeparation = function () {\n    return this.nodeSeparation;\n};\n\n// This function sets the node separation of this circle.\nAVSDFCircle.prototype.setNodeSeparation = function (nodeSeparation) {\n    this.nodeSeparation = nodeSeparation;\n};\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function traverses the vertices of this circle and corrects the angle\n// of the vertices with respect to their circle indices.\nAVSDFCircle.prototype.correctAngles = function () {\n    let self = this;\n    self.currentIndex = 0;\n\n    self.inOrder.forEach(node => self.putInOrder(node));\n};\n\n// This function puts the given node on the circle in the current order and\n// sets its angle appropriately.\nAVSDFCircle.prototype.putInOrder = function (node) {\n    let self = this;\n\n    let nodes = self.getNodes();\n\n    // Note that id attribute of a node is added before\n    // AVSDFLayout is called\n    let found = false;\n    for (let i = 0; i < nodes.length; i++) {\n        if (nodes[i].id == node.id) {\n            found = true;\n            break;\n        }\n    }\n\n    if (!found) {\n        throw \"The node must be a member of LGraph\";\n    }\n\n    self.inOrder[self.currentIndex] = node;\n    node.setIndex(self.currentIndex);\n\n    if (self.currentIndex === 0) {\n        node.setAngle(0.0);\n    } else {\n        node.setAngle(self.inOrder[self.currentIndex - 1].getAngle() + 2 * Math.PI * (node.getDiagonal() / 2 + self.nodeSeparation + self.inOrder[self.currentIndex - 1].getDiagonal() / 2) / self.perimeter);\n    }\n\n    self.currentIndex++;\n};\n\n// This function returns the next node to be placed on this circle with\n// respect to the AVSDF algorithm.\nAVSDFCircle.prototype.findNodeToPlace = function () {\n    let self = this;\n    let sDegreeNode = undefined;\n\n    // Find the smallest degree vertex if the stack is empty\n    if (self.stack.length === 0) {\n        sDegreeNode = self.findUnorderedSmallestDegreeNode();\n    }\n    // Find the first vertex in the stack not yet placed\n    else {\n            let foundUnorderNode = false;\n\n            while (!foundUnorderNode && !(self.stack.length === 0)) {\n                sDegreeNode = self.stack.pop();\n                foundUnorderNode = !sDegreeNode.isOrdered();\n            }\n\n            if (!foundUnorderNode) {\n                sDegreeNode = undefined;\n            }\n        }\n\n    // If no unordered vertex is found in the stack, find one\n    // from the remaining ones\n    if (sDegreeNode === undefined) {\n        sDegreeNode = self.findUnorderedSmallestDegreeNode();\n    }\n\n    // Add the unordered neighbors of this node to the stack\n    if (sDegreeNode !== undefined) {\n        let neighbors = sDegreeNode.getNeighborsSortedByDegree();\n\n        for (let i = neighbors.length - 1; i >= 0; i--) {\n            let neighbor = neighbors[i];\n\n            if (!neighbor.isOrdered()) // Check here for possible error\n                {\n                    self.stack.push(neighbor);\n                }\n        }\n    }\n\n    return sDegreeNode;\n};\n\n// This function calculates the radius of this circle with respect to the sizes\n// of the vertices and the node separation parameter.\nAVSDFCircle.prototype.calculateRadius = function () {\n    let self = this;\n    let totalDiagonal = 0;\n\n    self.getNodes().forEach(node => totalDiagonal += Math.sqrt(node.getWidth() * node.getWidth() + node.getHeight() * node.getHeight()));\n\n    self.perimeter = totalDiagonal + self.getNodes().length * self.nodeSeparation;\n    let radius = self.perimeter / (2 * Math.PI);\n\n    // Check here for possible error\n\n    self.getParent().setWidth(2 * radius);\n    self.getParent().setHeight(2 * radius);\n    self.getParent().setCenter(self.getParent().getWidth(), self.getParent().getHeight());\n\n    self.centerX = self.getParent().getCenterX();\n    self.centerY = self.getParent().getCenterY();\n    self.radius = self.getParent().getHeight() / 2;\n};\n\n// This function calculates the total number of crossings of all vertices of\n// this circle.\nAVSDFCircle.prototype.calculateEdgeCrossingsOfNodes = function () {\n    this.getNodes().forEach(node => node.calculateTotalCrossing());\n};\n\n// This function sets the index of each vertex to its position in inOrder\n// array. Note that index of a node can be different from its place in the\n// array due to crossing reduction phase of the AVSDF algorithm. It loads\n// old index values to vertices due to an increase in the number of\n// crossings with the new indices.\nAVSDFCircle.prototype.loadOldIndicesOfNodes = function () {\n    //this.inOrder.forEach( (node,index) => node.setIndex(index));\n    var self = this;\n    for (let i = 0; i < this.inOrder.length; i++) {\n        self.inOrder[i].setIndex(i);\n    }\n};\n\n// This function sets the position of each node in inOrder array to its index.\n// Note that index of a node can be different from its place in the inOrder\n// array due to crossing reduction phase of the AVSDF algorithm. This function\n// puts the nodes to their new index values in inOrder array due to a\n// decrease in the number of crossings with the new indices.\nAVSDFCircle.prototype.reOrderVertices = function () {\n    var self = this;\n    this.getNodes().forEach(node => self.inOrder[node.getIndex()] = node);\n};\n\n// This function finds and returns the unordered smallest degree vertex on\n// this circle.\nAVSDFCircle.prototype.findUnorderedSmallestDegreeNode = function () {\n    let minDegree = Number.MAX_SAFE_INTEGER;\n    let sDegreeNode;\n\n    this.getNodes().forEach(function (node) {\n        if (node.getDegree() < minDegree && !node.isOrdered()) {\n            minDegree = node.getDegree();\n            sDegreeNode = node;\n        }\n    });\n\n    return sDegreeNode;\n};\n\nmodule.exports = AVSDFCircle;\n\n/***/ }),\n/* 5 */\n/***/ (function(module, exports, __webpack_require__) {\n\n/**\n * This class implements the overall layout process for the AVSDF algorithm\n * (Circular Drawing Algorithm by He and Sykora).\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet Layout = __webpack_require__(1).Layout;\nlet AVSDFConstants = __webpack_require__(2);\nlet AVSDFCircle = __webpack_require__(4);\nlet AVSDFNode = __webpack_require__(6);\nlet AVSDFEdge = __webpack_require__(3);\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\n// Constructor\nfunction AVSDFLayout() {\n    Layout.call(this);\n    this.nodeSeparation = AVSDFConstants.DEFAULT_NODE_SEPARATION;\n}\n\nAVSDFLayout.prototype = Object.create(Layout.prototype);\n\nfor (let property in Layout) {\n    AVSDFLayout[property] = Layout[property];\n}\n\nAVSDFLayout.prototype.newGraph = function (vObject) {\n    this.avsdfCircle = new AVSDFCircle(null, this.graphManager, vObject);\n\n    return this.avsdfCircle;\n};\n\nAVSDFLayout.prototype.newNode = function (vNode) {\n    return new AVSDFNode(this.graphManager, vNode);\n};\n\nAVSDFLayout.prototype.newEdge = function (vEdge) {\n    return new AVSDFEdge(null, null, vEdge);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the position data for all nodes\nAVSDFLayout.prototype.getPositionsData = function () {\n    var allNodes = this.graphManager.getAllNodes();\n    var pData = {};\n\n    for (var i = 0; i < allNodes.length; i++) {\n        var rect = allNodes[i].rect;\n        var id = allNodes[i].id;\n\n        pData[id] = {\n            id: id,\n            x: rect.getCenterX(),\n            y: rect.getCenterY(),\n            w: rect.width,\n            h: rect.height\n        };\n    }\n\n    return pData;\n};\n\n// -----------------------------------------------------------------------------\n// Section: Layout Related\n// -----------------------------------------------------------------------------\n\n/**\n * This function performs layout on constructed l-level graph.\n * It returns true on success, false otherwise.\n * Important!: If you want to see the results of this function then, after this function is called, you have to calculate\n * and set the positions of every node. To do this call updateNodeCoordinates. However, updateNodeAngles on the other\n * hand is not needed (redundant) for this function.\n */\nAVSDFLayout.prototype.layout = function () {\n    let self = this;\n\n    // Check if graph contains any compound structures\n    if (self.graphManager.getGraphs().length > 1) {\n        return false;\n    }\n\n    let clusterGraph = this.avsdfCircle; // Fixed reference, but now it is a bit redundant\n\n    clusterGraph.setNodeSeparation(this.nodeSeparation);\n    clusterGraph.calculateRadius();\n    clusterGraph.initOrdering();\n\n    while (!clusterGraph.hasFinishedOrdering()) {\n        let node = clusterGraph.findNodeToPlace();\n        clusterGraph.putInOrder(node);\n    }\n\n    return true;\n};\n\n// This function updates the angle (in radians) property of AVSDFNode elements in the circle\nAVSDFLayout.prototype.updateNodeAngles = function () {\n    this.graphManager.getRoot().correctAngles(); //AVSDFCircle object\n};\n\n// This function traverses the vertices of the graph and sets their correct coordinates with respect to the owner circle.\nAVSDFLayout.prototype.updateNodeCoordinates = function () {\n    let clusterGraph = this.graphManager.getRoot();\n\n    clusterGraph.getNodes().forEach(function (node) {\n        node.setCenter(clusterGraph.getCenterX() + clusterGraph.getRadius() * Math.cos(node.getAngle()), clusterGraph.getCenterY() + clusterGraph.getRadius() * Math.sin(node.getAngle()));\n    });\n};\n\n// -----------------------------------------------------------------------------\n// Section: Post Processing\n// -----------------------------------------------------------------------------\n\n/**\n * This method implements the post processing step of the algorithm, which\n * tries to minimize the number of edges further with respect to the local\n * adjusting algorithm described by He and Sykora.\n */\nAVSDFLayout.prototype.initPostProcess = function () {\n    this.avsdfCircle.calculateEdgeCrossingsOfNodes();\n\n    let list = this.avsdfCircle.getNodes();\n\n    list.sort(function (a, b) {\n        return b.getTotalCrossingOfEdges() - a.getTotalCrossingOfEdges();\n    });\n\n    return list;\n};\n\nAVSDFLayout.prototype.oneStepPostProcess = function (node) {\n    let self = this;\n\n    let currentCrossingNumber = node.getTotalCrossingOfEdges();\n    let newCrossingNumber;\n\n    let neighbours = [];\n    node.getNeighborsList().addAllTo(neighbours);\n\n    for (let j = 0; j < neighbours.length; j++) {\n        let neighbour = neighbours[j];\n\n        let oldIndex = node.getIndex();\n        let newIndex = (neighbour.getIndex() + 1) % self.avsdfCircle.getSize();\n\n        if (oldIndex !== newIndex) {\n            node.setIndex(newIndex);\n\n            if (oldIndex < node.getIndex()) {\n                oldIndex += self.avsdfCircle.getSize();\n            }\n\n            let index = node.getIndex();\n\n            while (index < oldIndex) {\n                let temp = self.avsdfCircle.getOrder()[index % self.avsdfCircle.getSize()];\n                temp.setIndex((temp.getIndex() + 1) % self.avsdfCircle.getSize());\n                index += 1;\n            }\n\n            node.calculateTotalCrossing();\n            newCrossingNumber = node.getTotalCrossingOfEdges();\n\n            if (newCrossingNumber >= currentCrossingNumber) {\n                self.avsdfCircle.loadOldIndicesOfNodes();\n            } else {\n                self.avsdfCircle.reOrderVertices();\n                currentCrossingNumber = newCrossingNumber;\n            }\n        }\n    }\n};\n\nmodule.exports = AVSDFLayout;\n\n/***/ }),\n/* 6 */\n/***/ (function(module, exports, __webpack_require__) {\n\n/**\n * This class implements data and functionality required for AVSDF layout per\n * node.\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LNode = __webpack_require__(1).LNode;\nlet Quicksort = __webpack_require__(1).Quicksort;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFNode(gm, vNode, loc, size) {\n    // Constructor 1: AVSDFNode(gm, vNode, loc, size)\n    if (loc !== undefined && size !== undefined) {\n        LNode.call(this, gm, vNode, loc, size);\n    }\n    // Constructor 2: AVSDFNode(gm, vNode)\n    else {\n            LNode.call(this, gm, vNode);\n        }\n\n    // Angle of this node on the owner circle in radians\n    this.angle = 0;\n\n    // Index of this node on the owner circle\n    this.circleIndex = -1;\n\n    // Total number of crossings of the edges this node is incident to\n    this.totalCrossingOfEdges = -1;\n\n    // Whether the current edge crossing number is valid or it needs to be\n    // recalculated\n    this.isCrossingNumberValid = false;\n}\n\nAVSDFNode.prototype = Object.create(LNode.prototype);\nfor (let properties in LNode) {\n    AVSDFNode[properties] = LNode[properties];\n}\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the circle this node is owned by.\nAVSDFNode.prototype.getCircle = function () {\n    return this.getOwner();\n};\n\n// This function sets the index of this node on the circle, and sets the\n// crossing number invalid. Due to the index change of the node; it needs to\n// be recalculated.\nAVSDFNode.prototype.setIndex = function (index) {\n    this.circleIndex = index;\n    this.isCrossingNumberValid = false;\n};\n\n// This function returns the index of this node in the ordering of its owner\n// circle. Here -1 means that the vertex is not yet placed on its owner\n//circle.\nAVSDFNode.prototype.getIndex = function () {\n    return this.circleIndex;\n};\n\n// This function returns the array of the neigbors of this node sorted in\n// ascending order.\nAVSDFNode.prototype.getNeighborsSortedByDegree = function () {\n    let self = this;\n\n    let neighborsList = [];\n    self.getNeighborsList().addAllTo(neighborsList);\n    let result = neighborsList.filter(node => node.getIndex() === -1);\n\n    result.sort(function (a, b) {\n        return a.getDegree() - b.getDegree();\n    });\n\n    return result;\n};\n\n// This function returns the degree of this node.\nAVSDFNode.prototype.getDegree = function () {\n    return this.getEdges().length;\n};\n\n// This function returns whether or not this node is currently placed on its\n// owner circle.\nAVSDFNode.prototype.isOrdered = function () {\n    return this.getIndex() > -1;\n};\n\n// This function sets the angle of this node w.r.t. its owner circle. Here\n// the angle value is in radian.\nAVSDFNode.prototype.setAngle = function (angle) {\n    this.angle = angle;\n};\n\n// This function returns the angle of this node w.r.t. its owner circle. Here\n// the angle value is in radian.\nAVSDFNode.prototype.getAngle = function () {\n    return this.angle;\n};\n\n// This function returns the index difference of this node with the input\n// node. Note that the index difference cannot be negative if both nodes are\n// placed on the circle. Here -1 means at least one of the nodes are not yet\n// placed on the circle.\nAVSDFNode.prototype.getCircDistWithTheNode = function (refNode) {\n    let self = this;\n    let otherIndex = refNode.getIndex();\n\n    if (otherIndex === -1 || self.getIndex() === -1) {\n        return -1;\n    }\n\n    let diff = self.getIndex() - otherIndex;\n\n    if (diff < 0) {\n        diff += self.getCircle().getSize();\n    }\n\n    return diff;\n};\n\n// This function finds the number of edge crossings between the edges of\n// this node and the edges of the input one.\nAVSDFNode.prototype.getCrossingNumberWithNode = function (otherNode) {\n    let self = this;\n    let totalCrossing = 0;\n\n    self.getEdges().forEach(function (edge) {\n        otherNode.getEdges().forEach(function (otherEdge) {\n            totalCrossing += edge.crossingWithEdge(otherEdge);\n        });\n    });\n\n    return totalCrossing;\n};\n\n// This function returns the total number of edge crossings. If the previously\n// calculated value is not valid due to an index change on the circle, then\n// a recalculation is performed.\nAVSDFNode.prototype.getTotalCrossingOfEdges = function () {\n    let self = this;\n\n    if (!self.isCrossingNumberValid) {\n        self.calculateTotalCrossing();\n        self.isCrossingNumberValid = true;\n    }\n\n    return self.totalCrossingOfEdges;\n};\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function calculates the total number of crossings the edges of this\n// node cause.\nAVSDFNode.prototype.calculateTotalCrossing = function () {\n    let self = this;\n    let temp_crossing_count = 0;\n    let temp_edge_list = [];\n    temp_edge_list.push.apply(temp_edge_list, self.getCircle().getEdges());\n    temp_edge_list = temp_edge_list.filter(ele => self.getEdges().indexOf(ele) < 0);\n\n    self.getEdges().forEach(edge => temp_crossing_count += edge.calculateTotalCrossingWithList(temp_edge_list));\n\n    self.totalCrossingOfEdges = temp_crossing_count;\n};\n\nmodule.exports = AVSDFNode;\n\n/***/ })\n/******/ ]);\n});\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://avsdfBase/webpack/universalModuleDefinition","webpack://avsdfBase/webpack/bootstrap","webpack://avsdfBase/./index.js","webpack://avsdfBase/./node_modules/layout-base/layout-base.js","webpack://avsdfBase/./src/AVSDFConstants.js","webpack://avsdfBase/./src/AVSDFEdge.js","webpack://avsdfBase/./src/AVSDFCircle.js","webpack://avsdfBase/./src/AVSDFLayout.js","webpack://avsdfBase/./src/AVSDFNode.js"],"names":["avsdfBase","layoutBase","require","AVSDFConstants","AVSDFEdge","AVSDFCircle","AVSDFLayout","AVSDFNode","module","exports","LayoutConstants","prop","DEFAULT_NODE_SEPARATION","LEdge","source","target","vEdge","call","prototype","Object","create","properties","getOtherEnd","node","crossesWithEdge","otherEdge","self","sourcePos","getSource","getIndex","targetPos","getTarget","otherSourcePos","otherTargetPos","otherSourceDist","getCircDistWithTheNode","otherTargetDist","thisTargetDist","Math","max","min","crossingWithEdge","result","calculateTotalCrossingWithList","edgeList","totalCrossing","forEach","edge","LGraph","parent","graphMgr","vObject","inOrder","undefined","currentIndex","nodeSeparation","stack","perimeter","centerX","centerY","radius","property","initOrdering","getOrder","getCenterX","getCenterY","getRadius","getSize","getNodes","length","getTotalCrossingOfCircle","crossingNumber","nodeCrossing","getTotalCrossingOfEdges","hasFinishedOrdering","getNodeSeparation","setNodeSeparation","correctAngles","putInOrder","nodes","found","i","id","setIndex","setAngle","getAngle","PI","getDiagonal","findNodeToPlace","sDegreeNode","findUnorderedSmallestDegreeNode","foundUnorderNode","pop","isOrdered","neighbors","getNeighborsSortedByDegree","neighbor","push","calculateRadius","totalDiagonal","sqrt","getWidth","getHeight","getParent","setWidth","setHeight","setCenter","calculateEdgeCrossingsOfNodes","calculateTotalCrossing","loadOldIndicesOfNodes","reOrderVertices","minDegree","Number","MAX_SAFE_INTEGER","getDegree","Layout","newGraph","avsdfCircle","graphManager","newNode","vNode","newEdge","getPositionsData","allNodes","getAllNodes","pData","rect","x","y","w","width","h","height","layout","getGraphs","clusterGraph","updateNodeAngles","getRoot","updateNodeCoordinates","cos","sin","initPostProcess","list","sort","a","b","oneStepPostProcess","currentCrossingNumber","newCrossingNumber","neighbours","getNeighborsList","addAllTo","j","neighbour","oldIndex","newIndex","index","temp","LNode","Quicksort","gm","loc","size","angle","circleIndex","totalCrossingOfEdges","isCrossingNumberValid","getCircle","getOwner","neighborsList","filter","getEdges","refNode","otherIndex","diff","getCrossingNumberWithNode","otherNode","temp_crossing_count","temp_edge_list","apply","ele","indexOf"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;AClFa;;AAEb,IAAIA,YAAY,EAAhB;;AAEAA,UAAUC,UAAV,GAAuBC,mBAAOA,CAAC,CAAR,CAAvB;AACAF,UAAUG,cAAV,GAA2BD,mBAAOA,CAAC,CAAR,CAA3B;AACAF,UAAUI,SAAV,GAAsBF,mBAAOA,CAAC,CAAR,CAAtB;AACAF,UAAUK,WAAV,GAAwBH,mBAAOA,CAAC,CAAR,CAAxB;AACAF,UAAUM,WAAV,GAAwBJ,mBAAOA,CAAC,CAAR,CAAxB;AACAF,UAAUO,SAAV,GAAsBL,mBAAOA,CAAC,CAAR,CAAtB;;AAEAM,OAAOC,OAAP,GAAiBT,SAAjB,C;;;;;;ACXA;AACA,IAAI,IAAyD;AAC7D;AACA,MAAM,EAK2B;AACjC,CAAC;AACD,oCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,gCAAgC;AAClF;AACA;AACA;AACA;AACA;AACA;AACA,gEAAgE,kBAAkB;AAClF;AACA,yDAAyD,cAAc;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,iCAAiC;AAClF,wHAAwH,mBAAmB,EAAE;AAC7I;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,0BAA0B,EAAE;AAC/D,yCAAyC,eAAe;AACxD;AACA;AACA;AACA;AACA;AACA,8DAA8D,+DAA+D;AAC7H;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,qBAAqB;AACtC;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,eAAe,mBAAmB;AAClC;AACA;AACA;AACA;AACA,GAAG;AACH,eAAe,mBAAmB;AAClC;;AAEA,qBAAqB,mBAAmB;AACxC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,qBAAqB;AACtC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,iBAAiB,WAAW;AAC5B;AACA;;AAEA,iBAAiB,WAAW;AAC5B,mBAAmB,WAAW;AAC9B;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,sBAAsB,cAAc;AACpC,wBAAwB,cAAc;AACtC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,aAAa,mBAAmB;AAChC;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,uBAAuB;AACzD,oCAAoC,uBAAuB;AAC3D;AACA,yBAAyB,uBAAuB;AAChD;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,aAAa,8BAA8B;AAC3C;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,qBAAqB;AACxC;AACA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,qBAAqB,kBAAkB;AACvC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,qBAAqB,kBAAkB;AACvC;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA,mBAAmB,kBAAkB;AACrC;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,iBAAiB,qBAAqB;AACtC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,qBAAqB,0BAA0B;AAC/C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,iBAAiB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,iBAAiB,4BAA4B;AAC7C;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,iBAAiB,kBAAkB;AACnC;;AAEA;AACA;;AAEA,qBAAqB,iBAAiB;AACtC;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,iBAAiB;AAClC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,mBAAmB,iBAAiB;AACpC;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA,mCAAmC;AACnC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,mBAAmB;AACtC;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,6BAA6B;AAC7B;;AAEA;AACA;AACA,yBAAyB,KAAK;;AAE9B;AACA;AACA,yBAAyB,KAAK;;AAE9B;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,OAAO;AAC1B;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,iBAAiB,OAAO;AACxB;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,UAAU;AAC7B;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,qGAAqG;AACrG;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA,mBAAmB,kBAAkB;AACrC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB,YAAY;AAC7B;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,OAAO;AACxB;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA,4BAA4B,gCAAgC;;AAE5D;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,OAAO,aAAa;;AAEpB;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA,qCAAqC,QAAQ;AAC7C;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,2BAA2B;AAC5C;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,OAAO;AACP;AACA,CAAC,E;;;;;;ACp0HD,IAAIU,kBAAkBR,mBAAOA,CAAC,CAAR,EAAuBQ,eAA7C;;AAEA,SAASP,cAAT,GAAyB,CAAE;;AAE3B;AACA,KAAI,IAAIQ,IAAR,IAAgBD,eAAhB,EAAgC;AAC5BP,mBAAeQ,IAAf,IAAuBD,gBAAgBC,IAAhB,CAAvB;AACH;;AAEDR,eAAeS,uBAAf,GAAyC,EAAzC;;AAE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","file":"avsdf-base.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"avsdfBase\"] = factory();\n\telse\n\t\troot[\"avsdfBase\"] = factory();\n})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","'use strict';\n\nlet avsdfBase = {};\n\navsdfBase.layoutBase = require('layout-base');\navsdfBase.AVSDFConstants = require('./src/AVSDFConstants');\navsdfBase.AVSDFEdge = require('./src/AVSDFEdge');\navsdfBase.AVSDFCircle = require('./src/AVSDFCircle');\navsdfBase.AVSDFLayout = require('./src/AVSDFLayout');\navsdfBase.AVSDFNode = require('./src/AVSDFNode');\n\nmodule.exports = avsdfBase;","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"layoutBase\"] = factory();\n\telse\n\t\troot[\"layoutBase\"] = factory();\n})(window, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nlet layoutBase = function () {\n  return;\n};\n\nlayoutBase.FDLayout = __webpack_require__(1);\nlayoutBase.FDLayoutConstants = __webpack_require__(22);\nlayoutBase.FDLayoutEdge = __webpack_require__(23);\nlayoutBase.FDLayoutNode = __webpack_require__(24);\nlayoutBase.DimensionD = __webpack_require__(25);\nlayoutBase.HashMap = __webpack_require__(4);\nlayoutBase.HashSet = __webpack_require__(17);\nlayoutBase.IGeometry = __webpack_require__(9);\nlayoutBase.IMath = __webpack_require__(10);\nlayoutBase.Integer = __webpack_require__(12);\nlayoutBase.Point = __webpack_require__(18);\nlayoutBase.PointD = __webpack_require__(16);\nlayoutBase.RandomSeed = __webpack_require__(15);\nlayoutBase.RectangleD = __webpack_require__(14);\nlayoutBase.Transform = __webpack_require__(20);\nlayoutBase.UniqueIDGeneretor = __webpack_require__(5);\nlayoutBase.Quicksort = __webpack_require__(26);\nlayoutBase.LinkedList = __webpack_require__(19);\nlayoutBase.LGraphObject = __webpack_require__(8);\nlayoutBase.LGraph = __webpack_require__(11);\nlayoutBase.LEdge = __webpack_require__(7);\nlayoutBase.LGraphManager = __webpack_require__(6);\nlayoutBase.LNode = __webpack_require__(13);\nlayoutBase.Layout = __webpack_require__(2);\nlayoutBase.LayoutConstants = __webpack_require__(3);\n\nmodule.exports = layoutBase;\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar Layout = __webpack_require__(2);\nvar FDLayoutConstants = __webpack_require__(22);\nvar LayoutConstants = __webpack_require__(3);\nvar IGeometry = __webpack_require__(9);\nvar IMath = __webpack_require__(10);\n\nfunction FDLayout() {\n  Layout.call(this);\n\n  this.useSmartIdealEdgeLengthCalculation = FDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION;\n  this.idealEdgeLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH;\n  this.springConstant = FDLayoutConstants.DEFAULT_SPRING_STRENGTH;\n  this.repulsionConstant = FDLayoutConstants.DEFAULT_REPULSION_STRENGTH;\n  this.gravityConstant = FDLayoutConstants.DEFAULT_GRAVITY_STRENGTH;\n  this.compoundGravityConstant = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH;\n  this.gravityRangeFactor = FDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR;\n  this.compoundGravityRangeFactor = FDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR;\n  this.displacementThresholdPerNode = 3.0 * FDLayoutConstants.DEFAULT_EDGE_LENGTH / 100;\n  this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL;\n  this.initialCoolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL;\n  this.totalDisplacement = 0.0;\n  this.oldTotalDisplacement = 0.0;\n  this.maxIterations = FDLayoutConstants.MAX_ITERATIONS;\n}\n\nFDLayout.prototype = Object.create(Layout.prototype);\n\nfor (var prop in Layout) {\n  FDLayout[prop] = Layout[prop];\n}\n\nFDLayout.prototype.initParameters = function () {\n  Layout.prototype.initParameters.call(this, arguments);\n\n  if (this.layoutQuality == LayoutConstants.DRAFT_QUALITY) {\n    this.displacementThresholdPerNode += 0.30;\n    this.maxIterations *= 0.8;\n  } else if (this.layoutQuality == LayoutConstants.PROOF_QUALITY) {\n    this.displacementThresholdPerNode -= 0.30;\n    this.maxIterations *= 1.2;\n  }\n\n  this.totalIterations = 0;\n  this.notAnimatedIterations = 0;\n\n  this.useFRGridVariant = FDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION;\n\n  this.grid = [];\n};\n\nFDLayout.prototype.calcIdealEdgeLengths = function () {\n  var edge;\n  var lcaDepth;\n  var source;\n  var target;\n  var sizeOfSourceInLca;\n  var sizeOfTargetInLca;\n\n  var allEdges = this.getGraphManager().getAllEdges();\n  for (var i = 0; i < allEdges.length; i++) {\n    edge = allEdges[i];\n\n    edge.idealLength = this.idealEdgeLength;\n\n    if (edge.isInterGraph) {\n      source = edge.getSource();\n      target = edge.getTarget();\n\n      sizeOfSourceInLca = edge.getSourceInLca().getEstimatedSize();\n      sizeOfTargetInLca = edge.getTargetInLca().getEstimatedSize();\n\n      if (this.useSmartIdealEdgeLengthCalculation) {\n        edge.idealLength += sizeOfSourceInLca + sizeOfTargetInLca - 2 * LayoutConstants.SIMPLE_NODE_SIZE;\n      }\n\n      lcaDepth = edge.getLca().getInclusionTreeDepth();\n\n      edge.idealLength += FDLayoutConstants.DEFAULT_EDGE_LENGTH * FDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR * (source.getInclusionTreeDepth() + target.getInclusionTreeDepth() - 2 * lcaDepth);\n    }\n  }\n};\n\nFDLayout.prototype.initSpringEmbedder = function () {\n\n  if (this.incremental) {\n    this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL;\n  } else {\n    this.coolingFactor = 1.0;\n    this.initialCoolingFactor = 1.0;\n    this.maxNodeDisplacement = FDLayoutConstants.MAX_NODE_DISPLACEMENT;\n  }\n\n  this.maxIterations = Math.max(this.getAllNodes().length * 5, this.maxIterations);\n\n  this.totalDisplacementThreshold = this.displacementThresholdPerNode * this.getAllNodes().length;\n\n  this.repulsionRange = this.calcRepulsionRange();\n};\n\nFDLayout.prototype.calcSpringForces = function () {\n  var lEdges = this.getAllEdges();\n  var edge;\n\n  for (var i = 0; i < lEdges.length; i++) {\n    edge = lEdges[i];\n\n    this.calcSpringForce(edge, edge.idealLength);\n  }\n};\n\nFDLayout.prototype.calcRepulsionForces = function (gridUpdateAllowed = true, forceToNodeSurroundingUpdate = false) {\n  var i, j;\n  var nodeA, nodeB;\n  var lNodes = this.getAllNodes();\n  var processedNodeSet;\n\n  if (this.useFRGridVariant) {\n    if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed) {\n      this.updateGrid();\n    }\n\n    processedNodeSet = new Set();\n\n    // calculate repulsion forces between each nodes and its surrounding\n    for (i = 0; i < lNodes.length; i++) {\n      nodeA = lNodes[i];\n      this.calculateRepulsionForceOfANode(nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate);\n      processedNodeSet.add(nodeA);\n    }\n  } else {\n    for (i = 0; i < lNodes.length; i++) {\n      nodeA = lNodes[i];\n\n      for (j = i + 1; j < lNodes.length; j++) {\n        nodeB = lNodes[j];\n\n        // If both nodes are not members of the same graph, skip.\n        if (nodeA.getOwner() != nodeB.getOwner()) {\n          continue;\n        }\n\n        this.calcRepulsionForce(nodeA, nodeB);\n      }\n    }\n  }\n};\n\nFDLayout.prototype.calcGravitationalForces = function () {\n  var node;\n  var lNodes = this.getAllNodesToApplyGravitation();\n\n  for (var i = 0; i < lNodes.length; i++) {\n    node = lNodes[i];\n    this.calcGravitationalForce(node);\n  }\n};\n\nFDLayout.prototype.moveNodes = function () {\n  var lNodes = this.getAllNodes();\n  var node;\n\n  for (var i = 0; i < lNodes.length; i++) {\n    node = lNodes[i];\n    node.move();\n  }\n};\n\nFDLayout.prototype.calcSpringForce = function (edge, idealLength) {\n  var sourceNode = edge.getSource();\n  var targetNode = edge.getTarget();\n\n  var length;\n  var springForce;\n  var springForceX;\n  var springForceY;\n\n  // Update edge length\n  if (this.uniformLeafNodeSizes && sourceNode.getChild() == null && targetNode.getChild() == null) {\n    edge.updateLengthSimple();\n  } else {\n    edge.updateLength();\n\n    if (edge.isOverlapingSourceAndTarget) {\n      return;\n    }\n  }\n\n  length = edge.getLength();\n\n  // Calculate spring forces\n  springForce = this.springConstant * (length - idealLength);\n\n  // Project force onto x and y axes\n  springForceX = springForce * (edge.lengthX / length);\n  springForceY = springForce * (edge.lengthY / length);\n\n  // Apply forces on the end nodes\n  sourceNode.springForceX += springForceX;\n  sourceNode.springForceY += springForceY;\n  targetNode.springForceX -= springForceX;\n  targetNode.springForceY -= springForceY;\n};\n\nFDLayout.prototype.calcRepulsionForce = function (nodeA, nodeB) {\n  var rectA = nodeA.getRect();\n  var rectB = nodeB.getRect();\n  var overlapAmount = new Array(2);\n  var clipPoints = new Array(4);\n  var distanceX;\n  var distanceY;\n  var distanceSquared;\n  var distance;\n  var repulsionForce;\n  var repulsionForceX;\n  var repulsionForceY;\n\n  if (rectA.intersects(rectB)) // two nodes overlap\n    {\n      // calculate separation amount in x and y directions\n      IGeometry.calcSeparationAmount(rectA, rectB, overlapAmount, FDLayoutConstants.DEFAULT_EDGE_LENGTH / 2.0);\n\n      repulsionForceX = 2 * overlapAmount[0];\n      repulsionForceY = 2 * overlapAmount[1];\n\n      var childrenConstant = nodeA.noOfChildren * nodeB.noOfChildren / (nodeA.noOfChildren + nodeB.noOfChildren);\n\n      // Apply forces on the two nodes\n      nodeA.repulsionForceX -= childrenConstant * repulsionForceX;\n      nodeA.repulsionForceY -= childrenConstant * repulsionForceY;\n      nodeB.repulsionForceX += childrenConstant * repulsionForceX;\n      nodeB.repulsionForceY += childrenConstant * repulsionForceY;\n    } else // no overlap\n    {\n      // calculate distance\n\n      if (this.uniformLeafNodeSizes && nodeA.getChild() == null && nodeB.getChild() == null) // simply base repulsion on distance of node centers\n        {\n          distanceX = rectB.getCenterX() - rectA.getCenterX();\n          distanceY = rectB.getCenterY() - rectA.getCenterY();\n        } else // use clipping points\n        {\n          IGeometry.getIntersection(rectA, rectB, clipPoints);\n\n          distanceX = clipPoints[2] - clipPoints[0];\n          distanceY = clipPoints[3] - clipPoints[1];\n        }\n\n      // No repulsion range. FR grid variant should take care of this.\n      if (Math.abs(distanceX) < FDLayoutConstants.MIN_REPULSION_DIST) {\n        distanceX = IMath.sign(distanceX) * FDLayoutConstants.MIN_REPULSION_DIST;\n      }\n\n      if (Math.abs(distanceY) < FDLayoutConstants.MIN_REPULSION_DIST) {\n        distanceY = IMath.sign(distanceY) * FDLayoutConstants.MIN_REPULSION_DIST;\n      }\n\n      distanceSquared = distanceX * distanceX + distanceY * distanceY;\n      distance = Math.sqrt(distanceSquared);\n\n      repulsionForce = this.repulsionConstant * nodeA.noOfChildren * nodeB.noOfChildren / distanceSquared;\n\n      // Project force onto x and y axes\n      repulsionForceX = repulsionForce * distanceX / distance;\n      repulsionForceY = repulsionForce * distanceY / distance;\n\n      // Apply forces on the two nodes    \n      nodeA.repulsionForceX -= repulsionForceX;\n      nodeA.repulsionForceY -= repulsionForceY;\n      nodeB.repulsionForceX += repulsionForceX;\n      nodeB.repulsionForceY += repulsionForceY;\n    }\n};\n\nFDLayout.prototype.calcGravitationalForce = function (node) {\n  var ownerGraph;\n  var ownerCenterX;\n  var ownerCenterY;\n  var distanceX;\n  var distanceY;\n  var absDistanceX;\n  var absDistanceY;\n  var estimatedSize;\n  ownerGraph = node.getOwner();\n\n  ownerCenterX = (ownerGraph.getRight() + ownerGraph.getLeft()) / 2;\n  ownerCenterY = (ownerGraph.getTop() + ownerGraph.getBottom()) / 2;\n  distanceX = node.getCenterX() - ownerCenterX;\n  distanceY = node.getCenterY() - ownerCenterY;\n  absDistanceX = Math.abs(distanceX) + node.getWidth() / 2;\n  absDistanceY = Math.abs(distanceY) + node.getHeight() / 2;\n\n  if (node.getOwner() == this.graphManager.getRoot()) // in the root graph\n    {\n      estimatedSize = ownerGraph.getEstimatedSize() * this.gravityRangeFactor;\n\n      if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) {\n        node.gravitationForceX = -this.gravityConstant * distanceX;\n        node.gravitationForceY = -this.gravityConstant * distanceY;\n      }\n    } else // inside a compound\n    {\n      estimatedSize = ownerGraph.getEstimatedSize() * this.compoundGravityRangeFactor;\n\n      if (absDistanceX > estimatedSize || absDistanceY > estimatedSize) {\n        node.gravitationForceX = -this.gravityConstant * distanceX * this.compoundGravityConstant;\n        node.gravitationForceY = -this.gravityConstant * distanceY * this.compoundGravityConstant;\n      }\n    }\n};\n\nFDLayout.prototype.isConverged = function () {\n  var converged;\n  var oscilating = false;\n\n  if (this.totalIterations > this.maxIterations / 3) {\n    oscilating = Math.abs(this.totalDisplacement - this.oldTotalDisplacement) < 2;\n  }\n\n  converged = this.totalDisplacement < this.totalDisplacementThreshold;\n\n  this.oldTotalDisplacement = this.totalDisplacement;\n\n  return converged || oscilating;\n};\n\nFDLayout.prototype.animate = function () {\n  if (this.animationDuringLayout && !this.isSubLayout) {\n    if (this.notAnimatedIterations == this.animationPeriod) {\n      this.update();\n      this.notAnimatedIterations = 0;\n    } else {\n      this.notAnimatedIterations++;\n    }\n  }\n};\n\n//This method calculates the number of children (weight) for all nodes\nFDLayout.prototype.calcNoOfChildrenForAllNodes = function () {\n  var node;\n  var allNodes = this.graphManager.getAllNodes();\n\n  for (var i = 0; i < allNodes.length; i++) {\n    node = allNodes[i];\n    node.noOfChildren = node.getNoOfChildren();\n  }\n};\n\n// -----------------------------------------------------------------------------\n// Section: FR-Grid Variant Repulsion Force Calculation\n// -----------------------------------------------------------------------------\n\nFDLayout.prototype.calcGrid = function (graph) {\n\n  var sizeX = 0;\n  var sizeY = 0;\n\n  sizeX = parseInt(Math.ceil((graph.getRight() - graph.getLeft()) / this.repulsionRange));\n  sizeY = parseInt(Math.ceil((graph.getBottom() - graph.getTop()) / this.repulsionRange));\n\n  var grid = new Array(sizeX);\n\n  for (var i = 0; i < sizeX; i++) {\n    grid[i] = new Array(sizeY);\n  }\n\n  for (var i = 0; i < sizeX; i++) {\n    for (var j = 0; j < sizeY; j++) {\n      grid[i][j] = new Array();\n    }\n  }\n\n  return grid;\n};\n\nFDLayout.prototype.addNodeToGrid = function (v, left, top) {\n\n  var startX = 0;\n  var finishX = 0;\n  var startY = 0;\n  var finishY = 0;\n\n  startX = parseInt(Math.floor((v.getRect().x - left) / this.repulsionRange));\n  finishX = parseInt(Math.floor((v.getRect().width + v.getRect().x - left) / this.repulsionRange));\n  startY = parseInt(Math.floor((v.getRect().y - top) / this.repulsionRange));\n  finishY = parseInt(Math.floor((v.getRect().height + v.getRect().y - top) / this.repulsionRange));\n\n  for (var i = startX; i <= finishX; i++) {\n    for (var j = startY; j <= finishY; j++) {\n      this.grid[i][j].push(v);\n      v.setGridCoordinates(startX, finishX, startY, finishY);\n    }\n  }\n};\n\nFDLayout.prototype.updateGrid = function () {\n  var i;\n  var nodeA;\n  var lNodes = this.getAllNodes();\n\n  this.grid = this.calcGrid(this.graphManager.getRoot());\n\n  // put all nodes to proper grid cells\n  for (i = 0; i < lNodes.length; i++) {\n    nodeA = lNodes[i];\n    this.addNodeToGrid(nodeA, this.graphManager.getRoot().getLeft(), this.graphManager.getRoot().getTop());\n  }\n};\n\nFDLayout.prototype.calculateRepulsionForceOfANode = function (nodeA, processedNodeSet, gridUpdateAllowed, forceToNodeSurroundingUpdate) {\n\n  if (this.totalIterations % FDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD == 1 && gridUpdateAllowed || forceToNodeSurroundingUpdate) {\n    var surrounding = new Set();\n    nodeA.surrounding = new Array();\n    var nodeB;\n    var grid = this.grid;\n\n    for (var i = nodeA.startX - 1; i < nodeA.finishX + 2; i++) {\n      for (var j = nodeA.startY - 1; j < nodeA.finishY + 2; j++) {\n        if (!(i < 0 || j < 0 || i >= grid.length || j >= grid[0].length)) {\n          for (var k = 0; k < grid[i][j].length; k++) {\n            nodeB = grid[i][j][k];\n\n            // If both nodes are not members of the same graph, \n            // or both nodes are the same, skip.\n            if (nodeA.getOwner() != nodeB.getOwner() || nodeA == nodeB) {\n              continue;\n            }\n\n            // check if the repulsion force between\n            // nodeA and nodeB has already been calculated\n            if (!processedNodeSet.has(nodeB) && !surrounding.has(nodeB)) {\n              var distanceX = Math.abs(nodeA.getCenterX() - nodeB.getCenterX()) - (nodeA.getWidth() / 2 + nodeB.getWidth() / 2);\n              var distanceY = Math.abs(nodeA.getCenterY() - nodeB.getCenterY()) - (nodeA.getHeight() / 2 + nodeB.getHeight() / 2);\n\n              // if the distance between nodeA and nodeB \n              // is less then calculation range\n              if (distanceX <= this.repulsionRange && distanceY <= this.repulsionRange) {\n                //then add nodeB to surrounding of nodeA\n                surrounding.add(nodeB);\n              }\n            }\n          }\n        }\n      }\n    }\n\n    nodeA.surrounding = [...surrounding];\n  }\n  for (i = 0; i < nodeA.surrounding.length; i++) {\n    this.calcRepulsionForce(nodeA, nodeA.surrounding[i]);\n  }\n};\n\nFDLayout.prototype.calcRepulsionRange = function () {\n  return 0.0;\n};\n\nmodule.exports = FDLayout;\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LayoutConstants = __webpack_require__(3);\nvar HashMap = __webpack_require__(4);\nvar LGraphManager = __webpack_require__(6);\nvar LNode = __webpack_require__(13);\nvar LEdge = __webpack_require__(7);\nvar LGraph = __webpack_require__(11);\nvar PointD = __webpack_require__(16);\nvar Transform = __webpack_require__(20);\nvar Emitter = __webpack_require__(21);\nvar HashSet = __webpack_require__(17);\n\nfunction Layout(isRemoteUse) {\n  Emitter.call(this);\n\n  //Layout Quality: 0:proof, 1:default, 2:draft\n  this.layoutQuality = LayoutConstants.DEFAULT_QUALITY;\n  //Whether layout should create bendpoints as needed or not\n  this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED;\n  //Whether layout should be incremental or not\n  this.incremental = LayoutConstants.DEFAULT_INCREMENTAL;\n  //Whether we animate from before to after layout node positions\n  this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT;\n  //Whether we animate the layout process or not\n  this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT;\n  //Number iterations that should be done between two successive animations\n  this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD;\n  /**\r\n   * Whether or not leaf nodes (non-compound nodes) are of uniform sizes. When\r\n   * they are, both spring and repulsion forces between two leaf nodes can be\r\n   * calculated without the expensive clipping point calculations, resulting\r\n   * in major speed-up.\r\n   */\n  this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES;\n  /**\r\n   * This is used for creation of bendpoints by using dummy nodes and edges.\r\n   * Maps an LEdge to its dummy bendpoint path.\r\n   */\n  this.edgeToDummyNodes = new HashMap();\n  this.graphManager = new LGraphManager(this);\n  this.isLayoutFinished = false;\n  this.isSubLayout = false;\n  this.isRemoteUse = false;\n\n  if (isRemoteUse != null) {\n    this.isRemoteUse = isRemoteUse;\n  }\n}\n\nLayout.RANDOM_SEED = 1;\n\nLayout.prototype = Object.create(Emitter.prototype);\n\nLayout.prototype.getGraphManager = function () {\n  return this.graphManager;\n};\n\nLayout.prototype.getAllNodes = function () {\n  return this.graphManager.getAllNodes();\n};\n\nLayout.prototype.getAllEdges = function () {\n  return this.graphManager.getAllEdges();\n};\n\nLayout.prototype.getAllNodesToApplyGravitation = function () {\n  return this.graphManager.getAllNodesToApplyGravitation();\n};\n\nLayout.prototype.newGraphManager = function () {\n  var gm = new LGraphManager(this);\n  this.graphManager = gm;\n  return gm;\n};\n\nLayout.prototype.newGraph = function (vGraph) {\n  return new LGraph(null, this.graphManager, vGraph);\n};\n\nLayout.prototype.newNode = function (vNode) {\n  return new LNode(this.graphManager, vNode);\n};\n\nLayout.prototype.newEdge = function (vEdge) {\n  return new LEdge(null, null, vEdge);\n};\n\nLayout.prototype.checkLayoutSuccess = function () {\n  return this.graphManager.getRoot() == null || this.graphManager.getRoot().getNodes().length == 0 || this.graphManager.includesInvalidEdge();\n};\n\nLayout.prototype.runLayout = function () {\n  this.isLayoutFinished = false;\n\n  if (this.tilingPreLayout) {\n    this.tilingPreLayout();\n  }\n\n  this.initParameters();\n  var isLayoutSuccessfull;\n\n  if (this.checkLayoutSuccess()) {\n    isLayoutSuccessfull = false;\n  } else {\n    isLayoutSuccessfull = this.layout();\n  }\n\n  if (LayoutConstants.ANIMATE === 'during') {\n    // If this is a 'during' layout animation. Layout is not finished yet. \n    // We need to perform these in index.js when layout is really finished.\n    return false;\n  }\n\n  if (isLayoutSuccessfull) {\n    if (!this.isSubLayout) {\n      this.doPostLayout();\n    }\n  }\n\n  if (this.tilingPostLayout) {\n    this.tilingPostLayout();\n  }\n\n  this.isLayoutFinished = true;\n\n  return isLayoutSuccessfull;\n};\n\n/**\r\n * This method performs the operations required after layout.\r\n */\nLayout.prototype.doPostLayout = function () {\n  //assert !isSubLayout : \"Should not be called on sub-layout!\";\n  // Propagate geometric changes to v-level objects\n  if (!this.incremental) {\n    this.transform();\n  }\n  this.update();\n};\n\n/**\r\n * This method updates the geometry of the target graph according to\r\n * calculated layout.\r\n */\nLayout.prototype.update2 = function () {\n  // update bend points\n  if (this.createBendsAsNeeded) {\n    this.createBendpointsFromDummyNodes();\n\n    // reset all edges, since the topology has changed\n    this.graphManager.resetAllEdges();\n  }\n\n  // perform edge, node and root updates if layout is not called\n  // remotely\n  if (!this.isRemoteUse) {\n    // update all edges\n    var edge;\n    var allEdges = this.graphManager.getAllEdges();\n    for (var i = 0; i < allEdges.length; i++) {\n      edge = allEdges[i];\n      //      this.update(edge);\n    }\n\n    // recursively update nodes\n    var node;\n    var nodes = this.graphManager.getRoot().getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      node = nodes[i];\n      //      this.update(node);\n    }\n\n    // update root graph\n    this.update(this.graphManager.getRoot());\n  }\n};\n\nLayout.prototype.update = function (obj) {\n  if (obj == null) {\n    this.update2();\n  } else if (obj instanceof LNode) {\n    var node = obj;\n    if (node.getChild() != null) {\n      // since node is compound, recursively update child nodes\n      var nodes = node.getChild().getNodes();\n      for (var i = 0; i < nodes.length; i++) {\n        update(nodes[i]);\n      }\n    }\n\n    // if the l-level node is associated with a v-level graph object,\n    // then it is assumed that the v-level node implements the\n    // interface Updatable.\n    if (node.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vNode = node.vGraphObject;\n\n      // call the update method of the interface\n      vNode.update(node);\n    }\n  } else if (obj instanceof LEdge) {\n    var edge = obj;\n    // if the l-level edge is associated with a v-level graph object,\n    // then it is assumed that the v-level edge implements the\n    // interface Updatable.\n\n    if (edge.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vEdge = edge.vGraphObject;\n\n      // call the update method of the interface\n      vEdge.update(edge);\n    }\n  } else if (obj instanceof LGraph) {\n    var graph = obj;\n    // if the l-level graph is associated with a v-level graph object,\n    // then it is assumed that the v-level object implements the\n    // interface Updatable.\n\n    if (graph.vGraphObject != null) {\n      // cast to Updatable without any type check\n      var vGraph = graph.vGraphObject;\n\n      // call the update method of the interface\n      vGraph.update(graph);\n    }\n  }\n};\n\n/**\r\n * This method is used to set all layout parameters to default values\r\n * determined at compile time.\r\n */\nLayout.prototype.initParameters = function () {\n  if (!this.isSubLayout) {\n    this.layoutQuality = LayoutConstants.DEFAULT_QUALITY;\n    this.animationDuringLayout = LayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT;\n    this.animationPeriod = LayoutConstants.DEFAULT_ANIMATION_PERIOD;\n    this.animationOnLayout = LayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT;\n    this.incremental = LayoutConstants.DEFAULT_INCREMENTAL;\n    this.createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED;\n    this.uniformLeafNodeSizes = LayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES;\n  }\n\n  if (this.animationDuringLayout) {\n    this.animationOnLayout = false;\n  }\n};\n\nLayout.prototype.transform = function (newLeftTop) {\n  if (newLeftTop == undefined) {\n    this.transform(new PointD(0, 0));\n  } else {\n    // create a transformation object (from Eclipse to layout). When an\n    // inverse transform is applied, we get upper-left coordinate of the\n    // drawing or the root graph at given input coordinate (some margins\n    // already included in calculation of left-top).\n\n    var trans = new Transform();\n    var leftTop = this.graphManager.getRoot().updateLeftTop();\n\n    if (leftTop != null) {\n      trans.setWorldOrgX(newLeftTop.x);\n      trans.setWorldOrgY(newLeftTop.y);\n\n      trans.setDeviceOrgX(leftTop.x);\n      trans.setDeviceOrgY(leftTop.y);\n\n      var nodes = this.getAllNodes();\n      var node;\n\n      for (var i = 0; i < nodes.length; i++) {\n        node = nodes[i];\n        node.transform(trans);\n      }\n    }\n  }\n};\n\nLayout.prototype.positionNodesRandomly = function (graph) {\n\n  if (graph == undefined) {\n    //assert !this.incremental;\n    this.positionNodesRandomly(this.getGraphManager().getRoot());\n    this.getGraphManager().getRoot().updateBounds(true);\n  } else {\n    var lNode;\n    var childGraph;\n\n    var nodes = graph.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      lNode = nodes[i];\n      childGraph = lNode.getChild();\n\n      if (childGraph == null) {\n        lNode.scatter();\n      } else if (childGraph.getNodes().length == 0) {\n        lNode.scatter();\n      } else {\n        this.positionNodesRandomly(childGraph);\n        lNode.updateBounds();\n      }\n    }\n  }\n};\n\n/**\r\n * This method returns a list of trees where each tree is represented as a\r\n * list of l-nodes. The method returns a list of size 0 when:\r\n * - The graph is not flat or\r\n * - One of the component(s) of the graph is not a tree.\r\n */\nLayout.prototype.getFlatForest = function () {\n  var flatForest = [];\n  var isForest = true;\n\n  // Quick reference for all nodes in the graph manager associated with\n  // this layout. The list should not be changed.\n  var allNodes = this.graphManager.getRoot().getNodes();\n\n  // First be sure that the graph is flat\n  var isFlat = true;\n\n  for (var i = 0; i < allNodes.length; i++) {\n    if (allNodes[i].getChild() != null) {\n      isFlat = false;\n    }\n  }\n\n  // Return empty forest if the graph is not flat.\n  if (!isFlat) {\n    return flatForest;\n  }\n\n  // Run BFS for each component of the graph.\n\n  var visited = new HashSet();\n  var toBeVisited = [];\n  var parents = new HashMap();\n  var unProcessedNodes = [];\n\n  unProcessedNodes = unProcessedNodes.concat(allNodes);\n\n  // Each iteration of this loop finds a component of the graph and\n  // decides whether it is a tree or not. If it is a tree, adds it to the\n  // forest and continued with the next component.\n\n  while (unProcessedNodes.length > 0 && isForest) {\n    toBeVisited.push(unProcessedNodes[0]);\n\n    // Start the BFS. Each iteration of this loop visits a node in a\n    // BFS manner.\n    while (toBeVisited.length > 0 && isForest) {\n      //pool operation\n      var currentNode = toBeVisited[0];\n      toBeVisited.splice(0, 1);\n      visited.add(currentNode);\n\n      // Traverse all neighbors of this node\n      var neighborEdges = currentNode.getEdges();\n\n      for (var i = 0; i < neighborEdges.length; i++) {\n        var currentNeighbor = neighborEdges[i].getOtherEnd(currentNode);\n\n        // If BFS is not growing from this neighbor.\n        if (parents.get(currentNode) != currentNeighbor) {\n          // We haven't previously visited this neighbor.\n          if (!visited.contains(currentNeighbor)) {\n            toBeVisited.push(currentNeighbor);\n            parents.put(currentNeighbor, currentNode);\n          }\n          // Since we have previously visited this neighbor and\n          // this neighbor is not parent of currentNode, given\n          // graph contains a component that is not tree, hence\n          // it is not a forest.\n          else {\n              isForest = false;\n              break;\n            }\n        }\n      }\n    }\n\n    // The graph contains a component that is not a tree. Empty\n    // previously found trees. The method will end.\n    if (!isForest) {\n      flatForest = [];\n    }\n    // Save currently visited nodes as a tree in our forest. Reset\n    // visited and parents lists. Continue with the next component of\n    // the graph, if any.\n    else {\n        var temp = [];\n        visited.addAllTo(temp);\n        flatForest.push(temp);\n        //flatForest = flatForest.concat(temp);\n        //unProcessedNodes.removeAll(visited);\n        for (var i = 0; i < temp.length; i++) {\n          var value = temp[i];\n          var index = unProcessedNodes.indexOf(value);\n          if (index > -1) {\n            unProcessedNodes.splice(index, 1);\n          }\n        }\n        visited = new HashSet();\n        parents = new HashMap();\n      }\n  }\n\n  return flatForest;\n};\n\n/**\r\n * This method creates dummy nodes (an l-level node with minimal dimensions)\r\n * for the given edge (one per bendpoint). The existing l-level structure\r\n * is updated accordingly.\r\n */\nLayout.prototype.createDummyNodesForBendpoints = function (edge) {\n  var dummyNodes = [];\n  var prev = edge.source;\n\n  var graph = this.graphManager.calcLowestCommonAncestor(edge.source, edge.target);\n\n  for (var i = 0; i < edge.bendpoints.length; i++) {\n    // create new dummy node\n    var dummyNode = this.newNode(null);\n    dummyNode.setRect(new Point(0, 0), new Dimension(1, 1));\n\n    graph.add(dummyNode);\n\n    // create new dummy edge between prev and dummy node\n    var dummyEdge = this.newEdge(null);\n    this.graphManager.add(dummyEdge, prev, dummyNode);\n\n    dummyNodes.add(dummyNode);\n    prev = dummyNode;\n  }\n\n  var dummyEdge = this.newEdge(null);\n  this.graphManager.add(dummyEdge, prev, edge.target);\n\n  this.edgeToDummyNodes.put(edge, dummyNodes);\n\n  // remove real edge from graph manager if it is inter-graph\n  if (edge.isInterGraph()) {\n    this.graphManager.remove(edge);\n  }\n  // else, remove the edge from the current graph\n  else {\n      graph.remove(edge);\n    }\n\n  return dummyNodes;\n};\n\n/**\r\n * This method creates bendpoints for edges from the dummy nodes\r\n * at l-level.\r\n */\nLayout.prototype.createBendpointsFromDummyNodes = function () {\n  var edges = [];\n  edges = edges.concat(this.graphManager.getAllEdges());\n  edges = this.edgeToDummyNodes.keySet().concat(edges);\n\n  for (var k = 0; k < edges.length; k++) {\n    var lEdge = edges[k];\n\n    if (lEdge.bendpoints.length > 0) {\n      var path = this.edgeToDummyNodes.get(lEdge);\n\n      for (var i = 0; i < path.length; i++) {\n        var dummyNode = path[i];\n        var p = new PointD(dummyNode.getCenterX(), dummyNode.getCenterY());\n\n        // update bendpoint's location according to dummy node\n        var ebp = lEdge.bendpoints.get(i);\n        ebp.x = p.x;\n        ebp.y = p.y;\n\n        // remove the dummy node, dummy edges incident with this\n        // dummy node is also removed (within the remove method)\n        dummyNode.getOwner().remove(dummyNode);\n      }\n\n      // add the real edge to graph\n      this.graphManager.add(lEdge, lEdge.source, lEdge.target);\n    }\n  }\n};\n\nLayout.transform = function (sliderValue, defaultValue, minDiv, maxMul) {\n  if (minDiv != undefined && maxMul != undefined) {\n    var value = defaultValue;\n\n    if (sliderValue <= 50) {\n      var minValue = defaultValue / minDiv;\n      value -= (defaultValue - minValue) / 50 * (50 - sliderValue);\n    } else {\n      var maxValue = defaultValue * maxMul;\n      value += (maxValue - defaultValue) / 50 * (sliderValue - 50);\n    }\n\n    return value;\n  } else {\n    var a, b;\n\n    if (sliderValue <= 50) {\n      a = 9.0 * defaultValue / 500.0;\n      b = defaultValue / 10.0;\n    } else {\n      a = 9.0 * defaultValue / 50.0;\n      b = -8 * defaultValue;\n    }\n\n    return a * sliderValue + b;\n  }\n};\n\n/**\r\n * This method finds and returns the center of the given nodes, assuming\r\n * that the given nodes form a tree in themselves.\r\n */\nLayout.findCenterOfTree = function (nodes) {\n  var list = [];\n  list = list.concat(nodes);\n\n  var removedNodes = [];\n  var remainingDegrees = new HashMap();\n  var foundCenter = false;\n  var centerNode = null;\n\n  if (list.length == 1 || list.length == 2) {\n    foundCenter = true;\n    centerNode = list[0];\n  }\n\n  for (var i = 0; i < list.length; i++) {\n    var node = list[i];\n    var degree = node.getNeighborsList().size();\n    remainingDegrees.put(node, node.getNeighborsList().size());\n\n    if (degree == 1) {\n      removedNodes.push(node);\n    }\n  }\n\n  var tempList = [];\n  tempList = tempList.concat(removedNodes);\n\n  while (!foundCenter) {\n    var tempList2 = [];\n    tempList2 = tempList2.concat(tempList);\n    tempList = [];\n\n    for (var i = 0; i < list.length; i++) {\n      var node = list[i];\n\n      var index = list.indexOf(node);\n      if (index >= 0) {\n        list.splice(index, 1);\n      }\n\n      var neighbours = node.getNeighborsList();\n\n      Object.keys(neighbours.set).forEach(function (j) {\n        var neighbour = neighbours.set[j];\n        if (removedNodes.indexOf(neighbour) < 0) {\n          var otherDegree = remainingDegrees.get(neighbour);\n          var newDegree = otherDegree - 1;\n\n          if (newDegree == 1) {\n            tempList.push(neighbour);\n          }\n\n          remainingDegrees.put(neighbour, newDegree);\n        }\n      });\n    }\n\n    removedNodes = removedNodes.concat(tempList);\n\n    if (list.length == 1 || list.length == 2) {\n      foundCenter = true;\n      centerNode = list[0];\n    }\n  }\n\n  return centerNode;\n};\n\n/**\r\n * During the coarsening process, this layout may be referenced by two graph managers\r\n * this setter function grants access to change the currently being used graph manager\r\n */\nLayout.prototype.setGraphManager = function (gm) {\n  this.graphManager = gm;\n};\n\nmodule.exports = Layout;\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports) {\n\nfunction LayoutConstants() {}\n\n/**\r\n * Layout Quality\r\n */\nLayoutConstants.PROOF_QUALITY = 0;\nLayoutConstants.DEFAULT_QUALITY = 1;\nLayoutConstants.DRAFT_QUALITY = 2;\n\n/**\r\n * Default parameters\r\n */\nLayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED = false;\n//LayoutConstants.DEFAULT_INCREMENTAL = true;\nLayoutConstants.DEFAULT_INCREMENTAL = false;\nLayoutConstants.DEFAULT_ANIMATION_ON_LAYOUT = true;\nLayoutConstants.DEFAULT_ANIMATION_DURING_LAYOUT = false;\nLayoutConstants.DEFAULT_ANIMATION_PERIOD = 50;\nLayoutConstants.DEFAULT_UNIFORM_LEAF_NODE_SIZES = false;\n\n// -----------------------------------------------------------------------------\n// Section: General other constants\n// -----------------------------------------------------------------------------\n/*\r\n * Margins of a graph to be applied on bouding rectangle of its contents. We\r\n * assume margins on all four sides to be uniform.\r\n */\nLayoutConstants.DEFAULT_GRAPH_MARGIN = 15;\n\n/*\r\n * Whether to consider labels in node dimensions or not\r\n */\nLayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS = false;\n\n/*\r\n * Default dimension of a non-compound node.\r\n */\nLayoutConstants.SIMPLE_NODE_SIZE = 40;\n\n/*\r\n * Default dimension of a non-compound node.\r\n */\nLayoutConstants.SIMPLE_NODE_HALF_SIZE = LayoutConstants.SIMPLE_NODE_SIZE / 2;\n\n/*\r\n * Empty compound node size. When a compound node is empty, its both\r\n * dimensions should be of this value.\r\n */\nLayoutConstants.EMPTY_COMPOUND_NODE_SIZE = 40;\n\n/*\r\n * Minimum length that an edge should take during layout\r\n */\nLayoutConstants.MIN_EDGE_LENGTH = 1;\n\n/*\r\n * World boundaries that layout operates on\r\n */\nLayoutConstants.WORLD_BOUNDARY = 1000000;\n\n/*\r\n * World boundaries that random positioning can be performed with\r\n */\nLayoutConstants.INITIAL_WORLD_BOUNDARY = LayoutConstants.WORLD_BOUNDARY / 1000;\n\n/*\r\n * Coordinates of the world center\r\n */\nLayoutConstants.WORLD_CENTER_X = 1200;\nLayoutConstants.WORLD_CENTER_Y = 900;\n\nmodule.exports = LayoutConstants;\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar UniqueIDGeneretor = __webpack_require__(5);\n\nfunction HashMap() {\n  this.map = {};\n  this.keys = [];\n}\n\nHashMap.prototype.put = function (key, value) {\n  var theId = UniqueIDGeneretor.createID(key);\n  if (!this.contains(theId)) {\n    this.map[theId] = value;\n    this.keys.push(key);\n  }\n};\n\nHashMap.prototype.contains = function (key) {\n  var theId = UniqueIDGeneretor.createID(key);\n  return this.map[key] != null;\n};\n\nHashMap.prototype.get = function (key) {\n  var theId = UniqueIDGeneretor.createID(key);\n  return this.map[theId];\n};\n\nHashMap.prototype.keySet = function () {\n  return this.keys;\n};\n\nmodule.exports = HashMap;\n\n/***/ }),\n/* 5 */\n/***/ (function(module, exports) {\n\nfunction UniqueIDGeneretor() {}\n\nUniqueIDGeneretor.lastID = 0;\n\nUniqueIDGeneretor.createID = function (obj) {\n  if (UniqueIDGeneretor.isPrimitive(obj)) {\n    return obj;\n  }\n  if (obj.uniqueID != null) {\n    return obj.uniqueID;\n  }\n  obj.uniqueID = UniqueIDGeneretor.getString();\n  UniqueIDGeneretor.lastID++;\n  return obj.uniqueID;\n};\n\nUniqueIDGeneretor.getString = function (id) {\n  if (id == null) id = UniqueIDGeneretor.lastID;\n  return \"Object#\" + id + \"\";\n};\n\nUniqueIDGeneretor.isPrimitive = function (arg) {\n  var type = typeof arg;\n  return arg == null || type != \"object\" && type != \"function\";\n};\n\nmodule.exports = UniqueIDGeneretor;\n\n/***/ }),\n/* 6 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraph;\nvar LEdge = __webpack_require__(7);\n\nfunction LGraphManager(layout) {\n  LGraph = __webpack_require__(11); // It may be better to initilize this out of this function but it gives an error (Right-hand side of 'instanceof' is not callable) now.\n  this.layout = layout;\n\n  this.graphs = [];\n  this.edges = [];\n}\n\nLGraphManager.prototype.addRoot = function () {\n  var ngraph = this.layout.newGraph();\n  var nnode = this.layout.newNode(null);\n  var root = this.add(ngraph, nnode);\n  this.setRootGraph(root);\n  return this.rootGraph;\n};\n\nLGraphManager.prototype.add = function (newGraph, parentNode, newEdge, sourceNode, targetNode) {\n  //there are just 2 parameters are passed then it adds an LGraph else it adds an LEdge\n  if (newEdge == null && sourceNode == null && targetNode == null) {\n    if (newGraph == null) {\n      throw \"Graph is null!\";\n    }\n    if (parentNode == null) {\n      throw \"Parent node is null!\";\n    }\n    if (this.graphs.indexOf(newGraph) > -1) {\n      throw \"Graph already in this graph mgr!\";\n    }\n\n    this.graphs.push(newGraph);\n\n    if (newGraph.parent != null) {\n      throw \"Already has a parent!\";\n    }\n    if (parentNode.child != null) {\n      throw \"Already has a child!\";\n    }\n\n    newGraph.parent = parentNode;\n    parentNode.child = newGraph;\n\n    return newGraph;\n  } else {\n    //change the order of the parameters\n    targetNode = newEdge;\n    sourceNode = parentNode;\n    newEdge = newGraph;\n    var sourceGraph = sourceNode.getOwner();\n    var targetGraph = targetNode.getOwner();\n\n    if (!(sourceGraph != null && sourceGraph.getGraphManager() == this)) {\n      throw \"Source not in this graph mgr!\";\n    }\n    if (!(targetGraph != null && targetGraph.getGraphManager() == this)) {\n      throw \"Target not in this graph mgr!\";\n    }\n\n    if (sourceGraph == targetGraph) {\n      newEdge.isInterGraph = false;\n      return sourceGraph.add(newEdge, sourceNode, targetNode);\n    } else {\n      newEdge.isInterGraph = true;\n\n      // set source and target\n      newEdge.source = sourceNode;\n      newEdge.target = targetNode;\n\n      // add edge to inter-graph edge list\n      if (this.edges.indexOf(newEdge) > -1) {\n        throw \"Edge already in inter-graph edge list!\";\n      }\n\n      this.edges.push(newEdge);\n\n      // add edge to source and target incidency lists\n      if (!(newEdge.source != null && newEdge.target != null)) {\n        throw \"Edge source and/or target is null!\";\n      }\n\n      if (!(newEdge.source.edges.indexOf(newEdge) == -1 && newEdge.target.edges.indexOf(newEdge) == -1)) {\n        throw \"Edge already in source and/or target incidency list!\";\n      }\n\n      newEdge.source.edges.push(newEdge);\n      newEdge.target.edges.push(newEdge);\n\n      return newEdge;\n    }\n  }\n};\n\nLGraphManager.prototype.remove = function (lObj) {\n  if (lObj instanceof LGraph) {\n    var graph = lObj;\n    if (graph.getGraphManager() != this) {\n      throw \"Graph not in this graph mgr\";\n    }\n    if (!(graph == this.rootGraph || graph.parent != null && graph.parent.graphManager == this)) {\n      throw \"Invalid parent node!\";\n    }\n\n    // first the edges (make a copy to do it safely)\n    var edgesToBeRemoved = [];\n\n    edgesToBeRemoved = edgesToBeRemoved.concat(graph.getEdges());\n\n    var edge;\n    var s = edgesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      edge = edgesToBeRemoved[i];\n      graph.remove(edge);\n    }\n\n    // then the nodes (make a copy to do it safely)\n    var nodesToBeRemoved = [];\n\n    nodesToBeRemoved = nodesToBeRemoved.concat(graph.getNodes());\n\n    var node;\n    s = nodesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      node = nodesToBeRemoved[i];\n      graph.remove(node);\n    }\n\n    // check if graph is the root\n    if (graph == this.rootGraph) {\n      this.setRootGraph(null);\n    }\n\n    // now remove the graph itself\n    var index = this.graphs.indexOf(graph);\n    this.graphs.splice(index, 1);\n\n    // also reset the parent of the graph\n    graph.parent = null;\n  } else if (lObj instanceof LEdge) {\n    edge = lObj;\n    if (edge == null) {\n      throw \"Edge is null!\";\n    }\n    if (!edge.isInterGraph) {\n      throw \"Not an inter-graph edge!\";\n    }\n    if (!(edge.source != null && edge.target != null)) {\n      throw \"Source and/or target is null!\";\n    }\n\n    // remove edge from source and target nodes' incidency lists\n\n    if (!(edge.source.edges.indexOf(edge) != -1 && edge.target.edges.indexOf(edge) != -1)) {\n      throw \"Source and/or target doesn't know this edge!\";\n    }\n\n    var index = edge.source.edges.indexOf(edge);\n    edge.source.edges.splice(index, 1);\n    index = edge.target.edges.indexOf(edge);\n    edge.target.edges.splice(index, 1);\n\n    // remove edge from owner graph manager's inter-graph edge list\n\n    if (!(edge.source.owner != null && edge.source.owner.getGraphManager() != null)) {\n      throw \"Edge owner graph or owner graph manager is null!\";\n    }\n    if (edge.source.owner.getGraphManager().edges.indexOf(edge) == -1) {\n      throw \"Not in owner graph manager's edge list!\";\n    }\n\n    var index = edge.source.owner.getGraphManager().edges.indexOf(edge);\n    edge.source.owner.getGraphManager().edges.splice(index, 1);\n  }\n};\n\nLGraphManager.prototype.updateBounds = function () {\n  this.rootGraph.updateBounds(true);\n};\n\nLGraphManager.prototype.getGraphs = function () {\n  return this.graphs;\n};\n\nLGraphManager.prototype.getAllNodes = function () {\n  if (this.allNodes == null) {\n    var nodeList = [];\n    var graphs = this.getGraphs();\n    var s = graphs.length;\n    for (var i = 0; i < s; i++) {\n      nodeList = nodeList.concat(graphs[i].getNodes());\n    }\n    this.allNodes = nodeList;\n  }\n  return this.allNodes;\n};\n\nLGraphManager.prototype.resetAllNodes = function () {\n  this.allNodes = null;\n};\n\nLGraphManager.prototype.resetAllEdges = function () {\n  this.allEdges = null;\n};\n\nLGraphManager.prototype.resetAllNodesToApplyGravitation = function () {\n  this.allNodesToApplyGravitation = null;\n};\n\nLGraphManager.prototype.getAllEdges = function () {\n  if (this.allEdges == null) {\n    var edgeList = [];\n    var graphs = this.getGraphs();\n    var s = graphs.length;\n    for (var i = 0; i < graphs.length; i++) {\n      edgeList = edgeList.concat(graphs[i].getEdges());\n    }\n\n    edgeList = edgeList.concat(this.edges);\n\n    this.allEdges = edgeList;\n  }\n  return this.allEdges;\n};\n\nLGraphManager.prototype.getAllNodesToApplyGravitation = function () {\n  return this.allNodesToApplyGravitation;\n};\n\nLGraphManager.prototype.setAllNodesToApplyGravitation = function (nodeList) {\n  if (this.allNodesToApplyGravitation != null) {\n    throw \"assert failed\";\n  }\n\n  this.allNodesToApplyGravitation = nodeList;\n};\n\nLGraphManager.prototype.getRoot = function () {\n  return this.rootGraph;\n};\n\nLGraphManager.prototype.setRootGraph = function (graph) {\n  if (graph.getGraphManager() != this) {\n    throw \"Root not in this graph mgr!\";\n  }\n\n  this.rootGraph = graph;\n  // root graph must have a root node associated with it for convenience\n  if (graph.parent == null) {\n    graph.parent = this.layout.newNode(\"Root node\");\n  }\n};\n\nLGraphManager.prototype.getLayout = function () {\n  return this.layout;\n};\n\nLGraphManager.prototype.isOneAncestorOfOther = function (firstNode, secondNode) {\n  if (!(firstNode != null && secondNode != null)) {\n    throw \"assert failed\";\n  }\n\n  if (firstNode == secondNode) {\n    return true;\n  }\n  // Is second node an ancestor of the first one?\n  var ownerGraph = firstNode.getOwner();\n  var parentNode;\n\n  do {\n    parentNode = ownerGraph.getParent();\n\n    if (parentNode == null) {\n      break;\n    }\n\n    if (parentNode == secondNode) {\n      return true;\n    }\n\n    ownerGraph = parentNode.getOwner();\n    if (ownerGraph == null) {\n      break;\n    }\n  } while (true);\n  // Is first node an ancestor of the second one?\n  ownerGraph = secondNode.getOwner();\n\n  do {\n    parentNode = ownerGraph.getParent();\n\n    if (parentNode == null) {\n      break;\n    }\n\n    if (parentNode == firstNode) {\n      return true;\n    }\n\n    ownerGraph = parentNode.getOwner();\n    if (ownerGraph == null) {\n      break;\n    }\n  } while (true);\n\n  return false;\n};\n\nLGraphManager.prototype.calcLowestCommonAncestors = function () {\n  var edge;\n  var sourceNode;\n  var targetNode;\n  var sourceAncestorGraph;\n  var targetAncestorGraph;\n\n  var edges = this.getAllEdges();\n  var s = edges.length;\n  for (var i = 0; i < s; i++) {\n    edge = edges[i];\n\n    sourceNode = edge.source;\n    targetNode = edge.target;\n    edge.lca = null;\n    edge.sourceInLca = sourceNode;\n    edge.targetInLca = targetNode;\n\n    if (sourceNode == targetNode) {\n      edge.lca = sourceNode.getOwner();\n      continue;\n    }\n\n    sourceAncestorGraph = sourceNode.getOwner();\n\n    while (edge.lca == null) {\n      edge.targetInLca = targetNode;\n      targetAncestorGraph = targetNode.getOwner();\n\n      while (edge.lca == null) {\n        if (targetAncestorGraph == sourceAncestorGraph) {\n          edge.lca = targetAncestorGraph;\n          break;\n        }\n\n        if (targetAncestorGraph == this.rootGraph) {\n          break;\n        }\n\n        if (edge.lca != null) {\n          throw \"assert failed\";\n        }\n        edge.targetInLca = targetAncestorGraph.getParent();\n        targetAncestorGraph = edge.targetInLca.getOwner();\n      }\n\n      if (sourceAncestorGraph == this.rootGraph) {\n        break;\n      }\n\n      if (edge.lca == null) {\n        edge.sourceInLca = sourceAncestorGraph.getParent();\n        sourceAncestorGraph = edge.sourceInLca.getOwner();\n      }\n    }\n\n    if (edge.lca == null) {\n      throw \"assert failed\";\n    }\n  }\n};\n\nLGraphManager.prototype.calcLowestCommonAncestor = function (firstNode, secondNode) {\n  if (firstNode == secondNode) {\n    return firstNode.getOwner();\n  }\n  var firstOwnerGraph = firstNode.getOwner();\n\n  do {\n    if (firstOwnerGraph == null) {\n      break;\n    }\n    var secondOwnerGraph = secondNode.getOwner();\n\n    do {\n      if (secondOwnerGraph == null) {\n        break;\n      }\n\n      if (secondOwnerGraph == firstOwnerGraph) {\n        return secondOwnerGraph;\n      }\n      secondOwnerGraph = secondOwnerGraph.getParent().getOwner();\n    } while (true);\n\n    firstOwnerGraph = firstOwnerGraph.getParent().getOwner();\n  } while (true);\n\n  return firstOwnerGraph;\n};\n\nLGraphManager.prototype.calcInclusionTreeDepths = function (graph, depth) {\n  if (graph == null && depth == null) {\n    graph = this.rootGraph;\n    depth = 1;\n  }\n  var node;\n\n  var nodes = graph.getNodes();\n  var s = nodes.length;\n  for (var i = 0; i < s; i++) {\n    node = nodes[i];\n    node.inclusionTreeDepth = depth;\n\n    if (node.child != null) {\n      this.calcInclusionTreeDepths(node.child, depth + 1);\n    }\n  }\n};\n\nLGraphManager.prototype.includesInvalidEdge = function () {\n  var edge;\n\n  var s = this.edges.length;\n  for (var i = 0; i < s; i++) {\n    edge = this.edges[i];\n\n    if (this.isOneAncestorOfOther(edge.source, edge.target)) {\n      return true;\n    }\n  }\n  return false;\n};\n\nmodule.exports = LGraphManager;\n\n/***/ }),\n/* 7 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar IGeometry = __webpack_require__(9);\nvar IMath = __webpack_require__(10);\n\nfunction LEdge(source, target, vEdge) {\n  LGraphObject.call(this, vEdge);\n\n  this.isOverlapingSourceAndTarget = false;\n  this.vGraphObject = vEdge;\n  this.bendpoints = [];\n  this.source = source;\n  this.target = target;\n}\n\nLEdge.prototype = Object.create(LGraphObject.prototype);\n\nfor (var prop in LGraphObject) {\n  LEdge[prop] = LGraphObject[prop];\n}\n\nLEdge.prototype.getSource = function () {\n  return this.source;\n};\n\nLEdge.prototype.getTarget = function () {\n  return this.target;\n};\n\nLEdge.prototype.isInterGraph = function () {\n  return this.isInterGraph;\n};\n\nLEdge.prototype.getLength = function () {\n  return this.length;\n};\n\nLEdge.prototype.isOverlapingSourceAndTarget = function () {\n  return this.isOverlapingSourceAndTarget;\n};\n\nLEdge.prototype.getBendpoints = function () {\n  return this.bendpoints;\n};\n\nLEdge.prototype.getLca = function () {\n  return this.lca;\n};\n\nLEdge.prototype.getSourceInLca = function () {\n  return this.sourceInLca;\n};\n\nLEdge.prototype.getTargetInLca = function () {\n  return this.targetInLca;\n};\n\nLEdge.prototype.getOtherEnd = function (node) {\n  if (this.source === node) {\n    return this.target;\n  } else if (this.target === node) {\n    return this.source;\n  } else {\n    throw \"Node is not incident with this edge\";\n  }\n};\n\nLEdge.prototype.getOtherEndInGraph = function (node, graph) {\n  var otherEnd = this.getOtherEnd(node);\n  var root = graph.getGraphManager().getRoot();\n\n  while (true) {\n    if (otherEnd.getOwner() == graph) {\n      return otherEnd;\n    }\n\n    if (otherEnd.getOwner() == root) {\n      break;\n    }\n\n    otherEnd = otherEnd.getOwner().getParent();\n  }\n\n  return null;\n};\n\nLEdge.prototype.updateLength = function () {\n  var clipPointCoordinates = new Array(4);\n\n  this.isOverlapingSourceAndTarget = IGeometry.getIntersection(this.target.getRect(), this.source.getRect(), clipPointCoordinates);\n\n  if (!this.isOverlapingSourceAndTarget) {\n    this.lengthX = clipPointCoordinates[0] - clipPointCoordinates[2];\n    this.lengthY = clipPointCoordinates[1] - clipPointCoordinates[3];\n\n    if (Math.abs(this.lengthX) < 1.0) {\n      this.lengthX = IMath.sign(this.lengthX);\n    }\n\n    if (Math.abs(this.lengthY) < 1.0) {\n      this.lengthY = IMath.sign(this.lengthY);\n    }\n\n    this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY);\n  }\n};\n\nLEdge.prototype.updateLengthSimple = function () {\n  this.lengthX = this.target.getCenterX() - this.source.getCenterX();\n  this.lengthY = this.target.getCenterY() - this.source.getCenterY();\n\n  if (Math.abs(this.lengthX) < 1.0) {\n    this.lengthX = IMath.sign(this.lengthX);\n  }\n\n  if (Math.abs(this.lengthY) < 1.0) {\n    this.lengthY = IMath.sign(this.lengthY);\n  }\n\n  this.length = Math.sqrt(this.lengthX * this.lengthX + this.lengthY * this.lengthY);\n};\n\nmodule.exports = LEdge;\n\n/***/ }),\n/* 8 */\n/***/ (function(module, exports) {\n\nfunction LGraphObject(vGraphObject) {\n  this.vGraphObject = vGraphObject;\n}\n\nmodule.exports = LGraphObject;\n\n/***/ }),\n/* 9 */\n/***/ (function(module, exports) {\n\nfunction IGeometry() {}\n\nIGeometry.calcSeparationAmount = function (rectA, rectB, overlapAmount, separationBuffer) {\n  if (!rectA.intersects(rectB)) {\n    throw \"assert failed\";\n  }\n  var directions = new Array(2);\n  IGeometry.decideDirectionsForOverlappingNodes(rectA, rectB, directions);\n  overlapAmount[0] = Math.min(rectA.getRight(), rectB.getRight()) - Math.max(rectA.x, rectB.x);\n  overlapAmount[1] = Math.min(rectA.getBottom(), rectB.getBottom()) - Math.max(rectA.y, rectB.y);\n  // update the overlapping amounts for the following cases:\n  if (rectA.getX() <= rectB.getX() && rectA.getRight() >= rectB.getRight()) {\n    overlapAmount[0] += Math.min(rectB.getX() - rectA.getX(), rectA.getRight() - rectB.getRight());\n  } else if (rectB.getX() <= rectA.getX() && rectB.getRight() >= rectA.getRight()) {\n    overlapAmount[0] += Math.min(rectA.getX() - rectB.getX(), rectB.getRight() - rectA.getRight());\n  }\n  if (rectA.getY() <= rectB.getY() && rectA.getBottom() >= rectB.getBottom()) {\n    overlapAmount[1] += Math.min(rectB.getY() - rectA.getY(), rectA.getBottom() - rectB.getBottom());\n  } else if (rectB.getY() <= rectA.getY() && rectB.getBottom() >= rectA.getBottom()) {\n    overlapAmount[1] += Math.min(rectA.getY() - rectB.getY(), rectB.getBottom() - rectA.getBottom());\n  }\n\n  // find slope of the line passes two centers\n  var slope = Math.abs((rectB.getCenterY() - rectA.getCenterY()) / (rectB.getCenterX() - rectA.getCenterX()));\n  // if centers are overlapped\n  if (rectB.getCenterY() == rectA.getCenterY() && rectB.getCenterX() == rectA.getCenterX()) {\n    // assume the slope is 1 (45 degree)\n    slope = 1.0;\n  }\n\n  var moveByY = slope * overlapAmount[0];\n  var moveByX = overlapAmount[1] / slope;\n  if (overlapAmount[0] < moveByX) {\n    moveByX = overlapAmount[0];\n  } else {\n    moveByY = overlapAmount[1];\n  }\n  // return half the amount so that if each rectangle is moved by these\n  // amounts in opposite directions, overlap will be resolved\n  overlapAmount[0] = -1 * directions[0] * (moveByX / 2 + separationBuffer);\n  overlapAmount[1] = -1 * directions[1] * (moveByY / 2 + separationBuffer);\n};\n\nIGeometry.decideDirectionsForOverlappingNodes = function (rectA, rectB, directions) {\n  if (rectA.getCenterX() < rectB.getCenterX()) {\n    directions[0] = -1;\n  } else {\n    directions[0] = 1;\n  }\n\n  if (rectA.getCenterY() < rectB.getCenterY()) {\n    directions[1] = -1;\n  } else {\n    directions[1] = 1;\n  }\n};\n\nIGeometry.getIntersection2 = function (rectA, rectB, result) {\n  //result[0-1] will contain clipPoint of rectA, result[2-3] will contain clipPoint of rectB\n  var p1x = rectA.getCenterX();\n  var p1y = rectA.getCenterY();\n  var p2x = rectB.getCenterX();\n  var p2y = rectB.getCenterY();\n\n  //if two rectangles intersect, then clipping points are centers\n  if (rectA.intersects(rectB)) {\n    result[0] = p1x;\n    result[1] = p1y;\n    result[2] = p2x;\n    result[3] = p2y;\n    return true;\n  }\n  //variables for rectA\n  var topLeftAx = rectA.getX();\n  var topLeftAy = rectA.getY();\n  var topRightAx = rectA.getRight();\n  var bottomLeftAx = rectA.getX();\n  var bottomLeftAy = rectA.getBottom();\n  var bottomRightAx = rectA.getRight();\n  var halfWidthA = rectA.getWidthHalf();\n  var halfHeightA = rectA.getHeightHalf();\n  //variables for rectB\n  var topLeftBx = rectB.getX();\n  var topLeftBy = rectB.getY();\n  var topRightBx = rectB.getRight();\n  var bottomLeftBx = rectB.getX();\n  var bottomLeftBy = rectB.getBottom();\n  var bottomRightBx = rectB.getRight();\n  var halfWidthB = rectB.getWidthHalf();\n  var halfHeightB = rectB.getHeightHalf();\n  //flag whether clipping points are found\n  var clipPointAFound = false;\n  var clipPointBFound = false;\n\n  // line is vertical\n  if (p1x == p2x) {\n    if (p1y > p2y) {\n      result[0] = p1x;\n      result[1] = topLeftAy;\n      result[2] = p2x;\n      result[3] = bottomLeftBy;\n      return false;\n    } else if (p1y < p2y) {\n      result[0] = p1x;\n      result[1] = bottomLeftAy;\n      result[2] = p2x;\n      result[3] = topLeftBy;\n      return false;\n    } else {\n      //not line, return null;\n    }\n  }\n  // line is horizontal\n  else if (p1y == p2y) {\n      if (p1x > p2x) {\n        result[0] = topLeftAx;\n        result[1] = p1y;\n        result[2] = topRightBx;\n        result[3] = p2y;\n        return false;\n      } else if (p1x < p2x) {\n        result[0] = topRightAx;\n        result[1] = p1y;\n        result[2] = topLeftBx;\n        result[3] = p2y;\n        return false;\n      } else {\n        //not valid line, return null;\n      }\n    } else {\n      //slopes of rectA's and rectB's diagonals\n      var slopeA = rectA.height / rectA.width;\n      var slopeB = rectB.height / rectB.width;\n\n      //slope of line between center of rectA and center of rectB\n      var slopePrime = (p2y - p1y) / (p2x - p1x);\n      var cardinalDirectionA;\n      var cardinalDirectionB;\n      var tempPointAx;\n      var tempPointAy;\n      var tempPointBx;\n      var tempPointBy;\n\n      //determine whether clipping point is the corner of nodeA\n      if (-slopeA == slopePrime) {\n        if (p1x > p2x) {\n          result[0] = bottomLeftAx;\n          result[1] = bottomLeftAy;\n          clipPointAFound = true;\n        } else {\n          result[0] = topRightAx;\n          result[1] = topLeftAy;\n          clipPointAFound = true;\n        }\n      } else if (slopeA == slopePrime) {\n        if (p1x > p2x) {\n          result[0] = topLeftAx;\n          result[1] = topLeftAy;\n          clipPointAFound = true;\n        } else {\n          result[0] = bottomRightAx;\n          result[1] = bottomLeftAy;\n          clipPointAFound = true;\n        }\n      }\n\n      //determine whether clipping point is the corner of nodeB\n      if (-slopeB == slopePrime) {\n        if (p2x > p1x) {\n          result[2] = bottomLeftBx;\n          result[3] = bottomLeftBy;\n          clipPointBFound = true;\n        } else {\n          result[2] = topRightBx;\n          result[3] = topLeftBy;\n          clipPointBFound = true;\n        }\n      } else if (slopeB == slopePrime) {\n        if (p2x > p1x) {\n          result[2] = topLeftBx;\n          result[3] = topLeftBy;\n          clipPointBFound = true;\n        } else {\n          result[2] = bottomRightBx;\n          result[3] = bottomLeftBy;\n          clipPointBFound = true;\n        }\n      }\n\n      //if both clipping points are corners\n      if (clipPointAFound && clipPointBFound) {\n        return false;\n      }\n\n      //determine Cardinal Direction of rectangles\n      if (p1x > p2x) {\n        if (p1y > p2y) {\n          cardinalDirectionA = IGeometry.getCardinalDirection(slopeA, slopePrime, 4);\n          cardinalDirectionB = IGeometry.getCardinalDirection(slopeB, slopePrime, 2);\n        } else {\n          cardinalDirectionA = IGeometry.getCardinalDirection(-slopeA, slopePrime, 3);\n          cardinalDirectionB = IGeometry.getCardinalDirection(-slopeB, slopePrime, 1);\n        }\n      } else {\n        if (p1y > p2y) {\n          cardinalDirectionA = IGeometry.getCardinalDirection(-slopeA, slopePrime, 1);\n          cardinalDirectionB = IGeometry.getCardinalDirection(-slopeB, slopePrime, 3);\n        } else {\n          cardinalDirectionA = IGeometry.getCardinalDirection(slopeA, slopePrime, 2);\n          cardinalDirectionB = IGeometry.getCardinalDirection(slopeB, slopePrime, 4);\n        }\n      }\n      //calculate clipping Point if it is not found before\n      if (!clipPointAFound) {\n        switch (cardinalDirectionA) {\n          case 1:\n            tempPointAy = topLeftAy;\n            tempPointAx = p1x + -halfHeightA / slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 2:\n            tempPointAx = bottomRightAx;\n            tempPointAy = p1y + halfWidthA * slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 3:\n            tempPointAy = bottomLeftAy;\n            tempPointAx = p1x + halfHeightA / slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n          case 4:\n            tempPointAx = bottomLeftAx;\n            tempPointAy = p1y + -halfWidthA * slopePrime;\n            result[0] = tempPointAx;\n            result[1] = tempPointAy;\n            break;\n        }\n      }\n      if (!clipPointBFound) {\n        switch (cardinalDirectionB) {\n          case 1:\n            tempPointBy = topLeftBy;\n            tempPointBx = p2x + -halfHeightB / slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 2:\n            tempPointBx = bottomRightBx;\n            tempPointBy = p2y + halfWidthB * slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 3:\n            tempPointBy = bottomLeftBy;\n            tempPointBx = p2x + halfHeightB / slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n          case 4:\n            tempPointBx = bottomLeftBx;\n            tempPointBy = p2y + -halfWidthB * slopePrime;\n            result[2] = tempPointBx;\n            result[3] = tempPointBy;\n            break;\n        }\n      }\n    }\n  return false;\n};\n\nIGeometry.getCardinalDirection = function (slope, slopePrime, line) {\n  if (slope > slopePrime) {\n    return line;\n  } else {\n    return 1 + line % 4;\n  }\n};\n\nIGeometry.getIntersection = function (s1, s2, f1, f2) {\n  if (f2 == null) {\n    return IGeometry.getIntersection2(s1, s2, f1);\n  }\n  var x1 = s1.x;\n  var y1 = s1.y;\n  var x2 = s2.x;\n  var y2 = s2.y;\n  var x3 = f1.x;\n  var y3 = f1.y;\n  var x4 = f2.x;\n  var y4 = f2.y;\n  var x, y; // intersection point\n  var a1, a2, b1, b2, c1, c2; // coefficients of line eqns.\n  var denom;\n\n  a1 = y2 - y1;\n  b1 = x1 - x2;\n  c1 = x2 * y1 - x1 * y2; // { a1*x + b1*y + c1 = 0 is line 1 }\n\n  a2 = y4 - y3;\n  b2 = x3 - x4;\n  c2 = x4 * y3 - x3 * y4; // { a2*x + b2*y + c2 = 0 is line 2 }\n\n  denom = a1 * b2 - a2 * b1;\n\n  if (denom == 0) {\n    return null;\n  }\n\n  x = (b1 * c2 - b2 * c1) / denom;\n  y = (a2 * c1 - a1 * c2) / denom;\n\n  return new Point(x, y);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Class Constants\n// -----------------------------------------------------------------------------\n/**\r\n * Some useful pre-calculated constants\r\n */\nIGeometry.HALF_PI = 0.5 * Math.PI;\nIGeometry.ONE_AND_HALF_PI = 1.5 * Math.PI;\nIGeometry.TWO_PI = 2.0 * Math.PI;\nIGeometry.THREE_PI = 3.0 * Math.PI;\n\nmodule.exports = IGeometry;\n\n/***/ }),\n/* 10 */\n/***/ (function(module, exports) {\n\nfunction IMath() {}\n\n/**\r\n * This method returns the sign of the input value.\r\n */\nIMath.sign = function (value) {\n  if (value > 0) {\n    return 1;\n  } else if (value < 0) {\n    return -1;\n  } else {\n    return 0;\n  }\n};\n\nIMath.floor = function (value) {\n  return value < 0 ? Math.ceil(value) : Math.floor(value);\n};\n\nIMath.ceil = function (value) {\n  return value < 0 ? Math.floor(value) : Math.ceil(value);\n};\n\nmodule.exports = IMath;\n\n/***/ }),\n/* 11 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar Integer = __webpack_require__(12);\nvar LayoutConstants = __webpack_require__(3);\nvar LGraphManager = __webpack_require__(6);\nvar LNode = __webpack_require__(13);\nvar LEdge = __webpack_require__(7);\nvar RectangleD = __webpack_require__(14);\nvar Point = __webpack_require__(18);\nvar LinkedList = __webpack_require__(19);\n\nfunction LGraph(parent, obj2, vGraph) {\n  LGraphObject.call(this, vGraph);\n  this.estimatedSize = Integer.MIN_VALUE;\n  this.margin = LayoutConstants.DEFAULT_GRAPH_MARGIN;\n  this.edges = [];\n  this.nodes = [];\n  this.isConnected = false;\n  this.parent = parent;\n\n  if (obj2 != null && obj2 instanceof LGraphManager) {\n    this.graphManager = obj2;\n  } else if (obj2 != null && obj2 instanceof Layout) {\n    this.graphManager = obj2.graphManager;\n  }\n}\n\nLGraph.prototype = Object.create(LGraphObject.prototype);\nfor (var prop in LGraphObject) {\n  LGraph[prop] = LGraphObject[prop];\n}\n\nLGraph.prototype.getNodes = function () {\n  return this.nodes;\n};\n\nLGraph.prototype.getEdges = function () {\n  return this.edges;\n};\n\nLGraph.prototype.getGraphManager = function () {\n  return this.graphManager;\n};\n\nLGraph.prototype.getParent = function () {\n  return this.parent;\n};\n\nLGraph.prototype.getLeft = function () {\n  return this.left;\n};\n\nLGraph.prototype.getRight = function () {\n  return this.right;\n};\n\nLGraph.prototype.getTop = function () {\n  return this.top;\n};\n\nLGraph.prototype.getBottom = function () {\n  return this.bottom;\n};\n\nLGraph.prototype.isConnected = function () {\n  return this.isConnected;\n};\n\nLGraph.prototype.add = function (obj1, sourceNode, targetNode) {\n  if (sourceNode == null && targetNode == null) {\n    var newNode = obj1;\n    if (this.graphManager == null) {\n      throw \"Graph has no graph mgr!\";\n    }\n    if (this.getNodes().indexOf(newNode) > -1) {\n      throw \"Node already in graph!\";\n    }\n    newNode.owner = this;\n    this.getNodes().push(newNode);\n\n    return newNode;\n  } else {\n    var newEdge = obj1;\n    if (!(this.getNodes().indexOf(sourceNode) > -1 && this.getNodes().indexOf(targetNode) > -1)) {\n      throw \"Source or target not in graph!\";\n    }\n\n    if (!(sourceNode.owner == targetNode.owner && sourceNode.owner == this)) {\n      throw \"Both owners must be this graph!\";\n    }\n\n    if (sourceNode.owner != targetNode.owner) {\n      return null;\n    }\n\n    // set source and target\n    newEdge.source = sourceNode;\n    newEdge.target = targetNode;\n\n    // set as intra-graph edge\n    newEdge.isInterGraph = false;\n\n    // add to graph edge list\n    this.getEdges().push(newEdge);\n\n    // add to incidency lists\n    sourceNode.edges.push(newEdge);\n\n    if (targetNode != sourceNode) {\n      targetNode.edges.push(newEdge);\n    }\n\n    return newEdge;\n  }\n};\n\nLGraph.prototype.remove = function (obj) {\n  var node = obj;\n  if (obj instanceof LNode) {\n    if (node == null) {\n      throw \"Node is null!\";\n    }\n    if (!(node.owner != null && node.owner == this)) {\n      throw \"Owner graph is invalid!\";\n    }\n    if (this.graphManager == null) {\n      throw \"Owner graph manager is invalid!\";\n    }\n    // remove incident edges first (make a copy to do it safely)\n    var edgesToBeRemoved = node.edges.slice();\n    var edge;\n    var s = edgesToBeRemoved.length;\n    for (var i = 0; i < s; i++) {\n      edge = edgesToBeRemoved[i];\n\n      if (edge.isInterGraph) {\n        this.graphManager.remove(edge);\n      } else {\n        edge.source.owner.remove(edge);\n      }\n    }\n\n    // now the node itself\n    var index = this.nodes.indexOf(node);\n    if (index == -1) {\n      throw \"Node not in owner node list!\";\n    }\n\n    this.nodes.splice(index, 1);\n  } else if (obj instanceof LEdge) {\n    var edge = obj;\n    if (edge == null) {\n      throw \"Edge is null!\";\n    }\n    if (!(edge.source != null && edge.target != null)) {\n      throw \"Source and/or target is null!\";\n    }\n    if (!(edge.source.owner != null && edge.target.owner != null && edge.source.owner == this && edge.target.owner == this)) {\n      throw \"Source and/or target owner is invalid!\";\n    }\n\n    var sourceIndex = edge.source.edges.indexOf(edge);\n    var targetIndex = edge.target.edges.indexOf(edge);\n    if (!(sourceIndex > -1 && targetIndex > -1)) {\n      throw \"Source and/or target doesn't know this edge!\";\n    }\n\n    edge.source.edges.splice(sourceIndex, 1);\n\n    if (edge.target != edge.source) {\n      edge.target.edges.splice(targetIndex, 1);\n    }\n\n    var index = edge.source.owner.getEdges().indexOf(edge);\n    if (index == -1) {\n      throw \"Not in owner's edge list!\";\n    }\n\n    edge.source.owner.getEdges().splice(index, 1);\n  }\n};\n\nLGraph.prototype.updateLeftTop = function () {\n  var top = Integer.MAX_VALUE;\n  var left = Integer.MAX_VALUE;\n  var nodeTop;\n  var nodeLeft;\n  var margin;\n\n  var nodes = this.getNodes();\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    nodeTop = lNode.getTop();\n    nodeLeft = lNode.getLeft();\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n  }\n\n  // Do we have any nodes in this graph?\n  if (top == Integer.MAX_VALUE) {\n    return null;\n  }\n\n  if (nodes[0].getParent().paddingLeft != undefined) {\n    margin = nodes[0].getParent().paddingLeft;\n  } else {\n    margin = this.margin;\n  }\n\n  this.left = left - margin;\n  this.top = top - margin;\n\n  // Apply the margins and return the result\n  return new Point(this.left, this.top);\n};\n\nLGraph.prototype.updateBounds = function (recursive) {\n  // calculate bounds\n  var left = Integer.MAX_VALUE;\n  var right = -Integer.MAX_VALUE;\n  var top = Integer.MAX_VALUE;\n  var bottom = -Integer.MAX_VALUE;\n  var nodeLeft;\n  var nodeRight;\n  var nodeTop;\n  var nodeBottom;\n  var margin;\n\n  var nodes = this.nodes;\n  var s = nodes.length;\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n\n    if (recursive && lNode.child != null) {\n      lNode.updateBounds();\n    }\n    nodeLeft = lNode.getLeft();\n    nodeRight = lNode.getRight();\n    nodeTop = lNode.getTop();\n    nodeBottom = lNode.getBottom();\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n\n    if (right < nodeRight) {\n      right = nodeRight;\n    }\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (bottom < nodeBottom) {\n      bottom = nodeBottom;\n    }\n  }\n\n  var boundingRect = new RectangleD(left, top, right - left, bottom - top);\n  if (left == Integer.MAX_VALUE) {\n    this.left = this.parent.getLeft();\n    this.right = this.parent.getRight();\n    this.top = this.parent.getTop();\n    this.bottom = this.parent.getBottom();\n  }\n\n  if (nodes[0].getParent().paddingLeft != undefined) {\n    margin = nodes[0].getParent().paddingLeft;\n  } else {\n    margin = this.margin;\n  }\n\n  this.left = boundingRect.x - margin;\n  this.right = boundingRect.x + boundingRect.width + margin;\n  this.top = boundingRect.y - margin;\n  this.bottom = boundingRect.y + boundingRect.height + margin;\n};\n\nLGraph.calculateBounds = function (nodes) {\n  var left = Integer.MAX_VALUE;\n  var right = -Integer.MAX_VALUE;\n  var top = Integer.MAX_VALUE;\n  var bottom = -Integer.MAX_VALUE;\n  var nodeLeft;\n  var nodeRight;\n  var nodeTop;\n  var nodeBottom;\n\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    nodeLeft = lNode.getLeft();\n    nodeRight = lNode.getRight();\n    nodeTop = lNode.getTop();\n    nodeBottom = lNode.getBottom();\n\n    if (left > nodeLeft) {\n      left = nodeLeft;\n    }\n\n    if (right < nodeRight) {\n      right = nodeRight;\n    }\n\n    if (top > nodeTop) {\n      top = nodeTop;\n    }\n\n    if (bottom < nodeBottom) {\n      bottom = nodeBottom;\n    }\n  }\n\n  var boundingRect = new RectangleD(left, top, right - left, bottom - top);\n\n  return boundingRect;\n};\n\nLGraph.prototype.getInclusionTreeDepth = function () {\n  if (this == this.graphManager.getRoot()) {\n    return 1;\n  } else {\n    return this.parent.getInclusionTreeDepth();\n  }\n};\n\nLGraph.prototype.getEstimatedSize = function () {\n  if (this.estimatedSize == Integer.MIN_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.estimatedSize;\n};\n\nLGraph.prototype.calcEstimatedSize = function () {\n  var size = 0;\n  var nodes = this.nodes;\n  var s = nodes.length;\n\n  for (var i = 0; i < s; i++) {\n    var lNode = nodes[i];\n    size += lNode.calcEstimatedSize();\n  }\n\n  if (size == 0) {\n    this.estimatedSize = LayoutConstants.EMPTY_COMPOUND_NODE_SIZE;\n  } else {\n    this.estimatedSize = size / Math.sqrt(this.nodes.length);\n  }\n\n  return this.estimatedSize;\n};\n\nLGraph.prototype.updateConnected = function () {\n  var self = this;\n  if (this.nodes.length == 0) {\n    this.isConnected = true;\n    return;\n  }\n\n  var queue = new LinkedList();\n  var visited = new Set();\n  var currentNode = this.nodes[0];\n  var neighborEdges;\n  var currentNeighbor;\n  var childrenOfNode = currentNode.withChildren();\n  childrenOfNode.forEach(function (node) {\n    queue.push(node);\n    visited.add(node);\n  });\n\n  while (queue.length !== 0) {\n    currentNode = queue.shift();\n\n    // Traverse all neighbors of this node\n    neighborEdges = currentNode.getEdges();\n    var size = neighborEdges.length;\n    for (var i = 0; i < size; i++) {\n      var neighborEdge = neighborEdges[i];\n      currentNeighbor = neighborEdge.getOtherEndInGraph(currentNode, this);\n\n      // Add unvisited neighbors to the list to visit\n      if (currentNeighbor != null && !visited.has(currentNeighbor)) {\n        var childrenOfNeighbor = currentNeighbor.withChildren();\n\n        childrenOfNeighbor.forEach(function (node) {\n          queue.push(node);\n          visited.add(node);\n        });\n      }\n    }\n  }\n\n  this.isConnected = false;\n\n  if (visited.size >= this.nodes.length) {\n    var noOfVisitedInThisGraph = 0;\n\n    visited.forEach(function (visitedNode) {\n      if (visitedNode.owner == self) {\n        noOfVisitedInThisGraph++;\n      }\n    });\n\n    if (noOfVisitedInThisGraph == this.nodes.length) {\n      this.isConnected = true;\n    }\n  }\n};\n\nmodule.exports = LGraph;\n\n/***/ }),\n/* 12 */\n/***/ (function(module, exports) {\n\nfunction Integer() {}\n\nInteger.MAX_VALUE = 2147483647;\nInteger.MIN_VALUE = -2147483648;\n\nmodule.exports = Integer;\n\n/***/ }),\n/* 13 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LGraphObject = __webpack_require__(8);\nvar Integer = __webpack_require__(12);\nvar RectangleD = __webpack_require__(14);\nvar LayoutConstants = __webpack_require__(3);\nvar RandomSeed = __webpack_require__(15);\nvar PointD = __webpack_require__(16);\nvar HashSet = __webpack_require__(17);\n\nfunction LNode(gm, loc, size, vNode) {\n  //Alternative constructor 1 : LNode(LGraphManager gm, Point loc, Dimension size, Object vNode)\n  if (size == null && vNode == null) {\n    vNode = loc;\n  }\n\n  LGraphObject.call(this, vNode);\n\n  //Alternative constructor 2 : LNode(Layout layout, Object vNode)\n  if (gm.graphManager != null) gm = gm.graphManager;\n\n  this.estimatedSize = Integer.MIN_VALUE;\n  this.inclusionTreeDepth = Integer.MAX_VALUE;\n  this.vGraphObject = vNode;\n  this.edges = [];\n  this.graphManager = gm;\n\n  if (size != null && loc != null) this.rect = new RectangleD(loc.x, loc.y, size.width, size.height);else this.rect = new RectangleD();\n}\n\nLNode.prototype = Object.create(LGraphObject.prototype);\nfor (var prop in LGraphObject) {\n  LNode[prop] = LGraphObject[prop];\n}\n\nLNode.prototype.getEdges = function () {\n  return this.edges;\n};\n\nLNode.prototype.getChild = function () {\n  return this.child;\n};\n\nLNode.prototype.getOwner = function () {\n  //  if (this.owner != null) {\n  //    if (!(this.owner == null || this.owner.getNodes().indexOf(this) > -1)) {\n  //      throw \"assert failed\";\n  //    }\n  //  }\n\n  return this.owner;\n};\n\nLNode.prototype.getWidth = function () {\n  return this.rect.width;\n};\n\nLNode.prototype.setWidth = function (width) {\n  this.rect.width = width;\n};\n\nLNode.prototype.getHeight = function () {\n  return this.rect.height;\n};\n\nLNode.prototype.setHeight = function (height) {\n  this.rect.height = height;\n};\n\nLNode.prototype.getCenterX = function () {\n  return this.rect.x + this.rect.width / 2;\n};\n\nLNode.prototype.getCenterY = function () {\n  return this.rect.y + this.rect.height / 2;\n};\n\nLNode.prototype.getCenter = function () {\n  return new PointD(this.rect.x + this.rect.width / 2, this.rect.y + this.rect.height / 2);\n};\n\nLNode.prototype.getLocation = function () {\n  return new PointD(this.rect.x, this.rect.y);\n};\n\nLNode.prototype.getRect = function () {\n  return this.rect;\n};\n\nLNode.prototype.getDiagonal = function () {\n  return Math.sqrt(this.rect.width * this.rect.width + this.rect.height * this.rect.height);\n};\n\nLNode.prototype.setRect = function (upperLeft, dimension) {\n  this.rect.x = upperLeft.x;\n  this.rect.y = upperLeft.y;\n  this.rect.width = dimension.width;\n  this.rect.height = dimension.height;\n};\n\nLNode.prototype.setCenter = function (cx, cy) {\n  this.rect.x = cx - this.rect.width / 2;\n  this.rect.y = cy - this.rect.height / 2;\n};\n\nLNode.prototype.setLocation = function (x, y) {\n  this.rect.x = x;\n  this.rect.y = y;\n};\n\nLNode.prototype.moveBy = function (dx, dy) {\n  this.rect.x += dx;\n  this.rect.y += dy;\n};\n\nLNode.prototype.getEdgeListToNode = function (to) {\n  var edgeList = [];\n  var edge;\n  var self = this;\n\n  self.edges.forEach(function (edge) {\n\n    if (edge.target == to) {\n      if (edge.source != self) throw \"Incorrect edge source!\";\n\n      edgeList.push(edge);\n    }\n  });\n\n  return edgeList;\n};\n\nLNode.prototype.getEdgesBetween = function (other) {\n  var edgeList = [];\n  var edge;\n\n  var self = this;\n  self.edges.forEach(function (edge) {\n\n    if (!(edge.source == self || edge.target == self)) throw \"Incorrect edge source and/or target\";\n\n    if (edge.target == other || edge.source == other) {\n      edgeList.push(edge);\n    }\n  });\n\n  return edgeList;\n};\n\nLNode.prototype.getNeighborsList = function () {\n  var neighbors = new HashSet();\n  var edge;\n\n  var self = this;\n  self.edges.forEach(function (edge) {\n\n    if (edge.source == self) {\n      neighbors.add(edge.target);\n    } else {\n      if (edge.target != self) {\n        throw \"Incorrect incidency!\";\n      }\n\n      neighbors.add(edge.source);\n    }\n  });\n\n  return neighbors;\n};\n\nLNode.prototype.withChildren = function () {\n  var withNeighborsList = new Set();\n  var childNode;\n  var children;\n\n  withNeighborsList.add(this);\n\n  if (this.child != null) {\n    var nodes = this.child.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      childNode = nodes[i];\n      children = childNode.withChildren();\n      children.forEach(function (node) {\n        withNeighborsList.add(node);\n      });\n    }\n  }\n\n  return withNeighborsList;\n};\n\nLNode.prototype.getNoOfChildren = function () {\n  var noOfChildren = 0;\n  var childNode;\n\n  if (this.child == null) {\n    noOfChildren = 1;\n  } else {\n    var nodes = this.child.getNodes();\n    for (var i = 0; i < nodes.length; i++) {\n      childNode = nodes[i];\n\n      noOfChildren += childNode.getNoOfChildren();\n    }\n  }\n\n  if (noOfChildren == 0) {\n    noOfChildren = 1;\n  }\n  return noOfChildren;\n};\n\nLNode.prototype.getEstimatedSize = function () {\n  if (this.estimatedSize == Integer.MIN_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.estimatedSize;\n};\n\nLNode.prototype.calcEstimatedSize = function () {\n  if (this.child == null) {\n    return this.estimatedSize = (this.rect.width + this.rect.height) / 2;\n  } else {\n    this.estimatedSize = this.child.calcEstimatedSize();\n    this.rect.width = this.estimatedSize;\n    this.rect.height = this.estimatedSize;\n\n    return this.estimatedSize;\n  }\n};\n\nLNode.prototype.scatter = function () {\n  var randomCenterX;\n  var randomCenterY;\n\n  var minX = -LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  var maxX = LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  randomCenterX = LayoutConstants.WORLD_CENTER_X + RandomSeed.nextDouble() * (maxX - minX) + minX;\n\n  var minY = -LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  var maxY = LayoutConstants.INITIAL_WORLD_BOUNDARY;\n  randomCenterY = LayoutConstants.WORLD_CENTER_Y + RandomSeed.nextDouble() * (maxY - minY) + minY;\n\n  this.rect.x = randomCenterX;\n  this.rect.y = randomCenterY;\n};\n\nLNode.prototype.updateBounds = function () {\n  if (this.getChild() == null) {\n    throw \"assert failed\";\n  }\n  if (this.getChild().getNodes().length != 0) {\n    // wrap the children nodes by re-arranging the boundaries\n    var childGraph = this.getChild();\n    childGraph.updateBounds(true);\n\n    this.rect.x = childGraph.getLeft();\n    this.rect.y = childGraph.getTop();\n\n    this.setWidth(childGraph.getRight() - childGraph.getLeft());\n    this.setHeight(childGraph.getBottom() - childGraph.getTop());\n\n    // Update compound bounds considering its label properties    \n    if (LayoutConstants.NODE_DIMENSIONS_INCLUDE_LABELS) {\n\n      var width = childGraph.getRight() - childGraph.getLeft();\n      var height = childGraph.getBottom() - childGraph.getTop();\n\n      if (this.labelWidth > width) {\n        this.rect.x -= (this.labelWidth - width) / 2;\n        this.setWidth(this.labelWidth);\n      }\n\n      if (this.labelHeight > height) {\n        if (this.labelPos == \"center\") {\n          this.rect.y -= (this.labelHeight - height) / 2;\n        } else if (this.labelPos == \"top\") {\n          this.rect.y -= this.labelHeight - height;\n        }\n        this.setHeight(this.labelHeight);\n      }\n    }\n  }\n};\n\nLNode.prototype.getInclusionTreeDepth = function () {\n  if (this.inclusionTreeDepth == Integer.MAX_VALUE) {\n    throw \"assert failed\";\n  }\n  return this.inclusionTreeDepth;\n};\n\nLNode.prototype.transform = function (trans) {\n  var left = this.rect.x;\n\n  if (left > LayoutConstants.WORLD_BOUNDARY) {\n    left = LayoutConstants.WORLD_BOUNDARY;\n  } else if (left < -LayoutConstants.WORLD_BOUNDARY) {\n    left = -LayoutConstants.WORLD_BOUNDARY;\n  }\n\n  var top = this.rect.y;\n\n  if (top > LayoutConstants.WORLD_BOUNDARY) {\n    top = LayoutConstants.WORLD_BOUNDARY;\n  } else if (top < -LayoutConstants.WORLD_BOUNDARY) {\n    top = -LayoutConstants.WORLD_BOUNDARY;\n  }\n\n  var leftTop = new PointD(left, top);\n  var vLeftTop = trans.inverseTransformPoint(leftTop);\n\n  this.setLocation(vLeftTop.x, vLeftTop.y);\n};\n\nLNode.prototype.getLeft = function () {\n  return this.rect.x;\n};\n\nLNode.prototype.getRight = function () {\n  return this.rect.x + this.rect.width;\n};\n\nLNode.prototype.getTop = function () {\n  return this.rect.y;\n};\n\nLNode.prototype.getBottom = function () {\n  return this.rect.y + this.rect.height;\n};\n\nLNode.prototype.getParent = function () {\n  if (this.owner == null) {\n    return null;\n  }\n\n  return this.owner.getParent();\n};\n\nmodule.exports = LNode;\n\n/***/ }),\n/* 14 */\n/***/ (function(module, exports) {\n\nfunction RectangleD(x, y, width, height) {\n  this.x = 0;\n  this.y = 0;\n  this.width = 0;\n  this.height = 0;\n\n  if (x != null && y != null && width != null && height != null) {\n    this.x = x;\n    this.y = y;\n    this.width = width;\n    this.height = height;\n  }\n}\n\nRectangleD.prototype.getX = function () {\n  return this.x;\n};\n\nRectangleD.prototype.setX = function (x) {\n  this.x = x;\n};\n\nRectangleD.prototype.getY = function () {\n  return this.y;\n};\n\nRectangleD.prototype.setY = function (y) {\n  this.y = y;\n};\n\nRectangleD.prototype.getWidth = function () {\n  return this.width;\n};\n\nRectangleD.prototype.setWidth = function (width) {\n  this.width = width;\n};\n\nRectangleD.prototype.getHeight = function () {\n  return this.height;\n};\n\nRectangleD.prototype.setHeight = function (height) {\n  this.height = height;\n};\n\nRectangleD.prototype.getRight = function () {\n  return this.x + this.width;\n};\n\nRectangleD.prototype.getBottom = function () {\n  return this.y + this.height;\n};\n\nRectangleD.prototype.intersects = function (a) {\n  if (this.getRight() < a.x) {\n    return false;\n  }\n\n  if (this.getBottom() < a.y) {\n    return false;\n  }\n\n  if (a.getRight() < this.x) {\n    return false;\n  }\n\n  if (a.getBottom() < this.y) {\n    return false;\n  }\n\n  return true;\n};\n\nRectangleD.prototype.getCenterX = function () {\n  return this.x + this.width / 2;\n};\n\nRectangleD.prototype.getMinX = function () {\n  return this.getX();\n};\n\nRectangleD.prototype.getMaxX = function () {\n  return this.getX() + this.width;\n};\n\nRectangleD.prototype.getCenterY = function () {\n  return this.y + this.height / 2;\n};\n\nRectangleD.prototype.getMinY = function () {\n  return this.getY();\n};\n\nRectangleD.prototype.getMaxY = function () {\n  return this.getY() + this.height;\n};\n\nRectangleD.prototype.getWidthHalf = function () {\n  return this.width / 2;\n};\n\nRectangleD.prototype.getHeightHalf = function () {\n  return this.height / 2;\n};\n\nmodule.exports = RectangleD;\n\n/***/ }),\n/* 15 */\n/***/ (function(module, exports) {\n\nfunction RandomSeed() {}\nRandomSeed.seed = 1;\nRandomSeed.x = 0;\n\nRandomSeed.nextDouble = function () {\n  RandomSeed.x = Math.sin(RandomSeed.seed++) * 10000;\n  return RandomSeed.x - Math.floor(RandomSeed.x);\n};\n\nmodule.exports = RandomSeed;\n\n/***/ }),\n/* 16 */\n/***/ (function(module, exports) {\n\nfunction PointD(x, y) {\n  if (x == null && y == null) {\n    this.x = 0;\n    this.y = 0;\n  } else {\n    this.x = x;\n    this.y = y;\n  }\n}\n\nPointD.prototype.getX = function () {\n  return this.x;\n};\n\nPointD.prototype.getY = function () {\n  return this.y;\n};\n\nPointD.prototype.setX = function (x) {\n  this.x = x;\n};\n\nPointD.prototype.setY = function (y) {\n  this.y = y;\n};\n\nPointD.prototype.getDifference = function (pt) {\n  return new DimensionD(this.x - pt.x, this.y - pt.y);\n};\n\nPointD.prototype.getCopy = function () {\n  return new PointD(this.x, this.y);\n};\n\nPointD.prototype.translate = function (dim) {\n  this.x += dim.width;\n  this.y += dim.height;\n  return this;\n};\n\nmodule.exports = PointD;\n\n/***/ }),\n/* 17 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar UniqueIDGeneretor = __webpack_require__(5);\n\nfunction HashSet() {\n  this.set = {};\n}\n;\n\nHashSet.prototype.add = function (obj) {\n  var theId = UniqueIDGeneretor.createID(obj);\n  if (!this.contains(theId)) this.set[theId] = obj;\n};\n\nHashSet.prototype.remove = function (obj) {\n  delete this.set[UniqueIDGeneretor.createID(obj)];\n};\n\nHashSet.prototype.clear = function () {\n  this.set = {};\n};\n\nHashSet.prototype.contains = function (obj) {\n  return this.set[UniqueIDGeneretor.createID(obj)] == obj;\n};\n\nHashSet.prototype.isEmpty = function () {\n  return this.size() === 0;\n};\n\nHashSet.prototype.size = function () {\n  return Object.keys(this.set).length;\n};\n\n//concats this.set to the given list\nHashSet.prototype.addAllTo = function (list) {\n  var keys = Object.keys(this.set);\n  var length = keys.length;\n  for (var i = 0; i < length; i++) {\n    list.push(this.set[keys[i]]);\n  }\n};\n\nHashSet.prototype.size = function () {\n  return Object.keys(this.set).length;\n};\n\nHashSet.prototype.addAll = function (list) {\n  var s = list.length;\n  for (var i = 0; i < s; i++) {\n    var v = list[i];\n    this.add(v);\n  }\n};\n\nmodule.exports = HashSet;\n\n/***/ }),\n/* 18 */\n/***/ (function(module, exports) {\n\n/*\r\n *This class is the javascript implementation of the Point.java class in jdk\r\n */\nfunction Point(x, y, p) {\n  this.x = null;\n  this.y = null;\n  if (x == null && y == null && p == null) {\n    this.x = 0;\n    this.y = 0;\n  } else if (typeof x == 'number' && typeof y == 'number' && p == null) {\n    this.x = x;\n    this.y = y;\n  } else if (x.constructor.name == 'Point' && y == null && p == null) {\n    p = x;\n    this.x = p.x;\n    this.y = p.y;\n  }\n}\n\nPoint.prototype.getX = function () {\n  return this.x;\n};\n\nPoint.prototype.getY = function () {\n  return this.y;\n};\n\nPoint.prototype.getLocation = function () {\n  return new Point(this.x, this.y);\n};\n\nPoint.prototype.setLocation = function (x, y, p) {\n  if (x.constructor.name == 'Point' && y == null && p == null) {\n    p = x;\n    this.setLocation(p.x, p.y);\n  } else if (typeof x == 'number' && typeof y == 'number' && p == null) {\n    //if both parameters are integer just move (x,y) location\n    if (parseInt(x) == x && parseInt(y) == y) {\n      this.move(x, y);\n    } else {\n      this.x = Math.floor(x + 0.5);\n      this.y = Math.floor(y + 0.5);\n    }\n  }\n};\n\nPoint.prototype.move = function (x, y) {\n  this.x = x;\n  this.y = y;\n};\n\nPoint.prototype.translate = function (dx, dy) {\n  this.x += dx;\n  this.y += dy;\n};\n\nPoint.prototype.equals = function (obj) {\n  if (obj.constructor.name == \"Point\") {\n    var pt = obj;\n    return this.x == pt.x && this.y == pt.y;\n  }\n  return this == obj;\n};\n\nPoint.prototype.toString = function () {\n  return new Point().constructor.name + \"[x=\" + this.x + \",y=\" + this.y + \"]\";\n};\n\nmodule.exports = Point;\n\n/***/ }),\n/* 19 */\n/***/ (function(module, exports) {\n\nconst nodeFrom = value => ({ value, next: null, prev: null });\n\nconst add = (prev, node, next, list) => {\n  if (prev !== null) {\n    prev.next = node;\n  } else {\n    list.head = node;\n  }\n\n  if (next !== null) {\n    next.prev = node;\n  } else {\n    list.tail = node;\n  }\n\n  node.prev = prev;\n  node.next = next;\n\n  list.length++;\n\n  return node;\n};\n\nconst remove = (node, list) => {\n  let { prev, next } = node;\n\n  if (prev !== null) {\n    prev.next = next;\n  } else {\n    list.head = next;\n  }\n\n  if (next !== null) {\n    next.prev = prev;\n  } else {\n    list.tail = prev;\n  }\n\n  node.prev = node.next = null;\n\n  list.length--;\n\n  return node;\n};\n\nclass LinkedList {\n  constructor(vals) {\n    this.length = 0;\n    this.head = null;\n    this.tail = null;\n\n    if (vals != null) {\n      vals.forEach(v => this.push(v));\n    }\n  }\n\n  size() {\n    return this.length;\n  }\n\n  insertBefore(val, otherNode) {\n    return add(otherNode.prev, nodeFrom(val), otherNode, this);\n  }\n\n  insertAfter(val, otherNode) {\n    return add(otherNode, nodeFrom(val), otherNode.next, this);\n  }\n\n  insertNodeBefore(newNode, otherNode) {\n    return add(otherNode.prev, newNode, otherNode, this);\n  }\n\n  insertNodeAfter(newNode, otherNode) {\n    return add(otherNode, newNode, otherNode.next, this);\n  }\n\n  push(val) {\n    return add(this.tail, nodeFrom(val), null, this);\n  }\n\n  unshift(val) {\n    return add(null, nodeFrom(val), this.head, this);\n  }\n\n  remove(node) {\n    return remove(node, this);\n  }\n\n  pop() {\n    return remove(this.tail, this).value;\n  }\n\n  popNode() {\n    return remove(this.tail, this);\n  }\n\n  shift() {\n    return remove(this.head, this).value;\n  }\n\n  shiftNode() {\n    return remove(this.head, this);\n  }\n\n  get_object_at(index) {\n    if (index <= this.length()) {\n      var i = 1;\n      var current = this.head;\n      while (i < index) {\n        current = current.next;\n        i++;\n      }\n      return current.value;\n    }\n  }\n\n  set_object_at(index, value) {\n    if (index <= this.length()) {\n      var i = 1;\n      var current = this.head;\n      while (i < index) {\n        current = current.next;\n        i++;\n      }\n      current.value = value;\n    }\n  }\n}\n\nmodule.exports = LinkedList;\n\n/***/ }),\n/* 20 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar PointD = __webpack_require__(16);\n\nfunction Transform(x, y) {\n  this.lworldOrgX = 0.0;\n  this.lworldOrgY = 0.0;\n  this.ldeviceOrgX = 0.0;\n  this.ldeviceOrgY = 0.0;\n  this.lworldExtX = 1.0;\n  this.lworldExtY = 1.0;\n  this.ldeviceExtX = 1.0;\n  this.ldeviceExtY = 1.0;\n}\n\nTransform.prototype.getWorldOrgX = function () {\n  return this.lworldOrgX;\n};\n\nTransform.prototype.setWorldOrgX = function (wox) {\n  this.lworldOrgX = wox;\n};\n\nTransform.prototype.getWorldOrgY = function () {\n  return this.lworldOrgY;\n};\n\nTransform.prototype.setWorldOrgY = function (woy) {\n  this.lworldOrgY = woy;\n};\n\nTransform.prototype.getWorldExtX = function () {\n  return this.lworldExtX;\n};\n\nTransform.prototype.setWorldExtX = function (wex) {\n  this.lworldExtX = wex;\n};\n\nTransform.prototype.getWorldExtY = function () {\n  return this.lworldExtY;\n};\n\nTransform.prototype.setWorldExtY = function (wey) {\n  this.lworldExtY = wey;\n};\n\n/* Device related */\n\nTransform.prototype.getDeviceOrgX = function () {\n  return this.ldeviceOrgX;\n};\n\nTransform.prototype.setDeviceOrgX = function (dox) {\n  this.ldeviceOrgX = dox;\n};\n\nTransform.prototype.getDeviceOrgY = function () {\n  return this.ldeviceOrgY;\n};\n\nTransform.prototype.setDeviceOrgY = function (doy) {\n  this.ldeviceOrgY = doy;\n};\n\nTransform.prototype.getDeviceExtX = function () {\n  return this.ldeviceExtX;\n};\n\nTransform.prototype.setDeviceExtX = function (dex) {\n  this.ldeviceExtX = dex;\n};\n\nTransform.prototype.getDeviceExtY = function () {\n  return this.ldeviceExtY;\n};\n\nTransform.prototype.setDeviceExtY = function (dey) {\n  this.ldeviceExtY = dey;\n};\n\nTransform.prototype.transformX = function (x) {\n  var xDevice = 0.0;\n  var worldExtX = this.lworldExtX;\n  if (worldExtX != 0.0) {\n    xDevice = this.ldeviceOrgX + (x - this.lworldOrgX) * this.ldeviceExtX / worldExtX;\n  }\n\n  return xDevice;\n};\n\nTransform.prototype.transformY = function (y) {\n  var yDevice = 0.0;\n  var worldExtY = this.lworldExtY;\n  if (worldExtY != 0.0) {\n    yDevice = this.ldeviceOrgY + (y - this.lworldOrgY) * this.ldeviceExtY / worldExtY;\n  }\n\n  return yDevice;\n};\n\nTransform.prototype.inverseTransformX = function (x) {\n  var xWorld = 0.0;\n  var deviceExtX = this.ldeviceExtX;\n  if (deviceExtX != 0.0) {\n    xWorld = this.lworldOrgX + (x - this.ldeviceOrgX) * this.lworldExtX / deviceExtX;\n  }\n\n  return xWorld;\n};\n\nTransform.prototype.inverseTransformY = function (y) {\n  var yWorld = 0.0;\n  var deviceExtY = this.ldeviceExtY;\n  if (deviceExtY != 0.0) {\n    yWorld = this.lworldOrgY + (y - this.ldeviceOrgY) * this.lworldExtY / deviceExtY;\n  }\n  return yWorld;\n};\n\nTransform.prototype.inverseTransformPoint = function (inPoint) {\n  var outPoint = new PointD(this.inverseTransformX(inPoint.x), this.inverseTransformY(inPoint.y));\n  return outPoint;\n};\n\nmodule.exports = Transform;\n\n/***/ }),\n/* 21 */\n/***/ (function(module, exports) {\n\nfunction Emitter() {\n  this.listeners = [];\n}\n\nvar p = Emitter.prototype;\n\np.addListener = function (event, callback) {\n  this.listeners.push({\n    event: event,\n    callback: callback\n  });\n};\n\np.removeListener = function (event, callback) {\n  for (var i = this.listeners.length; i >= 0; i--) {\n    var l = this.listeners[i];\n\n    if (l.event === event && l.callback === callback) {\n      this.listeners.splice(i, 1);\n    }\n  }\n};\n\np.emit = function (event, data) {\n  for (var i = 0; i < this.listeners.length; i++) {\n    var l = this.listeners[i];\n\n    if (event === l.event) {\n      l.callback(data);\n    }\n  }\n};\n\nmodule.exports = Emitter;\n\n/***/ }),\n/* 22 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LayoutConstants = __webpack_require__(3);\n\nfunction FDLayoutConstants() {}\n\n//FDLayoutConstants inherits static props in LayoutConstants\nfor (var prop in LayoutConstants) {\n  FDLayoutConstants[prop] = LayoutConstants[prop];\n}\n\nFDLayoutConstants.MAX_ITERATIONS = 2500;\n\nFDLayoutConstants.DEFAULT_EDGE_LENGTH = 50;\nFDLayoutConstants.DEFAULT_SPRING_STRENGTH = 0.45;\nFDLayoutConstants.DEFAULT_REPULSION_STRENGTH = 4500.0;\nFDLayoutConstants.DEFAULT_GRAVITY_STRENGTH = 0.4;\nFDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_STRENGTH = 1.0;\nFDLayoutConstants.DEFAULT_GRAVITY_RANGE_FACTOR = 3.8;\nFDLayoutConstants.DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR = 1.5;\nFDLayoutConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION = true;\nFDLayoutConstants.DEFAULT_USE_SMART_REPULSION_RANGE_CALCULATION = true;\nFDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL = 0.5;\nFDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL = 100.0;\nFDLayoutConstants.MAX_NODE_DISPLACEMENT = FDLayoutConstants.MAX_NODE_DISPLACEMENT_INCREMENTAL * 3;\nFDLayoutConstants.MIN_REPULSION_DIST = FDLayoutConstants.DEFAULT_EDGE_LENGTH / 10.0;\nFDLayoutConstants.CONVERGENCE_CHECK_PERIOD = 100;\nFDLayoutConstants.PER_LEVEL_IDEAL_EDGE_LENGTH_FACTOR = 0.1;\nFDLayoutConstants.MIN_EDGE_LENGTH = 1;\nFDLayoutConstants.GRID_CALCULATION_CHECK_PERIOD = 10;\n\nmodule.exports = FDLayoutConstants;\n\n/***/ }),\n/* 23 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LEdge = __webpack_require__(7);\nvar FDLayoutConstants = __webpack_require__(22);\n\nfunction FDLayoutEdge(source, target, vEdge) {\n  LEdge.call(this, source, target, vEdge);\n  this.idealLength = FDLayoutConstants.DEFAULT_EDGE_LENGTH;\n}\n\nFDLayoutEdge.prototype = Object.create(LEdge.prototype);\n\nfor (var prop in LEdge) {\n  FDLayoutEdge[prop] = LEdge[prop];\n}\n\nmodule.exports = FDLayoutEdge;\n\n/***/ }),\n/* 24 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar LNode = __webpack_require__(13);\n\nfunction FDLayoutNode(gm, loc, size, vNode) {\n  // alternative constructor is handled inside LNode\n  LNode.call(this, gm, loc, size, vNode);\n  //Spring, repulsion and gravitational forces acting on this node\n  this.springForceX = 0;\n  this.springForceY = 0;\n  this.repulsionForceX = 0;\n  this.repulsionForceY = 0;\n  this.gravitationForceX = 0;\n  this.gravitationForceY = 0;\n  //Amount by which this node is to be moved in this iteration\n  this.displacementX = 0;\n  this.displacementY = 0;\n\n  //Start and finish grid coordinates that this node is fallen into\n  this.startX = 0;\n  this.finishX = 0;\n  this.startY = 0;\n  this.finishY = 0;\n\n  //Geometric neighbors of this node\n  this.surrounding = [];\n}\n\nFDLayoutNode.prototype = Object.create(LNode.prototype);\n\nfor (var prop in LNode) {\n  FDLayoutNode[prop] = LNode[prop];\n}\n\nFDLayoutNode.prototype.setGridCoordinates = function (_startX, _finishX, _startY, _finishY) {\n  this.startX = _startX;\n  this.finishX = _finishX;\n  this.startY = _startY;\n  this.finishY = _finishY;\n};\n\nmodule.exports = FDLayoutNode;\n\n/***/ }),\n/* 25 */\n/***/ (function(module, exports) {\n\nfunction DimensionD(width, height) {\n  this.width = 0;\n  this.height = 0;\n  if (width !== null && height !== null) {\n    this.height = height;\n    this.width = width;\n  }\n}\n\nDimensionD.prototype.getWidth = function () {\n  return this.width;\n};\n\nDimensionD.prototype.setWidth = function (width) {\n  this.width = width;\n};\n\nDimensionD.prototype.getHeight = function () {\n  return this.height;\n};\n\nDimensionD.prototype.setHeight = function (height) {\n  this.height = height;\n};\n\nmodule.exports = DimensionD;\n\n/***/ }),\n/* 26 */\n/***/ (function(module, exports, __webpack_require__) {\n\nconst LinkedList = __webpack_require__(19);\n\nfunction Quicksort() {}\n\nQuicksort.get_object_at = function (list, i) {\n    if (list instanceof Array) {\n        return list[i];\n    } else if (list instanceof LinkedList) {\n        return list.get_object_at(i);\n    }\n};\n\nQuicksort.set_object_at = function (list, i, value) {\n    if (list instanceof Array) {\n        list[i] = value;\n    } else if (list instanceof LinkedList) {\n        list.set_object_at(i, value);\n    }\n};\n\nQuicksort.quicksort = function (list, comparison_fn) {\n\n    // input must be an instance of LinkedList class or must be an array in order to sort\n    if (!(list instanceof LinkedList || list instanceof Array)) {\n        return;\n    }\n\n    var comparison_function = comparison_fn;\n\n    if (comparison_function === undefined) {\n        comparison_function = Quicksort.compare;\n    }\n    var end_index;\n\n    if (list instanceof LinkedList) {\n        end_index = list.size();\n    } else if (list instanceof Array) {\n        end_index = list.length - 1;\n    }\n\n    // Prevent empty lists or arrays.\n    if (end_index >= 0) {\n        Quicksort.quicksort_between_indices(list, 0, end_index, comparison_function);\n    }\n};\n\nQuicksort.quicksort_between_indices = function (list, low, high, comparison_fn) {\n\n    // input must be an instance of LinkedList class or must be an array in order to sort\n    if (!(list instanceof LinkedList || list instanceof Array)) {\n        return;\n    }\n\n    if (comparison_fn === undefined) {\n        comparison_fn = Quicksort.compare;\n    }\n\n    var i = low;\n    var j = high;\n    var middleIndex = Math.floor((i + j) / 2);\n    var middle = Quicksort.get_object_at(list, middleIndex);\n\n    do {\n\n        while (comparison_fn(Quicksort.get_object_at(list, i), middle)) {\n\n            i++;\n        }\n\n        while (comparison_fn(middle, Quicksort.get_object_at(list, j))) {\n\n            j--;\n        }\n\n        if (i <= j) {\n\n            var temp = Quicksort.get_object_at(list, i);\n            Quicksort.set_object_at(list, i, Quicksort.get_object_at(list, j));\n            Quicksort.set_object_at(list, j, temp);\n            i++;\n            j--;\n        }\n    } while (i <= j);\n\n    if (low < j) {\n\n        Quicksort.quicksort_between_indices(list, low, j, comparison_fn);\n    }\n\n    if (high > i) {\n\n        Quicksort.quicksort_between_indices(list, i, high, comparison_fn);\n    }\n};\n\n// this function must be overriden for sorting different data types(e.g. string, integer etc.)\nQuicksort.compare = function (a, b) {\n    return b > a;\n};\n\nmodule.exports = Quicksort;\n\n/***/ })\n/******/ ]);\n});","var LayoutConstants = require('layout-base').LayoutConstants;\n\nfunction AVSDFConstants(){}\n\n// AVSDFConstants inherits properties in LayoutConstants\nfor(var prop in LayoutConstants){\n    AVSDFConstants[prop] = LayoutConstants[prop];\n}\n\nAVSDFConstants.DEFAULT_NODE_SEPARATION = 60;\n\nmodule.exports = AVSDFConstants;","/**\n * This class implements data and functionality required for AVSDF layout per\n * edge.\n *\n\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LEdge = require('layout-base').LEdge;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFEdge(source, target, vEdge)\n{\n    LEdge.call(this, source,target, vEdge);\n}\n\nAVSDFEdge.prototype = Object.create(LEdge.prototype);\n\nfor (let properties in LEdge)\n{\n    AVSDFEdge[properties] = LEdge[properties];\n}\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// The function getOtherEnd returns the other end of this edge.\nAVSDFEdge.prototype.getOtherEnd = function(node)\n{\n    return LEdge.prototype.getOtherEnd(node);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function checks whether this edge crosses with the input edge. It\n// returns false, if any of the vertices those edges are incident to are not\n// yet placed on the circle.\nAVSDFEdge.prototype.crossesWithEdge = function(otherEdge)\n{\n    let self = this;\n    let sourcePos = self.getSource().getIndex();\n    let targetPos = self.getTarget().getIndex();\n    let otherSourcePos = otherEdge.getSource().getIndex();\n    let otherTargetPos = otherEdge.getTarget().getIndex();\n    \n    // if any of the vertices those two edges are not yet placed\n    if(sourcePos === -1 || targetPos === -1 || otherSourcePos === -1 || otherTargetPos === -1)\n    {\n        return false;\n    }\n\n    let otherSourceDist = otherEdge.getSource().getCircDistWithTheNode(self.getSource());\n    let otherTargetDist = otherEdge.getTarget().getCircDistWithTheNode(self.getSource());\n    let thisTargetDist = self.getTarget().getCircDistWithTheNode(self.getSource());\n\n    if (thisTargetDist < Math.max(otherSourceDist, otherTargetDist) &&\n            thisTargetDist > Math.min(otherSourceDist, otherTargetDist) &&\n                otherTargetDist !== 0 && otherSourceDist !== 0)\n    {\n        return true;\n    }\n\n    return false;\n};\n\n// This function returns 1 if this edge crosses with the input edge, 0\n// otherwise.\nAVSDFEdge.prototype.crossingWithEdge = function(otherEdge)\n{\n    let self = this;\n    let result = self.crossesWithEdge(otherEdge);\n\n    return  result ? 1 : 0;\n};\n\n// This function calculates the total number of crossings of this edge with\n// all the edges given in the input list.\nAVSDFEdge.prototype.calculateTotalCrossingWithList = function(edgeList)\n{\n    let self = this;\n    let totalCrossing = 0;\n\n    edgeList.forEach(\n        (edge) => totalCrossing += self.crossingWithEdge(edge)\n    );\n\n    return totalCrossing;\n};\n\nmodule.exports = AVSDFEdge;","/**\n * This class implements data and functionality required for AVSDF layout per\n * circle.\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LGraph = require('layout-base').LGraph;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFCircle(parent, graphMgr, vObject)\n{\n    LGraph.call(this, parent, graphMgr, vObject);\n    this.inOrder = undefined;\n    this.currentIndex = 0;\n    this.nodeSeparation = undefined;\n    this.stack = [];\n    this.perimeter = 0;\n    this.centerX = 0;\n    this.centerY = 0;\n    this.radius = 0;\n}\n\nAVSDFCircle.prototype = Object.create(LGraph.prototype);\n\nfor(let property in LGraph)\n{\n    AVSDFCircle[property] = LGraph[property];\n}\n\nAVSDFCircle.prototype.initOrdering = function()\n{\n    this.inOrder = [];\n};\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the array in which the nodes of this circle are kept in order.\nAVSDFCircle.prototype.getOrder = function()\n{\n    return this.inOrder;\n};\n\n// This function returns the x-coordinate of the center of this circle.\nAVSDFCircle.prototype.getCenterX = function()\n{\n    return this.centerX;\n};\n\n// This function returns the y-coordinate of the center of this circle.\nAVSDFCircle.prototype.getCenterY = function()\n{\n    return this.centerY;\n};\n\n// This function returns the radius of this circle.\nAVSDFCircle.prototype.getRadius = function()\n{\n    return this.radius;\n};\n\n// This function returns the total number of vertices of this circle.\nAVSDFCircle.prototype.getSize = function()\n{\n    return this.getNodes().length;\n};\n\n// This function calculates and returns the total number of crossings in this\n// circle by adding up the crossing number of individual nodes on it.\nAVSDFCircle.prototype.getTotalCrossingOfCircle = function()\n{\n    let self = this;\n    let crossingNumber = 0;\n    \n    for(let node in self.inOrder)\n    {\n        let nodeCrossing = node.getTotalCrossingOfEdges();\n        if(nodeCrossing === -1)\n        {\n            return -1;\n        }\n        crossingNumber += nodeCrossing;\n    }\n\n    return crossingNumber / 4;\n};\n\n// This function checks whether or not all of the vertices of this circle are\n// assigned an index on the circle.\nAVSDFCircle.prototype.hasFinishedOrdering = function()\n{\n    return this.currentIndex === this.getNodes().length;\n};\n\n// This function returns the node separation of this circle.\nAVSDFCircle.prototype.getNodeSeparation = function()\n{\n    return this.nodeSeparation;\n};\n\n// This function sets the node separation of this circle.\nAVSDFCircle.prototype.setNodeSeparation = function(nodeSeparation)\n{\n    this.nodeSeparation = nodeSeparation;\n};\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function traverses the vertices of this circle and corrects the angle\n// of the vertices with respect to their circle indices.\nAVSDFCircle.prototype.correctAngles = function()\n{\n    let self = this;\n    self.currentIndex = 0;\n\n    self.inOrder.forEach(\n        (node) =>  self.putInOrder(node)\n    );\n};\n\n\n// This function puts the given node on the circle in the current order and\n// sets its angle appropriately.\nAVSDFCircle.prototype.putInOrder = function(node)\n{\n    let self = this;\n\n    let nodes = self.getNodes();\n\n    // Note that id attribute of a node is added before\n    // AVSDFLayout is called\n    let found = false;\n    for(let i = 0; i < nodes.length; i++) {\n        if (nodes[i].id == node.id) {\n            found = true;\n            break;\n        }\n    }\n\n    if(!found)\n    {\n        throw \"The node must be a member of LGraph\";\n    }\n\n    self.inOrder[self.currentIndex] = node;\n    node.setIndex(self.currentIndex);\n\n    if(self.currentIndex === 0)\n    {\n        node.setAngle(0.0);\n    }\n    else\n    {\n        node.setAngle(self.inOrder[self.currentIndex - 1].getAngle() + 2 * Math.PI *\n            (node.getDiagonal() / 2 + self.nodeSeparation +\n                self.inOrder[self.currentIndex - 1].getDiagonal() / 2)\n            / self.perimeter);\n    }\n\n    self.currentIndex++;\n};\n\n// This function returns the next node to be placed on this circle with\n// respect to the AVSDF algorithm.\nAVSDFCircle.prototype.findNodeToPlace = function()\n{\n    let self = this;\n    let sDegreeNode = undefined;\n\n    // Find the smallest degree vertex if the stack is empty\n    if(self.stack.length === 0)\n    {\n        sDegreeNode = self.findUnorderedSmallestDegreeNode();\n    }\n    // Find the first vertex in the stack not yet placed\n    else\n    {\n        let foundUnorderNode = false;\n\n        while (!foundUnorderNode && !(self.stack.length === 0))\n        {\n            sDegreeNode = self.stack.pop();\n            foundUnorderNode = !sDegreeNode.isOrdered();\n        }\n\n        if (!foundUnorderNode)\n        {\n            sDegreeNode = undefined;\n        }\n    }\n\n    // If no unordered vertex is found in the stack, find one\n    // from the remaining ones\n    if(sDegreeNode === undefined)\n    {\n        sDegreeNode = self.findUnorderedSmallestDegreeNode();\n    }\n\n    // Add the unordered neighbors of this node to the stack\n    if( sDegreeNode !== undefined)\n    {\n        let neighbors = sDegreeNode.getNeighborsSortedByDegree();\n\n        for(let i = neighbors.length - 1; i >= 0 ; i--)\n        {\n            let neighbor = neighbors[i];\n\n            if(!neighbor.isOrdered()) // Check here for possible error\n            {\n                self.stack.push(neighbor);\n            }\n        }\n    }\n\n    return sDegreeNode;\n};\n\n// This function calculates the radius of this circle with respect to the sizes\n// of the vertices and the node separation parameter.\nAVSDFCircle.prototype.calculateRadius = function()\n{\n    let self = this;\n    let totalDiagonal = 0;\n\n    self.getNodes().forEach(\n        (node) => totalDiagonal += Math.sqrt(node.getWidth() * node.getWidth() + node.getHeight() * node.getHeight())\n    );\n\n    self.perimeter = totalDiagonal + self.getNodes().length * self.nodeSeparation;\n    let radius = self.perimeter / ( 2 * Math.PI);\n\n    // Check here for possible error\n\n    self.getParent().setWidth( 2 * radius );\n    self.getParent().setHeight( 2 * radius );\n    self.getParent().setCenter( self.getParent().getWidth(), self.getParent().getHeight() );\n\n    self.centerX = self.getParent().getCenterX();\n    self.centerY = self.getParent().getCenterY();\n    self.radius = self.getParent().getHeight() / 2;\n};\n\n// This function calculates the total number of crossings of all vertices of\n// this circle.\nAVSDFCircle.prototype.calculateEdgeCrossingsOfNodes = function()\n{\n    this.getNodes().forEach( (node) => node.calculateTotalCrossing());\n};\n\n\n// This function sets the index of each vertex to its position in inOrder\n// array. Note that index of a node can be different from its place in the\n// array due to crossing reduction phase of the AVSDF algorithm. It loads\n// old index values to vertices due to an increase in the number of\n// crossings with the new indices.\nAVSDFCircle.prototype.loadOldIndicesOfNodes = function()\n{\n    //this.inOrder.forEach( (node,index) => node.setIndex(index));\n    var self = this;\n    for (let i = 0; i < this.inOrder.length; i++){\n        self.inOrder[i].setIndex(i);\n    }\n};\n\n// This function sets the position of each node in inOrder array to its index.\n// Note that index of a node can be different from its place in the inOrder\n// array due to crossing reduction phase of the AVSDF algorithm. This function\n// puts the nodes to their new index values in inOrder array due to a\n// decrease in the number of crossings with the new indices.\nAVSDFCircle.prototype.reOrderVertices = function()\n{\n    var self = this;\n    this.getNodes().forEach( (node) => self.inOrder[node.getIndex()] = node );\n};\n\n\n// This function finds and returns the unordered smallest degree vertex on\n// this circle.\nAVSDFCircle.prototype.findUnorderedSmallestDegreeNode = function()\n{\n    let minDegree = Number.MAX_SAFE_INTEGER;\n    let sDegreeNode;\n    \n    this.getNodes().forEach(\n        function(node){\n            if(node.getDegree() < minDegree && !node.isOrdered())\n            {\n                minDegree = node.getDegree();\n                sDegreeNode = node;\n            }\n        }\n    );\n\n    return sDegreeNode;\n};\n\n\nmodule.exports = AVSDFCircle;","/**\n * This class implements the overall layout process for the AVSDF algorithm\n * (Circular Drawing Algorithm by He and Sykora).\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet Layout = require('layout-base').Layout;\nlet AVSDFConstants = require('./AVSDFConstants.js');\nlet AVSDFCircle = require('./AVSDFCircle.js');\nlet AVSDFNode = require('./AVSDFNode.js');\nlet AVSDFEdge = require('./AVSDFEdge.js');\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\n// Constructor\nfunction AVSDFLayout()\n{\n    Layout.call(this);\n    this.nodeSeparation = AVSDFConstants.DEFAULT_NODE_SEPARATION;\n}\n\nAVSDFLayout.prototype = Object.create(Layout.prototype);\n\nfor (let property in Layout)\n{\n    AVSDFLayout[property] = Layout[property];\n}\n\nAVSDFLayout.prototype.newGraph = function (vObject)\n{\n    this.avsdfCircle = new AVSDFCircle(null, this.graphManager, vObject);\n\n    return this.avsdfCircle;\n};\n\nAVSDFLayout.prototype.newNode = function (vNode)\n{\n    return new AVSDFNode(this.graphManager, vNode);\n};\n\nAVSDFLayout.prototype.newEdge = function (vEdge)\n{\n    return new AVSDFEdge(null, null, vEdge);\n};\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the position data for all nodes\nAVSDFLayout.prototype.getPositionsData = function()\n{\n    var allNodes = this.graphManager.getAllNodes();\n    var pData = {};\n\n    for (var i = 0; i < allNodes.length; i++)\n    {\n        var rect = allNodes[i].rect;\n        var id = allNodes[i].id;\n\n        pData[id] = {\n            id: id,\n            x: rect.getCenterX(),\n            y: rect.getCenterY(),\n            w: rect.width,\n            h: rect.height\n        };\n    }\n\n    return pData;\n};\n\n// -----------------------------------------------------------------------------\n// Section: Layout Related\n// -----------------------------------------------------------------------------\n\n/**\n * This function performs layout on constructed l-level graph.\n * It returns true on success, false otherwise.\n * Important!: If you want to see the results of this function then, after this function is called, you have to calculate\n * and set the positions of every node. To do this call updateNodeCoordinates. However, updateNodeAngles on the other\n * hand is not needed (redundant) for this function.\n */\nAVSDFLayout.prototype.layout = function ()\n{\n    let self = this;\n\n    // Check if graph contains any compound structures\n    if (self.graphManager.getGraphs().length > 1)\n    {\n        return false;\n    }\n\n    let clusterGraph = this.avsdfCircle; // Fixed reference, but now it is a bit redundant\n\n    clusterGraph.setNodeSeparation(this.nodeSeparation);\n    clusterGraph.calculateRadius();\n    clusterGraph.initOrdering();\n\n    while (!clusterGraph.hasFinishedOrdering())\n    {\n        let node = clusterGraph.findNodeToPlace();\n        clusterGraph.putInOrder(node);\n    }\n\n    return true;\n};\n\n// This function updates the angle (in radians) property of AVSDFNode elements in the circle\nAVSDFLayout.prototype.updateNodeAngles = function (){\n    this.graphManager.getRoot().correctAngles(); //AVSDFCircle object\n};\n\n// This function traverses the vertices of the graph and sets their correct coordinates with respect to the owner circle.\nAVSDFLayout.prototype.updateNodeCoordinates = function (){\n    let clusterGraph = this.graphManager.getRoot();\n\n    clusterGraph.getNodes().forEach(function(node) {\n        node.setCenter(clusterGraph.getCenterX() + clusterGraph.getRadius() * Math.cos(node.getAngle()), clusterGraph.getCenterY() +\n            clusterGraph.getRadius() * Math.sin(node.getAngle()));\n    });\n};\n\n// -----------------------------------------------------------------------------\n// Section: Post Processing\n// -----------------------------------------------------------------------------\n\n/**\n * This method implements the post processing step of the algorithm, which\n * tries to minimize the number of edges further with respect to the local\n * adjusting algorithm described by He and Sykora.\n */\nAVSDFLayout.prototype.initPostProcess = function ()\n{\n    this.avsdfCircle.calculateEdgeCrossingsOfNodes();\n\n    let list = this.avsdfCircle.getNodes();\n\n    list.sort(function(a,b){\n        return b.getTotalCrossingOfEdges() - a.getTotalCrossingOfEdges();\n    });\n\n    return list;\n};\n\nAVSDFLayout.prototype.oneStepPostProcess = function (node)\n{\n    let self = this;\n\n    let currentCrossingNumber = node.getTotalCrossingOfEdges();\n    let newCrossingNumber;\n\n    let neighbours = [];\n    node.getNeighborsList().addAllTo(neighbours);\n\n    for (let j = 0; j < neighbours.length; j++)\n    {\n        let neighbour = neighbours[j];\n\n        let oldIndex = node.getIndex();\n        let newIndex = (neighbour.getIndex() + 1) % self.avsdfCircle.getSize();\n\n        if (oldIndex !== newIndex)\n        {\n            node.setIndex(newIndex);\n\n            if (oldIndex < node.getIndex())\n            {\n                oldIndex += self.avsdfCircle.getSize();\n            }\n\n            let index = node.getIndex();\n\n            while (index < oldIndex)\n            {\n                let temp = self.avsdfCircle.getOrder()[index % self.avsdfCircle.getSize()];\n                temp.setIndex((temp.getIndex() + 1) % self.avsdfCircle.getSize());\n                index += 1;\n            }\n\n            node.calculateTotalCrossing();\n            newCrossingNumber = node.getTotalCrossingOfEdges();\n\n            if (newCrossingNumber >= currentCrossingNumber)\n            {\n                self.avsdfCircle.loadOldIndicesOfNodes();\n            }\n            else\n            {\n                self.avsdfCircle.reOrderVertices();\n                currentCrossingNumber = newCrossingNumber;\n            }\n        }\n    }\n};\n\nmodule.exports = AVSDFLayout;","/**\n * This class implements data and functionality required for AVSDF layout per\n * node.\n *\n *\n * Copyright: i-Vis Research Group, Bilkent University, 2007 - present\n */\n\nlet LNode = require('layout-base').LNode;\nlet Quicksort = require('layout-base').Quicksort;\n\n// -----------------------------------------------------------------------------\n// Section: Initializations\n// -----------------------------------------------------------------------------\n\nfunction AVSDFNode(gm, vNode, loc, size)\n{\n    // Constructor 1: AVSDFNode(gm, vNode, loc, size)\n    if(loc !== undefined && size !== undefined)\n    {\n        LNode.call(this, gm, vNode, loc, size);\n    }\n    // Constructor 2: AVSDFNode(gm, vNode)\n    else\n    {\n        LNode.call(this, gm, vNode);\n    }\n\n\t// Angle of this node on the owner circle in radians\n    this.angle = 0;\n\n    // Index of this node on the owner circle\n    this.circleIndex = -1;\n\n    // Total number of crossings of the edges this node is incident to\n    this.totalCrossingOfEdges = -1;\n\n    // Whether the current edge crossing number is valid or it needs to be\n    // recalculated\n    this.isCrossingNumberValid = false;\n\n}\n\nAVSDFNode.prototype = Object.create(LNode.prototype);\nfor (let properties in LNode)\n{\n    AVSDFNode[properties] = LNode[properties];\n}\n\n// -----------------------------------------------------------------------------\n// Section: Accessor Functions\n// -----------------------------------------------------------------------------\n\n// This function returns the circle this node is owned by.\nAVSDFNode.prototype.getCircle = function()\n{\n    return this.getOwner();\n};\n\n// This function sets the index of this node on the circle, and sets the\n// crossing number invalid. Due to the index change of the node; it needs to\n// be recalculated.\nAVSDFNode.prototype.setIndex = function(index)\n{\n    this.circleIndex = index;\n    this.isCrossingNumberValid = false;\n};\n\n// This function returns the index of this node in the ordering of its owner\n// circle. Here -1 means that the vertex is not yet placed on its owner\n//circle.\nAVSDFNode.prototype.getIndex = function()\n{\n    return this.circleIndex;\n};\n\n// This function returns the array of the neigbors of this node sorted in\n// ascending order.\nAVSDFNode.prototype.getNeighborsSortedByDegree = function()\n{\n    let  self = this;\n\n    let neighborsList = [];\n    self.getNeighborsList().addAllTo(neighborsList);\n    let result = neighborsList.filter( node => ( node.getIndex() === -1 ) );\n\n    result.sort(function(a,b){\n        return a.getDegree() - b.getDegree();\n    });\n\n    return result;\n};\n\n// This function returns the degree of this node.\nAVSDFNode.prototype.getDegree = function()\n{\n    return this.getEdges().length;\n};\n\n// This function returns whether or not this node is currently placed on its\n// owner circle.\nAVSDFNode.prototype.isOrdered =  function()\n{\n    return (this.getIndex() > -1);\n};\n\n// This function sets the angle of this node w.r.t. its owner circle. Here\n// the angle value is in radian.\nAVSDFNode.prototype.setAngle = function(angle)\n{\n    this.angle = angle;\n};\n\n// This function returns the angle of this node w.r.t. its owner circle. Here\n// the angle value is in radian.\nAVSDFNode.prototype.getAngle = function()\n{\n    return this.angle;\n};\n\n// This function returns the index difference of this node with the input\n// node. Note that the index difference cannot be negative if both nodes are\n// placed on the circle. Here -1 means at least one of the nodes are not yet\n// placed on the circle.\nAVSDFNode.prototype.getCircDistWithTheNode =  function(refNode)\n{\n    let self = this;\n    let otherIndex = refNode.getIndex();\n    \n    if(otherIndex === -1 || self.getIndex() === -1)\n    {\n        return -1;\n    }\n\n    let diff = self.getIndex() - otherIndex;\n\n    if(diff < 0)\n    {\n        diff += self.getCircle().getSize();\n    }\n\n    return diff;\n};\n\n// This function finds the number of edge crossings between the edges of\n// this node and the edges of the input one.\nAVSDFNode.prototype.getCrossingNumberWithNode =  function(otherNode)\n{\n    let self = this;\n    let totalCrossing = 0;\n\n    self.getEdges().forEach(\n        function(edge)\n        {\n            otherNode.getEdges().forEach(\n                function(otherEdge)\n                {\n                    totalCrossing += edge.crossingWithEdge(otherEdge);\n                }\n            );\n        }\n    );\n\n    return totalCrossing;\n};\n\n// This function returns the total number of edge crossings. If the previously\n// calculated value is not valid due to an index change on the circle, then\n// a recalculation is performed.\nAVSDFNode.prototype.getTotalCrossingOfEdges = function()\n{\n    let self = this;\n    \n    if(!self.isCrossingNumberValid)\n    {\n        self.calculateTotalCrossing();\n        self.isCrossingNumberValid = true;\n\n    }\n\n    return self.totalCrossingOfEdges;\n};\n\n\n// -----------------------------------------------------------------------------\n// Section: Remaining Functions\n// -----------------------------------------------------------------------------\n\n// This function calculates the total number of crossings the edges of this\n// node cause.\nAVSDFNode.prototype.calculateTotalCrossing = function()\n{\n    let self = this;\n    let temp_crossing_count = 0;\n    let temp_edge_list = [];\n    temp_edge_list.push.apply(temp_edge_list, self.getCircle().getEdges());\n    temp_edge_list = temp_edge_list.filter( (ele) => self.getEdges().indexOf(ele) < 0);\n\n    self.getEdges().forEach(\n        (edge) => temp_crossing_count += edge.calculateTotalCrossingWithList(temp_edge_list)\n    );\n\n    self.totalCrossingOfEdges = temp_crossing_count;\n};\n\nmodule.exports = AVSDFNode;"],"sourceRoot":""}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/avsdf-base/avsdf-base.js\n// module id = 0\n// module chunks = 0","// Simple, internal Object.assign() polyfill for options objects etc.\n\nmodule.exports = Object.assign != null ? Object.assign.bind( Object ) : function( tgt, ...srcs ){\n  srcs.forEach( src => {\n    Object.keys( src ).forEach( k => tgt[k] = src[k] );\n  } );\n\n  return tgt;\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/assign.js","/**\n *\n * Choose the type of layout that best suits your usecase as a starting point.\n *\n * A discrete layout is one that algorithmically sets resultant positions.  It\n * does not have intermediate positions.\n *\n * A continuous layout is one that updates positions continuously, like a force-\n * directed / physics simulation layout.\n */\n\nmodule.exports = require('./AVSDF');\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/index.js","const impl = require('./layout');\n\n// registers the extension on a cytoscape lib ref\nlet register = function( cytoscape ){\n  if( !cytoscape ){ return; } // can't register if cytoscape unspecified\n\n  cytoscape( 'layout', 'avsdf', impl ); // register with cytoscape.js\n};\n\nif( typeof cytoscape !== 'undefined' ){ // expose to global cytoscape (i.e. window.cytoscape)\n  register( cytoscape );\n}\n\nmodule.exports = register;\n\n\n\n// WEBPACK FOOTER //\n// ./src/index.js","/**\n * This class implements the overall layout process for the\n * Adjacent Vertex with Smallest Degree First (AVSDF) algorithm.\n * (Circular Drawing Algorithm by Hongmei He & Ondrej Sýkora).\n *\n * @author Doruk Çakmakçı\n * @author Alihan Okka\n *\n * Copyright: i-Vis (Information Visualization) Research Lab, Bilkent University, 2019 - present\n*/\n\n// cytosscape.js-avsdf REQUIRES avsdf-base library elements\nconst AVSDFLayout = require('avsdf-base').AVSDFLayout;\nconst AVSDFNode = require('avsdf-base').AVSDFNode;\nconst AVSDFConstants = require('avsdf-base').AVSDFConstants;\nconst PointD = require('avsdf-base').layoutBase.PointD;\nconst DimensionD = require('avsdf-base').layoutBase.DimensionD;\n\n// Cytoscape-extention template requirements\n// More details can be found in NPM 'slush-cytoscape-extension' package\nconst assign = require('../assign');\nconst ContinuousLayout = require('./continuous-base');\n\nconst isFn = fn => typeof fn === 'function';\nconst optFn = ( opt, ele ) => {\n  if( isFn( opt ) ){\n    return opt( ele );\n  } else {\n    return opt;\n  }\n};\n\nlet defaults = {\n  ready: function () {}, // Called on `layoutready`\n  stop: function () {}, // Called on `layoutstop`\n  refresh: 30,  // number of ticks per frame; higher is faster but more jerky\n  fit: true,   // Whether to fit the network view after when done\n  padding: 10,   // Padding on fit\n  randomize: false,   // Whether to enable incremental mode\n  animate: 'end',   // Type of layout animation. The option set is {'during', 'end', false}\n  animationDuration: 500,   // Duration for animate:end\n  nodeSeparation: 60, // How apart the nodes are\n};\n\n/**\n *  This is the main class that does all the functionality.\n *  The class is utilized by functions in the continuous-base folder.\n */\nclass AVSDF extends ContinuousLayout {\n  constructor( options ){\n    super( assign( {}, defaults, options ) );\n\n    // Whether node separation value is used\n    if(options.nodeSeparation != null)\n      AVSDFConstants.DEFAULT_NODE_SEPARATION = options.nodeSeparation;\n    else\n      AVSDFConstants.DEFAULT_NODE_SEPARATION = defaults.nodeSeparation;\n  }\n\n  /**\n   *  Initializing AVSDF elements and arranging the nodes of the graph around the circle\n   */\n  prerun(){\n    let state = this.state; // options object combined with current state\n\n    // Initialize AVSDF elements and their requirements\n    let avsdfLayout = this.avsdfLayout = new AVSDFLayout();\n    let graphManager = this.graphManager = avsdfLayout.newGraphManager();\n    let root = this.root = graphManager.addRoot();\n    let nodes = state.nodes;\n    let edges = state.edges;\n\n    // Getting nodes of cytoscape and converting it to AVSDF structure\n    this.idToLNode = {};\n    this.processChildrenList(root, nodes, avsdfLayout);\n\n    // Getting edges of cytoscape and transfering it to GraphManager\n    for (let i = 0; i < edges.length; i++)\n    {\n      let edge = edges[i];\n      let sourceNode = this.idToLNode[edge.data(\"source\")];\n      let targetNode = this.idToLNode[edge.data(\"target\")];\n      if(sourceNode !== targetNode && sourceNode.getEdgesBetween(targetNode).length === 0)\n      {\n        let e1 = graphManager.add(avsdfLayout.newEdge(), sourceNode, targetNode);\n        e1.id = edge.id();\n      }\n    }\n\n    // Running the AVSDF layout.\n    // Note: This function doesn't do post-processing. Plus, nodes have to be positioned.\n    // See AVSDFLayout for details.\n    avsdfLayout.layout();\n\n    // We need to calculate the initial circle position if we want to render it\n    avsdfLayout.updateNodeCoordinates();\n\n    // Post process is iterated over the sorted list of vertex degrees (descending)\n    this.sortedByDegreeList = avsdfLayout.initPostProcess();\n  }\n\n\n  /**\n   *  Runs this in each iteration\n   */\n  tick(){\n    let state = this.state;\n\n    // This function is used for getting coordinates from AVSDF elements and passing it to cytoscape\n    let positions = this.avsdfLayout.getPositionsData();\n    let getPositions = function(ele, i){\n      if(typeof ele === \"number\") {\n        ele = i;\n      }\n\n      let lNode = positions[ele.data('id')];\n\n      return {\n        x: lNode.x,\n        y: lNode.y\n      };\n    };\n    this.options.eles.nodes().layoutPositions(this, this.options, getPositions);\n\n    if(state.tickIndex >= state.nodes.size())\n      return true;\n\n      this.avsdfLayout.oneStepPostProcess(this.sortedByDegreeList[state.tickIndex]);\n      this.avsdfLayout.updateNodeAngles();\n      this.avsdfLayout.updateNodeCoordinates();\n\n  }\n\n  /**\n   *  Runs this function after the layout is done ticking\n   */\n  postrun(){\n  }\n\n  /**\n   *  Clean up any object refs that could prevent garbage collection, etc.\n   */\n  destroy(){\n    super.destroy();\n    return this;\n  }\n\n  /**\n   *  Transition from cytoscape nodes to AVSDF elements\n   */\n  processChildrenList(parent, children, layout) {\n    let size = children.length;\n    for (let i = 0; i < size; i++)\n    {\n      let theChild = children[i];\n      let theNode;\n\n      //Label dimensions are NOT included when calculating node dimensions\n      let dimensions = theChild.layoutDimensions({\n        nodeDimensionsIncludeLabels: false\n      });\n\n      if (theChild.outerWidth() != null && theChild.outerHeight() != null)\n      {\n        theNode = parent.add(new AVSDFNode(layout.graphManager,\n            null,\n            new PointD(theChild.position('x') - dimensions.w / 2,\n                theChild.position('y') - dimensions.h / 2),\n            new DimensionD(parseFloat(dimensions.w),\n                parseFloat(dimensions.h))));\n      }\n      else\n      {\n        theNode = parent.add(new AVSDFNode(this.graphManager));\n      }\n\n      // Attach id to the layout node\n      theNode.id = theChild.data(\"id\");\n\n      // Attach the paddings of cy node to layout node\n      theNode.paddingLeft = parseInt( theChild.css('padding') );\n      theNode.paddingTop = parseInt( theChild.css('padding') );\n      theNode.paddingRight = parseInt( theChild.css('padding') );\n      theNode.paddingBottom = parseInt( theChild.css('padding') );\n\n      // Map the layout node\n      this.idToLNode[theChild.data(\"id\")] = theNode;\n\n      if (isNaN(theNode.rect.x))\n      {\n        theNode.rect.x = 0;\n      }\n\n      if (isNaN(theNode.rect.y))\n      {\n        theNode.rect.y = 0;\n      }\n\n    }\n  }\n}\n\nmodule.exports = AVSDF;\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/AVSDF.js","// general default options for force-directed layout\n\nmodule.exports = Object.freeze({\n  animate: true, // whether to show the layout as it's running; special 'end' value makes the layout animate like a discrete layout\n  refresh: 10, // number of ticks per frame; higher is faster but more jerky\n  ungrabifyWhileSimulating: false, // so you can't drag nodes during layout\n  fit: true, // on every layout reposition of nodes, fit the viewport\n  padding: 30, // padding around the simulation\n  boundingBox: undefined, // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h }\n\n  // layout event callbacks\n  ready: function(){}, // on layoutready\n  stop: function(){}, // on layoutstop\n\n  // positioning options\n  randomize: false, // use random node positions at beginning of layout\n  \n  // infinite layout options\n  infinite: false // overrides all other options for a forces-all-the-time mode\n});\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/continuous-base/defaults.js","/**\nA generic continuous layout class\n*/\n\nconst assign = require('../../assign');\nconst defaults = require('./defaults');\nconst makeBoundingBox = require('./make-bb');\nconst { setInitialPositionState, refreshPositions, getNodePositionData } = require('./position');\nconst { multitick } = require('./tick');\n\nclass ContinuousLayout {\n  constructor( options ){\n    let o = this.options = assign( {}, defaults, options );\n\n    let s = this.state = assign( {}, o, {\n      layout: this,\n      nodes: o.eles.nodes(),\n      edges: o.eles.edges(),\n      tickIndex: 0,\n      firstUpdate: true\n    } );\n\n    s.animateEnd = o.animate && o.animate === 'end';\n    s.animateContinuously = o.animate && !s.animateEnd;\n  }\n\n  getScratch( el ){\n    let name = this.state.name;\n    let scratch = el.scratch( name );\n\n    if( !scratch ){\n      scratch = {};\n\n      el.scratch(name, scratch);\n    }\n\n    return scratch;\n  }\n\n  run(){\n    let l = this;\n    let s = this.state;\n\n    s.tickIndex = 0;\n    s.firstUpdate = true;\n\n    s.running = true;\n\n    s.currentBoundingBox = makeBoundingBox( s.boundingBox, s.cy );\n\n    if( s.ready ){ l.one( 'ready', s.ready ); }\n    if( s.stop ){ l.one( 'stop', s.stop ); }\n\n    s.nodes.forEach( n => setInitialPositionState( n, s ) );\n\n    l.prerun( s );\n\n    if( s.animateContinuously ){\n      let ungrabify = node => {\n        if( !s.ungrabifyWhileSimulating ){ return; }\n\n        let grabbable = getNodePositionData( node, s ).grabbable = node.grabbable();\n\n        if( grabbable ){\n          node.ungrabify();\n        }\n      };\n\n      let regrabify = node => {\n        if( !s.ungrabifyWhileSimulating ){ return; }\n\n        let grabbable = getNodePositionData( node, s ).grabbable;\n\n        if( grabbable ){\n          node.grabify();\n        }\n      };\n\n      let updateGrabState = node => getNodePositionData( node, s ).grabbed = node.grabbed();\n\n      let onGrab = function({ target }){\n        updateGrabState( target );\n      };\n\n      let onFree = onGrab;\n\n      let onDrag = function({ target }){\n        let p = getNodePositionData( target, s );\n        let tp = target.position();\n\n        p.x = tp.x;\n        p.y = tp.y;\n      };\n\n      let listenToGrab = node => {\n        node.on('grab', onGrab);\n        node.on('free', onFree);\n        node.on('drag', onDrag);\n      };\n\n      let unlistenToGrab = node => {\n        node.removeListener('grab', onGrab);\n        node.removeListener('free', onFree);\n        node.removeListener('drag', onDrag);\n      };\n\n      let fit = () => {\n        if( s.fit && s.animateContinuously ){\n          s.cy.fit( s.padding );\n        }\n      };\n\n      let onNotDone = () => {\n        refreshPositions( s.nodes, s );\n        fit();\n\n        requestAnimationFrame( frame );\n      };\n\n      let frame = function(){\n        multitick( s, onNotDone, onDone );\n      };\n\n      let onDone = () => {\n        refreshPositions( s.nodes, s );\n        fit();\n\n        s.nodes.forEach( n => {\n          regrabify( n );\n          unlistenToGrab( n );\n        } );\n\n        s.running = false;\n\n        l.emit('layoutstop');\n      };\n\n      s.startTime = Date.now();\n\n      l.emit('layoutstart');\n\n      s.nodes.forEach( n => {\n        ungrabify( n );\n        listenToGrab( n );\n      } );\n\n      frame(); // kick off\n    } else {\n      multitick( s );\n\n      s.eles.layoutPositions( this, s, node => getNodePositionData( node, s ) );\n    }\n\n    l.postrun( s );\n\n    return this; // chaining\n  }\n\n  prerun(){}\n  postrun(){}\n  tick(){}\n\n  stop(){\n    this.state.running = false;\n\n    return this; // chaining\n  }\n\n  destroy(){\n    return this; // chaining\n  }\n}\n\nmodule.exports = ContinuousLayout;\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/continuous-base/index.js","module.exports = function( bb, cy ){\n  if( bb == null ){\n    bb = { x1: 0, y1: 0, w: cy.width(), h: cy.height() };\n  } else { // copy\n    bb = { x1: bb.x1, x2: bb.x2, y1: bb.y1, y2: bb.y2, w: bb.w, h: bb.h };\n  }\n\n  if( bb.x2 == null ){ bb.x2 = bb.x1 + bb.w; }\n  if( bb.w == null ){ bb.w = bb.x2 - bb.x1; }\n  if( bb.y2 == null ){ bb.y2 = bb.y1 + bb.h; }\n  if( bb.h == null ){ bb.h = bb.y2 - bb.y1; }\n\n  return bb;\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/continuous-base/make-bb.js","const assign = require('../../assign');\n\nlet setInitialPositionState = function( node, state ){\n  let p = node.position();\n  let bb = state.currentBoundingBox;\n  let scratch = node.scratch( state.name );\n\n  if( scratch == null ){\n    scratch = {};\n\n    node.scratch( state.name, scratch );\n  }\n\n  assign( scratch, state.randomize ? {\n    x: bb.x1 + Math.round( Math.random() * bb.w ),\n    y: bb.y1 + Math.round( Math.random() * bb.h )\n  } : {\n    x: p.x,\n    y: p.y\n  } );\n\n  scratch.locked = node.locked();\n};\n\nlet getNodePositionData = function( node, state ){\n  return node.scratch( state.name );\n};\n\nlet refreshPositions = function( nodes, state ){\n  nodes.positions(function( node ){\n    let scratch = node.scratch( state.name );\n\n    return {\n      x: scratch.x,\n      y: scratch.y\n    };\n  });\n};\n\nmodule.exports = { setInitialPositionState, getNodePositionData, refreshPositions };\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/continuous-base/position.js","const nop = function(){};\n\nlet tick = function( state ){\n  let s = state;\n  let l = state.layout;\n\n  let tickIndicatesDone = l.tick( s );\n\n  if( s.firstUpdate ){\n    if( s.animateContinuously ){ // indicate the initial positions have been set\n      s.layout.emit('layoutready');\n    }\n    s.firstUpdate = false;\n  }\n\n  s.tickIndex++;\n\n  let duration = s.startTime - Date.now();\n\n  return !s.infinite && ( tickIndicatesDone );\n};\n\nlet multitick = function( state, onNotDone = nop, onDone = nop ){\n  let done = false;\n  let s = state;\n\n  for( let i = 0; i < s.refresh; i++ ){\n    done = !s.running || tick( s );\n\n    if( done ){ break; }\n  }\n\n  if( !done ){\n    onNotDone();\n  } else {\n    onDone();\n  }\n};\n\nmodule.exports = { tick, multitick };\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/continuous-base/tick.js"],"sourceRoot":""} \ No newline at end of file +}); \ No newline at end of file diff --git a/demo.html b/demo.html index 542a7f70..8c043c3f 100644 --- a/demo.html +++ b/demo.html @@ -11,12 +11,20 @@ + + + + + + + +

cytoscape-avsdf demo

- +
+ Animation Type: + End + During
+
+ + + + +
diff --git a/src/layout/AVSDF.js b/src/layout/AVSDF.js index 63edb14b..c3e5aa28 100644 --- a/src/layout/AVSDF.js +++ b/src/layout/AVSDF.js @@ -99,28 +99,22 @@ class AVSDF extends ContinuousLayout { this.sortedByDegreeList = avsdfLayout.initPostProcess(); } - /** * Runs this in each iteration */ tick(){ let state = this.state; + let self = this; // This function is used for getting coordinates from AVSDF elements and passing it to cytoscape let positions = this.avsdfLayout.getPositionsData(); - let getPositions = function(ele, i){ - if(typeof ele === "number") { - ele = i; - } - - let lNode = positions[ele.data('id')]; + state.nodes.forEach( n => { + let s = this.getScratch(n); - return { - x: lNode.x, - y: lNode.y - }; - }; - this.options.eles.nodes().layoutPositions(this, this.options, getPositions); + // example : put node at random position + s.x = positions[n.data('id')].x; + s.y = positions[n.data('id')].y; + } ); if(state.tickIndex >= state.nodes.size()) return true; @@ -128,7 +122,6 @@ class AVSDF extends ContinuousLayout { this.avsdfLayout.oneStepPostProcess(this.sortedByDegreeList[state.tickIndex]); this.avsdfLayout.updateNodeAngles(); this.avsdfLayout.updateNodeCoordinates(); - } /** @@ -195,7 +188,6 @@ class AVSDF extends ContinuousLayout { { theNode.rect.y = 0; } - } } } diff --git a/src/layout/continuous-base/defaults.js b/src/layout/continuous-base/defaults.js index 093933ab..f2d85bc2 100644 --- a/src/layout/continuous-base/defaults.js +++ b/src/layout/continuous-base/defaults.js @@ -3,6 +3,7 @@ module.exports = Object.freeze({ animate: true, // whether to show the layout as it's running; special 'end' value makes the layout animate like a discrete layout refresh: 10, // number of ticks per frame; higher is faster but more jerky + maxIterations: 1000, // max iterations before the layout will bail out ungrabifyWhileSimulating: false, // so you can't drag nodes during layout fit: true, // on every layout reposition of nodes, fit the viewport padding: 30, // padding around the simulation @@ -14,7 +15,7 @@ module.exports = Object.freeze({ // positioning options randomize: false, // use random node positions at beginning of layout - + // infinite layout options infinite: false // overrides all other options for a forces-all-the-time mode -}); +}); \ No newline at end of file diff --git a/src/layout/continuous-base/index.js b/src/layout/continuous-base/index.js index ebbc97fb..804cc577 100644 --- a/src/layout/continuous-base/index.js +++ b/src/layout/continuous-base/index.js @@ -1,6 +1,6 @@ /** -A generic continuous layout class -*/ + A generic continuous layout class + */ const assign = require('../../assign'); const defaults = require('./defaults'); @@ -8,7 +8,7 @@ const makeBoundingBox = require('./make-bb'); const { setInitialPositionState, refreshPositions, getNodePositionData } = require('./position'); const { multitick } = require('./tick'); -class ContinuousLayout { +class Layout { constructor( options ){ let o = this.options = assign( {}, defaults, options ); @@ -43,7 +43,7 @@ class ContinuousLayout { s.tickIndex = 0; s.firstUpdate = true; - + s.startTime = Date.now(); s.running = true; s.currentBoundingBox = makeBoundingBox( s.boundingBox, s.cy ); @@ -135,8 +135,6 @@ class ContinuousLayout { l.emit('layoutstop'); }; - s.startTime = Date.now(); - l.emit('layoutstart'); s.nodes.forEach( n => { @@ -146,9 +144,19 @@ class ContinuousLayout { frame(); // kick off } else { - multitick( s ); + let done = false; + let onNotDone = () => {}; + let onDone = () => done = true; + + while( !done ){ + multitick( s, onNotDone, onDone ); + } + + s.eles.layoutPositions( this, s, node => { + let pd = getNodePositionData( node, s ); - s.eles.layoutPositions( this, s, node => getNodePositionData( node, s ) ); + return { x: pd.x, y: pd.y }; + } ); } l.postrun( s ); @@ -171,4 +179,4 @@ class ContinuousLayout { } } -module.exports = ContinuousLayout; +module.exports = Layout; \ No newline at end of file diff --git a/src/layout/continuous-base/make-bb.js b/src/layout/continuous-base/make-bb.js index 2d90d5fc..22b33032 100644 --- a/src/layout/continuous-base/make-bb.js +++ b/src/layout/continuous-base/make-bb.js @@ -11,4 +11,4 @@ module.exports = function( bb, cy ){ if( bb.h == null ){ bb.h = bb.y2 - bb.y1; } return bb; -}; +}; \ No newline at end of file diff --git a/src/layout/continuous-base/tick.js b/src/layout/continuous-base/tick.js index a1763371..23439b12 100644 --- a/src/layout/continuous-base/tick.js +++ b/src/layout/continuous-base/tick.js @@ -1,3 +1,4 @@ + const nop = function(){}; let tick = function( state ){ @@ -15,7 +16,7 @@ let tick = function( state ){ s.tickIndex++; - let duration = s.startTime - Date.now(); + let duration = Date.now() - s.startTime; return !s.infinite && ( tickIndicatesDone ); };