diff --git a/CHANGELOG.md b/CHANGELOG.md index 6582a61..348d6f8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,9 @@ + +# [2.4.0](https://github.com/ErikGartner/dtree/compare/2.3.0...v2.4.0) (2020-04-24) + + + + # [2.3.0](https://github.com/ErikGartner/dtree/compare/2.2.2...v2.3.0) (2020-04-24) diff --git a/README.md b/README.md index 6f73e53..710adbb 100644 --- a/README.md +++ b/README.md @@ -23,7 +23,7 @@ yarn add d3-dtree Lastly dTree is also available through several CDNs such as [jsDelivr](https://www.jsdelivr.com/package/npm/d3-dtree): ``` -https://cdn.jsdelivr.net/npm/d3-dtree@2.3.0/dist/dTree.min.js +https://cdn.jsdelivr.net/npm/d3-dtree@2.4.0/dist/dTree.min.js ``` ## Requirements @@ -121,7 +121,7 @@ The returned object, `tree = dTree.init(data, options)`, contains functions to - `zoomToFit(duration = 500)` - Zoom to fit the entire tree into the viewport ### Callbacks -Below follows a short descriptions of the available callback functions that may be passed to dTree. See [dtree.js](https://github.com/ErikGartner/dTree/blob/master/src/dtree.js) for the *default implementations*. +Below follows a short descriptions of the available callback functions that may be passed to dTree. See [dtree.js](https://github.com/ErikGartner/dTree/blob/master/src/dtree.js) for the *default implementations*. Information about e.g. mouse cursor position can retrieved by interacting with the `this` object, i.e. `d3.mouse(this)`. #### nodeClick ```javascript diff --git a/dist/dTree.js b/dist/dTree.js index 1b39751..a46d5eb 100644 --- a/dist/dTree.js +++ b/dist/dTree.js @@ -21,12 +21,12 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons this.allNodes = this._flatten(this.root); // calculate node sizes - this.nodeSize = opts.callbacks.nodeSize( + this.nodeSize = opts.callbacks.nodeSize.call(this, // filter hidden and marriage nodes _.filter(this.allNodes, function (node) { return !(node.hidden || _.get(node, 'data.isMarriage')); }), opts.nodeWidth, opts.callbacks.textRenderer); - this.marriageSize = opts.callbacks.marriageSize( + this.marriageSize = opts.callbacks.marriageSize.call(this, // filter hidden and non marriage nodes _.filter(this.allNodes, function (node) { return !node.hidden && _.get(node, 'data.isMarriage'); @@ -59,7 +59,7 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons svg.call(zoom.transform, d3.zoomIdentity.translate(width / 2, opts.margin.top).scale(1)); // Compute the layout. - this.tree = d3.tree().nodeSize([nodeSize[0] * 2, opts.callbacks.nodeHeightSeperation(nodeSize[0], nodeSize[1])]); + this.tree = d3.tree().nodeSize([nodeSize[0] * 2, opts.callbacks.nodeHeightSeperation.call(this, nodeSize[0], nodeSize[1])]); this.tree.separation(function separation(a, b) { if (a.data.hidden || b.data.hidden) { @@ -112,9 +112,9 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons return d.id; }).html(function (d) { if (d.data.isMarriage) { - return opts.callbacks.marriageRenderer(d.x, d.y, marriageSize[0], marriageSize[1], d.data.extra, d.data.id, d.data['class']); + return opts.callbacks.marriageRenderer.call(this, d.x, d.y, marriageSize[0], marriageSize[1], d.data.extra, d.data.id, d.data['class']); } else { - return opts.callbacks.nodeRenderer(d.data.name, d.x, d.y, nodeSize[0], nodeSize[1], d.data.extra, d.data.id, d.data['class'], d.data.textClass, opts.callbacks.textRenderer); + return opts.callbacks.nodeRenderer.call(this, d.data.name, d.x, d.y, nodeSize[0], nodeSize[1], d.data.extra, d.data.id, d.data['class'], d.data.textClass, opts.callbacks.textRenderer); } }).on('dblclick', function () { // do not propagate a double click on a node @@ -126,9 +126,9 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons return; } if (d.data.isMarriage) { - opts.callbacks.marriageClick(d.data.extra, d.data.id); + opts.callbacks.marriageClick.call(this, d.data.extra, d.data.id); } else { - opts.callbacks.nodeClick(d.data.name, d.data.extra, d.data.id); + opts.callbacks.nodeClick.call(this, d.data.name, d.data.extra, d.data.id); } }).on('contextmenu', function (d) { if (d.data.hidden) { @@ -136,9 +136,9 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons } d3.event.preventDefault(); if (d.data.isMarriage) { - opts.callbacks.marriageRightClick(d.data.extra, d.data.id); + opts.callbacks.marriageRightClick.call(this, d.data.extra, d.data.id); } else { - opts.callbacks.nodeRightClick(d.data.name, d.data.extra, d.data.id); + opts.callbacks.nodeRightClick.call(this, d.data.name, d.data.extra, d.data.id); } }); } @@ -344,7 +344,7 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons var dTree = { - VERSION: '2.3.0', + VERSION: '2.4.0', init: function init(data) { var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; @@ -556,7 +556,7 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons _sortPersons: function _sortPersons(persons, opts) { if (persons != undefined) { persons.sort(function (a, b) { - return opts.callbacks.nodeSorter(a.name, a.extra, b.name, b.extra); + return opts.callbacks.nodeSorter.call(this, a.name, a.extra, b.name, b.extra); }); } return persons; @@ -567,7 +567,7 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons marriages.sort(function (marriageA, marriageB) { var a = marriageA.spouse; var b = marriageB.spouse; - return opts.callbacks.nodeSorter(a.name, a.extra, b.name, b.extra); + return opts.callbacks.nodeSorter.call(this, a.name, a.extra, b.name, b.extra); }); } return marriages; diff --git a/dist/dTree.js.map b/dist/dTree.js.map index d2d1a4e..dfc0435 100644 --- a/dist/dTree.js.map +++ b/dist/dTree.js.map @@ -1 +1 @@ -{"version":3,"sources":["dTree.js"],"names":[],"mappings":"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","file":"dTree.js","sourcesContent":["(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n\ttypeof define === 'function' && define.amd ? define(factory) :\n\t(global.dTree = factory());\n}(this, (function () { 'use strict';\n\nclass TreeBuilder {\n\n constructor(root, siblings, opts) {\n TreeBuilder.DEBUG_LEVEL = opts.debug ? 1 : 0;\n\n this.root = root;\n this.siblings = siblings;\n this.opts = opts;\n\n // flatten nodes\n this.allNodes = this._flatten(this.root);\n\n // calculate node sizes\n this.nodeSize = opts.callbacks.nodeSize(\n // filter hidden and marriage nodes\n _.filter(\n this.allNodes,\n node => !(node.hidden || _.get(node, 'data.isMarriage'))\n ),\n opts.nodeWidth,\n opts.callbacks.textRenderer\n );\n this.marriageSize = opts.callbacks.marriageSize(\n // filter hidden and non marriage nodes\n _.filter(\n this.allNodes,\n node => !node.hidden && _.get(node, 'data.isMarriage')\n ),\n this.opts.marriageNodeSize\n );\n }\n\n create() {\n\n let opts = this.opts;\n let allNodes = this.allNodes;\n let nodeSize = this.nodeSize;\n\n let width = opts.width + opts.margin.left + opts.margin.right;\n let height = opts.height + opts.margin.top + opts.margin.bottom;\n\n // create zoom handler\n const zoom = this.zoom = d3.zoom()\n .scaleExtent([0.1, 10])\n .on('zoom', function () {\n g.attr('transform', d3.event.transform);\n });\n\n // make a svg\n const svg = this.svg = d3.select(opts.target)\n .append('svg')\n .attr('viewBox', [0, 0, width, height])\n .call(zoom);\n\n // create svg group that holds all nodes\n const g = this.g = svg.append('g');\n\n // set zoom identity\n svg.call(zoom.transform, d3.zoomIdentity.translate(width / 2, opts.margin.top).scale(1));\n\n // Compute the layout.\n this.tree = d3.tree()\n .nodeSize([nodeSize[0] * 2,\n opts.callbacks.nodeHeightSeperation(nodeSize[0], nodeSize[1])]);\n\n this.tree.separation(function separation(a, b) {\n if (a.data.hidden || b.data.hidden) {\n return 0.3;\n } else {\n return 0.6;\n }\n });\n\n this._update(this.root);\n\n }\n\n _update(source) {\n\n let opts = this.opts;\n let allNodes = this.allNodes;\n let nodeSize = this.nodeSize;\n let marriageSize = this.marriageSize;\n\n let treenodes = this.tree(source);\n let links = treenodes.links();\n\n // Create the link lines.\n this.g.selectAll('.link')\n .data(links)\n .enter()\n // filter links with no parents to prevent empty nodes\n .filter(function(l) {\n return !l.target.data.noParent;\n })\n .append('path')\n .attr('class', opts.styles.linage)\n .attr('d', this._elbow);\n\n let nodes = this.g.selectAll('.node')\n .data(treenodes.descendants())\n .enter();\n\n this._linkSiblings();\n\n // Draw siblings (marriage)\n this.g.selectAll('.sibling')\n .data(this.siblings)\n .enter()\n .append('path')\n .attr('class', opts.styles.marriage)\n .attr('d', _.bind(this._siblingLine, this));\n\n // Create the node rectangles.\n nodes.append('foreignObject')\n .filter(function(d) {\n return d.data.hidden ? false : true;\n })\n .attr('x', function(d) {\n return Math.round(d.x - d.cWidth / 2) + 'px';\n })\n .attr('y', function(d) {\n return Math.round(d.y - d.cHeight / 2) + 'px';\n })\n .attr('width', function(d) {\n return d.cWidth + 'px';\n })\n .attr('height', function(d) {\n return d.cHeight + 'px';\n })\n .attr('id', function(d) {\n return d.id;\n })\n .html(function(d) {\n if (d.data.isMarriage) {\n return opts.callbacks.marriageRenderer(\n d.x,\n d.y,\n marriageSize[0],\n marriageSize[1],\n d.data.extra,\n d.data.id,\n d.data.class\n )\n } else {\n return opts.callbacks.nodeRenderer(\n d.data.name,\n d.x,\n d.y,\n nodeSize[0],\n nodeSize[1],\n d.data.extra,\n d.data.id,\n d.data.class,\n d.data.textClass,\n opts.callbacks.textRenderer\n )\n }\n })\n .on('dblclick', function () {\n // do not propagate a double click on a node\n // to prevent the zoom from being triggered\n d3.event.stopPropagation();\n })\n .on('click', function(d)  {\n // ignore double-clicks and clicks on hidden nodes\n if (d3.event.detail === 2 || d.data.hidden) {\n return;\n }\n if (d.data.isMarriage) {\n opts.callbacks.marriageClick(d.data.extra, d.data.id);\n } else {\n opts.callbacks.nodeClick(d.data.name, d.data.extra, d.data.id);\n }\n })\n .on('contextmenu', function(d)  {\n if (d.data.hidden) {\n return;\n }\n d3.event.preventDefault();\n if (d.data.isMarriage) {\n opts.callbacks.marriageRightClick(d.data.extra, d.data.id);\n } else {\n opts.callbacks.nodeRightClick(d.data.name, d.data.extra, d.data.id);\n }\n });\n }\n\n _flatten(root) {\n let n = [];\n let i = 0;\n\n function recurse(node) {\n if (node.children) {\n node.children.forEach(recurse);\n }\n if (!node.id) {\n node.id = ++i;\n }\n n.push(node);\n }\n recurse(root);\n return n;\n }\n\n _elbow(d, i) {\n if (d.target.data.noParent) {\n return 'M0,0L0,0';\n }\n let ny = Math.round(d.target.y + (d.source.y - d.target.y) * 0.50);\n\n let linedata = [{\n x: d.target.x,\n y: d.target.y\n }, {\n x: d.target.x,\n y: ny\n }, {\n x: d.source.x,\n y: d.source.y\n }];\n\n let fun = d3.line().curve(d3.curveStepAfter)\n .x(function(d) {\n return d.x;\n })\n .y(function(d) {\n return d.y;\n });\n return fun(linedata);\n }\n\n _linkSiblings() {\n\n let allNodes = this.allNodes;\n\n _.forEach(this.siblings, function(d) {\n let start = allNodes.filter(function(v) {\n return d.source.id == v.data.id;\n });\n let end = allNodes.filter(function(v) {\n return d.target.id == v.data.id;\n });\n d.source.x = start[0].x;\n d.source.y = start[0].y;\n d.target.x = end[0].x;\n d.target.y = end[0].y;\n\n let marriageId = (start[0].data.marriageNode != null ?\n start[0].data.marriageNode.id :\n end[0].data.marriageNode.id);\n let marriageNode = allNodes.find(function(n) {\n return n.data.id == marriageId;\n });\n d.source.marriageNode = marriageNode;\n d.target.marriageNode = marriageNode;\n });\n\n }\n\n _siblingLine(d, i) {\n\n let ny = Math.round(d.target.y + (d.source.y - d.target.y) * 0.50);\n let nodeWidth = this.nodeSize[0];\n let nodeHeight = this.nodeSize[1];\n\n // Not first marriage\n if (d.number > 0) {\n ny -= Math.round(nodeHeight * 8 / 10);\n }\n\n let linedata = [{\n x: d.source.x,\n y: d.source.y\n }, {\n x: Math.round(d.source.x + nodeWidth * 6 / 10),\n y: d.source.y\n }, {\n x: Math.round(d.source.x + nodeWidth * 6 / 10),\n y: ny\n }, {\n x: d.target.marriageNode.x,\n y: ny\n }, {\n x: d.target.marriageNode.x,\n y: d.target.y\n }, {\n x: d.target.x,\n y: d.target.y\n }];\n\n let fun = d3.line().curve(d3.curveStepAfter)\n .x(function(d) {\n return d.x;\n })\n .y(function(d) {\n return d.y;\n });\n return fun(linedata);\n }\n\n static _nodeHeightSeperation(nodeWidth, nodeMaxHeight) {\n return nodeMaxHeight + 25;\n }\n\n static _nodeSize(nodes, width, textRenderer) {\n let maxWidth = 0;\n let maxHeight = 0;\n let tmpSvg = document.createElement('svg');\n document.body.appendChild(tmpSvg);\n\n _.map(nodes, function(n) {\n let container = document.createElement('div');\n container.setAttribute('class', n.data.class);\n container.style.visibility = 'hidden';\n container.style.maxWidth = width + 'px';\n\n let text = textRenderer(n.data.name, n.data.extra, n.data.textClass);\n container.innerHTML = text;\n\n tmpSvg.appendChild(container);\n let height = container.offsetHeight;\n tmpSvg.removeChild(container);\n\n maxHeight = Math.max(maxHeight, height);\n n.cHeight = height;\n if (n.data.hidden) {\n n.cWidth = 0;\n } else {\n n.cWidth = width;\n }\n });\n document.body.removeChild(tmpSvg);\n\n return [width, maxHeight];\n }\n\n static _marriageSize (nodes, size) {\n _.map(nodes, function (n) {\n if (!n.data.hidden) {\n n.cHeight = size;\n n.cWidth = size;\n }\n });\n\n return [size, size]\n }\n\n static _nodeRenderer(name, x, y, height, width, extra, id, nodeClass, textClass, textRenderer) {\n let node = '';\n node += '
\\n';\n node += textRenderer(name, extra, textClass);\n node += '
';\n return node;\n }\n\n static _textRenderer(name, extra, textClass) {\n let node = '';\n node += '

\\n';\n node += name;\n node += '

\\n';\n return node;\n }\n\n static _marriageRenderer (x, y, height, width, extra, id, nodeClass) {\n return `
`\n }\n\n static _debug(msg) {\n if (TreeBuilder.DEBUG_LEVEL > 0)  {\n console.log(msg);\n }\n }\n\n}\n\nconst dTree = {\n\n VERSION: '2.3.0',\n\n init: function(data, options = {}) {\n\n var opts = _.defaultsDeep(options || {}, {\n target: '#graph',\n debug: false,\n width: 600,\n height: 600,\n hideMarriageNodes: true,\n callbacks: {\n nodeClick: function(name, extra, id) {},\n nodeRightClick: function(name, extra, id) {},\n marriageClick: function(extra, id) {},\n marriageRightClick: function(extra, id) {},\n nodeHeightSeperation: function(nodeWidth, nodeMaxHeight) {\n return TreeBuilder._nodeHeightSeperation(nodeWidth, nodeMaxHeight);\n },\n nodeRenderer: function(name, x, y, height, width, extra, id, nodeClass, textClass, textRenderer) {\n return TreeBuilder._nodeRenderer(name, x, y, height, width, extra,\n id,nodeClass, textClass, textRenderer);\n },\n nodeSize: function(nodes, width, textRenderer) {\n return TreeBuilder._nodeSize(nodes, width, textRenderer);\n },\n nodeSorter: function(aName, aExtra, bName, bExtra) {return 0;},\n textRenderer: function(name, extra, textClass) {\n return TreeBuilder._textRenderer(name, extra, textClass);\n },\n marriageRenderer: function (x, y, height, width, extra, id, nodeClass) {\n return TreeBuilder._marriageRenderer(x, y, height, width, extra, id, nodeClass)\n },\n marriageSize: function (nodes, size) {\n return TreeBuilder._marriageSize(nodes, size)\n },\n },\n margin: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n },\n nodeWidth: 100,\n marriageNodeSize: 10,\n styles: {\n node: 'node',\n marriageNode: 'marriageNode',\n linage: 'linage',\n marriage: 'marriage',\n text: 'nodeText'\n }\n });\n\n var data = this._preprocess(data, opts);\n var treeBuilder = new TreeBuilder(data.root, data.siblings, opts);\n treeBuilder.create();\n\n function _zoomTo (x, y, zoom = 1, duration = 500) {\n treeBuilder.svg\n .transition()\n .duration(duration)\n .call(\n treeBuilder.zoom.transform,\n d3.zoomIdentity\n .translate(opts.width / 2, opts.height / 2)\n .scale(zoom)\n .translate(-x, -y)\n );\n }\n\n return {\n resetZoom: function (duration = 500) {\n treeBuilder.svg\n .transition()\n .duration(duration)\n .call(\n treeBuilder.zoom.transform,\n d3.zoomIdentity.translate(opts.width / 2, opts.margin.top).scale(1)\n );\n },\n zoomTo: _zoomTo,\n zoomToNode: function (nodeId, zoom = 2, duration = 500) {\n const node = _.find(treeBuilder.allNodes, {data: {id: nodeId}});\n if (node) {\n _zoomTo(node.x, node.y, zoom, duration);\n }\n },\n zoomToFit: function (duration = 500) {\n const groupBounds = treeBuilder.g.node().getBBox();\n const width = groupBounds.width;\n const height = groupBounds.height;\n const fullWidth = treeBuilder.svg.node().clientWidth;\n const fullHeight = treeBuilder.svg.node().clientHeight;\n const scale = 0.95 / Math.max(width / fullWidth, height / fullHeight);\n\n treeBuilder.svg\n .transition()\n .duration(duration)\n .call(\n treeBuilder.zoom.transform,\n d3.zoomIdentity\n .translate(\n fullWidth / 2 - scale * (groupBounds.x + width / 2),\n fullHeight / 2 - scale * (groupBounds.y + height / 2)\n )\n .scale(scale)\n );\n }\n }\n },\n\n _preprocess: function(data, opts) {\n\n var siblings = [];\n var id = 0;\n\n var root = {\n name: '',\n id: id++,\n hidden: true,\n children: []\n };\n\n var reconstructTree = function(person, parent) {\n\n // convert to person to d3 node\n var node = {\n name: person.name,\n id: id++,\n hidden: false,\n children: [],\n extra: person.extra,\n textClass: person.textClass ? person.textClass : opts.styles.text,\n class: person.class ? person.class : opts.styles.node\n };\n\n // hide linages to the hidden root node\n if (parent == root) {\n node.noParent = true;\n }\n\n // apply depth offset\n for (var i = 0; i < person.depthOffset; i++) {\n var pushNode = {\n name: '',\n id: id++,\n hidden: true,\n children: [],\n noParent: node.noParent\n };\n parent.children.push(pushNode);\n parent = pushNode;\n }\n\n // sort children\n dTree._sortPersons(person.children, opts);\n\n // add \"direct\" children\n _.forEach(person.children, function(child) {\n reconstructTree(child, node);\n });\n\n parent.children.push(node);\n\n //sort marriages\n dTree._sortMarriages(person.marriages, opts);\n\n // go through marriage\n _.forEach(person.marriages, function(marriage, index) {\n var m = {\n name: '',\n id: id++,\n hidden: opts.hideMarriageNodes,\n noParent: true,\n children: [],\n isMarriage: true,\n extra: marriage.extra,\n class: marriage.class ? marriage.class : opts.styles.marriageNode\n };\n\n var sp = marriage.spouse;\n\n var spouse = {\n name: sp.name,\n id: id++,\n hidden: false,\n noParent: true,\n children: [],\n textClass: sp.textClass ? sp.textClass : opts.styles.text,\n class: sp.class ? sp.class : opts.styles.node,\n extra: sp.extra,\n marriageNode: m\n };\n\n parent.children.push(m, spouse);\n\n dTree._sortPersons(marriage.children, opts);\n _.forEach(marriage.children, function(child) {\n reconstructTree(child, m);\n });\n\n siblings.push({\n source: {\n id: node.id\n },\n target: {\n id: spouse.id\n },\n number: index\n });\n });\n\n };\n\n _.forEach(data, function(person) {\n reconstructTree(person, root);\n });\n\n return {\n root: d3.hierarchy(root),\n siblings: siblings\n };\n\n },\n\n _sortPersons: function(persons, opts) {\n if (persons != undefined) {\n persons.sort(function(a, b) {\n return opts.callbacks.nodeSorter(a.name, a.extra, b.name, b.extra);\n });\n }\n return persons;\n },\n\n _sortMarriages: function(marriages, opts) {\n if (marriages != undefined && Array.isArray(marriages)) {\n marriages.sort(function(marriageA, marriageB) {\n var a = marriageA.spouse;\n var b = marriageB.spouse;\n return opts.callbacks.nodeSorter(a.name, a.extra, b.name, b.extra);\n });\n }\n return marriages;\n }\n\n};\n\nreturn dTree;\n\n})));\n"]} \ No newline at end of file +{"version":3,"sources":["dTree.js"],"names":[],"mappings":"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","file":"dTree.js","sourcesContent":["(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n\ttypeof define === 'function' && define.amd ? define(factory) :\n\t(global.dTree = factory());\n}(this, (function () { 'use strict';\n\nclass TreeBuilder {\n\n constructor(root, siblings, opts) {\n TreeBuilder.DEBUG_LEVEL = opts.debug ? 1 : 0;\n\n this.root = root;\n this.siblings = siblings;\n this.opts = opts;\n\n // flatten nodes\n this.allNodes = this._flatten(this.root);\n\n // calculate node sizes\n this.nodeSize = opts.callbacks.nodeSize.call(this,\n // filter hidden and marriage nodes\n _.filter(\n this.allNodes,\n node => !(node.hidden || _.get(node, 'data.isMarriage'))\n ),\n opts.nodeWidth,\n opts.callbacks.textRenderer\n );\n this.marriageSize = opts.callbacks.marriageSize.call(this,\n // filter hidden and non marriage nodes\n _.filter(\n this.allNodes,\n node => !node.hidden && _.get(node, 'data.isMarriage')\n ),\n this.opts.marriageNodeSize\n );\n }\n\n create() {\n\n let opts = this.opts;\n let allNodes = this.allNodes;\n let nodeSize = this.nodeSize;\n\n let width = opts.width + opts.margin.left + opts.margin.right;\n let height = opts.height + opts.margin.top + opts.margin.bottom;\n\n // create zoom handler\n const zoom = this.zoom = d3.zoom()\n .scaleExtent([0.1, 10])\n .on('zoom', function () {\n g.attr('transform', d3.event.transform);\n });\n\n // make a svg\n const svg = this.svg = d3.select(opts.target)\n .append('svg')\n .attr('viewBox', [0, 0, width, height])\n .call(zoom);\n\n // create svg group that holds all nodes\n const g = this.g = svg.append('g');\n\n // set zoom identity\n svg.call(zoom.transform, d3.zoomIdentity.translate(width / 2, opts.margin.top).scale(1));\n\n // Compute the layout.\n this.tree = d3.tree()\n .nodeSize([nodeSize[0] * 2,\n opts.callbacks.nodeHeightSeperation.call(this, nodeSize[0], nodeSize[1])]);\n\n this.tree.separation(function separation(a, b) {\n if (a.data.hidden || b.data.hidden) {\n return 0.3;\n } else {\n return 0.6;\n }\n });\n\n this._update(this.root);\n\n }\n\n _update(source) {\n\n let opts = this.opts;\n let allNodes = this.allNodes;\n let nodeSize = this.nodeSize;\n let marriageSize = this.marriageSize;\n\n let treenodes = this.tree(source);\n let links = treenodes.links();\n\n // Create the link lines.\n this.g.selectAll('.link')\n .data(links)\n .enter()\n // filter links with no parents to prevent empty nodes\n .filter(function(l) {\n return !l.target.data.noParent;\n })\n .append('path')\n .attr('class', opts.styles.linage)\n .attr('d', this._elbow);\n\n let nodes = this.g.selectAll('.node')\n .data(treenodes.descendants())\n .enter();\n\n this._linkSiblings();\n\n // Draw siblings (marriage)\n this.g.selectAll('.sibling')\n .data(this.siblings)\n .enter()\n .append('path')\n .attr('class', opts.styles.marriage)\n .attr('d', _.bind(this._siblingLine, this));\n\n // Create the node rectangles.\n nodes.append('foreignObject')\n .filter(function(d) {\n return d.data.hidden ? false : true;\n })\n .attr('x', function(d) {\n return Math.round(d.x - d.cWidth / 2) + 'px';\n })\n .attr('y', function(d) {\n return Math.round(d.y - d.cHeight / 2) + 'px';\n })\n .attr('width', function(d) {\n return d.cWidth + 'px';\n })\n .attr('height', function(d) {\n return d.cHeight + 'px';\n })\n .attr('id', function(d) {\n return d.id;\n })\n .html(function(d) {\n if (d.data.isMarriage) {\n return opts.callbacks.marriageRenderer.call(this,\n d.x,\n d.y,\n marriageSize[0],\n marriageSize[1],\n d.data.extra,\n d.data.id,\n d.data.class\n )\n } else {\n return opts.callbacks.nodeRenderer.call(this,\n d.data.name,\n d.x,\n d.y,\n nodeSize[0],\n nodeSize[1],\n d.data.extra,\n d.data.id,\n d.data.class,\n d.data.textClass,\n opts.callbacks.textRenderer\n )\n }\n })\n .on('dblclick', function () {\n // do not propagate a double click on a node\n // to prevent the zoom from being triggered\n d3.event.stopPropagation();\n })\n .on('click', function(d)  {\n // ignore double-clicks and clicks on hidden nodes\n if (d3.event.detail === 2 || d.data.hidden) {\n return;\n }\n if (d.data.isMarriage) {\n opts.callbacks.marriageClick.call(this, d.data.extra, d.data.id);\n } else {\n opts.callbacks.nodeClick.call(this, d.data.name, d.data.extra, d.data.id);\n }\n })\n .on('contextmenu', function(d)  {\n if (d.data.hidden) {\n return;\n }\n d3.event.preventDefault();\n if (d.data.isMarriage) {\n opts.callbacks.marriageRightClick.call(this, d.data.extra, d.data.id);\n } else {\n opts.callbacks.nodeRightClick.call(this, d.data.name, d.data.extra, d.data.id);\n }\n });\n }\n\n _flatten(root) {\n let n = [];\n let i = 0;\n\n function recurse(node) {\n if (node.children) {\n node.children.forEach(recurse);\n }\n if (!node.id) {\n node.id = ++i;\n }\n n.push(node);\n }\n recurse(root);\n return n;\n }\n\n _elbow(d, i) {\n if (d.target.data.noParent) {\n return 'M0,0L0,0';\n }\n let ny = Math.round(d.target.y + (d.source.y - d.target.y) * 0.50);\n\n let linedata = [{\n x: d.target.x,\n y: d.target.y\n }, {\n x: d.target.x,\n y: ny\n }, {\n x: d.source.x,\n y: d.source.y\n }];\n\n let fun = d3.line().curve(d3.curveStepAfter)\n .x(function(d) {\n return d.x;\n })\n .y(function(d) {\n return d.y;\n });\n return fun(linedata);\n }\n\n _linkSiblings() {\n\n let allNodes = this.allNodes;\n\n _.forEach(this.siblings, function(d) {\n let start = allNodes.filter(function(v) {\n return d.source.id == v.data.id;\n });\n let end = allNodes.filter(function(v) {\n return d.target.id == v.data.id;\n });\n d.source.x = start[0].x;\n d.source.y = start[0].y;\n d.target.x = end[0].x;\n d.target.y = end[0].y;\n\n let marriageId = (start[0].data.marriageNode != null ?\n start[0].data.marriageNode.id :\n end[0].data.marriageNode.id);\n let marriageNode = allNodes.find(function(n) {\n return n.data.id == marriageId;\n });\n d.source.marriageNode = marriageNode;\n d.target.marriageNode = marriageNode;\n });\n\n }\n\n _siblingLine(d, i) {\n\n let ny = Math.round(d.target.y + (d.source.y - d.target.y) * 0.50);\n let nodeWidth = this.nodeSize[0];\n let nodeHeight = this.nodeSize[1];\n\n // Not first marriage\n if (d.number > 0) {\n ny -= Math.round(nodeHeight * 8 / 10);\n }\n\n let linedata = [{\n x: d.source.x,\n y: d.source.y\n }, {\n x: Math.round(d.source.x + nodeWidth * 6 / 10),\n y: d.source.y\n }, {\n x: Math.round(d.source.x + nodeWidth * 6 / 10),\n y: ny\n }, {\n x: d.target.marriageNode.x,\n y: ny\n }, {\n x: d.target.marriageNode.x,\n y: d.target.y\n }, {\n x: d.target.x,\n y: d.target.y\n }];\n\n let fun = d3.line().curve(d3.curveStepAfter)\n .x(function(d) {\n return d.x;\n })\n .y(function(d) {\n return d.y;\n });\n return fun(linedata);\n }\n\n static _nodeHeightSeperation(nodeWidth, nodeMaxHeight) {\n return nodeMaxHeight + 25;\n }\n\n static _nodeSize(nodes, width, textRenderer) {\n let maxWidth = 0;\n let maxHeight = 0;\n let tmpSvg = document.createElement('svg');\n document.body.appendChild(tmpSvg);\n\n _.map(nodes, function(n) {\n let container = document.createElement('div');\n container.setAttribute('class', n.data.class);\n container.style.visibility = 'hidden';\n container.style.maxWidth = width + 'px';\n\n let text = textRenderer(n.data.name, n.data.extra, n.data.textClass);\n container.innerHTML = text;\n\n tmpSvg.appendChild(container);\n let height = container.offsetHeight;\n tmpSvg.removeChild(container);\n\n maxHeight = Math.max(maxHeight, height);\n n.cHeight = height;\n if (n.data.hidden) {\n n.cWidth = 0;\n } else {\n n.cWidth = width;\n }\n });\n document.body.removeChild(tmpSvg);\n\n return [width, maxHeight];\n }\n\n static _marriageSize (nodes, size) {\n _.map(nodes, function (n) {\n if (!n.data.hidden) {\n n.cHeight = size;\n n.cWidth = size;\n }\n });\n\n return [size, size]\n }\n\n static _nodeRenderer(name, x, y, height, width, extra, id, nodeClass, textClass, textRenderer) {\n let node = '';\n node += '
\\n';\n node += textRenderer(name, extra, textClass);\n node += '
';\n return node;\n }\n\n static _textRenderer(name, extra, textClass) {\n let node = '';\n node += '

\\n';\n node += name;\n node += '

\\n';\n return node;\n }\n\n static _marriageRenderer (x, y, height, width, extra, id, nodeClass) {\n return `
`\n }\n\n static _debug(msg) {\n if (TreeBuilder.DEBUG_LEVEL > 0)  {\n console.log(msg);\n }\n }\n\n}\n\nconst dTree = {\n\n VERSION: '2.4.0',\n\n init: function(data, options = {}) {\n\n var opts = _.defaultsDeep(options || {}, {\n target: '#graph',\n debug: false,\n width: 600,\n height: 600,\n hideMarriageNodes: true,\n callbacks: {\n nodeClick: function(name, extra, id) {},\n nodeRightClick: function(name, extra, id) {},\n marriageClick: function(extra, id) {},\n marriageRightClick: function(extra, id) {},\n nodeHeightSeperation: function(nodeWidth, nodeMaxHeight) {\n return TreeBuilder._nodeHeightSeperation(nodeWidth, nodeMaxHeight);\n },\n nodeRenderer: function(name, x, y, height, width, extra, id, nodeClass, textClass, textRenderer) {\n return TreeBuilder._nodeRenderer(name, x, y, height, width, extra,\n id,nodeClass, textClass, textRenderer);\n },\n nodeSize: function(nodes, width, textRenderer) {\n return TreeBuilder._nodeSize(nodes, width, textRenderer);\n },\n nodeSorter: function(aName, aExtra, bName, bExtra) {return 0;},\n textRenderer: function(name, extra, textClass) {\n return TreeBuilder._textRenderer(name, extra, textClass);\n },\n marriageRenderer: function (x, y, height, width, extra, id, nodeClass) {\n return TreeBuilder._marriageRenderer(x, y, height, width, extra, id, nodeClass)\n },\n marriageSize: function (nodes, size) {\n return TreeBuilder._marriageSize(nodes, size)\n },\n },\n margin: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n },\n nodeWidth: 100,\n marriageNodeSize: 10,\n styles: {\n node: 'node',\n marriageNode: 'marriageNode',\n linage: 'linage',\n marriage: 'marriage',\n text: 'nodeText'\n }\n });\n\n var data = this._preprocess(data, opts);\n var treeBuilder = new TreeBuilder(data.root, data.siblings, opts);\n treeBuilder.create();\n\n function _zoomTo (x, y, zoom = 1, duration = 500) {\n treeBuilder.svg\n .transition()\n .duration(duration)\n .call(\n treeBuilder.zoom.transform,\n d3.zoomIdentity\n .translate(opts.width / 2, opts.height / 2)\n .scale(zoom)\n .translate(-x, -y)\n );\n }\n\n return {\n resetZoom: function (duration = 500) {\n treeBuilder.svg\n .transition()\n .duration(duration)\n .call(\n treeBuilder.zoom.transform,\n d3.zoomIdentity.translate(opts.width / 2, opts.margin.top).scale(1)\n );\n },\n zoomTo: _zoomTo,\n zoomToNode: function (nodeId, zoom = 2, duration = 500) {\n const node = _.find(treeBuilder.allNodes, {data: {id: nodeId}});\n if (node) {\n _zoomTo(node.x, node.y, zoom, duration);\n }\n },\n zoomToFit: function (duration = 500) {\n const groupBounds = treeBuilder.g.node().getBBox();\n const width = groupBounds.width;\n const height = groupBounds.height;\n const fullWidth = treeBuilder.svg.node().clientWidth;\n const fullHeight = treeBuilder.svg.node().clientHeight;\n const scale = 0.95 / Math.max(width / fullWidth, height / fullHeight);\n\n treeBuilder.svg\n .transition()\n .duration(duration)\n .call(\n treeBuilder.zoom.transform,\n d3.zoomIdentity\n .translate(\n fullWidth / 2 - scale * (groupBounds.x + width / 2),\n fullHeight / 2 - scale * (groupBounds.y + height / 2)\n )\n .scale(scale)\n );\n }\n }\n },\n\n _preprocess: function(data, opts) {\n\n var siblings = [];\n var id = 0;\n\n var root = {\n name: '',\n id: id++,\n hidden: true,\n children: []\n };\n\n var reconstructTree = function(person, parent) {\n\n // convert to person to d3 node\n var node = {\n name: person.name,\n id: id++,\n hidden: false,\n children: [],\n extra: person.extra,\n textClass: person.textClass ? person.textClass : opts.styles.text,\n class: person.class ? person.class : opts.styles.node\n };\n\n // hide linages to the hidden root node\n if (parent == root) {\n node.noParent = true;\n }\n\n // apply depth offset\n for (var i = 0; i < person.depthOffset; i++) {\n var pushNode = {\n name: '',\n id: id++,\n hidden: true,\n children: [],\n noParent: node.noParent\n };\n parent.children.push(pushNode);\n parent = pushNode;\n }\n\n // sort children\n dTree._sortPersons(person.children, opts);\n\n // add \"direct\" children\n _.forEach(person.children, function(child) {\n reconstructTree(child, node);\n });\n\n parent.children.push(node);\n\n //sort marriages\n dTree._sortMarriages(person.marriages, opts);\n\n // go through marriage\n _.forEach(person.marriages, function(marriage, index) {\n var m = {\n name: '',\n id: id++,\n hidden: opts.hideMarriageNodes,\n noParent: true,\n children: [],\n isMarriage: true,\n extra: marriage.extra,\n class: marriage.class ? marriage.class : opts.styles.marriageNode\n };\n\n var sp = marriage.spouse;\n\n var spouse = {\n name: sp.name,\n id: id++,\n hidden: false,\n noParent: true,\n children: [],\n textClass: sp.textClass ? sp.textClass : opts.styles.text,\n class: sp.class ? sp.class : opts.styles.node,\n extra: sp.extra,\n marriageNode: m\n };\n\n parent.children.push(m, spouse);\n\n dTree._sortPersons(marriage.children, opts);\n _.forEach(marriage.children, function(child) {\n reconstructTree(child, m);\n });\n\n siblings.push({\n source: {\n id: node.id\n },\n target: {\n id: spouse.id\n },\n number: index\n });\n });\n\n };\n\n _.forEach(data, function(person) {\n reconstructTree(person, root);\n });\n\n return {\n root: d3.hierarchy(root),\n siblings: siblings\n };\n\n },\n\n _sortPersons: function(persons, opts) {\n if (persons != undefined) {\n persons.sort(function(a, b) {\n return opts.callbacks.nodeSorter.call(this, a.name, a.extra, b.name, b.extra);\n });\n }\n return persons;\n },\n\n _sortMarriages: function(marriages, opts) {\n if (marriages != undefined && Array.isArray(marriages)) {\n marriages.sort(function(marriageA, marriageB) {\n var a = marriageA.spouse;\n var b = marriageB.spouse;\n return opts.callbacks.nodeSorter.call(this, a.name, a.extra, b.name, b.extra);\n });\n }\n return marriages;\n }\n\n};\n\nreturn dTree;\n\n})));\n"]} \ No newline at end of file diff --git a/dist/dTree.min.js b/dist/dTree.min.js index efc8ddf..95a9d85 100644 --- a/dist/dTree.min.js +++ b/dist/dTree.min.js @@ -1,2 +1,2 @@ -function _classCallCheck(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var _createClass=function(){function e(e,t){for(var a=0;a0&&(a-=Math.round(8*n/10));var i=[{x:e.source.x,y:e.source.y},{x:Math.round(e.source.x+6*r/10),y:e.source.y},{x:Math.round(e.source.x+6*r/10),y:a},{x:e.target.marriageNode.x,y:a},{x:e.target.marriageNode.x,y:e.target.y},{x:e.target.x,y:e.target.y}],o=d3.line().curve(d3.curveStepAfter).x(function(e){return e.x}).y(function(e){return e.y});return o(i)}}],[{key:"_nodeHeightSeperation",value:function(e,t){return t+25}},{key:"_nodeSize",value:function(e,t,a){var r=0,n=document.createElement("svg");return document.body.appendChild(n),_.map(e,function(e){var i=document.createElement("div");i.setAttribute("class",e.data["class"]),i.style.visibility="hidden",i.style.maxWidth=t+"px";var o=a(e.data.name,e.data.extra,e.data.textClass);i.innerHTML=o,n.appendChild(i);var d=i.offsetHeight;n.removeChild(i),r=Math.max(r,d),e.cHeight=d,e.data.hidden?e.cWidth=0:e.cWidth=t}),document.body.removeChild(n),[t,r]}},{key:"_marriageSize",value:function(e,t){return _.map(e,function(e){e.data.hidden||(e.cHeight=t,e.cWidth=t)}),[t,t]}},{key:"_nodeRenderer",value:function(e,t,a,r,n,i,o,d,s,c){var l="";return l+="
\n',l+=c(e,i,s),l+="
"}},{key:"_textRenderer",value:function(e,t,a){var r="";return r+="

\n',r+=e,r+="

\n"}},{key:"_marriageRenderer",value:function(e,t,a,r,n,i,o){return'
'}},{key:"_debug",value:function(t){e.DEBUG_LEVEL>0&&console.log(t)}}]),e}(),t={VERSION:"2.3.0",init:function(t){function a(e,t){var a=arguments.length<=2||void 0===arguments[2]?1:arguments[2],r=arguments.length<=3||void 0===arguments[3]?500:arguments[3];i.svg.transition().duration(r).call(i.zoom.transform,d3.zoomIdentity.translate(n.width/2,n.height/2).scale(a).translate(-e,-t))}var r=arguments.length<=1||void 0===arguments[1]?{}:arguments[1],n=_.defaultsDeep(r||{},{target:"#graph",debug:!1,width:600,height:600,hideMarriageNodes:!0,callbacks:{nodeClick:function(e,t,a){},nodeRightClick:function(e,t,a){},marriageClick:function(e,t){},marriageRightClick:function(e,t){},nodeHeightSeperation:function(t,a){return e._nodeHeightSeperation(t,a)},nodeRenderer:function(t,a,r,n,i,o,d,s,c,l){return e._nodeRenderer(t,a,r,n,i,o,d,s,c,l)},nodeSize:function(t,a,r){return e._nodeSize(t,a,r)},nodeSorter:function(e,t,a,r){return 0},textRenderer:function(t,a,r){return e._textRenderer(t,a,r)},marriageRenderer:function(t,a,r,n,i,o,d){return e._marriageRenderer(t,a,r,n,i,o,d)},marriageSize:function(t,a){return e._marriageSize(t,a)}},margin:{top:0,right:0,bottom:0,left:0},nodeWidth:100,marriageNodeSize:10,styles:{node:"node",marriageNode:"marriageNode",linage:"linage",marriage:"marriage",text:"nodeText"}}),t=this._preprocess(t,n),i=new e(t.root,t.siblings,n);return i.create(),{resetZoom:function(){var e=arguments.length<=0||void 0===arguments[0]?500:arguments[0];i.svg.transition().duration(e).call(i.zoom.transform,d3.zoomIdentity.translate(n.width/2,n.margin.top).scale(1))},zoomTo:a,zoomToNode:function(e){var t=arguments.length<=1||void 0===arguments[1]?2:arguments[1],r=arguments.length<=2||void 0===arguments[2]?500:arguments[2],n=_.find(i.allNodes,{data:{id:e}});n&&a(n.x,n.y,t,r)},zoomToFit:function(){var e=arguments.length<=0||void 0===arguments[0]?500:arguments[0],t=i.g.node().getBBox(),a=t.width,r=t.height,n=i.svg.node().clientWidth,o=i.svg.node().clientHeight,d=.95/Math.max(a/n,r/o);i.svg.transition().duration(e).call(i.zoom.transform,d3.zoomIdentity.translate(n/2-d*(t.x+a/2),o/2-d*(t.y+r/2)).scale(d))}}},_preprocess:function(e,a){var r=[],n=0,i={name:"",id:n++,hidden:!0,children:[]},o=function d(e,o){var s={name:e.name,id:n++,hidden:!1,children:[],extra:e.extra,textClass:e.textClass?e.textClass:a.styles.text,"class":e["class"]?e["class"]:a.styles.node};o==i&&(s.noParent=!0);for(var c=0;c0&&(a-=Math.round(8*n/10));var i=[{x:e.source.x,y:e.source.y},{x:Math.round(e.source.x+6*r/10),y:e.source.y},{x:Math.round(e.source.x+6*r/10),y:a},{x:e.target.marriageNode.x,y:a},{x:e.target.marriageNode.x,y:e.target.y},{x:e.target.x,y:e.target.y}],o=d3.line().curve(d3.curveStepAfter).x(function(e){return e.x}).y(function(e){return e.y});return o(i)}}],[{key:"_nodeHeightSeperation",value:function(e,t){return t+25}},{key:"_nodeSize",value:function(e,t,a){var r=0,n=document.createElement("svg");return document.body.appendChild(n),_.map(e,function(e){var i=document.createElement("div");i.setAttribute("class",e.data["class"]),i.style.visibility="hidden",i.style.maxWidth=t+"px";var o=a(e.data.name,e.data.extra,e.data.textClass);i.innerHTML=o,n.appendChild(i);var d=i.offsetHeight;n.removeChild(i),r=Math.max(r,d),e.cHeight=d,e.data.hidden?e.cWidth=0:e.cWidth=t}),document.body.removeChild(n),[t,r]}},{key:"_marriageSize",value:function(e,t){return _.map(e,function(e){e.data.hidden||(e.cHeight=t,e.cWidth=t)}),[t,t]}},{key:"_nodeRenderer",value:function(e,t,a,r,n,i,o,d,s,l){var c="";return c+="
\n',c+=l(e,i,s),c+="
"}},{key:"_textRenderer",value:function(e,t,a){var r="";return r+="

\n',r+=e,r+="

\n"}},{key:"_marriageRenderer",value:function(e,t,a,r,n,i,o){return'
'}},{key:"_debug",value:function(t){e.DEBUG_LEVEL>0&&console.log(t)}}]),e}(),t={VERSION:"2.4.0",init:function(t){function a(e,t){var a=arguments.length<=2||void 0===arguments[2]?1:arguments[2],r=arguments.length<=3||void 0===arguments[3]?500:arguments[3];i.svg.transition().duration(r).call(i.zoom.transform,d3.zoomIdentity.translate(n.width/2,n.height/2).scale(a).translate(-e,-t))}var r=arguments.length<=1||void 0===arguments[1]?{}:arguments[1],n=_.defaultsDeep(r||{},{target:"#graph",debug:!1,width:600,height:600,hideMarriageNodes:!0,callbacks:{nodeClick:function(e,t,a){},nodeRightClick:function(e,t,a){},marriageClick:function(e,t){},marriageRightClick:function(e,t){},nodeHeightSeperation:function(t,a){return e._nodeHeightSeperation(t,a)},nodeRenderer:function(t,a,r,n,i,o,d,s,l,c){return e._nodeRenderer(t,a,r,n,i,o,d,s,l,c)},nodeSize:function(t,a,r){return e._nodeSize(t,a,r)},nodeSorter:function(e,t,a,r){return 0},textRenderer:function(t,a,r){return e._textRenderer(t,a,r)},marriageRenderer:function(t,a,r,n,i,o,d){return e._marriageRenderer(t,a,r,n,i,o,d)},marriageSize:function(t,a){return e._marriageSize(t,a)}},margin:{top:0,right:0,bottom:0,left:0},nodeWidth:100,marriageNodeSize:10,styles:{node:"node",marriageNode:"marriageNode",linage:"linage",marriage:"marriage",text:"nodeText"}}),t=this._preprocess(t,n),i=new e(t.root,t.siblings,n);return i.create(),{resetZoom:function(){var e=arguments.length<=0||void 0===arguments[0]?500:arguments[0];i.svg.transition().duration(e).call(i.zoom.transform,d3.zoomIdentity.translate(n.width/2,n.margin.top).scale(1))},zoomTo:a,zoomToNode:function(e){var t=arguments.length<=1||void 0===arguments[1]?2:arguments[1],r=arguments.length<=2||void 0===arguments[2]?500:arguments[2],n=_.find(i.allNodes,{data:{id:e}});n&&a(n.x,n.y,t,r)},zoomToFit:function(){var e=arguments.length<=0||void 0===arguments[0]?500:arguments[0],t=i.g.node().getBBox(),a=t.width,r=t.height,n=i.svg.node().clientWidth,o=i.svg.node().clientHeight,d=.95/Math.max(a/n,r/o);i.svg.transition().duration(e).call(i.zoom.transform,d3.zoomIdentity.translate(n/2-d*(t.x+a/2),o/2-d*(t.y+r/2)).scale(d))}}},_preprocess:function(e,a){var r=[],n=0,i={name:"",id:n++,hidden:!0,children:[]},o=function d(e,o){var s={name:e.name,id:n++,hidden:!1,children:[],extra:e.extra,textClass:e.textClass?e.textClass:a.styles.text,"class":e["class"]?e["class"]:a.styles.node};o==i&&(s.noParent=!0);for(var l=0;l