From 85f08825d7bb5ba4ab4aad2251a00a6caa0923f1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Mon, 28 Dec 2015 00:44:02 +0100 Subject: [PATCH] Implement support for CSS blend-modes in SVGExport. --- src/svg/SVGExport.js | 29 ++++++++++++++++------------- src/svg/SVGStyles.js | 2 +- 2 files changed, 17 insertions(+), 14 deletions(-) diff --git a/src/svg/SVGExport.js b/src/svg/SVGExport.js index d8f50526..56c129f8 100644 --- a/src/svg/SVGExport.js +++ b/src/svg/SVGExport.js @@ -284,7 +284,8 @@ new function() { function applyStyle(item, node, isRoot) { var attrs = {}, - parent = !isRoot && item.getParent(); + parent = !isRoot && item.getParent(), + style = []; if (item._name != null) attrs.id = item._name; @@ -306,23 +307,25 @@ new function() { if (alpha < 1) attrs[entry.attribute + '-opacity'] = alpha; } - attrs[entry.attribute] = value == null - ? 'none' - : type === 'number' - ? formatter.number(value) - : type === 'color' - ? value.gradient - ? exportGradient(value, item) + if (type === 'style') { + style.push(entry.attribute + ': ' + value) + } else { + attrs[entry.attribute] = value == null ? 'none' + : type === 'number' ? formatter.number(value) + : type === 'color' ? value.gradient // true for noAlpha, see above + ? exportGradient(value, item) : value.toCSS(true) - : type === 'array' - ? value.join(',') - : type === 'lookup' - ? entry.toSVG[value] - : value; + : type === 'array' ? value.join(',') + : type === 'lookup' ? entry.toSVG[value] + : value; + } } }); + if (style.length) + attrs.style = style.join(';'); + if (attrs.opacity === 1) delete attrs.opacity; diff --git a/src/svg/SVGStyles.js b/src/svg/SVGStyles.js index 269c3bda..0fada395 100644 --- a/src/svg/SVGStyles.js +++ b/src/svg/SVGStyles.js @@ -43,7 +43,7 @@ var SVGStyles = Base.each({ }], // Item opacity: ['opacity', 'number'], - blendMode: ['mix-blend-mode', 'string'] + blendMode: ['mix-blend-mode', 'style'] }, function(entry, key) { var part = Base.capitalize(key), lookup = entry[2];