@loaders.gl/images 3.1.0-alpha.4 → 3.1.0-alpha.5

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 (69) hide show
  1. package/dist/bundle.d.ts +1 -0
  2. package/dist/dist.min.js +1 -1
  3. package/dist/dist.min.js.map +1 -1
  4. package/dist/es5/bundle.js +1 -1
  5. package/dist/es5/bundle.js.map +1 -1
  6. package/dist/es5/image-loader.js +6 -8
  7. package/dist/es5/image-loader.js.map +1 -1
  8. package/dist/es5/image-writer.js +1 -1
  9. package/dist/es5/image-writer.js.map +1 -1
  10. package/dist/es5/index.js +11 -11
  11. package/dist/es5/lib/category-api/binary-image-api.js +22 -22
  12. package/dist/es5/lib/category-api/binary-image-api.js.map +1 -1
  13. package/dist/es5/lib/category-api/image-format.js +7 -5
  14. package/dist/es5/lib/category-api/image-format.js.map +1 -1
  15. package/dist/es5/lib/category-api/image-type.js +7 -5
  16. package/dist/es5/lib/category-api/image-type.js.map +1 -1
  17. package/dist/es5/lib/category-api/parsed-image-api.js +4 -8
  18. package/dist/es5/lib/category-api/parsed-image-api.js.map +1 -1
  19. package/dist/es5/lib/encoders/encode-image.js +45 -97
  20. package/dist/es5/lib/encoders/encode-image.js.map +1 -1
  21. package/dist/es5/lib/parsers/parse-image.js +31 -66
  22. package/dist/es5/lib/parsers/parse-image.js.map +1 -1
  23. package/dist/es5/lib/parsers/parse-to-image-bitmap.js +26 -98
  24. package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +1 -1
  25. package/dist/es5/lib/parsers/parse-to-image.js +27 -93
  26. package/dist/es5/lib/parsers/parse-to-image.js.map +1 -1
  27. package/dist/es5/lib/parsers/parse-to-node-image.js +7 -35
  28. package/dist/es5/lib/parsers/parse-to-node-image.js.map +1 -1
  29. package/dist/es5/lib/parsers/svg-utils.js +5 -5
  30. package/dist/es5/lib/parsers/svg-utils.js.map +1 -1
  31. package/dist/es5/lib/texture-api/async-deep-map.js +27 -156
  32. package/dist/es5/lib/texture-api/async-deep-map.js.map +1 -1
  33. package/dist/es5/lib/texture-api/deep-load.js +6 -67
  34. package/dist/es5/lib/texture-api/deep-load.js.map +1 -1
  35. package/dist/es5/lib/texture-api/generate-url.js +7 -11
  36. package/dist/es5/lib/texture-api/generate-url.js.map +1 -1
  37. package/dist/es5/lib/texture-api/load-image.js +39 -143
  38. package/dist/es5/lib/texture-api/load-image.js.map +1 -1
  39. package/dist/es5/lib/utils/version.js +1 -1
  40. package/dist/es5/lib/utils/version.js.map +1 -1
  41. package/dist/esm/lib/category-api/image-type.js +1 -1
  42. package/dist/esm/lib/category-api/image-type.js.map +1 -1
  43. package/dist/esm/lib/parsers/parse-to-image.js +1 -1
  44. package/dist/esm/lib/parsers/parse-to-image.js.map +1 -1
  45. package/dist/esm/lib/parsers/svg-utils.js +1 -1
  46. package/dist/esm/lib/parsers/svg-utils.js.map +1 -1
  47. package/dist/esm/lib/texture-api/generate-url.js +1 -1
  48. package/dist/esm/lib/texture-api/generate-url.js.map +1 -1
  49. package/dist/esm/lib/utils/version.js +1 -1
  50. package/dist/image-loader.d.ts +25 -0
  51. package/dist/image-writer.d.ts +15 -0
  52. package/dist/index.d.ts +9 -0
  53. package/dist/lib/category-api/binary-image-api.d.ts +18 -0
  54. package/dist/lib/category-api/image-format.d.ts +4 -0
  55. package/dist/lib/category-api/image-type.d.ts +11 -0
  56. package/dist/lib/category-api/parsed-image-api.d.ts +9 -0
  57. package/dist/lib/encoders/encode-image.d.ts +11 -0
  58. package/dist/lib/parsers/parse-image.d.ts +4 -0
  59. package/dist/lib/parsers/parse-to-image-bitmap.d.ts +9 -0
  60. package/dist/lib/parsers/parse-to-image.d.ts +3 -0
  61. package/dist/lib/parsers/parse-to-node-image.d.ts +3 -0
  62. package/dist/lib/parsers/svg-utils.d.ts +3 -0
  63. package/dist/lib/texture-api/async-deep-map.d.ts +2 -0
  64. package/dist/lib/texture-api/deep-load.d.ts +2 -0
  65. package/dist/lib/texture-api/generate-url.d.ts +1 -0
  66. package/dist/lib/texture-api/load-image.d.ts +6 -0
  67. package/dist/lib/utils/version.d.ts +1 -0
  68. package/dist/types.d.ts +17 -0
  69. package/package.json +5 -4
