mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-19 14:10:14 -05:00
Node: Improve DOMParser#parseFromString() polyfill for Node.js
And no need to move imported SVG nodes into document, since we don't have styling in Node.js
This commit is contained in:
parent
662b974104
commit
e02e9f4643
2 changed files with 29 additions and 14 deletions
|
@ -51,9 +51,18 @@ function DOMParser() {
|
||||||
}
|
}
|
||||||
|
|
||||||
DOMParser.prototype.parseFromString = function(string, contenType) {
|
DOMParser.prototype.parseFromString = function(string, contenType) {
|
||||||
var div = document.createElement('div');
|
// Create a new document, since we're supposed to always return one.
|
||||||
div.innerHTML = string;
|
var doc = document.implementation.createHTMLDocument(''),
|
||||||
return div.firstChild;
|
body = doc.body,
|
||||||
|
last;
|
||||||
|
// Set the body's HTML, then change the DOM according the specs.
|
||||||
|
body.innerHTML = string;
|
||||||
|
// Remove all top-level children (<html><head/><body/></html>)
|
||||||
|
while (last = doc.lastChild)
|
||||||
|
doc.removeChild(last);
|
||||||
|
// Insert the first child of the body at the top.
|
||||||
|
doc.appendChild(body.firstChild);
|
||||||
|
return doc;
|
||||||
};
|
};
|
||||||
|
|
||||||
window.XMLSerializer = XMLSerializer;
|
window.XMLSerializer = XMLSerializer;
|
||||||
|
|
|
@ -186,21 +186,27 @@ new function() {
|
||||||
// nodeNames still.
|
// nodeNames still.
|
||||||
var importers = {
|
var importers = {
|
||||||
'#document': function (node, type, options, isRoot) {
|
'#document': function (node, type, options, isRoot) {
|
||||||
var nodes = node.childNodes;
|
var nodes = node.childNodes,
|
||||||
|
move = !paper.agent.node;
|
||||||
for (var i = 0, l = nodes.length; i < l; i++) {
|
for (var i = 0, l = nodes.length; i < l; i++) {
|
||||||
var child = nodes[i];
|
var child = nodes[i],
|
||||||
|
next;
|
||||||
if (child.nodeType === 1) {
|
if (child.nodeType === 1) {
|
||||||
|
if (move) {
|
||||||
// NOTE: We need to move the svg node into our current
|
// NOTE: We need to move the svg node into our current
|
||||||
// document, so default styles apply!
|
// document, so default styles apply!
|
||||||
var next = child.nextSibling;
|
next = child.nextSibling;
|
||||||
document.body.appendChild(child);
|
document.body.appendChild(child);
|
||||||
|
}
|
||||||
var item = importSVG(child, options, isRoot);
|
var item = importSVG(child, options, isRoot);
|
||||||
|
if (move) {
|
||||||
// After import, we move it back to where it was:
|
// After import, we move it back to where it was:
|
||||||
if (next) {
|
if (next) {
|
||||||
node.insertBefore(child, next);
|
node.insertBefore(child, next);
|
||||||
} else {
|
} else {
|
||||||
node.appendChild(child);
|
node.appendChild(child);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue