@loaders.gl/images 3.1.3 → 4.0.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 (120) hide show
  1. package/dist/bundle.js +2 -2
  2. package/dist/bundle.js.map +1 -0
  3. package/dist/image-loader.js +20 -39
  4. package/dist/image-loader.js.map +1 -0
  5. package/dist/image-writer.js +16 -19
  6. package/dist/image-writer.js.map +1 -0
  7. package/dist/index.js +8 -27
  8. package/dist/index.js.map +1 -0
  9. package/dist/lib/category-api/binary-image-api.js +102 -125
  10. package/dist/lib/category-api/binary-image-api.js.map +1 -0
  11. package/dist/lib/category-api/image-format.js +37 -56
  12. package/dist/lib/category-api/image-format.js.map +1 -0
  13. package/dist/lib/category-api/image-type.js +38 -44
  14. package/dist/lib/category-api/image-type.js.map +1 -0
  15. package/dist/lib/category-api/parsed-image-api.js +57 -62
  16. package/dist/lib/category-api/parsed-image-api.js.map +1 -0
  17. package/dist/lib/encoders/encode-image.js +60 -73
  18. package/dist/lib/encoders/encode-image.js.map +1 -0
  19. package/dist/lib/parsers/parse-image.js +49 -54
  20. package/dist/lib/parsers/parse-image.js.map +1 -0
  21. package/dist/lib/parsers/parse-to-image-bitmap.js +35 -53
  22. package/dist/lib/parsers/parse-to-image-bitmap.js.map +1 -0
  23. package/dist/lib/parsers/parse-to-image.js +30 -43
  24. package/dist/lib/parsers/parse-to-image.js.map +1 -0
  25. package/dist/lib/parsers/parse-to-node-image.js +10 -13
  26. package/dist/lib/parsers/parse-to-node-image.js.map +1 -0
  27. package/dist/lib/parsers/svg-utils.js +26 -36
  28. package/dist/lib/parsers/svg-utils.js.map +1 -0
  29. package/dist/lib/texture-api/async-deep-map.js +32 -49
  30. package/dist/lib/texture-api/async-deep-map.js.map +1 -0
  31. package/dist/lib/texture-api/deep-load.js +8 -13
  32. package/dist/lib/texture-api/deep-load.js.map +1 -0
  33. package/dist/lib/texture-api/generate-url.js +21 -19
  34. package/dist/lib/texture-api/generate-url.js.map +1 -0
  35. package/dist/lib/texture-api/load-image.js +47 -42
  36. package/dist/lib/texture-api/load-image.js.map +1 -0
  37. package/dist/lib/utils/version.js +2 -7
  38. package/dist/lib/utils/version.js.map +1 -0
  39. package/dist/types.js +2 -2
  40. package/dist/{es5/types.js.map → types.js.map} +0 -0
  41. package/package.json +5 -5
  42. package/dist/es5/bundle.js +0 -7
  43. package/dist/es5/bundle.js.map +0 -1
  44. package/dist/es5/image-loader.js +0 -40
  45. package/dist/es5/image-loader.js.map +0 -1
  46. package/dist/es5/image-writer.js +0 -27
  47. package/dist/es5/image-writer.js.map +0 -1
  48. package/dist/es5/index.js +0 -86
  49. package/dist/es5/index.js.map +0 -1
  50. package/dist/es5/lib/category-api/binary-image-api.js +0 -126
  51. package/dist/es5/lib/category-api/binary-image-api.js.map +0 -1
  52. package/dist/es5/lib/category-api/image-format.js +0 -51
  53. package/dist/es5/lib/category-api/image-format.js.map +0 -1
  54. package/dist/es5/lib/category-api/image-type.js +0 -51
  55. package/dist/es5/lib/category-api/image-type.js.map +0 -1
  56. package/dist/es5/lib/category-api/parsed-image-api.js +0 -83
  57. package/dist/es5/lib/category-api/parsed-image-api.js.map +0 -1
  58. package/dist/es5/lib/encoders/encode-image.js +0 -131
  59. package/dist/es5/lib/encoders/encode-image.js.map +0 -1
  60. package/dist/es5/lib/parsers/parse-image.js +0 -102
  61. package/dist/es5/lib/parsers/parse-image.js.map +0 -1
  62. package/dist/es5/lib/parsers/parse-to-image-bitmap.js +0 -127
  63. package/dist/es5/lib/parsers/parse-to-image-bitmap.js.map +0 -1
  64. package/dist/es5/lib/parsers/parse-to-image.js +0 -110
  65. package/dist/es5/lib/parsers/parse-to-image.js.map +0 -1
  66. package/dist/es5/lib/parsers/parse-to-node-image.js +0 -48
  67. package/dist/es5/lib/parsers/parse-to-node-image.js.map +0 -1
  68. package/dist/es5/lib/parsers/svg-utils.js +0 -43
  69. package/dist/es5/lib/parsers/svg-utils.js.map +0 -1
  70. package/dist/es5/lib/texture-api/async-deep-map.js +0 -177
  71. package/dist/es5/lib/texture-api/async-deep-map.js.map +0 -1
  72. package/dist/es5/lib/texture-api/deep-load.js +0 -81
  73. package/dist/es5/lib/texture-api/deep-load.js.map +0 -1
  74. package/dist/es5/lib/texture-api/generate-url.js +0 -34
  75. package/dist/es5/lib/texture-api/generate-url.js.map +0 -1
  76. package/dist/es5/lib/texture-api/load-image.js +0 -173
  77. package/dist/es5/lib/texture-api/load-image.js.map +0 -1
  78. package/dist/es5/lib/utils/version.js +0 -9
  79. package/dist/es5/lib/utils/version.js.map +0 -1
  80. package/dist/es5/types.js +0 -2
  81. package/dist/esm/bundle.js +0 -5
  82. package/dist/esm/bundle.js.map +0 -1
  83. package/dist/esm/image-loader.js +0 -24
  84. package/dist/esm/image-loader.js.map +0 -1
  85. package/dist/esm/image-writer.js +0 -17
  86. package/dist/esm/image-writer.js.map +0 -1
  87. package/dist/esm/index.js +0 -8
  88. package/dist/esm/index.js.map +0 -1
  89. package/dist/esm/lib/category-api/binary-image-api.js +0 -118
  90. package/dist/esm/lib/category-api/binary-image-api.js.map +0 -1
  91. package/dist/esm/lib/category-api/image-format.js +0 -44
  92. package/dist/esm/lib/category-api/image-format.js.map +0 -1
  93. package/dist/esm/lib/category-api/image-type.js +0 -42
  94. package/dist/esm/lib/category-api/image-type.js.map +0 -1
  95. package/dist/esm/lib/category-api/parsed-image-api.js +0 -64
  96. package/dist/esm/lib/category-api/parsed-image-api.js.map +0 -1
  97. package/dist/esm/lib/encoders/encode-image.js +0 -69
  98. package/dist/esm/lib/encoders/encode-image.js.map +0 -1
  99. package/dist/esm/lib/parsers/parse-image.js +0 -52
  100. package/dist/esm/lib/parsers/parse-image.js.map +0 -1
  101. package/dist/esm/lib/parsers/parse-to-image-bitmap.js +0 -43
  102. package/dist/esm/lib/parsers/parse-to-image-bitmap.js.map +0 -1
  103. package/dist/esm/lib/parsers/parse-to-image.js +0 -34
  104. package/dist/esm/lib/parsers/parse-to-image.js.map +0 -1
  105. package/dist/esm/lib/parsers/parse-to-node-image.js +0 -11
  106. package/dist/esm/lib/parsers/parse-to-node-image.js.map +0 -1
  107. package/dist/esm/lib/parsers/svg-utils.js +0 -32
  108. package/dist/esm/lib/parsers/svg-utils.js.map +0 -1
  109. package/dist/esm/lib/texture-api/async-deep-map.js +0 -39
  110. package/dist/esm/lib/texture-api/async-deep-map.js.map +0 -1
  111. package/dist/esm/lib/texture-api/deep-load.js +0 -10
  112. package/dist/esm/lib/texture-api/deep-load.js.map +0 -1
  113. package/dist/esm/lib/texture-api/generate-url.js +0 -22
  114. package/dist/esm/lib/texture-api/generate-url.js.map +0 -1
  115. package/dist/esm/lib/texture-api/load-image.js +0 -52
  116. package/dist/esm/lib/texture-api/load-image.js.map +0 -1
  117. package/dist/esm/lib/utils/version.js +0 -2
  118. package/dist/esm/lib/utils/version.js.map +0 -1
  119. package/dist/esm/types.js +0 -2
  120. package/dist/esm/types.js.map +0 -1
