@loaders.gl/images 3.1.0-beta.7 → 3.1.3

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 (40) hide show
  1. package/dist/es5/bundle.js +1 -1
  2. package/dist/es5/bundle.js.map +1 -1
  3. package/dist/es5/image-loader.js +8 -6
  4. package/dist/es5/image-loader.js.map +1 -1
  5. package/dist/es5/image-writer.js +1 -1
  6. package/dist/es5/image-writer.js.map +1 -1
  7. package/dist/es5/index.js +11 -11
  8. package/dist/es5/lib/category-api/binary-image-api.js +22 -22
  9. package/dist/es5/lib/category-api/binary-image-api.js.map +1 -1
  10. package/dist/es5/lib/category-api/image-format.js +5 -7
  11. package/dist/es5/lib/category-api/image-format.js.map +1 -1
  12. package/dist/es5/lib/category-api/image-type.js +5 -7
  13. package/dist/es5/lib/category-api/image-type.js.map +1 -1
  14. package/dist/es5/lib/category-api/parsed-image-api.js +8 -4
  15. package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -1
  16. package/dist/es5/lib/encoders/encode-image.js +97 -45
  17. package/dist/es5/lib/encoders/encode-image.js.map +1 -1
  18. package/dist/es5/lib/parsers/parse-image.js +66 -31
  19. package/dist/es5/lib/parsers/parse-image.js.map +1 -1
  20. package/dist/es5/lib/parsers/parse-to-image-bitmap.js +98 -26
  21. package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -1
  22. package/dist/es5/lib/parsers/parse-to-image.js +93 -27
  23. package/dist/es5/lib/parsers/parse-to-image.js.map +1 -1
  24. package/dist/es5/lib/parsers/parse-to-node-image.js +35 -7
  25. package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -1
  26. package/dist/es5/lib/parsers/svg-utils.js +5 -5
  27. package/dist/es5/lib/parsers/svg-utils.js.map +1 -1
  28. package/dist/es5/lib/texture-api/async-deep-map.js +156 -27
  29. package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -1
  30. package/dist/es5/lib/texture-api/deep-load.js +67 -6
  31. package/dist/es5/lib/texture-api/deep-load.js.map +1 -1
  32. package/dist/es5/lib/texture-api/generate-url.js +11 -7
  33. package/dist/es5/lib/texture-api/generate-url.js.map +1 -1
  34. package/dist/es5/lib/texture-api/load-image.js +143 -39
  35. package/dist/es5/lib/texture-api/load-image.js.map +1 -1
  36. package/dist/es5/lib/utils/version.js +1 -1
  37. package/dist/es5/lib/utils/version.js.map +1 -1
  38. package/dist/esm/lib/utils/version.js +1 -1
  39. package/dist/esm/lib/utils/version.js.map +1 -1
  40. package/package.json +3 -3
@@ -1,74 +1,126 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
8
  exports.encodeImage = encodeImage;
7
9
 
10
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
+
12
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
13
+
8
14
  var _parsedImageApi = require("../category-api/parsed-image-api");
9
15
 
10
- const {
11
- _encodeImageNode
12
- } = globalThis;
16
+ var _encodeImageNode = globalThis._encodeImageNode;
13
17
 
14
- async function encodeImage(image, options) {
15
- options = options || {};
16
- options.image = options.image || {};
17
- return _encodeImageNode ? _encodeImageNode(image, {
18
- type: options.image.mimeType
19
- }) : encodeImageInBrowser(image, options);
18
+ function encodeImage(_x, _x2) {
19
+ return _encodeImage.apply(this, arguments);
20
20
  }
21
21
 
22
- let qualityParamSupported = true;
23
-
24
- async function encodeImageInBrowser(image, options) {
25
- const {
26
- mimeType,
27
- jpegQuality
28
- } = options.image;
29
- const {
30
- width,
31
- height
32
- } = (0, _parsedImageApi.getImageSize)(image);
33
- const canvas = document.createElement('canvas');
34
- canvas.width = width;
35
- canvas.height = height;
36
- drawImageToCanvas(image, canvas);
37
- const blob = await new Promise(resolve => {
38
- if (jpegQuality && qualityParamSupported) {
39
- try {
40
- canvas.toBlob(resolve, mimeType, jpegQuality);
41
- return;
42
- } catch (error) {
43
- qualityParamSupported = false;
22
+ function _encodeImage() {
23
+ _encodeImage = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(image, options) {
24
+ return _regenerator.default.wrap(function _callee$(_context2) {
25
+ while (1) {
26
+ switch (_context2.prev = _context2.next) {
27
+ case 0:
28
+ options = options || {};
29
+ options.image = options.image || {};
30
+ return _context2.abrupt("return", _encodeImageNode ? _encodeImageNode(image, {
31
+ type: options.image.mimeType
32
+ }) : encodeImageInBrowser(image, options));
33
+
34
+ case 3:
35
+ case "end":
36
+ return _context2.stop();
37
+ }
44
38
  }
45
- }
39
+ }, _callee);
40
+ }));
41
+ return _encodeImage.apply(this, arguments);
42
+ }
46
43
 
47
- canvas.toBlob(resolve, mimeType);
48
- });
44
+ var qualityParamSupported = true;
49
45
 
50
- if (!blob) {
51
- throw new Error('image encoding failed');
52
- }
46
+ function encodeImageInBrowser(_x3, _x4) {
47
+ return _encodeImageInBrowser.apply(this, arguments);
48
+ }
49
+
50
+ function _encodeImageInBrowser() {
51
+ _encodeImageInBrowser = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(image, options) {
52
+ var _options$image, mimeType, jpegQuality, _getImageSize, width, height, canvas, blob;
53
+
54
+ return _regenerator.default.wrap(function _callee2$(_context3) {
55
+ while (1) {
56
+ switch (_context3.prev = _context3.next) {
57
+ case 0:
58
+ _options$image = options.image, mimeType = _options$image.mimeType, jpegQuality = _options$image.jpegQuality;
59
+ _getImageSize = (0, _parsedImageApi.getImageSize)(image), width = _getImageSize.width, height = _getImageSize.height;
60
+ canvas = document.createElement('canvas');
61
+ canvas.width = width;
62
+ canvas.height = height;
63
+ drawImageToCanvas(image, canvas);
64
+ _context3.next = 8;
65
+ return new Promise(function (resolve) {
66
+ if (jpegQuality && qualityParamSupported) {
67
+ try {
68
+ canvas.toBlob(resolve, mimeType, jpegQuality);
69
+ return;
70
+ } catch (error) {
71
+ qualityParamSupported = false;
72
+ }
73
+ }
53
74
 
54
- return await blob.arrayBuffer();
75
+ canvas.toBlob(resolve, mimeType);
76
+ });
77
+
78
+ case 8:
79
+ blob = _context3.sent;
80
+
81
+ if (blob) {
82
+ _context3.next = 11;
83
+ break;
84
+ }
85
+
86
+ throw new Error('image encoding failed');
87
+
88
+ case 11:
89
+ _context3.next = 13;
90
+ return blob.arrayBuffer();
91
+
92
+ case 13:
93
+ return _context3.abrupt("return", _context3.sent);
94
+
95
+ case 14:
96
+ case "end":
97
+ return _context3.stop();
98
+ }
99
+ }
100
+ }, _callee2);
101
+ }));
102
+ return _encodeImageInBrowser.apply(this, arguments);
55
103
  }
