ag-psd 15.0.0 → 15.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (102) hide show
  1. package/TODO +0 -2
  2. package/clean.js +3 -0
  3. package/dist/abr.d.ts +132 -132
  4. package/dist/abr.js +270 -271
  5. package/dist/abr.js.map +1 -0
  6. package/dist/additionalInfo.d.ts +25 -25
  7. package/dist/additionalInfo.js +2026 -2045
  8. package/dist/additionalInfo.js.map +1 -0
  9. package/dist/bundle.js +9133 -8707
  10. package/dist/csh.d.ts +10 -10
  11. package/dist/csh.js +48 -49
  12. package/dist/csh.js.map +1 -0
  13. package/dist/descriptor.d.ts +411 -390
  14. package/dist/descriptor.js +1689 -1644
  15. package/dist/descriptor.js.map +1 -0
  16. package/dist/effectsHelpers.d.ts +5 -5
  17. package/dist/effectsHelpers.js +309 -310
  18. package/dist/effectsHelpers.js.map +1 -0
  19. package/dist/engineData.d.ts +2 -2
  20. package/dist/engineData.js +337 -338
  21. package/dist/engineData.js.map +1 -0
  22. package/dist/helpers.d.ts +93 -93
  23. package/dist/helpers.js +332 -333
  24. package/dist/helpers.js.map +1 -0
  25. package/dist/imageResources.d.ts +13 -13
  26. package/dist/imageResources.js +1007 -788
  27. package/dist/imageResources.js.map +1 -0
  28. package/dist/index.d.ts +20 -20
  29. package/dist/index.js +53 -54
  30. package/dist/index.js.map +1 -0
  31. package/dist/initializeCanvas.d.ts +1 -1
  32. package/dist/initializeCanvas.js +26 -27
  33. package/dist/initializeCanvas.js.map +1 -0
  34. package/dist/jpeg.d.ts +1 -1
  35. package/dist/jpeg.js +1019 -1020
  36. package/dist/jpeg.js.map +1 -0
  37. package/dist/psd.d.ts +1200 -1147
  38. package/dist/psd.js +22 -23
  39. package/dist/psd.js.map +1 -0
  40. package/dist/psdReader.d.ts +36 -34
  41. package/dist/psdReader.js +958 -941
  42. package/dist/psdReader.js.map +1 -0
  43. package/dist/psdWriter.d.ts +27 -27
  44. package/dist/psdWriter.js +694 -690
  45. package/dist/psdWriter.js.map +1 -0
  46. package/dist/text.d.ts +168 -168
  47. package/dist/text.js +557 -558
  48. package/dist/text.js.map +1 -0
  49. package/dist/utf8.d.ts +5 -5
  50. package/dist/utf8.js +152 -153
  51. package/dist/utf8.js.map +1 -0
  52. package/dist-es/abr.d.ts +132 -132
  53. package/dist-es/abr.js +266 -267
  54. package/dist-es/abr.js.map +1 -0
  55. package/dist-es/additionalInfo.d.ts +25 -25
  56. package/dist-es/additionalInfo.js +2020 -2039
  57. package/dist-es/additionalInfo.js.map +1 -0
  58. package/dist-es/csh.d.ts +10 -10
  59. package/dist-es/csh.js +44 -45
  60. package/dist-es/csh.js.map +1 -0
  61. package/dist-es/descriptor.d.ts +411 -390
  62. package/dist-es/descriptor.js +1661 -1616
  63. package/dist-es/descriptor.js.map +1 -0
  64. package/dist-es/effectsHelpers.d.ts +5 -5
  65. package/dist-es/effectsHelpers.js +304 -305
  66. package/dist-es/effectsHelpers.js.map +1 -0
  67. package/dist-es/engineData.d.ts +2 -2
  68. package/dist-es/engineData.js +332 -333
  69. package/dist-es/engineData.js.map +1 -0
  70. package/dist-es/helpers.d.ts +93 -93
  71. package/dist-es/helpers.js +315 -316
  72. package/dist-es/helpers.js.map +1 -0
  73. package/dist-es/imageResources.d.ts +13 -13
  74. package/dist-es/imageResources.js +1004 -785
  75. package/dist-es/imageResources.js.map +1 -0
  76. package/dist-es/index.d.ts +20 -20
  77. package/dist-es/index.js +31 -32
  78. package/dist-es/index.js.map +1 -0
  79. package/dist-es/initializeCanvas.d.ts +1 -1
  80. package/dist-es/initializeCanvas.js +22 -23
  81. package/dist-es/initializeCanvas.js.map +1 -0
  82. package/dist-es/jpeg.d.ts +1 -1
  83. package/dist-es/jpeg.js +1015 -1016
  84. package/dist-es/jpeg.js.map +1 -0
  85. package/dist-es/psd.d.ts +1200 -1147
  86. package/dist-es/psd.js +19 -20
  87. package/dist-es/psd.js.map +1 -0
  88. package/dist-es/psdReader.d.ts +36 -34
  89. package/dist-es/psdReader.js +928 -912
  90. package/dist-es/psdReader.js.map +1 -0
  91. package/dist-es/psdWriter.d.ts +27 -27
  92. package/dist-es/psdWriter.js +670 -666
  93. package/dist-es/psdWriter.js.map +1 -0
  94. package/dist-es/text.d.ts +168 -168
  95. package/dist-es/text.js +552 -553
  96. package/dist-es/text.js.map +1 -0
  97. package/dist-es/utf8.d.ts +5 -5
  98. package/dist-es/utf8.js +145 -146
  99. package/dist-es/utf8.js.map +1 -0
  100. package/package.json +11 -17
  101. package/tsconfig-es6.json +7 -0
  102. package/tsconfig.json +7 -1
