@loaders.gl/images 3.0.13 → 3.0.14

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 (43) hide show
  1. package/dist/dist.es5.min.js +1 -1
  2. package/dist/dist.es5.min.js.map +1 -1
  3. package/dist/dist.min.js +1 -1
  4. package/dist/dist.min.js.map +1 -1
  5. package/dist/es5/bundle.js +2 -2
  6. package/dist/es5/bundle.js.map +1 -1
  7. package/dist/es5/image-loader.js +7 -5
  8. package/dist/es5/image-loader.js.map +1 -1
  9. package/dist/es5/image-writer.js +1 -1
  10. package/dist/es5/image-writer.js.map +1 -1
  11. package/dist/es5/index.js +10 -10
  12. package/dist/es5/lib/category-api/binary-image-api.js +22 -22
  13. package/dist/es5/lib/category-api/binary-image-api.js.map +1 -1
  14. package/dist/es5/lib/category-api/image-type.js +5 -7
  15. package/dist/es5/lib/category-api/image-type.js.map +1 -1
  16. package/dist/es5/lib/category-api/parsed-image-api.js +8 -4
  17. package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -1
  18. package/dist/es5/lib/encoders/encode-image.js +97 -45
  19. package/dist/es5/lib/encoders/encode-image.js.map +1 -1
  20. package/dist/es5/lib/parsers/parse-image.js +66 -31
  21. package/dist/es5/lib/parsers/parse-image.js.map +1 -1
  22. package/dist/es5/lib/parsers/parse-to-image-bitmap.js +98 -26
  23. package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -1
  24. package/dist/es5/lib/parsers/parse-to-image.js +93 -27
  25. package/dist/es5/lib/parsers/parse-to-image.js.map +1 -1
  26. package/dist/es5/lib/parsers/parse-to-node-image.js +4 -6
  27. package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -1
  28. package/dist/es5/lib/parsers/svg-utils.js +5 -5
  29. package/dist/es5/lib/parsers/svg-utils.js.map +1 -1
  30. package/dist/es5/lib/texture-api/async-deep-map.js +156 -27
  31. package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -1
  32. package/dist/es5/lib/texture-api/deep-load.js +67 -6
  33. package/dist/es5/lib/texture-api/deep-load.js.map +1 -1
  34. package/dist/es5/lib/texture-api/generate-url.js +11 -7
  35. package/dist/es5/lib/texture-api/generate-url.js.map +1 -1
  36. package/dist/es5/lib/texture-api/load-image.js +143 -39
  37. package/dist/es5/lib/texture-api/load-image.js.map +1 -1
  38. package/dist/es5/lib/utils/globals.js +14 -9
  39. package/dist/es5/lib/utils/globals.js.map +1 -1
  40. package/dist/es5/lib/utils/version.js +1 -1
  41. package/dist/es5/lib/utils/version.js.map +1 -1
  42. package/dist/esm/lib/utils/version.js +1 -1
  43. package/package.json +3 -3
