From 60ea055d91a9e1fb92b89afaa3daa4ef06714e64 Mon Sep 17 00:00:00 2001 From: Mike Bostock Date: Sun, 10 Mar 2019 22:25:24 -0700 Subject: [PATCH] Add sankey.linkSort. --- src/sankey.js | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/src/sankey.js b/src/sankey.js index 5066551..be5e169 100644 --- a/src/sankey.js +++ b/src/sankey.js @@ -44,6 +44,7 @@ export default function Sankey() { id = defaultId, align = justify, sort, + linkSort, nodes = defaultNodes, links = defaultLinks, iterations = 6; @@ -91,6 +92,10 @@ export default function Sankey() { return arguments.length ? (links = typeof _ === "function" ? _ : constant(_), sankey) : links; }; + sankey.linkSort = function(_) { + return arguments.length ? (linkSort = _, sankey) : linkSort; + }; + sankey.size = function(_) { return arguments.length ? (x0 = y0 = 0, x1 = +_[0], y1 = +_[1], sankey) : [x1 - x0, y1 - y0]; }; @@ -182,11 +187,11 @@ export default function Sankey() { for (var i = 0, n = iterations; i < n; ++i) { const a = Math.pow(0.99, i); const b = (i + 1) / n; - reorderLinks(); + reorderLinks(graph); relaxRightToLeft(a); resolveCollisionsTopToBottom(b); resolveCollisionsBottomToTop(b); - reorderLinks(); + reorderLinks(graph); relaxLeftToRight(a); resolveCollisionsTopToBottom(b); resolveCollisionsBottomToTop(b); @@ -210,14 +215,10 @@ export default function Sankey() { graph.links.forEach(function(link) { link.width = link.value * ky; }); - } - function reorderLinks() { - columns.forEach(function(nodes) { - nodes.forEach(function(node) { - node.sourceLinks.sort(ascendingTargetBreadth); - node.targetLinks.sort(ascendingSourceBreadth); - }); + if (linkSort != null) graph.nodes.forEach(function(node) { + node.sourceLinks.sort(linkSort); + node.targetLinks.sort(linkSort); }); } @@ -296,11 +297,15 @@ export default function Sankey() { } } - function computeLinkBreadths(graph) { - graph.nodes.forEach(function(node) { + function reorderLinks(graph) { + if (linkSort === undefined) graph.nodes.forEach(function(node) { node.sourceLinks.sort(ascendingTargetBreadth); node.targetLinks.sort(ascendingSourceBreadth); }); + } + + function computeLinkBreadths(graph) { + reorderLinks(graph); graph.nodes.forEach(function(node) { var y0 = node.y0, y1 = y0; node.sourceLinks.forEach(function(link) {