You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
25 lines
183 KiB
JavaScript
25 lines
183 KiB
JavaScript
"use strict";
|
|
/*
|
|
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
* This devtool is neither made for production nor for readable output files.
|
|
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
* or disable the default devtool with "devtool: false".
|
|
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
*/
|
|
exports.id = "vendor-chunks/cose-base";
|
|
exports.ids = ["vendor-chunks/cose-base"];
|
|
exports.modules = {
|
|
|
|
/***/ "(ssr)/./node_modules/cose-base/cose-base.js":
|
|
/*!*********************************************!*\
|
|
!*** ./node_modules/cose-base/cose-base.js ***!
|
|
\*********************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n(function webpackUniversalModuleDefinition(root, factory) {\n if (true) module.exports = factory(__webpack_require__(/*! layout-base */ \"(ssr)/./node_modules/layout-base/layout-base.js\"));\n else {}\n})(void 0, function(__WEBPACK_EXTERNAL_MODULE_0__) {\n return /******/ function(modules) {\n /******/ // The module cache\n /******/ var installedModules = {};\n /******/ /******/ // The require function\n /******/ function __nested_webpack_require_691__(moduleId) {\n /******/ /******/ // Check if module is in cache\n /******/ if (installedModules[moduleId]) {\n /******/ return installedModules[moduleId].exports;\n /******/ }\n /******/ // Create a new module (and put it into the cache)\n /******/ var module1 = installedModules[moduleId] = {\n /******/ i: moduleId,\n /******/ l: false,\n /******/ exports: {}\n };\n /******/ /******/ // Execute the module function\n /******/ modules[moduleId].call(module1.exports, module1, module1.exports, __nested_webpack_require_691__);\n /******/ /******/ // Flag the module as loaded\n /******/ module1.l = true;\n /******/ /******/ // Return the exports of the module\n /******/ return module1.exports;\n /******/ }\n /******/ /******/ /******/ // expose the modules object (__webpack_modules__)\n /******/ __nested_webpack_require_691__.m = modules;\n /******/ /******/ // expose the module cache\n /******/ __nested_webpack_require_691__.c = installedModules;\n /******/ /******/ // identity function for calling harmony imports with the correct context\n /******/ __nested_webpack_require_691__.i = function(value) {\n return value;\n };\n /******/ /******/ // define getter function for harmony exports\n /******/ __nested_webpack_require_691__.d = function(exports1, name, getter) {\n /******/ if (!__nested_webpack_require_691__.o(exports1, name)) {\n /******/ Object.defineProperty(exports1, name, {\n /******/ configurable: false,\n /******/ enumerable: true,\n /******/ get: getter\n });\n /******/ }\n /******/ };\n /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules\n /******/ __nested_webpack_require_691__.n = function(module1) {\n /******/ var getter = module1 && module1.__esModule ? /******/ function getDefault() {\n return module1[\"default\"];\n } : /******/ function getModuleExports() {\n return module1;\n };\n /******/ __nested_webpack_require_691__.d(getter, \"a\", getter);\n /******/ return getter;\n /******/ };\n /******/ /******/ // Object.prototype.hasOwnProperty.call\n /******/ __nested_webpack_require_691__.o = function(object, property) {\n return Object.prototype.hasOwnProperty.call(object, property);\n };\n /******/ /******/ // __webpack_public_path__\n /******/ __nested_webpack_require_691__.p = \"\";\n /******/ /******/ // Load entry module and return exports\n /******/ return __nested_webpack_require_691__(__nested_webpack_require_691__.s = 7);\n /******/ }([\n /* 0 */ /***/ function(module1, exports1) {\n module1.exports = __WEBPACK_EXTERNAL_MODULE_0__;\n /***/ },\n /* 1 */ /***/ function(module1, exports1, __nested_webpack_require_3704__) {\n \"use strict\";\n var FDLayoutConstants = __nested_webpack_require_3704__(0).FDLayoutConstants;\n function CoSEConstants() {}\n //CoSEConstants inherits static props in FDLayoutConstants\n for(var prop in FDLayoutConstants){\n CoSEConstants[prop] = FDLayoutConstants[prop];\n }\n CoSEConstants.DEFAULT_USE_MULTI_LEVEL_SCALING = false;\n CoSEConstants.DEFAULT_RADIAL_SEPARATION = FDLayoutConstants.DEFAULT_EDGE_LENGTH;\n CoSEConstants.DEFAULT_COMPONENT_SEPERATION = 60;\n CoSEConstants.TILE = true;\n CoSEConstants.TILING_PADDING_VERTICAL = 10;\n CoSEConstants.TILING_PADDING_HORIZONTAL = 10;\n CoSEConstants.TREE_REDUCTION_ON_INCREMENTAL = false; // make this true when cose is used incrementally as a part of other non-incremental layout\n module1.exports = CoSEConstants;\n /***/ },\n /* 2 */ /***/ function(module1, exports1, __nested_webpack_require_4710__) {\n \"use strict\";\n var FDLayoutEdge = __nested_webpack_require_4710__(0).FDLayoutEdge;\n function CoSEEdge(source, target, vEdge) {\n FDLayoutEdge.call(this, source, target, vEdge);\n }\n CoSEEdge.prototype = Object.create(FDLayoutEdge.prototype);\n for(var prop in FDLayoutEdge){\n CoSEEdge[prop] = FDLayoutEdge[prop];\n }\n module1.exports = CoSEEdge;\n /***/ },\n /* 3 */ /***/ function(module1, exports1, __nested_webpack_require_5249__) {\n \"use strict\";\n var LGraph = __nested_webpack_require_5249__(0).LGraph;\n function CoSEGraph(parent, graphMgr, vGraph) {\n LGraph.call(this, parent, graphMgr, vGraph);\n }\n CoSEGraph.prototype = Object.create(LGraph.prototype);\n for(var prop in LGraph){\n CoSEGraph[prop] = LGraph[prop];\n }\n module1.exports = CoSEGraph;\n /***/ },\n /* 4 */ /***/ function(module1, exports1, __nested_webpack_require_5762__) {\n \"use strict\";\n var LGraphManager = __nested_webpack_require_5762__(0).LGraphManager;\n function CoSEGraphManager(layout) {\n LGraphManager.call(this, layout);\n }\n CoSEGraphManager.prototype = Object.create(LGraphManager.prototype);\n for(var prop in LGraphManager){\n CoSEGraphManager[prop] = LGraphManager[prop];\n }\n module1.exports = CoSEGraphManager;\n /***/ },\n /* 5 */ /***/ function(module1, exports1, __nested_webpack_require_6309__) {\n \"use strict\";\n var FDLayoutNode = __nested_webpack_require_6309__(0).FDLayoutNode;\n var IMath = __nested_webpack_require_6309__(0).IMath;\n function CoSENode(gm, loc, size, vNode) {\n FDLayoutNode.call(this, gm, loc, size, vNode);\n }\n CoSENode.prototype = Object.create(FDLayoutNode.prototype);\n for(var prop in FDLayoutNode){\n CoSENode[prop] = FDLayoutNode[prop];\n }\n CoSENode.prototype.move = function() {\n var layout = this.graphManager.getLayout();\n this.displacementX = layout.coolingFactor * (this.springForceX + this.repulsionForceX + this.gravitationForceX) / this.noOfChildren;\n this.displacementY = layout.coolingFactor * (this.springForceY + this.repulsionForceY + this.gravitationForceY) / this.noOfChildren;\n if (Math.abs(this.displacementX) > layout.coolingFactor * layout.maxNodeDisplacement) {\n this.displacementX = layout.coolingFactor * layout.maxNodeDisplacement * IMath.sign(this.displacementX);\n }\n if (Math.abs(this.displacementY) > layout.coolingFactor * layout.maxNodeDisplacement) {\n this.displacementY = layout.coolingFactor * layout.maxNodeDisplacement * IMath.sign(this.displacementY);\n }\n // a simple node, just move it\n if (this.child == null) {\n this.moveBy(this.displacementX, this.displacementY);\n } else if (this.child.getNodes().length == 0) {\n this.moveBy(this.displacementX, this.displacementY);\n } else {\n this.propogateDisplacementToChildren(this.displacementX, this.displacementY);\n }\n layout.totalDisplacement += Math.abs(this.displacementX) + Math.abs(this.displacementY);\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 this.displacementX = 0;\n this.displacementY = 0;\n };\n CoSENode.prototype.propogateDisplacementToChildren = function(dX, dY) {\n var nodes = this.getChild().getNodes();\n var node;\n for(var i = 0; i < nodes.length; i++){\n node = nodes[i];\n if (node.getChild() == null) {\n node.moveBy(dX, dY);\n node.displacementX += dX;\n node.displacementY += dY;\n } else {\n node.propogateDisplacementToChildren(dX, dY);\n }\n }\n };\n CoSENode.prototype.setPred1 = function(pred11) {\n this.pred1 = pred11;\n };\n CoSENode.prototype.getPred1 = function() {\n return pred1;\n };\n CoSENode.prototype.getPred2 = function() {\n return pred2;\n };\n CoSENode.prototype.setNext = function(next1) {\n this.next = next1;\n };\n CoSENode.prototype.getNext = function() {\n return next;\n };\n CoSENode.prototype.setProcessed = function(processed1) {\n this.processed = processed1;\n };\n CoSENode.prototype.isProcessed = function() {\n return processed;\n };\n module1.exports = CoSENode;\n /***/ },\n /* 6 */ /***/ function(module1, exports1, __nested_webpack_require_10057__) {\n \"use strict\";\n var FDLayout = __nested_webpack_require_10057__(0).FDLayout;\n var CoSEGraphManager = __nested_webpack_require_10057__(4);\n var CoSEGraph = __nested_webpack_require_10057__(3);\n var CoSENode = __nested_webpack_require_10057__(5);\n var CoSEEdge = __nested_webpack_require_10057__(2);\n var CoSEConstants = __nested_webpack_require_10057__(1);\n var FDLayoutConstants = __nested_webpack_require_10057__(0).FDLayoutConstants;\n var LayoutConstants = __nested_webpack_require_10057__(0).LayoutConstants;\n var Point = __nested_webpack_require_10057__(0).Point;\n var PointD = __nested_webpack_require_10057__(0).PointD;\n var Layout = __nested_webpack_require_10057__(0).Layout;\n var Integer = __nested_webpack_require_10057__(0).Integer;\n var IGeometry = __nested_webpack_require_10057__(0).IGeometry;\n var LGraph = __nested_webpack_require_10057__(0).LGraph;\n var Transform = __nested_webpack_require_10057__(0).Transform;\n function CoSELayout() {\n FDLayout.call(this);\n this.toBeTiled = {}; // Memorize if a node is to be tiled or is tiled\n }\n CoSELayout.prototype = Object.create(FDLayout.prototype);\n for(var prop in FDLayout){\n CoSELayout[prop] = FDLayout[prop];\n }\n CoSELayout.prototype.newGraphManager = function() {\n var gm = new CoSEGraphManager(this);\n this.graphManager = gm;\n return gm;\n };\n CoSELayout.prototype.newGraph = function(vGraph) {\n return new CoSEGraph(null, this.graphManager, vGraph);\n };\n CoSELayout.prototype.newNode = function(vNode) {\n return new CoSENode(this.graphManager, vNode);\n };\n CoSELayout.prototype.newEdge = function(vEdge) {\n return new CoSEEdge(null, null, vEdge);\n };\n CoSELayout.prototype.initParameters = function() {\n FDLayout.prototype.initParameters.call(this, arguments);\n if (!this.isSubLayout) {\n if (CoSEConstants.DEFAULT_EDGE_LENGTH < 10) {\n this.idealEdgeLength = 10;\n } else {\n this.idealEdgeLength = CoSEConstants.DEFAULT_EDGE_LENGTH;\n }\n this.useSmartIdealEdgeLengthCalculation = CoSEConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION;\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 // variables for tree reduction support\n this.prunedNodesAll = [];\n this.growTreeIterations = 0;\n this.afterGrowthIterations = 0;\n this.isTreeGrowing = false;\n this.isGrowthFinished = false;\n // variables for cooling\n this.coolingCycle = 0;\n this.maxCoolingCycle = this.maxIterations / FDLayoutConstants.CONVERGENCE_CHECK_PERIOD;\n this.finalTemperature = FDLayoutConstants.CONVERGENCE_CHECK_PERIOD / this.maxIterations;\n this.coolingAdjuster = 1;\n }\n };\n CoSELayout.prototype.layout = function() {\n var createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED;\n if (createBendsAsNeeded) {\n this.createBendpoints();\n this.graphManager.resetAllEdges();\n }\n this.level = 0;\n return this.classicLayout();\n };\n CoSELayout.prototype.classicLayout = function() {\n this.nodesWithGravity = this.calculateNodesToApplyGravitationTo();\n this.graphManager.setAllNodesToApplyGravitation(this.nodesWithGravity);\n this.calcNoOfChildrenForAllNodes();\n this.graphManager.calcLowestCommonAncestors();\n this.graphManager.calcInclusionTreeDepths();\n this.graphManager.getRoot().calcEstimatedSize();\n this.calcIdealEdgeLengths();\n if (!this.incremental) {\n var forest = this.getFlatForest();\n // The graph associated with this layout is flat and a forest\n if (forest.length > 0) {\n this.positionNodesRadially(forest);\n } else {\n // Reduce the trees when incremental mode is not enabled and graph is not a forest \n this.reduceTrees();\n // Update nodes that gravity will be applied\n this.graphManager.resetAllNodesToApplyGravitation();\n var allNodes = new Set(this.getAllNodes());\n var intersection = this.nodesWithGravity.filter(function(x) {\n return allNodes.has(x);\n });\n this.graphManager.setAllNodesToApplyGravitation(intersection);\n this.positionNodesRandomly();\n }\n } else {\n if (CoSEConstants.TREE_REDUCTION_ON_INCREMENTAL) {\n // Reduce the trees in incremental mode if only this constant is set to true \n this.reduceTrees();\n // Update nodes that gravity will be applied\n this.graphManager.resetAllNodesToApplyGravitation();\n var allNodes = new Set(this.getAllNodes());\n var intersection = this.nodesWithGravity.filter(function(x) {\n return allNodes.has(x);\n });\n this.graphManager.setAllNodesToApplyGravitation(intersection);\n }\n }\n this.initSpringEmbedder();\n this.runSpringEmbedder();\n return true;\n };\n CoSELayout.prototype.tick = function() {\n this.totalIterations++;\n if (this.totalIterations === this.maxIterations && !this.isTreeGrowing && !this.isGrowthFinished) {\n if (this.prunedNodesAll.length > 0) {\n this.isTreeGrowing = true;\n } else {\n return true;\n }\n }\n if (this.totalIterations % FDLayoutConstants.CONVERGENCE_CHECK_PERIOD == 0 && !this.isTreeGrowing && !this.isGrowthFinished) {\n if (this.isConverged()) {\n if (this.prunedNodesAll.length > 0) {\n this.isTreeGrowing = true;\n } else {\n return true;\n }\n }\n this.coolingCycle++;\n if (this.layoutQuality == 0) {\n // quality - \"draft\"\n this.coolingAdjuster = this.coolingCycle;\n } else if (this.layoutQuality == 1) {\n // quality - \"default\"\n this.coolingAdjuster = this.coolingCycle / 3;\n }\n // cooling schedule is based on http://www.btluke.com/simanf1.html -> cooling schedule 3\n this.coolingFactor = Math.max(this.initialCoolingFactor - Math.pow(this.coolingCycle, Math.log(100 * (this.initialCoolingFactor - this.finalTemperature)) / Math.log(this.maxCoolingCycle)) / 100 * this.coolingAdjuster, this.finalTemperature);\n this.animationPeriod = Math.ceil(this.initialAnimationPeriod * Math.sqrt(this.coolingFactor));\n }\n // Operations while tree is growing again \n if (this.isTreeGrowing) {\n if (this.growTreeIterations % 10 == 0) {\n if (this.prunedNodesAll.length > 0) {\n this.graphManager.updateBounds();\n this.updateGrid();\n this.growTree(this.prunedNodesAll);\n // Update nodes that gravity will be applied\n this.graphManager.resetAllNodesToApplyGravitation();\n var allNodes = new Set(this.getAllNodes());\n var intersection = this.nodesWithGravity.filter(function(x) {\n return allNodes.has(x);\n });\n this.graphManager.setAllNodesToApplyGravitation(intersection);\n this.graphManager.updateBounds();\n this.updateGrid();\n this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL;\n } else {\n this.isTreeGrowing = false;\n this.isGrowthFinished = true;\n }\n }\n this.growTreeIterations++;\n }\n // Operations after growth is finished\n if (this.isGrowthFinished) {\n if (this.isConverged()) {\n return true;\n }\n if (this.afterGrowthIterations % 10 == 0) {\n this.graphManager.updateBounds();\n this.updateGrid();\n }\n this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL * ((100 - this.afterGrowthIterations) / 100);\n this.afterGrowthIterations++;\n }\n var gridUpdateAllowed = !this.isTreeGrowing && !this.isGrowthFinished;\n var forceToNodeSurroundingUpdate = this.growTreeIterations % 10 == 1 && this.isTreeGrowing || this.afterGrowthIterations % 10 == 1 && this.isGrowthFinished;\n this.totalDisplacement = 0;\n this.graphManager.updateBounds();\n this.calcSpringForces();\n this.calcRepulsionForces(gridUpdateAllowed, forceToNodeSurroundingUpdate);\n this.calcGravitationalForces();\n this.moveNodes();\n this.animate();\n return false; // Layout is not ended yet return false\n };\n CoSELayout.prototype.getPositionsData = function() {\n var allNodes = this.graphManager.getAllNodes();\n var pData = {};\n for(var i = 0; i < allNodes.length; i++){\n var rect = allNodes[i].rect;\n var id = allNodes[i].id;\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 return pData;\n };\n CoSELayout.prototype.runSpringEmbedder = function() {\n this.initialAnimationPeriod = 25;\n this.animationPeriod = this.initialAnimationPeriod;\n var layoutEnded = false;\n // If aminate option is 'during' signal that layout is supposed to start iterating\n if (FDLayoutConstants.ANIMATE === \"during\") {\n this.emit(\"layoutstarted\");\n } else {\n // If aminate option is 'during' tick() function will be called on index.js\n while(!layoutEnded){\n layoutEnded = this.tick();\n }\n this.graphManager.updateBounds();\n }\n };\n CoSELayout.prototype.calculateNodesToApplyGravitationTo = function() {\n var nodeList = [];\n var graph;\n var graphs = this.graphManager.getGraphs();\n var size = graphs.length;\n var i;\n for(i = 0; i < size; i++){\n graph = graphs[i];\n graph.updateConnected();\n if (!graph.isConnected) {\n nodeList = nodeList.concat(graph.getNodes());\n }\n }\n return nodeList;\n };\n CoSELayout.prototype.createBendpoints = function() {\n var edges = [];\n edges = edges.concat(this.graphManager.getAllEdges());\n var visited = new Set();\n var i;\n for(i = 0; i < edges.length; i++){\n var edge = edges[i];\n if (!visited.has(edge)) {\n var source = edge.getSource();\n var target = edge.getTarget();\n if (source == target) {\n edge.getBendpoints().push(new PointD());\n edge.getBendpoints().push(new PointD());\n this.createDummyNodesForBendpoints(edge);\n visited.add(edge);\n } else {\n var edgeList = [];\n edgeList = edgeList.concat(source.getEdgeListToNode(target));\n edgeList = edgeList.concat(target.getEdgeListToNode(source));\n if (!visited.has(edgeList[0])) {\n if (edgeList.length > 1) {\n var k;\n for(k = 0; k < edgeList.length; k++){\n var multiEdge = edgeList[k];\n multiEdge.getBendpoints().push(new PointD());\n this.createDummyNodesForBendpoints(multiEdge);\n }\n }\n edgeList.forEach(function(edge) {\n visited.add(edge);\n });\n }\n }\n }\n if (visited.size == edges.length) {\n break;\n }\n }\n };\n CoSELayout.prototype.positionNodesRadially = function(forest) {\n // We tile the trees to a grid row by row; first tree starts at (0,0)\n var currentStartingPoint = new Point(0, 0);\n var numberOfColumns = Math.ceil(Math.sqrt(forest.length));\n var height = 0;\n var currentY = 0;\n var currentX = 0;\n var point = new PointD(0, 0);\n for(var i = 0; i < forest.length; i++){\n if (i % numberOfColumns == 0) {\n // Start of a new row, make the x coordinate 0, increment the\n // y coordinate with the max height of the previous row\n currentX = 0;\n currentY = height;\n if (i != 0) {\n currentY += CoSEConstants.DEFAULT_COMPONENT_SEPERATION;\n }\n height = 0;\n }\n var tree = forest[i];\n // Find the center of the tree\n var centerNode = Layout.findCenterOfTree(tree);\n // Set the staring point of the next tree\n currentStartingPoint.x = currentX;\n currentStartingPoint.y = currentY;\n // Do a radial layout starting with the center\n point = CoSELayout.radialLayout(tree, centerNode, currentStartingPoint);\n if (point.y > height) {\n height = Math.floor(point.y);\n }\n currentX = Math.floor(point.x + CoSEConstants.DEFAULT_COMPONENT_SEPERATION);\n }\n this.transform(new PointD(LayoutConstants.WORLD_CENTER_X - point.x / 2, LayoutConstants.WORLD_CENTER_Y - point.y / 2));\n };\n CoSELayout.radialLayout = function(tree, centerNode, startingPoint) {\n var radialSep = Math.max(this.maxDiagonalInTree(tree), CoSEConstants.DEFAULT_RADIAL_SEPARATION);\n CoSELayout.branchRadialLayout(centerNode, null, 0, 359, 0, radialSep);\n var bounds = LGraph.calculateBounds(tree);\n var transform = new Transform();\n transform.setDeviceOrgX(bounds.getMinX());\n transform.setDeviceOrgY(bounds.getMinY());\n transform.setWorldOrgX(startingPoint.x);\n transform.setWorldOrgY(startingPoint.y);\n for(var i = 0; i < tree.length; i++){\n var node = tree[i];\n node.transform(transform);\n }\n var bottomRight = new PointD(bounds.getMaxX(), bounds.getMaxY());\n return transform.inverseTransformPoint(bottomRight);\n };\n CoSELayout.branchRadialLayout = function(node, parentOfNode, startAngle, endAngle, distance, radialSeparation) {\n // First, position this node by finding its angle.\n var halfInterval = (endAngle - startAngle + 1) / 2;\n if (halfInterval < 0) {\n halfInterval += 180;\n }\n var nodeAngle = (halfInterval + startAngle) % 360;\n var teta = nodeAngle * IGeometry.TWO_PI / 360;\n // Make polar to java cordinate conversion.\n var cos_teta = Math.cos(teta);\n var x_ = distance * Math.cos(teta);\n var y_ = distance * Math.sin(teta);\n node.setCenter(x_, y_);\n // Traverse all neighbors of this node and recursively call this\n // function.\n var neighborEdges = [];\n neighborEdges = neighborEdges.concat(node.getEdges());\n var childCount = neighborEdges.length;\n if (parentOfNode != null) {\n childCount--;\n }\n var branchCount = 0;\n var incEdgesCount = neighborEdges.length;\n var startIndex;\n var edges = node.getEdgesBetween(parentOfNode);\n // If there are multiple edges, prune them until there remains only one\n // edge.\n while(edges.length > 1){\n //neighborEdges.remove(edges.remove(0));\n var temp = edges[0];\n edges.splice(0, 1);\n var index = neighborEdges.indexOf(temp);\n if (index >= 0) {\n neighborEdges.splice(index, 1);\n }\n incEdgesCount--;\n childCount--;\n }\n if (parentOfNode != null) {\n //assert edges.length == 1;\n startIndex = (neighborEdges.indexOf(edges[0]) + 1) % incEdgesCount;\n } else {\n startIndex = 0;\n }\n var stepAngle = Math.abs(endAngle - startAngle) / childCount;\n for(var i = startIndex; branchCount != childCount; i = ++i % incEdgesCount){\n var currentNeighbor = neighborEdges[i].getOtherEnd(node);\n // Don't back traverse to root node in current tree.\n if (currentNeighbor == parentOfNode) {\n continue;\n }\n var childStartAngle = (startAngle + branchCount * stepAngle) % 360;\n var childEndAngle = (childStartAngle + stepAngle) % 360;\n CoSELayout.branchRadialLayout(currentNeighbor, node, childStartAngle, childEndAngle, distance + radialSeparation, radialSeparation);\n branchCount++;\n }\n };\n CoSELayout.maxDiagonalInTree = function(tree) {\n var maxDiagonal = Integer.MIN_VALUE;\n for(var i = 0; i < tree.length; i++){\n var node = tree[i];\n var diagonal = node.getDiagonal();\n if (diagonal > maxDiagonal) {\n maxDiagonal = diagonal;\n }\n }\n return maxDiagonal;\n };\n CoSELayout.prototype.calcRepulsionRange = function() {\n // formula is 2 x (level + 1) x idealEdgeLength\n return 2 * (this.level + 1) * this.idealEdgeLength;\n };\n // Tiling methods\n // Group zero degree members whose parents are not to be tiled, create dummy parents where needed and fill memberGroups by their dummp parent id's\n CoSELayout.prototype.groupZeroDegreeMembers = function() {\n var self = this;\n // array of [parent_id x oneDegreeNode_id]\n var tempMemberGroups = {}; // A temporary map of parent node and its zero degree members\n this.memberGroups = {}; // A map of dummy parent node and its zero degree members whose parents are not to be tiled\n this.idToDummyNode = {}; // A map of id to dummy node \n var zeroDegree = []; // List of zero degree nodes whose parents are not to be tiled\n var allNodes = this.graphManager.getAllNodes();\n // Fill zero degree list\n for(var i = 0; i < allNodes.length; i++){\n var node = allNodes[i];\n var parent = node.getParent();\n // If a node has zero degree and its parent is not to be tiled if exists add that node to zeroDegres list\n if (this.getNodeDegreeWithChildren(node) === 0 && (parent.id == undefined || !this.getToBeTiled(parent))) {\n zeroDegree.push(node);\n }\n }\n // Create a map of parent node and its zero degree members\n for(var i = 0; i < zeroDegree.length; i++){\n var node = zeroDegree[i]; // Zero degree node itself\n var p_id = node.getParent().id; // Parent id\n if (typeof tempMemberGroups[p_id] === \"undefined\") tempMemberGroups[p_id] = [];\n tempMemberGroups[p_id] = tempMemberGroups[p_id].concat(node); // Push node to the list belongs to its parent in tempMemberGroups\n }\n // If there are at least two nodes at a level, create a dummy compound for them\n Object.keys(tempMemberGroups).forEach(function(p_id) {\n if (tempMemberGroups[p_id].length > 1) {\n var dummyCompoundId = \"DummyCompound_\" + p_id; // The id of dummy compound which will be created soon\n self.memberGroups[dummyCompoundId] = tempMemberGroups[p_id]; // Add dummy compound to memberGroups\n var parent = tempMemberGroups[p_id][0].getParent(); // The parent of zero degree nodes will be the parent of new dummy compound\n // Create a dummy compound with calculated id\n var dummyCompound = new CoSENode(self.graphManager);\n dummyCompound.id = dummyCompoundId;\n dummyCompound.paddingLeft = parent.paddingLeft || 0;\n dummyCompound.paddingRight = parent.paddingRight || 0;\n dummyCompound.paddingBottom = parent.paddingBottom || 0;\n dummyCompound.paddingTop = parent.paddingTop || 0;\n self.idToDummyNode[dummyCompoundId] = dummyCompound;\n var dummyParentGraph = self.getGraphManager().add(self.newGraph(), dummyCompound);\n var parentGraph = parent.getChild();\n // Add dummy compound to parent the graph\n parentGraph.add(dummyCompound);\n // For each zero degree node in this level remove it from its parent graph and add it to the graph of dummy parent\n for(var i = 0; i < tempMemberGroups[p_id].length; i++){\n var node = tempMemberGroups[p_id][i];\n parentGraph.remove(node);\n dummyParentGraph.add(node);\n }\n }\n });\n };\n CoSELayout.prototype.clearCompounds = function() {\n var childGraphMap = {};\n var idToNode = {};\n // Get compound ordering by finding the inner one first\n this.performDFSOnCompounds();\n for(var i = 0; i < this.compoundOrder.length; i++){\n idToNode[this.compoundOrder[i].id] = this.compoundOrder[i];\n childGraphMap[this.compoundOrder[i].id] = [].concat(this.compoundOrder[i].getChild().getNodes());\n // Remove children of compounds\n this.graphManager.remove(this.compoundOrder[i].getChild());\n this.compoundOrder[i].child = null;\n }\n this.graphManager.resetAllNodes();\n // Tile the removed children\n this.tileCompoundMembers(childGraphMap, idToNode);\n };\n CoSELayout.prototype.clearZeroDegreeMembers = function() {\n var self = this;\n var tiledZeroDegreePack = this.tiledZeroDegreePack = [];\n Object.keys(this.memberGroups).forEach(function(id) {\n var compoundNode = self.idToDummyNode[id]; // Get the dummy compound\n tiledZeroDegreePack[id] = self.tileNodes(self.memberGroups[id], compoundNode.paddingLeft + compoundNode.paddingRight);\n // Set the width and height of the dummy compound as calculated\n compoundNode.rect.width = tiledZeroDegreePack[id].width;\n compoundNode.rect.height = tiledZeroDegreePack[id].height;\n });\n };\n CoSELayout.prototype.repopulateCompounds = function() {\n for(var i = this.compoundOrder.length - 1; i >= 0; i--){\n var lCompoundNode = this.compoundOrder[i];\n var id = lCompoundNode.id;\n var horizontalMargin = lCompoundNode.paddingLeft;\n var verticalMargin = lCompoundNode.paddingTop;\n this.adjustLocations(this.tiledMemberPack[id], lCompoundNode.rect.x, lCompoundNode.rect.y, horizontalMargin, verticalMargin);\n }\n };\n CoSELayout.prototype.repopulateZeroDegreeMembers = function() {\n var self = this;\n var tiledPack = this.tiledZeroDegreePack;\n Object.keys(tiledPack).forEach(function(id) {\n var compoundNode = self.idToDummyNode[id]; // Get the dummy compound by its id\n var horizontalMargin = compoundNode.paddingLeft;\n var verticalMargin = compoundNode.paddingTop;\n // Adjust the positions of nodes wrt its compound\n self.adjustLocations(tiledPack[id], compoundNode.rect.x, compoundNode.rect.y, horizontalMargin, verticalMargin);\n });\n };\n CoSELayout.prototype.getToBeTiled = function(node) {\n var id = node.id;\n //firstly check the previous results\n if (this.toBeTiled[id] != null) {\n return this.toBeTiled[id];\n }\n //only compound nodes are to be tiled\n var childGraph = node.getChild();\n if (childGraph == null) {\n this.toBeTiled[id] = false;\n return false;\n }\n var children = childGraph.getNodes(); // Get the children nodes\n //a compound node is not to be tiled if all of its compound children are not to be tiled\n for(var i = 0; i < children.length; i++){\n var theChild = children[i];\n if (this.getNodeDegree(theChild) > 0) {\n this.toBeTiled[id] = false;\n return false;\n }\n //pass the children not having the compound structure\n if (theChild.getChild() == null) {\n this.toBeTiled[theChild.id] = false;\n continue;\n }\n if (!this.getToBeTiled(theChild)) {\n this.toBeTiled[id] = false;\n return false;\n }\n }\n this.toBeTiled[id] = true;\n return true;\n };\n // Get degree of a node depending of its edges and independent of its children\n CoSELayout.prototype.getNodeDegree = function(node) {\n var id = node.id;\n var edges = node.getEdges();\n var degree = 0;\n // For the edges connected\n for(var i = 0; i < edges.length; i++){\n var edge = edges[i];\n if (edge.getSource().id !== edge.getTarget().id) {\n degree = degree + 1;\n }\n }\n return degree;\n };\n // Get degree of a node with its children\n CoSELayout.prototype.getNodeDegreeWithChildren = function(node) {\n var degree = this.getNodeDegree(node);\n if (node.getChild() == null) {\n return degree;\n }\n var children = node.getChild().getNodes();\n for(var i = 0; i < children.length; i++){\n var child = children[i];\n degree += this.getNodeDegreeWithChildren(child);\n }\n return degree;\n };\n CoSELayout.prototype.performDFSOnCompounds = function() {\n this.compoundOrder = [];\n this.fillCompexOrderByDFS(this.graphManager.getRoot().getNodes());\n };\n CoSELayout.prototype.fillCompexOrderByDFS = function(children) {\n for(var i = 0; i < children.length; i++){\n var child = children[i];\n if (child.getChild() != null) {\n this.fillCompexOrderByDFS(child.getChild().getNodes());\n }\n if (this.getToBeTiled(child)) {\n this.compoundOrder.push(child);\n }\n }\n };\n /**\n* This method places each zero degree member wrt given (x,y) coordinates (top left).\n*/ CoSELayout.prototype.adjustLocations = function(organization, x, y, compoundHorizontalMargin, compoundVerticalMargin) {\n x += compoundHorizontalMargin;\n y += compoundVerticalMargin;\n var left = x;\n for(var i = 0; i < organization.rows.length; i++){\n var row = organization.rows[i];\n x = left;\n var maxHeight = 0;\n for(var j = 0; j < row.length; j++){\n var lnode = row[j];\n lnode.rect.x = x; // + lnode.rect.width / 2;\n lnode.rect.y = y; // + lnode.rect.height / 2;\n x += lnode.rect.width + organization.horizontalPadding;\n if (lnode.rect.height > maxHeight) maxHeight = lnode.rect.height;\n }\n y += maxHeight + organization.verticalPadding;\n }\n };\n CoSELayout.prototype.tileCompoundMembers = function(childGraphMap, idToNode) {\n var self = this;\n this.tiledMemberPack = [];\n Object.keys(childGraphMap).forEach(function(id) {\n // Get the compound node\n var compoundNode = idToNode[id];\n self.tiledMemberPack[id] = self.tileNodes(childGraphMap[id], compoundNode.paddingLeft + compoundNode.paddingRight);\n compoundNode.rect.width = self.tiledMemberPack[id].width;\n compoundNode.rect.height = self.tiledMemberPack[id].height;\n });\n };\n CoSELayout.prototype.tileNodes = function(nodes, minWidth) {\n var verticalPadding = CoSEConstants.TILING_PADDING_VERTICAL;\n var horizontalPadding = CoSEConstants.TILING_PADDING_HORIZONTAL;\n var organization = {\n rows: [],\n rowWidth: [],\n rowHeight: [],\n width: 0,\n height: minWidth,\n verticalPadding: verticalPadding,\n horizontalPadding: horizontalPadding\n };\n // Sort the nodes in ascending order of their areas\n nodes.sort(function(n1, n2) {\n if (n1.rect.width * n1.rect.height > n2.rect.width * n2.rect.height) return -1;\n if (n1.rect.width * n1.rect.height < n2.rect.width * n2.rect.height) return 1;\n return 0;\n });\n // Create the organization -> tile members\n for(var i = 0; i < nodes.length; i++){\n var lNode = nodes[i];\n if (organization.rows.length == 0) {\n this.insertNodeToRow(organization, lNode, 0, minWidth);\n } else if (this.canAddHorizontal(organization, lNode.rect.width, lNode.rect.height)) {\n this.insertNodeToRow(organization, lNode, this.getShortestRowIndex(organization), minWidth);\n } else {\n this.insertNodeToRow(organization, lNode, organization.rows.length, minWidth);\n }\n this.shiftToLastRow(organization);\n }\n return organization;\n };\n CoSELayout.prototype.insertNodeToRow = function(organization, node, rowIndex, minWidth) {\n var minCompoundSize = minWidth;\n // Add new row if needed\n if (rowIndex == organization.rows.length) {\n var secondDimension = [];\n organization.rows.push(secondDimension);\n organization.rowWidth.push(minCompoundSize);\n organization.rowHeight.push(0);\n }\n // Update row width\n var w = organization.rowWidth[rowIndex] + node.rect.width;\n if (organization.rows[rowIndex].length > 0) {\n w += organization.horizontalPadding;\n }\n organization.rowWidth[rowIndex] = w;\n // Update compound width\n if (organization.width < w) {\n organization.width = w;\n }\n // Update height\n var h = node.rect.height;\n if (rowIndex > 0) h += organization.verticalPadding;\n var extraHeight = 0;\n if (h > organization.rowHeight[rowIndex]) {\n extraHeight = organization.rowHeight[rowIndex];\n organization.rowHeight[rowIndex] = h;\n extraHeight = organization.rowHeight[rowIndex] - extraHeight;\n }\n organization.height += extraHeight;\n // Insert node\n organization.rows[rowIndex].push(node);\n };\n //Scans the rows of an organization and returns the one with the min width\n CoSELayout.prototype.getShortestRowIndex = function(organization) {\n var r = -1;\n var min = Number.MAX_VALUE;\n for(var i = 0; i < organization.rows.length; i++){\n if (organization.rowWidth[i] < min) {\n r = i;\n min = organization.rowWidth[i];\n }\n }\n return r;\n };\n //Scans the rows of an organization and returns the one with the max width\n CoSELayout.prototype.getLongestRowIndex = function(organization) {\n var r = -1;\n var max = Number.MIN_VALUE;\n for(var i = 0; i < organization.rows.length; i++){\n if (organization.rowWidth[i] > max) {\n r = i;\n max = organization.rowWidth[i];\n }\n }\n return r;\n };\n /**\n* This method checks whether adding extra width to the organization violates\n* the aspect ratio(1) or not.\n*/ CoSELayout.prototype.canAddHorizontal = function(organization, extraWidth, extraHeight) {\n var sri = this.getShortestRowIndex(organization);\n if (sri < 0) {\n return true;\n }\n var min = organization.rowWidth[sri];\n if (min + organization.horizontalPadding + extraWidth <= organization.width) return true;\n var hDiff = 0;\n // Adding to an existing row\n if (organization.rowHeight[sri] < extraHeight) {\n if (sri > 0) hDiff = extraHeight + organization.verticalPadding - organization.rowHeight[sri];\n }\n var add_to_row_ratio;\n if (organization.width - min >= extraWidth + organization.horizontalPadding) {\n add_to_row_ratio = (organization.height + hDiff) / (min + extraWidth + organization.horizontalPadding);\n } else {\n add_to_row_ratio = (organization.height + hDiff) / organization.width;\n }\n // Adding a new row for this node\n hDiff = extraHeight + organization.verticalPadding;\n var add_new_row_ratio;\n if (organization.width < extraWidth) {\n add_new_row_ratio = (organization.height + hDiff) / extraWidth;\n } else {\n add_new_row_ratio = (organization.height + hDiff) / organization.width;\n }\n if (add_new_row_ratio < 1) add_new_row_ratio = 1 / add_new_row_ratio;\n if (add_to_row_ratio < 1) add_to_row_ratio = 1 / add_to_row_ratio;\n return add_to_row_ratio < add_new_row_ratio;\n };\n //If moving the last node from the longest row and adding it to the last\n //row makes the bounding box smaller, do it.\n CoSELayout.prototype.shiftToLastRow = function(organization) {\n var longest = this.getLongestRowIndex(organization);\n var last = organization.rowWidth.length - 1;\n var row = organization.rows[longest];\n var node = row[row.length - 1];\n var diff = node.width + organization.horizontalPadding;\n // Check if there is enough space on the last row\n if (organization.width - organization.rowWidth[last] > diff && longest != last) {\n // Remove the last element of the longest row\n row.splice(-1, 1);\n // Push it to the last row\n organization.rows[last].push(node);\n organization.rowWidth[longest] = organization.rowWidth[longest] - diff;\n organization.rowWidth[last] = organization.rowWidth[last] + diff;\n organization.width = organization.rowWidth[instance.getLongestRowIndex(organization)];\n // Update heights of the organization\n var maxHeight = Number.MIN_VALUE;\n for(var i = 0; i < row.length; i++){\n if (row[i].height > maxHeight) maxHeight = row[i].height;\n }\n if (longest > 0) maxHeight += organization.verticalPadding;\n var prevTotal = organization.rowHeight[longest] + organization.rowHeight[last];\n organization.rowHeight[longest] = maxHeight;\n if (organization.rowHeight[last] < node.height + organization.verticalPadding) organization.rowHeight[last] = node.height + organization.verticalPadding;\n var finalTotal = organization.rowHeight[longest] + organization.rowHeight[last];\n organization.height += finalTotal - prevTotal;\n this.shiftToLastRow(organization);\n }\n };\n CoSELayout.prototype.tilingPreLayout = function() {\n if (CoSEConstants.TILE) {\n // Find zero degree nodes and create a compound for each level\n this.groupZeroDegreeMembers();\n // Tile and clear children of each compound\n this.clearCompounds();\n // Separately tile and clear zero degree nodes for each level\n this.clearZeroDegreeMembers();\n }\n };\n CoSELayout.prototype.tilingPostLayout = function() {\n if (CoSEConstants.TILE) {\n this.repopulateZeroDegreeMembers();\n this.repopulateCompounds();\n }\n };\n // -----------------------------------------------------------------------------\n // Section: Tree Reduction methods\n // -----------------------------------------------------------------------------\n // Reduce trees \n CoSELayout.prototype.reduceTrees = function() {\n var prunedNodesAll = [];\n var containsLeaf = true;\n var node;\n while(containsLeaf){\n var allNodes = this.graphManager.getAllNodes();\n var prunedNodesInStepTemp = [];\n containsLeaf = false;\n for(var i = 0; i < allNodes.length; i++){\n node = allNodes[i];\n if (node.getEdges().length == 1 && !node.getEdges()[0].isInterGraph && node.getChild() == null) {\n prunedNodesInStepTemp.push([\n node,\n node.getEdges()[0],\n node.getOwner()\n ]);\n containsLeaf = true;\n }\n }\n if (containsLeaf == true) {\n var prunedNodesInStep = [];\n for(var j = 0; j < prunedNodesInStepTemp.length; j++){\n if (prunedNodesInStepTemp[j][0].getEdges().length == 1) {\n prunedNodesInStep.push(prunedNodesInStepTemp[j]);\n prunedNodesInStepTemp[j][0].getOwner().remove(prunedNodesInStepTemp[j][0]);\n }\n }\n prunedNodesAll.push(prunedNodesInStep);\n this.graphManager.resetAllNodes();\n this.graphManager.resetAllEdges();\n }\n }\n this.prunedNodesAll = prunedNodesAll;\n };\n // Grow tree one step \n CoSELayout.prototype.growTree = function(prunedNodesAll) {\n var lengthOfPrunedNodesInStep = prunedNodesAll.length;\n var prunedNodesInStep = prunedNodesAll[lengthOfPrunedNodesInStep - 1];\n var nodeData;\n for(var i = 0; i < prunedNodesInStep.length; i++){\n nodeData = prunedNodesInStep[i];\n this.findPlaceforPrunedNode(nodeData);\n nodeData[2].add(nodeData[0]);\n nodeData[2].add(nodeData[1], nodeData[1].source, nodeData[1].target);\n }\n prunedNodesAll.splice(prunedNodesAll.length - 1, 1);\n this.graphManager.resetAllNodes();\n this.graphManager.resetAllEdges();\n };\n // Find an appropriate position to replace pruned node, this method can be improved\n CoSELayout.prototype.findPlaceforPrunedNode = function(nodeData) {\n var gridForPrunedNode;\n var nodeToConnect;\n var prunedNode = nodeData[0];\n if (prunedNode == nodeData[1].source) {\n nodeToConnect = nodeData[1].target;\n } else {\n nodeToConnect = nodeData[1].source;\n }\n var startGridX = nodeToConnect.startX;\n var finishGridX = nodeToConnect.finishX;\n var startGridY = nodeToConnect.startY;\n var finishGridY = nodeToConnect.finishY;\n var upNodeCount = 0;\n var downNodeCount = 0;\n var rightNodeCount = 0;\n var leftNodeCount = 0;\n var controlRegions = [\n upNodeCount,\n rightNodeCount,\n downNodeCount,\n leftNodeCount\n ];\n if (startGridY > 0) {\n for(var i = startGridX; i <= finishGridX; i++){\n controlRegions[0] += this.grid[i][startGridY - 1].length + this.grid[i][startGridY].length - 1;\n }\n }\n if (finishGridX < this.grid.length - 1) {\n for(var i = startGridY; i <= finishGridY; i++){\n controlRegions[1] += this.grid[finishGridX + 1][i].length + this.grid[finishGridX][i].length - 1;\n }\n }\n if (finishGridY < this.grid[0].length - 1) {\n for(var i = startGridX; i <= finishGridX; i++){\n controlRegions[2] += this.grid[i][finishGridY + 1].length + this.grid[i][finishGridY].length - 1;\n }\n }\n if (startGridX > 0) {\n for(var i = startGridY; i <= finishGridY; i++){\n controlRegions[3] += this.grid[startGridX - 1][i].length + this.grid[startGridX][i].length - 1;\n }\n }\n var min = Integer.MAX_VALUE;\n var minCount;\n var minIndex;\n for(var j = 0; j < controlRegions.length; j++){\n if (controlRegions[j] < min) {\n min = controlRegions[j];\n minCount = 1;\n minIndex = j;\n } else if (controlRegions[j] == min) {\n minCount++;\n }\n }\n if (minCount == 3 && min == 0) {\n if (controlRegions[0] == 0 && controlRegions[1] == 0 && controlRegions[2] == 0) {\n gridForPrunedNode = 1;\n } else if (controlRegions[0] == 0 && controlRegions[1] == 0 && controlRegions[3] == 0) {\n gridForPrunedNode = 0;\n } else if (controlRegions[0] == 0 && controlRegions[2] == 0 && controlRegions[3] == 0) {\n gridForPrunedNode = 3;\n } else if (controlRegions[1] == 0 && controlRegions[2] == 0 && controlRegions[3] == 0) {\n gridForPrunedNode = 2;\n }\n } else if (minCount == 2 && min == 0) {\n var random = Math.floor(Math.random() * 2);\n if (controlRegions[0] == 0 && controlRegions[1] == 0) {\n ;\n if (random == 0) {\n gridForPrunedNode = 0;\n } else {\n gridForPrunedNode = 1;\n }\n } else if (controlRegions[0] == 0 && controlRegions[2] == 0) {\n if (random == 0) {\n gridForPrunedNode = 0;\n } else {\n gridForPrunedNode = 2;\n }\n } else if (controlRegions[0] == 0 && controlRegions[3] == 0) {\n if (random == 0) {\n gridForPrunedNode = 0;\n } else {\n gridForPrunedNode = 3;\n }\n } else if (controlRegions[1] == 0 && controlRegions[2] == 0) {\n if (random == 0) {\n gridForPrunedNode = 1;\n } else {\n gridForPrunedNode = 2;\n }\n } else if (controlRegions[1] == 0 && controlRegions[3] == 0) {\n if (random == 0) {\n gridForPrunedNode = 1;\n } else {\n gridForPrunedNode = 3;\n }\n } else {\n if (random == 0) {\n gridForPrunedNode = 2;\n } else {\n gridForPrunedNode = 3;\n }\n }\n } else if (minCount == 4 && min == 0) {\n var random = Math.floor(Math.random() * 4);\n gridForPrunedNode = random;\n } else {\n gridForPrunedNode = minIndex;\n }\n if (gridForPrunedNode == 0) {\n prunedNode.setCenter(nodeToConnect.getCenterX(), nodeToConnect.getCenterY() - nodeToConnect.getHeight() / 2 - FDLayoutConstants.DEFAULT_EDGE_LENGTH - prunedNode.getHeight() / 2);\n } else if (gridForPrunedNode == 1) {\n prunedNode.setCenter(nodeToConnect.getCenterX() + nodeToConnect.getWidth() / 2 + FDLayoutConstants.DEFAULT_EDGE_LENGTH + prunedNode.getWidth() / 2, nodeToConnect.getCenterY());\n } else if (gridForPrunedNode == 2) {\n prunedNode.setCenter(nodeToConnect.getCenterX(), nodeToConnect.getCenterY() + nodeToConnect.getHeight() / 2 + FDLayoutConstants.DEFAULT_EDGE_LENGTH + prunedNode.getHeight() / 2);\n } else {\n prunedNode.setCenter(nodeToConnect.getCenterX() - nodeToConnect.getWidth() / 2 - FDLayoutConstants.DEFAULT_EDGE_LENGTH - prunedNode.getWidth() / 2, nodeToConnect.getCenterY());\n }\n };\n module1.exports = CoSELayout;\n /***/ },\n /* 7 */ /***/ function(module1, exports1, __nested_webpack_require_61777__) {\n \"use strict\";\n var coseBase = {};\n coseBase.layoutBase = __nested_webpack_require_61777__(0);\n coseBase.CoSEConstants = __nested_webpack_require_61777__(1);\n coseBase.CoSEEdge = __nested_webpack_require_61777__(2);\n coseBase.CoSEGraph = __nested_webpack_require_61777__(3);\n coseBase.CoSEGraphManager = __nested_webpack_require_61777__(4);\n coseBase.CoSELayout = __nested_webpack_require_61777__(6);\n coseBase.CoSENode = __nested_webpack_require_61777__(5);\n module1.exports = coseBase;\n /***/ }\n ]);\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/cose-base/cose-base.js","mappings":"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","sources":["webpack://nextchat/./node_modules/cose-base/cose-base.js?f8cf"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"layout-base\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"layout-base\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"coseBase\"] = factory(require(\"layout-base\"));\n\telse\n\t\troot[\"coseBase\"] = factory(root[\"layoutBase\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE_0__) {\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// 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 = 7);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_0__;\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar FDLayoutConstants = __webpack_require__(0).FDLayoutConstants;\n\nfunction CoSEConstants() {}\n\n//CoSEConstants inherits static props in FDLayoutConstants\nfor (var prop in FDLayoutConstants) {\n  CoSEConstants[prop] = FDLayoutConstants[prop];\n}\n\nCoSEConstants.DEFAULT_USE_MULTI_LEVEL_SCALING = false;\nCoSEConstants.DEFAULT_RADIAL_SEPARATION = FDLayoutConstants.DEFAULT_EDGE_LENGTH;\nCoSEConstants.DEFAULT_COMPONENT_SEPERATION = 60;\nCoSEConstants.TILE = true;\nCoSEConstants.TILING_PADDING_VERTICAL = 10;\nCoSEConstants.TILING_PADDING_HORIZONTAL = 10;\nCoSEConstants.TREE_REDUCTION_ON_INCREMENTAL = false; // make this true when cose is used incrementally as a part of other non-incremental layout\n\nmodule.exports = CoSEConstants;\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar FDLayoutEdge = __webpack_require__(0).FDLayoutEdge;\n\nfunction CoSEEdge(source, target, vEdge) {\n  FDLayoutEdge.call(this, source, target, vEdge);\n}\n\nCoSEEdge.prototype = Object.create(FDLayoutEdge.prototype);\nfor (var prop in FDLayoutEdge) {\n  CoSEEdge[prop] = FDLayoutEdge[prop];\n}\n\nmodule.exports = CoSEEdge;\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar LGraph = __webpack_require__(0).LGraph;\n\nfunction CoSEGraph(parent, graphMgr, vGraph) {\n  LGraph.call(this, parent, graphMgr, vGraph);\n}\n\nCoSEGraph.prototype = Object.create(LGraph.prototype);\nfor (var prop in LGraph) {\n  CoSEGraph[prop] = LGraph[prop];\n}\n\nmodule.exports = CoSEGraph;\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar LGraphManager = __webpack_require__(0).LGraphManager;\n\nfunction CoSEGraphManager(layout) {\n  LGraphManager.call(this, layout);\n}\n\nCoSEGraphManager.prototype = Object.create(LGraphManager.prototype);\nfor (var prop in LGraphManager) {\n  CoSEGraphManager[prop] = LGraphManager[prop];\n}\n\nmodule.exports = CoSEGraphManager;\n\n/***/ }),\n/* 5 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar FDLayoutNode = __webpack_require__(0).FDLayoutNode;\nvar IMath = __webpack_require__(0).IMath;\n\nfunction CoSENode(gm, loc, size, vNode) {\n  FDLayoutNode.call(this, gm, loc, size, vNode);\n}\n\nCoSENode.prototype = Object.create(FDLayoutNode.prototype);\nfor (var prop in FDLayoutNode) {\n  CoSENode[prop] = FDLayoutNode[prop];\n}\n\nCoSENode.prototype.move = function () {\n  var layout = this.graphManager.getLayout();\n  this.displacementX = layout.coolingFactor * (this.springForceX + this.repulsionForceX + this.gravitationForceX) / this.noOfChildren;\n  this.displacementY = layout.coolingFactor * (this.springForceY + this.repulsionForceY + this.gravitationForceY) / this.noOfChildren;\n\n  if (Math.abs(this.displacementX) > layout.coolingFactor * layout.maxNodeDisplacement) {\n    this.displacementX = layout.coolingFactor * layout.maxNodeDisplacement * IMath.sign(this.displacementX);\n  }\n\n  if (Math.abs(this.displacementY) > layout.coolingFactor * layout.maxNodeDisplacement) {\n    this.displacementY = layout.coolingFactor * layout.maxNodeDisplacement * IMath.sign(this.displacementY);\n  }\n\n  // a simple node, just move it\n  if (this.child == null) {\n    this.moveBy(this.displacementX, this.displacementY);\n  }\n  // an empty compound node, again just move it\n  else if (this.child.getNodes().length == 0) {\n      this.moveBy(this.displacementX, this.displacementY);\n    }\n    // non-empty compound node, propogate movement to children as well\n    else {\n        this.propogateDisplacementToChildren(this.displacementX, this.displacementY);\n      }\n\n  layout.totalDisplacement += Math.abs(this.displacementX) + Math.abs(this.displacementY);\n\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  this.displacementX = 0;\n  this.displacementY = 0;\n};\n\nCoSENode.prototype.propogateDisplacementToChildren = function (dX, dY) {\n  var nodes = this.getChild().getNodes();\n  var node;\n  for (var i = 0; i < nodes.length; i++) {\n    node = nodes[i];\n    if (node.getChild() == null) {\n      node.moveBy(dX, dY);\n      node.displacementX += dX;\n      node.displacementY += dY;\n    } else {\n      node.propogateDisplacementToChildren(dX, dY);\n    }\n  }\n};\n\nCoSENode.prototype.setPred1 = function (pred1) {\n  this.pred1 = pred1;\n};\n\nCoSENode.prototype.getPred1 = function () {\n  return pred1;\n};\n\nCoSENode.prototype.getPred2 = function () {\n  return pred2;\n};\n\nCoSENode.prototype.setNext = function (next) {\n  this.next = next;\n};\n\nCoSENode.prototype.getNext = function () {\n  return next;\n};\n\nCoSENode.prototype.setProcessed = function (processed) {\n  this.processed = processed;\n};\n\nCoSENode.prototype.isProcessed = function () {\n  return processed;\n};\n\nmodule.exports = CoSENode;\n\n/***/ }),\n/* 6 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar FDLayout = __webpack_require__(0).FDLayout;\nvar CoSEGraphManager = __webpack_require__(4);\nvar CoSEGraph = __webpack_require__(3);\nvar CoSENode = __webpack_require__(5);\nvar CoSEEdge = __webpack_require__(2);\nvar CoSEConstants = __webpack_require__(1);\nvar FDLayoutConstants = __webpack_require__(0).FDLayoutConstants;\nvar LayoutConstants = __webpack_require__(0).LayoutConstants;\nvar Point = __webpack_require__(0).Point;\nvar PointD = __webpack_require__(0).PointD;\nvar Layout = __webpack_require__(0).Layout;\nvar Integer = __webpack_require__(0).Integer;\nvar IGeometry = __webpack_require__(0).IGeometry;\nvar LGraph = __webpack_require__(0).LGraph;\nvar Transform = __webpack_require__(0).Transform;\n\nfunction CoSELayout() {\n  FDLayout.call(this);\n\n  this.toBeTiled = {}; // Memorize if a node is to be tiled or is tiled\n}\n\nCoSELayout.prototype = Object.create(FDLayout.prototype);\n\nfor (var prop in FDLayout) {\n  CoSELayout[prop] = FDLayout[prop];\n}\n\nCoSELayout.prototype.newGraphManager = function () {\n  var gm = new CoSEGraphManager(this);\n  this.graphManager = gm;\n  return gm;\n};\n\nCoSELayout.prototype.newGraph = function (vGraph) {\n  return new CoSEGraph(null, this.graphManager, vGraph);\n};\n\nCoSELayout.prototype.newNode = function (vNode) {\n  return new CoSENode(this.graphManager, vNode);\n};\n\nCoSELayout.prototype.newEdge = function (vEdge) {\n  return new CoSEEdge(null, null, vEdge);\n};\n\nCoSELayout.prototype.initParameters = function () {\n  FDLayout.prototype.initParameters.call(this, arguments);\n  if (!this.isSubLayout) {\n    if (CoSEConstants.DEFAULT_EDGE_LENGTH < 10) {\n      this.idealEdgeLength = 10;\n    } else {\n      this.idealEdgeLength = CoSEConstants.DEFAULT_EDGE_LENGTH;\n    }\n\n    this.useSmartIdealEdgeLengthCalculation = CoSEConstants.DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION;\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\n    // variables for tree reduction support\n    this.prunedNodesAll = [];\n    this.growTreeIterations = 0;\n    this.afterGrowthIterations = 0;\n    this.isTreeGrowing = false;\n    this.isGrowthFinished = false;\n\n    // variables for cooling\n    this.coolingCycle = 0;\n    this.maxCoolingCycle = this.maxIterations / FDLayoutConstants.CONVERGENCE_CHECK_PERIOD;\n    this.finalTemperature = FDLayoutConstants.CONVERGENCE_CHECK_PERIOD / this.maxIterations;\n    this.coolingAdjuster = 1;\n  }\n};\n\nCoSELayout.prototype.layout = function () {\n  var createBendsAsNeeded = LayoutConstants.DEFAULT_CREATE_BENDS_AS_NEEDED;\n  if (createBendsAsNeeded) {\n    this.createBendpoints();\n    this.graphManager.resetAllEdges();\n  }\n\n  this.level = 0;\n  return this.classicLayout();\n};\n\nCoSELayout.prototype.classicLayout = function () {\n  this.nodesWithGravity = this.calculateNodesToApplyGravitationTo();\n  this.graphManager.setAllNodesToApplyGravitation(this.nodesWithGravity);\n  this.calcNoOfChildrenForAllNodes();\n  this.graphManager.calcLowestCommonAncestors();\n  this.graphManager.calcInclusionTreeDepths();\n  this.graphManager.getRoot().calcEstimatedSize();\n  this.calcIdealEdgeLengths();\n\n  if (!this.incremental) {\n    var forest = this.getFlatForest();\n\n    // The graph associated with this layout is flat and a forest\n    if (forest.length > 0) {\n      this.positionNodesRadially(forest);\n    }\n    // The graph associated with this layout is not flat or a forest\n    else {\n        // Reduce the trees when incremental mode is not enabled and graph is not a forest \n        this.reduceTrees();\n        // Update nodes that gravity will be applied\n        this.graphManager.resetAllNodesToApplyGravitation();\n        var allNodes = new Set(this.getAllNodes());\n        var intersection = this.nodesWithGravity.filter(function (x) {\n          return allNodes.has(x);\n        });\n        this.graphManager.setAllNodesToApplyGravitation(intersection);\n\n        this.positionNodesRandomly();\n      }\n  } else {\n    if (CoSEConstants.TREE_REDUCTION_ON_INCREMENTAL) {\n      // Reduce the trees in incremental mode if only this constant is set to true \n      this.reduceTrees();\n      // Update nodes that gravity will be applied\n      this.graphManager.resetAllNodesToApplyGravitation();\n      var allNodes = new Set(this.getAllNodes());\n      var intersection = this.nodesWithGravity.filter(function (x) {\n        return allNodes.has(x);\n      });\n      this.graphManager.setAllNodesToApplyGravitation(intersection);\n    }\n  }\n\n  this.initSpringEmbedder();\n  this.runSpringEmbedder();\n\n  return true;\n};\n\nCoSELayout.prototype.tick = function () {\n  this.totalIterations++;\n\n  if (this.totalIterations === this.maxIterations && !this.isTreeGrowing && !this.isGrowthFinished) {\n    if (this.prunedNodesAll.length > 0) {\n      this.isTreeGrowing = true;\n    } else {\n      return true;\n    }\n  }\n\n  if (this.totalIterations % FDLayoutConstants.CONVERGENCE_CHECK_PERIOD == 0 && !this.isTreeGrowing && !this.isGrowthFinished) {\n    if (this.isConverged()) {\n      if (this.prunedNodesAll.length > 0) {\n        this.isTreeGrowing = true;\n      } else {\n        return true;\n      }\n    }\n\n    this.coolingCycle++;\n\n    if (this.layoutQuality == 0) {\n      // quality - \"draft\"\n      this.coolingAdjuster = this.coolingCycle;\n    } else if (this.layoutQuality == 1) {\n      // quality - \"default\"\n      this.coolingAdjuster = this.coolingCycle / 3;\n    }\n\n    // cooling schedule is based on http://www.btluke.com/simanf1.html -> cooling schedule 3\n    this.coolingFactor = Math.max(this.initialCoolingFactor - Math.pow(this.coolingCycle, Math.log(100 * (this.initialCoolingFactor - this.finalTemperature)) / Math.log(this.maxCoolingCycle)) / 100 * this.coolingAdjuster, this.finalTemperature);\n    this.animationPeriod = Math.ceil(this.initialAnimationPeriod * Math.sqrt(this.coolingFactor));\n  }\n  // Operations while tree is growing again \n  if (this.isTreeGrowing) {\n    if (this.growTreeIterations % 10 == 0) {\n      if (this.prunedNodesAll.length > 0) {\n        this.graphManager.updateBounds();\n        this.updateGrid();\n        this.growTree(this.prunedNodesAll);\n        // Update nodes that gravity will be applied\n        this.graphManager.resetAllNodesToApplyGravitation();\n        var allNodes = new Set(this.getAllNodes());\n        var intersection = this.nodesWithGravity.filter(function (x) {\n          return allNodes.has(x);\n        });\n        this.graphManager.setAllNodesToApplyGravitation(intersection);\n\n        this.graphManager.updateBounds();\n        this.updateGrid();\n        this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL;\n      } else {\n        this.isTreeGrowing = false;\n        this.isGrowthFinished = true;\n      }\n    }\n    this.growTreeIterations++;\n  }\n  // Operations after growth is finished\n  if (this.isGrowthFinished) {\n    if (this.isConverged()) {\n      return true;\n    }\n    if (this.afterGrowthIterations % 10 == 0) {\n      this.graphManager.updateBounds();\n      this.updateGrid();\n    }\n    this.coolingFactor = FDLayoutConstants.DEFAULT_COOLING_FACTOR_INCREMENTAL * ((100 - this.afterGrowthIterations) / 100);\n    this.afterGrowthIterations++;\n  }\n\n  var gridUpdateAllowed = !this.isTreeGrowing && !this.isGrowthFinished;\n  var forceToNodeSurroundingUpdate = this.growTreeIterations % 10 == 1 && this.isTreeGrowing || this.afterGrowthIterations % 10 == 1 && this.isGrowthFinished;\n\n  this.totalDisplacement = 0;\n  this.graphManager.updateBounds();\n  this.calcSpringForces();\n  this.calcRepulsionForces(gridUpdateAllowed, forceToNodeSurroundingUpdate);\n  this.calcGravitationalForces();\n  this.moveNodes();\n  this.animate();\n\n  return false; // Layout is not ended yet return false\n};\n\nCoSELayout.prototype.getPositionsData = function () {\n  var allNodes = this.graphManager.getAllNodes();\n  var pData = {};\n  for (var i = 0; i < allNodes.length; i++) {\n    var rect = allNodes[i].rect;\n    var id = allNodes[i].id;\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\nCoSELayout.prototype.runSpringEmbedder = function () {\n  this.initialAnimationPeriod = 25;\n  this.animationPeriod = this.initialAnimationPeriod;\n  var layoutEnded = false;\n\n  // If aminate option is 'during' signal that layout is supposed to start iterating\n  if (FDLayoutConstants.ANIMATE === 'during') {\n    this.emit('layoutstarted');\n  } else {\n    // If aminate option is 'during' tick() function will be called on index.js\n    while (!layoutEnded) {\n      layoutEnded = this.tick();\n    }\n\n    this.graphManager.updateBounds();\n  }\n};\n\nCoSELayout.prototype.calculateNodesToApplyGravitationTo = function () {\n  var nodeList = [];\n  var graph;\n\n  var graphs = this.graphManager.getGraphs();\n  var size = graphs.length;\n  var i;\n  for (i = 0; i < size; i++) {\n    graph = graphs[i];\n\n    graph.updateConnected();\n\n    if (!graph.isConnected) {\n      nodeList = nodeList.concat(graph.getNodes());\n    }\n  }\n\n  return nodeList;\n};\n\nCoSELayout.prototype.createBendpoints = function () {\n  var edges = [];\n  edges = edges.concat(this.graphManager.getAllEdges());\n  var visited = new Set();\n  var i;\n  for (i = 0; i < edges.length; i++) {\n    var edge = edges[i];\n\n    if (!visited.has(edge)) {\n      var source = edge.getSource();\n      var target = edge.getTarget();\n\n      if (source == target) {\n        edge.getBendpoints().push(new PointD());\n        edge.getBendpoints().push(new PointD());\n        this.createDummyNodesForBendpoints(edge);\n        visited.add(edge);\n      } else {\n        var edgeList = [];\n\n        edgeList = edgeList.concat(source.getEdgeListToNode(target));\n        edgeList = edgeList.concat(target.getEdgeListToNode(source));\n\n        if (!visited.has(edgeList[0])) {\n          if (edgeList.length > 1) {\n            var k;\n            for (k = 0; k < edgeList.length; k++) {\n              var multiEdge = edgeList[k];\n              multiEdge.getBendpoints().push(new PointD());\n              this.createDummyNodesForBendpoints(multiEdge);\n            }\n          }\n          edgeList.forEach(function (edge) {\n            visited.add(edge);\n          });\n        }\n      }\n    }\n\n    if (visited.size == edges.length) {\n      break;\n    }\n  }\n};\n\nCoSELayout.prototype.positionNodesRadially = function (forest) {\n  // We tile the trees to a grid row by row; first tree starts at (0,0)\n  var currentStartingPoint = new Point(0, 0);\n  var numberOfColumns = Math.ceil(Math.sqrt(forest.length));\n  var height = 0;\n  var currentY = 0;\n  var currentX = 0;\n  var point = new PointD(0, 0);\n\n  for (var i = 0; i < forest.length; i++) {\n    if (i % numberOfColumns == 0) {\n      // Start of a new row, make the x coordinate 0, increment the\n      // y coordinate with the max height of the previous row\n      currentX = 0;\n      currentY = height;\n\n      if (i != 0) {\n        currentY += CoSEConstants.DEFAULT_COMPONENT_SEPERATION;\n      }\n\n      height = 0;\n    }\n\n    var tree = forest[i];\n\n    // Find the center of the tree\n    var centerNode = Layout.findCenterOfTree(tree);\n\n    // Set the staring point of the next tree\n    currentStartingPoint.x = currentX;\n    currentStartingPoint.y = currentY;\n\n    // Do a radial layout starting with the center\n    point = CoSELayout.radialLayout(tree, centerNode, currentStartingPoint);\n\n    if (point.y > height) {\n      height = Math.floor(point.y);\n    }\n\n    currentX = Math.floor(point.x + CoSEConstants.DEFAULT_COMPONENT_SEPERATION);\n  }\n\n  this.transform(new PointD(LayoutConstants.WORLD_CENTER_X - point.x / 2, LayoutConstants.WORLD_CENTER_Y - point.y / 2));\n};\n\nCoSELayout.radialLayout = function (tree, centerNode, startingPoint) {\n  var radialSep = Math.max(this.maxDiagonalInTree(tree), CoSEConstants.DEFAULT_RADIAL_SEPARATION);\n  CoSELayout.branchRadialLayout(centerNode, null, 0, 359, 0, radialSep);\n  var bounds = LGraph.calculateBounds(tree);\n\n  var transform = new Transform();\n  transform.setDeviceOrgX(bounds.getMinX());\n  transform.setDeviceOrgY(bounds.getMinY());\n  transform.setWorldOrgX(startingPoint.x);\n  transform.setWorldOrgY(startingPoint.y);\n\n  for (var i = 0; i < tree.length; i++) {\n    var node = tree[i];\n    node.transform(transform);\n  }\n\n  var bottomRight = new PointD(bounds.getMaxX(), bounds.getMaxY());\n\n  return transform.inverseTransformPoint(bottomRight);\n};\n\nCoSELayout.branchRadialLayout = function (node, parentOfNode, startAngle, endAngle, distance, radialSeparation) {\n  // First, position this node by finding its angle.\n  var halfInterval = (endAngle - startAngle + 1) / 2;\n\n  if (halfInterval < 0) {\n    halfInterval += 180;\n  }\n\n  var nodeAngle = (halfInterval + startAngle) % 360;\n  var teta = nodeAngle * IGeometry.TWO_PI / 360;\n\n  // Make polar to java cordinate conversion.\n  var cos_teta = Math.cos(teta);\n  var x_ = distance * Math.cos(teta);\n  var y_ = distance * Math.sin(teta);\n\n  node.setCenter(x_, y_);\n\n  // Traverse all neighbors of this node and recursively call this\n  // function.\n  var neighborEdges = [];\n  neighborEdges = neighborEdges.concat(node.getEdges());\n  var childCount = neighborEdges.length;\n\n  if (parentOfNode != null) {\n    childCount--;\n  }\n\n  var branchCount = 0;\n\n  var incEdgesCount = neighborEdges.length;\n  var startIndex;\n\n  var edges = node.getEdgesBetween(parentOfNode);\n\n  // If there are multiple edges, prune them until there remains only one\n  // edge.\n  while (edges.length > 1) {\n    //neighborEdges.remove(edges.remove(0));\n    var temp = edges[0];\n    edges.splice(0, 1);\n    var index = neighborEdges.indexOf(temp);\n    if (index >= 0) {\n      neighborEdges.splice(index, 1);\n    }\n    incEdgesCount--;\n    childCount--;\n  }\n\n  if (parentOfNode != null) {\n    //assert edges.length == 1;\n    startIndex = (neighborEdges.indexOf(edges[0]) + 1) % incEdgesCount;\n  } else {\n    startIndex = 0;\n  }\n\n  var stepAngle = Math.abs(endAngle - startAngle) / childCount;\n\n  for (var i = startIndex; branchCount != childCount; i = ++i % incEdgesCount) {\n    var currentNeighbor = neighborEdges[i].getOtherEnd(node);\n\n    // Don't back traverse to root node in current tree.\n    if (currentNeighbor == parentOfNode) {\n      continue;\n    }\n\n    var childStartAngle = (startAngle + branchCount * stepAngle) % 360;\n    var childEndAngle = (childStartAngle + stepAngle) % 360;\n\n    CoSELayout.branchRadialLayout(currentNeighbor, node, childStartAngle, childEndAngle, distance + radialSeparation, radialSeparation);\n\n    branchCount++;\n  }\n};\n\nCoSELayout.maxDiagonalInTree = function (tree) {\n  var maxDiagonal = Integer.MIN_VALUE;\n\n  for (var i = 0; i < tree.length; i++) {\n    var node = tree[i];\n    var diagonal = node.getDiagonal();\n\n    if (diagonal > maxDiagonal) {\n      maxDiagonal = diagonal;\n    }\n  }\n\n  return maxDiagonal;\n};\n\nCoSELayout.prototype.calcRepulsionRange = function () {\n  // formula is 2 x (level + 1) x idealEdgeLength\n  return 2 * (this.level + 1) * this.idealEdgeLength;\n};\n\n// Tiling methods\n\n// Group zero degree members whose parents are not to be tiled, create dummy parents where needed and fill memberGroups by their dummp parent id's\nCoSELayout.prototype.groupZeroDegreeMembers = function () {\n  var self = this;\n  // array of [parent_id x oneDegreeNode_id]\n  var tempMemberGroups = {}; // A temporary map of parent node and its zero degree members\n  this.memberGroups = {}; // A map of dummy parent node and its zero degree members whose parents are not to be tiled\n  this.idToDummyNode = {}; // A map of id to dummy node \n\n  var zeroDegree = []; // List of zero degree nodes whose parents are not to be tiled\n  var allNodes = this.graphManager.getAllNodes();\n\n  // Fill zero degree list\n  for (var i = 0; i < allNodes.length; i++) {\n    var node = allNodes[i];\n    var parent = node.getParent();\n    // If a node has zero degree and its parent is not to be tiled if exists add that node to zeroDegres list\n    if (this.getNodeDegreeWithChildren(node) === 0 && (parent.id == undefined || !this.getToBeTiled(parent))) {\n      zeroDegree.push(node);\n    }\n  }\n\n  // Create a map of parent node and its zero degree members\n  for (var i = 0; i < zeroDegree.length; i++) {\n    var node = zeroDegree[i]; // Zero degree node itself\n    var p_id = node.getParent().id; // Parent id\n\n    if (typeof tempMemberGroups[p_id] === \"undefined\") tempMemberGroups[p_id] = [];\n\n    tempMemberGroups[p_id] = tempMemberGroups[p_id].concat(node); // Push node to the list belongs to its parent in tempMemberGroups\n  }\n\n  // If there are at least two nodes at a level, create a dummy compound for them\n  Object.keys(tempMemberGroups).forEach(function (p_id) {\n    if (tempMemberGroups[p_id].length > 1) {\n      var dummyCompoundId = \"DummyCompound_\" + p_id; // The id of dummy compound which will be created soon\n      self.memberGroups[dummyCompoundId] = tempMemberGroups[p_id]; // Add dummy compound to memberGroups\n\n      var parent = tempMemberGroups[p_id][0].getParent(); // The parent of zero degree nodes will be the parent of new dummy compound\n\n      // Create a dummy compound with calculated id\n      var dummyCompound = new CoSENode(self.graphManager);\n      dummyCompound.id = dummyCompoundId;\n      dummyCompound.paddingLeft = parent.paddingLeft || 0;\n      dummyCompound.paddingRight = parent.paddingRight || 0;\n      dummyCompound.paddingBottom = parent.paddingBottom || 0;\n      dummyCompound.paddingTop = parent.paddingTop || 0;\n\n      self.idToDummyNode[dummyCompoundId] = dummyCompound;\n\n      var dummyParentGraph = self.getGraphManager().add(self.newGraph(), dummyCompound);\n      var parentGraph = parent.getChild();\n\n      // Add dummy compound to parent the graph\n      parentGraph.add(dummyCompound);\n\n      // For each zero degree node in this level remove it from its parent graph and add it to the graph of dummy parent\n      for (var i = 0; i < tempMemberGroups[p_id].length; i++) {\n        var node = tempMemberGroups[p_id][i];\n\n        parentGraph.remove(node);\n        dummyParentGraph.add(node);\n      }\n    }\n  });\n};\n\nCoSELayout.prototype.clearCompounds = function () {\n  var childGraphMap = {};\n  var idToNode = {};\n\n  // Get compound ordering by finding the inner one first\n  this.performDFSOnCompounds();\n\n  for (var i = 0; i < this.compoundOrder.length; i++) {\n\n    idToNode[this.compoundOrder[i].id] = this.compoundOrder[i];\n    childGraphMap[this.compoundOrder[i].id] = [].concat(this.compoundOrder[i].getChild().getNodes());\n\n    // Remove children of compounds\n    this.graphManager.remove(this.compoundOrder[i].getChild());\n    this.compoundOrder[i].child = null;\n  }\n\n  this.graphManager.resetAllNodes();\n\n  // Tile the removed children\n  this.tileCompoundMembers(childGraphMap, idToNode);\n};\n\nCoSELayout.prototype.clearZeroDegreeMembers = function () {\n  var self = this;\n  var tiledZeroDegreePack = this.tiledZeroDegreePack = [];\n\n  Object.keys(this.memberGroups).forEach(function (id) {\n    var compoundNode = self.idToDummyNode[id]; // Get the dummy compound\n\n    tiledZeroDegreePack[id] = self.tileNodes(self.memberGroups[id], compoundNode.paddingLeft + compoundNode.paddingRight);\n\n    // Set the width and height of the dummy compound as calculated\n    compoundNode.rect.width = tiledZeroDegreePack[id].width;\n    compoundNode.rect.height = tiledZeroDegreePack[id].height;\n  });\n};\n\nCoSELayout.prototype.repopulateCompounds = function () {\n  for (var i = this.compoundOrder.length - 1; i >= 0; i--) {\n    var lCompoundNode = this.compoundOrder[i];\n    var id = lCompoundNode.id;\n    var horizontalMargin = lCompoundNode.paddingLeft;\n    var verticalMargin = lCompoundNode.paddingTop;\n\n    this.adjustLocations(this.tiledMemberPack[id], lCompoundNode.rect.x, lCompoundNode.rect.y, horizontalMargin, verticalMargin);\n  }\n};\n\nCoSELayout.prototype.repopulateZeroDegreeMembers = function () {\n  var self = this;\n  var tiledPack = this.tiledZeroDegreePack;\n\n  Object.keys(tiledPack).forEach(function (id) {\n    var compoundNode = self.idToDummyNode[id]; // Get the dummy compound by its id\n    var horizontalMargin = compoundNode.paddingLeft;\n    var verticalMargin = compoundNode.paddingTop;\n\n    // Adjust the positions of nodes wrt its compound\n    self.adjustLocations(tiledPack[id], compoundNode.rect.x, compoundNode.rect.y, horizontalMargin, verticalMargin);\n  });\n};\n\nCoSELayout.prototype.getToBeTiled = function (node) {\n  var id = node.id;\n  //firstly check the previous results\n  if (this.toBeTiled[id] != null) {\n    return this.toBeTiled[id];\n  }\n\n  //only compound nodes are to be tiled\n  var childGraph = node.getChild();\n  if (childGraph == null) {\n    this.toBeTiled[id] = false;\n    return false;\n  }\n\n  var children = childGraph.getNodes(); // Get the children nodes\n\n  //a compound node is not to be tiled if all of its compound children are not to be tiled\n  for (var i = 0; i < children.length; i++) {\n    var theChild = children[i];\n\n    if (this.getNodeDegree(theChild) > 0) {\n      this.toBeTiled[id] = false;\n      return false;\n    }\n\n    //pass the children not having the compound structure\n    if (theChild.getChild() == null) {\n      this.toBeTiled[theChild.id] = false;\n      continue;\n    }\n\n    if (!this.getToBeTiled(theChild)) {\n      this.toBeTiled[id] = false;\n      return false;\n    }\n  }\n  this.toBeTiled[id] = true;\n  return true;\n};\n\n// Get degree of a node depending of its edges and independent of its children\nCoSELayout.prototype.getNodeDegree = function (node) {\n  var id = node.id;\n  var edges = node.getEdges();\n  var degree = 0;\n\n  // For the edges connected\n  for (var i = 0; i < edges.length; i++) {\n    var edge = edges[i];\n    if (edge.getSource().id !== edge.getTarget().id) {\n      degree = degree + 1;\n    }\n  }\n  return degree;\n};\n\n// Get degree of a node with its children\nCoSELayout.prototype.getNodeDegreeWithChildren = function (node) {\n  var degree = this.getNodeDegree(node);\n  if (node.getChild() == null) {\n    return degree;\n  }\n  var children = node.getChild().getNodes();\n  for (var i = 0; i < children.length; i++) {\n    var child = children[i];\n    degree += this.getNodeDegreeWithChildren(child);\n  }\n  return degree;\n};\n\nCoSELayout.prototype.performDFSOnCompounds = function () {\n  this.compoundOrder = [];\n  this.fillCompexOrderByDFS(this.graphManager.getRoot().getNodes());\n};\n\nCoSELayout.prototype.fillCompexOrderByDFS = function (children) {\n  for (var i = 0; i < children.length; i++) {\n    var child = children[i];\n    if (child.getChild() != null) {\n      this.fillCompexOrderByDFS(child.getChild().getNodes());\n    }\n    if (this.getToBeTiled(child)) {\n      this.compoundOrder.push(child);\n    }\n  }\n};\n\n/**\n* This method places each zero degree member wrt given (x,y) coordinates (top left).\n*/\nCoSELayout.prototype.adjustLocations = function (organization, x, y, compoundHorizontalMargin, compoundVerticalMargin) {\n  x += compoundHorizontalMargin;\n  y += compoundVerticalMargin;\n\n  var left = x;\n\n  for (var i = 0; i < organization.rows.length; i++) {\n    var row = organization.rows[i];\n    x = left;\n    var maxHeight = 0;\n\n    for (var j = 0; j < row.length; j++) {\n      var lnode = row[j];\n\n      lnode.rect.x = x; // + lnode.rect.width / 2;\n      lnode.rect.y = y; // + lnode.rect.height / 2;\n\n      x += lnode.rect.width + organization.horizontalPadding;\n\n      if (lnode.rect.height > maxHeight) maxHeight = lnode.rect.height;\n    }\n\n    y += maxHeight + organization.verticalPadding;\n  }\n};\n\nCoSELayout.prototype.tileCompoundMembers = function (childGraphMap, idToNode) {\n  var self = this;\n  this.tiledMemberPack = [];\n\n  Object.keys(childGraphMap).forEach(function (id) {\n    // Get the compound node\n    var compoundNode = idToNode[id];\n\n    self.tiledMemberPack[id] = self.tileNodes(childGraphMap[id], compoundNode.paddingLeft + compoundNode.paddingRight);\n\n    compoundNode.rect.width = self.tiledMemberPack[id].width;\n    compoundNode.rect.height = self.tiledMemberPack[id].height;\n  });\n};\n\nCoSELayout.prototype.tileNodes = function (nodes, minWidth) {\n  var verticalPadding = CoSEConstants.TILING_PADDING_VERTICAL;\n  var horizontalPadding = CoSEConstants.TILING_PADDING_HORIZONTAL;\n  var organization = {\n    rows: [],\n    rowWidth: [],\n    rowHeight: [],\n    width: 0,\n    height: minWidth, // assume minHeight equals to minWidth\n    verticalPadding: verticalPadding,\n    horizontalPadding: horizontalPadding\n  };\n\n  // Sort the nodes in ascending order of their areas\n  nodes.sort(function (n1, n2) {\n    if (n1.rect.width * n1.rect.height > n2.rect.width * n2.rect.height) return -1;\n    if (n1.rect.width * n1.rect.height < n2.rect.width * n2.rect.height) return 1;\n    return 0;\n  });\n\n  // Create the organization -> tile members\n  for (var i = 0; i < nodes.length; i++) {\n    var lNode = nodes[i];\n\n    if (organization.rows.length == 0) {\n      this.insertNodeToRow(organization, lNode, 0, minWidth);\n    } else if (this.canAddHorizontal(organization, lNode.rect.width, lNode.rect.height)) {\n      this.insertNodeToRow(organization, lNode, this.getShortestRowIndex(organization), minWidth);\n    } else {\n      this.insertNodeToRow(organization, lNode, organization.rows.length, minWidth);\n    }\n\n    this.shiftToLastRow(organization);\n  }\n\n  return organization;\n};\n\nCoSELayout.prototype.insertNodeToRow = function (organization, node, rowIndex, minWidth) {\n  var minCompoundSize = minWidth;\n\n  // Add new row if needed\n  if (rowIndex == organization.rows.length) {\n    var secondDimension = [];\n\n    organization.rows.push(secondDimension);\n    organization.rowWidth.push(minCompoundSize);\n    organization.rowHeight.push(0);\n  }\n\n  // Update row width\n  var w = organization.rowWidth[rowIndex] + node.rect.width;\n\n  if (organization.rows[rowIndex].length > 0) {\n    w += organization.horizontalPadding;\n  }\n\n  organization.rowWidth[rowIndex] = w;\n  // Update compound width\n  if (organization.width < w) {\n    organization.width = w;\n  }\n\n  // Update height\n  var h = node.rect.height;\n  if (rowIndex > 0) h += organization.verticalPadding;\n\n  var extraHeight = 0;\n  if (h > organization.rowHeight[rowIndex]) {\n    extraHeight = organization.rowHeight[rowIndex];\n    organization.rowHeight[rowIndex] = h;\n    extraHeight = organization.rowHeight[rowIndex] - extraHeight;\n  }\n\n  organization.height += extraHeight;\n\n  // Insert node\n  organization.rows[rowIndex].push(node);\n};\n\n//Scans the rows of an organization and returns the one with the min width\nCoSELayout.prototype.getShortestRowIndex = function (organization) {\n  var r = -1;\n  var min = Number.MAX_VALUE;\n\n  for (var i = 0; i < organization.rows.length; i++) {\n    if (organization.rowWidth[i] < min) {\n      r = i;\n      min = organization.rowWidth[i];\n    }\n  }\n  return r;\n};\n\n//Scans the rows of an organization and returns the one with the max width\nCoSELayout.prototype.getLongestRowIndex = function (organization) {\n  var r = -1;\n  var max = Number.MIN_VALUE;\n\n  for (var i = 0; i < organization.rows.length; i++) {\n\n    if (organization.rowWidth[i] > max) {\n      r = i;\n      max = organization.rowWidth[i];\n    }\n  }\n\n  return r;\n};\n\n/**\n* This method checks whether adding extra width to the organization violates\n* the aspect ratio(1) or not.\n*/\nCoSELayout.prototype.canAddHorizontal = function (organization, extraWidth, extraHeight) {\n\n  var sri = this.getShortestRowIndex(organization);\n\n  if (sri < 0) {\n    return true;\n  }\n\n  var min = organization.rowWidth[sri];\n\n  if (min + organization.horizontalPadding + extraWidth <= organization.width) return true;\n\n  var hDiff = 0;\n\n  // Adding to an existing row\n  if (organization.rowHeight[sri] < extraHeight) {\n    if (sri > 0) hDiff = extraHeight + organization.verticalPadding - organization.rowHeight[sri];\n  }\n\n  var add_to_row_ratio;\n  if (organization.width - min >= extraWidth + organization.horizontalPadding) {\n    add_to_row_ratio = (organization.height + hDiff) / (min + extraWidth + organization.horizontalPadding);\n  } else {\n    add_to_row_ratio = (organization.height + hDiff) / organization.width;\n  }\n\n  // Adding a new row for this node\n  hDiff = extraHeight + organization.verticalPadding;\n  var add_new_row_ratio;\n  if (organization.width < extraWidth) {\n    add_new_row_ratio = (organization.height + hDiff) / extraWidth;\n  } else {\n    add_new_row_ratio = (organization.height + hDiff) / organization.width;\n  }\n\n  if (add_new_row_ratio < 1) add_new_row_ratio = 1 / add_new_row_ratio;\n\n  if (add_to_row_ratio < 1) add_to_row_ratio = 1 / add_to_row_ratio;\n\n  return add_to_row_ratio < add_new_row_ratio;\n};\n\n//If moving the last node from the longest row and adding it to the last\n//row makes the bounding box smaller, do it.\nCoSELayout.prototype.shiftToLastRow = function (organization) {\n  var longest = this.getLongestRowIndex(organization);\n  var last = organization.rowWidth.length - 1;\n  var row = organization.rows[longest];\n  var node = row[row.length - 1];\n\n  var diff = node.width + organization.horizontalPadding;\n\n  // Check if there is enough space on the last row\n  if (organization.width - organization.rowWidth[last] > diff && longest != last) {\n    // Remove the last element of the longest row\n    row.splice(-1, 1);\n\n    // Push it to the last row\n    organization.rows[last].push(node);\n\n    organization.rowWidth[longest] = organization.rowWidth[longest] - diff;\n    organization.rowWidth[last] = organization.rowWidth[last] + diff;\n    organization.width = organization.rowWidth[instance.getLongestRowIndex(organization)];\n\n    // Update heights of the organization\n    var maxHeight = Number.MIN_VALUE;\n    for (var i = 0; i < row.length; i++) {\n      if (row[i].height > maxHeight) maxHeight = row[i].height;\n    }\n    if (longest > 0) maxHeight += organization.verticalPadding;\n\n    var prevTotal = organization.rowHeight[longest] + organization.rowHeight[last];\n\n    organization.rowHeight[longest] = maxHeight;\n    if (organization.rowHeight[last] < node.height + organization.verticalPadding) organization.rowHeight[last] = node.height + organization.verticalPadding;\n\n    var finalTotal = organization.rowHeight[longest] + organization.rowHeight[last];\n    organization.height += finalTotal - prevTotal;\n\n    this.shiftToLastRow(organization);\n  }\n};\n\nCoSELayout.prototype.tilingPreLayout = function () {\n  if (CoSEConstants.TILE) {\n    // Find zero degree nodes and create a compound for each level\n    this.groupZeroDegreeMembers();\n    // Tile and clear children of each compound\n    this.clearCompounds();\n    // Separately tile and clear zero degree nodes for each level\n    this.clearZeroDegreeMembers();\n  }\n};\n\nCoSELayout.prototype.tilingPostLayout = function () {\n  if (CoSEConstants.TILE) {\n    this.repopulateZeroDegreeMembers();\n    this.repopulateCompounds();\n  }\n};\n\n// -----------------------------------------------------------------------------\n// Section: Tree Reduction methods\n// -----------------------------------------------------------------------------\n// Reduce trees \nCoSELayout.prototype.reduceTrees = function () {\n  var prunedNodesAll = [];\n  var containsLeaf = true;\n  var node;\n\n  while (containsLeaf) {\n    var allNodes = this.graphManager.getAllNodes();\n    var prunedNodesInStepTemp = [];\n    containsLeaf = false;\n\n    for (var i = 0; i < allNodes.length; i++) {\n      node = allNodes[i];\n      if (node.getEdges().length == 1 && !node.getEdges()[0].isInterGraph && node.getChild() == null) {\n        prunedNodesInStepTemp.push([node, node.getEdges()[0], node.getOwner()]);\n        containsLeaf = true;\n      }\n    }\n    if (containsLeaf == true) {\n      var prunedNodesInStep = [];\n      for (var j = 0; j < prunedNodesInStepTemp.length; j++) {\n        if (prunedNodesInStepTemp[j][0].getEdges().length == 1) {\n          prunedNodesInStep.push(prunedNodesInStepTemp[j]);\n          prunedNodesInStepTemp[j][0].getOwner().remove(prunedNodesInStepTemp[j][0]);\n        }\n      }\n      prunedNodesAll.push(prunedNodesInStep);\n      this.graphManager.resetAllNodes();\n      this.graphManager.resetAllEdges();\n    }\n  }\n  this.prunedNodesAll = prunedNodesAll;\n};\n\n// Grow tree one step \nCoSELayout.prototype.growTree = function (prunedNodesAll) {\n  var lengthOfPrunedNodesInStep = prunedNodesAll.length;\n  var prunedNodesInStep = prunedNodesAll[lengthOfPrunedNodesInStep - 1];\n\n  var nodeData;\n  for (var i = 0; i < prunedNodesInStep.length; i++) {\n    nodeData = prunedNodesInStep[i];\n\n    this.findPlaceforPrunedNode(nodeData);\n\n    nodeData[2].add(nodeData[0]);\n    nodeData[2].add(nodeData[1], nodeData[1].source, nodeData[1].target);\n  }\n\n  prunedNodesAll.splice(prunedNodesAll.length - 1, 1);\n  this.graphManager.resetAllNodes();\n  this.graphManager.resetAllEdges();\n};\n\n// Find an appropriate position to replace pruned node, this method can be improved\nCoSELayout.prototype.findPlaceforPrunedNode = function (nodeData) {\n\n  var gridForPrunedNode;\n  var nodeToConnect;\n  var prunedNode = nodeData[0];\n  if (prunedNode == nodeData[1].source) {\n    nodeToConnect = nodeData[1].target;\n  } else {\n    nodeToConnect = nodeData[1].source;\n  }\n  var startGridX = nodeToConnect.startX;\n  var finishGridX = nodeToConnect.finishX;\n  var startGridY = nodeToConnect.startY;\n  var finishGridY = nodeToConnect.finishY;\n\n  var upNodeCount = 0;\n  var downNodeCount = 0;\n  var rightNodeCount = 0;\n  var leftNodeCount = 0;\n  var controlRegions = [upNodeCount, rightNodeCount, downNodeCount, leftNodeCount];\n\n  if (startGridY > 0) {\n    for (var i = startGridX; i <= finishGridX; i++) {\n      controlRegions[0] += this.grid[i][startGridY - 1].length + this.grid[i][startGridY].length - 1;\n    }\n  }\n  if (finishGridX < this.grid.length - 1) {\n    for (var i = startGridY; i <= finishGridY; i++) {\n      controlRegions[1] += this.grid[finishGridX + 1][i].length + this.grid[finishGridX][i].length - 1;\n    }\n  }\n  if (finishGridY < this.grid[0].length - 1) {\n    for (var i = startGridX; i <= finishGridX; i++) {\n      controlRegions[2] += this.grid[i][finishGridY + 1].length + this.grid[i][finishGridY].length - 1;\n    }\n  }\n  if (startGridX > 0) {\n    for (var i = startGridY; i <= finishGridY; i++) {\n      controlRegions[3] += this.grid[startGridX - 1][i].length + this.grid[startGridX][i].length - 1;\n    }\n  }\n  var min = Integer.MAX_VALUE;\n  var minCount;\n  var minIndex;\n  for (var j = 0; j < controlRegions.length; j++) {\n    if (controlRegions[j] < min) {\n      min = controlRegions[j];\n      minCount = 1;\n      minIndex = j;\n    } else if (controlRegions[j] == min) {\n      minCount++;\n    }\n  }\n\n  if (minCount == 3 && min == 0) {\n    if (controlRegions[0] == 0 && controlRegions[1] == 0 && controlRegions[2] == 0) {\n      gridForPrunedNode = 1;\n    } else if (controlRegions[0] == 0 && controlRegions[1] == 0 && controlRegions[3] == 0) {\n      gridForPrunedNode = 0;\n    } else if (controlRegions[0] == 0 && controlRegions[2] == 0 && controlRegions[3] == 0) {\n      gridForPrunedNode = 3;\n    } else if (controlRegions[1] == 0 && controlRegions[2] == 0 && controlRegions[3] == 0) {\n      gridForPrunedNode = 2;\n    }\n  } else if (minCount == 2 && min == 0) {\n    var random = Math.floor(Math.random() * 2);\n    if (controlRegions[0] == 0 && controlRegions[1] == 0) {\n      ;\n      if (random == 0) {\n        gridForPrunedNode = 0;\n      } else {\n        gridForPrunedNode = 1;\n      }\n    } else if (controlRegions[0] == 0 && controlRegions[2] == 0) {\n      if (random == 0) {\n        gridForPrunedNode = 0;\n      } else {\n        gridForPrunedNode = 2;\n      }\n    } else if (controlRegions[0] == 0 && controlRegions[3] == 0) {\n      if (random == 0) {\n        gridForPrunedNode = 0;\n      } else {\n        gridForPrunedNode = 3;\n      }\n    } else if (controlRegions[1] == 0 && controlRegions[2] == 0) {\n      if (random == 0) {\n        gridForPrunedNode = 1;\n      } else {\n        gridForPrunedNode = 2;\n      }\n    } else if (controlRegions[1] == 0 && controlRegions[3] == 0) {\n      if (random == 0) {\n        gridForPrunedNode = 1;\n      } else {\n        gridForPrunedNode = 3;\n      }\n    } else {\n      if (random == 0) {\n        gridForPrunedNode = 2;\n      } else {\n        gridForPrunedNode = 3;\n      }\n    }\n  } else if (minCount == 4 && min == 0) {\n    var random = Math.floor(Math.random() * 4);\n    gridForPrunedNode = random;\n  } else {\n    gridForPrunedNode = minIndex;\n  }\n\n  if (gridForPrunedNode == 0) {\n    prunedNode.setCenter(nodeToConnect.getCenterX(), nodeToConnect.getCenterY() - nodeToConnect.getHeight() / 2 - FDLayoutConstants.DEFAULT_EDGE_LENGTH - prunedNode.getHeight() / 2);\n  } else if (gridForPrunedNode == 1) {\n    prunedNode.setCenter(nodeToConnect.getCenterX() + nodeToConnect.getWidth() / 2 + FDLayoutConstants.DEFAULT_EDGE_LENGTH + prunedNode.getWidth() / 2, nodeToConnect.getCenterY());\n  } else if (gridForPrunedNode == 2) {\n    prunedNode.setCenter(nodeToConnect.getCenterX(), nodeToConnect.getCenterY() + nodeToConnect.getHeight() / 2 + FDLayoutConstants.DEFAULT_EDGE_LENGTH + prunedNode.getHeight() / 2);\n  } else {\n    prunedNode.setCenter(nodeToConnect.getCenterX() - nodeToConnect.getWidth() / 2 - FDLayoutConstants.DEFAULT_EDGE_LENGTH - prunedNode.getWidth() / 2, nodeToConnect.getCenterY());\n  }\n};\n\nmodule.exports = CoSELayout;\n\n/***/ }),\n/* 7 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar coseBase = {};\n\ncoseBase.layoutBase = __webpack_require__(0);\ncoseBase.CoSEConstants = __webpack_require__(1);\ncoseBase.CoSEEdge = __webpack_require__(2);\ncoseBase.CoSEGraph = __webpack_require__(3);\ncoseBase.CoSEGraphManager = __webpack_require__(4);\ncoseBase.CoSELayout = __webpack_require__(6);\ncoseBase.CoSENode = __webpack_require__(5);\n\nmodule.exports = coseBase;\n\n/***/ })\n/******/ ]);\n});"],"names":["webpackUniversalModuleDefinition","root","factory","exports","module","require","define","amd","__WEBPACK_EXTERNAL_MODULE_0__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","value","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","getDefault","getModuleExports","object","property","prototype","hasOwnProperty","p","s","FDLayoutConstants","CoSEConstants","prop","DEFAULT_USE_MULTI_LEVEL_SCALING","DEFAULT_RADIAL_SEPARATION","DEFAULT_EDGE_LENGTH","DEFAULT_COMPONENT_SEPERATION","TILE","TILING_PADDING_VERTICAL","TILING_PADDING_HORIZONTAL","TREE_REDUCTION_ON_INCREMENTAL","FDLayoutEdge","CoSEEdge","source","target","vEdge","create","LGraph","CoSEGraph","parent","graphMgr","vGraph","LGraphManager","CoSEGraphManager","layout","FDLayoutNode","IMath","CoSENode","gm","loc","size","vNode","move","graphManager","getLayout","displacementX","coolingFactor","springForceX","repulsionForceX","gravitationForceX","noOfChildren","displacementY","springForceY","repulsionForceY","gravitationForceY","Math","abs","maxNodeDisplacement","sign","child","moveBy","getNodes","length","propogateDisplacementToChildren","totalDisplacement","dX","dY","nodes","getChild","node","setPred1","pred1","getPred1","getPred2","pred2","setNext","next","getNext","setProcessed","processed","isProcessed","FDLayout","LayoutConstants","Point","PointD","Layout","Integer","IGeometry","Transform","CoSELayout","toBeTiled","newGraphManager","newGraph","newNode","newEdge","initParameters","arguments","isSubLayout","idealEdgeLength","useSmartIdealEdgeLengthCalculation","DEFAULT_USE_SMART_IDEAL_EDGE_LENGTH_CALCULATION","springConstant","DEFAULT_SPRING_STRENGTH","repulsionConstant","DEFAULT_REPULSION_STRENGTH","gravityConstant","DEFAULT_GRAVITY_STRENGTH","compoundGravityConstant","DEFAULT_COMPOUND_GRAVITY_STRENGTH","gravityRangeFactor","DEFAULT_GRAVITY_RANGE_FACTOR","compoundGravityRangeFactor","DEFAULT_COMPOUND_GRAVITY_RANGE_FACTOR","prunedNodesAll","growTreeIterations","afterGrowthIterations","isTreeGrowing","isGrowthFinished","coolingCycle","maxCoolingCycle","maxIterations","CONVERGENCE_CHECK_PERIOD","finalTemperature","coolingAdjuster","createBendsAsNeeded","DEFAULT_CREATE_BENDS_AS_NEEDED","createBendpoints","resetAllEdges","level","classicLayout","nodesWithGravity","calculateNodesToApplyGravitationTo","setAllNodesToApplyGravitation","calcNoOfChildrenForAllNodes","calcLowestCommonAncestors","calcInclusionTreeDepths","getRoot","calcEstimatedSize","calcIdealEdgeLengths","incremental","forest","getFlatForest","positionNodesRadially","reduceTrees","resetAllNodesToApplyGravitation","allNodes","Set","getAllNodes","intersection","filter","x","has","positionNodesRandomly","initSpringEmbedder","runSpringEmbedder","tick","totalIterations","isConverged","layoutQuality","max","initialCoolingFactor","pow","log","animationPeriod","ceil","initialAnimationPeriod","sqrt","updateBounds","updateGrid","growTree","DEFAULT_COOLING_FACTOR_INCREMENTAL","gridUpdateAllowed","forceToNodeSurroundingUpdate","calcSpringForces","calcRepulsionForces","calcGravitationalForces","moveNodes","animate","getPositionsData","pData","rect","id","getCenterX","y","getCenterY","w","width","h","height","layoutEnded","ANIMATE","emit","nodeList","graph","graphs","getGraphs","updateConnected","isConnected","concat","edges","getAllEdges","visited","edge","getSource","getTarget","getBendpoints","push","createDummyNodesForBendpoints","add","edgeList","getEdgeListToNode","k","multiEdge","forEach","currentStartingPoint","numberOfColumns","currentY","currentX","point","tree","centerNode","findCenterOfTree","radialLayout","floor","transform","WORLD_CENTER_X","WORLD_CENTER_Y","startingPoint","radialSep","maxDiagonalInTree","branchRadialLayout","bounds","calculateBounds","setDeviceOrgX","getMinX","setDeviceOrgY","getMinY","setWorldOrgX","setWorldOrgY","bottomRight","getMaxX","getMaxY","inverseTransformPoint","parentOfNode","startAngle","endAngle","distance","radialSeparation","halfInterval","nodeAngle","teta","TWO_PI","cos_teta","cos","x_","y_","sin","setCenter","neighborEdges","getEdges","childCount","branchCount","incEdgesCount","startIndex","getEdgesBetween","temp","splice","index","indexOf","stepAngle","currentNeighbor","getOtherEnd","childStartAngle","childEndAngle","maxDiagonal","MIN_VALUE","diagonal","getDiagonal","calcRepulsionRange","groupZeroDegreeMembers","self","tempMemberGroups","memberGroups","idToDummyNode","zeroDegree","getParent","getNodeDegreeWithChildren","undefined","getToBeTiled","p_id","keys","dummyCompoundId","dummyCompound","paddingLeft","paddingRight","paddingBottom","paddingTop","dummyParentGraph","getGraphManager","parentGraph","remove","clearCompounds","childGraphMap","idToNode","performDFSOnCompounds","compoundOrder","resetAllNodes","tileCompoundMembers","clearZeroDegreeMembers","tiledZeroDegreePack","compoundNode","tileNodes","repopulateCompounds","lCompoundNode","horizontalMargin","verticalMargin","adjustLocations","tiledMemberPack","repopulateZeroDegreeMembers","tiledPack","childGraph","children","theChild","getNodeDegree","degree","fillCompexOrderByDFS","organization","compoundHorizontalMargin","compoundVerticalMargin","left","rows","row","maxHeight","j","lnode","horizontalPadding","verticalPadding","minWidth","rowWidth","rowHeight","sort","n1","n2","lNode","insertNodeToRow","canAddHorizontal","getShortestRowIndex","shiftToLastRow","rowIndex","minCompoundSize","secondDimension","extraHeight","r","min","Number","MAX_VALUE","getLongestRowIndex","extraWidth","sri","hDiff","add_to_row_ratio","add_new_row_ratio","longest","last","diff","instance","prevTotal","finalTotal","tilingPreLayout","tilingPostLayout","containsLeaf","prunedNodesInStepTemp","isInterGraph","getOwner","prunedNodesInStep","lengthOfPrunedNodesInStep","nodeData","findPlaceforPrunedNode","gridForPrunedNode","nodeToConnect","prunedNode","startGridX","startX","finishGridX","finishX","startGridY","startY","finishGridY","finishY","upNodeCount","downNodeCount","rightNodeCount","leftNodeCount","controlRegions","grid","minCount","minIndex","random","getHeight","getWidth","coseBase","layoutBase"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/cose-base/cose-base.js\n");
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |