Skip to content

Commit

Permalink
Use SVG Namespace for SVG Elements (fabricjs#5957)
Browse files Browse the repository at this point in the history
* Use SVG Namespace for createElement of SVG elements

* Updating to use setAttributeNS

* Reverting line endings... I hope

* Fixing linter errors

* Resetting dist/ and removing .gitattributes
  • Loading branch information
rockerBOO authored and Hristo Chakarov committed Jul 27, 2021
1 parent efad2ad commit bc181cd
Show file tree
Hide file tree
Showing 11 changed files with 387 additions and 339 deletions.
7 changes: 4 additions & 3 deletions src/parser.js
Original file line number Diff line number Diff line change
Expand Up @@ -476,10 +476,11 @@

applyViewboxTransform(el2);
if (/^svg$/i.test(el2.nodeName)) {
var el3 = el2.ownerDocument.createElement('g');
var namespace = 'http://www.w3.org/2000/svg';
var el3 = el2.ownerDocument.createElementNS(namespace, 'g');
for (j = 0, attrs = el2.attributes, len = attrs.length; j < len; j++) {
attr = attrs.item(j);
el3.setAttribute(attr.nodeName, attr.nodeValue);
el3.setAttributeNS(namespace, attr.nodeName, attr.nodeValue);
}
// el2.firstChild != null
while (el2.firstChild) {
Expand Down Expand Up @@ -624,7 +625,7 @@
(minY * scaleY + heightDiff) + ') ';
parsedDim.viewboxTransform = fabric.parseTransformAttribute(matrix);
if (element.nodeName === 'svg') {
el = element.ownerDocument.createElement('g');
el = element.ownerDocument.createElementNS('http://www.w3.org/2000/svg', 'g');
// element.firstChild != null
while (element.firstChild) {
el.appendChild(element.firstChild);
Expand Down
27 changes: 14 additions & 13 deletions test/unit/circle.js
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,8 @@
QUnit.test('fromElement', function(assert) {
assert.ok(typeof fabric.Circle.fromElement === 'function');

var elCircle = fabric.document.createElement('circle'),
var namespace = 'http://www.w3.org/2000/svg';
var elCircle = fabric.document.createElementNS(namespace, 'circle'),
radius = 10,
left = 12,
top = 15,
Expand All @@ -170,16 +171,16 @@
strokeMiterLimit = 5;


elCircle.setAttribute('r', radius);
elCircle.setAttribute('cx', left);
elCircle.setAttribute('cy', top);
elCircle.setAttribute('fill', fill);
elCircle.setAttribute('opacity', opacity);
elCircle.setAttribute('stroke-width', strokeWidth);
elCircle.setAttribute('stroke-dasharray', '5, 2');
elCircle.setAttribute('stroke-linecap', strokeLineCap);
elCircle.setAttribute('stroke-linejoin', strokeLineJoin);
elCircle.setAttribute('stroke-miterlimit', strokeMiterLimit);
elCircle.setAttributeNS(namespace, 'r', radius);
elCircle.setAttributeNS(namespace, 'cx', left);
elCircle.setAttributeNS(namespace, 'cy', top);
elCircle.setAttributeNS(namespace, 'fill', fill);
elCircle.setAttributeNS(namespace, 'opacity', opacity);
elCircle.setAttributeNS(namespace, 'stroke-width', strokeWidth);
elCircle.setAttributeNS(namespace, 'stroke-dasharray', '5, 2');
elCircle.setAttributeNS(namespace, 'stroke-linecap', strokeLineCap);
elCircle.setAttributeNS(namespace, 'stroke-linejoin', strokeLineJoin);
elCircle.setAttributeNS(namespace, 'stroke-miterlimit', strokeMiterLimit);

fabric.Circle.fromElement(elCircle, function(oCircle) {
assert.ok(oCircle instanceof fabric.Circle);
Expand All @@ -194,8 +195,8 @@
assert.equal(oCircle.get('strokeLineJoin'), strokeLineJoin);
assert.equal(oCircle.get('strokeMiterLimit'), strokeMiterLimit);

var elFaultyCircle = fabric.document.createElement('circle');
elFaultyCircle.setAttribute('r', '-10');
var elFaultyCircle = fabric.document.createElementNS(namespace, 'circle');
elFaultyCircle.setAttributeNS(namespace, 'r', '-10');

var error;
try {
Expand Down
25 changes: 13 additions & 12 deletions test/unit/ellipse.js
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,8 @@
QUnit.test('fromElement', function(assert) {
assert.ok(typeof fabric.Ellipse.fromElement === 'function');

var elEllipse = fabric.document.createElement('ellipse'),
var namespace = 'http://www.w3.org/2000/svg';
var elEllipse = fabric.document.createElementNS(namespace, 'ellipse'),
rx = 5,
ry = 7,
left = 12,
Expand All @@ -131,17 +132,17 @@
strokeLineJoin = 'bevil',
strokeMiterLimit = 5;

elEllipse.setAttribute('rx', rx);
elEllipse.setAttribute('ry', ry);
elEllipse.setAttribute('cx', left);
elEllipse.setAttribute('cy', top);
elEllipse.setAttribute('fill', fill);
elEllipse.setAttribute('opacity', opacity);
elEllipse.setAttribute('stroke-width', strokeWidth);
elEllipse.setAttribute('stroke-dasharray', '5, 2');
elEllipse.setAttribute('stroke-linecap', strokeLineCap);
elEllipse.setAttribute('stroke-linejoin', strokeLineJoin);
elEllipse.setAttribute('stroke-miterlimit', strokeMiterLimit);
elEllipse.setAttributeNS(namespace, 'rx', rx);
elEllipse.setAttributeNS(namespace, 'ry', ry);
elEllipse.setAttributeNS(namespace, 'cx', left);
elEllipse.setAttributeNS(namespace, 'cy', top);
elEllipse.setAttributeNS(namespace, 'fill', fill);
elEllipse.setAttributeNS(namespace, 'opacity', opacity);
elEllipse.setAttributeNS(namespace, 'stroke-width', strokeWidth);
elEllipse.setAttributeNS(namespace, 'stroke-dasharray', '5, 2');
elEllipse.setAttributeNS(namespace, 'stroke-linecap', strokeLineCap);
elEllipse.setAttributeNS(namespace, 'stroke-linejoin', strokeLineJoin);
elEllipse.setAttributeNS(namespace, 'stroke-miterlimit', strokeMiterLimit);

fabric.Ellipse.fromElement(elEllipse, function(oEllipse) {
assert.ok(oEllipse instanceof fabric.Ellipse);
Expand Down
Loading

0 comments on commit bc181cd

Please sign in to comment.