mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-19 14:10:14 -05:00
SvgImport: Implement support for onLoad and onError callbacks on string input.
Closes #827
This commit is contained in:
parent
2025bd1a77
commit
75c40babc9
1 changed files with 26 additions and 19 deletions
|
@ -640,22 +640,32 @@ new function() {
|
||||||
return null;
|
return null;
|
||||||
options = typeof options === 'function' ? { onLoad: options }
|
options = typeof options === 'function' ? { onLoad: options }
|
||||||
: options || {};
|
: options || {};
|
||||||
var node = source,
|
// Remember current scope so we can restore it in onLoad.
|
||||||
// Remember current scope so we can restore it in onLoad.
|
var scope = paper,
|
||||||
scope = paper;
|
item = null;
|
||||||
|
|
||||||
function onLoad(svg) {
|
function onLoad(svg) {
|
||||||
paper = scope;
|
try {
|
||||||
var item = importSVG(svg, options, true),
|
var node = typeof svg === 'object' ? svg : new window.DOMParser()
|
||||||
onLoad = options.onLoad;
|
.parseFromString(svg, 'image/svg+xml');
|
||||||
if (onLoad)
|
if (!node.nodeName) {
|
||||||
onLoad.call(this, item, svg);
|
node = null;
|
||||||
|
throw new Error('Unsupported SVG source: ' + source);
|
||||||
|
}
|
||||||
|
paper = scope;
|
||||||
|
item = importNode(node, options, true);
|
||||||
|
var onLoad = options.onLoad;
|
||||||
|
if (onLoad)
|
||||||
|
onLoad(item, svg);
|
||||||
|
} catch (e) {
|
||||||
|
onError(e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function onError(message, status) {
|
function onError(message, status) {
|
||||||
var onError = options.onError;
|
var onError = options.onError;
|
||||||
if (onError) {
|
if (onError) {
|
||||||
onError.call(this, message, status);
|
onError(message, status);
|
||||||
} else {
|
} else {
|
||||||
throw new Error(message);
|
throw new Error(message);
|
||||||
}
|
}
|
||||||
|
@ -667,15 +677,16 @@ new function() {
|
||||||
if (typeof source === 'string' && !/^.*</.test(source)) {
|
if (typeof source === 'string' && !/^.*</.test(source)) {
|
||||||
// First see if we're meant to import an element with the given
|
// First see if we're meant to import an element with the given
|
||||||
// id.
|
// id.
|
||||||
node = document.getElementById(source);
|
var node = document.getElementById(source);
|
||||||
// Check if the string does not represent SVG data, in which
|
// Check if the string does not represent SVG data, in which
|
||||||
// case it must be the URL of a SVG to be loaded.
|
// case it must be the URL of a SVG to be loaded.
|
||||||
if (node) {
|
if (node) {
|
||||||
source = null;
|
onLoad(node);
|
||||||
} else {
|
} else {
|
||||||
Http.request({
|
Http.request({
|
||||||
url: source, async: true,
|
url: source, async: true,
|
||||||
onLoad: onLoad, onError: onError
|
onLoad: onLoad,
|
||||||
|
onError: onError
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
} else if (typeof File !== 'undefined' && source instanceof File) {
|
} else if (typeof File !== 'undefined' && source instanceof File) {
|
||||||
|
@ -688,15 +699,11 @@ new function() {
|
||||||
onError(reader.error);
|
onError(reader.error);
|
||||||
};
|
};
|
||||||
return reader.readAsText(source);
|
return reader.readAsText(source);
|
||||||
|
} else {
|
||||||
|
onLoad(source);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof source === 'string') {
|
return item;
|
||||||
node = new window.DOMParser().parseFromString(source,
|
|
||||||
'image/svg+xml');
|
|
||||||
}
|
|
||||||
if (!node.nodeName)
|
|
||||||
throw new Error('Unsupported SVG source: ' + source);
|
|
||||||
return importNode(node, options, true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE: Documentation is in Item#importSVG()
|
// NOTE: Documentation is in Item#importSVG()
|
||||||
|
|
Loading…
Reference in a new issue