Skip to content

Commit

Permalink
Merge pull request #100 from MrMartiniMo/65-add-support-for-a-custom-…
Browse files Browse the repository at this point in the history
…renderer-for-marriages

feat(#65): add custom renderer for marriages
  • Loading branch information
ErikGartner authored Apr 24, 2020
2 parents 91c4c28 + b4111d6 commit cb562f1
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 23 deletions.
87 changes: 68 additions & 19 deletions src/builder.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,24 @@ class TreeBuilder {
// flatten nodes
this.allNodes = this._flatten(this.root);

// Calculate node size
let visibleNodes = _.filter(this.allNodes, function(n) {
return !n.hidden;
});
this.nodeSize = opts.callbacks.nodeSize(visibleNodes,
opts.nodeWidth, opts.callbacks.textRenderer);
// calculate node sizes
this.nodeSize = opts.callbacks.nodeSize(
// filter hidden and marriage nodes
_.filter(
this.allNodes,
node => !(node.hidden || _.get(node, 'data.isMarriage'))
),
opts.nodeWidth,
opts.callbacks.textRenderer
)
this.marriageSize = opts.callbacks.marriageSize(
// filter hidden and non marriage nodes
_.filter(
this.allNodes,
node => !node.hidden && _.get(node, 'data.isMarriage')
),
this.opts.marriageNodeSize
)
}

create() {
Expand Down Expand Up @@ -68,6 +80,7 @@ class TreeBuilder {
let opts = this.opts;
let allNodes = this.allNodes;
let nodeSize = this.nodeSize;
let marriageSize = this.marriageSize;

let treenodes = this.tree(source);
let links = treenodes.links();
Expand Down Expand Up @@ -119,17 +132,30 @@ class TreeBuilder {
return d.id;
})
.html(function(d) {
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);
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
)
} 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
)
}
})
.on('dblclick', function () {
// do not propagate a double click on a node
Expand All @@ -141,14 +167,22 @@ class TreeBuilder {
if (d3.event.detail === 2 || d.data.hidden) {
return;
}
opts.callbacks.nodeClick(d.data.name, d.data.extra, d.data.id);
if (d.data.isMarriage) {
opts.callbacks.marriageClick(d.data.extra, d.data.id)
} else {
opts.callbacks.nodeClick(d.data.name, d.data.extra, d.data.id)
}
})
.on('contextmenu', function(d)  {
if (d.data.hidden) {
return;
}
d3.event.preventDefault();
opts.callbacks.nodeRightClick(d.data.name, d.data.extra, d.data.id);
if (d.data.isMarriage) {
opts.callbacks.marriageRightClick(d.data.extra, d.data.id)
} else {
opts.callbacks.nodeRightClick(d.data.name, d.data.extra, d.data.id)
}
});
}

Expand Down Expand Up @@ -301,6 +335,17 @@ class TreeBuilder {
return [width, maxHeight];
}

static _marriageSize (nodes, size) {
_.map(nodes, function (n) {
if (!n.data.hidden) {
n.cHeight = size
n.cWidth = size
}
})

return [size, size]
}

static _nodeRenderer(name, x, y, height, width, extra, id, nodeClass, textClass, textRenderer) {
let node = '';
node += '<div ';
Expand All @@ -322,6 +367,10 @@ class TreeBuilder {
return node;
}

static _marriageRenderer (x, y, height, width, extra, id, nodeClass) {
return `<div style="height:100%" class="${nodeClass}" id="node${id}"></div>`
}

static _debug(msg) {
if (TreeBuilder.DEBUG_LEVEL > 0)  {
console.log(msg);
Expand Down
20 changes: 16 additions & 4 deletions src/dtree.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,12 @@ const dTree = {
debug: false,
width: 600,
height: 600,
hideMarriageNodes: true,
callbacks: {
nodeClick: function(name, extra, id) {},
nodeRightClick: function(name, extra, id) {},
marriageClick: function(extra, id) {},
marriageRightClick: function(extra, id) {},
nodeHeightSeperation: function(nodeWidth, nodeMaxHeight) {
return TreeBuilder._nodeHeightSeperation(nodeWidth, nodeMaxHeight);
},
Expand All @@ -28,6 +31,12 @@ const dTree = {
textRenderer: function(name, extra, textClass) {
return TreeBuilder._textRenderer(name, extra, textClass);
},
marriageRenderer: function (x, y, height, width, extra, id, nodeClass) {
return TreeBuilder._marriageRenderer(x, y, height, width, extra, id, nodeClass)
},
marriageSize: function (nodes, size) {
return TreeBuilder._marriageSize(nodes, size)
},
},
margin: {
top: 0,
Expand All @@ -36,8 +45,10 @@ const dTree = {
left: 0
},
nodeWidth: 100,
marriageNodeSize: 10,
styles: {
node: 'node',
marriageNode: 'marriageNode',
linage: 'linage',
marriage: 'marriage',
text: 'nodeText'
Expand Down Expand Up @@ -160,15 +171,16 @@ const dTree = {

// go through marriage
_.forEach(person.marriages, function(marriage, index) {

var m = {
name: '',
id: id++,
hidden: true,
hidden: opts.hideMarriageNodes,
noParent: true,
children: [],
extra: marriage.extra
};
isMarriage: true,
extra: marriage.extra,
class: marriage.class ? marriage.class : opts.styles.marriageNode
}

var sp = marriage.spouse;

Expand Down

0 comments on commit cb562f1

Please sign in to comment.