diff --git a/cytoscape-euler.js b/cytoscape-euler.js deleted file mode 100644 index 13c2271..0000000 --- a/cytoscape-euler.js +++ /dev/null @@ -1,1429 +0,0 @@ -(function webpackUniversalModuleDefinition(root, factory) { - if(typeof exports === 'object' && typeof module === 'object') - module.exports = factory(); - else if(typeof define === 'function' && define.amd) - define([], factory); - else if(typeof exports === 'object') - exports["cytoscapeEuler"] = factory(); - else - root["cytoscapeEuler"] = factory(); -})(this, function() { -return /******/ (function(modules) { // webpackBootstrap -/******/ // The module cache -/******/ var installedModules = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ -/******/ // Check if module is in cache -/******/ if(installedModules[moduleId]) { -/******/ return installedModules[moduleId].exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = installedModules[moduleId] = { -/******/ i: moduleId, -/******/ l: false, -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); -/******/ -/******/ // Flag the module as loaded -/******/ module.l = true; -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/******/ -/******/ // expose the modules object (__webpack_modules__) -/******/ __webpack_require__.m = modules; -/******/ -/******/ // expose the module cache -/******/ __webpack_require__.c = installedModules; -/******/ -/******/ // identity function for calling harmony imports with the correct context -/******/ __webpack_require__.i = function(value) { return value; }; -/******/ -/******/ // define getter function for harmony exports -/******/ __webpack_require__.d = function(exports, name, getter) { -/******/ if(!__webpack_require__.o(exports, name)) { -/******/ Object.defineProperty(exports, name, { -/******/ configurable: false, -/******/ enumerable: true, -/******/ get: getter -/******/ }); -/******/ } -/******/ }; -/******/ -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = function(module) { -/******/ var getter = module && module.__esModule ? -/******/ function getDefault() { return module['default']; } : -/******/ function getModuleExports() { return module; }; -/******/ __webpack_require__.d(getter, 'a', getter); -/******/ return getter; -/******/ }; -/******/ -/******/ // Object.prototype.hasOwnProperty.call -/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; -/******/ -/******/ // __webpack_public_path__ -/******/ __webpack_require__.p = ""; -/******/ -/******/ // Load entry module and return exports -/******/ return __webpack_require__(__webpack_require__.s = 11); -/******/ }) -/************************************************************************/ -/******/ ([ -/* 0 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -module.exports = Object.assign != null ? Object.assign.bind(Object) : function (tgt) { - for (var _len = arguments.length, srcs = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - srcs[_key - 1] = arguments[_key]; - } - - srcs.forEach(function (src) { - Object.keys(src).forEach(function (k) { - return tgt[k] = src[k]; - }); - }); - - return tgt; -}; - -/***/ }), -/* 1 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var assign = __webpack_require__(0); - -var defaults = Object.freeze({ - source: null, - target: null, - length: 80, - coeff: 0.0002, - weight: 1 -}); - -function makeSpring(spring) { - return assign({}, defaults, spring); -} - -function applySpring(spring) { - var body1 = spring.source, - body2 = spring.target, - length = spring.length < 0 ? defaults.length : spring.length, - dx = body2.pos.x - body1.pos.x, - dy = body2.pos.y - body1.pos.y, - r = Math.sqrt(dx * dx + dy * dy); - - if (r === 0) { - dx = (Math.random() - 0.5) / 50; - dy = (Math.random() - 0.5) / 50; - r = Math.sqrt(dx * dx + dy * dy); - } - - var d = r - length; - var coeff = (!spring.coeff || spring.coeff < 0 ? defaults.springCoeff : spring.coeff) * d / r * spring.weight; - - body1.force.x += coeff * dx; - body1.force.y += coeff * dy; - - body2.force.x -= coeff * dx; - body2.force.y -= coeff * dy; -} - -module.exports = { makeSpring: makeSpring, applySpring: applySpring }; - -/***/ }), -/* 2 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } - -/** -The implementation of the Euler layout algorithm -*/ - -var Layout = __webpack_require__(13); -var assign = __webpack_require__(0); -var defaults = __webpack_require__(4); - -var _require = __webpack_require__(10), - _tick = _require.tick; - -var _require2 = __webpack_require__(7), - makeQuadtree = _require2.makeQuadtree; - -var _require3 = __webpack_require__(3), - makeBody = _require3.makeBody; - -var _require4 = __webpack_require__(1), - makeSpring = _require4.makeSpring; - -var isFn = function isFn(fn) { - return typeof fn === 'function'; -}; -var isParent = function isParent(n) { - return n.isParent(); -}; -var notIsParent = function notIsParent(n) { - return !isParent(n); -}; -var isLocked = function isLocked(n) { - return n.locked(); -}; -var notIsLocked = function notIsLocked(n) { - return !isLocked(n); -}; -var isParentEdge = function isParentEdge(e) { - return isParent(e.source()) || isParent(e.target()); -}; -var notIsParentEdge = function notIsParentEdge(e) { - return !isParentEdge(e); -}; -var getBody = function getBody(n) { - return n.scratch('euler').body; -}; -var getNonParentDescendants = function getNonParentDescendants(n) { - return isParent(n) ? n.descendants().filter(notIsParent) : n; -}; - -var getScratch = function getScratch(el) { - var scratch = el.scratch('euler'); - - if (!scratch) { - scratch = {}; - - el.scratch('euler', scratch); - } - - return scratch; -}; - -var optFn = function optFn(opt, ele) { - if (isFn(opt)) { - return opt(ele); - } else { - return opt; - } -}; - -var Euler = function (_Layout) { - _inherits(Euler, _Layout); - - function Euler(options) { - _classCallCheck(this, Euler); - - return _possibleConstructorReturn(this, (Euler.__proto__ || Object.getPrototypeOf(Euler)).call(this, assign({}, defaults, options))); - } - - _createClass(Euler, [{ - key: 'prerun', - value: function prerun(state) { - var s = state; - - s.quadtree = makeQuadtree(); - - var bodies = s.bodies = []; - - // regular nodes - s.nodes.filter(function (n) { - return notIsParent(n); - }).forEach(function (n) { - var scratch = getScratch(n); - - var body = makeBody({ - pos: { x: scratch.x, y: scratch.y }, - mass: optFn(s.mass, n), - locked: scratch.locked - }); - - body._cyNode = n; - - scratch.body = body; - - body._scratch = scratch; - - bodies.push(body); - }); - - var springs = s.springs = []; - - // regular edge springs - s.edges.filter(notIsParentEdge).forEach(function (e) { - var spring = makeSpring({ - source: getBody(e.source()), - target: getBody(e.target()), - length: optFn(s.springLength, e), - coeff: optFn(s.springCoeff, e) - }); - - spring._cyEdge = e; - - var scratch = getScratch(e); - - spring._scratch = scratch; - - scratch.spring = spring; - - springs.push(spring); - }); - - // compound edge springs - s.edges.filter(isParentEdge).forEach(function (e) { - var sources = getNonParentDescendants(e.source()); - var targets = getNonParentDescendants(e.target()); - - // just add one spring for perf - sources = [sources[0]]; - targets = [targets[0]]; - - sources.forEach(function (src) { - targets.forEach(function (tgt) { - springs.push(makeSpring({ - source: getBody(src), - target: getBody(tgt), - length: optFn(s.springLength, e), - coeff: optFn(s.springCoeff, e) - })); - }); - }); - }); - } - }, { - key: 'tick', - value: function tick(state) { - var movement = _tick(state); - - var isDone = movement <= state.movementThreshold; - - return isDone; - } - }]); - - return Euler; -}(Layout); - -module.exports = Euler; - -/***/ }), -/* 3 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var defaults = Object.freeze({ - pos: { x: 0, y: 0 }, - prevPos: { x: 0, y: 0 }, - force: { x: 0, y: 0 }, - velocity: { x: 0, y: 0 }, - mass: 1 -}); - -var copyVec = function copyVec(v) { - return { x: v.x, y: v.y }; -}; -var getValue = function getValue(val, def) { - return val != null ? val : def; -}; -var getVec = function getVec(vec, def) { - return copyVec(getValue(vec, def)); -}; - -function makeBody(opts) { - var b = {}; - - b.pos = getVec(opts.pos, defaults.pos); - b.prevPos = getVec(opts.prevPos, b.pos); - b.force = getVec(opts.force, defaults.force); - b.velocity = getVec(opts.velocity, defaults.velocity); - b.mass = opts.mass != null ? opts.mass : defaults.mass; - b.locked = opts.locked; - - return b; -} - -module.exports = { makeBody: makeBody }; - -/***/ }), -/* 4 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var defaults = Object.freeze({ - // The ideal legth of a spring - // - This acts as a hint for the edge length - // - The edge length can be longer or shorter if the forces are set to extreme values - springLength: function springLength(edge) { - return 80; - }, - - // Hooke's law coefficient - // - The value ranges on [0, 1] - // - Lower values give looser springs - // - Higher values give tighter springs - springCoeff: function springCoeff(edge) { - return 0.0008; - }, - - // The mass of the node in the physics simulation - // - The mass affects the gravity node repulsion/attraction - mass: function mass(node) { - return 4; - }, - - // Coulomb's law coefficient - // - Makes the nodes repel each other for negative values - // - Makes the nodes attract each other for positive values - gravity: -1.2, - - // A force that pulls nodes towards the origin (0, 0) - // Higher values keep the components less spread out - pull: 0.001, - - // Theta coefficient from Barnes-Hut simulation - // - Value ranges on [0, 1] - // - Performance is better with smaller values - // - Very small values may not create enough force to give a good result - theta: 0.666, - - // Friction / drag coefficient to make the system stabilise over time - dragCoeff: 0.02, - - // When the total of the squared position deltas is less than this value, the simulation ends - movementThreshold: 1, - - // The amount of time passed per tick - // - Larger values result in faster runtimes but might spread things out too far - // - Smaller values produce more accurate results - timeStep: 20 -}); - -module.exports = defaults; - -/***/ }), -/* 5 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var defaultCoeff = 0.02; - -function applyDrag(body, manualDragCoeff) { - var dragCoeff = void 0; - - if (manualDragCoeff != null) { - dragCoeff = manualDragCoeff; - } else if (body.dragCoeff != null) { - dragCoeff = body.dragCoeff; - } else { - dragCoeff = defaultCoeff; - } - - body.force.x -= dragCoeff * body.velocity.x; - body.force.y -= dragCoeff * body.velocity.y; -} - -module.exports = { applyDrag: applyDrag }; - -/***/ }), -/* 6 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -// use euler method for force integration http://en.wikipedia.org/wiki/Euler_method -// return sum of squared position deltas -function integrate(bodies, timeStep) { - var dx = 0, - tx = 0, - dy = 0, - ty = 0, - i, - max = bodies.length; - - if (max === 0) { - return 0; - } - - for (i = 0; i < max; ++i) { - var body = bodies[i], - coeff = timeStep / body.mass; - - if (body.grabbed) { - continue; - } - - if (body.locked) { - body.velocity.x = 0; - body.velocity.y = 0; - } else { - body.velocity.x += coeff * body.force.x; - body.velocity.y += coeff * body.force.y; - } - - var vx = body.velocity.x, - vy = body.velocity.y, - v = Math.sqrt(vx * vx + vy * vy); - - if (v > 1) { - body.velocity.x = vx / v; - body.velocity.y = vy / v; - } - - dx = timeStep * body.velocity.x; - dy = timeStep * body.velocity.y; - - body.pos.x += dx; - body.pos.y += dy; - - tx += Math.abs(dx);ty += Math.abs(dy); - } - - return (tx * tx + ty * ty) / max; -} - -module.exports = { integrate: integrate }; - -/***/ }), -/* 7 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -// impl of barnes hut -// http://www.eecs.berkeley.edu/~demmel/cs267/lecture26/lecture26.html -// http://en.wikipedia.org/wiki/Barnes%E2%80%93Hut_simulation - -var Node = __webpack_require__(9); -var InsertStack = __webpack_require__(8); - -var resetVec = function resetVec(v) { - v.x = 0;v.y = 0; -}; - -var isSamePosition = function isSamePosition(p1, p2) { - var threshold = 1e-8; - var dx = Math.abs(p1.x - p2.x); - var dy = Math.abs(p1.y - p2.y); - - return dx < threshold && dy < threshold; -}; - -function makeQuadtree() { - var updateQueue = [], - insertStack = new InsertStack(), - nodesCache = [], - currentInCache = 0, - root = newNode(); - - function newNode() { - // To avoid pressure on GC we reuse nodes. - var node = nodesCache[currentInCache]; - if (node) { - node.quad0 = null; - node.quad1 = null; - node.quad2 = null; - node.quad3 = null; - node.body = null; - node.mass = node.massX = node.massY = 0; - node.left = node.right = node.top = node.bottom = 0; - } else { - node = new Node(); - nodesCache[currentInCache] = node; - } - - ++currentInCache; - return node; - } - - function update(sourceBody, gravity, theta, pull) { - var queue = updateQueue, - v = void 0, - dx = void 0, - dy = void 0, - r = void 0, - fx = 0, - fy = 0, - queueLength = 1, - shiftIdx = 0, - pushIdx = 1; - - queue[0] = root; - - resetVec(sourceBody.force); - - var px = -sourceBody.pos.x; - var py = -sourceBody.pos.y; - var pr = Math.sqrt(px * px + py * py); - var pv = sourceBody.mass * pull / pr; - - fx += pv * px; - fy += pv * py; - - while (queueLength) { - var node = queue[shiftIdx], - body = node.body; - - queueLength -= 1; - shiftIdx += 1; - var differentBody = body !== sourceBody; - if (body && differentBody) { - // If the current node is a leaf node (and it is not source body), - // calculate the force exerted by the current node on body, and add this - // amount to body's net force. - dx = body.pos.x - sourceBody.pos.x; - dy = body.pos.y - sourceBody.pos.y; - r = Math.sqrt(dx * dx + dy * dy); - - if (r === 0) { - // Poor man's protection against zero distance. - dx = (Math.random() - 0.5) / 50; - dy = (Math.random() - 0.5) / 50; - r = Math.sqrt(dx * dx + dy * dy); - } - - // This is standard gravition force calculation but we divide - // by r^3 to save two operations when normalizing force vector. - v = gravity * body.mass * sourceBody.mass / (r * r * r); - fx += v * dx; - fy += v * dy; - } else if (differentBody) { - // Otherwise, calculate the ratio s / r, where s is the width of the region - // represented by the internal node, and r is the distance between the body - // and the node's center-of-mass - dx = node.massX / node.mass - sourceBody.pos.x; - dy = node.massY / node.mass - sourceBody.pos.y; - r = Math.sqrt(dx * dx + dy * dy); - - if (r === 0) { - // Sorry about code duplucation. I don't want to create many functions - // right away. Just want to see performance first. - dx = (Math.random() - 0.5) / 50; - dy = (Math.random() - 0.5) / 50; - r = Math.sqrt(dx * dx + dy * dy); - } - // If s / r < θ, treat this internal node as a single body, and calculate the - // force it exerts on sourceBody, and add this amount to sourceBody's net force. - if ((node.right - node.left) / r < theta) { - // in the if statement above we consider node's width only - // because the region was squarified during tree creation. - // Thus there is no difference between using width or height. - v = gravity * node.mass * sourceBody.mass / (r * r * r); - fx += v * dx; - fy += v * dy; - } else { - // Otherwise, run the procedure recursively on each of the current node's children. - - // I intentionally unfolded this loop, to save several CPU cycles. - if (node.quad0) { - queue[pushIdx] = node.quad0; - queueLength += 1; - pushIdx += 1; - } - if (node.quad1) { - queue[pushIdx] = node.quad1; - queueLength += 1; - pushIdx += 1; - } - if (node.quad2) { - queue[pushIdx] = node.quad2; - queueLength += 1; - pushIdx += 1; - } - if (node.quad3) { - queue[pushIdx] = node.quad3; - queueLength += 1; - pushIdx += 1; - } - } - } - } - - sourceBody.force.x += fx; - sourceBody.force.y += fy; - } - - function insertBodies(bodies) { - if (bodies.length === 0) { - return; - } - - var x1 = Number.MAX_VALUE, - y1 = Number.MAX_VALUE, - x2 = Number.MIN_VALUE, - y2 = Number.MIN_VALUE, - i = void 0, - max = bodies.length; - - // To reduce quad tree depth we are looking for exact bounding box of all particles. - i = max; - while (i--) { - var x = bodies[i].pos.x; - var y = bodies[i].pos.y; - if (x < x1) { - x1 = x; - } - if (x > x2) { - x2 = x; - } - if (y < y1) { - y1 = y; - } - if (y > y2) { - y2 = y; - } - } - - // Squarify the bounds. - var dx = x2 - x1, - dy = y2 - y1; - if (dx > dy) { - y2 = y1 + dx; - } else { - x2 = x1 + dy; - } - - currentInCache = 0; - root = newNode(); - root.left = x1; - root.right = x2; - root.top = y1; - root.bottom = y2; - - i = max - 1; - if (i >= 0) { - root.body = bodies[i]; - } - while (i--) { - insert(bodies[i], root); - } - } - - function insert(newBody) { - insertStack.reset(); - insertStack.push(root, newBody); - - while (!insertStack.isEmpty()) { - var stackItem = insertStack.pop(), - node = stackItem.node, - body = stackItem.body; - - if (!node.body) { - // This is internal node. Update the total mass of the node and center-of-mass. - var x = body.pos.x; - var y = body.pos.y; - node.mass = node.mass + body.mass; - node.massX = node.massX + body.mass * x; - node.massY = node.massY + body.mass * y; - - // Recursively insert the body in the appropriate quadrant. - // But first find the appropriate quadrant. - var quadIdx = 0, - // Assume we are in the 0's quad. - left = node.left, - right = (node.right + left) / 2, - top = node.top, - bottom = (node.bottom + top) / 2; - - if (x > right) { - // somewhere in the eastern part. - quadIdx = quadIdx + 1; - left = right; - right = node.right; - } - if (y > bottom) { - // and in south. - quadIdx = quadIdx + 2; - top = bottom; - bottom = node.bottom; - } - - var child = getChild(node, quadIdx); - if (!child) { - // The node is internal but this quadrant is not taken. Add - // subnode to it. - child = newNode(); - child.left = left; - child.top = top; - child.right = right; - child.bottom = bottom; - child.body = body; - - setChild(node, quadIdx, child); - } else { - // continue searching in this quadrant. - insertStack.push(child, body); - } - } else { - // We are trying to add to the leaf node. - // We have to convert current leaf into internal node - // and continue adding two nodes. - var oldBody = node.body; - node.body = null; // internal nodes do not cary bodies - - if (isSamePosition(oldBody.pos, body.pos)) { - // Prevent infinite subdivision by bumping one node - // anywhere in this quadrant - var retriesCount = 3; - do { - var offset = Math.random(); - var dx = (node.right - node.left) * offset; - var dy = (node.bottom - node.top) * offset; - - oldBody.pos.x = node.left + dx; - oldBody.pos.y = node.top + dy; - retriesCount -= 1; - // Make sure we don't bump it out of the box. If we do, next iteration should fix it - } while (retriesCount > 0 && isSamePosition(oldBody.pos, body.pos)); - - if (retriesCount === 0 && isSamePosition(oldBody.pos, body.pos)) { - // This is very bad, we ran out of precision. - // if we do not return from the method we'll get into - // infinite loop here. So we sacrifice correctness of layout, and keep the app running - // Next layout iteration should get larger bounding box in the first step and fix this - return; - } - } - // Next iteration should subdivide node further. - insertStack.push(node, oldBody); - insertStack.push(node, body); - } - } - } - - return { - insertBodies: insertBodies, - updateBodyForce: update - }; -} - -function getChild(node, idx) { - if (idx === 0) return node.quad0; - if (idx === 1) return node.quad1; - if (idx === 2) return node.quad2; - if (idx === 3) return node.quad3; - return null; -} - -function setChild(node, idx, child) { - if (idx === 0) node.quad0 = child;else if (idx === 1) node.quad1 = child;else if (idx === 2) node.quad2 = child;else if (idx === 3) node.quad3 = child; -} - -module.exports = { makeQuadtree: makeQuadtree }; - -/***/ }), -/* 8 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -module.exports = InsertStack; - -/** - * Our implmentation of QuadTree is non-recursive to avoid GC hit - * This data structure represent stack of elements - * which we are trying to insert into quad tree. - */ -function InsertStack() { - this.stack = []; - this.popIdx = 0; -} - -InsertStack.prototype = { - isEmpty: function isEmpty() { - return this.popIdx === 0; - }, - push: function push(node, body) { - var item = this.stack[this.popIdx]; - if (!item) { - // we are trying to avoid memory pressue: create new element - // only when absolutely necessary - this.stack[this.popIdx] = new InsertStackElement(node, body); - } else { - item.node = node; - item.body = body; - } - ++this.popIdx; - }, - pop: function pop() { - if (this.popIdx > 0) { - return this.stack[--this.popIdx]; - } - }, - reset: function reset() { - this.popIdx = 0; - } -}; - -function InsertStackElement(node, body) { - this.node = node; // QuadTree node - this.body = body; // physical body which needs to be inserted to node -} - -/***/ }), -/* 9 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -/** - * Internal data structure to represent 2D QuadTree node - */ -module.exports = function Node() { - // body stored inside this node. In quad tree only leaf nodes (by construction) - // contain boides: - this.body = null; - - // Child nodes are stored in quads. Each quad is presented by number: - // 0 | 1 - // ----- - // 2 | 3 - this.quad0 = null; - this.quad1 = null; - this.quad2 = null; - this.quad3 = null; - - // Total mass of current node - this.mass = 0; - - // Center of mass coordinates - this.massX = 0; - this.massY = 0; - - // bounding box coordinates - this.left = 0; - this.top = 0; - this.bottom = 0; - this.right = 0; -}; - -/***/ }), -/* 10 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var _require = __webpack_require__(6), - integrate = _require.integrate; - -var _require2 = __webpack_require__(5), - applyDrag = _require2.applyDrag; - -var _require3 = __webpack_require__(1), - applySpring = _require3.applySpring; - -function tick(_ref) { - var bodies = _ref.bodies, - springs = _ref.springs, - quadtree = _ref.quadtree, - timeStep = _ref.timeStep, - gravity = _ref.gravity, - theta = _ref.theta, - dragCoeff = _ref.dragCoeff, - pull = _ref.pull; - - // update body from scratch in case of any changes - bodies.forEach(function (body) { - var p = body._scratch; - - if (!p) { - return; - } - - body.locked = p.locked; - body.grabbed = p.grabbed; - body.pos.x = p.x; - body.pos.y = p.y; - }); - - quadtree.insertBodies(bodies); - - for (var i = 0; i < bodies.length; i++) { - var body = bodies[i]; - - quadtree.updateBodyForce(body, gravity, theta, pull); - applyDrag(body, dragCoeff); - } - - for (var _i = 0; _i < springs.length; _i++) { - var spring = springs[_i]; - - applySpring(spring); - } - - var movement = integrate(bodies, timeStep); - - // update scratch positions from body positions - bodies.forEach(function (body) { - var p = body._scratch; - - if (!p) { - return; - } - - p.x = body.pos.x; - p.y = body.pos.y; - }); - - return movement; -} - -module.exports = { tick: tick }; - -/***/ }), -/* 11 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var Euler = __webpack_require__(2); - -// registers the extension on a cytoscape lib ref -var register = function register(cytoscape) { - if (!cytoscape) { - return; - } // can't register if cytoscape unspecified - - cytoscape('layout', 'euler', Euler); // register with cytoscape.js -}; - -if (typeof cytoscape !== 'undefined') { - // expose to global cytoscape (i.e. window.cytoscape) - register(cytoscape); -} - -module.exports = register; - -/***/ }), -/* 12 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -// general default options for force-directed layout - -module.exports = Object.freeze({ - animate: true, // whether to show the layout as it's running; special 'end' value makes the layout animate like a discrete layout - refresh: 10, // number of ticks per frame; higher is faster but more jerky - maxIterations: 1000, // max iterations before the layout will bail out - maxSimulationTime: 4000, // max length in ms to run the layout - ungrabifyWhileSimulating: false, // so you can't drag nodes during layout - fit: true, // on every layout reposition of nodes, fit the viewport - padding: 30, // padding around the simulation - boundingBox: undefined, // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } - - // layout event callbacks - ready: function ready() {}, // on layoutready - stop: function stop() {}, // on layoutstop - - // positioning options - randomize: false, // use random node positions at beginning of layout - - // infinite layout options - infinite: false // overrides all other options for a forces-all-the-time mode -}); - -/***/ }), -/* 13 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -/** -A generic continuous layout class -*/ - -var assign = __webpack_require__(0); -var defaults = __webpack_require__(12); -var makeBoundingBox = __webpack_require__(14); - -var _require = __webpack_require__(15), - setInitialPositionState = _require.setInitialPositionState, - refreshPositions = _require.refreshPositions, - getNodePositionData = _require.getNodePositionData; - -var _require2 = __webpack_require__(16), - multitick = _require2.multitick; - -var Layout = function () { - function Layout(options) { - _classCallCheck(this, Layout); - - var o = this.options = assign({}, defaults, options); - - var nodes = o.eles.nodes(); - // prevent infinite loop and memory overflow when nodes occupy the same position - if (!o.randomize) { - nodes = nodes.sort(function (a, b) { - return a.position().x - b.position().x; - }); - var prev = { x: 0, y: 0 }; - var pos = {}; - nodes.forEach(function (n) { - Object.assign(pos, n.position()); - if (Math.abs(prev.x - pos.x) < o.theta && Math.abs(prev.y - pos.y) < o.theta) { - n.position({ x: Math.random() * 100, y: Math.random() * 100 }); - } - Object.assign(prev, pos); - }); - } - - var s = this.state = assign({}, o, { - layout: this, - nodes: nodes, - edges: o.eles.edges(), - tickIndex: 0, - firstUpdate: true - }); - - s.animateEnd = o.animate && o.animate === 'end'; - s.animateContinuously = o.animate && !s.animateEnd; - } - - _createClass(Layout, [{ - key: 'run', - value: function run() { - var l = this; - var s = this.state; - - s.tickIndex = 0; - s.firstUpdate = true; - s.startTime = Date.now(); - s.running = true; - - s.currentBoundingBox = makeBoundingBox(s.boundingBox, s.cy); - - if (s.ready) { - l.one('ready', s.ready); - } - if (s.stop) { - l.one('stop', s.stop); - } - - s.nodes.forEach(function (n) { - return setInitialPositionState(n, s); - }); - - l.prerun(s); - - if (s.animateContinuously) { - var ungrabify = function ungrabify(node) { - if (!s.ungrabifyWhileSimulating) { - return; - } - - var grabbable = getNodePositionData(node, s).grabbable = node.grabbable(); - - if (grabbable) { - node.ungrabify(); - } - }; - - var regrabify = function regrabify(node) { - if (!s.ungrabifyWhileSimulating) { - return; - } - - var grabbable = getNodePositionData(node, s).grabbable; - - if (grabbable) { - node.grabify(); - } - }; - - var updateGrabState = function updateGrabState(node) { - return getNodePositionData(node, s).grabbed = node.grabbed(); - }; - - var onGrab = function onGrab(_ref) { - var target = _ref.target; - - updateGrabState(target); - }; - - var onFree = onGrab; - - var onDrag = function onDrag(_ref2) { - var target = _ref2.target; - - var p = getNodePositionData(target, s); - var tp = target.position(); - - p.x = tp.x; - p.y = tp.y; - }; - - var listenToGrab = function listenToGrab(node) { - node.on('grab', onGrab); - node.on('free', onFree); - node.on('drag', onDrag); - }; - - var unlistenToGrab = function unlistenToGrab(node) { - node.removeListener('grab', onGrab); - node.removeListener('free', onFree); - node.removeListener('drag', onDrag); - }; - - var fit = function fit() { - if (s.fit && s.animateContinuously) { - s.cy.fit(s.padding); - } - }; - - var onNotDone = function onNotDone() { - refreshPositions(s.nodes, s); - fit(); - - requestAnimationFrame(_frame); - }; - - var _frame = function _frame() { - multitick(s, onNotDone, _onDone); - }; - - var _onDone = function _onDone() { - refreshPositions(s.nodes, s); - fit(); - - s.nodes.forEach(function (n) { - regrabify(n); - unlistenToGrab(n); - }); - - s.running = false; - - l.emit('layoutstop'); - }; - - l.emit('layoutstart'); - - s.nodes.forEach(function (n) { - ungrabify(n); - listenToGrab(n); - }); - - _frame(); // kick off - } else { - var done = false; - var _onNotDone = function _onNotDone() {}; - var _onDone2 = function _onDone2() { - return done = true; - }; - - while (!done) { - multitick(s, _onNotDone, _onDone2); - } - - s.eles.layoutPositions(this, s, function (node) { - var pd = getNodePositionData(node, s); - - return { x: pd.x, y: pd.y }; - }); - } - - l.postrun(s); - - return this; // chaining - } - }, { - key: 'prerun', - value: function prerun() {} - }, { - key: 'postrun', - value: function postrun() {} - }, { - key: 'tick', - value: function tick() {} - }, { - key: 'stop', - value: function stop() { - this.state.running = false; - - return this; // chaining - } - }, { - key: 'destroy', - value: function destroy() { - return this; // chaining - } - }]); - - return Layout; -}(); - -module.exports = Layout; - -/***/ }), -/* 14 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -module.exports = function (bb, cy) { - if (bb == null) { - bb = { x1: 0, y1: 0, w: cy.width(), h: cy.height() }; - } else { - // copy - bb = { x1: bb.x1, x2: bb.x2, y1: bb.y1, y2: bb.y2, w: bb.w, h: bb.h }; - } - - if (bb.x2 == null) { - bb.x2 = bb.x1 + bb.w; - } - if (bb.w == null) { - bb.w = bb.x2 - bb.x1; - } - if (bb.y2 == null) { - bb.y2 = bb.y1 + bb.h; - } - if (bb.h == null) { - bb.h = bb.y2 - bb.y1; - } - - return bb; -}; - -/***/ }), -/* 15 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var assign = __webpack_require__(0); - -var setInitialPositionState = function setInitialPositionState(node, state) { - var p = node.position(); - var bb = state.currentBoundingBox; - var scratch = node.scratch(state.name); - - if (scratch == null) { - scratch = {}; - - node.scratch(state.name, scratch); - } - - assign(scratch, state.randomize ? { - x: bb.x1 + Math.random() * bb.w, - y: bb.y1 + Math.random() * bb.h - } : { - x: p.x, - y: p.y - }); - - scratch.locked = node.locked(); -}; - -var getNodePositionData = function getNodePositionData(node, state) { - return node.scratch(state.name); -}; - -var refreshPositions = function refreshPositions(nodes, state) { - nodes.positions(function (node) { - var scratch = node.scratch(state.name); - - return { - x: scratch.x, - y: scratch.y - }; - }); -}; - -module.exports = { setInitialPositionState: setInitialPositionState, getNodePositionData: getNodePositionData, refreshPositions: refreshPositions }; - -/***/ }), -/* 16 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var nop = function nop() {}; - -var tick = function tick(state) { - var s = state; - var l = state.layout; - - var tickIndicatesDone = l.tick(s); - - if (s.firstUpdate) { - if (s.animateContinuously) { - // indicate the initial positions have been set - s.layout.emit('layoutready'); - } - s.firstUpdate = false; - } - - s.tickIndex++; - - var duration = Date.now() - s.startTime; - - return !s.infinite && (tickIndicatesDone || s.tickIndex >= s.maxIterations || duration >= s.maxSimulationTime); -}; - -var multitick = function multitick(state) { - var onNotDone = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : nop; - var onDone = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : nop; - - var done = false; - var s = state; - - for (var i = 0; i < s.refresh; i++) { - done = !s.running || tick(s); - - if (done) { - break; - } - } - - if (!done) { - onNotDone(); - } else { - onDone(); - } -}; - -module.exports = { tick: tick, multitick: multitick }; - -/***/ }) -/******/ ]); -}); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 50bc65c99ab5cf08ee3e","webpack:///./src/assign.js","webpack:///./src/euler/spring.js","webpack:///./src/euler/index.js","webpack:///./src/euler/body.js","webpack:///./src/euler/defaults.js","webpack:///./src/euler/drag.js","webpack:///./src/euler/integrate.js","webpack:///./src/euler/quadtree/index.js","webpack:///./src/euler/quadtree/insertStack.js","webpack:///./src/euler/quadtree/node.js","webpack:///./src/euler/tick.js","webpack:///./src/index.js","webpack:///./src/layout/defaults.js","webpack:///./src/layout/index.js","webpack:///./src/layout/make-bb.js","webpack:///./src/layout/position.js","webpack:///./src/layout/tick.js"],"names":["module","exports","Object","assign","bind","tgt","srcs","forEach","keys","src","k","require","defaults","freeze","source","target","length","coeff","weight","makeSpring","spring","applySpring","body1","body2","dx","pos","x","dy","y","r","Math","sqrt","random","d","springCoeff","force","Layout","tick","makeQuadtree","makeBody","isFn","fn","isParent","n","notIsParent","isLocked","locked","notIsLocked","isParentEdge","e","notIsParentEdge","getBody","scratch","body","getNonParentDescendants","descendants","filter","getScratch","el","optFn","opt","ele","Euler","options","state","s","quadtree","bodies","nodes","mass","_cyNode","_scratch","push","springs","edges","springLength","_cyEdge","sources","targets","movement","isDone","movementThreshold","prevPos","velocity","copyVec","v","getValue","val","def","getVec","vec","opts","b","gravity","pull","theta","dragCoeff","timeStep","defaultCoeff","applyDrag","manualDragCoeff","integrate","tx","ty","i","max","grabbed","vx","vy","abs","Node","InsertStack","resetVec","isSamePosition","p1","p2","threshold","updateQueue","insertStack","nodesCache","currentInCache","root","newNode","node","quad0","quad1","quad2","quad3","massX","massY","left","right","top","bottom","update","sourceBody","queue","fx","fy","queueLength","shiftIdx","pushIdx","px","py","pr","pv","differentBody","insertBodies","x1","Number","MAX_VALUE","y1","x2","MIN_VALUE","y2","insert","newBody","reset","isEmpty","stackItem","pop","quadIdx","child","getChild","setChild","oldBody","retriesCount","offset","updateBodyForce","idx","stack","popIdx","prototype","item","InsertStackElement","p","register","cytoscape","animate","refresh","maxIterations","maxSimulationTime","ungrabifyWhileSimulating","fit","padding","boundingBox","undefined","ready","stop","randomize","infinite","makeBoundingBox","setInitialPositionState","refreshPositions","getNodePositionData","multitick","o","eles","sort","a","position","prev","layout","tickIndex","firstUpdate","animateEnd","animateContinuously","l","startTime","Date","now","running","currentBoundingBox","cy","one","prerun","ungrabify","grabbable","regrabify","grabify","updateGrabState","onGrab","onFree","onDrag","tp","listenToGrab","on","unlistenToGrab","removeListener","onNotDone","requestAnimationFrame","frame","onDone","emit","done","layoutPositions","pd","postrun","bb","w","width","h","height","name","positions","nop","tickIndicatesDone","duration"],"mappings":"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","file":"cytoscape-euler.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"cytoscapeEuler\"] = factory();\n\telse\n\t\troot[\"cytoscapeEuler\"] = factory();\n})(this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 11);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 50bc65c99ab5cf08ee3e","module.exports = Object.assign != null ? Object.assign.bind( Object ) : function( tgt, ...srcs ){\n  srcs.forEach( src => {\n    Object.keys( src ).forEach( k => tgt[k] = src[k] );\n  } );\n\n  return tgt;\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/assign.js","const assign = require('../assign');\n\nconst defaults = Object.freeze({\n  source: null,\n  target: null,\n  length: 80,\n  coeff: 0.0002,\n  weight: 1\n});\n\nfunction makeSpring( spring ){\n  return assign( {}, defaults, spring );\n}\n\nfunction applySpring( spring ){\n  let body1 = spring.source,\n      body2 = spring.target,\n      length = spring.length < 0 ? defaults.length : spring.length,\n      dx = body2.pos.x - body1.pos.x,\n      dy = body2.pos.y - body1.pos.y,\n      r = Math.sqrt(dx * dx + dy * dy);\n\n  if (r === 0) {\n      dx = (Math.random() - 0.5) / 50;\n      dy = (Math.random() - 0.5) / 50;\n      r = Math.sqrt(dx * dx + dy * dy);\n  }\n\n  let d = r - length;\n  let coeff = ((!spring.coeff || spring.coeff < 0) ? defaults.springCoeff : spring.coeff) * d / r * spring.weight;\n\n  body1.force.x += coeff * dx;\n  body1.force.y += coeff * dy;\n\n  body2.force.x -= coeff * dx;\n  body2.force.y -= coeff * dy;\n}\n\nmodule.exports = { makeSpring, applySpring };\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/spring.js","/**\nThe implementation of the Euler layout algorithm\n*/\n\nconst Layout = require('../layout');\nconst assign = require('../assign');\nconst defaults = require('./defaults');\nconst { tick } = require('./tick');\nconst { makeQuadtree } = require('./quadtree');\nconst { makeBody } = require('./body');\nconst { makeSpring } = require('./spring');\nconst isFn = fn => typeof fn === 'function';\nconst isParent = n => n.isParent();\nconst notIsParent = n => !isParent(n);\nconst isLocked = n => n.locked();\nconst notIsLocked = n => !isLocked(n);\nconst isParentEdge = e => isParent( e.source() ) || isParent( e.target() );\nconst notIsParentEdge = e => !isParentEdge(e);\nconst getBody = n => n.scratch('euler').body;\nconst getNonParentDescendants = n => isParent(n) ? n.descendants().filter( notIsParent ) : n;\n\nconst getScratch = el => {\n  let scratch = el.scratch('euler');\n\n  if( !scratch ){\n    scratch = {};\n\n    el.scratch('euler', scratch);\n  }\n\n  return scratch;\n};\n\nconst optFn = ( opt, ele ) => {\n  if( isFn( opt ) ){\n    return opt( ele );\n  } else {\n    return opt;\n  }\n};\n\nclass Euler extends Layout {\n  constructor( options ){\n    super( assign( {}, defaults, options ) );\n  }\n\n  prerun( state ){\n    let s = state;\n\n    s.quadtree = makeQuadtree();\n\n    let bodies = s.bodies = [];\n\n    // regular nodes\n    s.nodes.filter( n => notIsParent(n) ).forEach( n => {\n      let scratch = getScratch( n );\n\n      let body = makeBody({\n        pos: { x: scratch.x, y: scratch.y },\n        mass: optFn( s.mass, n ),\n        locked: scratch.locked\n      });\n\n      body._cyNode = n;\n\n      scratch.body = body;\n\n      body._scratch = scratch;\n\n      bodies.push( body );\n    } );\n\n    let springs = s.springs = [];\n\n    // regular edge springs\n    s.edges.filter( notIsParentEdge ).forEach( e => {\n      let spring = makeSpring({\n        source: getBody( e.source() ),\n        target: getBody( e.target() ),\n        length: optFn( s.springLength, e ),\n        coeff: optFn( s.springCoeff, e )\n      });\n\n      spring._cyEdge = e;\n\n      let scratch = getScratch( e );\n\n      spring._scratch = scratch;\n\n      scratch.spring = spring;\n\n      springs.push( spring );\n    } );\n\n    // compound edge springs\n    s.edges.filter( isParentEdge ).forEach( e => {\n      let sources = getNonParentDescendants( e.source() );\n      let targets = getNonParentDescendants( e.target() );\n\n      // just add one spring for perf\n      sources = [ sources[0] ];\n      targets = [ targets[0] ];\n\n      sources.forEach( src => {\n        targets.forEach( tgt => {\n          springs.push( makeSpring({\n            source: getBody( src ),\n            target: getBody( tgt ),\n            length: optFn( s.springLength, e ),\n            coeff: optFn( s.springCoeff, e )\n          }) );\n        } );\n      } );\n    } );\n  }\n\n  tick( state ){\n    let movement = tick( state );\n\n    let isDone = movement <= state.movementThreshold;\n\n    return isDone;\n  }\n}\n\nmodule.exports = Euler;\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/index.js","const defaults = Object.freeze({\n  pos: { x: 0, y: 0 },\n  prevPos: { x: 0, y: 0 },\n  force: { x: 0, y: 0 },\n  velocity: { x: 0, y: 0 },\n  mass: 1\n});\n\nconst copyVec = v => ({ x: v.x, y: v.y });\nconst getValue = ( val, def ) => val != null ? val : def;\nconst getVec = ( vec, def ) => copyVec( getValue( vec, def ) );\n\nfunction makeBody( opts ){\n  let b = {};\n\n  b.pos = getVec( opts.pos, defaults.pos );\n  b.prevPos = getVec( opts.prevPos, b.pos );\n  b.force = getVec( opts.force, defaults.force );\n  b.velocity = getVec( opts.velocity, defaults.velocity );\n  b.mass = opts.mass != null ? opts.mass : defaults.mass;\n  b.locked = opts.locked;\n\n  return b;\n}\n\nmodule.exports = { makeBody };\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/body.js","const defaults = Object.freeze({\n  // The ideal legth of a spring\n  // - This acts as a hint for the edge length\n  // - The edge length can be longer or shorter if the forces are set to extreme values\n  springLength: edge => 80,\n\n  // Hooke's law coefficient\n  // - The value ranges on [0, 1]\n  // - Lower values give looser springs\n  // - Higher values give tighter springs\n  springCoeff: edge => 0.0008,\n\n  // The mass of the node in the physics simulation\n  // - The mass affects the gravity node repulsion/attraction\n  mass: node => 4,\n\n  // Coulomb's law coefficient\n  // - Makes the nodes repel each other for negative values\n  // - Makes the nodes attract each other for positive values\n  gravity: -1.2,\n\n  // A force that pulls nodes towards the origin (0, 0)\n  // Higher values keep the components less spread out\n  pull: 0.001,\n\n  // Theta coefficient from Barnes-Hut simulation\n  // - Value ranges on [0, 1]\n  // - Performance is better with smaller values\n  // - Very small values may not create enough force to give a good result\n  theta: 0.666,\n\n  // Friction / drag coefficient to make the system stabilise over time\n  dragCoeff: 0.02,\n\n  // When the total of the squared position deltas is less than this value, the simulation ends\n  movementThreshold: 1,\n\n  // The amount of time passed per tick\n  // - Larger values result in faster runtimes but might spread things out too far\n  // - Smaller values produce more accurate results\n  timeStep: 20\n});\n\nmodule.exports = defaults;\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/defaults.js","const defaultCoeff = 0.02;\n\nfunction applyDrag( body, manualDragCoeff ){\n  let dragCoeff;\n\n  if( manualDragCoeff != null ){\n    dragCoeff = manualDragCoeff;\n  } else if( body.dragCoeff != null ){\n    dragCoeff = body.dragCoeff;\n  } else {\n    dragCoeff = defaultCoeff;\n  }\n\n  body.force.x -= dragCoeff * body.velocity.x;\n  body.force.y -= dragCoeff * body.velocity.y;\n}\n\nmodule.exports = { applyDrag };\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/drag.js","// use euler method for force integration http://en.wikipedia.org/wiki/Euler_method\n// return sum of squared position deltas\nfunction integrate( bodies, timeStep ){\n  var dx = 0, tx = 0,\n      dy = 0, ty = 0,\n      i,\n      max = bodies.length;\n\n  if (max === 0) {\n    return 0;\n  }\n\n  for (i = 0; i < max; ++i) {\n    var body = bodies[i],\n        coeff = timeStep / body.mass;\n\n    if( body.grabbed ){ continue; }\n\n    if( body.locked ){\n      body.velocity.x = 0;\n      body.velocity.y = 0;\n    } else {\n      body.velocity.x += coeff * body.force.x;\n      body.velocity.y += coeff * body.force.y;\n    }\n\n    var vx = body.velocity.x,\n        vy = body.velocity.y,\n        v = Math.sqrt(vx * vx + vy * vy);\n\n    if (v > 1) {\n      body.velocity.x = vx / v;\n      body.velocity.y = vy / v;\n    }\n\n    dx = timeStep * body.velocity.x;\n    dy = timeStep * body.velocity.y;\n\n    body.pos.x += dx;\n    body.pos.y += dy;\n\n    tx += Math.abs(dx); ty += Math.abs(dy);\n  }\n\n  return (tx * tx + ty * ty)/max;\n}\n\nmodule.exports = { integrate };\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/integrate.js","// impl of barnes hut\n// http://www.eecs.berkeley.edu/~demmel/cs267/lecture26/lecture26.html\n// http://en.wikipedia.org/wiki/Barnes%E2%80%93Hut_simulation\n\nconst Node = require('./node');\nconst InsertStack = require('./insertStack');\n\nconst resetVec = v => { v.x = 0; v.y = 0; };\n\nconst isSamePosition = (p1, p2) => {\n  let threshold = 1e-8;\n  let dx = Math.abs(p1.x - p2.x);\n  let dy = Math.abs(p1.y - p2.y);\n\n  return dx < threshold && dy < threshold;\n};\n\nfunction makeQuadtree(){\n  let updateQueue = [],\n    insertStack = new InsertStack(),\n    nodesCache = [],\n    currentInCache = 0,\n    root = newNode();\n\n  function newNode() {\n    // To avoid pressure on GC we reuse nodes.\n    let node = nodesCache[currentInCache];\n    if (node) {\n      node.quad0 = null;\n      node.quad1 = null;\n      node.quad2 = null;\n      node.quad3 = null;\n      node.body = null;\n      node.mass = node.massX = node.massY = 0;\n      node.left = node.right = node.top = node.bottom = 0;\n    } else {\n      node = new Node();\n      nodesCache[currentInCache] = node;\n    }\n\n    ++currentInCache;\n    return node;\n  }\n\n  function update( sourceBody, gravity, theta, pull ) {\n    let queue = updateQueue,\n      v,\n      dx,\n      dy,\n      r, fx = 0,\n      fy = 0,\n      queueLength = 1,\n      shiftIdx = 0,\n      pushIdx = 1;\n\n    queue[0] = root;\n\n    resetVec( sourceBody.force );\n\n    let px = -sourceBody.pos.x;\n    let py = -sourceBody.pos.y;\n    let pr = Math.sqrt(px * px + py * py);\n    let pv = sourceBody.mass * pull / pr;\n\n    fx += pv * px;\n    fy += pv * py;\n\n    while (queueLength) {\n      let node = queue[shiftIdx],\n        body = node.body;\n\n      queueLength -= 1;\n      shiftIdx += 1;\n      let differentBody = (body !== sourceBody);\n      if (body && differentBody) {\n        // If the current node is a leaf node (and it is not source body),\n        // calculate the force exerted by the current node on body, and add this\n        // amount to body's net force.\n        dx = body.pos.x - sourceBody.pos.x;\n        dy = body.pos.y - sourceBody.pos.y;\n        r = Math.sqrt(dx * dx + dy * dy);\n\n        if (r === 0) {\n          // Poor man's protection against zero distance.\n          dx = (Math.random() - 0.5) / 50;\n          dy = (Math.random() - 0.5) / 50;\n          r = Math.sqrt(dx * dx + dy * dy);\n        }\n\n        // This is standard gravition force calculation but we divide\n        // by r^3 to save two operations when normalizing force vector.\n        v = gravity * body.mass * sourceBody.mass / (r * r * r);\n        fx += v * dx;\n        fy += v * dy;\n      } else if (differentBody) {\n        // Otherwise, calculate the ratio s / r,  where s is the width of the region\n        // represented by the internal node, and r is the distance between the body\n        // and the node's center-of-mass\n        dx = node.massX / node.mass - sourceBody.pos.x;\n        dy = node.massY / node.mass - sourceBody.pos.y;\n        r = Math.sqrt(dx * dx + dy * dy);\n\n        if (r === 0) {\n          // Sorry about code duplucation. I don't want to create many functions\n          // right away. Just want to see performance first.\n          dx = (Math.random() - 0.5) / 50;\n          dy = (Math.random() - 0.5) / 50;\n          r = Math.sqrt(dx * dx + dy * dy);\n        }\n        // If s / r < θ, treat this internal node as a single body, and calculate the\n        // force it exerts on sourceBody, and add this amount to sourceBody's net force.\n        if ((node.right - node.left) / r < theta) {\n          // in the if statement above we consider node's width only\n          // because the region was squarified during tree creation.\n          // Thus there is no difference between using width or height.\n          v = gravity * node.mass * sourceBody.mass / (r * r * r);\n          fx += v * dx;\n          fy += v * dy;\n        } else {\n          // Otherwise, run the procedure recursively on each of the current node's children.\n\n          // I intentionally unfolded this loop, to save several CPU cycles.\n          if (node.quad0) {\n            queue[pushIdx] = node.quad0;\n            queueLength += 1;\n            pushIdx += 1;\n          }\n          if (node.quad1) {\n            queue[pushIdx] = node.quad1;\n            queueLength += 1;\n            pushIdx += 1;\n          }\n          if (node.quad2) {\n            queue[pushIdx] = node.quad2;\n            queueLength += 1;\n            pushIdx += 1;\n          }\n          if (node.quad3) {\n            queue[pushIdx] = node.quad3;\n            queueLength += 1;\n            pushIdx += 1;\n          }\n        }\n      }\n    }\n\n    sourceBody.force.x += fx;\n    sourceBody.force.y += fy;\n  }\n\n  function insertBodies(bodies) {\n    if( bodies.length === 0 ){ return; }\n\n    let x1 = Number.MAX_VALUE,\n      y1 = Number.MAX_VALUE,\n      x2 = Number.MIN_VALUE,\n      y2 = Number.MIN_VALUE,\n      i,\n      max = bodies.length;\n\n    // To reduce quad tree depth we are looking for exact bounding box of all particles.\n    i = max;\n    while (i--) {\n      let x = bodies[i].pos.x;\n      let y = bodies[i].pos.y;\n      if (x < x1) {\n        x1 = x;\n      }\n      if (x > x2) {\n        x2 = x;\n      }\n      if (y < y1) {\n        y1 = y;\n      }\n      if (y > y2) {\n        y2 = y;\n      }\n    }\n\n    // Squarify the bounds.\n    let dx = x2 - x1,\n      dy = y2 - y1;\n    if (dx > dy) {\n      y2 = y1 + dx;\n    } else {\n      x2 = x1 + dy;\n    }\n\n    currentInCache = 0;\n    root = newNode();\n    root.left = x1;\n    root.right = x2;\n    root.top = y1;\n    root.bottom = y2;\n\n    i = max - 1;\n    if (i >= 0) {\n      root.body = bodies[i];\n    }\n    while (i--) {\n      insert(bodies[i], root);\n    }\n  }\n\n  function insert(newBody) {\n    insertStack.reset();\n    insertStack.push(root, newBody);\n\n    while (!insertStack.isEmpty()) {\n      let stackItem = insertStack.pop(),\n        node = stackItem.node,\n        body = stackItem.body;\n\n      if (!node.body) {\n        // This is internal node. Update the total mass of the node and center-of-mass.\n        let x = body.pos.x;\n        let y = body.pos.y;\n        node.mass = node.mass + body.mass;\n        node.massX = node.massX + body.mass * x;\n        node.massY = node.massY + body.mass * y;\n\n        // Recursively insert the body in the appropriate quadrant.\n        // But first find the appropriate quadrant.\n        let quadIdx = 0, // Assume we are in the 0's quad.\n          left = node.left,\n          right = (node.right + left) / 2,\n          top = node.top,\n          bottom = (node.bottom + top) / 2;\n\n        if (x > right) { // somewhere in the eastern part.\n          quadIdx = quadIdx + 1;\n          left = right;\n          right = node.right;\n        }\n        if (y > bottom) { // and in south.\n          quadIdx = quadIdx + 2;\n          top = bottom;\n          bottom = node.bottom;\n        }\n\n        let child = getChild(node, quadIdx);\n        if (!child) {\n          // The node is internal but this quadrant is not taken. Add\n          // subnode to it.\n          child = newNode();\n          child.left = left;\n          child.top = top;\n          child.right = right;\n          child.bottom = bottom;\n          child.body = body;\n\n          setChild(node, quadIdx, child);\n        } else {\n          // continue searching in this quadrant.\n          insertStack.push(child, body);\n        }\n      } else {\n        // We are trying to add to the leaf node.\n        // We have to convert current leaf into internal node\n        // and continue adding two nodes.\n        let oldBody = node.body;\n        node.body = null; // internal nodes do not cary bodies\n\n        if (isSamePosition(oldBody.pos, body.pos)) {\n          // Prevent infinite subdivision by bumping one node\n          // anywhere in this quadrant\n          let retriesCount = 3;\n          do {\n            let offset = Math.random();\n            let dx = (node.right - node.left) * offset;\n            let dy = (node.bottom - node.top) * offset;\n\n            oldBody.pos.x = node.left + dx;\n            oldBody.pos.y = node.top + dy;\n            retriesCount -= 1;\n            // Make sure we don't bump it out of the box. If we do, next iteration should fix it\n          } while (retriesCount > 0 && isSamePosition(oldBody.pos, body.pos));\n\n          if (retriesCount === 0 && isSamePosition(oldBody.pos, body.pos)) {\n            // This is very bad, we ran out of precision.\n            // if we do not return from the method we'll get into\n            // infinite loop here. So we sacrifice correctness of layout, and keep the app running\n            // Next layout iteration should get larger bounding box in the first step and fix this\n            return;\n          }\n        }\n        // Next iteration should subdivide node further.\n        insertStack.push(node, oldBody);\n        insertStack.push(node, body);\n      }\n    }\n  }\n\n  return {\n    insertBodies: insertBodies,\n    updateBodyForce: update\n  };\n}\n\nfunction getChild(node, idx) {\n  if (idx === 0) return node.quad0;\n  if (idx === 1) return node.quad1;\n  if (idx === 2) return node.quad2;\n  if (idx === 3) return node.quad3;\n  return null;\n}\n\nfunction setChild(node, idx, child) {\n  if (idx === 0) node.quad0 = child;\n  else if (idx === 1) node.quad1 = child;\n  else if (idx === 2) node.quad2 = child;\n  else if (idx === 3) node.quad3 = child;\n}\n\nmodule.exports = { makeQuadtree };\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/quadtree/index.js","module.exports = InsertStack;\n\n/**\n * Our implmentation of QuadTree is non-recursive to avoid GC hit\n * This data structure represent stack of elements\n * which we are trying to insert into quad tree.\n */\nfunction InsertStack () {\n    this.stack = [];\n    this.popIdx = 0;\n}\n\nInsertStack.prototype = {\n    isEmpty: function() {\n        return this.popIdx === 0;\n    },\n    push: function (node, body) {\n        let item = this.stack[this.popIdx];\n        if (!item) {\n            // we are trying to avoid memory pressue: create new element\n            // only when absolutely necessary\n            this.stack[this.popIdx] = new InsertStackElement(node, body);\n        } else {\n            item.node = node;\n            item.body = body;\n        }\n        ++this.popIdx;\n    },\n    pop: function () {\n        if (this.popIdx > 0) {\n            return this.stack[--this.popIdx];\n        }\n    },\n    reset: function () {\n        this.popIdx = 0;\n    }\n};\n\nfunction InsertStackElement(node, body) {\n    this.node = node; // QuadTree node\n    this.body = body; // physical body which needs to be inserted to node\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/quadtree/insertStack.js","/**\n * Internal data structure to represent 2D QuadTree node\n */\nmodule.exports = function Node() {\n  // body stored inside this node. In quad tree only leaf nodes (by construction)\n  // contain boides:\n  this.body = null;\n\n  // Child nodes are stored in quads. Each quad is presented by number:\n  // 0 | 1\n  // -----\n  // 2 | 3\n  this.quad0 = null;\n  this.quad1 = null;\n  this.quad2 = null;\n  this.quad3 = null;\n\n  // Total mass of current node\n  this.mass = 0;\n\n  // Center of mass coordinates\n  this.massX = 0;\n  this.massY = 0;\n\n  // bounding box coordinates\n  this.left = 0;\n  this.top = 0;\n  this.bottom = 0;\n  this.right = 0;\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/quadtree/node.js","const { integrate } = require('./integrate');\nconst { applyDrag } = require('./drag');\nconst { applySpring } = require('./spring');\n\nfunction tick({ bodies, springs, quadtree, timeStep, gravity, theta, dragCoeff, pull }){\n  // update body from scratch in case of any changes\n  bodies.forEach( body => {\n    let p = body._scratch;\n\n    if( !p ){ return; }\n\n    body.locked = p.locked;\n    body.grabbed = p.grabbed;\n    body.pos.x = p.x;\n    body.pos.y = p.y;\n  } );\n\n  quadtree.insertBodies( bodies );\n\n  for( let i = 0; i < bodies.length; i++ ){\n    let body = bodies[i];\n\n    quadtree.updateBodyForce( body, gravity, theta, pull );\n    applyDrag( body, dragCoeff );\n  }\n\n  for( let i = 0; i < springs.length; i++ ){\n    let spring = springs[i];\n\n    applySpring( spring );\n  }\n\n  let movement = integrate( bodies, timeStep );\n\n  // update scratch positions from body positions\n  bodies.forEach( body => {\n    let p = body._scratch;\n\n    if( !p ){ return; }\n\n    p.x = body.pos.x;\n    p.y = body.pos.y;\n  } );\n\n  return movement;\n}\n\nmodule.exports = { tick };\n\n\n\n// WEBPACK FOOTER //\n// ./src/euler/tick.js","const Euler = require('./euler');\n\n// registers the extension on a cytoscape lib ref\nlet register = function( cytoscape ){\n  if( !cytoscape ){ return; } // can't register if cytoscape unspecified\n\n  cytoscape( 'layout', 'euler', Euler ); // register with cytoscape.js\n};\n\nif( typeof cytoscape !== 'undefined' ){ // expose to global cytoscape (i.e. window.cytoscape)\n  register( cytoscape );\n}\n\nmodule.exports = register;\n\n\n\n// WEBPACK FOOTER //\n// ./src/index.js","// general default options for force-directed layout\n\nmodule.exports = Object.freeze({\n  animate: true, // whether to show the layout as it's running; special 'end' value makes the layout animate like a discrete layout\n  refresh: 10, // number of ticks per frame; higher is faster but more jerky\n  maxIterations: 1000, // max iterations before the layout will bail out\n  maxSimulationTime: 4000, // max length in ms to run the layout\n  ungrabifyWhileSimulating: false, // so you can't drag nodes during layout\n  fit: true, // on every layout reposition of nodes, fit the viewport\n  padding: 30, // padding around the simulation\n  boundingBox: undefined, // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h }\n\n  // layout event callbacks\n  ready: function(){}, // on layoutready\n  stop: function(){}, // on layoutstop\n\n  // positioning options\n  randomize: false, // use random node positions at beginning of layout\n  \n  // infinite layout options\n  infinite: false // overrides all other options for a forces-all-the-time mode\n});\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/defaults.js","/**\nA generic continuous layout class\n*/\n\nconst assign = require('../assign');\nconst defaults = require('./defaults');\nconst makeBoundingBox = require('./make-bb');\nconst { setInitialPositionState, refreshPositions, getNodePositionData } = require('./position');\nconst { multitick } = require('./tick');\n\nclass Layout {\n  constructor( options ){\n    let o = this.options = assign( {}, defaults, options );\n\n\t\tlet nodes = o.eles.nodes();\n\t\t// prevent infinite loop and memory overflow when nodes occupy the same position\n\t\tif(!o.randomize)\n\t\t{\n\t\t\tnodes = nodes.sort((a,b)=>a.position().x-b.position().x);\n\t\t\tconst prev = {x: 0, y: 0};\n\t\t\tconst pos = {};\n\t\t\tnodes.forEach(n=>\n\t\t\t{\n\t\t\t\tObject.assign(pos,n.position());\n\t\t\t\tif(Math.abs(prev.x - pos.x) < o.theta && Math.abs(prev.y - pos.y) < o.theta)\n\t\t\t\t{\n\t\t\t\t\tn.position({x: Math.random()*100, y: Math.random()*100});\n\t\t\t\t}\n\t\t\t\tObject.assign(prev,pos);\n\t\t\t});\n\t\t}\n\n    let s = this.state = assign( {}, o, {\n      layout: this,\n      nodes,\n      edges: o.eles.edges(),\n      tickIndex: 0,\n      firstUpdate: true\n    } );\n\n    s.animateEnd = o.animate && o.animate === 'end';\n    s.animateContinuously = o.animate && !s.animateEnd;\n  }\n\n  run(){\n    let l = this;\n    let s = this.state;\n\n    s.tickIndex = 0;\n    s.firstUpdate = true;\n    s.startTime = Date.now();\n    s.running = true;\n\n    s.currentBoundingBox = makeBoundingBox( s.boundingBox, s.cy );\n\n    if( s.ready ){ l.one( 'ready', s.ready ); }\n    if( s.stop ){ l.one( 'stop', s.stop ); }\n\n    s.nodes.forEach( n => setInitialPositionState( n, s ) );\n\n    l.prerun( s );\n\n    if( s.animateContinuously ){\n      let ungrabify = node => {\n        if( !s.ungrabifyWhileSimulating ){ return; }\n\n        let grabbable = getNodePositionData( node, s ).grabbable = node.grabbable();\n\n        if( grabbable ){\n          node.ungrabify();\n        }\n      };\n\n      let regrabify = node => {\n        if( !s.ungrabifyWhileSimulating ){ return; }\n\n        let grabbable = getNodePositionData( node, s ).grabbable;\n\n        if( grabbable ){\n          node.grabify();\n        }\n      };\n\n      let updateGrabState = node => getNodePositionData( node, s ).grabbed = node.grabbed();\n\n      let onGrab = function({ target }){\n        updateGrabState( target );\n      };\n\n      let onFree = onGrab;\n\n      let onDrag = function({ target }){\n        let p = getNodePositionData( target, s );\n        let tp = target.position();\n\n        p.x = tp.x;\n        p.y = tp.y;\n      };\n\n      let listenToGrab = node => {\n        node.on('grab', onGrab);\n        node.on('free', onFree);\n        node.on('drag', onDrag);\n      };\n\n      let unlistenToGrab = node => {\n        node.removeListener('grab', onGrab);\n        node.removeListener('free', onFree);\n        node.removeListener('drag', onDrag);\n      };\n\n      let fit = () => {\n        if( s.fit && s.animateContinuously ){\n          s.cy.fit( s.padding );\n        }\n      };\n\n      let onNotDone = () => {\n        refreshPositions( s.nodes, s );\n        fit();\n\n        requestAnimationFrame( frame );\n      };\n\n      let frame = function(){\n        multitick( s, onNotDone, onDone );\n      };\n\n      let onDone = () => {\n        refreshPositions( s.nodes, s );\n        fit();\n\n        s.nodes.forEach( n => {\n          regrabify( n );\n          unlistenToGrab( n );\n        } );\n\n        s.running = false;\n\n        l.emit('layoutstop');\n      };\n\n      l.emit('layoutstart');\n\n      s.nodes.forEach( n => {\n        ungrabify( n );\n        listenToGrab( n );\n      } );\n\n      frame(); // kick off\n    } else {\n      let done = false;\n      let onNotDone = () => {};\n      let onDone = () => done = true;\n\n      while( !done ){\n        multitick( s, onNotDone, onDone );\n      }\n\n      s.eles.layoutPositions( this, s, node => {\n        let pd = getNodePositionData( node, s );\n\n        return { x: pd.x, y: pd.y };\n      } );\n    }\n\n    l.postrun( s );\n\n    return this; // chaining\n  }\n\n  prerun(){}\n  postrun(){}\n  tick(){}\n\n  stop(){\n    this.state.running = false;\n\n    return this; // chaining\n  }\n\n  destroy(){\n    return this; // chaining\n  }\n}\n\nmodule.exports = Layout;\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/index.js","module.exports = function( bb, cy ){\n  if( bb == null ){\n    bb = { x1: 0, y1: 0, w: cy.width(), h: cy.height() };\n  } else { // copy\n    bb = { x1: bb.x1, x2: bb.x2, y1: bb.y1, y2: bb.y2, w: bb.w, h: bb.h };\n  }\n\n  if( bb.x2 == null ){ bb.x2 = bb.x1 + bb.w; }\n  if( bb.w == null ){ bb.w = bb.x2 - bb.x1; }\n  if( bb.y2 == null ){ bb.y2 = bb.y1 + bb.h; }\n  if( bb.h == null ){ bb.h = bb.y2 - bb.y1; }\n\n  return bb;\n};\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/make-bb.js","const assign = require('../assign');\n\nlet setInitialPositionState = function( node, state ){\n  let p = node.position();\n  let bb = state.currentBoundingBox;\n  let scratch = node.scratch( state.name );\n\n  if( scratch == null ){\n    scratch = {};\n\n    node.scratch( state.name, scratch );\n  }\n\n  assign( scratch, state.randomize ? {\n    x: bb.x1 + Math.random() * bb.w,\n    y: bb.y1 + Math.random() * bb.h\n  } : {\n    x: p.x,\n    y: p.y\n  } );\n\n  scratch.locked = node.locked();\n};\n\nlet getNodePositionData = function( node, state ){\n  return node.scratch( state.name );\n};\n\nlet refreshPositions = function( nodes, state ){\n  nodes.positions(function( node ){\n    let scratch = node.scratch( state.name );\n\n    return {\n      x: scratch.x,\n      y: scratch.y\n    };\n  });\n};\n\nmodule.exports = { setInitialPositionState, getNodePositionData, refreshPositions };\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/position.js","const nop = function(){};\n\nlet tick = function( state ){\n  let s = state;\n  let l = state.layout;\n\n  let tickIndicatesDone = l.tick( s );\n\n  if( s.firstUpdate ){\n    if( s.animateContinuously ){ // indicate the initial positions have been set\n      s.layout.emit('layoutready');\n    }\n    s.firstUpdate = false;\n  }\n\n  s.tickIndex++;\n\n  let duration = Date.now() - s.startTime;\n\n  return !s.infinite && ( tickIndicatesDone || s.tickIndex >= s.maxIterations || duration >= s.maxSimulationTime );\n};\n\nlet multitick = function( state, onNotDone = nop, onDone = nop ){\n  let done = false;\n  let s = state;\n\n  for( let i = 0; i < s.refresh; i++ ){\n    done = !s.running || tick( s );\n\n    if( done ){ break; }\n  }\n\n  if( !done ){\n    onNotDone();\n  } else {\n    onDone();\n  }\n};\n\nmodule.exports = { tick, multitick };\n\n\n\n// WEBPACK FOOTER //\n// ./src/layout/tick.js"],"sourceRoot":""} \ No newline at end of file