@@ -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":";;;;;;;;;AAAA;;AACA;;AAEA,MAAMA,YAAY,GAAG,EAArB;AAEA,IAAIC,2BAA2B,GAAG,IAAlC;;AASe,eAAeC,kBAAf,CAAkCC,WAAlC,EAA+CC,OAA/C,EAAwDC,GAAxD,EAA6D;AAC1E,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,CAAqCJ,IAArC,EAA2CE,kBAAkB,GAAG,IAAhE,EAAsE;AACpE,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 {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(arrayBuffer, options, url) {\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(blob, imagebitmapOptions = null) {\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":";;;;;;;;;;;;;AAAA;;AACA;;AAEA,IAAMA,YAAY,GAAG,EAArB;AAEA,IAAIC,2BAA2B,GAAG,IAAlC;;SAS8BC,kB;;;;;kFAAf,iBAAkCC,WAAlC,EAA+CC,OAA/C,EAAwDC,GAAxD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAIT,qBAAMA,GAAN,CAJS;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAMS,2BAAaF,WAAb,EAA0BC,OAA1B,EAAmCC,GAAnC,CANT;;AAAA;AAMLC,YAAAA,KANK;AAOXC,YAAAA,IAAI,GAAGD,KAAP;AAPW;AAAA;;AAAA;AAUXC,YAAAA,IAAI,GAAG,uBAAQJ,WAAR,EAAqBE,GAArB,CAAP;;AAVW;AAaPG,YAAAA,kBAbO,GAacJ,OAAO,IAAIA,OAAO,CAACK,WAbjC;AAAA;AAAA,mBAeAC,qBAAqB,CAACH,IAAD,EAAOC,kBAAP,CAfrB;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;SAwBAE,qB;;;;;qFAAf,kBAAqCH,IAArC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAA2CC,YAAAA,kBAA3C,8DAAgE,IAAhE;;AACE,gBAAIG,aAAa,CAACH,kBAAD,CAAb,IAAqC,CAACP,2BAA1C,EAAuE;AACrEO,cAAAA,kBAAkB,GAAG,IAArB;AACD;;AAHH,iBAKMA,kBALN;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA,mBAQmBI,iBAAiB,CAACL,IAAD,EAAOC,kBAAP,CARpC;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAUMK,YAAAA,OAAO,CAACC,IAAR;AACAb,YAAAA,2BAA2B,GAAG,KAA9B;;AAXN;AAAA;AAAA,mBAeeW,iBAAiB,CAACL,IAAD,CAfhC;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAkBA,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 {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(arrayBuffer, options, url) {\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(blob, imagebitmapOptions = null) {\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
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/parsers/parse-to-image.ts"],"names":["parseToImage","arrayBuffer","options","url","blobOrDataUrl","URL","self","webkitURL","objectUrl","createObjectURL","loadToImage","revokeObjectURL","image","Image","src","decode","Promise","resolve","reject","onload","onerror","err","Error","error"],"mappings":";;;;;;;;AAAA;;AAGe,eAAeA,YAAf,CAA4BC,WAA5B,EAAyCC,OAAzC,EAAkDC,GAAlD,EAAuD;AAKpE,QAAMC,aAAa,GAAG,mCAAoBH,WAApB,EAAiCE,GAAjC,CAAtB;AACA,QAAME,GAAG,GAAGC,IAAI,CAACD,GAAL,IAAYC,IAAI,CAACC,SAA7B;AACA,QAAMC,SAAS,GAAG,OAAOJ,aAAP,KAAyB,QAAzB,IAAqCC,GAAG,CAACI,eAAJ,CAAoBL,aAApB,CAAvD;;AACA,MAAI;AACF,WAAO,MAAMM,WAAW,CAACF,SAAS,IAAIJ,aAAd,EAA6BF,OAA7B,CAAxB;AACD,GAFD,SAEU;AACR,QAAIM,SAAJ,EAAe;AACbH,MAAAA,GAAG,CAACM,eAAJ,CAAoBH,SAApB;AACD;AACF;AACF;;AAEM,eAAeE,WAAf,CAA2BP,GAA3B,EAAgCD,OAAhC,EAAyC;AAC9C,QAAMU,KAAK,GAAG,IAAIC,KAAJ,EAAd;AACAD,EAAAA,KAAK,CAACE,GAAN,GAAYX,GAAZ;;AASA,MAAID,OAAO,CAACU,KAAR,IAAiBV,OAAO,CAACU,KAAR,CAAcG,MAA/B,IAAyCH,KAAK,CAACG,MAAnD,EAA2D;AACzD,UAAMH,KAAK,CAACG,MAAN,EAAN;AACA,WAAOH,KAAP;AACD;;AAGD,SAAO,MAAM,IAAII,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AAC5C,QAAI;AACFN,MAAAA,KAAK,CAACO,MAAN,GAAe,MAAMF,OAAO,CAACL,KAAD,CAA5B;;AACAA,MAAAA,KAAK,CAACQ,OAAN,GAAiBC,GAAD,IAASH,MAAM,CAAC,IAAII,KAAJ,gCAAkCnB,GAAlC,eAA0CkB,GAA1C,EAAD,CAA/B;AACD,KAHD,CAGE,OAAOE,KAAP,EAAc;AACdL,MAAAA,MAAM,CAACK,KAAD,CAAN;AACD;AACF,GAPY,CAAb;AAQD","sourcesContent":["import {getBlobOrSVGDataUrl} from './svg-utils';\n\n// Parses html image from array buffer\nexport default async function parseToImage(arrayBuffer, options, url) {\n // Note: image parsing requires conversion to Blob (for createObjectURL).\n // Potentially inefficient for not using `response.blob()` (and for File / Blob inputs)...\n // But presumably not worth adding 'blob' flag to loader objects?\n\n const blobOrDataUrl = getBlobOrSVGDataUrl(arrayBuffer, url);\n const URL = self.URL || self.webkitURL;\n const objectUrl = typeof blobOrDataUrl !== 'string' && URL.createObjectURL(blobOrDataUrl);\n try {\n return await loadToImage(objectUrl || blobOrDataUrl, options);\n } finally {\n if (objectUrl) {\n URL.revokeObjectURL(objectUrl);\n }\n }\n}\n\nexport async function loadToImage(url, options) {\n const image = new Image();\n image.src = url;\n\n // The `image.onload()` callback does not guarantee that the image has been decoded\n // so a main thread \"freeze\" can be incurred when using the image for the first time.\n // `Image.decode()` returns a promise that completes when image is decoded.\n\n // https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/decode\n // Note: When calling `img.decode()`, we do not need to wait for `img.onload()`\n // Note: `HTMLImageElement.decode()` is not available in Edge and IE11\n if (options.image && options.image.decode && image.decode) {\n await image.decode();\n return image;\n }\n\n // Create a promise that tracks onload/onerror callbacks\n return await new Promise((resolve, reject) => {\n try {\n image.onload = () => resolve(image);\n image.onerror = (err) => reject(new Error(`Could not load image ${url}: ${err}`));\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"file":"parse-to-image.js"}
1
+ {"version":3,"sources":["../../../../src/lib/parsers/parse-to-image.ts"],"names":["parseToImage","arrayBuffer","options","url","blobOrDataUrl","URL","self","webkitURL","objectUrl","createObjectURL","loadToImage","revokeObjectURL","image","Image","src","decode","Promise","resolve","reject","onload","onerror","err","Error","error"],"mappings":";;;;;;;;;;;;;;AAAA;;SAG8BA,Y;;;;;4EAAf,iBAA4BC,WAA5B,EAAyCC,OAAzC,EAAkDC,GAAlD;AAAA;AAAA;AAAA;AAAA;AAAA;AAKPC,YAAAA,aALO,GAKS,mCAAoBH,WAApB,EAAiCE,GAAjC,CALT;AAMPE,YAAAA,GANO,GAMDC,IAAI,CAACD,GAAL,IAAYC,IAAI,CAACC,SANhB;AAOPC,YAAAA,SAPO,GAOK,OAAOJ,aAAP,KAAyB,QAAzB,IAAqCC,GAAG,CAACI,eAAJ,CAAoBL,aAApB,CAP1C;AAAA;AAAA;AAAA,mBASEM,WAAW,CAACF,SAAS,IAAIJ,aAAd,EAA6BF,OAA7B,CATb;;AAAA;AAAA;;AAAA;AAAA;;AAWX,gBAAIM,SAAJ,EAAe;AACbH,cAAAA,GAAG,CAACM,eAAJ,CAAoBH,SAApB;AACD;;AAbU;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;SAiBOE,W;;;;;2EAAf,kBAA2BP,GAA3B,EAAgCD,OAAhC;AAAA;AAAA;AAAA;AAAA;AAAA;AACCU,YAAAA,KADD,GACS,IAAIC,KAAJ,EADT;AAELD,YAAAA,KAAK,CAACE,GAAN,GAAYX,GAAZ;;AAFK,kBAWDD,OAAO,CAACU,KAAR,IAAiBV,OAAO,CAACU,KAAR,CAAcG,MAA/B,IAAyCH,KAAK,CAACG,MAX9C;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAYGH,KAAK,CAACG,MAAN,EAZH;;AAAA;AAAA,8CAaIH,KAbJ;;AAAA;AAAA;AAAA,mBAiBQ,IAAII,OAAJ,CAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;AAC5C,kBAAI;AACFN,gBAAAA,KAAK,CAACO,MAAN,GAAe;AAAA,yBAAMF,OAAO,CAACL,KAAD,CAAb;AAAA,iBAAf;;AACAA,gBAAAA,KAAK,CAACQ,OAAN,GAAgB,UAACC,GAAD;AAAA,yBAASH,MAAM,CAAC,IAAII,KAAJ,gCAAkCnB,GAAlC,eAA0CkB,GAA1C,EAAD,CAAf;AAAA,iBAAhB;AACD,eAHD,CAGE,OAAOE,KAAP,EAAc;AACdL,gBAAAA,MAAM,CAACK,KAAD,CAAN;AACD;AACF,aAPY,CAjBR;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["import {getBlobOrSVGDataUrl} from './svg-utils';\n\n// Parses html image from array buffer\nexport default async function parseToImage(arrayBuffer, options, url) {\n // Note: image parsing requires conversion to Blob (for createObjectURL).\n // Potentially inefficient for not using `response.blob()` (and for File / Blob inputs)...\n // But presumably not worth adding 'blob' flag to loader objects?\n\n const blobOrDataUrl = getBlobOrSVGDataUrl(arrayBuffer, url);\n const URL = self.URL || self.webkitURL;\n const objectUrl = typeof blobOrDataUrl !== 'string' && URL.createObjectURL(blobOrDataUrl);\n try {\n return await loadToImage(objectUrl || blobOrDataUrl, options);\n } finally {\n if (objectUrl) {\n URL.revokeObjectURL(objectUrl);\n }\n }\n}\n\nexport async function loadToImage(url, options) {\n const image = new Image();\n image.src = url;\n\n // The `image.onload()` callback does not guarantee that the image has been decoded\n // so a main thread \"freeze\" can be incurred when using the image for the first time.\n // `Image.decode()` returns a promise that completes when image is decoded.\n\n // https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/decode\n // Note: When calling `img.decode()`, we do not need to wait for `img.onload()`\n // Note: `HTMLImageElement.decode()` is not available in Edge and IE11\n if (options.image && options.image.decode && image.decode) {\n await image.decode();\n return image;\n }\n\n // Create a promise that tracks onload/onerror callbacks\n return await new Promise((resolve, reject) => {\n try {\n image.onload = () => resolve(image);\n image.onerror = (err) => reject(new Error(`Could not load image ${url}: ${err}`));\n } catch (error) {\n reject(error);\n }\n });\n}\n"],"file":"parse-to-image.js"}
@@ -12,12 +12,10 @@ var _assert = require("../utils/assert");
12
12
  var _binaryImageApi = require("../category-api/binary-image-api");
13
13
 
14
14
  function parseToNodeImage(arrayBuffer, options) {
15
- const {
16
- mimeType
17
- } = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {};
18
- const {
19
- _parseImageNode
20
- } = _globals.global;
15
+ var _ref = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {},
16
+ mimeType = _ref.mimeType;
17
+
18
+ var _parseImageNode = _globals.global._parseImageNode;
21
19
  (0, _assert.assert)(_parseImageNode);
22
20
  return _parseImageNode(arrayBuffer, mimeType, options);
23
21
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/parsers/parse-to-node-image.ts"],"names":["parseToNodeImage","arrayBuffer","options","mimeType","_parseImageNode","global"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AAGe,SAASA,gBAAT,CAA0BC,WAA1B,EAAuCC,OAAvC,EAAgD;AAC7D,QAAM;AAACC,IAAAA;AAAD,MAAa,4CAAuBF,WAAvB,KAAuC,EAA1D;AAGA,QAAM;AAACG,IAAAA;AAAD,MAAoBC,eAA1B;AACA,sBAAOD,eAAP;AAEA,SAAOA,eAAe,CAACH,WAAD,EAAcE,QAAd,EAAwBD,OAAxB,CAAtB;AACD","sourcesContent":["import {global} from '../utils/globals';\nimport {assert} from '../utils/assert';\nimport {getBinaryImageMetadata} from '../category-api/binary-image-api';\n\n// Use polyfills if installed to p[arsed image using get-pixels\nexport default function parseToNodeImage(arrayBuffer, options) {\n const {mimeType} = getBinaryImageMetadata(arrayBuffer) || {};\n\n // @ts-ignore\n const {_parseImageNode} = global;\n assert(_parseImageNode); // '@loaders.gl/polyfills not installed'\n\n return _parseImageNode(arrayBuffer, mimeType, options);\n}\n"],"file":"parse-to-node-image.js"}
1
+ {"version":3,"sources":["../../../../src/lib/parsers/parse-to-node-image.ts"],"names":["parseToNodeImage","arrayBuffer","options","mimeType","_parseImageNode","global"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AAGe,SAASA,gBAAT,CAA0BC,WAA1B,EAAuCC,OAAvC,EAAgD;AAC7D,aAAmB,4CAAuBD,WAAvB,KAAuC,EAA1D;AAAA,MAAOE,QAAP,QAAOA,QAAP;;AAGA,MAAOC,eAAP,GAA0BC,eAA1B,CAAOD,eAAP;AACA,sBAAOA,eAAP;AAEA,SAAOA,eAAe,CAACH,WAAD,EAAcE,QAAd,EAAwBD,OAAxB,CAAtB;AACD","sourcesContent":["import {global} from '../utils/globals';\nimport {assert} from '../utils/assert';\nimport {getBinaryImageMetadata} from '../category-api/binary-image-api';\n\n// Use polyfills if installed to p[arsed image using get-pixels\nexport default function parseToNodeImage(arrayBuffer, options) {\n const {mimeType} = getBinaryImageMetadata(arrayBuffer) || {};\n\n // @ts-ignore\n const {_parseImageNode} = global;\n assert(_parseImageNode); // '@loaders.gl/polyfills not installed'\n\n return _parseImageNode(arrayBuffer, mimeType, options);\n}\n"],"file":"parse-to-node-image.js"}
@@ -6,8 +6,8 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.isSVG = isSVG;
7
7
  exports.getBlobOrSVGDataUrl = getBlobOrSVGDataUrl;
8
8
  exports.getBlob = getBlob;
9
- const SVG_DATA_URL_PATTERN = /^data:image\/svg\+xml/;
10
- const SVG_URL_PATTERN = /\.svg((\?|#).*)?$/;
9
+ var SVG_DATA_URL_PATTERN = /^data:image\/svg\+xml/;
10
+ var SVG_URL_PATTERN = /\.svg((\?|#).*)?$/;
11
11
 
12
12
  function isSVG(url) {
13
13
  return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));
@@ -15,8 +15,8 @@ function isSVG(url) {
15
15
 
16
16
  function getBlobOrSVGDataUrl(arrayBuffer, url) {
17
17
  if (isSVG(url)) {
18
- const textDecoder = new TextDecoder();
19
- let xmlText = textDecoder.decode(arrayBuffer);
18
+ var textDecoder = new TextDecoder();
19
+ var xmlText = textDecoder.decode(arrayBuffer);
20
20
 
21
21
  try {
22
22
  if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {
@@ -26,7 +26,7 @@ function getBlobOrSVGDataUrl(arrayBuffer, url) {
26
26
  throw new Error(error.message);
27
27
  }
28
28
 
29
- const src = "data:image/svg+xml;base64,".concat(btoa(xmlText));
29
+ var src = "data:image/svg+xml;base64,".concat(btoa(xmlText));
30
30
  return src;
31
31
  }
32
32
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/parsers/svg-utils.ts"],"names":["SVG_DATA_URL_PATTERN","SVG_URL_PATTERN","isSVG","url","test","getBlobOrSVGDataUrl","arrayBuffer","textDecoder","TextDecoder","xmlText","decode","unescape","encodeURIComponent","error","Error","message","src","btoa","getBlob","Blob","Uint8Array"],"mappings":";;;;;;;;AAGA,MAAMA,oBAAoB,GAAG,uBAA7B;AACA,MAAMC,eAAe,GAAG,mBAAxB;;AAEO,SAASC,KAAT,CAAeC,GAAf,EAAoB;AACzB,SAAOA,GAAG,KAAKH,oBAAoB,CAACI,IAArB,CAA0BD,GAA1B,KAAkCF,eAAe,CAACG,IAAhB,CAAqBD,GAArB,CAAvC,CAAV;AACD;;AAEM,SAASE,mBAAT,CAA6BC,WAA7B,EAA0CH,GAA1C,EAA+C;AACpD,MAAID,KAAK,CAACC,GAAD,CAAT,EAAgB;AAEd,UAAMI,WAAW,GAAG,IAAIC,WAAJ,EAApB;AACA,QAAIC,OAAO,GAAGF,WAAW,CAACG,MAAZ,CAAmBJ,WAAnB,CAAd;;AAEA,QAAI;AACF,UAAI,OAAOK,QAAP,KAAoB,UAApB,IAAkC,OAAOC,kBAAP,KAA8B,UAApE,EAAgF;AAC9EH,QAAAA,OAAO,GAAGE,QAAQ,CAACC,kBAAkB,CAACH,OAAD,CAAnB,CAAlB;AACD;AACF,KAJD,CAIE,OAAOI,KAAP,EAAc;AACd,YAAM,IAAIC,KAAJ,CAAWD,KAAD,CAAiBE,OAA3B,CAAN;AACD;;AAED,UAAMC,GAAG,uCAAgCC,IAAI,CAACR,OAAD,CAApC,CAAT;AACA,WAAOO,GAAP;AACD;;AACD,SAAOE,OAAO,CAACZ,WAAD,EAAcH,GAAd,CAAd;AACD;;AAEM,SAASe,OAAT,CAAiBZ,WAAjB,EAA8BH,GAA9B,EAAmC;AACxC,MAAID,KAAK,CAACC,GAAD,CAAT,EAAgB;AAGd,UAAM,IAAIW,KAAJ,CAAU,8CAAV,CAAN;AACD;;AAED,SAAO,IAAIK,IAAJ,CAAS,CAAC,IAAIC,UAAJ,CAAed,WAAf,CAAD,CAAT,CAAP;AACD","sourcesContent":["// SVG parsing has limitations, e.g:\n// https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n\nconst SVG_DATA_URL_PATTERN = /^data:image\\/svg\\+xml/;\nconst SVG_URL_PATTERN = /\\.svg((\\?|#).*)?$/;\n\nexport function isSVG(url) {\n return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));\n}\n\nexport function getBlobOrSVGDataUrl(arrayBuffer, url) {\n if (isSVG(url)) {\n // Prepare a properly tagged data URL, and load using normal mechanism\n const textDecoder = new TextDecoder();\n let xmlText = textDecoder.decode(arrayBuffer);\n // TODO Escape in browser to support e.g. Chinese characters\n try {\n if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {\n xmlText = unescape(encodeURIComponent(xmlText));\n }\n } catch (error) {\n throw new Error((error as Error).message);\n }\n // base64 encoding is safer. utf-8 fails in some browsers\n const src = `data:image/svg+xml;base64,${btoa(xmlText)}`;\n return src;\n }\n return getBlob(arrayBuffer, url);\n}\n\nexport function getBlob(arrayBuffer, url) {\n if (isSVG(url)) {\n // https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n // return new Blob([new Uint8Array(arrayBuffer)], {type: 'image/svg+xml'});\n throw new Error('SVG cannot be parsed directly to imagebitmap');\n }\n // TODO - how to determine mime type? Param? Sniff here?\n return new Blob([new Uint8Array(arrayBuffer)]); // MIME type not needed?\n}\n"],"file":"svg-utils.js"}
1
+ {"version":3,"sources":["../../../../src/lib/parsers/svg-utils.ts"],"names":["SVG_DATA_URL_PATTERN","SVG_URL_PATTERN","isSVG","url","test","getBlobOrSVGDataUrl","arrayBuffer","textDecoder","TextDecoder","xmlText","decode","unescape","encodeURIComponent","error","Error","message","src","btoa","getBlob","Blob","Uint8Array"],"mappings":";;;;;;;;AAGA,IAAMA,oBAAoB,GAAG,uBAA7B;AACA,IAAMC,eAAe,GAAG,mBAAxB;;AAEO,SAASC,KAAT,CAAeC,GAAf,EAAoB;AACzB,SAAOA,GAAG,KAAKH,oBAAoB,CAACI,IAArB,CAA0BD,GAA1B,KAAkCF,eAAe,CAACG,IAAhB,CAAqBD,GAArB,CAAvC,CAAV;AACD;;AAEM,SAASE,mBAAT,CAA6BC,WAA7B,EAA0CH,GAA1C,EAA+C;AACpD,MAAID,KAAK,CAACC,GAAD,CAAT,EAAgB;AAEd,QAAMI,WAAW,GAAG,IAAIC,WAAJ,EAApB;AACA,QAAIC,OAAO,GAAGF,WAAW,CAACG,MAAZ,CAAmBJ,WAAnB,CAAd;;AAEA,QAAI;AACF,UAAI,OAAOK,QAAP,KAAoB,UAApB,IAAkC,OAAOC,kBAAP,KAA8B,UAApE,EAAgF;AAC9EH,QAAAA,OAAO,GAAGE,QAAQ,CAACC,kBAAkB,CAACH,OAAD,CAAnB,CAAlB;AACD;AACF,KAJD,CAIE,OAAOI,KAAP,EAAc;AACd,YAAM,IAAIC,KAAJ,CAAWD,KAAD,CAAiBE,OAA3B,CAAN;AACD;;AAED,QAAMC,GAAG,uCAAgCC,IAAI,CAACR,OAAD,CAApC,CAAT;AACA,WAAOO,GAAP;AACD;;AACD,SAAOE,OAAO,CAACZ,WAAD,EAAcH,GAAd,CAAd;AACD;;AAEM,SAASe,OAAT,CAAiBZ,WAAjB,EAA8BH,GAA9B,EAAmC;AACxC,MAAID,KAAK,CAACC,GAAD,CAAT,EAAgB;AAGd,UAAM,IAAIW,KAAJ,CAAU,8CAAV,CAAN;AACD;;AAED,SAAO,IAAIK,IAAJ,CAAS,CAAC,IAAIC,UAAJ,CAAed,WAAf,CAAD,CAAT,CAAP;AACD","sourcesContent":["// SVG parsing has limitations, e.g:\n// https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n\nconst SVG_DATA_URL_PATTERN = /^data:image\\/svg\\+xml/;\nconst SVG_URL_PATTERN = /\\.svg((\\?|#).*)?$/;\n\nexport function isSVG(url) {\n return url && (SVG_DATA_URL_PATTERN.test(url) || SVG_URL_PATTERN.test(url));\n}\n\nexport function getBlobOrSVGDataUrl(arrayBuffer, url) {\n if (isSVG(url)) {\n // Prepare a properly tagged data URL, and load using normal mechanism\n const textDecoder = new TextDecoder();\n let xmlText = textDecoder.decode(arrayBuffer);\n // TODO Escape in browser to support e.g. Chinese characters\n try {\n if (typeof unescape === 'function' && typeof encodeURIComponent === 'function') {\n xmlText = unescape(encodeURIComponent(xmlText));\n }\n } catch (error) {\n throw new Error((error as Error).message);\n }\n // base64 encoding is safer. utf-8 fails in some browsers\n const src = `data:image/svg+xml;base64,${btoa(xmlText)}`;\n return src;\n }\n return getBlob(arrayBuffer, url);\n}\n\nexport function getBlob(arrayBuffer, url) {\n if (isSVG(url)) {\n // https://bugs.chromium.org/p/chromium/issues/detail?id=606319\n // return new Blob([new Uint8Array(arrayBuffer)], {type: 'image/svg+xml'});\n throw new Error('SVG cannot be parsed directly to imagebitmap');\n }\n // TODO - how to determine mime type? Param? Sniff here?\n return new Blob([new Uint8Array(arrayBuffer)]); // MIME type not needed?\n}\n"],"file":"svg-utils.js"}
@@ -1,48 +1,177 @@
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.asyncDeepMap = asyncDeepMap;
7
9
  exports.mapSubtree = mapSubtree;
8
10
 
9
- const isObject = value => value && typeof value === 'object';
11
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
12
+
13
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
14
+
15
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
16
+
17
+ var isObject = function isObject(value) {
18
+ return value && (0, _typeof2.default)(value) === 'object';
19
+ };
10
20
 
11
- async function asyncDeepMap(tree, func, options = {}) {
12
- return await mapSubtree(tree, func, options);
21
+ function asyncDeepMap(_x, _x2) {
22
+ return _asyncDeepMap.apply(this, arguments);
13
23
  }
14
24
 
15
- async function mapSubtree(object, func, options) {
16
- if (Array.isArray(object)) {
17
- return await mapArray(object, func, options);
18
- }
25
+ function _asyncDeepMap() {
26
+ _asyncDeepMap = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(tree, func) {
27
+ var options,
28
+ _args = arguments;
29
+ return _regenerator.default.wrap(function _callee$(_context) {
30
+ while (1) {
31
+ switch (_context.prev = _context.next) {
32
+ case 0:
33
+ options = _args.length > 2 && _args[2] !== undefined ? _args[2] : {};
34
+ _context.next = 3;
35
+ return mapSubtree(tree, func, options);
36
+
37
+ case 3:
38
+ return _context.abrupt("return", _context.sent);
39
+
40
+ case 4:
41
+ case "end":
42
+ return _context.stop();
43
+ }
44
+ }
45
+ }, _callee);
46
+ }));
47
+ return _asyncDeepMap.apply(this, arguments);
48
+ }
49
+
50
+ function mapSubtree(_x3, _x4, _x5) {
51
+ return _mapSubtree.apply(this, arguments);
52
+ }
53
+
54
+ function _mapSubtree() {
55
+ _mapSubtree = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(object, func, options) {
56
+ var url;
57
+ return _regenerator.default.wrap(function _callee2$(_context2) {
58
+ while (1) {
59
+ switch (_context2.prev = _context2.next) {
60
+ case 0:
61
+ if (!Array.isArray(object)) {
62
+ _context2.next = 4;
63
+ break;
64
+ }
65
+
66
+ _context2.next = 3;
67
+ return mapArray(object, func, options);
68
+
69
+ case 3:
70
+ return _context2.abrupt("return", _context2.sent);
71
+
72
+ case 4:
73
+ if (!isObject(object)) {
74
+ _context2.next = 8;
75
+ break;
76
+ }
19
77
 
20
- if (isObject(object)) {
21
- return await mapObject(object, func, options);
22
- }
78
+ _context2.next = 7;
79
+ return mapObject(object, func, options);
23
80
 
24
- const url = object;
25
- return await func(url, options);
81
+ case 7:
82
+ return _context2.abrupt("return", _context2.sent);
83
+
84
+ case 8:
85
+ url = object;
86
+ _context2.next = 11;
87
+ return func(url, options);
88
+
89
+ case 11:
90
+ return _context2.abrupt("return", _context2.sent);
91
+
92
+ case 12:
93
+ case "end":
94
+ return _context2.stop();
95
+ }
96
+ }
97
+ }, _callee2);
98
+ }));
99
+ return _mapSubtree.apply(this, arguments);
26
100
  }
27
101
 
28
- async function mapObject(object, func, options) {
29
- const promises = [];
30
- const values = {};
102
+ function mapObject(_x6, _x7, _x8) {
103
+ return _mapObject.apply(this, arguments);
104
+ }
105
+
106
+ function _mapObject() {
107
+ _mapObject = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee3(object, func, options) {
108
+ var promises, values, _loop, key;
109
+
110
+ return _regenerator.default.wrap(function _callee3$(_context3) {
111
+ while (1) {
112
+ switch (_context3.prev = _context3.next) {
113
+ case 0:
114
+ promises = [];
115
+ values = {};
116
+
117
+ _loop = function _loop(key) {
118
+ var url = object[key];
119
+ var promise = mapSubtree(url, func, options).then(function (value) {
120
+ values[key] = value;
121
+ });
122
+ promises.push(promise);
123
+ };
31
124
 
32
- for (const key in object) {
33
- const url = object[key];
34
- const promise = mapSubtree(url, func, options).then(value => {
35
- values[key] = value;
36
- });
37
- promises.push(promise);
38
- }
125
+ for (key in object) {
126
+ _loop(key);
127
+ }
39
128
 
40
- await Promise.all(promises);
41
- return values;
129
+ _context3.next = 6;
130
+ return Promise.all(promises);
131
+
132
+ case 6:
133
+ return _context3.abrupt("return", values);
134
+
135
+ case 7:
136
+ case "end":
137
+ return _context3.stop();
138
+ }
139
+ }
140
+ }, _callee3);
141
+ }));
142
+ return _mapObject.apply(this, arguments);
143
+ }
144
+
145
+ function mapArray(_x9, _x10) {
146
+ return _mapArray.apply(this, arguments);
42
147
  }
43
148
 
44
- async function mapArray(urlArray, func, options = {}) {
45
- const promises = urlArray.map(url => mapSubtree(url, func, options));
46
- return await Promise.all(promises);
149
+ function _mapArray() {
150
+ _mapArray = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee4(urlArray, func) {
151
+ var options,
152
+ promises,
153
+ _args4 = arguments;
154
+ return _regenerator.default.wrap(function _callee4$(_context4) {
155
+ while (1) {
156
+ switch (_context4.prev = _context4.next) {
157
+ case 0:
158
+ options = _args4.length > 2 && _args4[2] !== undefined ? _args4[2] : {};
159
+ promises = urlArray.map(function (url) {
160
+ return mapSubtree(url, func, options);
161
+ });
162
+ _context4.next = 4;
163
+ return Promise.all(promises);
164
+
165
+ case 4:
166
+ return _context4.abrupt("return", _context4.sent);
167
+
168
+ case 5:
169
+ case "end":
170
+ return _context4.stop();
171
+ }
172
+ }
173
+ }, _callee4);
174
+ }));
175
+ return _mapArray.apply(this, arguments);
47
176
  }
48
177
  //# sourceMappingURL=async-deep-map.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/texture-api/async-deep-map.ts"],"names":["isObject","value","asyncDeepMap","tree","func","options","mapSubtree","object","Array","isArray","mapArray","mapObject","url","promises","values","key","promise","then","push","Promise","all","urlArray","map"],"mappings":";;;;;;;;AAgBA,MAAMA,QAAQ,GAAIC,KAAD,IAAWA,KAAK,IAAI,OAAOA,KAAP,KAAiB,QAAtD;;AAKO,eAAeC,YAAf,CAA4BC,IAA5B,EAAkCC,IAAlC,EAAwCC,OAAO,GAAG,EAAlD,EAAsD;AAC3D,SAAO,MAAMC,UAAU,CAACH,IAAD,EAAOC,IAAP,EAAaC,OAAb,CAAvB;AACD;;AAEM,eAAeC,UAAf,CAA0BC,MAA1B,EAAkCH,IAAlC,EAAwCC,OAAxC,EAAiD;AACtD,MAAIG,KAAK,CAACC,OAAN,CAAcF,MAAd,CAAJ,EAA2B;AACzB,WAAO,MAAMG,QAAQ,CAACH,MAAD,EAASH,IAAT,EAAeC,OAAf,CAArB;AACD;;AAED,MAAIL,QAAQ,CAACO,MAAD,CAAZ,EAAsB;AACpB,WAAO,MAAMI,SAAS,CAACJ,MAAD,EAASH,IAAT,EAAeC,OAAf,CAAtB;AACD;;AAGD,QAAMO,GAAG,GAAGL,MAAZ;AACA,SAAO,MAAMH,IAAI,CAACQ,GAAD,EAAMP,OAAN,CAAjB;AACD;;AAID,eAAeM,SAAf,CAAyBJ,MAAzB,EAAiCH,IAAjC,EAAuCC,OAAvC,EAAgD;AAC9C,QAAMQ,QAAwB,GAAG,EAAjC;AACA,QAAMC,MAAM,GAAG,EAAf;;AAEA,OAAK,MAAMC,GAAX,IAAkBR,MAAlB,EAA0B;AACxB,UAAMK,GAAG,GAAGL,MAAM,CAACQ,GAAD,CAAlB;AACA,UAAMC,OAAO,GAAGV,UAAU,CAACM,GAAD,EAAMR,IAAN,EAAYC,OAAZ,CAAV,CAA+BY,IAA/B,CAAqChB,KAAD,IAAW;AAC7Da,MAAAA,MAAM,CAACC,GAAD,CAAN,GAAcd,KAAd;AACD,KAFe,CAAhB;AAGAY,IAAAA,QAAQ,CAACK,IAAT,CAAcF,OAAd;AACD;;AAED,QAAMG,OAAO,CAACC,GAAR,CAAYP,QAAZ,CAAN;AAEA,SAAOC,MAAP;AACD;;AAED,eAAeJ,QAAf,CAAwBW,QAAxB,EAAkCjB,IAAlC,EAAwCC,OAAO,GAAG,EAAlD,EAAsD;AACpD,QAAMQ,QAAQ,GAAGQ,QAAQ,CAACC,GAAT,CAAcV,GAAD,IAASN,UAAU,CAACM,GAAD,EAAMR,IAAN,EAAYC,OAAZ,CAAhC,CAAjB;AACA,SAAO,MAAMc,OAAO,CAACC,GAAR,CAAYP,QAAZ,CAAb;AACD","sourcesContent":["/*\nAsynchronously maps a deep structure of values (e.g. objects and arrays of urls).\n\nE.g. a mipmapped cubemap\n{\n [CUBE_FACE_FRONT]: [\n \"image-front-0.jpg\",\n \"image-front-1.jpg\",\n \"image-front-2.jpg\",\n ],\n [CUBE_MAP_BACK]: [\n ...\n ]\n}\n*/\n\nconst isObject = (value) => value && typeof value === 'object';\n\n// Loads a deep structure of urls (objects and arrays of urls)\n// Returns an object with six key-value pairs containing the images (or image mip arrays)\n// for each cube face\nexport async function asyncDeepMap(tree, func, options = {}) {\n return await mapSubtree(tree, func, options);\n}\n\nexport async function mapSubtree(object, func, options) {\n if (Array.isArray(object)) {\n return await mapArray(object, func, options);\n }\n\n if (isObject(object)) {\n return await mapObject(object, func, options);\n }\n\n // TODO - ignore non-urls, non-arraybuffers?\n const url = object;\n return await func(url, options);\n}\n\n// HELPERS\n\nasync function mapObject(object, func, options) {\n const promises: Promise<any>[] = [];\n const values = {};\n\n for (const key in object) {\n const url = object[key];\n const promise = mapSubtree(url, func, options).then((value) => {\n values[key] = value;\n });\n promises.push(promise);\n }\n\n await Promise.all(promises);\n\n return values;\n}\n\nasync function mapArray(urlArray, func, options = {}) {\n const promises = urlArray.map((url) => mapSubtree(url, func, options));\n return await Promise.all(promises);\n}\n"],"file":"async-deep-map.js"}
1
+ {"version":3,"sources":["../../../../src/lib/texture-api/async-deep-map.ts"],"names":["isObject","value","asyncDeepMap","tree","func","options","mapSubtree","object","Array","isArray","mapArray","mapObject","url","promises","values","key","promise","then","push","Promise","all","urlArray","map"],"mappings":";;;;;;;;;;;;;;;;AAgBA,IAAMA,QAAQ,GAAG,SAAXA,QAAW,CAACC,KAAD;AAAA,SAAWA,KAAK,IAAI,sBAAOA,KAAP,MAAiB,QAArC;AAAA,CAAjB;;SAKsBC,Y;;;;;4EAAf,iBAA4BC,IAA5B,EAAkCC,IAAlC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAwCC,YAAAA,OAAxC,2DAAkD,EAAlD;AAAA;AAAA,mBACQC,UAAU,CAACH,IAAD,EAAOC,IAAP,EAAaC,OAAb,CADlB;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;SAIeC,U;;;;;0EAAf,kBAA0BC,MAA1B,EAAkCH,IAAlC,EAAwCC,OAAxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBACDG,KAAK,CAACC,OAAN,CAAcF,MAAd,CADC;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAEUG,QAAQ,CAACH,MAAD,EAASH,IAAT,EAAeC,OAAf,CAFlB;;AAAA;AAAA;;AAAA;AAAA,iBAKDL,QAAQ,CAACO,MAAD,CALP;AAAA;AAAA;AAAA;;AAAA;AAAA,mBAMUI,SAAS,CAACJ,MAAD,EAASH,IAAT,EAAeC,OAAf,CANnB;;AAAA;AAAA;;AAAA;AAUCO,YAAAA,GAVD,GAUOL,MAVP;AAAA;AAAA,mBAWQH,IAAI,CAACQ,GAAD,EAAMP,OAAN,CAXZ;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;SAgBQM,S;;;;;yEAAf,kBAAyBJ,MAAzB,EAAiCH,IAAjC,EAAuCC,OAAvC;AAAA;;AAAA;AAAA;AAAA;AAAA;AACQQ,YAAAA,QADR,GACmC,EADnC;AAEQC,YAAAA,MAFR,GAEiB,EAFjB;;AAAA,mCAIaC,GAJb;AAKI,kBAAMH,GAAG,GAAGL,MAAM,CAACQ,GAAD,CAAlB;AACA,kBAAMC,OAAO,GAAGV,UAAU,CAACM,GAAD,EAAMR,IAAN,EAAYC,OAAZ,CAAV,CAA+BY,IAA/B,CAAoC,UAAChB,KAAD,EAAW;AAC7Da,gBAAAA,MAAM,CAACC,GAAD,CAAN,GAAcd,KAAd;AACD,eAFe,CAAhB;AAGAY,cAAAA,QAAQ,CAACK,IAAT,CAAcF,OAAd;AATJ;;AAIE,iBAAWD,GAAX,IAAkBR,MAAlB,EAA0B;AAAA,oBAAfQ,GAAe;AAMzB;;AAVH;AAAA,mBAYQI,OAAO,CAACC,GAAR,CAAYP,QAAZ,CAZR;;AAAA;AAAA,8CAcSC,MAdT;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;SAiBeJ,Q;;;;;wEAAf,kBAAwBW,QAAxB,EAAkCjB,IAAlC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAwCC,YAAAA,OAAxC,8DAAkD,EAAlD;AACQQ,YAAAA,QADR,GACmBQ,QAAQ,CAACC,GAAT,CAAa,UAACV,GAAD;AAAA,qBAASN,UAAU,CAACM,GAAD,EAAMR,IAAN,EAAYC,OAAZ,CAAnB;AAAA,aAAb,CADnB;AAAA;AAAA,mBAEec,OAAO,CAACC,GAAR,CAAYP,QAAZ,CAFf;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["/*\nAsynchronously maps a deep structure of values (e.g. objects and arrays of urls).\n\nE.g. a mipmapped cubemap\n{\n [CUBE_FACE_FRONT]: [\n \"image-front-0.jpg\",\n \"image-front-1.jpg\",\n \"image-front-2.jpg\",\n ],\n [CUBE_MAP_BACK]: [\n ...\n ]\n}\n*/\n\nconst isObject = (value) => value && typeof value === 'object';\n\n// Loads a deep structure of urls (objects and arrays of urls)\n// Returns an object with six key-value pairs containing the images (or image mip arrays)\n// for each cube face\nexport async function asyncDeepMap(tree, func, options = {}) {\n return await mapSubtree(tree, func, options);\n}\n\nexport async function mapSubtree(object, func, options) {\n if (Array.isArray(object)) {\n return await mapArray(object, func, options);\n }\n\n if (isObject(object)) {\n return await mapObject(object, func, options);\n }\n\n // TODO - ignore non-urls, non-arraybuffers?\n const url = object;\n return await func(url, options);\n}\n\n// HELPERS\n\nasync function mapObject(object, func, options) {\n const promises: Promise<any>[] = [];\n const values = {};\n\n for (const key in object) {\n const url = object[key];\n const promise = mapSubtree(url, func, options).then((value) => {\n values[key] = value;\n });\n promises.push(promise);\n }\n\n await Promise.all(promises);\n\n return values;\n}\n\nasync function mapArray(urlArray, func, options = {}) {\n const promises = urlArray.map((url) => mapSubtree(url, func, options));\n return await Promise.all(promises);\n}\n"],"file":"async-deep-map.js"}