@@ -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;;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"}
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"}
@@ -7,118 +7,46 @@ 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
-
14
10
  var _svgUtils = require("./svg-utils");
15
11
 
16
12
  var _parseToImage = _interopRequireDefault(require("./parse-to-image"));
17
13
 
18
- var EMPTY_OBJECT = {};
19
- var imagebitmapOptionsSupported = true;
20
-
21
- function parseToImageBitmap(_x, _x2, _x3) {
22
- return _parseToImageBitmap.apply(this, arguments);
23
- }
24
-
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
- }
14
+ const EMPTY_OBJECT = {};
15
+ let imagebitmapOptionsSupported = true;
36
16
 
37
- _context.next = 3;
38
- return (0, _parseToImage.default)(arrayBuffer, options, url);
17
+ async function parseToImageBitmap(arrayBuffer, options, url) {
18
+ let blob;
39
19
 
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);
65
- }
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
+ }
66
26
 
67
- function safeCreateImageBitmap(_x4) {
68
- return _safeCreateImageBitmap.apply(this, arguments);
27
+ const imagebitmapOptions = options && options.imagebitmap;
28
+ return await safeCreateImageBitmap(blob, imagebitmapOptions);
69
29
  }
70
30
 
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);
31
+ async function safeCreateImageBitmap(blob, imagebitmapOptions = null) {
32
+ if (isEmptyObject(imagebitmapOptions) || !imagebitmapOptionsSupported) {
33
+ imagebitmapOptions = null;
34
+ }
106
35
 
107
- case 15:
108
- return _context2.abrupt("return", _context2.sent);
36
+ if (imagebitmapOptions) {
37
+ try {
38
+ return await createImageBitmap(blob, imagebitmapOptions);
39
+ } catch (error) {
40
+ console.warn(error);
41
+ imagebitmapOptionsSupported = false;
42
+ }
43
+ }
109
44
 
110
- case 16:
111
- case "end":
112
- return _context2.stop();
113
- }
114
- }
115
- }, _callee2, null, [[3, 9]]);
116
- }));
117
- return _safeCreateImageBitmap.apply(this, arguments);
45
+ return await createImageBitmap(blob);
118
46
  }
119
47
 
120
48
  function isEmptyObject(object) {
121
- for (var key in object || EMPTY_OBJECT) {
49
+ for (const key in object || EMPTY_OBJECT) {
122
50
  return false;
123
51
  }
124
52
 
@@ -1 +1 @@
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
+ {"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,110 +1,44 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
3
  Object.defineProperty(exports, "__esModule", {
6
4
  value: true
7
5
  });
8
6
  exports.default = parseToImage;
9
7
  exports.loadToImage = loadToImage;
10
8
 
11
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
12
-
13
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
14
-
15
9
  var _svgUtils = require("./svg-utils");
16
10
 
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);
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
+ }
59
23
  }
60
24
 
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
- };
25
+ async function loadToImage(url, options) {
26
+ const image = new Image();
27
+ image.src = url;
89
28
 
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
- });
29
+ if (options.image && options.image.decode && image.decode) {
30
+ await image.decode();
31
+ return image;
32
+ }
97
33
 
98
- case 8:
99
- return _context2.abrupt("return", _context2.sent);
34
+ return await new Promise((resolve, reject) => {
35
+ try {
36
+ image.onload = () => resolve(image);
100
37
 
101
- case 9:
102
- case "end":
103
- return _context2.stop();
104
- }
105
- }
106
- }, _callee2);
107
- }));
108
- return _loadToImage.apply(this, arguments);
38
+ image.onerror = err => reject(new Error("Could not load image ".concat(url, ": ").concat(err)));
39
+ } catch (error) {
40
+ reject(error);
41
+ }
42
+ });
109
43
  }
