@embedpdf/engines 1.0.3 → 1.0.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 (49) hide show
  1. package/dist/converters.cjs +130 -115
  2. package/dist/converters.cjs.map +1 -1
  3. package/dist/converters.d.ts +7 -12
  4. package/dist/converters.js +125 -86
  5. package/dist/converters.js.map +1 -1
  6. package/dist/index.cjs +5362 -5978
  7. package/dist/index.cjs.map +1 -1
  8. package/dist/index.d.ts +1479 -6
  9. package/dist/index.js +5399 -356
  10. package/dist/index.js.map +1 -1
  11. package/dist/pdfium-direct-engine.cjs +4037 -0
  12. package/dist/pdfium-direct-engine.cjs.map +1 -0
  13. package/dist/{pdfium.d.cts → pdfium-direct-engine.d.ts} +7 -99
  14. package/dist/pdfium-direct-engine.js +4035 -0
  15. package/dist/pdfium-direct-engine.js.map +1 -0
  16. package/dist/pdfium-worker-engine.cjs +800 -0
  17. package/dist/pdfium-worker-engine.cjs.map +1 -0
  18. package/dist/{worker.d.cts → pdfium-worker-engine.d.ts} +38 -6
  19. package/dist/pdfium-worker-engine.js +798 -0
  20. package/dist/pdfium-worker-engine.js.map +1 -0
  21. package/dist/pdfium.cjs +4243 -5647
  22. package/dist/pdfium.cjs.map +1 -1
  23. package/dist/pdfium.d.ts +134 -6
  24. package/dist/pdfium.js +4288 -21
  25. package/dist/pdfium.js.map +1 -1
  26. package/dist/preact.cjs +39 -0
  27. package/dist/preact.cjs.map +1 -0
  28. package/dist/preact.d.ts +13 -0
  29. package/dist/preact.js +37 -0
  30. package/dist/preact.js.map +1 -0
  31. package/dist/react.cjs +39 -0
  32. package/dist/react.cjs.map +1 -0
  33. package/dist/react.d.ts +13 -0
  34. package/dist/react.js +37 -0
  35. package/dist/react.js.map +1 -0
  36. package/dist/worker.cjs +771 -1104
  37. package/dist/worker.cjs.map +1 -1
  38. package/dist/worker.d.ts +32 -6
  39. package/dist/worker.js +786 -11
  40. package/dist/worker.js.map +1 -1
  41. package/package.json +42 -8
  42. package/dist/chunk-FXQUMVH5.js +0 -4599
  43. package/dist/chunk-FXQUMVH5.js.map +0 -1
  44. package/dist/chunk-YZLT3A2D.js +0 -1101
  45. package/dist/chunk-YZLT3A2D.js.map +0 -1
  46. package/dist/converters.d.cts +0 -69
  47. package/dist/index.d.cts +0 -32
  48. package/dist/runner-BvRtPCKL.d.cts +0 -131
  49. package/dist/runner-BvRtPCKL.d.ts +0 -131
@@ -1,124 +1,139 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
1
+ 'use strict';
19
2
 
