51 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
		
			
		
	
	
			51 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
|  | /* | ||
|  |  * base64-arraybuffer 1.0.2 <https://github.com/niklasvh/base64-arraybuffer>
 | ||
|  |  * Copyright (c) 2022 Niklas von Hertzen <https://hertzen.com>
 | ||
|  |  * Released under MIT License | ||
|  |  */ | ||
|  | var chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; | ||
|  | // Use a lookup table to find the index.
 | ||
|  | var lookup = typeof Uint8Array === 'undefined' ? [] : new Uint8Array(256); | ||
|  | for (var i = 0; i < chars.length; i++) { | ||
|  |     lookup[chars.charCodeAt(i)] = i; | ||
|  | } | ||
|  | var encode = function (arraybuffer) { | ||
|  |     var bytes = new Uint8Array(arraybuffer), i, len = bytes.length, base64 = ''; | ||
|  |     for (i = 0; i < len; i += 3) { | ||
|  |         base64 += chars[bytes[i] >> 2]; | ||
|  |         base64 += chars[((bytes[i] & 3) << 4) | (bytes[i + 1] >> 4)]; | ||
|  |         base64 += chars[((bytes[i + 1] & 15) << 2) | (bytes[i + 2] >> 6)]; | ||
|  |         base64 += chars[bytes[i + 2] & 63]; | ||
|  |     } | ||
|  |     if (len % 3 === 2) { | ||
|  |         base64 = base64.substring(0, base64.length - 1) + '='; | ||
|  |     } | ||
|  |     else if (len % 3 === 1) { | ||
|  |         base64 = base64.substring(0, base64.length - 2) + '=='; | ||
|  |     } | ||
|  |     return base64; | ||
|  | }; | ||
|  | var decode = function (base64) { | ||
|  |     var bufferLength = base64.length * 0.75, len = base64.length, i, p = 0, encoded1, encoded2, encoded3, encoded4; | ||
|  |     if (base64[base64.length - 1] === '=') { | ||
|  |         bufferLength--; | ||
|  |         if (base64[base64.length - 2] === '=') { | ||
|  |             bufferLength--; | ||
|  |         } | ||
|  |     } | ||
|  |     var arraybuffer = new ArrayBuffer(bufferLength), bytes = new Uint8Array(arraybuffer); | ||
|  |     for (i = 0; i < len; i += 4) { | ||
|  |         encoded1 = lookup[base64.charCodeAt(i)]; | ||
|  |         encoded2 = lookup[base64.charCodeAt(i + 1)]; | ||
|  |         encoded3 = lookup[base64.charCodeAt(i + 2)]; | ||
|  |         encoded4 = lookup[base64.charCodeAt(i + 3)]; | ||
|  |         bytes[p++] = (encoded1 << 2) | (encoded2 >> 4); | ||
|  |         bytes[p++] = ((encoded2 & 15) << 4) | (encoded3 >> 2); | ||
|  |         bytes[p++] = ((encoded3 & 3) << 6) | (encoded4 & 63); | ||
|  |     } | ||
|  |     return arraybuffer; | ||
|  | }; | ||
|  | 
 | ||
|  | export { decode, encode }; | ||
|  | //# sourceMappingURL=base64-arraybuffer.es5.js.map
 |