110
44
  //# 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":";;;;;;;;;;;;;;AACA;;SAG8BA,Y;;;;;4EAAf,iBACbC,WADa,EAEbC,OAFa,EAGbC,GAHa;AAAA;AAAA;AAAA;AAAA;AAAA;AASPC,YAAAA,aATO,GASS,mCAAoBH,WAApB,EAAiCE,GAAjC,CATT;AAUPE,YAAAA,GAVO,GAUDC,IAAI,CAACD,GAAL,IAAYC,IAAI,CAACC,SAVhB;AAWPC,YAAAA,SAXO,GAWK,OAAOJ,aAAP,KAAyB,QAAzB,IAAqCC,GAAG,CAACI,eAAJ,CAAoBL,aAApB,CAX1C;AAAA;AAAA;AAAA,mBAaEM,WAAW,CAACF,SAAS,IAAIJ,aAAd,EAA6BF,OAA7B,CAbb;;AAAA;AAAA;;AAAA;AAAA;;AAeX,gBAAIM,SAAJ,EAAe;AACbH,cAAAA,GAAG,CAACM,eAAJ,CAAoBH,SAApB;AACD;;AAjBU;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;SAqBOE,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 type {ImageLoaderOptions} from '../../image-loader';\nimport {getBlobOrSVGDataUrl} from './svg-utils';\n\n// Parses html image from array buffer\nexport default async function parseToImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions,\n url?: string\n): Promise<HTMLImageElement> {\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): Promise<HTMLImageElement> {\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":";;;;;;;;AACA;;AAGe,eAAeA,YAAf,CACbC,WADa,EAEbC,OAFa,EAGbC,GAHa,EAIc;AAK3B,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,EAAoE;AACzE,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 type {ImageLoaderOptions} from '../../image-loader';\nimport {getBlobOrSVGDataUrl} from './svg-utils';\n\n// Parses html image from array buffer\nexport default async function parseToImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions,\n url?: string\n): Promise<HTMLImageElement> {\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): Promise<HTMLImageElement> {\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,48 +1,20 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
3
  Object.defineProperty(exports, "__esModule", {
6
4
  value: true
7
5
  });
8
6
  exports.default = parseToNodeImage;
9
7
 
10
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
-
12
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
13
-
14
8
  var _loaderUtils = require("@loaders.gl/loader-utils");
15
9
 
16
10
  var _binaryImageApi = require("../category-api/binary-image-api");
17
11
 
18
- function parseToNodeImage(_x, _x2) {
19
- return _parseToNodeImage.apply(this, arguments);
20
- }
21
-
22
- function _parseToNodeImage() {
23
- _parseToNodeImage = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(arrayBuffer, options) {
24
- var _ref, mimeType, _parseImageNode;
25
-
26
- return _regenerator.default.wrap(function _callee$(_context) {
27
- while (1) {
28
- switch (_context.prev = _context.next) {
29
- case 0:
30
- _ref = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {}, mimeType = _ref.mimeType;
31
- _parseImageNode = globalThis._parseImageNode;
32
- (0, _loaderUtils.assert)(_parseImageNode);
33
- _context.next = 5;
34
- return _parseImageNode(arrayBuffer, mimeType);
35
-
36
- case 5:
37
- return _context.abrupt("return", _context.sent);
38
-
39
- case 6:
40
- case "end":
41
- return _context.stop();
42
- }
43
- }
44
- }, _callee);
45
- }));
46
- return _parseToNodeImage.apply(this, arguments);
12
+ async function parseToNodeImage(arrayBuffer, options) {
13
+ const {
14
+ mimeType
15
+ } = (0, _binaryImageApi.getBinaryImageMetadata)(arrayBuffer) || {};
16
+ const _parseImageNode = globalThis._parseImageNode;
17
+ (0, _loaderUtils.assert)(_parseImageNode);
18
+ return await _parseImageNode(arrayBuffer, mimeType);
47
19
  }
