You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

103 lines
2.3 KiB
JavaScript

/*
* https://github.com/Jam3/svg-to-image
* https://github.com/mattdesl/load-img
*/
function loadImage(src, opt, callback) {
if (typeof opt === 'function') {
callback = opt;
opt = null;
}
var el = document.createElement('img');
var locked;
el.onload = function onLoaded() {
if (locked)
return;
locked = true;
if (callback)
callback(undefined, el);
};
el.onerror = function onError() {
if (locked)
return;
locked = true;
if (callback)
callback(new Error('Unable to load "' + src + '"'), el);
};
if (opt && opt.crossOrigin) {
el.crossOrigin = opt.crossOrigin;
}
el.src = src;
return el;
}
function svgToImage(svg, opt, cb) {
if (typeof opt === 'function') {
cb = opt
opt = {}
}
cb = cb || noop
opt = opt || {}
if (typeof window === 'undefined') {
return bail('window global is undefined; not in a browser')
}
var DOMURL = getURL()
if (!DOMURL ||
typeof DOMURL.createObjectURL !== 'function' ||
typeof DOMURL.revokeObjectURL !== 'function') {
return bail('browser does not support URL.createObjectURL')
}
if (typeof window.Blob === 'undefined') {
return bail('browser does not support Blob constructor')
}
if (!Array.isArray(svg)) {
svg = [svg]
}
var blob
try {
blob = new window.Blob(svg, {
type: 'image/svg+xml;charset=utf-8'
})
} catch (e) {
return bail(e)
}
var url = DOMURL.createObjectURL(blob)
loadImage(url, opt, function (err, img) {
DOMURL.revokeObjectURL(url)
if (err) {
// try again for Safari 8.0, using simple encodeURIComponent
// this will fail with DOM content but at least it works with SVG
var url2 = 'data:image/svg+xml,' + encodeURIComponent(svg.join(''))
return loadImage(url2, opt, cb)
}
cb(err, img)
})
function getURL() {
return window.URL ||
window.webkitURL ||
window.mozURL ||
window.msURL
}
function bail(msg) {
process.nextTick(function () {
cb(new Error(msg))
})
}
}