@@ -1,316 +1,315 @@
1
- import { fromByteArray } from 'base64-js';
2
- import { deflate } from 'pako';
3
- export var MOCK_HANDLERS = false;
4
- export var RAW_IMAGE_DATA = false;
5
- export var fromBlendMode = {};
6
- export var toBlendMode = {
7
- 'pass': 'pass through',
8
- 'norm': 'normal',
9
- 'diss': 'dissolve',
10
- 'dark': 'darken',
11
- 'mul ': 'multiply',
12
- 'idiv': 'color burn',
13
- 'lbrn': 'linear burn',
14
- 'dkCl': 'darker color',
15
- 'lite': 'lighten',
16
- 'scrn': 'screen',
17
- 'div ': 'color dodge',
18
- 'lddg': 'linear dodge',
19
- 'lgCl': 'lighter color',
20
- 'over': 'overlay',
21
- 'sLit': 'soft light',
22
- 'hLit': 'hard light',
23
- 'vLit': 'vivid light',
24
- 'lLit': 'linear light',
25
- 'pLit': 'pin light',
26
- 'hMix': 'hard mix',
27
- 'diff': 'difference',
28
- 'smud': 'exclusion',
29
- 'fsub': 'subtract',
30
- 'fdiv': 'divide',
31
- 'hue ': 'hue',
32
- 'sat ': 'saturation',
33
- 'colr': 'color',
34
- 'lum ': 'luminosity',
35
- };
36
- Object.keys(toBlendMode).forEach(function (key) { return fromBlendMode[toBlendMode[key]] = key; });
37
- export var layerColors = [
38
- 'none', 'red', 'orange', 'yellow', 'green', 'blue', 'violet', 'gray'
39
- ];
40
- export var largeAdditionalInfoKeys = [
41
- // from documentation
42
- 'LMsk', 'Lr16', 'Lr32', 'Layr', 'Mt16', 'Mt32', 'Mtrn', 'Alph', 'FMsk', 'lnk2', 'FEid', 'FXid', 'PxSD',
43
- // from guessing
44
- 'cinf',
45
- ];
46
- export function revMap(map) {
47
- var result = {};
48
- Object.keys(map).forEach(function (key) { return result[map[key]] = key; });
49
- return result;
50
- }
51
- export function createEnum(prefix, def, map) {
52
- var rev = revMap(map);
53
- var decode = function (val) {
54
- var value = val.split('.')[1];
55
- if (value && !rev[value])
56
- throw new Error("Unrecognized value for enum: '".concat(val, "'"));
57
- return rev[value] || def;
58
- };
59
- var encode = function (val) {
60
- if (val && !map[val])
61
- throw new Error("Invalid value for enum: '".concat(val, "'"));
62
- return "".concat(prefix, ".").concat(map[val] || map[def]);
63
- };
64
- return { decode: decode, encode: encode };
65
- }
66
- export var ColorSpace;
67
- (function (ColorSpace) {
68
- ColorSpace[ColorSpace["RGB"] = 0] = "RGB";
69
- ColorSpace[ColorSpace["HSB"] = 1] = "HSB";
70
- ColorSpace[ColorSpace["CMYK"] = 2] = "CMYK";
71
- ColorSpace[ColorSpace["Lab"] = 7] = "Lab";
72
- ColorSpace[ColorSpace["Grayscale"] = 8] = "Grayscale";
73
- })(ColorSpace || (ColorSpace = {}));
74
- export var LayerMaskFlags;
75
- (function (LayerMaskFlags) {
76
- LayerMaskFlags[LayerMaskFlags["PositionRelativeToLayer"] = 1] = "PositionRelativeToLayer";
77
- LayerMaskFlags[LayerMaskFlags["LayerMaskDisabled"] = 2] = "LayerMaskDisabled";
78
- LayerMaskFlags[LayerMaskFlags["InvertLayerMaskWhenBlending"] = 4] = "InvertLayerMaskWhenBlending";
79
- LayerMaskFlags[LayerMaskFlags["LayerMaskFromRenderingOtherData"] = 8] = "LayerMaskFromRenderingOtherData";
80
- LayerMaskFlags[LayerMaskFlags["MaskHasParametersAppliedToIt"] = 16] = "MaskHasParametersAppliedToIt";
81
- })(LayerMaskFlags || (LayerMaskFlags = {}));
82
- export var MaskParams;
83
- (function (MaskParams) {
84
- MaskParams[MaskParams["UserMaskDensity"] = 1] = "UserMaskDensity";
85
- MaskParams[MaskParams["UserMaskFeather"] = 2] = "UserMaskFeather";
86
- MaskParams[MaskParams["VectorMaskDensity"] = 4] = "VectorMaskDensity";
87
- MaskParams[MaskParams["VectorMaskFeather"] = 8] = "VectorMaskFeather";
88
- })(MaskParams || (MaskParams = {}));
89
- export var ChannelID;
90
- (function (ChannelID) {
91
- ChannelID[ChannelID["Color0"] = 0] = "Color0";
92
- ChannelID[ChannelID["Color1"] = 1] = "Color1";
93
- ChannelID[ChannelID["Color2"] = 2] = "Color2";
94
- ChannelID[ChannelID["Color3"] = 3] = "Color3";
95
- ChannelID[ChannelID["Transparency"] = -1] = "Transparency";
96
- ChannelID[ChannelID["UserMask"] = -2] = "UserMask";
97
- ChannelID[ChannelID["RealUserMask"] = -3] = "RealUserMask";
98
- })(ChannelID || (ChannelID = {}));
99
- export var Compression;
100
- (function (Compression) {
101
- Compression[Compression["RawData"] = 0] = "RawData";
102
- Compression[Compression["RleCompressed"] = 1] = "RleCompressed";
103
- Compression[Compression["ZipWithoutPrediction"] = 2] = "ZipWithoutPrediction";
104
- Compression[Compression["ZipWithPrediction"] = 3] = "ZipWithPrediction";
105
- })(Compression || (Compression = {}));
106
- export function offsetForChannel(channelId, cmyk) {
107
- switch (channelId) {
108
- case 0 /* ChannelID.Color0 */: return 0;
109
- case 1 /* ChannelID.Color1 */: return 1;
110
- case 2 /* ChannelID.Color2 */: return 2;
111
- case 3 /* ChannelID.Color3 */: return cmyk ? 3 : channelId + 1;
112
- case -1 /* ChannelID.Transparency */: return cmyk ? 4 : 3;
113
- default: return channelId + 1;
114
- }
115
- }
116
- export function clamp(value, min, max) {
117
- return value < min ? min : (value > max ? max : value);
118
- }
119
- export function hasAlpha(data) {
120
- var size = data.width * data.height * 4;
121
- for (var i = 3; i < size; i += 4) {
122
- if (data.data[i] !== 255) {
123
- return true;
124
- }
125
- }
126
- return false;
127
- }
128
- export function resetImageData(_a) {
129
- var data = _a.data;
130
- var buffer = new Uint32Array(data.buffer);
131
- var size = buffer.length | 0;
132
- for (var p = 0; p < size; p = (p + 1) | 0) {
133
- buffer[p] = 0xff000000;
134
- }
135
- }
136
- export function decodeBitmap(input, output, width, height) {
137
- for (var y = 0, p = 0, o = 0; y < height; y++) {
138
- for (var x = 0; x < width;) {
139
- var b = input[o++];
140
- for (var i = 0; i < 8 && x < width; i++, x++) {
141
- var v = b & 0x80 ? 0 : 255;
142
- b = b << 1;
143
- output[p++] = v;
144
- output[p++] = v;
145
- output[p++] = v;
146
- output[p++] = 255;
147
- }
148
- }
149
- }
150
- }
151
- export function writeDataRaw(data, offset, width, height) {
152
- if (!width || !height)
153
- return undefined;
154
- var array = new Uint8Array(width * height);
155
- for (var i = 0; i < array.length; i++) {
156
- array[i] = data.data[i * 4 + offset];
157
- }
158
- return array;
159
- }
160
- export function writeDataRLE(buffer, _a, offsets, large) {
161
- var data = _a.data, width = _a.width, height = _a.height;
162
- if (!width || !height)
163
- return undefined;
164
- var stride = (4 * width) | 0;
165
- var ol = 0;
166
- var o = (offsets.length * (large ? 4 : 2) * height) | 0;
167
- for (var _i = 0, offsets_1 = offsets; _i < offsets_1.length; _i++) {
168
- var offset = offsets_1[_i];
169
- for (var y = 0, p = offset | 0; y < height; y++) {
170
- var strideStart = (y * stride) | 0;
171
- var strideEnd = (strideStart + stride) | 0;
172
- var lastIndex = (strideEnd + offset - 4) | 0;
173
- var lastIndex2 = (lastIndex - 4) | 0;
174
- var startOffset = o;
175
- for (p = (strideStart + offset) | 0; p < strideEnd; p = (p + 4) | 0) {
176
- if (p < lastIndex2) {
177
- var value1 = data[p];
178
- p = (p + 4) | 0;
179
- var value2 = data[p];
180
- p = (p + 4) | 0;
181
- var value3 = data[p];
182
- if (value1 === value2 && value1 === value3) {
183
- var count = 3;
184
- while (count < 128 && p < lastIndex && data[(p + 4) | 0] === value1) {
185
- count = (count + 1) | 0;
186
- p = (p + 4) | 0;
187
- }
188
- buffer[o++] = 1 - count;
189
- buffer[o++] = value1;
190
- }
191
- else {
192
- var countIndex = o;
193
- var writeLast = true;
194
- var count = 1;
195
- buffer[o++] = 0;
196
- buffer[o++] = value1;
197
- while (p < lastIndex && count < 128) {
198
- p = (p + 4) | 0;
199
- value1 = value2;
200
- value2 = value3;
201
- value3 = data[p];
202
- if (value1 === value2 && value1 === value3) {
203
- p = (p - 12) | 0;
204
- writeLast = false;
205
- break;
206
- }
207
- else {
208
- count++;
209
- buffer[o++] = value1;
210
- }
211
- }
212
- if (writeLast) {
213
- if (count < 127) {
214
- buffer[o++] = value2;
215
- buffer[o++] = value3;
216
- count += 2;
217
- }
218
- else if (count < 128) {
219
- buffer[o++] = value2;
220
- count++;
221
- p = (p - 4) | 0;
222
- }
223
- else {
224
- p = (p - 8) | 0;
225
- }
226
- }
227
- buffer[countIndex] = count - 1;
228
- }
229
- }
230
- else if (p === lastIndex) {
231
- buffer[o++] = 0;
232
- buffer[o++] = data[p];
233
- }
234
- else { // p === lastIndex2
235
- buffer[o++] = 1;
236
- buffer[o++] = data[p];
237
- p = (p + 4) | 0;
238
- buffer[o++] = data[p];
239
- }
240
- }
241
- var length_1 = o - startOffset;
242
- if (large) {
243
- buffer[ol++] = (length_1 >> 24) & 0xff;
244
- buffer[ol++] = (length_1 >> 16) & 0xff;
245
- }
246
- buffer[ol++] = (length_1 >> 8) & 0xff;
247
- buffer[ol++] = length_1 & 0xff;
248
- }
249
- }
250
- return buffer.slice(0, o);
251
- }
252
- export function writeDataZipWithoutPrediction(_a, offsets) {
253
- var data = _a.data, width = _a.width, height = _a.height;
254
- var size = width * height;
255
- var channel = new Uint8Array(size);
256
- var buffers = [];
257
- var totalLength = 0;
258
- for (var _i = 0, offsets_2 = offsets; _i < offsets_2.length; _i++) {
259
- var offset = offsets_2[_i];
260
- for (var i = 0, o = offset; i < size; i++, o += 4) {
261
- channel[i] = data[o];
262
- }
263
- var buffer = deflate(channel);
264
- buffers.push(buffer);
265
- totalLength += buffer.byteLength;
266
- }
267
- if (buffers.length > 0) {
268
- var buffer = new Uint8Array(totalLength);
269
- var offset = 0;
270
- for (var _b = 0, buffers_1 = buffers; _b < buffers_1.length; _b++) {
271
- var b = buffers_1[_b];
272
- buffer.set(b, offset);
273
- offset += b.byteLength;
274
- }
275
- return buffer;
276
- }
277
- else {
278
- return buffers[0];
279
- }
280
- }
281
- export var createCanvas = function () {
282
- throw new Error('Canvas not initialized, use initializeCanvas method to set up createCanvas method');
283
- };
284
- export var createCanvasFromData = function () {
285
- throw new Error('Canvas not initialized, use initializeCanvas method to set up createCanvasFromData method');
286
- };
287
- var tempCanvas = undefined;
288
- export var createImageData = function (width, height) {
289
- if (!tempCanvas)
290
- tempCanvas = createCanvas(1, 1);
291
- return tempCanvas.getContext('2d').createImageData(width, height);
292
- };
293
- if (typeof document !== 'undefined') {
294
- createCanvas = function (width, height) {
295
- var canvas = document.createElement('canvas');
296
- canvas.width = width;
297
- canvas.height = height;
298
- return canvas;
299
- };
300
- createCanvasFromData = function (data) {
301
- var image = new Image();
302
- image.src = 'data:image/jpeg;base64,' + fromByteArray(data);
303
- var canvas = document.createElement('canvas');
304
- canvas.width = image.width;
305
- canvas.height = image.height;
306
- canvas.getContext('2d').drawImage(image, 0, 0);
307
- return canvas;
308
- };
309
- }
310
- export function initializeCanvas(createCanvasMethod, createCanvasFromDataMethod, createImageDataMethod) {
311
- createCanvas = createCanvasMethod;
312
- createCanvasFromData = createCanvasFromDataMethod || createCanvasFromData;
313
- createImageData = createImageDataMethod || createImageData;
314
- }
315
-
316
- //# 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"}
1
+ import { fromByteArray } from 'base64-js';
2
+ import { deflate } from 'pako';
3
+ export var MOCK_HANDLERS = false;
4
+ export var RAW_IMAGE_DATA = false;
5
+ export var fromBlendMode = {};
6
+ export var toBlendMode = {
7
+ 'pass': 'pass through',
8
+ 'norm': 'normal',
9
+ 'diss': 'dissolve',
10
+ 'dark': 'darken',
11
+ 'mul ': 'multiply',
12
+ 'idiv': 'color burn',
13
+ 'lbrn': 'linear burn',
14
+ 'dkCl': 'darker color',
15
+ 'lite': 'lighten',
16
+ 'scrn': 'screen',
17
+ 'div ': 'color dodge',
18
+ 'lddg': 'linear dodge',
19
+ 'lgCl': 'lighter color',
20
+ 'over': 'overlay',
21
+ 'sLit': 'soft light',
22
+ 'hLit': 'hard light',
23
+ 'vLit': 'vivid light',
24
+ 'lLit': 'linear light',
25
+ 'pLit': 'pin light',
26
+ 'hMix': 'hard mix',
27
+ 'diff': 'difference',
28
+ 'smud': 'exclusion',
29
+ 'fsub': 'subtract',
30
+ 'fdiv': 'divide',
31
+ 'hue ': 'hue',
32
+ 'sat ': 'saturation',
33
+ 'colr': 'color',
34
+ 'lum ': 'luminosity',
35
+ };
36
+ Object.keys(toBlendMode).forEach(function (key) { return fromBlendMode[toBlendMode[key]] = key; });
37
+ export var layerColors = [
38
+ 'none', 'red', 'orange', 'yellow', 'green', 'blue', 'violet', 'gray'
39
+ ];
40
+ export var largeAdditionalInfoKeys = [
41
+ // from documentation
42
+ 'LMsk', 'Lr16', 'Lr32', 'Layr', 'Mt16', 'Mt32', 'Mtrn', 'Alph', 'FMsk', 'lnk2', 'FEid', 'FXid', 'PxSD',
43
+ // from guessing
44
+ 'cinf',
45
+ ];
46
+ export function revMap(map) {
47
+ var result = {};
48
+ Object.keys(map).forEach(function (key) { return result[map[key]] = key; });
49
+ return result;
50
+ }
51
+ export function createEnum(prefix, def, map) {
52
+ var rev = revMap(map);
53
+ var decode = function (val) {
54
+ var value = val.split('.')[1];
55
+ if (value && !rev[value])
56
+ throw new Error("Unrecognized value for enum: '".concat(val, "'"));
57
+ return rev[value] || def;
58
+ };
59
+ var encode = function (val) {
60
+ if (val && !map[val])
61
+ throw new Error("Invalid value for enum: '".concat(val, "'"));
62
+ return "".concat(prefix, ".").concat(map[val] || map[def]);
63
+ };
64
+ return { decode: decode, encode: encode };
65
+ }
66
+ export var ColorSpace;
67
+ (function (ColorSpace) {
68
+ ColorSpace[ColorSpace["RGB"] = 0] = "RGB";
69
+ ColorSpace[ColorSpace["HSB"] = 1] = "HSB";
70
+ ColorSpace[ColorSpace["CMYK"] = 2] = "CMYK";
71
+ ColorSpace[ColorSpace["Lab"] = 7] = "Lab";
72
+ ColorSpace[ColorSpace["Grayscale"] = 8] = "Grayscale";
73
+ })(ColorSpace || (ColorSpace = {}));
74
+ export var LayerMaskFlags;
75
+ (function (LayerMaskFlags) {
76
+ LayerMaskFlags[LayerMaskFlags["PositionRelativeToLayer"] = 1] = "PositionRelativeToLayer";
77
+ LayerMaskFlags[LayerMaskFlags["LayerMaskDisabled"] = 2] = "LayerMaskDisabled";
78
+ LayerMaskFlags[LayerMaskFlags["InvertLayerMaskWhenBlending"] = 4] = "InvertLayerMaskWhenBlending";
79
+ LayerMaskFlags[LayerMaskFlags["LayerMaskFromRenderingOtherData"] = 8] = "LayerMaskFromRenderingOtherData";
80
+ LayerMaskFlags[LayerMaskFlags["MaskHasParametersAppliedToIt"] = 16] = "MaskHasParametersAppliedToIt";
81
+ })(LayerMaskFlags || (LayerMaskFlags = {}));
82
+ export var MaskParams;
83
+ (function (MaskParams) {
84
+ MaskParams[MaskParams["UserMaskDensity"] = 1] = "UserMaskDensity";
85
+ MaskParams[MaskParams["UserMaskFeather"] = 2] = "UserMaskFeather";
86
+ MaskParams[MaskParams["VectorMaskDensity"] = 4] = "VectorMaskDensity";
87
+ MaskParams[MaskParams["VectorMaskFeather"] = 8] = "VectorMaskFeather";
88
+ })(MaskParams || (MaskParams = {}));
89
+ export var ChannelID;
90
+ (function (ChannelID) {
91
+ ChannelID[ChannelID["Color0"] = 0] = "Color0";
92
+ ChannelID[ChannelID["Color1"] = 1] = "Color1";
93
+ ChannelID[ChannelID["Color2"] = 2] = "Color2";
94
+ ChannelID[ChannelID["Color3"] = 3] = "Color3";
95
+ ChannelID[ChannelID["Transparency"] = -1] = "Transparency";
96
+ ChannelID[ChannelID["UserMask"] = -2] = "UserMask";
97
+ ChannelID[ChannelID["RealUserMask"] = -3] = "RealUserMask";
98
+ })(ChannelID || (ChannelID = {}));
99
+ export var Compression;
100
+ (function (Compression) {
101
+ Compression[Compression["RawData"] = 0] = "RawData";
102
+ Compression[Compression["RleCompressed"] = 1] = "RleCompressed";
103
+ Compression[Compression["ZipWithoutPrediction"] = 2] = "ZipWithoutPrediction";
104
+ Compression[Compression["ZipWithPrediction"] = 3] = "ZipWithPrediction";
105
+ })(Compression || (Compression = {}));
106
+ export function offsetForChannel(channelId, cmyk) {
107
+ switch (channelId) {
108
+ case 0 /* ChannelID.Color0 */: return 0;
109
+ case 1 /* ChannelID.Color1 */: return 1;
110
+ case 2 /* ChannelID.Color2 */: return 2;
111
+ case 3 /* ChannelID.Color3 */: return cmyk ? 3 : channelId + 1;
112
+ case -1 /* ChannelID.Transparency */: return cmyk ? 4 : 3;
113
+ default: return channelId + 1;
114
+ }
115
+ }
116
+ export function clamp(value, min, max) {
117
+ return value < min ? min : (value > max ? max : value);
118
+ }
119
+ export function hasAlpha(data) {
120
+ var size = data.width * data.height * 4;
121
+ for (var i = 3; i < size; i += 4) {
122
+ if (data.data[i] !== 255) {
123
+ return true;
124
+ }
125
+ }
126
+ return false;
127
+ }
128
+ export function resetImageData(_a) {
129
+ var data = _a.data;
130
+ var buffer = new Uint32Array(data.buffer);
131
+ var size = buffer.length | 0;
132
+ for (var p = 0; p < size; p = (p + 1) | 0) {
133
+ buffer[p] = 0xff000000;
134
+ }
135
+ }
136
+ export function decodeBitmap(input, output, width, height) {
137
+ for (var y = 0, p = 0, o = 0; y < height; y++) {
138
+ for (var x = 0; x < width;) {
139
+ var b = input[o++];
140
+ for (var i = 0; i < 8 && x < width; i++, x++) {
141
+ var v = b & 0x80 ? 0 : 255;
142
+ b = b << 1;
143
+ output[p++] = v;
144
+ output[p++] = v;
145
+ output[p++] = v;
146
+ output[p++] = 255;
147
+ }
148
+ }
149
+ }
150
+ }
151
+ export function writeDataRaw(data, offset, width, height) {
152
+ if (!width || !height)
153
+ return undefined;
154
+ var array = new Uint8Array(width * height);
155
+ for (var i = 0; i < array.length; i++) {
156
+ array[i] = data.data[i * 4 + offset];
157
+ }
158
+ return array;
159
+ }
160
+ export function writeDataRLE(buffer, _a, offsets, large) {
161
+ var data = _a.data, width = _a.width, height = _a.height;
162
+ if (!width || !height)
163
+ return undefined;
164
+ var stride = (4 * width) | 0;
165
+ var ol = 0;
166
+ var o = (offsets.length * (large ? 4 : 2) * height) | 0;
167
+ for (var _i = 0, offsets_1 = offsets; _i < offsets_1.length; _i++) {
168
+ var offset = offsets_1[_i];
169
+ for (var y = 0, p = offset | 0; y < height; y++) {
170
+ var strideStart = (y * stride) | 0;
171
+ var strideEnd = (strideStart + stride) | 0;
172
+ var lastIndex = (strideEnd + offset - 4) | 0;
173
+ var lastIndex2 = (lastIndex - 4) | 0;
174
+ var startOffset = o;
175
+ for (p = (strideStart + offset) | 0; p < strideEnd; p = (p + 4) | 0) {
176
+ if (p < lastIndex2) {
177
+ var value1 = data[p];
178
+ p = (p + 4) | 0;
179
+ var value2 = data[p];
180
+ p = (p + 4) | 0;
181
+ var value3 = data[p];
182
+ if (value1 === value2 && value1 === value3) {
183
+ var count = 3;
184
+ while (count < 128 && p < lastIndex && data[(p + 4) | 0] === value1) {
185
+ count = (count + 1) | 0;
186
+ p = (p + 4) | 0;
187
+ }
188
+ buffer[o++] = 1 - count;
189
+ buffer[o++] = value1;
190
+ }
191
+ else {
192
+ var countIndex = o;
193
+ var writeLast = true;
194
+ var count = 1;
195
+ buffer[o++] = 0;
196
+ buffer[o++] = value1;
197
+ while (p < lastIndex && count < 128) {
198
+ p = (p + 4) | 0;
199
+ value1 = value2;
200
+ value2 = value3;
201
+ value3 = data[p];
202
+ if (value1 === value2 && value1 === value3) {
203
+ p = (p - 12) | 0;
204
+ writeLast = false;
205
+ break;
206
+ }
207
+ else {
208
+ count++;
209
+ buffer[o++] = value1;
210
+ }
211
+ }
212
+ if (writeLast) {
213
+ if (count < 127) {
214
+ buffer[o++] = value2;
215
+ buffer[o++] = value3;
216
+ count += 2;
217
+ }
218
+ else if (count < 128) {
219
+ buffer[o++] = value2;
220
+ count++;
221
+ p = (p - 4) | 0;
222
+ }
223
+ else {
224
+ p = (p - 8) | 0;
225
+ }
226
+ }
227
+ buffer[countIndex] = count - 1;
228
+ }
229
+ }
230
+ else if (p === lastIndex) {
231
+ buffer[o++] = 0;
232
+ buffer[o++] = data[p];
233
+ }
234
+ else { // p === lastIndex2
235
+ buffer[o++] = 1;
236
+ buffer[o++] = data[p];
237
+ p = (p + 4) | 0;
238
+ buffer[o++] = data[p];
239
+ }
240
+ }
241
+ var length_1 = o - startOffset;
242
+ if (large) {
243
+ buffer[ol++] = (length_1 >> 24) & 0xff;
244
+ buffer[ol++] = (length_1 >> 16) & 0xff;
245
+ }
246
+ buffer[ol++] = (length_1 >> 8) & 0xff;
247
+ buffer[ol++] = length_1 & 0xff;
248
+ }
249
+ }
250
+ return buffer.slice(0, o);
251
+ }
252
+ export function writeDataZipWithoutPrediction(_a, offsets) {
253
+ var data = _a.data, width = _a.width, height = _a.height;
254
+ var size = width * height;
255
+ var channel = new Uint8Array(size);
256
+ var buffers = [];
257
+ var totalLength = 0;
258
+ for (var _i = 0, offsets_2 = offsets; _i < offsets_2.length; _i++) {
259
+ var offset = offsets_2[_i];
260
+ for (var i = 0, o = offset; i < size; i++, o += 4) {
261
+ channel[i] = data[o];
262
+ }
263
+ var buffer = deflate(channel);
264
+ buffers.push(buffer);
265
+ totalLength += buffer.byteLength;
266
+ }
267
+ if (buffers.length > 0) {
268
+ var buffer = new Uint8Array(totalLength);
269
+ var offset = 0;
270
+ for (var _b = 0, buffers_1 = buffers; _b < buffers_1.length; _b++) {
271
+ var b = buffers_1[_b];
272
+ buffer.set(b, offset);
273
+ offset += b.byteLength;
274
+ }
275
+ return buffer;
276
+ }
277
+ else {
278
+ return buffers[0];
279
+ }
280
+ }
281
+ export var createCanvas = function () {
282
+ throw new Error('Canvas not initialized, use initializeCanvas method to set up createCanvas method');
283
+ };
284
+ export var createCanvasFromData = function () {
285
+ throw new Error('Canvas not initialized, use initializeCanvas method to set up createCanvasFromData method');
286
+ };
287
+ var tempCanvas = undefined;
288
+ export var createImageData = function (width, height) {
289
+ if (!tempCanvas)
290
+ tempCanvas = createCanvas(1, 1);
291
+ return tempCanvas.getContext('2d').createImageData(width, height);
292
+ };
293
+ if (typeof document !== 'undefined') {
294
+ createCanvas = function (width, height) {
295
+ var canvas = document.createElement('canvas');
296
+ canvas.width = width;
297
+ canvas.height = height;
298
+ return canvas;
299
+ };
300
+ createCanvasFromData = function (data) {
301
+ var image = new Image();
302
+ image.src = 'data:image/jpeg;base64,' + fromByteArray(data);
303
+ var canvas = document.createElement('canvas');
304
+ canvas.width = image.width;
305
+ canvas.height = image.height;
306
+ canvas.getContext('2d').drawImage(image, 0, 0);
307
+ return canvas;
308
+ };
309
+ }
310
+ export function initializeCanvas(createCanvasMethod, createCanvasFromDataMethod, createImageDataMethod) {
311
+ createCanvas = createCanvasMethod;
312
+ createCanvasFromData = createCanvasFromDataMethod || createCanvasFromData;
313
+ createImageData = createImageDataMethod || createImageData;
314
+ }
315
+ //# sourceMappingURL=helpers.js.map