48
20
  //# sourceMappingURL=parse-to-node-image.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/parsers/parse-to-node-image.ts"],"names":["parseToNodeImage","arrayBuffer","options","mimeType","_parseImageNode","globalThis"],"mappings":";;;;;;;;;;;;;AAEA;;AACA;;SAgB8BA,gB;;;;;gFAAf,iBACbC,WADa,EAEbC,OAFa;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA,mBAIM,4CAAuBD,WAAvB,KAAuC,EAJ7C,EAINE,QAJM,QAINA,QAJM;AAOPC,YAAAA,eAPO,GAO2BC,UAAU,CAACD,eAPtC;AAQb,qCAAOA,eAAP;AARa;AAAA,mBAWAA,eAAe,CAACH,WAAD,EAAcE,QAAd,CAXf;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport type {ImageDataType} from '../../types';\nimport {assert} from '@loaders.gl/loader-utils';\nimport {getBinaryImageMetadata} from '../category-api/binary-image-api';\n\n// Note: These types should be consistent with loaders.gl/polyfills\n\ntype NDArray = {\n shape: number[];\n data: Uint8Array;\n width: number;\n height: number;\n components: number;\n layers: number[];\n};\n\ntype ParseImageNode = (arrayBuffer: ArrayBuffer, mimeType: string) => Promise<NDArray>;\n\n// Use polyfills if installed to parsed image using get-pixels\nexport default async function parseToNodeImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions\n): Promise<ImageDataType> {\n const {mimeType} = getBinaryImageMetadata(arrayBuffer) || {};\n\n // @ts-ignore\n const _parseImageNode: ParseImageNode = globalThis._parseImageNode;\n assert(_parseImageNode); // '@loaders.gl/polyfills not installed'\n\n // @ts-expect-error TODO should we throw error in this case?\n return await _parseImageNode(arrayBuffer, mimeType);\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","globalThis"],"mappings":";;;;;;;AAEA;;AACA;;AAgBe,eAAeA,gBAAf,CACbC,WADa,EAEbC,OAFa,EAGW;AACxB,QAAM;AAACC,IAAAA;AAAD,MAAa,4CAAuBF,WAAvB,KAAuC,EAA1D;AAGA,QAAMG,eAA+B,GAAGC,UAAU,CAACD,eAAnD;AACA,2BAAOA,eAAP;AAGA,SAAO,MAAMA,eAAe,CAACH,WAAD,EAAcE,QAAd,CAA5B;AACD","sourcesContent":["import type {ImageLoaderOptions} from '../../image-loader';\nimport type {ImageDataType} from '../../types';\nimport {assert} from '@loaders.gl/loader-utils';\nimport {getBinaryImageMetadata} from '../category-api/binary-image-api';\n\n// Note: These types should be consistent with loaders.gl/polyfills\n\ntype NDArray = {\n shape: number[];\n data: Uint8Array;\n width: number;\n height: number;\n components: number;\n layers: number[];\n};\n\ntype ParseImageNode = (arrayBuffer: ArrayBuffer, mimeType: string) => Promise<NDArray>;\n\n// Use polyfills if installed to parsed image using get-pixels\nexport default async function parseToNodeImage(\n arrayBuffer: ArrayBuffer,\n options: ImageLoaderOptions\n): Promise<ImageDataType> {\n const {mimeType} = getBinaryImageMetadata(arrayBuffer) || {};\n\n // @ts-ignore\n const _parseImageNode: ParseImageNode = globalThis._parseImageNode;\n assert(_parseImageNode); // '@loaders.gl/polyfills not installed'\n\n // @ts-expect-error TODO should we throw error in this case?\n return await _parseImageNode(arrayBuffer, mimeType);\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
- var SVG_DATA_URL_PATTERN = /^data:image\/svg\+xml/;
10
- var SVG_URL_PATTERN = /\.svg((\?|#).*)?$/;
9
+ const SVG_DATA_URL_PATTERN = /^data:image\/svg\+xml/;
10
+ const 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
- var textDecoder = new TextDecoder();
19
- var xmlText = textDecoder.decode(arrayBuffer);
18
+ const textDecoder = new TextDecoder();
19
+ let 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
- var src = "data:image/svg+xml;base64,".concat(btoa(xmlText));
29
+ const 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,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,EAAuDH,GAAvD,EAAoF;AACzF,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,EAA2CH,GAA3C,EAA+D;AACpE,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: ArrayBuffer, url?: string): Blob | string {\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: ArrayBuffer, url?: string): Blob {\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,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,EAAuDH,GAAvD,EAAoF;AACzF,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,EAA2CH,GAA3C,EAA+D;AACpE,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: ArrayBuffer, url?: string): Blob | string {\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: ArrayBuffer, url?: string): Blob {\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"}