20
- // src/converters/index.ts
21
- var converters_exports = {};
22
- __export(converters_exports, {
23
- browserImageDataToBlobConverter: () => browserImageDataToBlobConverter,
24
- createBrowserImageDataToBlobConverter: () => createBrowserImageDataToBlobConverter,
25
- createCustomImageDataToBlobConverter: () => createCustomImageDataToBlobConverter,
26
- createCustomImageDataToBufferConverter: () => createCustomImageDataToBufferConverter,
27
- createNodeCanvasImageDataToBlobConverter: () => createNodeCanvasImageDataToBlobConverter,
28
- createNodeImageDataToBufferConverter: () => createNodeImageDataToBufferConverter
29
- });
30
- module.exports = __toCommonJS(converters_exports);
31
- var browserImageDataToBlobConverter = (imageData) => {
32
- if (typeof OffscreenCanvas === "undefined") {
33
- throw new Error(
34
- "OffscreenCanvas is not available in this environment. This converter is intended for browser use only. Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js."
35
- );
36
- }
37
- const off = new OffscreenCanvas(imageData.width, imageData.height);
38
- off.getContext("2d").putImageData(imageData, 0, 0);
39
- return off.convertToBlob({ type: "image/webp" });
40
- };
41
- function createBrowserImageDataToBlobConverter(imageType = "image/webp") {
42
- return (imageData) => {
43
- if (typeof OffscreenCanvas === "undefined") {
44
- throw new Error(
45
- "OffscreenCanvas is not available in this environment. This converter is intended for browser use only. Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js."
46
- );
3
+ /**
4
+ * Browser implementation using OffscreenCanvas
5
+ * This is the default implementation used in browser environments
6
+ */
7
+ const browserImageDataToBlobConverter = (imageData, imageType = 'image/webp') => {
8
+ // Check if we're in a browser environment
9
+ if (typeof OffscreenCanvas === 'undefined') {
10
+ throw new Error('OffscreenCanvas is not available in this environment. ' +
11
+ 'This converter is intended for browser use only. ' +
12
+ 'Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js.');
47
13
  }
48
14
  const off = new OffscreenCanvas(imageData.width, imageData.height);
49
- off.getContext("2d").putImageData(imageData, 0, 0);
15
+ off.getContext('2d').putImageData(imageData, 0, 0);
50
16
  return off.convertToBlob({ type: imageType });
51
- };
52
- }
53
- function createNodeImageDataToBufferConverter(sharp, imageType = "image/webp") {
54
- return async (imageData) => {
55
- const { width, height, data } = imageData;
56
- let sharpInstance = sharp(Buffer.from(data), {
57
- raw: {
58
- width,
59
- height,
60
- channels: 4
61
- // RGBA
62
- }
63
- });
64
- let buffer;
65
- switch (imageType) {
66
- case "image/webp":
67
- buffer = await sharpInstance.webp().toBuffer();
68
- break;
69
- case "image/png":
70
- buffer = await sharpInstance.png().toBuffer();
71
- break;
72
- case "image/jpeg":
73
- buffer = await sharpInstance.flatten({ background: { r: 255, g: 255, b: 255 } }).jpeg().toBuffer();
74
- break;
75
- default:
76
- throw new Error(`Unsupported image type: ${imageType}`);
77
- }
78
- return buffer;
79
- };
17
+ };
18
+ /**
19
+ * Node.js implementation using Sharp
20
+ * This requires the 'sharp' package to be installed
21
+ *
22
+ * @example
23
+ * ```typescript
24
+ * import sharp from 'sharp';
25
+ * import { createNodeImageDataToBufferConverter } from '@embedpdf/engines/pdfium/image-converters';
26
+ *
27
+ * const converter = createNodeImageDataToBufferConverter(sharp);
28
+ * const engine = new PdfiumEngine(pdfiumModule, logger, converter);
29
+ * ```
30
+ */
31
+ function createNodeImageDataToBufferConverter(sharp) {
32
+ return async (imageData, imageType = 'image/webp') => {
33
+ const { width, height, data } = imageData;
34
+ // Convert ImageData to Sharp format
35
+ // ImageData uses RGBA format, Sharp expects the same
36
+ let sharpInstance = sharp(Buffer.from(data), {
37
+ raw: {
38
+ width,
39
+ height,
40
+ channels: 4, // RGBA
41
+ },
42
+ });
43
+ // Apply the appropriate format conversion based on imageType
44
+ let buffer;
45
+ switch (imageType) {
46
+ case 'image/webp':
47
+ buffer = await sharpInstance.webp().toBuffer();
48
+ break;
49
+ case 'image/png':
50
+ buffer = await sharpInstance.png().toBuffer();
51
+ break;
52
+ case 'image/jpeg':
53
+ // JPEG doesn't support transparency, so we need to composite onto a white background
54
+ buffer = await sharpInstance
55
+ .flatten({ background: { r: 255, g: 255, b: 255 } }) // Remove alpha channel with white background
56
+ .jpeg()
57
+ .toBuffer();
58
+ break;
59
+ default:
60
+ throw new Error(`Unsupported image type: ${imageType}`);
61
+ }
62
+ return buffer;
63
+ };
80
64
  }
81
- function createNodeCanvasImageDataToBlobConverter(createCanvas, imageType = "image/webp") {
82
- return async (imageData) => {
83
- const { width, height } = imageData;
84
- const canvas = createCanvas(width, height);
85
- const ctx = canvas.getContext("2d");
86
- ctx.putImageData(imageData, 0, 0);
87
- let buffer;
88
- switch (imageType) {
89
- case "image/webp":
90
- buffer = canvas.toBuffer("image/webp");
91
- break;
92
- case "image/png":
93
- buffer = canvas.toBuffer("image/png");
94
- break;
95
- case "image/jpeg":
96
- buffer = canvas.toBuffer("image/jpeg");
97
- break;
98
- default:
99
- throw new Error(`Unsupported image type: ${imageType}`);
100
- }
101
- return buffer;
102
- };
65
+ /**
66
+ * Alternative Node.js implementation using canvas (node-canvas)
67
+ * This requires the 'canvas' package to be installed
68
+ *
69
+ * @example
70
+ * ```typescript
71
+ * import { createCanvas } from 'canvas';
72
+ * import { createNodeCanvasImageDataToBlobConverter } from '@embedpdf/engines/pdfium/image-converters';
73
+ *
74
+ * const converter = createNodeCanvasImageDataToBlobConverter(createCanvas, 'image/png');
75
+ * const engine = new PdfiumEngine(pdfiumModule, logger, converter);
76
+ * ```
77
+ */
78
+ function createNodeCanvasImageDataToBlobConverter(createCanvas) {
79
+ return async (imageData, imageType = 'image/webp') => {
80
+ const { width, height } = imageData;
81
+ // Create a canvas and put the image data
82
+ const canvas = createCanvas(width, height);
83
+ const ctx = canvas.getContext('2d');
84
+ ctx.putImageData(imageData, 0, 0);
85
+ // Convert to buffer and create blob based on the requested type
86
+ let buffer;
87
+ switch (imageType) {
88
+ case 'image/webp':
89
+ buffer = canvas.toBuffer('image/webp');
90
+ break;
91
+ case 'image/png':
92
+ buffer = canvas.toBuffer('image/png');
93
+ break;
94
+ case 'image/jpeg':
95
+ buffer = canvas.toBuffer('image/jpeg');
96
+ break;
97
+ default:
98
+ throw new Error(`Unsupported image type: ${imageType}`);
99
+ }
100
+ return buffer;
101
+ };
103
102
  }
104
- function createCustomImageDataToBlobConverter(processor, imageType = "image/webp") {
105
- return async (imageData) => {
106
- const buffer = await processor(imageData);
107
- return new Blob([buffer], { type: imageType });
108
- };
103
+ /**
104
+ * Generic Node.js implementation that works with any image processing library
105
+ * that can handle raw RGBA data
106
+ *
107
+ * @example
108
+ * ```typescript
109
+ * const converter = createCustomImageDataToBlobConverter(async (imageData) => {
110
+ * // Your custom image processing logic here
111
+ * // Return a Buffer that will be wrapped in a Blob
112
+ * return processImageWithYourLibrary(imageData);
113
+ * });
114
+ * ```
115
+ */
116
+ function createCustomImageDataToBlobConverter(processor) {
117
+ return async (imageData, imageType = 'image/webp') => {
118
+ const buffer = await processor(imageData);
119
+ return new Blob([buffer], { type: imageType });
120
+ };
109
121
  }
122
+ /**
123
+ * Create a custom converter that returns a Buffer
124
+ * @param processor - function to process the image data
125
+ * @param imageType - image type
126
+ * @returns ImageDataToBlobConverter<Buffer>
127
+ */
110
128
  function createCustomImageDataToBufferConverter(processor) {
111
- return async (imageData) => {
112
- return await processor(imageData);
113
- };
129
+ return async (imageData, imageType = 'image/webp') => {
130
+ return await processor(imageData, imageType);
131
+ };
114
132
  }
115
- // Annotate the CommonJS export names for ESM import in node:
116
- 0 && (module.exports = {
117
- browserImageDataToBlobConverter,
118
- createBrowserImageDataToBlobConverter,
119
- createCustomImageDataToBlobConverter,
120
- createCustomImageDataToBufferConverter,
121
- createNodeCanvasImageDataToBlobConverter,
122
- createNodeImageDataToBufferConverter
123
- });
124
- //# sourceMappingURL=converters.cjs.map
133
+
134
+ exports.browserImageDataToBlobConverter = browserImageDataToBlobConverter;
135
+ exports.createCustomImageDataToBlobConverter = createCustomImageDataToBlobConverter;
136
+ exports.createCustomImageDataToBufferConverter = createCustomImageDataToBufferConverter;
137
+ exports.createNodeCanvasImageDataToBlobConverter = createNodeCanvasImageDataToBlobConverter;
138
+ exports.createNodeImageDataToBufferConverter = createNodeImageDataToBufferConverter;
139
+ //# sourceMappingURL=converters.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/converters/index.ts"],"sourcesContent":["/**\n * Function type for converting ImageData to Blob\n * In browser: uses OffscreenCanvas\n * In Node.js: can use Sharp or other image processing libraries\n */\nexport type ImageDataConverter<T = Blob> = (imageData: ImageData) => Promise<T>;\n\nexport type ImageConversionTypes = 'image/webp' | 'image/png' | 'image/jpeg';\n/**\n * Browser implementation using OffscreenCanvas\n * This is the default implementation used in browser environments\n */\nexport const browserImageDataToBlobConverter: ImageDataConverter = (\n imageData: ImageData,\n): Promise<Blob> => {\n // Check if we're in a browser environment\n if (typeof OffscreenCanvas === 'undefined') {\n throw new Error(\n 'OffscreenCanvas is not available in this environment. ' +\n 'This converter is intended for browser use only. ' +\n 'Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js.',\n );\n }\n\n const off = new OffscreenCanvas(imageData.width, imageData.height);\n off.getContext('2d')!.putImageData(imageData, 0, 0);\n return off.convertToBlob({ type: 'image/webp' });\n};\n\n/**\n * Create a browser implementation with custom image type\n */\nexport function createBrowserImageDataToBlobConverter(\n imageType: ImageConversionTypes = 'image/webp',\n): ImageDataConverter {\n return (imageData: ImageData): Promise<Blob> => {\n // Check if we're in a browser environment\n if (typeof OffscreenCanvas === 'undefined') {\n throw new Error(\n 'OffscreenCanvas is not available in this environment. ' +\n 'This converter is intended for browser use only. ' +\n 'Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js.',\n );\n }\n\n const off = new OffscreenCanvas(imageData.width, imageData.height);\n off.getContext('2d')!.putImageData(imageData, 0, 0);\n return off.convertToBlob({ type: imageType });\n };\n}\n\n/**\n * Node.js implementation using Sharp\n * This requires the 'sharp' package to be installed\n *\n * @example\n * ```typescript\n * import sharp from 'sharp';\n * import { createNodeImageDataToBufferConverter } from '@embedpdf/engines/pdfium/image-converters';\n *\n * const converter = createNodeImageDataToBufferConverter(sharp);\n * const engine = new PdfiumEngine(pdfiumModule, logger, converter);\n * ```\n */\nexport function createNodeImageDataToBufferConverter(\n sharp: any, // Using 'any' to avoid requiring sharp as a dependency\n imageType: ImageConversionTypes = 'image/webp',\n): ImageDataConverter<Buffer> {\n return async (imageData: ImageData): Promise<Buffer> => {\n const { width, height, data } = imageData;\n\n // Convert ImageData to Sharp format\n // ImageData uses RGBA format, Sharp expects the same\n let sharpInstance = sharp(Buffer.from(data), {\n raw: {\n width,\n height,\n channels: 4, // RGBA\n },\n });\n\n // Apply the appropriate format conversion based on imageType\n let buffer: Buffer;\n switch (imageType) {\n case 'image/webp':\n buffer = await sharpInstance.webp().toBuffer();\n break;\n case 'image/png':\n buffer = await sharpInstance.png().toBuffer();\n break;\n case 'image/jpeg':\n // JPEG doesn't support transparency, so we need to composite onto a white background\n buffer = await sharpInstance\n .flatten({ background: { r: 255, g: 255, b: 255 } }) // Remove alpha channel with white background\n .jpeg()\n .toBuffer();\n break;\n default:\n throw new Error(`Unsupported image type: ${imageType}`);\n }\n\n return buffer;\n };\n}\n\n/**\n * Alternative Node.js implementation using canvas (node-canvas)\n * This requires the 'canvas' package to be installed\n *\n * @example\n * ```typescript\n * import { createCanvas } from 'canvas';\n * import { createNodeCanvasImageDataToBlobConverter } from '@embedpdf/engines/pdfium/image-converters';\n *\n * const converter = createNodeCanvasImageDataToBlobConverter(createCanvas, 'image/png');\n * const engine = new PdfiumEngine(pdfiumModule, logger, converter);\n * ```\n */\nexport function createNodeCanvasImageDataToBlobConverter(\n createCanvas: any, // Using 'any' to avoid requiring canvas as a dependency\n imageType: ImageConversionTypes = 'image/webp',\n): ImageDataConverter<Buffer> {\n return async (imageData: ImageData): Promise<Buffer> => {\n const { width, height } = imageData;\n\n // Create a canvas and put the image data\n const canvas = createCanvas(width, height);\n const ctx = canvas.getContext('2d');\n ctx.putImageData(imageData, 0, 0);\n\n // Convert to buffer and create blob based on the requested type\n let buffer: Buffer;\n switch (imageType) {\n case 'image/webp':\n buffer = canvas.toBuffer('image/webp');\n break;\n case 'image/png':\n buffer = canvas.toBuffer('image/png');\n break;\n case 'image/jpeg':\n buffer = canvas.toBuffer('image/jpeg');\n break;\n default:\n throw new Error(`Unsupported image type: ${imageType}`);\n }\n\n return buffer;\n };\n}\n\n/**\n * Generic Node.js implementation that works with any image processing library\n * that can handle raw RGBA data\n *\n * @example\n * ```typescript\n * const converter = createCustomImageDataToBlobConverter(async (imageData) => {\n * // Your custom image processing logic here\n * // Return a Buffer that will be wrapped in a Blob\n * return processImageWithYourLibrary(imageData);\n * });\n * ```\n */\nexport function createCustomImageDataToBlobConverter(\n processor: (imageData: ImageData) => Promise<Buffer>,\n imageType: ImageConversionTypes = 'image/webp',\n): ImageDataConverter {\n return async (imageData: ImageData): Promise<Blob> => {\n const buffer = await processor(imageData);\n return new Blob([buffer], { type: imageType });\n };\n}\n\n/**\n * Create a custom converter that returns a Buffer\n * @param processor - function to process the image data\n * @param imageType - image type\n * @returns ImageDataToBlobConverter<Buffer>\n */\nexport function createCustomImageDataToBufferConverter(\n processor: (imageData: ImageData) => Promise<Buffer>,\n): ImageDataConverter<Buffer> {\n return async (imageData: ImageData): Promise<Buffer> => {\n return await processor(imageData);\n };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAYO,IAAM,kCAAsD,CACjE,cACkB;AAElB,MAAI,OAAO,oBAAoB,aAAa;AAC1C,UAAM,IAAI;AAAA,MACR;AAAA,IAGF;AAAA,EACF;AAEA,QAAM,MAAM,IAAI,gBAAgB,UAAU,OAAO,UAAU,MAAM;AACjE,MAAI,WAAW,IAAI,EAAG,aAAa,WAAW,GAAG,CAAC;AAClD,SAAO,IAAI,cAAc,EAAE,MAAM,aAAa,CAAC;AACjD;AAKO,SAAS,sCACd,YAAkC,cACd;AACpB,SAAO,CAAC,cAAwC;AAE9C,QAAI,OAAO,oBAAoB,aAAa;AAC1C,YAAM,IAAI;AAAA,QACR;AAAA,MAGF;AAAA,IACF;AAEA,UAAM,MAAM,IAAI,gBAAgB,UAAU,OAAO,UAAU,MAAM;AACjE,QAAI,WAAW,IAAI,EAAG,aAAa,WAAW,GAAG,CAAC;AAClD,WAAO,IAAI,cAAc,EAAE,MAAM,UAAU,CAAC;AAAA,EAC9C;AACF;AAeO,SAAS,qCACd,OACA,YAAkC,cACN;AAC5B,SAAO,OAAO,cAA0C;AACtD,UAAM,EAAE,OAAO,QAAQ,KAAK,IAAI;AAIhC,QAAI,gBAAgB,MAAM,OAAO,KAAK,IAAI,GAAG;AAAA,MAC3C,KAAK;AAAA,QACH;AAAA,QACA;AAAA,QACA,UAAU;AAAA;AAAA,MACZ;AAAA,IACF,CAAC;AAGD,QAAI;AACJ,YAAQ,WAAW;AAAA,MACjB,KAAK;AACH,iBAAS,MAAM,cAAc,KAAK,EAAE,SAAS;AAC7C;AAAA,MACF,KAAK;AACH,iBAAS,MAAM,cAAc,IAAI,EAAE,SAAS;AAC5C;AAAA,MACF,KAAK;AAEH,iBAAS,MAAM,cACZ,QAAQ,EAAE,YAAY,EAAE,GAAG,KAAK,GAAG,KAAK,GAAG,IAAI,EAAE,CAAC,EAClD,KAAK,EACL,SAAS;AACZ;AAAA,MACF;AACE,cAAM,IAAI,MAAM,2BAA2B,SAAS,EAAE;AAAA,IAC1D;AAEA,WAAO;AAAA,EACT;AACF;AAeO,SAAS,yCACd,cACA,YAAkC,cACN;AAC5B,SAAO,OAAO,cAA0C;AACtD,UAAM,EAAE,OAAO,OAAO,IAAI;AAG1B,UAAM,SAAS,aAAa,OAAO,MAAM;AACzC,UAAM,MAAM,OAAO,WAAW,IAAI;AAClC,QAAI,aAAa,WAAW,GAAG,CAAC;AAGhC,QAAI;AACJ,YAAQ,WAAW;AAAA,MACjB,KAAK;AACH,iBAAS,OAAO,SAAS,YAAY;AACrC;AAAA,MACF,KAAK;AACH,iBAAS,OAAO,SAAS,WAAW;AACpC;AAAA,MACF,KAAK;AACH,iBAAS,OAAO,SAAS,YAAY;AACrC;AAAA,MACF;AACE,cAAM,IAAI,MAAM,2BAA2B,SAAS,EAAE;AAAA,IAC1D;AAEA,WAAO;AAAA,EACT;AACF;AAeO,SAAS,qCACd,WACA,YAAkC,cACd;AACpB,SAAO,OAAO,cAAwC;AACpD,UAAM,SAAS,MAAM,UAAU,SAAS;AACxC,WAAO,IAAI,KAAK,CAAC,MAAM,GAAG,EAAE,MAAM,UAAU,CAAC;AAAA,EAC/C;AACF;AAQO,SAAS,uCACd,WAC4B;AAC5B,SAAO,OAAO,cAA0C;AACtD,WAAO,MAAM,UAAU,SAAS;AAAA,EAClC;AACF;","names":[]}
1
+ {"version":3,"file":"converters.cjs","sources":["../src/lib/converters/index.ts"],"sourcesContent":["/**\n * Function type for converting ImageData to Blob\n * In browser: uses OffscreenCanvas\n * In Node.js: can use Sharp or other image processing libraries\n */\nexport type ImageDataConverter<T = Blob> = (\n imageData: ImageData,\n imageType?: ImageConversionTypes,\n) => Promise<T>;\n\nexport type ImageConversionTypes = 'image/webp' | 'image/png' | 'image/jpeg';\n/**\n * Browser implementation using OffscreenCanvas\n * This is the default implementation used in browser environments\n */\nexport const browserImageDataToBlobConverter: ImageDataConverter = (\n imageData: ImageData,\n imageType: ImageConversionTypes = 'image/webp',\n): Promise<Blob> => {\n // Check if we're in a browser environment\n if (typeof OffscreenCanvas === 'undefined') {\n throw new Error(\n 'OffscreenCanvas is not available in this environment. ' +\n 'This converter is intended for browser use only. ' +\n 'Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js.',\n );\n }\n\n const off = new OffscreenCanvas(imageData.width, imageData.height);\n off.getContext('2d')!.putImageData(imageData, 0, 0);\n return off.convertToBlob({ type: imageType });\n};\n\n/**\n * Node.js implementation using Sharp\n * This requires the 'sharp' package to be installed\n *\n * @example\n * ```typescript\n * import sharp from 'sharp';\n * import { createNodeImageDataToBufferConverter } from '@embedpdf/engines/pdfium/image-converters';\n *\n * const converter = createNodeImageDataToBufferConverter(sharp);\n * const engine = new PdfiumEngine(pdfiumModule, logger, converter);\n * ```\n */\nexport function createNodeImageDataToBufferConverter(\n sharp: any, // Using 'any' to avoid requiring sharp as a dependency\n): ImageDataConverter<Buffer> {\n return async (\n imageData: ImageData,\n imageType: ImageConversionTypes = 'image/webp',\n ): Promise<Buffer> => {\n const { width, height, data } = imageData;\n\n // Convert ImageData to Sharp format\n // ImageData uses RGBA format, Sharp expects the same\n let sharpInstance = sharp(Buffer.from(data), {\n raw: {\n width,\n height,\n channels: 4, // RGBA\n },\n });\n\n // Apply the appropriate format conversion based on imageType\n let buffer: Buffer;\n switch (imageType) {\n case 'image/webp':\n buffer = await sharpInstance.webp().toBuffer();\n break;\n case 'image/png':\n buffer = await sharpInstance.png().toBuffer();\n break;\n case 'image/jpeg':\n // JPEG doesn't support transparency, so we need to composite onto a white background\n buffer = await sharpInstance\n .flatten({ background: { r: 255, g: 255, b: 255 } }) // Remove alpha channel with white background\n .jpeg()\n .toBuffer();\n break;\n default:\n throw new Error(`Unsupported image type: ${imageType}`);\n }\n\n return buffer;\n };\n}\n\n/**\n * Alternative Node.js implementation using canvas (node-canvas)\n * This requires the 'canvas' package to be installed\n *\n * @example\n * ```typescript\n * import { createCanvas } from 'canvas';\n * import { createNodeCanvasImageDataToBlobConverter } from '@embedpdf/engines/pdfium/image-converters';\n *\n * const converter = createNodeCanvasImageDataToBlobConverter(createCanvas, 'image/png');\n * const engine = new PdfiumEngine(pdfiumModule, logger, converter);\n * ```\n */\nexport function createNodeCanvasImageDataToBlobConverter(\n createCanvas: any, // Using 'any' to avoid requiring canvas as a dependency\n): ImageDataConverter<Buffer> {\n return async (\n imageData: ImageData,\n imageType: ImageConversionTypes = 'image/webp',\n ): Promise<Buffer> => {\n const { width, height } = imageData;\n\n // Create a canvas and put the image data\n const canvas = createCanvas(width, height);\n const ctx = canvas.getContext('2d');\n ctx.putImageData(imageData, 0, 0);\n\n // Convert to buffer and create blob based on the requested type\n let buffer: Buffer;\n switch (imageType) {\n case 'image/webp':\n buffer = canvas.toBuffer('image/webp');\n break;\n case 'image/png':\n buffer = canvas.toBuffer('image/png');\n break;\n case 'image/jpeg':\n buffer = canvas.toBuffer('image/jpeg');\n break;\n default:\n throw new Error(`Unsupported image type: ${imageType}`);\n }\n\n return buffer;\n };\n}\n\n/**\n * Generic Node.js implementation that works with any image processing library\n * that can handle raw RGBA data\n *\n * @example\n * ```typescript\n * const converter = createCustomImageDataToBlobConverter(async (imageData) => {\n * // Your custom image processing logic here\n * // Return a Buffer that will be wrapped in a Blob\n * return processImageWithYourLibrary(imageData);\n * });\n * ```\n */\nexport function createCustomImageDataToBlobConverter(\n processor: (imageData: ImageData) => Promise<Buffer>,\n): ImageDataConverter {\n return async (\n imageData: ImageData,\n imageType: ImageConversionTypes = 'image/webp',\n ): Promise<Blob> => {\n const buffer = await processor(imageData);\n return new Blob([buffer], { type: imageType });\n };\n}\n\n/**\n * Create a custom converter that returns a Buffer\n * @param processor - function to process the image data\n * @param imageType - image type\n * @returns ImageDataToBlobConverter<Buffer>\n */\nexport function createCustomImageDataToBufferConverter(\n processor: (imageData: ImageData, imageType: ImageConversionTypes) => Promise<Buffer>,\n): ImageDataConverter<Buffer> {\n return async (\n imageData: ImageData,\n imageType: ImageConversionTypes = 'image/webp',\n ): Promise<Buffer> => {\n return await processor(imageData, imageType);\n };\n}\n"],"names":[],"mappings":"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"}
@@ -3,17 +3,13 @@
3
3
  * In browser: uses OffscreenCanvas
4
4
  * In Node.js: can use Sharp or other image processing libraries
5
5
  */
6
- type ImageDataConverter<T = Blob> = (imageData: ImageData) => Promise<T>;
6
+ type ImageDataConverter<T = Blob> = (imageData: ImageData, imageType?: ImageConversionTypes) => Promise<T>;
7
7
  type ImageConversionTypes = 'image/webp' | 'image/png' | 'image/jpeg';
8
8
  /**
9
9
  * Browser implementation using OffscreenCanvas
10
10
  * This is the default implementation used in browser environments
11
11
  */
12
12
  declare const browserImageDataToBlobConverter: ImageDataConverter;
13
- /**
14
- * Create a browser implementation with custom image type
15
- */
16
- declare function createBrowserImageDataToBlobConverter(imageType?: ImageConversionTypes): ImageDataConverter;
17
13
  /**
18
14
  * Node.js implementation using Sharp
19
15
  * This requires the 'sharp' package to be installed
@@ -27,8 +23,7 @@ declare function createBrowserImageDataToBlobConverter(imageType?: ImageConversi
27
23
  * const engine = new PdfiumEngine(pdfiumModule, logger, converter);
28
24
  * ```
29
25
  */
30
- declare function createNodeImageDataToBufferConverter(sharp: any, // Using 'any' to avoid requiring sharp as a dependency
31
- imageType?: ImageConversionTypes): ImageDataConverter<Buffer>;
26
+ declare function createNodeImageDataToBufferConverter(sharp: any): ImageDataConverter<Buffer>;
32
27
  /**
33
28
  * Alternative Node.js implementation using canvas (node-canvas)
34
29
  * This requires the 'canvas' package to be installed
@@ -42,8 +37,7 @@ imageType?: ImageConversionTypes): ImageDataConverter<Buffer>;
42
37
  * const engine = new PdfiumEngine(pdfiumModule, logger, converter);
43
38
  * ```
44
39
  */
45
- declare function createNodeCanvasImageDataToBlobConverter(createCanvas: any, // Using 'any' to avoid requiring canvas as a dependency
46
- imageType?: ImageConversionTypes): ImageDataConverter<Buffer>;
40
+ declare function createNodeCanvasImageDataToBlobConverter(createCanvas: any): ImageDataConverter<Buffer>;
47
41
  /**
48
42
  * Generic Node.js implementation that works with any image processing library
49
43
  * that can handle raw RGBA data
@@ -57,13 +51,14 @@ imageType?: ImageConversionTypes): ImageDataConverter<Buffer>;
57
51
  * });
58
52
  * ```
59
53
  */
60
- declare function createCustomImageDataToBlobConverter(processor: (imageData: ImageData) => Promise<Buffer>, imageType?: ImageConversionTypes): ImageDataConverter;
54
+ declare function createCustomImageDataToBlobConverter(processor: (imageData: ImageData) => Promise<Buffer>): ImageDataConverter;
61
55
  /**
62
56
  * Create a custom converter that returns a Buffer
63
57
  * @param processor - function to process the image data
64
58
  * @param imageType - image type
65
59
  * @returns ImageDataToBlobConverter<Buffer>
66
60
  */
67
- declare function createCustomImageDataToBufferConverter(processor: (imageData: ImageData) => Promise<Buffer>): ImageDataConverter<Buffer>;
61
+ declare function createCustomImageDataToBufferConverter(processor: (imageData: ImageData, imageType: ImageConversionTypes) => Promise<Buffer>): ImageDataConverter<Buffer>;
68
62
 
69
- export { type ImageConversionTypes, type ImageDataConverter, browserImageDataToBlobConverter, createBrowserImageDataToBlobConverter, createCustomImageDataToBlobConverter, createCustomImageDataToBufferConverter, createNodeCanvasImageDataToBlobConverter, createNodeImageDataToBufferConverter };
63
+ export { browserImageDataToBlobConverter, createCustomImageDataToBlobConverter, createCustomImageDataToBufferConverter, createNodeCanvasImageDataToBlobConverter, createNodeImageDataToBufferConverter };
64
+ export type { ImageConversionTypes, ImageDataConverter };
@@ -1,94 +1,133 @@
1
- // src/converters/index.ts
2
- var browserImageDataToBlobConverter = (imageData) => {
3
- if (typeof OffscreenCanvas === "undefined") {
4
- throw new Error(
5
- "OffscreenCanvas is not available in this environment. This converter is intended for browser use only. Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js."
6
- );
7
- }
8
- const off = new OffscreenCanvas(imageData.width, imageData.height);
9
- off.getContext("2d").putImageData(imageData, 0, 0);
10
- return off.convertToBlob({ type: "image/webp" });
11
- };
12
- function createBrowserImageDataToBlobConverter(imageType = "image/webp") {
13
- return (imageData) => {
14
- if (typeof OffscreenCanvas === "undefined") {
15
- throw new Error(
16
- "OffscreenCanvas is not available in this environment. This converter is intended for browser use only. Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js."
17
- );
1
+ /**
2
+ * Browser implementation using OffscreenCanvas
3
+ * This is the default implementation used in browser environments
4
+ */
5
+ const browserImageDataToBlobConverter = (imageData, imageType = 'image/webp') => {
6
+ // Check if we're in a browser environment
7
+ if (typeof OffscreenCanvas === 'undefined') {
8
+ throw new Error('OffscreenCanvas is not available in this environment. ' +
9
+ 'This converter is intended for browser use only. ' +
10
+ 'Please use createNodeImageDataToBlobConverter() or createNodeCanvasImageDataToBlobConverter() for Node.js.');
18
11
  }
19
12
  const off = new OffscreenCanvas(imageData.width, imageData.height);
20
- off.getContext("2d").putImageData(imageData, 0, 0);
13
+ off.getContext('2d').putImageData(imageData, 0, 0);
21
14
  return off.convertToBlob({ type: imageType });
22
- };
23
- }
24
- function createNodeImageDataToBufferConverter(sharp, imageType = "image/webp") {
25
- return async (imageData) => {
26
- const { width, height, data } = imageData;
27
- let sharpInstance = sharp(Buffer.from(data), {
28
- raw: {
29
- width,
30
- height,
31
- channels: 4
32
- // RGBA
33
- }
34
- });
35
- let buffer;
36
- switch (imageType) {
37
- case "image/webp":
38
- buffer = await sharpInstance.webp().toBuffer();
39
- break;
40
- case "image/png":
41
- buffer = await sharpInstance.png().toBuffer();
42
- break;
43
- case "image/jpeg":
44
- buffer = await sharpInstance.flatten({ background: { r: 255, g: 255, b: 255 } }).jpeg().toBuffer();
45
- break;
46
- default:
47
- throw new Error(`Unsupported image type: ${imageType}`);
48
- }
49
- return buffer;
50
- };
15
+ };
16
+ /**
17
+ * Node.js implementation using Sharp
18
+ * This requires the 'sharp' package to be installed
19
+ *
20
+ * @example
21
+ * ```typescript
22
+ * import sharp from 'sharp';
23
+ * import { createNodeImageDataToBufferConverter } from '@embedpdf/engines/pdfium/image-converters';
24
+ *
25
+ * const converter = createNodeImageDataToBufferConverter(sharp);
26
+ * const engine = new PdfiumEngine(pdfiumModule, logger, converter);
27
+ * ```
28
+ */
29
+ function createNodeImageDataToBufferConverter(sharp) {
30
+ return async (imageData, imageType = 'image/webp') => {
31
+ const { width, height, data } = imageData;
32
+ // Convert ImageData to Sharp format
33
+ // ImageData uses RGBA format, Sharp expects the same
34
+ let sharpInstance = sharp(Buffer.from(data), {
35
+ raw: {
36
+ width,
37
+ height,
38
+ channels: 4, // RGBA
39
+ },
40
+ });
41
+ // Apply the appropriate format conversion based on imageType
42
+ let buffer;
43
+ switch (imageType) {
44
+ case 'image/webp':
45
+ buffer = await sharpInstance.webp().toBuffer();
46
+ break;
47
+ case 'image/png':
48
+ buffer = await sharpInstance.png().toBuffer();
49
+ break;
50
+ case 'image/jpeg':
51
+ // JPEG doesn't support transparency, so we need to composite onto a white background
52
+ buffer = await sharpInstance
53
+ .flatten({ background: { r: 255, g: 255, b: 255 } }) // Remove alpha channel with white background
54
+ .jpeg()
55
+ .toBuffer();
56
+ break;
57
+ default:
58
+ throw new Error(`Unsupported image type: ${imageType}`);
59
+ }
60
+ return buffer;
61
+ };
51
62
  }
52
- function createNodeCanvasImageDataToBlobConverter(createCanvas, imageType = "image/webp") {
53
- return async (imageData) => {
54
- const { width, height } = imageData;
55
- const canvas = createCanvas(width, height);
56
- const ctx = canvas.getContext("2d");
57
- ctx.putImageData(imageData, 0, 0);
58
- let buffer;
59
- switch (imageType) {
60
- case "image/webp":
61
- buffer = canvas.toBuffer("image/webp");
62
- break;
63
- case "image/png":
64
- buffer = canvas.toBuffer("image/png");
65
- break;
66
- case "image/jpeg":
67
- buffer = canvas.toBuffer("image/jpeg");
68
- break;
69
- default:
70
- throw new Error(`Unsupported image type: ${imageType}`);
71
- }
72
- return buffer;
73
- };
63
+ /**
64
+ * Alternative Node.js implementation using canvas (node-canvas)
65
+ * This requires the 'canvas' package to be installed
66
+ *
67
+ * @example
68
+ * ```typescript
69
+ * import { createCanvas } from 'canvas';
70
+ * import { createNodeCanvasImageDataToBlobConverter } from '@embedpdf/engines/pdfium/image-converters';
71
+ *
72
+ * const converter = createNodeCanvasImageDataToBlobConverter(createCanvas, 'image/png');
73
+ * const engine = new PdfiumEngine(pdfiumModule, logger, converter);
74
+ * ```
75
+ */
76
+ function createNodeCanvasImageDataToBlobConverter(createCanvas) {
77
+ return async (imageData, imageType = 'image/webp') => {
78
+ const { width, height } = imageData;
79
+ // Create a canvas and put the image data
80
+ const canvas = createCanvas(width, height);
81
+ const ctx = canvas.getContext('2d');
82
+ ctx.putImageData(imageData, 0, 0);
83
+ // Convert to buffer and create blob based on the requested type
84
+ let buffer;
85
+ switch (imageType) {
86
+ case 'image/webp':
87
+ buffer = canvas.toBuffer('image/webp');
88
+ break;
89
+ case 'image/png':
90
+ buffer = canvas.toBuffer('image/png');
91
+ break;
92
+ case 'image/jpeg':
93
+ buffer = canvas.toBuffer('image/jpeg');
94
+ break;
95
+ default:
96
+ throw new Error(`Unsupported image type: ${imageType}`);
97
+ }
98
+ return buffer;
99
+ };
74
100
  }
75
- function createCustomImageDataToBlobConverter(processor, imageType = "image/webp") {
76
- return async (imageData) => {
77
- const buffer = await processor(imageData);
78
- return new Blob([buffer], { type: imageType });
79
- };
101
+ /**
102
+ * Generic Node.js implementation that works with any image processing library
103
+ * that can handle raw RGBA data
104
+ *
105
+ * @example
106
+ * ```typescript
107
+ * const converter = createCustomImageDataToBlobConverter(async (imageData) => {
108
+ * // Your custom image processing logic here
109
+ * // Return a Buffer that will be wrapped in a Blob
110
+ * return processImageWithYourLibrary(imageData);
111
+ * });
112
+ * ```
113
+ */
114
+ function createCustomImageDataToBlobConverter(processor) {
115
+ return async (imageData, imageType = 'image/webp') => {
116
+ const buffer = await processor(imageData);
117
+ return new Blob([buffer], { type: imageType });
118
+ };
80
119
  }
120
+ /**
121
+ * Create a custom converter that returns a Buffer
122
+ * @param processor - function to process the image data
123
+ * @param imageType - image type
124
+ * @returns ImageDataToBlobConverter<Buffer>
125
+ */
81
126
  function createCustomImageDataToBufferConverter(processor) {
82
- return async (imageData) => {
83
- return await processor(imageData);
84
- };
127
+ return async (imageData, imageType = 'image/webp') => {
128
+ return await processor(imageData, imageType);
129
+ };
85
130
  }
86
- export {
87
- browserImageDataToBlobConverter,
88
- createBrowserImageDataToBlobConverter,
89
- createCustomImageDataToBlobConverter,
90
- createCustomImageDataToBufferConverter,
91
- createNodeCanvasImageDataToBlobConverter,
92
- createNodeImageDataToBufferConverter
93
- };
94
- //# sourceMappingURL=converters.js.map
131
+
132
+ export { browserImageDataToBlobConverter, createCustomImageDataToBlobConverter, createCustomImageDataToBufferConverter, createNodeCanvasImageDataToBlobConverter, createNodeImageDataToBufferConverter };
133
+ //# sourceMappingURL=converters.js.map