From 879da091d3dde90a42cacd587494538c97b4fbdc Mon Sep 17 00:00:00 2001 From: Adrian Hall Date: Thu, 5 Nov 2020 11:56:57 +0000 Subject: [PATCH] Fix padding for entities with no attributes --- src/diagrams/er/erRenderer.js | 11 ++++++++--- src/diagrams/er/parser/erDiagram.jison | 2 +- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/src/diagrams/er/erRenderer.js b/src/diagrams/er/erRenderer.js index 6ec654720..0df6cfd37 100644 --- a/src/diagrams/er/erRenderer.js +++ b/src/diagrams/er/erRenderer.js @@ -32,7 +32,7 @@ export const setConf = function(cnf) { const drawAttributes = (groupNode, entityTextNode, attributes) => { const heightPadding = conf.entityPadding / 3; // Padding internal to attribute boxes const widthPadding = conf.entityPadding / 3; // Ditto - const attrFontSize = conf.fontSize * 0.8; + const attrFontSize = conf.fontSize * 0.85; const labelBBox = entityTextNode.node().getBBox(); const attributeNodes = []; // Intermediate storage for attribute nodes created so that we can do a second pass let maxTypeWidth = 0; @@ -90,10 +90,15 @@ const drawAttributes = (groupNode, entityTextNode, attributes) => { const bBox = { width: Math.max( conf.minEntityWidth, - Math.max(labelBBox.width + widthPadding * 2, maxTypeWidth + maxNameWidth + widthPadding * 4) + Math.max( + labelBBox.width + conf.entityPadding * 2, + maxTypeWidth + maxNameWidth + widthPadding * 4 + ) ), height: - attributes.length > 0 ? cumulativeHeight : Math.max(conf.minEntityHeight, cumulativeHeight) + attributes.length > 0 + ? cumulativeHeight + : Math.max(conf.minEntityHeight, labelBBox.height + conf.entityPadding * 2) }; // There might be some spare width for padding out attributes if the entity name is very long diff --git a/src/diagrams/er/parser/erDiagram.jison b/src/diagrams/er/parser/erDiagram.jison index 2a6bc5ac1..6e4815f28 100644 --- a/src/diagrams/er/parser/erDiagram.jison +++ b/src/diagrams/er/parser/erDiagram.jison @@ -18,7 +18,7 @@ "erDiagram" return 'ER_DIAGRAM'; "{" { this.begin("block"); return 'BLOCK_START'; } \s+ /* skip whitespace in block */ -[A-Za-z][A-Za-z0-9\-_]+ { return 'ATTRIBUTE_WORD'; } +[A-Za-z][A-Za-z0-9\-_]* { return 'ATTRIBUTE_WORD'; } [\n]+ /* nothing */ "}" { this.popState(); return 'BLOCK_STOP'; } . return yytext[0];