From 261fc02c1ddafe294af4849750091b0f055f917f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Thu, 23 Mar 2017 00:14:03 +0100 Subject: [PATCH] SVG Import: Improve handling of sizes in percent. Closes #1242 --- src/path/PathItem.Boolean.js | 6 ++--- src/svg/SvgImport.js | 43 +++++++++++++++++++----------------- 2 files changed, 26 insertions(+), 23 deletions(-) diff --git a/src/path/PathItem.Boolean.js b/src/path/PathItem.Boolean.js index b5fdcb47..29d79e04 100644 --- a/src/path/PathItem.Boolean.js +++ b/src/path/PathItem.Boolean.js @@ -163,10 +163,10 @@ PathItem.inject(new function() { var _path1 = preparePath(path1), _path2 = preparePath(path2), crossings = _path1.getCrossings(_path2), - added = {}, - paths = [], + subtract = operation === 'subtract', divide = operation === 'divide', - subtract = operation === 'subtract'; + added = {}, + paths = []; function addPath(path) { // Simple see if the point halfway across the open path is inside diff --git a/src/svg/SvgImport.js b/src/svg/SvgImport.js index a6dc65bd..539283bf 100644 --- a/src/svg/SvgImport.js +++ b/src/svg/SvgImport.js @@ -521,23 +521,25 @@ new function() { * @param {Item} item the item to apply the style and attributes to */ function applyAttributes(item, node, isRoot) { - // SVG attributes can be set both as styles and direct node attributes, - // so we need to handle both. - var parent = node.parentNode, - styles = { - node: DomElement.getStyles(node) || {}, - // Do not check for inheritance if this is root, since we want - // the default SVG settings to stick. Also detect defs parents, - // of which children need to explicitly inherit their styles. - parent: !isRoot && !/^defs$/i.test(parent.tagName) - && DomElement.getStyles(parent) || {} - }; - Base.each(attributes, function(apply, name) { - var value = getAttribute(node, name, styles); - // 'clip-path' attribute returns a new item, support it here: - item = value !== undefined && apply(item, value, name, node, styles) - || item; - }); + if (node.style) { + // SVG attributes can be set both as styles and direct node + // attributes, so we need to handle both. + var parent = node.parentNode, + styles = { + node: DomElement.getStyles(node) || {}, + // Do not check for inheritance if this is root, to make the + // default SVG settings stick. Also detect defs parents, of + // which children need to explicitly inherit their styles. + parent: !isRoot && !/^defs$/i.test(parent.tagName) + && DomElement.getStyles(parent) || {} + }; + Base.each(attributes, function(apply, name) { + var value = getAttribute(node, name, styles); + // 'clip-path' attribute returns a new item, support it here: + item = value !== undefined + && apply(item, value, name, node, styles) || item; + }); + } return item; } @@ -571,9 +573,10 @@ new function() { parent, next; if (isRoot && isElement) { - // Set rootSize root element size, fall-back to view size. - rootSize = getSize(node, null, null, true) - || paper.getView().getSize(); + // Set rootSize to view size, as getSize() may refer to it (#1242). + rootSize = paper.getView().getSize(); + // Now set rootSize to the root element size, and fall-back to view. + rootSize = getSize(node, null, null, true) || rootSize; // We need to move the SVG node to the current document, so default // styles are correctly inherited! For this we create and insert a // temporary SVG container which is removed again at the end. This