From 5afc2c862bfca3106a93f49ed130d20c80d7fca5 Mon Sep 17 00:00:00 2001 From: Michael Kelly Date: Wed, 17 Jan 2018 19:02:46 -0800 Subject: [PATCH] Fix bug 1431162: Fix errors in crontabber_status.js due to D3/sankey updates. - Fix some inconsistent indenting that was failing eslint. - The `d.x`, `d.y`, and `d.dy` attributes on sankey datums appears to have been replaced with `d.x0`, `d.x1`, `d.y0`, and `d.y1`. So we replace all old attributes with the new ones (dy is computed from y0 and y1). - Pass nodes and links via the sankey constructor. - Replace `sankey.nodeWidth` call with a property computed from the datum's `x0` and `x1` values. - Replace `sankey.update` with `sankey.relayout`. - Replace `sankey.link` with `d3.sankeyLinkHorizontal`. Most of these changes were found in the release notes on the sankey Github: https://github.com/d3/d3-sankey/releases. --- .../crashstats/js/socorro/crontabber_state.js | 67 ++++++++++--------- 1 file changed, 37 insertions(+), 30 deletions(-) diff --git a/webapp-django/crashstats/crashstats/static/crashstats/js/socorro/crontabber_state.js b/webapp-django/crashstats/crashstats/static/crashstats/js/socorro/crontabber_state.js index 1ec4b01078..9433d8a79f 100644 --- a/webapp-django/crashstats/crashstats/static/crashstats/js/socorro/crontabber_state.js +++ b/webapp-django/crashstats/crashstats/static/crashstats/js/socorro/crontabber_state.js @@ -45,19 +45,22 @@ var format = d3.format(',.0f'), return name + ' is working normally.'; }; -var svg = d3.select('#crontabber-chart').append('svg') +var svg = d3.select('#crontabber-chart') + .append('svg') .attr('width', width + margin.left + margin.right) .attr('height', height + margin.top + margin.bottom) - .append('g') - .attr('transform', - 'translate(' + margin.left + ',' + margin.top + ')'); + .append('g') + .attr( + 'transform', + 'translate(' + margin.left + ',' + margin.top + ')' + ); var sankey = d3.sankey() .nodeWidth(15) .nodePadding(10) .size([width, height]); -var path = sankey.link(); +var path = d3.sankeyLinkHorizontal(); function escapeHtml(unsafe) { return unsafe @@ -119,45 +122,49 @@ d3.json('/api/CrontabberState/', function(data) { }); }); - sankey - .nodes(nodes) - .links(links) - .layout(32); + var graph = { + nodes: nodes, + links: links + }; + sankey(graph); - var link = svg.append('g').selectAll('.link') + var link = svg.append('g') + .selectAll('path') .data(links) - .enter().append('path') + .enter() + .append('path') .attr('class', 'link') .attr('d', path) .style('stroke-width', function(d) { - return Math.max(1, d.dy); + return Math.max(1, (d.y1 - d.y0)); }) .style('stroke', function(d) { return d.color = color(d); }) - .sort(function(a, b) { return b.dy - a.dy; }); + .sort(function(a, b) { return (b.y1 - b.y0) - (a.y1 - a.y0); }); link.append('title') .text(title); - var node = svg.append('g').selectAll('.node') + var node = svg.append('g') + .selectAll('g') .data(nodes) .enter() .append('g') .attr('class', 'node') .attr('transform', function(d) { - return 'translate(' + d.x + ',' + d.y + ')'; - }) - .call(d3.behavior.drag() - .origin(function(d) { return d; }) - .on('dragstart', function() { - this.parentNode.appendChild(this); + return 'translate(' + d.x0 + ',' + d.y0 + ')'; }) - .on('drag', dragmove)); + .call(d3.drag() + .on('start', function() { + this.parentNode.appendChild(this); + }) + .on('drag', dragmove) + ); node.append('rect') - .attr('height', function(d) { return d.dy; }) - .attr('width', sankey.nodeWidth()) + .attr('height', function(d) { return d.y1 - d.y0; }) + .attr('width', function(d) { return d.x1 - d.x0; }) .style('fill', function(d) { return d.color = color(d); }) @@ -167,27 +174,27 @@ d3.json('/api/CrontabberState/', function(data) { .style('stroke', function(d) { return d3.rgb(d.color).darker(2); }) - .append('title') + .append('title') .text(title) .style(color); node.append('text') .attr('x', -6) - .attr('y', function(d) { return d.dy / 2; }) + .attr('y', function(d) { return (d.y1 - d.y0) / 2; }) .attr('dy', '.35em') .attr('text-anchor', 'end') .attr('transform', null) .text(function(d) { return d.name; }) - .filter(function(d) { return d.x < width / 2;}) + .filter(function(d) { return d.x0 < width / 2;}) .attr('x', 6 + sankey.nodeWidth()) .attr('text-anchor', 'start'); function dragmove(d) { - d.y = Math.max(0, Math.min(height - d.dy, d3.event.y)); + d.y0 = Math.max(0, Math.min(height - (d.y1 - d.y0), d3.event.y)); d3.select(this).attr( 'transform', - 'translate(' + d.x + ',' + d.y + ')'); - sankey.relayout(); + 'translate(' + d.x0 + ',' + d.y0 + ')'); + sankey.update(graph); link.attr('d', path); } @@ -212,7 +219,7 @@ d3.json('/api/CrontabberState/', function(data) { thead.append('tr').selectAll('th') .data(tableFields) - .enter().append('th') + .enter().append('th') .text(function capitalize(s) { return s[0].toUpperCase() + s.slice(1).replace('_', ' '); })