From 35b752d8b783e7e2d204b0d44cfb1c38d233a59b Mon Sep 17 00:00:00 2001 From: Ryan Ashley Date: Wed, 3 Apr 2019 15:20:48 -0400 Subject: [PATCH] fix: cleaned up wonkiness of label text --- .../visualization/d3-viz/append-circles.js | 33 +++++++++++-------- 1 file changed, 20 insertions(+), 13 deletions(-) diff --git a/src/features/visualization/d3-viz/append-circles.js b/src/features/visualization/d3-viz/append-circles.js index 566a6c59b..4d8175ee2 100644 --- a/src/features/visualization/d3-viz/append-circles.js +++ b/src/features/visualization/d3-viz/append-circles.js @@ -106,7 +106,7 @@ const scaleAndTrimToLabelWidth = (node, datum, initialFontScale) => { const maxTextWidth = 0.80 * getLabelWidth(datum); const maxTextHeight = 0.80 * datum.labelSize; const minFontScale = 10; - const maxFontScale = 75; + const maxFontScale = 125; let boxWidth = node.getBBox().width; let boxHeight = node.getBBox().height; @@ -115,9 +115,20 @@ const scaleAndTrimToLabelWidth = (node, datum, initialFontScale) => { //scale to height if ((boxHeight > maxTextHeight)){ - const heightScale = Math.abs((boxHeight - maxTextHeight)/maxTextHeight); - const widthScale = Math.abs((boxWidth -maxTextWidth)/maxTextWidth); - fontScale = Math.max(minFontScale, Math.min(heightScale * initialFontScale, widthScale *initialFontScale, maxFontScale)); + const heightScale = 1-Math.abs((boxHeight - maxTextHeight)/boxHeight); + fontScale = Math.max(minFontScale, heightScale * initialFontScale); + if (datum.data.fieldValue === "File server"){ + console.log("boxHeight: %o", boxHeight); + console.log("maxTextHeight: %o", maxTextHeight); + console.log("initialFontScale: %o", initialFontScale); + console.log("fontScale: %o", fontScale); + } + select(node) + .style('font-size', (d, i, nodes) => fontScale + "%") + .text(labelText); + } else if(boxHeight < 0.75 * maxTextHeight){ + const heightScale = 1 + Math.abs((boxHeight - maxTextHeight)/maxTextHeight); + fontScale = Math.min(maxFontScale, heightScale * initialFontScale); select(node) .style('font-size', (d, i, nodes) => fontScale + "%") .text(labelText); @@ -127,16 +138,12 @@ const scaleAndTrimToLabelWidth = (node, datum, initialFontScale) => { //trim to width if(boxWidth > maxTextWidth) { - const lengthToTrimTo = Math.trunc(((boxWidth -maxTextWidth)/maxTextWidth) * labelText.length) - 3; - if(lengthToTrimTo > 0){ - labelText = labelText.substr(0, lengthToTrimTo) + "..."; - } - else{ - labelText = "..."; - } - + const lengthToTrimTo = Math.trunc(0.75*labelText.length); + labelText = labelText.substr(0, lengthToTrimTo) + "..." select(node) - .text(labelText); + .attr('textLength', maxTextWidth) + .attr('lengthAdjust', "spacingAndGlyphs") + .text(labelText); } }