@embedpdf/engines 1.0.10 → 1.0.12

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 (104) hide show
  1. package/dist/engine-B7CS6Qyp.cjs +2 -0
  2. package/dist/engine-B7CS6Qyp.cjs.map +1 -0
  3. package/dist/engine-M0_XZhss.js +5043 -0
  4. package/dist/engine-M0_XZhss.js.map +1 -0
  5. package/dist/index.cjs +1 -5846
  6. package/dist/index.cjs.map +1 -1
  7. package/dist/index.d.ts +1 -1613
  8. package/dist/index.js +339 -5824
  9. package/dist/index.js.map +1 -1
  10. package/dist/lib/converters/index.cjs +2 -0
  11. package/dist/lib/converters/index.cjs.map +1 -0
  12. package/dist/{converters.d.ts → lib/converters/index.d.ts} +7 -10
  13. package/dist/lib/converters/index.js +80 -0
  14. package/dist/{converters.cjs.map → lib/converters/index.js.map} +1 -1
  15. package/dist/lib/index.d.ts +7 -0
  16. package/dist/lib/mock/index.d.ts +25 -0
  17. package/dist/lib/pdfium/cache.d.ts +62 -0
  18. package/dist/{pdfium-direct-engine.d.ts → lib/pdfium/engine.d.ts} +73 -8
  19. package/dist/lib/pdfium/helper.d.ts +21 -0
  20. package/dist/lib/pdfium/index.cjs +2 -0
  21. package/dist/lib/pdfium/index.cjs.map +1 -0
  22. package/dist/lib/pdfium/index.d.ts +3 -0
  23. package/dist/lib/pdfium/index.js +13 -0
  24. package/dist/lib/pdfium/index.js.map +1 -0
  25. package/dist/lib/pdfium/runner.d.ts +16 -0
  26. package/dist/lib/pdfium/web/direct-engine.cjs +2 -0
  27. package/dist/lib/pdfium/web/direct-engine.cjs.map +1 -0
  28. package/dist/lib/pdfium/web/direct-engine.d.ts +3 -0
  29. package/dist/lib/pdfium/web/direct-engine.js +12 -0
  30. package/dist/lib/pdfium/web/direct-engine.js.map +1 -0
  31. package/dist/lib/pdfium/web/worker-engine.cjs +2 -0
  32. package/dist/lib/pdfium/web/worker-engine.cjs.map +1 -0
  33. package/dist/lib/pdfium/web/worker-engine.d.ts +7 -0
  34. package/dist/lib/pdfium/web/worker-engine.js +15 -0
  35. package/dist/lib/pdfium/web/worker-engine.js.map +1 -0
  36. package/dist/lib/pdfium/worker.d.ts +1 -0
  37. package/dist/lib/pdfium-engine.d.ts +1 -0
  38. package/dist/lib/webworker/engine.cjs +2 -0
  39. package/dist/lib/webworker/engine.cjs.map +1 -0
  40. package/dist/{worker.d.ts → lib/webworker/engine.d.ts} +4 -34
  41. package/dist/lib/webworker/engine.js +887 -0
  42. package/dist/lib/webworker/engine.js.map +1 -0
  43. package/dist/lib/webworker/index.d.ts +2 -0
  44. package/dist/lib/webworker/runner.d.ts +128 -0
  45. package/dist/lib/webworker-engine.d.ts +1 -0
  46. package/dist/preact/adapter.d.ts +1 -0
  47. package/dist/preact/index.cjs +2 -0
  48. package/dist/preact/index.cjs.map +1 -0
  49. package/dist/preact/index.d.ts +1 -0
  50. package/dist/preact/index.js +37 -0
  51. package/dist/preact/index.js.map +1 -0
  52. package/dist/react/adapter.d.ts +1 -0
  53. package/dist/react/index.cjs +2 -0
  54. package/dist/react/index.cjs.map +1 -0
  55. package/dist/react/index.d.ts +1 -0
  56. package/dist/react/index.js +37 -0
  57. package/dist/react/index.js.map +1 -0
  58. package/dist/runner-BcS-WEof.cjs +2 -0
  59. package/dist/runner-BcS-WEof.cjs.map +1 -0
  60. package/dist/runner-DUp_7Uu_.js +269 -0
  61. package/dist/runner-DUp_7Uu_.js.map +1 -0
  62. package/dist/shared-preact/hooks/index.d.ts +1 -0
  63. package/dist/{preact.d.ts → shared-preact/hooks/use-pdfium-engine.d.ts} +3 -5
  64. package/dist/shared-preact/index.d.ts +1 -0
  65. package/dist/shared-react/hooks/index.d.ts +1 -0
  66. package/dist/{react.d.ts → shared-react/hooks/use-pdfium-engine.d.ts} +3 -5
  67. package/dist/shared-react/index.d.ts +1 -0
  68. package/dist/vue/hooks/index.d.ts +1 -0
  69. package/dist/vue/hooks/use-pdfium-engine.d.ts +18 -0
  70. package/dist/vue/index.cjs +2 -0
  71. package/dist/vue/index.cjs.map +1 -0
  72. package/dist/vue/index.d.ts +1 -0
  73. package/dist/vue/index.js +39 -0
  74. package/dist/vue/index.js.map +1 -0
  75. package/package.json +41 -41
  76. package/dist/converters.cjs +0 -139
  77. package/dist/converters.js +0 -133
  78. package/dist/converters.js.map +0 -1
  79. package/dist/pdfium-direct-engine.cjs +0 -4400
  80. package/dist/pdfium-direct-engine.cjs.map +0 -1
  81. package/dist/pdfium-direct-engine.js +0 -4398
  82. package/dist/pdfium-direct-engine.js.map +0 -1
  83. package/dist/pdfium-worker-engine.cjs +0 -851
  84. package/dist/pdfium-worker-engine.cjs.map +0 -1
  85. package/dist/pdfium-worker-engine.d.ts +0 -314
  86. package/dist/pdfium-worker-engine.js +0 -849
  87. package/dist/pdfium-worker-engine.js.map +0 -1
  88. package/dist/pdfium.cjs +0 -4667
  89. package/dist/pdfium.cjs.map +0 -1
  90. package/dist/pdfium.d.ts +0 -1311
  91. package/dist/pdfium.js +0 -4661
  92. package/dist/pdfium.js.map +0 -1
  93. package/dist/preact.cjs +0 -41
  94. package/dist/preact.cjs.map +0 -1
  95. package/dist/preact.js +0 -39
  96. package/dist/preact.js.map +0 -1
  97. package/dist/react.cjs +0 -41
  98. package/dist/react.cjs.map +0 -1
  99. package/dist/react.js +0 -39
  100. package/dist/react.js.map +0 -1
  101. package/dist/worker.cjs +0 -839
  102. package/dist/worker.cjs.map +0 -1
  103. package/dist/worker.js +0 -836
  104. package/dist/worker.js.map +0 -1
@@ -1,139 +0,0 @@
1
- 'use strict';
2
-
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.');
13
- }
14
- const off = new OffscreenCanvas(imageData.width, imageData.height);
15
- off.getContext('2d').putImageData(imageData, 0, 0);
16
- return off.convertToBlob({ type: imageType });
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
- };
64
- }
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
- };
102
- }
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
- };
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
- */
128
- function createCustomImageDataToBufferConverter(processor) {
129
- return async (imageData, imageType = 'image/webp') => {
130
- return await processor(imageData, imageType);
131
- };
132
- }
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,133 +0,0 @@
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.');
11
- }
12
- const off = new OffscreenCanvas(imageData.width, imageData.height);
13
- off.getContext('2d').putImageData(imageData, 0, 0);
14
- return off.convertToBlob({ type: imageType });
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
- };
62
- }
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
- };
100
- }
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
- };
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
- */
126
- function createCustomImageDataToBufferConverter(processor) {
127
- return async (imageData, imageType = 'image/webp') => {
128
- return await processor(imageData, imageType);
129
- };
130
- }
131
-
132
- export { browserImageDataToBlobConverter, createCustomImageDataToBlobConverter, createCustomImageDataToBufferConverter, createNodeCanvasImageDataToBlobConverter, createNodeImageDataToBufferConverter };
133
- //# sourceMappingURL=converters.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"converters.js","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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"}