import { fromByteArray } from 'base64-js'; import { deflate } from 'pako'; export var MOCK_HANDLERS = false; export var RAW_IMAGE_DATA = false; export var fromBlendMode = {}; export var toBlendMode = { 'pass': 'pass through', 'norm': 'normal', 'diss': 'dissolve', 'dark': 'darken', 'mul ': 'multiply', 'idiv': 'color burn', 'lbrn': 'linear burn', 'dkCl': 'darker color', 'lite': 'lighten', 'scrn': 'screen', 'div ': 'color dodge', 'lddg': 'linear dodge', 'lgCl': 'lighter color', 'over': 'overlay', 'sLit': 'soft light', 'hLit': 'hard light', 'vLit': 'vivid light', 'lLit': 'linear light', 'pLit': 'pin light', 'hMix': 'hard mix', 'diff': 'difference', 'smud': 'exclusion', 'fsub': 'subtract', 'fdiv': 'divide', 'hue ': 'hue', 'sat ': 'saturation', 'colr': 'color', 'lum ': 'luminosity', }; Object.keys(toBlendMode).forEach(function (key) { return fromBlendMode[toBlendMode[key]] = key; }); export var layerColors = [ 'none', 'red', 'orange', 'yellow', 'green', 'blue', 'violet', 'gray' ]; export var largeAdditionalInfoKeys = [ // from documentation 'LMsk', 'Lr16', 'Lr32', 'Layr', 'Mt16', 'Mt32', 'Mtrn', 'Alph', 'FMsk', 'lnk2', 'FEid', 'FXid', 'PxSD', // from guessing 'cinf', ]; export function revMap(map) { var result = {}; Object.keys(map).forEach(function (key) { return result[map[key]] = key; }); return result; } export function createEnum(prefix, def, map) { var rev = revMap(map); var decode = function (val) { var value = val.split('.')[1]; if (value && !rev[value]) throw new Error("Unrecognized value for enum: '".concat(val, "'")); return rev[value] || def; }; var encode = function (val) { if (val && !map[val]) throw new Error("Invalid value for enum: '".concat(val, "'")); return "".concat(prefix, ".").concat(map[val] || map[def]); }; return { decode: decode, encode: encode }; } export var ColorSpace; (function (ColorSpace) { ColorSpace[ColorSpace["RGB"] = 0] = "RGB"; ColorSpace[ColorSpace["HSB"] = 1] = "HSB"; ColorSpace[ColorSpace["CMYK"] = 2] = "CMYK"; ColorSpace[ColorSpace["Lab"] = 7] = "Lab"; ColorSpace[ColorSpace["Grayscale"] = 8] = "Grayscale"; })(ColorSpace || (ColorSpace = {})); export var LayerMaskFlags; (function (LayerMaskFlags) { LayerMaskFlags[LayerMaskFlags["PositionRelativeToLayer"] = 1] = "PositionRelativeToLayer"; LayerMaskFlags[LayerMaskFlags["LayerMaskDisabled"] = 2] = "LayerMaskDisabled"; LayerMaskFlags[LayerMaskFlags["InvertLayerMaskWhenBlending"] = 4] = "InvertLayerMaskWhenBlending"; LayerMaskFlags[LayerMaskFlags["LayerMaskFromRenderingOtherData"] = 8] = "LayerMaskFromRenderingOtherData"; LayerMaskFlags[LayerMaskFlags["MaskHasParametersAppliedToIt"] = 16] = "MaskHasParametersAppliedToIt"; })(LayerMaskFlags || (LayerMaskFlags = {})); export var MaskParams; (function (MaskParams) { MaskParams[MaskParams["UserMaskDensity"] = 1] = "UserMaskDensity"; MaskParams[MaskParams["UserMaskFeather"] = 2] = "UserMaskFeather"; MaskParams[MaskParams["VectorMaskDensity"] = 4] = "VectorMaskDensity"; MaskParams[MaskParams["VectorMaskFeather"] = 8] = "VectorMaskFeather"; })(MaskParams || (MaskParams = {})); export var ChannelID; (function (ChannelID) { ChannelID[ChannelID["Color0"] = 0] = "Color0"; ChannelID[ChannelID["Color1"] = 1] = "Color1"; ChannelID[ChannelID["Color2"] = 2] = "Color2"; ChannelID[ChannelID["Color3"] = 3] = "Color3"; ChannelID[ChannelID["Transparency"] = -1] = "Transparency"; ChannelID[ChannelID["UserMask"] = -2] = "UserMask"; ChannelID[ChannelID["RealUserMask"] = -3] = "RealUserMask"; })(ChannelID || (ChannelID = {})); export var Compression; (function (Compression) { Compression[Compression["RawData"] = 0] = "RawData"; Compression[Compression["RleCompressed"] = 1] = "RleCompressed"; Compression[Compression["ZipWithoutPrediction"] = 2] = "ZipWithoutPrediction"; Compression[Compression["ZipWithPrediction"] = 3] = "ZipWithPrediction"; })(Compression || (Compression = {})); export function offsetForChannel(channelId, cmyk) { switch (channelId) { case 0 /* ChannelID.Color0 */: return 0; case 1 /* ChannelID.Color1 */: return 1; case 2 /* ChannelID.Color2 */: return 2; case 3 /* ChannelID.Color3 */: return cmyk ? 3 : channelId + 1; case -1 /* ChannelID.Transparency */: return cmyk ? 4 : 3; default: return channelId + 1; } } export function clamp(value, min, max) { return value < min ? min : (value > max ? max : value); } export function hasAlpha(data) { var size = data.width * data.height * 4; for (var i = 3; i < size; i += 4) { if (data.data[i] !== 255) { return true; } } return false; } export function resetImageData(_a) { var data = _a.data; var buffer = new Uint32Array(data.buffer); var size = buffer.length | 0; for (var p = 0; p < size; p = (p + 1) | 0) { buffer[p] = 0xff000000; } } export function decodeBitmap(input, output, width, height) { for (var y = 0, p = 0, o = 0; y < height; y++) { for (var x = 0; x < width;) { var b = input[o++]; for (var i = 0; i < 8 && x < width; i++, x++) { var v = b & 0x80 ? 0 : 255; b = b << 1; output[p++] = v; output[p++] = v; output[p++] = v; output[p++] = 255; } } } } export function writeDataRaw(data, offset, width, height) { if (!width || !height) return undefined; var array = new Uint8Array(width * height); for (var i = 0; i < array.length; i++) { array[i] = data.data[i * 4 + offset]; } return array; } export function writeDataRLE(buffer, _a, offsets, large) { var data = _a.data, width = _a.width, height = _a.height; if (!width || !height) return undefined; var stride = (4 * width) | 0; var ol = 0; var o = (offsets.length * (large ? 4 : 2) * height) | 0; for (var _i = 0, offsets_1 = offsets; _i < offsets_1.length; _i++) { var offset = offsets_1[_i]; for (var y = 0, p = offset | 0; y < height; y++) { var strideStart = (y * stride) | 0; var strideEnd = (strideStart + stride) | 0; var lastIndex = (strideEnd + offset - 4) | 0; var lastIndex2 = (lastIndex - 4) | 0; var startOffset = o; for (p = (strideStart + offset) | 0; p < strideEnd; p = (p + 4) | 0) { if (p < lastIndex2) { var value1 = data[p]; p = (p + 4) | 0; var value2 = data[p]; p = (p + 4) | 0; var value3 = data[p]; if (value1 === value2 && value1 === value3) { var count = 3; while (count < 128 && p < lastIndex && data[(p + 4) | 0] === value1) { count = (count + 1) | 0; p = (p + 4) | 0; } buffer[o++] = 1 - count; buffer[o++] = value1; } else { var countIndex = o; var writeLast = true; var count = 1; buffer[o++] = 0; buffer[o++] = value1; while (p < lastIndex && count < 128) { p = (p + 4) | 0; value1 = value2; value2 = value3; value3 = data[p]; if (value1 === value2 && value1 === value3) { p = (p - 12) | 0; writeLast = false; break; } else { count++; buffer[o++] = value1; } } if (writeLast) { if (count < 127) { buffer[o++] = value2; buffer[o++] = value3; count += 2; } else if (count < 128) { buffer[o++] = value2; count++; p = (p - 4) | 0; } else { p = (p - 8) | 0; } } buffer[countIndex] = count - 1; } } else if (p === lastIndex) { buffer[o++] = 0; buffer[o++] = data[p]; } else { // p === lastIndex2 buffer[o++] = 1; buffer[o++] = data[p]; p = (p + 4) | 0; buffer[o++] = data[p]; } } var length_1 = o - startOffset; if (large) { buffer[ol++] = (length_1 >> 24) & 0xff; buffer[ol++] = (length_1 >> 16) & 0xff; } buffer[ol++] = (length_1 >> 8) & 0xff; buffer[ol++] = length_1 & 0xff; } } return buffer.slice(0, o); } export function writeDataZipWithoutPrediction(_a, offsets) { var data = _a.data, width = _a.width, height = _a.height; var size = width * height; var channel = new Uint8Array(size); var buffers = []; var totalLength = 0; for (var _i = 0, offsets_2 = offsets; _i < offsets_2.length; _i++) { var offset = offsets_2[_i]; for (var i = 0, o = offset; i < size; i++, o += 4) { channel[i] = data[o]; } var buffer = deflate(channel); buffers.push(buffer); totalLength += buffer.byteLength; } if (buffers.length > 0) { var buffer = new Uint8Array(totalLength); var offset = 0; for (var _b = 0, buffers_1 = buffers; _b < buffers_1.length; _b++) { var b = buffers_1[_b]; buffer.set(b, offset); offset += b.byteLength; } return buffer; } else { return buffers[0]; } } export var createCanvas = function () { throw new Error('Canvas not initialized, use initializeCanvas method to set up createCanvas method'); }; export var createCanvasFromData = function () { throw new Error('Canvas not initialized, use initializeCanvas method to set up createCanvasFromData method'); }; var tempCanvas = undefined; export var createImageData = function (width, height) { if (!tempCanvas) tempCanvas = createCanvas(1, 1); return tempCanvas.getContext('2d').createImageData(width, height); }; if (typeof document !== 'undefined') { createCanvas = function (width, height) { var canvas = document.createElement('canvas'); canvas.width = width; canvas.height = height; return canvas; }; createCanvasFromData = function (data) { var image = new Image(); image.src = 'data:image/jpeg;base64,' + fromByteArray(data); var canvas = document.createElement('canvas'); canvas.width = image.width; canvas.height = image.height; canvas.getContext('2d').drawImage(image, 0, 0); return canvas; }; } export function initializeCanvas(createCanvasMethod, createCanvasFromDataMethod, createImageDataMethod) { createCanvas = createCanvasMethod; createCanvasFromData = createCanvasFromDataMethod || createCanvasFromData; createImageData = createImageDataMethod || createImageData; } //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["helpers.ts"],"names":[],"mappings":"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","file":"helpers.js","sourcesContent":["import { fromByteArray } from 'base64-js';\nimport { deflate } from 'pako';\nimport { Layer, BlendMode, LayerColor } from './psd';\n\nexport const MOCK_HANDLERS = false;\nexport const RAW_IMAGE_DATA = false;\n\nexport const fromBlendMode: { [key: string]: string } = {};\nexport const toBlendMode: { [key: string]: BlendMode } = {\n\t'pass': 'pass through',\n\t'norm': 'normal',\n\t'diss': 'dissolve',\n\t'dark': 'darken',\n\t'mul ': 'multiply',\n\t'idiv': 'color burn',\n\t'lbrn': 'linear burn',\n\t'dkCl': 'darker color',\n\t'lite': 'lighten',\n\t'scrn': 'screen',\n\t'div ': 'color dodge',\n\t'lddg': 'linear dodge',\n\t'lgCl': 'lighter color',\n\t'over': 'overlay',\n\t'sLit': 'soft light',\n\t'hLit': 'hard light',\n\t'vLit': 'vivid light',\n\t'lLit': 'linear light',\n\t'pLit': 'pin light',\n\t'hMix': 'hard mix',\n\t'diff': 'difference',\n\t'smud': 'exclusion',\n\t'fsub': 'subtract',\n\t'fdiv': 'divide',\n\t'hue ': 'hue',\n\t'sat ': 'saturation',\n\t'colr': 'color',\n\t'lum ': 'luminosity',\n};\n\nObject.keys(toBlendMode).forEach(key => fromBlendMode[toBlendMode[key]] = key);\n\nexport const layerColors: LayerColor[] = [\n\t'none', 'red', 'orange', 'yellow', 'green', 'blue', 'violet', 'gray'\n];\n\nexport const largeAdditionalInfoKeys = [\n\t// from documentation\n\t'LMsk', 'Lr16', 'Lr32', 'Layr', 'Mt16', 'Mt32', 'Mtrn', 'Alph', 'FMsk', 'lnk2', 'FEid', 'FXid', 'PxSD',\n\t// from guessing\n\t'cinf',\n];\n\nexport interface Dict {\n\t[key: string]: string;\n}\n\nexport function revMap(map: Dict) {\n\tconst result: Dict = {};\n\tObject.keys(map).forEach(key => result[map[key]] = key);\n\treturn result;\n}\n\nexport function createEnum<T>(prefix: string, def: string, map: Dict) {\n\tconst rev = revMap(map);\n\tconst decode = (val: string): T => {\n\t\tconst value = val.split('.')[1];\n\t\tif (value && !rev[value]) throw new Error(`Unrecognized value for enum: '${val}'`);\n\t\treturn (rev[value] as any) || def;\n\t};\n\tconst encode = (val: T | undefined): string => {\n\t\tif (val && !map[val as any]) throw new Error(`Invalid value for enum: '${val}'`);\n\t\treturn `${prefix}.${map[val as any] || map[def]}`;\n\t};\n\treturn { decode, encode };\n}\n\nexport const enum ColorSpace {\n\tRGB = 0,\n\tHSB = 1,\n\tCMYK = 2,\n\tLab = 7,\n\tGrayscale = 8,\n}\n\nexport const enum LayerMaskFlags {\n\tPositionRelativeToLayer = 1,\n\tLayerMaskDisabled = 2,\n\tInvertLayerMaskWhenBlending = 4, // obsolete\n\tLayerMaskFromRenderingOtherData = 8,\n\tMaskHasParametersAppliedToIt = 16,\n}\n\nexport const enum MaskParams {\n\tUserMaskDensity = 1,\n\tUserMaskFeather = 2,\n\tVectorMaskDensity = 4,\n\tVectorMaskFeather = 8,\n}\n\nexport const enum ChannelID {\n\tColor0 = 0, // red (rgb) / cyan (cmyk)\n\tColor1 = 1, // green (rgb) / magenta (cmyk)\n\tColor2 = 2, // blue (rgb) / yellow (cmyk)\n\tColor3 = 3, // - (rgb) / black (cmyk)\n\tTransparency = -1,\n\tUserMask = -2,\n\tRealUserMask = -3,\n}\n\nexport const enum Compression {\n\tRawData = 0,\n\tRleCompressed = 1,\n\tZipWithoutPrediction = 2,\n\tZipWithPrediction = 3,\n}\n\nexport interface ChannelData {\n\tchannelId: ChannelID;\n\tcompression: Compression;\n\tbuffer: Uint8Array | undefined;\n\tlength: number;\n}\n\nexport interface Bounds {\n\ttop: number;\n\tleft: number;\n\tright: number;\n\tbottom: number;\n}\n\nexport interface LayerChannelData {\n\tlayer: Layer;\n\tchannels: ChannelData[];\n\ttop: number;\n\tleft: number;\n\tright: number;\n\tbottom: number;\n\tmask?: Bounds;\n}\n\nexport type PixelArray = Uint8ClampedArray | Uint8Array;\n\nexport interface PixelData {\n\tdata: PixelArray;\n\twidth: number;\n\theight: number;\n}\n\nexport function offsetForChannel(channelId: ChannelID, cmyk: boolean) {\n\tswitch (channelId) {\n\t\tcase ChannelID.Color0: return 0;\n\t\tcase ChannelID.Color1: return 1;\n\t\tcase ChannelID.Color2: return 2;\n\t\tcase ChannelID.Color3: return cmyk ? 3 : channelId + 1;\n\t\tcase ChannelID.Transparency: return cmyk ? 4 : 3;\n\t\tdefault: return channelId + 1;\n\t}\n}\n\nexport function clamp(value: number, min: number, max: number) {\n\treturn value < min ? min : (value > max ? max : value);\n}\n\nexport function hasAlpha(data: PixelData) {\n\tconst size = data.width * data.height * 4;\n\n\tfor (let i = 3; i < size; i += 4) {\n\t\tif (data.data[i] !== 255) {\n\t\t\treturn true;\n\t\t}\n\t}\n\n\treturn false;\n}\n\nexport function resetImageData({ data }: PixelData) {\n\tconst buffer = new Uint32Array(data.buffer);\n\tconst size = buffer.length | 0;\n\n\tfor (let p = 0; p < size; p = (p + 1) | 0) {\n\t\tbuffer[p] = 0xff000000;\n\t}\n}\n\nexport function decodeBitmap(input: PixelArray, output: PixelArray, width: number, height: number) {\n\tfor (let y = 0, p = 0, o = 0; y < height; y++) {\n\t\tfor (let x = 0; x < width;) {\n\t\t\tlet b = input[o++];\n\n\t\t\tfor (let i = 0; i < 8 && x < width; i++, x++) {\n\t\t\t\tconst v = b & 0x80 ? 0 : 255;\n\t\t\t\tb = b << 1;\n\t\t\t\toutput[p++] = v;\n\t\t\t\toutput[p++] = v;\n\t\t\t\toutput[p++] = v;\n\t\t\t\toutput[p++] = 255;\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport function writeDataRaw(data: PixelData, offset: number, width: number, height: number) {\n\tif (!width || !height)\n\t\treturn undefined;\n\n\tconst array = new Uint8Array(width * height);\n\n\tfor (let i = 0; i < array.length; i++) {\n\t\tarray[i] = data.data[i * 4 + offset];\n\t}\n\n\treturn array;\n}\n\nexport function writeDataRLE(buffer: Uint8Array, { data, width, height }: PixelData, offsets: number[], large: boolean) {\n\tif (!width || !height) return undefined;\n\n\tconst stride = (4 * width) | 0;\n\n\tlet ol = 0;\n\tlet o = (offsets.length * (large ? 4 : 2) * height) | 0;\n\n\tfor (const offset of offsets) {\n\t\tfor (let y = 0, p = offset | 0; y < height; y++) {\n\t\t\tconst strideStart = (y * stride) | 0;\n\t\t\tconst strideEnd = (strideStart + stride) | 0;\n\t\t\tconst lastIndex = (strideEnd + offset - 4) | 0;\n\t\t\tconst lastIndex2 = (lastIndex - 4) | 0;\n\t\t\tconst startOffset = o;\n\n\t\t\tfor (p = (strideStart + offset) | 0; p < strideEnd; p = (p + 4) | 0) {\n\t\t\t\tif (p < lastIndex2) {\n\t\t\t\t\tlet value1 = data[p];\n\t\t\t\t\tp = (p + 4) | 0;\n\t\t\t\t\tlet value2 = data[p];\n\t\t\t\t\tp = (p + 4) | 0;\n\t\t\t\t\tlet value3 = data[p];\n\n\t\t\t\t\tif (value1 === value2 && value1 === value3) {\n\t\t\t\t\t\tlet count = 3;\n\n\t\t\t\t\t\twhile (count < 128 && p < lastIndex && data[(p + 4) | 0] === value1) {\n\t\t\t\t\t\t\tcount = (count + 1) | 0;\n\t\t\t\t\t\t\tp = (p + 4) | 0;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tbuffer[o++] = 1 - count;\n\t\t\t\t\t\tbuffer[o++] = value1;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tconst countIndex = o;\n\t\t\t\t\t\tlet writeLast = true;\n\t\t\t\t\t\tlet count = 1;\n\t\t\t\t\t\tbuffer[o++] = 0;\n\t\t\t\t\t\tbuffer[o++] = value1;\n\n\t\t\t\t\t\twhile (p < lastIndex && count < 128) {\n\t\t\t\t\t\t\tp = (p + 4) | 0;\n\t\t\t\t\t\t\tvalue1 = value2;\n\t\t\t\t\t\t\tvalue2 = value3;\n\t\t\t\t\t\t\tvalue3 = data[p];\n\n\t\t\t\t\t\t\tif (value1 === value2 && value1 === value3) {\n\t\t\t\t\t\t\t\tp = (p - 12) | 0;\n\t\t\t\t\t\t\t\twriteLast = false;\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tcount++;\n\t\t\t\t\t\t\t\tbuffer[o++] = value1;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (writeLast) {\n\t\t\t\t\t\t\tif (count < 127) {\n\t\t\t\t\t\t\t\tbuffer[o++] = value2;\n\t\t\t\t\t\t\t\tbuffer[o++] = value3;\n\t\t\t\t\t\t\t\tcount += 2;\n\t\t\t\t\t\t\t} else if (count < 128) {\n\t\t\t\t\t\t\t\tbuffer[o++] = value2;\n\t\t\t\t\t\t\t\tcount++;\n\t\t\t\t\t\t\t\tp = (p - 4) | 0;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tp = (p - 8) | 0;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tbuffer[countIndex] = count - 1;\n\t\t\t\t\t}\n\t\t\t\t} else if (p === lastIndex) {\n\t\t\t\t\tbuffer[o++] = 0;\n\t\t\t\t\tbuffer[o++] = data[p];\n\t\t\t\t} else { // p === lastIndex2\n\t\t\t\t\tbuffer[o++] = 1;\n\t\t\t\t\tbuffer[o++] = data[p];\n\t\t\t\t\tp = (p + 4) | 0;\n\t\t\t\t\tbuffer[o++] = data[p];\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst length = o - startOffset;\n\n\t\t\tif (large) {\n\t\t\t\tbuffer[ol++] = (length >> 24) & 0xff;\n\t\t\t\tbuffer[ol++] = (length >> 16) & 0xff;\n\t\t\t}\n\n\t\t\tbuffer[ol++] = (length >> 8) & 0xff;\n\t\t\tbuffer[ol++] = length & 0xff;\n\t\t}\n\t}\n\n\treturn buffer.slice(0, o);\n}\n\nexport function writeDataZipWithoutPrediction({ data, width, height }: PixelData, offsets: number[]) {\n\tconst size = width * height;\n\tconst channel = new Uint8Array(size);\n\tconst buffers: Uint8Array[] = [];\n\tlet totalLength = 0;\n\n\tfor (const offset of offsets) {\n\t\tfor (let i = 0, o = offset; i < size; i++, o += 4) {\n\t\t\tchannel[i] = data[o];\n\t\t}\n\n\t\tconst buffer = deflate(channel);\n\t\tbuffers.push(buffer);\n\t\ttotalLength += buffer.byteLength;\n\t}\n\n\tif (buffers.length > 0) {\n\t\tconst buffer = new Uint8Array(totalLength);\n\t\tlet offset = 0;\n\n\t\tfor (const b of buffers) {\n\t\t\tbuffer.set(b, offset);\n\t\t\toffset += b.byteLength;\n\t\t}\n\n\t\treturn buffer;\n\t} else {\n\t\treturn buffers[0];\n\t}\n}\n\nexport let createCanvas: (width: number, height: number) => HTMLCanvasElement = () => {\n\tthrow new Error('Canvas not initialized, use initializeCanvas method to set up createCanvas method');\n};\n\nexport let createCanvasFromData: (data: Uint8Array) => HTMLCanvasElement = () => {\n\tthrow new Error('Canvas not initialized, use initializeCanvas method to set up createCanvasFromData method');\n};\n\nlet tempCanvas: HTMLCanvasElement | undefined = undefined;\n\nexport let createImageData: (width: number, height: number) => ImageData = (width, height) => {\n\tif (!tempCanvas) tempCanvas = createCanvas(1, 1);\n\treturn tempCanvas.getContext('2d')!.createImageData(width, height);\n};\n\nif (typeof document !== 'undefined') {\n\tcreateCanvas = (width, height) => {\n\t\tconst canvas = document.createElement('canvas');\n\t\tcanvas.width = width;\n\t\tcanvas.height = height;\n\t\treturn canvas;\n\t};\n\n\tcreateCanvasFromData = (data) => {\n\t\tconst image = new Image();\n\t\timage.src = 'data:image/jpeg;base64,' + fromByteArray(data);\n\t\tconst canvas = document.createElement('canvas');\n\t\tcanvas.width = image.width;\n\t\tcanvas.height = image.height;\n\t\tcanvas.getContext('2d')!.drawImage(image, 0, 0);\n\t\treturn canvas;\n\t};\n}\n\nexport function initializeCanvas(\n\tcreateCanvasMethod: (width: number, height: number) => HTMLCanvasElement,\n\tcreateCanvasFromDataMethod?: (data: Uint8Array) => HTMLCanvasElement,\n\tcreateImageDataMethod?: (width: number, height: number) => ImageData\n) {\n\tcreateCanvas = createCanvasMethod;\n\tcreateCanvasFromData = createCanvasFromDataMethod || createCanvasFromData;\n\tcreateImageData = createImageDataMethod || createImageData;\n}\n"],"sourceRoot":"C:\\Projects\\github\\ag-psd\\src"}