56
104
 
57
- function drawImageToCanvas(image, canvas, x = 0, y = 0) {
105
+ function drawImageToCanvas(image, canvas) {
106
+ var x = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
107
+ var y = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;
108
+
58
109
  if (x === 0 && y === 0 && typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {
59
- const context = canvas.getContext('bitmaprenderer');
110
+ var _context = canvas.getContext('bitmaprenderer');
111
+
112
+ if (_context) {
113
+ _context.transferFromImageBitmap(image);
60
114
 
61
- if (context) {
62
- context.transferFromImageBitmap(image);
63
115
  return canvas;
64
116
  }
65
117
  }
66
118
 
67
- const context = canvas.getContext('2d');
119
+ var context = canvas.getContext('2d');
68
120
 
69
121
  if (image.data) {
70
- const clampedArray = new Uint8ClampedArray(image.data);
71
- const imageData = new ImageData(clampedArray, image.width, image.height);
122
+ var clampedArray = new Uint8ClampedArray(image.data);
123
+ var imageData = new ImageData(clampedArray, image.width, image.height);
72
124
  context.putImageData(imageData, 0, 0);
73
125
  return canvas;
74
126
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/encoders/encode-image.ts"],"names":["_encodeImageNode","globalThis","encodeImage","image","options","type","mimeType","encodeImageInBrowser","qualityParamSupported","jpegQuality","width","height","canvas","document","createElement","drawImageToCanvas","blob","Promise","resolve","toBlob","error","Error","arrayBuffer","x","y","ImageBitmap","context","getContext","transferFromImageBitmap","data","clampedArray","Uint8ClampedArray","imageData","ImageData","putImageData","drawImage"],"mappings":";;;;;;;AACA;;AAGA,MAAM;AAACA,EAAAA;AAAD,IAAqBC,UAA3B;;AAUO,eAAeC,WAAf,CACLC,KADK,EAELC,OAFK,EAGiB;AACtBA,EAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;AACAA,EAAAA,OAAO,CAACD,KAAR,GAAgBC,OAAO,CAACD,KAAR,IAAkB,EAAlC;AAEA,SAAOH,gBAAgB,GACnBA,gBAAgB,CAACG,KAAD,EAAQ;AAACE,IAAAA,IAAI,EAAED,OAAO,CAACD,KAAR,CAAcG;AAArB,GAAR,CADG,GAEnBC,oBAAoB,CAACJ,KAAD,EAAQC,OAAR,CAFxB;AAGD;;AAGD,IAAII,qBAAqB,GAAG,IAA5B;;AASA,eAAeD,oBAAf,CAAoCJ,KAApC,EAA2CC,OAA3C,EAAoD;AAClD,QAAM;AAACE,IAAAA,QAAD;AAAWG,IAAAA;AAAX,MAA0BL,OAAO,CAACD,KAAxC;AAEA,QAAM;AAACO,IAAAA,KAAD;AAAQC,IAAAA;AAAR,MAAkB,kCAAaR,KAAb,CAAxB;AAGA,QAAMS,MAAM,GAAGC,QAAQ,CAACC,aAAT,CAAuB,QAAvB,CAAf;AACAF,EAAAA,MAAM,CAACF,KAAP,GAAeA,KAAf;AACAE,EAAAA,MAAM,CAACD,MAAP,GAAgBA,MAAhB;AAEAI,EAAAA,iBAAiB,CAACZ,KAAD,EAAQS,MAAR,CAAjB;AAGA,QAAMI,IAAI,GAAG,MAAM,IAAIC,OAAJ,CAA0BC,OAAD,IAAa;AAEvD,QAAIT,WAAW,IAAID,qBAAnB,EAA0C;AACxC,UAAI;AACFI,QAAAA,MAAM,CAACO,MAAP,CAAcD,OAAd,EAAuBZ,QAAvB,EAAiCG,WAAjC;AACA;AACD,OAHD,CAGE,OAAOW,KAAP,EAAc;AACdZ,QAAAA,qBAAqB,GAAG,KAAxB;AACD;AACF;;AACDI,IAAAA,MAAM,CAACO,MAAP,CAAcD,OAAd,EAAuBZ,QAAvB;AACD,GAXkB,CAAnB;;AAaA,MAAI,CAACU,IAAL,EAAW;AACT,UAAM,IAAIK,KAAJ,CAAU,uBAAV,CAAN;AACD;;AAED,SAAO,MAAML,IAAI,CAACM,WAAL,EAAb;AACD;;AAED,SAASP,iBAAT,CAA2BZ,KAA3B,EAAkCS,MAAlC,EAA0CW,CAAC,GAAG,CAA9C,EAAiDC,CAAC,GAAG,CAArD,EAAwD;AAEtD,MAAID,CAAC,KAAK,CAAN,IAAWC,CAAC,KAAK,CAAjB,IAAsB,OAAOC,WAAP,KAAuB,WAA7C,IAA4DtB,KAAK,YAAYsB,WAAjF,EAA8F;AAC5F,UAAMC,OAAO,GAAGd,MAAM,CAACe,UAAP,CAAkB,gBAAlB,CAAhB;;AACA,QAAID,OAAJ,EAAa;AAEXA,MAAAA,OAAO,CAACE,uBAAR,CAAgCzB,KAAhC;AACA,aAAOS,MAAP;AACD;AACF;;AAGD,QAAMc,OAAO,GAAGd,MAAM,CAACe,UAAP,CAAkB,IAAlB,CAAhB;;AACA,MAAIxB,KAAK,CAAC0B,IAAV,EAAgB;AAEd,UAAMC,YAAY,GAAG,IAAIC,iBAAJ,CAAsB5B,KAAK,CAAC0B,IAA5B,CAArB;AACA,UAAMG,SAAS,GAAG,IAAIC,SAAJ,CAAcH,YAAd,EAA4B3B,KAAK,CAACO,KAAlC,EAAyCP,KAAK,CAACQ,MAA/C,CAAlB;AACAe,IAAAA,OAAO,CAACQ,YAAR,CAAqBF,SAArB,EAAgC,CAAhC,EAAmC,CAAnC;AACA,WAAOpB,MAAP;AACD;;AAGDc,EAAAA,OAAO,CAACS,SAAR,CAAkBhC,KAAlB,EAAyB,CAAzB,EAA4B,CAA5B;AACA,SAAOS,MAAP;AACD","sourcesContent":["// Image loading/saving for browser and Node.js\nimport {getImageSize} from '../category-api/parsed-image-api';\n\n// @ts-ignore TS2339: Property does not exist on type\nconst {_encodeImageNode} = globalThis;\n\n/**\n * Returns data bytes representing a compressed image in PNG or JPG format,\n * This data can be saved using file system (f) methods or used in a request.\n * @param image - ImageBitmap Image or Canvas\n * @param options\n * param opt.type='png' - png, jpg or image/png, image/jpg are valid\n * param mimeType= - Whether to include a data URI header\n */\nexport async function encodeImage(\n image: any,\n options?: {[key: string]: any}\n): Promise<ArrayBuffer> {\n options = options || {};\n options.image = options.image || ({} as {[key: string]: any});\n\n return _encodeImageNode\n ? _encodeImageNode(image, {type: options.image.mimeType})\n : encodeImageInBrowser(image, options);\n}\n\n// In case we get exceptions from canvas.toBlob(resolve, type, quality)\nlet qualityParamSupported = true;\n\n/**\n *\n * @param image\n * @param options\n * @note Based on canvas.toBlob\n * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob\n */\nasync function encodeImageInBrowser(image, options) {\n const {mimeType, jpegQuality} = options.image;\n\n const {width, height} = getImageSize(image);\n\n // create a canvas and resize it to the size of our image\n const canvas = document.createElement('canvas');\n canvas.width = width;\n canvas.height = height;\n\n drawImageToCanvas(image, canvas);\n\n // The actual encoding is done asynchronously with `canvas.toBlob()`\n const blob = await new Promise<Blob | null>((resolve) => {\n // get it back as a Blob\n if (jpegQuality && qualityParamSupported) {\n try {\n canvas.toBlob(resolve, mimeType, jpegQuality);\n return;\n } catch (error) {\n qualityParamSupported = false;\n }\n }\n canvas.toBlob(resolve, mimeType);\n });\n\n if (!blob) {\n throw new Error('image encoding failed');\n }\n\n return await blob.arrayBuffer();\n}\n\nfunction drawImageToCanvas(image, canvas, x = 0, y = 0) {\n // Try optimized path for ImageBitmaps via bitmaprenderer context\n if (x === 0 && y === 0 && typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {\n const context = canvas.getContext('bitmaprenderer');\n if (context) {\n // transfer the ImageBitmap to it\n context.transferFromImageBitmap(image);\n return canvas;\n }\n }\n\n // Available on most platforms, except IE11 and Andriod WebViews...\n const context = canvas.getContext('2d');\n if (image.data) {\n // ImageData constructor expects clamped array even though getImageData does not return a clamped array...\n const clampedArray = new Uint8ClampedArray(image.data);\n const imageData = new ImageData(clampedArray, image.width, image.height);\n context.putImageData(imageData, 0, 0);\n return canvas;\n }\n\n // Fall back to generic image/image bitmap rendering path\n context.drawImage(image, 0, 0);\n return canvas;\n}\n"],"file":"encode-image.js"}
1
+ {"version":3,"sources":["../../../../src/lib/encoders/encode-image.ts"],"names":["_encodeImageNode","globalThis","encodeImage","image","options","type","mimeType","encodeImageInBrowser","qualityParamSupported","jpegQuality","width","height","canvas","document","createElement","drawImageToCanvas","Promise","resolve","toBlob","error","blob","Error","arrayBuffer","x","y","ImageBitmap","context","getContext","transferFromImageBitmap","data","clampedArray","Uint8ClampedArray","imageData","ImageData","putImageData","drawImage"],"mappings":"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","sourcesContent":["// Image loading/saving for browser and Node.js\nimport {getImageSize} from '../category-api/parsed-image-api';\n\n// @ts-ignore TS2339: Property does not exist on type\nconst {_encodeImageNode} = globalThis;\n\n/**\n * Returns data bytes representing a compressed image in PNG or JPG format,\n * This data can be saved using file system (f) methods or used in a request.\n * @param image - ImageBitmap Image or Canvas\n * @param options\n * param opt.type='png' - png, jpg or image/png, image/jpg are valid\n * param mimeType= - Whether to include a data URI header\n */\nexport async function encodeImage(\n image: any,\n options?: {[key: string]: any}\n): Promise<ArrayBuffer> {\n options = options || {};\n options.image = options.image || ({} as {[key: string]: any});\n\n return _encodeImageNode\n ? _encodeImageNode(image, {type: options.image.mimeType})\n : encodeImageInBrowser(image, options);\n}\n\n// In case we get exceptions from canvas.toBlob(resolve, type, quality)\nlet qualityParamSupported = true;\n\n/**\n *\n * @param image\n * @param options\n * @note Based on canvas.toBlob\n * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob\n */\nasync function encodeImageInBrowser(image, options) {\n const {mimeType, jpegQuality} = options.image;\n\n const {width, height} = getImageSize(image);\n\n // create a canvas and resize it to the size of our image\n const canvas = document.createElement('canvas');\n canvas.width = width;\n canvas.height = height;\n\n drawImageToCanvas(image, canvas);\n\n // The actual encoding is done asynchronously with `canvas.toBlob()`\n const blob = await new Promise<Blob | null>((resolve) => {\n // get it back as a Blob\n if (jpegQuality && qualityParamSupported) {\n try {\n canvas.toBlob(resolve, mimeType, jpegQuality);\n return;\n } catch (error) {\n qualityParamSupported = false;\n }\n }\n canvas.toBlob(resolve, mimeType);\n });\n\n if (!blob) {\n throw new Error('image encoding failed');\n }\n\n return await blob.arrayBuffer();\n}\n\nfunction drawImageToCanvas(image, canvas, x = 0, y = 0) {\n // Try optimized path for ImageBitmaps via bitmaprenderer context\n if (x === 0 && y === 0 && typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {\n const context = canvas.getContext('bitmaprenderer');\n if (context) {\n // transfer the ImageBitmap to it\n context.transferFromImageBitmap(image);\n return canvas;\n }\n }\n\n // Available on most platforms, except IE11 and Andriod WebViews...\n const context = canvas.getContext('2d');\n if (image.data) {\n // ImageData constructor expects clamped array even though getImageData does not return a clamped array...\n const clampedArray = new Uint8ClampedArray(image.data);\n const imageData = new ImageData(clampedArray, image.width, image.height);\n context.putImageData(imageData, 0, 0);\n return canvas;\n }\n\n // Fall back to generic image/image bitmap rendering path\n context.drawImage(image, 0, 0);\n return canvas;\n}\n"],"file":"encode-image.js"}
@@ -7,6 +7,10 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.default = parseImage;
9
9
 
10
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
+
12
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
13
+
10
14
  var _loaderUtils = require("@loaders.gl/loader-utils");
11
15
 
12
16
  var _imageType = require("../category-api/image-type");
@@ -19,38 +23,69 @@ var _parseToImageBitmap = _interopRequireDefault(require("./parse-to-image-bitma
19
23
 
20
24
  var _parseToNodeImage = _interopRequireDefault(require("./parse-to-node-image"));
21
25
 
22
- async function parseImage(arrayBuffer, options, context) {
23
- options = options || {};
24
- const imageOptions = options.image || {};
25
- const imageType = imageOptions.type || 'auto';
26
- const {
27
- url
28
- } = context || {};
29
- const loadType = getLoadableImageType(imageType);
30
- let image;
31
-
32
- switch (loadType) {
33
- case 'imagebitmap':
34
- image = await (0, _parseToImageBitmap.default)(arrayBuffer, options, url);
35
- break;
36
-
37
- case 'image':
38
- image = await (0, _parseToImage.default)(arrayBuffer, options, url);
39
- break;
40
-
41
- case 'data':
42
- image = await (0, _parseToNodeImage.default)(arrayBuffer, options);
43
- break;
44
-
45
- default:
46
- (0, _loaderUtils.assert)(false);
47
- }
48
-
49
- if (imageType === 'data') {
50
- image = (0, _parsedImageApi.getImageData)(image);
51
- }
26
+ function parseImage(_x, _x2, _x3) {
27
+ return _parseImage.apply(this, arguments);
28
+ }
52
29
 
53
- return image;
30
+ function _parseImage() {
31
+ _parseImage = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(arrayBuffer, options, context) {
32
+ var imageOptions, imageType, _ref, url, loadType, image;
33
+
34
+ return _regenerator.default.wrap(function _callee$(_context) {
35
+ while (1) {
36
+ switch (_context.prev = _context.next) {
37
+ case 0:
38
+ options = options || {};
39
+ imageOptions = options.image || {};
40
+ imageType = imageOptions.type || 'auto';
41
+ _ref = context || {}, url = _ref.url;
42
+ loadType = getLoadableImageType(imageType);
43
+ _context.t0 = loadType;
44
+ _context.next = _context.t0 === 'imagebitmap' ? 8 : _context.t0 === 'image' ? 12 : _context.t0 === 'data' ? 16 : 20;
45
+ break;
46
+
47
+ case 8:
48
+ _context.next = 10;
49
+ return (0, _parseToImageBitmap.default)(arrayBuffer, options, url);
50
+
51
+ case 10:
52
+ image = _context.sent;
53
+ return _context.abrupt("break", 21);
54
+
55
+ case 12:
56
+ _context.next = 14;
57
+ return (0, _parseToImage.default)(arrayBuffer, options, url);
58
+
59
+ case 14:
60
+ image = _context.sent;
61
+ return _context.abrupt("break", 21);
62
+
63
+ case 16:
64
+ _context.next = 18;
65
+ return (0, _parseToNodeImage.default)(arrayBuffer, options);
66
+
67
+ case 18:
68
+ image = _context.sent;
69
+ return _context.abrupt("break", 21);
70
+
71
+ case 20:
72
+ (0, _loaderUtils.assert)(false);
73
+
74
+ case 21:
75
+ if (imageType === 'data') {
76
+ image = (0, _parsedImageApi.getImageData)(image);
77
+ }
78
+
79
+ return _context.abrupt("return", image);
80
+
81
+ case 23:
82
+ case "end":
83
+ return _context.stop();
84
+ }
85
+ }
86
+ }, _callee);
87
+ }));
88
+ return _parseImage.apply(this, arguments);
54
89
  }
55
90
 
56
91
  function getLoadableImageType(type) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/parsers/parse-image.ts"],"names":["parseImage","arrayBuffer","options","context","imageOptions","image","imageType","type","url","loadType","getLoadableImageType"],"mappings":";;;;;;;;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AAIe,eAAeA,UAAf,CACbC,WADa,EAEbC,OAFa,EAGbC,OAHa,EAIO;AACpBD,EAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;AACA,QAAME,YAAY,GAAGF,OAAO,CAACG,KAAR,IAAiB,EAAtC;AAGA,QAAMC,SAAS,GAAGF,YAAY,CAACG,IAAb,IAAqB,MAAvC;AAEA,QAAM;AAACC,IAAAA;AAAD,MAAQL,OAAO,IAAI,EAAzB;AAGA,QAAMM,QAAQ,GAAGC,oBAAoB,CAACJ,SAAD,CAArC;AAEA,MAAID,KAAJ;;AACA,UAAQI,QAAR;AACE,SAAK,aAAL;AACEJ,MAAAA,KAAK,GAAG,MAAM,iCAAmBJ,WAAnB,EAAgCC,OAAhC,EAAyCM,GAAzC,CAAd;AACA;;AACF,SAAK,OAAL;AACEH,MAAAA,KAAK,GAAG,MAAM,2BAAaJ,WAAb,EAA0BC,OAA1B,EAAmCM,GAAnC,CAAd;AACA;;AACF,SAAK,MAAL;AAEEH,MAAAA,KAAK,GAAG,MAAM,+BAAiBJ,WAAjB,EAA8BC,OAA9B,CAAd;AACA;;AACF;AACE,+BAAO,KAAP;AAZJ;;AAgBA,MAAII,SAAS,KAAK,MAAlB,EAA0B;AACxBD,IAAAA,KAAK,GAAG,kCAAaA,KAAb,CAAR;AACD;;AAED,SAAOA,KAAP;AACD;;AAGD,SAASK,oBAAT,CAA8BH,IAA9B,EAAoC;AAClC,UAAQA,IAAR;AACE,SAAK,MAAL;AACA,SAAK,MAAL;AAGE,aAAO,qCAAP;;AACF;AAEE,2CAAqBA,IAArB;AACA,aAAOA,IAAP;AATJ;AAWD","sourcesContent":["import type {LoaderContext} from '@loaders.gl/loader-utils';\nimport {assert} from '@loaders.gl/loader-utils';\nimport type {ImageType} from '../../types';\nimport type {ImageLoaderOptions} from '../../image-loader';\nimport {isImageTypeSupported, getDefaultImageType} from '../category-api/image-type';\nimport {getImageData} from '../category-api/parsed-image-api';\nimport parseToImage from './parse-to-image';\nimport parseToImageBitmap from './parse-to-image-bitmap';\nimport parseToNodeImage from './parse-to-node-image';\n\n// Parse to platform defined image type (data on node, ImageBitmap or HTMLImage on browser)\n// eslint-disable-next-line complexity\nexport default async function parseImage(\n arrayBuffer: ArrayBuffer,\n options?: ImageLoaderOptions,\n context?: LoaderContext\n): Promise<ImageType> {\n options = options || {};\n const imageOptions = options.image || {};\n\n // The user can request a specific output format via `options.image.type`\n const imageType = imageOptions.type || 'auto';\n\n const {url} = context || {};\n\n // Note: For options.image.type === `data`, we may still need to load as `image` or `imagebitmap`\n const loadType = getLoadableImageType(imageType);\n\n let image;\n switch (loadType) {\n case 'imagebitmap':\n image = await parseToImageBitmap(arrayBuffer, options, url);\n break;\n case 'image':\n image = await parseToImage(arrayBuffer, options, url);\n break;\n case 'data':\n // Node.js loads imagedata directly\n image = await parseToNodeImage(arrayBuffer, options);\n break;\n default:\n assert(false);\n }\n\n // Browser: if options.image.type === 'data', we can now extract data from the loaded image\n if (imageType === 'data') {\n image = getImageData(image);\n }\n\n return image;\n}\n\n// Get a loadable image type from image type\nfunction getLoadableImageType(type) {\n switch (type) {\n case 'auto':\n case 'data':\n // Browser: For image data we need still need to load using an image format\n // Node: the default image type is `data`.\n return getDefaultImageType();\n default:\n // Throw an error if not supported\n isImageTypeSupported(type);\n return type;\n }\n}\n"],"file":"parse-image.js"}
1
+ {"version":3,"sources":["../../../../src/lib/parsers/parse-image.ts"],"names":["parseImage","arrayBuffer","options","context","imageOptions","image","imageType","type","url","loadType","getLoadableImageType"],"mappings":";;;;;;;;;;;;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;SAI8BA,U;;;;;0EAAf,iBACbC,WADa,EAEbC,OAFa,EAGbC,OAHa;AAAA;;AAAA;AAAA;AAAA;AAAA;AAKbD,YAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;AACME,YAAAA,YANO,GAMQF,OAAO,CAACG,KAAR,IAAiB,EANzB;AASPC,YAAAA,SATO,GASKF,YAAY,CAACG,IAAb,IAAqB,MAT1B;AAAA,mBAWCJ,OAAO,IAAI,EAXZ,EAWNK,GAXM,QAWNA,GAXM;AAcPC,YAAAA,QAdO,GAcIC,oBAAoB,CAACJ,SAAD,CAdxB;AAAA,0BAiBLG,QAjBK;AAAA,4CAkBN,aAlBM,uBAqBN,OArBM,wBAwBN,MAxBM;AAAA;;AAAA;AAAA;AAAA,mBAmBK,iCAAmBR,WAAnB,EAAgCC,OAAhC,EAAyCM,GAAzC,CAnBL;;AAAA;AAmBTH,YAAAA,KAnBS;AAAA;;AAAA;AAAA;AAAA,mBAsBK,2BAAaJ,WAAb,EAA0BC,OAA1B,EAAmCM,GAAnC,CAtBL;;AAAA;AAsBTH,YAAAA,KAtBS;AAAA;;AAAA;AAAA;AAAA,mBA0BK,+BAAiBJ,WAAjB,EAA8BC,OAA9B,CA1BL;;AAAA;AA0BTG,YAAAA,KA1BS;AAAA;;AAAA;AA6BT,qCAAO,KAAP;;AA7BS;AAiCb,gBAAIC,SAAS,KAAK,MAAlB,EAA0B;AACxBD,cAAAA,KAAK,GAAG,kCAAaA,KAAb,CAAR;AACD;;AAnCY,6CAqCNA,KArCM;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAyCf,SAASK,oBAAT,CAA8BH,IAA9B,EAAoC;AAClC,UAAQA,IAAR;AACE,SAAK,MAAL;AACA,SAAK,MAAL;AAGE,aAAO,qCAAP;;AACF;AAEE,2CAAqBA,IAArB;AACA,aAAOA,IAAP;AATJ;AAWD","sourcesContent":["import type {LoaderContext} from '@loaders.gl/loader-utils';\nimport {assert} from '@loaders.gl/loader-utils';\nimport type {ImageType} from '../../types';\nimport type {ImageLoaderOptions} from '../../image-loader';\nimport {isImageTypeSupported, getDefaultImageType} from '../category-api/image-type';\nimport {getImageData} from '../category-api/parsed-image-api';\nimport parseToImage from './parse-to-image';\nimport parseToImageBitmap from './parse-to-image-bitmap';\nimport parseToNodeImage from './parse-to-node-image';\n\n// Parse to platform defined image type (data on node, ImageBitmap or HTMLImage on browser)\n// eslint-disable-next-line complexity\nexport default async function parseImage(\n arrayBuffer: ArrayBuffer,\n options?: ImageLoaderOptions,\n context?: LoaderContext\n): Promise<ImageType> {\n options = options || {};\n const imageOptions = options.image || {};\n\n // The user can request a specific output format via `options.image.type`\n const imageType = imageOptions.type || 'auto';\n\n const {url} = context || {};\n\n // Note: For options.image.type === `data`, we may still need to load as `image` or `imagebitmap`\n const loadType = getLoadableImageType(imageType);\n\n let image;\n switch (loadType) {\n case 'imagebitmap':\n image = await parseToImageBitmap(arrayBuffer, options, url);\n break;\n case 'image':\n image = await parseToImage(arrayBuffer, options, url);\n break;\n case 'data':\n // Node.js loads imagedata directly\n image = await parseToNodeImage(arrayBuffer, options);\n break;\n default:\n assert(false);\n }\n\n // Browser: if options.image.type === 'data', we can now extract data from the loaded image\n if (imageType === 'data') {\n image = getImageData(image);\n }\n\n return image;\n}\n\n// Get a loadable image type from image type\nfunction getLoadableImageType(type) {\n switch (type) {\n case 'auto':\n case 'data':\n // Browser: For image data we need still need to load using an image format\n // Node: the default image type is `data`.\n return getDefaultImageType();\n default:\n // Throw an error if not supported\n isImageTypeSupported(type);\n return type;\n }\n}\n"],"file":"parse-image.js"}
@@ -7,46 +7,118 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.default = parseToImageBitmap;
9
9
 
10
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
+
12
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
13
+
10
14
  var _svgUtils = require("./svg-utils");
11
15
 
12
16
  var _parseToImage = _interopRequireDefault(require("./parse-to-image"));
13
17
 
14
- const EMPTY_OBJECT = {};
15
- let imagebitmapOptionsSupported = true;
18
+ var EMPTY_OBJECT = {};
19
+ var imagebitmapOptionsSupported = true;
16
20
 
17
- async function parseToImageBitmap(arrayBuffer, options, url) {
18
- let blob;
21
+ function parseToImageBitmap(_x, _x2, _x3) {
22
+ return _parseToImageBitmap.apply(this, arguments);
23
+ }
19
24
 
20
- if ((0, _svgUtils.isSVG)(url)) {
21
- const image = await (0, _parseToImage.default)(arrayBuffer, options, url);
22
- blob = image;
23
- } else {
24
- blob = (0, _svgUtils.getBlob)(arrayBuffer, url);
25
- }
25
+ function _parseToImageBitmap() {
26
+ _parseToImageBitmap = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(arrayBuffer, options, url) {
27
+ var blob, image, imagebitmapOptions;
28
+ return _regenerator.default.wrap(function _callee$(_context) {
29
+ while (1) {
30
+ switch (_context.prev = _context.next) {
31
+ case 0:
32
+ if (!(0, _svgUtils.isSVG)(url)) {
33
+ _context.next = 7;
34
+ break;
35
+ }
36
+
37
+ _context.next = 3;
38
+ return (0, _parseToImage.default)(arrayBuffer, options, url);
26
39
 
27
- const imagebitmapOptions = options && options.imagebitmap;
28
- return await safeCreateImageBitmap(blob, imagebitmapOptions);
40
+ case 3:
41
+ image = _context.sent;
42
+ blob = image;
43
+ _context.next = 8;
44
+ break;
45
+
46
+ case 7:
47
+ blob = (0, _svgUtils.getBlob)(arrayBuffer, url);
48
+
49
+ case 8:
50
+ imagebitmapOptions = options && options.imagebitmap;
51
+ _context.next = 11;
52
+ return safeCreateImageBitmap(blob, imagebitmapOptions);
53
+
54
+ case 11:
55
+ return _context.abrupt("return", _context.sent);
56
+
57
+ case 12:
58
+ case "end":
59
+ return _context.stop();
60
+ }
61
+ }
62
+ }, _callee);
63
+ }));
64
+ return _parseToImageBitmap.apply(this, arguments);
29
65
  }
30
66
 
31
- async function safeCreateImageBitmap(blob, imagebitmapOptions = null) {
32
- if (isEmptyObject(imagebitmapOptions) || !imagebitmapOptionsSupported) {
33
- imagebitmapOptions = null;
34
- }
67
+ function safeCreateImageBitmap(_x4) {
68
+ return _safeCreateImageBitmap.apply(this, arguments);
69
+ }
35
70
 
36
- if (imagebitmapOptions) {
37
- try {
38
- return await createImageBitmap(blob, imagebitmapOptions);
39
- } catch (error) {
40
- console.warn(error);
41
- imagebitmapOptionsSupported = false;
42
- }
43
- }
71
+ function _safeCreateImageBitmap() {
72
+ _safeCreateImageBitmap = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(blob) {
73
+ var imagebitmapOptions,
74
+ _args2 = arguments;
75
+ return _regenerator.default.wrap(function _callee2$(_context2) {
76
+ while (1) {
77
+ switch (_context2.prev = _context2.next) {
78
+ case 0:
79
+ imagebitmapOptions = _args2.length > 1 && _args2[1] !== undefined ? _args2[1] : null;
80
+
81
+ if (isEmptyObject(imagebitmapOptions) || !imagebitmapOptionsSupported) {
82
+ imagebitmapOptions = null;
83
+ }
84
+
85
+ if (!imagebitmapOptions) {
86
+ _context2.next = 13;
87
+ break;
88
+ }
89
+
90
+ _context2.prev = 3;
91
+ _context2.next = 6;
92
+ return createImageBitmap(blob, imagebitmapOptions);
93
+
94
+ case 6:
95
+ return _context2.abrupt("return", _context2.sent);
96
+
97
+ case 9:
98
+ _context2.prev = 9;
99
+ _context2.t0 = _context2["catch"](3);
100
+ console.warn(_context2.t0);
101
+ imagebitmapOptionsSupported = false;
102
+
103
+ case 13:
104
+ _context2.next = 15;
105
+ return createImageBitmap(blob);
106
+
107
+ case 15:
108
+ return _context2.abrupt("return", _context2.sent);
44
109
 
45
- return await createImageBitmap(blob);
110
+ case 16:
111
+ case "end":
112
+ return _context2.stop();
113
+ }
114
+ }
115
+ }, _callee2, null, [[3, 9]]);
116
+ }));
117
+ return _safeCreateImageBitmap.apply(this, arguments);
46
118
  }
47
119
 
48
120
  function isEmptyObject(object) {
49
- for (const key in object || EMPTY_OBJECT) {
121
+ for (var key in object || EMPTY_OBJECT) {
50
122
  return false;
51
123
  }
52
124
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/parsers/parse-to-image-bitmap.ts"],"names":["EMPTY_OBJECT","imagebitmapOptionsSupported","parseToImageBitmap","arrayBuffer","options","url","blob","image","imagebitmapOptions","imagebitmap","safeCreateImageBitmap","isEmptyObject","createImageBitmap","error","console","warn","object","key"],"mappings":";;;;;;;;;AACA;;AACA;;AAEA,MAAMA,YAAY,GAAG,EAArB;AAEA,IAAIC,2BAA2B,GAAG,IAAlC;;AASe,eAAeC,kBAAf,CACbC,WADa,EAEbC,OAFa,EAGbC,GAHa,EAIS;AACtB,MAAIC,IAAJ;;AAGA,MAAI,qBAAMD,GAAN,CAAJ,EAAgB;AAEd,UAAME,KAAK,GAAG,MAAM,2BAAaJ,WAAb,EAA0BC,OAA1B,EAAmCC,GAAnC,CAApB;AACAC,IAAAA,IAAI,GAAGC,KAAP;AACD,GAJD,MAIO;AAELD,IAAAA,IAAI,GAAG,uBAAQH,WAAR,EAAqBE,GAArB,CAAP;AACD;;AAED,QAAMG,kBAAkB,GAAGJ,OAAO,IAAIA,OAAO,CAACK,WAA9C;AAEA,SAAO,MAAMC,qBAAqB,CAACJ,IAAD,EAAOE,kBAAP,CAAlC;AACD;;AAQD,eAAeE,qBAAf,CACEJ,IADF,EAEEE,kBAA6C,GAAG,IAFlD,EAGwB;AACtB,MAAIG,aAAa,CAACH,kBAAD,CAAb,IAAqC,CAACP,2BAA1C,EAAuE;AACrEO,IAAAA,kBAAkB,GAAG,IAArB;AACD;;AAED,MAAIA,kBAAJ,EAAwB;AACtB,QAAI;AAEF,aAAO,MAAMI,iBAAiB,CAACN,IAAD,EAAOE,kBAAP,CAA9B;AACD,KAHD,CAGE,OAAOK,KAAP,EAAc;AACdC,MAAAA,OAAO,CAACC,IAAR,CAAaF,KAAb;AACAZ,MAAAA,2BAA2B,GAAG,KAA9B;AACD;AACF;;AAED,SAAO,MAAMW,iBAAiB,CAACN,IAAD,CAA9B;AACD;;AAED,SAASK,aAAT,CAAuBK,MAAvB,EAA+B;AAE7B,OAAK,MAAMC,GAAX,IAAkBD,MAAM,IAAIhB,YAA5B,EAA0C;AACxC,WAAO,KAAP;AACD;;AACD,SAAO,IAAP;AACD","sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport {isSVG, getBlob} from './svg-utils';\nimport parseToImage from './parse-to-image';\n\nconst EMPTY_OBJECT = {};\n\nlet imagebitmapOptionsSupported = true;\n\n/**\n * Asynchronously parses an array buffer into an ImageBitmap - this contains the decoded data\n * ImageBitmaps are supported on worker threads, but not supported on Edge, IE11 and Safari\n * https://developer.mozilla.org/en-US/docs/Web/API/ImageBitmap#Browser_compatibility\n *\n * TODO - createImageBitmap supports source rect (5 param overload), pass through?\n */\nexport default async function parseToImageBitmap(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions,\n url?: string\n): Promise<ImageBitmap> {\n let blob;\n\n // Cannot parse SVG directly to ImageBitmap, parse to Image first\n if (isSVG(url)) {\n // Note: this only works on main thread\n const image = await parseToImage(arrayBuffer, options, url);\n blob = image;\n } else {\n // Create blob from the array buffer\n blob = getBlob(arrayBuffer, url);\n }\n\n const imagebitmapOptions = options && options.imagebitmap;\n\n return await safeCreateImageBitmap(blob, imagebitmapOptions);\n}\n\n/**\n * Safely creates an imageBitmap with options\n * *\n * Firefox crashes if imagebitmapOptions is supplied\n * Avoid supplying if not provided or supported, remember if not supported\n */\nasync function safeCreateImageBitmap(\n blob: Blob,\n imagebitmapOptions: ImageBitmapOptions | null = null\n): Promise<ImageBitmap> {\n if (isEmptyObject(imagebitmapOptions) || !imagebitmapOptionsSupported) {\n imagebitmapOptions = null;\n }\n\n if (imagebitmapOptions) {\n try {\n // @ts-ignore Options\n return await createImageBitmap(blob, imagebitmapOptions);\n } catch (error) {\n console.warn(error); // eslint-disable-line\n imagebitmapOptionsSupported = false;\n }\n }\n\n return await createImageBitmap(blob);\n}\n\nfunction isEmptyObject(object) {\n // @ts-ignore\n for (const key in object || EMPTY_OBJECT) {\n return false;\n }\n return true;\n}\n"],"file":"parse-to-image-bitmap.js"}
1
+ {"version":3,"sources":["../../../../src/lib/parsers/parse-to-image-bitmap.ts"],"names":["EMPTY_OBJECT","imagebitmapOptionsSupported","parseToImageBitmap","arrayBuffer","options","url","image","blob","imagebitmapOptions","imagebitmap","safeCreateImageBitmap","isEmptyObject","createImageBitmap","console","warn","object","key"],"mappings":";;;;;;;;;;;;;AACA;;AACA;;AAEA,IAAMA,YAAY,GAAG,EAArB;AAEA,IAAIC,2BAA2B,GAAG,IAAlC;;SAS8BC,kB;;;;;kFAAf,iBACbC,WADa,EAEbC,OAFa,EAGbC,GAHa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAQT,qBAAMA,GAAN,CARS;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAUS,2BAAaF,WAAb,EAA0BC,OAA1B,EAAmCC,GAAnC,CAVT;;AAAA;AAULC,YAAAA,KAVK;AAWXC,YAAAA,IAAI,GAAGD,KAAP;AAXW;AAAA;;AAAA;AAcXC,YAAAA,IAAI,GAAG,uBAAQJ,WAAR,EAAqBE,GAArB,CAAP;;AAdW;AAiBPG,YAAAA,kBAjBO,GAiBcJ,OAAO,IAAIA,OAAO,CAACK,WAjBjC;AAAA;AAAA,mBAmBAC,qBAAqB,CAACH,IAAD,EAAOC,kBAAP,CAnBrB;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;SA4BAE,qB;;;;;qFAAf,kBACEH,IADF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEEC,YAAAA,kBAFF,8DAEkD,IAFlD;;AAIE,gBAAIG,aAAa,CAACH,kBAAD,CAAb,IAAqC,CAACP,2BAA1C,EAAuE;AACrEO,cAAAA,kBAAkB,GAAG,IAArB;AACD;;AANH,iBAQMA,kBARN;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA,mBAWmBI,iBAAiB,CAACL,IAAD,EAAOC,kBAAP,CAXpC;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAaMK,YAAAA,OAAO,CAACC,IAAR;AACAb,YAAAA,2BAA2B,GAAG,KAA9B;;AAdN;AAAA;AAAA,mBAkBeW,iBAAiB,CAACL,IAAD,CAlBhC;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAqBA,SAASI,aAAT,CAAuBI,MAAvB,EAA+B;AAE7B,OAAK,IAAMC,GAAX,IAAkBD,MAAM,IAAIf,YAA5B,EAA0C;AACxC,WAAO,KAAP;AACD;;AACD,SAAO,IAAP;AACD","sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport {isSVG, getBlob} from './svg-utils';\nimport parseToImage from './parse-to-image';\n\nconst EMPTY_OBJECT = {};\n\nlet imagebitmapOptionsSupported = true;\n\n/**\n * Asynchronously parses an array buffer into an ImageBitmap - this contains the decoded data\n * ImageBitmaps are supported on worker threads, but not supported on Edge, IE11 and Safari\n * https://developer.mozilla.org/en-US/docs/Web/API/ImageBitmap#Browser_compatibility\n *\n * TODO - createImageBitmap supports source rect (5 param overload), pass through?\n */\nexport default async function parseToImageBitmap(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions,\n url?: string\n): Promise<ImageBitmap> {\n let blob;\n\n // Cannot parse SVG directly to ImageBitmap, parse to Image first\n if (isSVG(url)) {\n // Note: this only works on main thread\n const image = await parseToImage(arrayBuffer, options, url);\n blob = image;\n } else {\n // Create blob from the array buffer\n blob = getBlob(arrayBuffer, url);\n }\n\n const imagebitmapOptions = options && options.imagebitmap;\n\n return await safeCreateImageBitmap(blob, imagebitmapOptions);\n}\n\n/**\n * Safely creates an imageBitmap with options\n * *\n * Firefox crashes if imagebitmapOptions is supplied\n * Avoid supplying if not provided or supported, remember if not supported\n */\nasync function safeCreateImageBitmap(\n blob: Blob,\n imagebitmapOptions: ImageBitmapOptions | null = null\n): Promise<ImageBitmap> {\n if (isEmptyObject(imagebitmapOptions) || !imagebitmapOptionsSupported) {\n imagebitmapOptions = null;\n }\n\n if (imagebitmapOptions) {\n try {\n // @ts-ignore Options\n return await createImageBitmap(blob, imagebitmapOptions);\n } catch (error) {\n console.warn(error); // eslint-disable-line\n imagebitmapOptionsSupported = false;\n }\n }\n\n return await createImageBitmap(blob);\n}\n\nfunction isEmptyObject(object) {\n // @ts-ignore\n for (const key in object || EMPTY_OBJECT) {\n return false;\n }\n return true;\n}\n"],"file":"parse-to-image-bitmap.js"}
@@ -1,44 +1,110 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
8
  exports.default = parseToImage;
7
9
  exports.loadToImage = loadToImage;
8
10
 
11
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
12
+
13
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
14
+
9
15
  var _svgUtils = require("./svg-utils");
10
16
 
11
- async function parseToImage(arrayBuffer, options, url) {
12
- const blobOrDataUrl = (0, _svgUtils.getBlobOrSVGDataUrl)(arrayBuffer, url);
13
- const URL = self.URL || self.webkitURL;
14
- const objectUrl = typeof blobOrDataUrl !== 'string' && URL.createObjectURL(blobOrDataUrl);
15
-
16
- try {
17
- return await loadToImage(objectUrl || blobOrDataUrl, options);
18
- } finally {
19
- if (objectUrl) {
20
- URL.revokeObjectURL(objectUrl);
21
- }
22
- }
17
+ function parseToImage(_x, _x2, _x3) {
18
+ return _parseToImage.apply(this, arguments);
19
+ }
20
+
21
+ function _parseToImage() {
22
+ _parseToImage = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(arrayBuffer, options, url) {
23
+ var blobOrDataUrl, URL, objectUrl;
24
+ return _regenerator.default.wrap(function _callee$(_context) {
25
+ while (1) {
26
+ switch (_context.prev = _context.next) {
27
+ case 0:
28
+ blobOrDataUrl = (0, _svgUtils.getBlobOrSVGDataUrl)(arrayBuffer, url);
29
+ URL = self.URL || self.webkitURL;
30
+ objectUrl = typeof blobOrDataUrl !== 'string' && URL.createObjectURL(blobOrDataUrl);
31
+ _context.prev = 3;
32
+ _context.next = 6;
33
+ return loadToImage(objectUrl || blobOrDataUrl, options);
34
+
35
+ case 6:
36
+ return _context.abrupt("return", _context.sent);
37
+
38
+ case 7:
39
+ _context.prev = 7;
40
+
41
+ if (objectUrl) {
42
+ URL.revokeObjectURL(objectUrl);
43
+ }
44
+
45
+ return _context.finish(7);
46
+
47
+ case 10:
48
+ case "end":
49
+ return _context.stop();
50
+ }
51
+ }
52
+ }, _callee, null, [[3,, 7, 10]]);
53
+ }));
54
+ return _parseToImage.apply(this, arguments);
55
+ }
56
+
57
+ function loadToImage(_x4, _x5) {
58
+ return _loadToImage.apply(this, arguments);
23
59
  }
24
60
 
25
- async function loadToImage(url, options) {
26
- const image = new Image();
27
- image.src = url;
61
+ function _loadToImage() {
62
+ _loadToImage = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(url, options) {
63
+ var image;
64
+ return _regenerator.default.wrap(function _callee2$(_context2) {
65
+ while (1) {
66
+ switch (_context2.prev = _context2.next) {
67
+ case 0:
68
+ image = new Image();
69
+ image.src = url;
70
+
71
+ if (!(options.image && options.image.decode && image.decode)) {
72
+ _context2.next = 6;
73
+ break;
74
+ }
75
+
76
+ _context2.next = 5;
77
+ return image.decode();
78
+
79
+ case 5:
80
+ return _context2.abrupt("return", image);
81
+
82
+ case 6:
83
+ _context2.next = 8;
84
+ return new Promise(function (resolve, reject) {
85
+ try {
86
+ image.onload = function () {
87
+ return resolve(image);
88
+ };
28
89
 
29
- if (options.image && options.image.decode && image.decode) {
30
- await image.decode();
31
- return image;
32
- }
90
+ image.onerror = function (err) {
91
+ return reject(new Error("Could not load image ".concat(url, ": ").concat(err)));
92
+ };
93
+ } catch (error) {
94
+ reject(error);
95
+ }
96
+ });
33
97
 
34
- return await new Promise((resolve, reject) => {
35
- try {
36
- image.onload = () => resolve(image);
98
+ case 8:
99
+ return _context2.abrupt("return", _context2.sent);
37
100
 
38
- image.onerror = err => reject(new Error("Could not load image ".concat(url, ": ").concat(err)));
39
- } catch (error) {
40
- reject(error);
41
- }
42
- });
101
+ case 9:
102
+ case "end":
103
+ return _context2.stop();
104
+ }
105
+ }
106
+ }, _callee2);
107
+ }));
108
+ return _loadToImage.apply(this, arguments);
43
109
  }
44
110
  //# sourceMappingURL=parse-to-image.js.map