|
|
|
|
|
const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=' |
|
const PREFIX = 'data:image/svg+xml;base64,' |
|
|
|
const utf8Encode = (string: string) => { |
|
string = string.replace(/\r\n/g, '\n') |
|
let utftext = '' |
|
|
|
for (let n = 0; n < string.length; n++) { |
|
const c = string.charCodeAt(n) |
|
|
|
if (c < 128) { |
|
utftext += String.fromCharCode(c) |
|
} |
|
else if (c > 127 && c < 2048) { |
|
utftext += String.fromCharCode((c >> 6) | 192) |
|
utftext += String.fromCharCode((c & 63) | 128) |
|
} |
|
else { |
|
utftext += String.fromCharCode((c >> 12) | 224) |
|
utftext += String.fromCharCode(((c >> 6) & 63) | 128) |
|
utftext += String.fromCharCode((c & 63) | 128) |
|
} |
|
} |
|
|
|
return utftext |
|
} |
|
|
|
const encode = (input: string) => { |
|
let output = '' |
|
let chr1, chr2, chr3, enc1, enc2, enc3, enc4 |
|
let i = 0 |
|
input = utf8Encode(input) |
|
while (i < input.length) { |
|
chr1 = input.charCodeAt(i++) |
|
chr2 = input.charCodeAt(i++) |
|
chr3 = input.charCodeAt(i++) |
|
enc1 = chr1 >> 2 |
|
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4) |
|
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6) |
|
enc4 = chr3 & 63 |
|
if (isNaN(chr2)) enc3 = enc4 = 64 |
|
else if (isNaN(chr3)) enc4 = 64 |
|
output = output + characters.charAt(enc1) + characters.charAt(enc2) + characters.charAt(enc3) + characters.charAt(enc4) |
|
} |
|
return output |
|
} |
|
|
|
export const svg2Base64 = (element: Element) => { |
|
const XMLS = new XMLSerializer() |
|
const svg = XMLS.serializeToString(element) |
|
|
|
return PREFIX + encode(svg) |
|
} |