@@ -1,48 +1,42 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getDefaultImageType = exports.isImageTypeSupported = void 0;
4
- const loader_utils_1 = require("@loaders.gl/loader-utils");
5
- // @ts-ignore TS2339: Property does not exist on type
6
- const { _parseImageNode } = globalThis;
7
- const IMAGE_SUPPORTED = typeof Image !== 'undefined'; // NOTE: "false" positives if jsdom is installed
1
+ import { isBrowser } from '@loaders.gl/loader-utils';
2
+ const {
3
+ _parseImageNode
4
+ } = globalThis;
5
+ const IMAGE_SUPPORTED = typeof Image !== 'undefined';
8
6
  const IMAGE_BITMAP_SUPPORTED = typeof ImageBitmap !== 'undefined';
9
7
  const NODE_IMAGE_SUPPORTED = Boolean(_parseImageNode);
10
- const DATA_SUPPORTED = loader_utils_1.isBrowser ? true : NODE_IMAGE_SUPPORTED;
11
- /**
12
- * Checks if a loaders.gl image type is supported
13
- * @param type image type string
14
- */
15
- function isImageTypeSupported(type) {
16
- switch (type) {
17
- case 'auto':
18
- // Should only ever be false in Node.js, if polyfills have not been installed...
19
- return IMAGE_BITMAP_SUPPORTED || IMAGE_SUPPORTED || DATA_SUPPORTED;
20
- case 'imagebitmap':
21
- return IMAGE_BITMAP_SUPPORTED;
22
- case 'image':
23
- return IMAGE_SUPPORTED;
24
- case 'data':
25
- return DATA_SUPPORTED;
26
- default:
27
- throw new Error(`@loaders.gl/images: image ${type} not supported in this environment`);
28
- }
8
+ const DATA_SUPPORTED = isBrowser ? true : NODE_IMAGE_SUPPORTED;
9
+ export function isImageTypeSupported(type) {
10
+ switch (type) {
11
+ case 'auto':
12
+ return IMAGE_BITMAP_SUPPORTED || IMAGE_SUPPORTED || DATA_SUPPORTED;
13
+
14
+ case 'imagebitmap':
15
+ return IMAGE_BITMAP_SUPPORTED;
16
+
17
+ case 'image':
18
+ return IMAGE_SUPPORTED;
19
+
20
+ case 'data':
21
+ return DATA_SUPPORTED;
22
+
23
+ default:
24
+ throw new Error("@loaders.gl/images: image ".concat(type, " not supported in this environment"));
25
+ }
29
26
  }
30
- exports.isImageTypeSupported = isImageTypeSupported;
31
- /**
32
- * Returns the "most performant" supported image type on this platform
33
- * @returns image type string
34
- */
35
- function getDefaultImageType() {
36
- if (IMAGE_BITMAP_SUPPORTED) {
37
- return 'imagebitmap';
38
- }
39
- if (IMAGE_SUPPORTED) {
40
- return 'image';
41
- }
42
- if (DATA_SUPPORTED) {
43
- return 'data';
44
- }
45
- // This should only happen in Node.js
46
- throw new Error('Install \'@loaders.gl/polyfills\' to parse images under Node.js');
27
+ export function getDefaultImageType() {
28
+ if (IMAGE_BITMAP_SUPPORTED) {
29
+ return 'imagebitmap';
30
+ }
31
+
32
+ if (IMAGE_SUPPORTED) {
33
+ return 'image';
34
+ }
35
+
36
+ if (DATA_SUPPORTED) {
37
+ return 'data';
38
+ }
39
+
40
+ throw new Error('Install \'@loaders.gl/polyfills\' to parse images under Node.js');
47
41
  }
48
- exports.getDefaultImageType = getDefaultImageType;
42
+ //# sourceMappingURL=image-type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/category-api/image-type.ts"],"names":["isBrowser","_parseImageNode","globalThis","IMAGE_SUPPORTED","Image","IMAGE_BITMAP_SUPPORTED","ImageBitmap","NODE_IMAGE_SUPPORTED","Boolean","DATA_SUPPORTED","isImageTypeSupported","type","Error","getDefaultImageType"],"mappings":"AAAA,SAAQA,SAAR,QAAwB,0BAAxB;AAIA,MAAM;AAACC,EAAAA;AAAD,IAAoBC,UAA1B;AAEA,MAAMC,eAAe,GAAG,OAAOC,KAAP,KAAiB,WAAzC;AACA,MAAMC,sBAAsB,GAAG,OAAOC,WAAP,KAAuB,WAAtD;AACA,MAAMC,oBAAoB,GAAGC,OAAO,CAACP,eAAD,CAApC;AACA,MAAMQ,cAAc,GAAGT,SAAS,GAAG,IAAH,GAAUO,oBAA1C;AAMA,OAAO,SAASG,oBAAT,CAA8BC,IAA9B,EAAqD;AAC1D,UAAQA,IAAR;AACE,SAAK,MAAL;AAEE,aAAON,sBAAsB,IAAIF,eAA1B,IAA6CM,cAApD;;AAEF,SAAK,aAAL;AACE,aAAOJ,sBAAP;;AACF,SAAK,OAAL;AACE,aAAOF,eAAP;;AACF,SAAK,MAAL;AACE,aAAOM,cAAP;;AAEF;AACE,YAAM,IAAIG,KAAJ,qCAAuCD,IAAvC,wCAAN;AAbJ;AAeD;AAMD,OAAO,SAASE,mBAAT,GAA8C;AACnD,MAAIR,sBAAJ,EAA4B;AAC1B,WAAO,aAAP;AACD;;AACD,MAAIF,eAAJ,EAAqB;AACnB,WAAO,OAAP;AACD;;AACD,MAAIM,cAAJ,EAAoB;AAClB,WAAO,MAAP;AACD;;AAGD,QAAM,IAAIG,KAAJ,CAAU,iEAAV,CAAN;AACD","sourcesContent":["import {isBrowser} from '@loaders.gl/loader-utils';\nimport type {ImageTypeEnum} from '../../types';\n\n// @ts-ignore TS2339: Property does not exist on type\nconst {_parseImageNode} = globalThis;\n\nconst IMAGE_SUPPORTED = typeof Image !== 'undefined'; // NOTE: \"false\" positives if jsdom is installed\nconst IMAGE_BITMAP_SUPPORTED = typeof ImageBitmap !== 'undefined';\nconst NODE_IMAGE_SUPPORTED = Boolean(_parseImageNode);\nconst DATA_SUPPORTED = isBrowser ? true : NODE_IMAGE_SUPPORTED;\n\n/**\n * Checks if a loaders.gl image type is supported\n * @param type image type string\n */\nexport function isImageTypeSupported(type: string): boolean {\n switch (type) {\n case 'auto':\n // Should only ever be false in Node.js, if polyfills have not been installed...\n return IMAGE_BITMAP_SUPPORTED || IMAGE_SUPPORTED || DATA_SUPPORTED;\n\n case 'imagebitmap':\n return IMAGE_BITMAP_SUPPORTED;\n case 'image':\n return IMAGE_SUPPORTED;\n case 'data':\n return DATA_SUPPORTED;\n\n default:\n throw new Error(`@loaders.gl/images: image ${type} not supported in this environment`);\n }\n}\n\n/**\n * Returns the \"most performant\" supported image type on this platform\n * @returns image type string\n */\nexport function getDefaultImageType(): ImageTypeEnum {\n if (IMAGE_BITMAP_SUPPORTED) {\n return 'imagebitmap';\n }\n if (IMAGE_SUPPORTED) {\n return 'image';\n }\n if (DATA_SUPPORTED) {\n return 'data';\n }\n\n // This should only happen in Node.js\n throw new Error('Install \\'@loaders.gl/polyfills\\' to parse images under Node.js');\n}\n"],"file":"image-type.js"}
@@ -1,69 +1,64 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getImageData = exports.getImageSize = exports.getImageType = exports.deleteImage = exports.isImage = void 0;
4
- function isImage(image) {
5
- return Boolean(getImageTypeOrNull(image));
1
+ export function isImage(image) {
2
+ return Boolean(getImageTypeOrNull(image));
6
3
  }
7
- exports.isImage = isImage;
8
- function deleteImage(image) {
9
- switch (getImageType(image)) {
10
- case 'imagebitmap':
11
- image.close();
12
- break;
13
- default:
14
- // Nothing to do for images and image data objects
15
- }
4
+ export function deleteImage(image) {
5
+ switch (getImageType(image)) {
6
+ case 'imagebitmap':
7
+ image.close();
8
+ break;
9
+
10
+ default:
11
+ }
16
12
  }
17
- exports.deleteImage = deleteImage;
18
- function getImageType(image) {
19
- const format = getImageTypeOrNull(image);
20
- if (!format) {
21
- throw new Error('Not an image');
22
- }
23
- return format;
13
+ export function getImageType(image) {
14
+ const format = getImageTypeOrNull(image);
15
+
16
+ if (!format) {
17
+ throw new Error('Not an image');
18
+ }
19
+
20
+ return format;
24
21
  }
25
- exports.getImageType = getImageType;
26
- function getImageSize(image) {
27
- return getImageData(image);
22
+ export function getImageSize(image) {
23
+ return getImageData(image);
28
24
  }
29
- exports.getImageSize = getImageSize;
30
- function getImageData(image) {
31
- switch (getImageType(image)) {
32
- case 'data':
33
- return image;
34
- case 'image':
35
- case 'imagebitmap':
36
- // Extract the image data from the image via a canvas
37
- const canvas = document.createElement('canvas');
38
- // TODO - reuse the canvas?
39
- const context = canvas.getContext('2d');
40
- if (!context) {
41
- throw new Error('getImageData');
42
- }
43
- // @ts-ignore
44
- canvas.width = image.width;
45
- // @ts-ignore
46
- canvas.height = image.height;
47
- // @ts-ignore
48
- context.drawImage(image, 0, 0);
49
- // @ts-ignore
50
- return context.getImageData(0, 0, image.width, image.height);
51
- default:
52
- throw new Error('getImageData');
53
- }
25
+ export function getImageData(image) {
26
+ switch (getImageType(image)) {
27
+ case 'data':
28
+ return image;
29
+
30
+ case 'image':
31
+ case 'imagebitmap':
32
+ const canvas = document.createElement('canvas');
33
+ const context = canvas.getContext('2d');
34
+
35
+ if (!context) {
36
+ throw new Error('getImageData');
37
+ }
38
+
39
+ canvas.width = image.width;
40
+ canvas.height = image.height;
41
+ context.drawImage(image, 0, 0);
42
+ return context.getImageData(0, 0, image.width, image.height);
43
+
44
+ default:
45
+ throw new Error('getImageData');
46
+ }
54
47
  }
55
- exports.getImageData = getImageData;
56
- // PRIVATE
57
- // eslint-disable-next-line complexity
48
+
58
49
  function getImageTypeOrNull(image) {
59
- if (typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {
60
- return 'imagebitmap';
61
- }
62
- if (typeof Image !== 'undefined' && image instanceof Image) {
63
- return 'image';
64
- }
65
- if (image && typeof image === 'object' && image.data && image.width && image.height) {
66
- return 'data';
67
- }
68
- return null;
50
+ if (typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {
51
+ return 'imagebitmap';
52
+ }
53
+
54
+ if (typeof Image !== 'undefined' && image instanceof Image) {
55
+ return 'image';
56
+ }
57
+
58
+ if (image && typeof image === 'object' && image.data && image.width && image.height) {
59
+ return 'data';
60
+ }
61
+
62
+ return null;
69
63
  }
64
+ //# sourceMappingURL=parsed-image-api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/category-api/parsed-image-api.ts"],"names":["isImage","image","Boolean","getImageTypeOrNull","deleteImage","getImageType","close","format","Error","getImageSize","getImageData","canvas","document","createElement","context","getContext","width","height","drawImage","ImageBitmap","Image","data"],"mappings":"AAEA,OAAO,SAASA,OAAT,CAAiBC,KAAjB,EAA4C;AACjD,SAAOC,OAAO,CAACC,kBAAkB,CAACF,KAAD,CAAnB,CAAd;AACD;AAED,OAAO,SAASG,WAAT,CAAqBH,KAArB,EAA6C;AAClD,UAAQI,YAAY,CAACJ,KAAD,CAApB;AACE,SAAK,aAAL;AACGA,MAAAA,KAAD,CAAuBK,KAAvB;AACA;;AACF;AAJF;AAOD;AAED,OAAO,SAASD,YAAT,CAAsBJ,KAAtB,EAAuD;AAC5D,QAAMM,MAAM,GAAGJ,kBAAkB,CAACF,KAAD,CAAjC;;AACA,MAAI,CAACM,MAAL,EAAa;AACX,UAAM,IAAIC,KAAJ,CAAU,cAAV,CAAN;AACD;;AACD,SAAOD,MAAP;AACD;AAED,OAAO,SAASE,YAAT,CAAsBR,KAAtB,EAAyE;AAC9E,SAAOS,YAAY,CAACT,KAAD,CAAnB;AACD;AAED,OAAO,SAASS,YAAT,CAAsBT,KAAtB,EAAmE;AACxE,UAAQI,YAAY,CAACJ,KAAD,CAApB;AACE,SAAK,MAAL;AACE,aAAOA,KAAP;;AAEF,SAAK,OAAL;AACA,SAAK,aAAL;AAEE,YAAMU,MAAM,GAAGC,QAAQ,CAACC,aAAT,CAAuB,QAAvB,CAAf;AAEA,YAAMC,OAAO,GAAGH,MAAM,CAACI,UAAP,CAAkB,IAAlB,CAAhB;;AACA,UAAI,CAACD,OAAL,EAAc;AACZ,cAAM,IAAIN,KAAJ,CAAU,cAAV,CAAN;AACD;;AAEDG,MAAAA,MAAM,CAACK,KAAP,GAAef,KAAK,CAACe,KAArB;AAEAL,MAAAA,MAAM,CAACM,MAAP,GAAgBhB,KAAK,CAACgB,MAAtB;AAEAH,MAAAA,OAAO,CAACI,SAAR,CAAkBjB,KAAlB,EAAyB,CAAzB,EAA4B,CAA5B;AAEA,aAAOa,OAAO,CAACJ,YAAR,CAAqB,CAArB,EAAwB,CAAxB,EAA2BT,KAAK,CAACe,KAAjC,EAAwCf,KAAK,CAACgB,MAA9C,CAAP;;AAEF;AACE,YAAM,IAAIT,KAAJ,CAAU,cAAV,CAAN;AAvBJ;AAyBD;;AAKD,SAASL,kBAAT,CAA4BF,KAA5B,EAAmC;AACjC,MAAI,OAAOkB,WAAP,KAAuB,WAAvB,IAAsClB,KAAK,YAAYkB,WAA3D,EAAwE;AACtE,WAAO,aAAP;AACD;;AACD,MAAI,OAAOC,KAAP,KAAiB,WAAjB,IAAgCnB,KAAK,YAAYmB,KAArD,EAA4D;AAC1D,WAAO,OAAP;AACD;;AACD,MAAInB,KAAK,IAAI,OAAOA,KAAP,KAAiB,QAA1B,IAAsCA,KAAK,CAACoB,IAA5C,IAAoDpB,KAAK,CAACe,KAA1D,IAAmEf,KAAK,CAACgB,MAA7E,EAAqF;AACnF,WAAO,MAAP;AACD;;AACD,SAAO,IAAP;AACD","sourcesContent":["import type {ImageType, ImageTypeEnum, ImageDataType} from '../../types';\n\nexport function isImage(image: ImageType): boolean {\n return Boolean(getImageTypeOrNull(image));\n}\n\nexport function deleteImage(image: ImageType): void {\n switch (getImageType(image)) {\n case 'imagebitmap':\n (image as ImageBitmap).close();\n break;\n default:\n // Nothing to do for images and image data objects\n }\n}\n\nexport function getImageType(image: ImageType): ImageTypeEnum {\n const format = getImageTypeOrNull(image);\n if (!format) {\n throw new Error('Not an image');\n }\n return format;\n}\n\nexport function getImageSize(image: ImageType): {width: number; height: number} {\n return getImageData(image);\n}\n\nexport function getImageData(image: ImageType): ImageDataType | ImageData {\n switch (getImageType(image)) {\n case 'data':\n return image as unknown as ImageData;\n\n case 'image':\n case 'imagebitmap':\n // Extract the image data from the image via a canvas\n const canvas = document.createElement('canvas');\n // TODO - reuse the canvas?\n const context = canvas.getContext('2d');\n if (!context) {\n throw new Error('getImageData');\n }\n // @ts-ignore\n canvas.width = image.width;\n // @ts-ignore\n canvas.height = image.height;\n // @ts-ignore\n context.drawImage(image, 0, 0);\n // @ts-ignore\n return context.getImageData(0, 0, image.width, image.height);\n\n default:\n throw new Error('getImageData');\n }\n}\n\n// PRIVATE\n\n// eslint-disable-next-line complexity\nfunction getImageTypeOrNull(image) {\n if (typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {\n return 'imagebitmap';\n }\n if (typeof Image !== 'undefined' && image instanceof Image) {\n return 'image';\n }\n if (image && typeof image === 'object' && image.data && image.width && image.height) {\n return 'data';\n }\n return null;\n}\n"],"file":"parsed-image-api.js"}
@@ -1,82 +1,69 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.encodeImage = void 0;
4
- // Image loading/saving for browser and Node.js
5
- const parsed_image_api_1 = require("../category-api/parsed-image-api");
6
- // @ts-ignore TS2339: Property does not exist on type
7
- const { _encodeImageNode } = globalThis;
8
- /**
9
- * Returns data bytes representing a compressed image in PNG or JPG format,
10
- * This data can be saved using file system (f) methods or used in a request.
11
- * @param image - ImageBitmap Image or Canvas
12
- * @param options
13
- * param opt.type='png' - png, jpg or image/png, image/jpg are valid
14
- * param mimeType= - Whether to include a data URI header
15
- */
16
- async function encodeImage(image, options) {
17
- options = options || {};
18
- options.image = options.image || {};
19
- return _encodeImageNode
20
- ? _encodeImageNode(image, { type: options.image.mimeType })
21
- : encodeImageInBrowser(image, options);
1
+ import { getImageSize } from '../category-api/parsed-image-api';
2
+ const {
3
+ _encodeImageNode
4
+ } = globalThis;
5
+ export async function encodeImage(image, options) {
6
+ options = options || {};
7
+ options.image = options.image || {};
8
+ return _encodeImageNode ? _encodeImageNode(image, {
9
+ type: options.image.mimeType
10
+ }) : encodeImageInBrowser(image, options);
22
11
  }
23
- exports.encodeImage = encodeImage;
24
- // In case we get exceptions from canvas.toBlob(resolve, type, quality)
25
12
  let qualityParamSupported = true;
26
- /**
27
- *
28
- * @param image
29
- * @param options
30
- * @note Based on canvas.toBlob
31
- * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob
32
- */
13
+
33
14
  async function encodeImageInBrowser(image, options) {
34
- const { mimeType, jpegQuality } = options.image;
35
- const { width, height } = (0, parsed_image_api_1.getImageSize)(image);
36
- // create a canvas and resize it to the size of our image
37
- const canvas = document.createElement('canvas');
38
- canvas.width = width;
39
- canvas.height = height;
40
- drawImageToCanvas(image, canvas);
41
- // The actual encoding is done asynchronously with `canvas.toBlob()`
42
- const blob = await new Promise((resolve) => {
43
- // get it back as a Blob
44
- if (jpegQuality && qualityParamSupported) {
45
- try {
46
- canvas.toBlob(resolve, mimeType, jpegQuality);
47
- return;
48
- }
49
- catch (error) {
50
- qualityParamSupported = false;
51
- }
52
- }
53
- canvas.toBlob(resolve, mimeType);
54
- });
55
- if (!blob) {
56
- throw new Error('image encoding failed');
15
+ const {
16
+ mimeType,
17
+ jpegQuality
18
+ } = options.image;
19
+ const {
20
+ width,
21
+ height
22
+ } = getImageSize(image);
23
+ const canvas = document.createElement('canvas');
24
+ canvas.width = width;
25
+ canvas.height = height;
26
+ drawImageToCanvas(image, canvas);
27
+ const blob = await new Promise(resolve => {
28
+ if (jpegQuality && qualityParamSupported) {
29
+ try {
30
+ canvas.toBlob(resolve, mimeType, jpegQuality);
31
+ return;
32
+ } catch (error) {
33
+ qualityParamSupported = false;
34
+ }
57
35
  }
58
- return await blob.arrayBuffer();
36
+
37
+ canvas.toBlob(resolve, mimeType);
38
+ });
39
+
40
+ if (!blob) {
41
+ throw new Error('image encoding failed');
42
+ }
43
+
44
+ return await blob.arrayBuffer();
59
45
  }
46
+
60
47
  function drawImageToCanvas(image, canvas, x = 0, y = 0) {
61
- // Try optimized path for ImageBitmaps via bitmaprenderer context
62
- if (x === 0 && y === 0 && typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {
63
- const context = canvas.getContext('bitmaprenderer');
64
- if (context) {
65
- // transfer the ImageBitmap to it
66
- context.transferFromImageBitmap(image);
67
- return canvas;
68
- }
48
+ if (x === 0 && y === 0 && typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {
49
+ const context = canvas.getContext('bitmaprenderer');
50
+
51
+ if (context) {
52
+ context.transferFromImageBitmap(image);
53
+ return canvas;
69
54
  }
70
- // Available on most platforms, except IE11 and Andriod WebViews...
71
- const context = canvas.getContext('2d');
72
- if (image.data) {
73
- // ImageData constructor expects clamped array even though getImageData does not return a clamped array...
74
- const clampedArray = new Uint8ClampedArray(image.data);
75
- const imageData = new ImageData(clampedArray, image.width, image.height);
76
- context.putImageData(imageData, 0, 0);
77
- return canvas;
78
- }
79
- // Fall back to generic image/image bitmap rendering path
80
- context.drawImage(image, 0, 0);
55
+ }
56
+
57
+ const context = canvas.getContext('2d');
58
+
59
+ if (image.data) {
60
+ const clampedArray = new Uint8ClampedArray(image.data);
61
+ const imageData = new ImageData(clampedArray, image.width, image.height);
62
+ context.putImageData(imageData, 0, 0);
81
63
  return canvas;
64
+ }
65
+
66
+ context.drawImage(image, 0, 0);
67
+ return canvas;
82
68
  }
69
+ //# sourceMappingURL=encode-image.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/encoders/encode-image.ts"],"names":["getImageSize","_encodeImageNode","globalThis","encodeImage","image","options","type","mimeType","encodeImageInBrowser","qualityParamSupported","jpegQuality","width","height","canvas","document","createElement","drawImageToCanvas","blob","Promise","resolve","toBlob","error","Error","arrayBuffer","x","y","ImageBitmap","context","getContext","transferFromImageBitmap","data","clampedArray","Uint8ClampedArray","imageData","ImageData","putImageData","drawImage"],"mappings":"AACA,SAAQA,YAAR,QAA2B,kCAA3B;AAGA,MAAM;AAACC,EAAAA;AAAD,IAAqBC,UAA3B;AAUA,OAAO,eAAeC,WAAf,CACLC,KADK,EAELC,OAFK,EAGiB;AACtBA,EAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;AACAA,EAAAA,OAAO,CAACD,KAAR,GAAgBC,OAAO,CAACD,KAAR,IAAkB,EAAlC;AAEA,SAAOH,gBAAgB,GACnBA,gBAAgB,CAACG,KAAD,EAAQ;AAACE,IAAAA,IAAI,EAAED,OAAO,CAACD,KAAR,CAAcG;AAArB,GAAR,CADG,GAEnBC,oBAAoB,CAACJ,KAAD,EAAQC,OAAR,CAFxB;AAGD;AAGD,IAAII,qBAAqB,GAAG,IAA5B;;AASA,eAAeD,oBAAf,CAAoCJ,KAApC,EAA2CC,OAA3C,EAAoD;AAClD,QAAM;AAACE,IAAAA,QAAD;AAAWG,IAAAA;AAAX,MAA0BL,OAAO,CAACD,KAAxC;AAEA,QAAM;AAACO,IAAAA,KAAD;AAAQC,IAAAA;AAAR,MAAkBZ,YAAY,CAACI,KAAD,CAApC;AAGA,QAAMS,MAAM,GAAGC,QAAQ,CAACC,aAAT,CAAuB,QAAvB,CAAf;AACAF,EAAAA,MAAM,CAACF,KAAP,GAAeA,KAAf;AACAE,EAAAA,MAAM,CAACD,MAAP,GAAgBA,MAAhB;AAEAI,EAAAA,iBAAiB,CAACZ,KAAD,EAAQS,MAAR,CAAjB;AAGA,QAAMI,IAAI,GAAG,MAAM,IAAIC,OAAJ,CAA0BC,OAAD,IAAa;AAEvD,QAAIT,WAAW,IAAID,qBAAnB,EAA0C;AACxC,UAAI;AACFI,QAAAA,MAAM,CAACO,MAAP,CAAcD,OAAd,EAAuBZ,QAAvB,EAAiCG,WAAjC;AACA;AACD,OAHD,CAGE,OAAOW,KAAP,EAAc;AACdZ,QAAAA,qBAAqB,GAAG,KAAxB;AACD;AACF;;AACDI,IAAAA,MAAM,CAACO,MAAP,CAAcD,OAAd,EAAuBZ,QAAvB;AACD,GAXkB,CAAnB;;AAaA,MAAI,CAACU,IAAL,EAAW;AACT,UAAM,IAAIK,KAAJ,CAAU,uBAAV,CAAN;AACD;;AAED,SAAO,MAAML,IAAI,CAACM,WAAL,EAAb;AACD;;AAED,SAASP,iBAAT,CAA2BZ,KAA3B,EAAkCS,MAAlC,EAA0CW,CAAC,GAAG,CAA9C,EAAiDC,CAAC,GAAG,CAArD,EAAwD;AAEtD,MAAID,CAAC,KAAK,CAAN,IAAWC,CAAC,KAAK,CAAjB,IAAsB,OAAOC,WAAP,KAAuB,WAA7C,IAA4DtB,KAAK,YAAYsB,WAAjF,EAA8F;AAC5F,UAAMC,OAAO,GAAGd,MAAM,CAACe,UAAP,CAAkB,gBAAlB,CAAhB;;AACA,QAAID,OAAJ,EAAa;AAEXA,MAAAA,OAAO,CAACE,uBAAR,CAAgCzB,KAAhC;AACA,aAAOS,MAAP;AACD;AACF;;AAGD,QAAMc,OAAO,GAAGd,MAAM,CAACe,UAAP,CAAkB,IAAlB,CAAhB;;AACA,MAAIxB,KAAK,CAAC0B,IAAV,EAAgB;AAEd,UAAMC,YAAY,GAAG,IAAIC,iBAAJ,CAAsB5B,KAAK,CAAC0B,IAA5B,CAArB;AACA,UAAMG,SAAS,GAAG,IAAIC,SAAJ,CAAcH,YAAd,EAA4B3B,KAAK,CAACO,KAAlC,EAAyCP,KAAK,CAACQ,MAA/C,CAAlB;AACAe,IAAAA,OAAO,CAACQ,YAAR,CAAqBF,SAArB,EAAgC,CAAhC,EAAmC,CAAnC;AACA,WAAOpB,MAAP;AACD;;AAGDc,EAAAA,OAAO,CAACS,SAAR,CAAkBhC,KAAlB,EAAyB,CAAzB,EAA4B,CAA5B;AACA,SAAOS,MAAP;AACD","sourcesContent":["// Image loading/saving for browser and Node.js\nimport {getImageSize} from '../category-api/parsed-image-api';\n\n// @ts-ignore TS2339: Property does not exist on type\nconst {_encodeImageNode} = globalThis;\n\n/**\n * Returns data bytes representing a compressed image in PNG or JPG format,\n * This data can be saved using file system (f) methods or used in a request.\n * @param image - ImageBitmap Image or Canvas\n * @param options\n * param opt.type='png' - png, jpg or image/png, image/jpg are valid\n * param mimeType= - Whether to include a data URI header\n */\nexport async function encodeImage(\n image: any,\n options?: {[key: string]: any}\n): Promise<ArrayBuffer> {\n options = options || {};\n options.image = options.image || ({} as {[key: string]: any});\n\n return _encodeImageNode\n ? _encodeImageNode(image, {type: options.image.mimeType})\n : encodeImageInBrowser(image, options);\n}\n\n// In case we get exceptions from canvas.toBlob(resolve, type, quality)\nlet qualityParamSupported = true;\n\n/**\n *\n * @param image\n * @param options\n * @note Based on canvas.toBlob\n * @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob\n */\nasync function encodeImageInBrowser(image, options) {\n const {mimeType, jpegQuality} = options.image;\n\n const {width, height} = getImageSize(image);\n\n // create a canvas and resize it to the size of our image\n const canvas = document.createElement('canvas');\n canvas.width = width;\n canvas.height = height;\n\n drawImageToCanvas(image, canvas);\n\n // The actual encoding is done asynchronously with `canvas.toBlob()`\n const blob = await new Promise<Blob | null>((resolve) => {\n // get it back as a Blob\n if (jpegQuality && qualityParamSupported) {\n try {\n canvas.toBlob(resolve, mimeType, jpegQuality);\n return;\n } catch (error) {\n qualityParamSupported = false;\n }\n }\n canvas.toBlob(resolve, mimeType);\n });\n\n if (!blob) {\n throw new Error('image encoding failed');\n }\n\n return await blob.arrayBuffer();\n}\n\nfunction drawImageToCanvas(image, canvas, x = 0, y = 0) {\n // Try optimized path for ImageBitmaps via bitmaprenderer context\n if (x === 0 && y === 0 && typeof ImageBitmap !== 'undefined' && image instanceof ImageBitmap) {\n const context = canvas.getContext('bitmaprenderer');\n if (context) {\n // transfer the ImageBitmap to it\n context.transferFromImageBitmap(image);\n return canvas;\n }\n }\n\n // Available on most platforms, except IE11 and Andriod WebViews...\n const context = canvas.getContext('2d');\n if (image.data) {\n // ImageData constructor expects clamped array even though getImageData does not return a clamped array...\n const clampedArray = new Uint8ClampedArray(image.data);\n const imageData = new ImageData(clampedArray, image.width, image.height);\n context.putImageData(imageData, 0, 0);\n return canvas;\n }\n\n // Fall back to generic image/image bitmap rendering path\n context.drawImage(image, 0, 0);\n return canvas;\n}\n"],"file":"encode-image.js"}
@@ -1,57 +1,52 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const loader_utils_1 = require("@loaders.gl/loader-utils");
7
- const image_type_1 = require("../category-api/image-type");
8
- const parsed_image_api_1 = require("../category-api/parsed-image-api");
9
- const parse_to_image_1 = __importDefault(require("./parse-to-image"));
10
- const parse_to_image_bitmap_1 = __importDefault(require("./parse-to-image-bitmap"));
11
- const parse_to_node_image_1 = __importDefault(require("./parse-to-node-image"));
12
- // Parse to platform defined image type (data on node, ImageBitmap or HTMLImage on browser)
13
- // eslint-disable-next-line complexity
14
- async function parseImage(arrayBuffer, options, context) {
15
- options = options || {};
16
- const imageOptions = options.image || {};
17
- // The user can request a specific output format via `options.image.type`
18
- const imageType = imageOptions.type || 'auto';
19
- const { url } = context || {};
20
- // Note: For options.image.type === `data`, we may still need to load as `image` or `imagebitmap`
21
- const loadType = getLoadableImageType(imageType);
22
- let image;
23
- switch (loadType) {
24
- case 'imagebitmap':
25
- image = await (0, parse_to_image_bitmap_1.default)(arrayBuffer, options, url);
26
- break;
27
- case 'image':
28
- image = await (0, parse_to_image_1.default)(arrayBuffer, options, url);
29
- break;
30
- case 'data':
31
- // Node.js loads imagedata directly
32
- image = await (0, parse_to_node_image_1.default)(arrayBuffer, options);
33
- break;
34
- default:
35
- (0, loader_utils_1.assert)(false);
36
- }
37
- // Browser: if options.image.type === 'data', we can now extract data from the loaded image
38
- if (imageType === 'data') {
39
- image = (0, parsed_image_api_1.getImageData)(image);
40
- }
41
- return image;
1
+ import { assert } from '@loaders.gl/loader-utils';
2
+ import { isImageTypeSupported, getDefaultImageType } from '../category-api/image-type';
3
+ import { getImageData } from '../category-api/parsed-image-api';
4
+ import parseToImage from './parse-to-image';
5
+ import parseToImageBitmap from './parse-to-image-bitmap';
6
+ import parseToNodeImage from './parse-to-node-image';
7
+ export default async function parseImage(arrayBuffer, options, context) {
8
+ options = options || {};
9
+ const imageOptions = options.image || {};
10
+ const imageType = imageOptions.type || 'auto';
11
+ const {
12
+ url
13
+ } = context || {};
14
+ const loadType = getLoadableImageType(imageType);
15
+ let image;
16
+
17
+ switch (loadType) {
18
+ case 'imagebitmap':
19
+ image = await parseToImageBitmap(arrayBuffer, options, url);
20
+ break;
21
+
22
+ case 'image':
23
+ image = await parseToImage(arrayBuffer, options, url);
24
+ break;
25
+
26
+ case 'data':
27
+ image = await parseToNodeImage(arrayBuffer, options);
28
+ break;
29
+
30
+ default:
31
+ assert(false);
32
+ }
33
+
34
+ if (imageType === 'data') {
35
+ image = getImageData(image);
36
+ }
37
+
38
+ return image;
42
39
  }
43
- exports.default = parseImage;
44
- // Get a loadable image type from image type
40
+
45
41
  function getLoadableImageType(type) {
46
- switch (type) {
47
- case 'auto':
48
- case 'data':
49
- // Browser: For image data we need still need to load using an image format
50
- // Node: the default image type is `data`.
51
- return (0, image_type_1.getDefaultImageType)();
52
- default:
53
- // Throw an error if not supported
54
- (0, image_type_1.isImageTypeSupported)(type);
55
- return type;
56
- }
42
+ switch (type) {
43
+ case 'auto':
44
+ case 'data':
45
+ return getDefaultImageType();
46
+
47
+ default:
48
+ isImageTypeSupported(type);
49
+ return type;
50
+ }
57
51
  }
52
+ //# sourceMappingURL=parse-image.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/parsers/parse-image.ts"],"names":["assert","isImageTypeSupported","getDefaultImageType","getImageData","parseToImage","parseToImageBitmap","parseToNodeImage","parseImage","arrayBuffer","options","context","imageOptions","image","imageType","type","url","loadType","getLoadableImageType"],"mappings":"AACA,SAAQA,MAAR,QAAqB,0BAArB;AAGA,SAAQC,oBAAR,EAA8BC,mBAA9B,QAAwD,4BAAxD;AACA,SAAQC,YAAR,QAA2B,kCAA3B;AACA,OAAOC,YAAP,MAAyB,kBAAzB;AACA,OAAOC,kBAAP,MAA+B,yBAA/B;AACA,OAAOC,gBAAP,MAA6B,uBAA7B;AAIA,eAAe,eAAeC,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,MAAMP,kBAAkB,CAACG,WAAD,EAAcC,OAAd,EAAuBM,GAAvB,CAAhC;AACA;;AACF,SAAK,OAAL;AACEH,MAAAA,KAAK,GAAG,MAAMR,YAAY,CAACI,WAAD,EAAcC,OAAd,EAAuBM,GAAvB,CAA1B;AACA;;AACF,SAAK,MAAL;AAEEH,MAAAA,KAAK,GAAG,MAAMN,gBAAgB,CAACE,WAAD,EAAcC,OAAd,CAA9B;AACA;;AACF;AACET,MAAAA,MAAM,CAAC,KAAD,CAAN;AAZJ;;AAgBA,MAAIa,SAAS,KAAK,MAAlB,EAA0B;AACxBD,IAAAA,KAAK,GAAGT,YAAY,CAACS,KAAD,CAApB;AACD;;AAED,SAAOA,KAAP;AACD;;AAGD,SAASK,oBAAT,CAA8BH,IAA9B,EAAoC;AAClC,UAAQA,IAAR;AACE,SAAK,MAAL;AACA,SAAK,MAAL;AAGE,aAAOZ,mBAAmB,EAA1B;;AACF;AAEED,MAAAA,oBAAoB,CAACa,IAAD,CAApB;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,61 +1,43 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const svg_utils_1 = require("./svg-utils");
7
- const parse_to_image_1 = __importDefault(require("./parse-to-image"));
1
+ import { isSVG, getBlob } from './svg-utils';
2
+ import parseToImage from './parse-to-image';
8
3
  const EMPTY_OBJECT = {};
9
4
  let imagebitmapOptionsSupported = true;
10
- /**
11
- * Asynchronously parses an array buffer into an ImageBitmap - this contains the decoded data
12
- * ImageBitmaps are supported on worker threads, but not supported on Edge, IE11 and Safari
13
- * https://developer.mozilla.org/en-US/docs/Web/API/ImageBitmap#Browser_compatibility
14
- *
15
- * TODO - createImageBitmap supports source rect (5 param overload), pass through?
16
- */
17
- async function parseToImageBitmap(arrayBuffer, options, url) {
18
- let blob;
19
- // Cannot parse SVG directly to ImageBitmap, parse to Image first
20
- if ((0, svg_utils_1.isSVG)(url)) {
21
- // Note: this only works on main thread
22
- const image = await (0, parse_to_image_1.default)(arrayBuffer, options, url);
23
- blob = image;
24
- }
25
- else {
26
- // Create blob from the array buffer
27
- blob = (0, svg_utils_1.getBlob)(arrayBuffer, url);
28
- }
29
- const imagebitmapOptions = options && options.imagebitmap;
30
- return await safeCreateImageBitmap(blob, imagebitmapOptions);
5
+ export default async function parseToImageBitmap(arrayBuffer, options, url) {
6
+ let blob;
7
+
8
+ if (isSVG(url)) {
9
+ const image = await parseToImage(arrayBuffer, options, url);
10
+ blob = image;
11
+ } else {
12
+ blob = getBlob(arrayBuffer, url);
13
+ }
14
+
15
+ const imagebitmapOptions = options && options.imagebitmap;
16
+ return await safeCreateImageBitmap(blob, imagebitmapOptions);
31
17
  }
32
- exports.default = parseToImageBitmap;
33
- /**
34
- * Safely creates an imageBitmap with options
35
- * *
36
- * Firefox crashes if imagebitmapOptions is supplied
37
- * Avoid supplying if not provided or supported, remember if not supported
38
- */
18
+
39
19
  async function safeCreateImageBitmap(blob, imagebitmapOptions = null) {
40
- if (isEmptyObject(imagebitmapOptions) || !imagebitmapOptionsSupported) {
41
- imagebitmapOptions = null;
20
+ if (isEmptyObject(imagebitmapOptions) || !imagebitmapOptionsSupported) {
21
+ imagebitmapOptions = null;
22
+ }
23
+
24
+ if (imagebitmapOptions) {
25
+ try {
26
+ return await createImageBitmap(blob, imagebitmapOptions);
27
+ } catch (error) {
28
+ console.warn(error);
29
+ imagebitmapOptionsSupported = false;
42
30
  }
43
- if (imagebitmapOptions) {
44
- try {
45
- // @ts-ignore Options
46
- return await createImageBitmap(blob, imagebitmapOptions);
47
- }
48
- catch (error) {
49
- console.warn(error); // eslint-disable-line
50
- imagebitmapOptionsSupported = false;
51
- }
52
- }
53
- return await createImageBitmap(blob);
31
+ }
32
+
33
+ return await createImageBitmap(blob);
54
34
  }
35
+
55
36
  function isEmptyObject(object) {
56
- // @ts-ignore
57
- for (const key in object || EMPTY_OBJECT) {
58
- return false;
59
- }
60
- return true;
37
+ for (const key in object || EMPTY_OBJECT) {
38
+ return false;
39
+ }
40
+
41
+ return true;
61
42
  }
43
+ //# sourceMappingURL=parse-to-image-bitmap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/parsers/parse-to-image-bitmap.ts"],"names":["isSVG","getBlob","parseToImage","EMPTY_OBJECT","imagebitmapOptionsSupported","parseToImageBitmap","arrayBuffer","options","url","blob","image","imagebitmapOptions","imagebitmap","safeCreateImageBitmap","isEmptyObject","createImageBitmap","error","console","warn","object","key"],"mappings":"AACA,SAAQA,KAAR,EAAeC,OAAf,QAA6B,aAA7B;AACA,OAAOC,YAAP,MAAyB,kBAAzB;AAEA,MAAMC,YAAY,GAAG,EAArB;AAEA,IAAIC,2BAA2B,GAAG,IAAlC;AASA,eAAe,eAAeC,kBAAf,CACbC,WADa,EAEbC,OAFa,EAGbC,GAHa,EAIS;AACtB,MAAIC,IAAJ;;AAGA,MAAIT,KAAK,CAACQ,GAAD,CAAT,EAAgB;AAEd,UAAME,KAAK,GAAG,MAAMR,YAAY,CAACI,WAAD,EAAcC,OAAd,EAAuBC,GAAvB,CAAhC;AACAC,IAAAA,IAAI,GAAGC,KAAP;AACD,GAJD,MAIO;AAELD,IAAAA,IAAI,GAAGR,OAAO,CAACK,WAAD,EAAcE,GAAd,CAAd;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"}