@embedpdf/engines 2.0.0-next.1 → 2.0.0-next.3
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.
- package/dist/browser-B5Y-F6il.cjs +2 -0
- package/dist/browser-B5Y-F6il.cjs.map +1 -0
- package/dist/browser-Cm3DA8l_.js +70 -0
- package/dist/browser-Cm3DA8l_.js.map +1 -0
- package/dist/{engine-B-RaFU77.js → direct-engine-BZRK27cv.js} +197 -508
- package/dist/direct-engine-BZRK27cv.js.map +1 -0
- package/dist/direct-engine-CZAhOupl.cjs +2 -0
- package/dist/direct-engine-CZAhOupl.cjs.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +283 -9
- package/dist/index.js.map +1 -1
- package/dist/lib/converters/browser.d.ts +32 -0
- package/dist/lib/converters/index.cjs +1 -1
- package/dist/lib/converters/index.cjs.map +1 -1
- package/dist/lib/converters/index.d.ts +3 -51
- package/dist/lib/converters/index.js +6 -1
- package/dist/lib/converters/index.js.map +1 -1
- package/dist/lib/converters/node.d.ts +51 -0
- package/dist/lib/converters/types.d.ts +6 -3
- package/dist/lib/image-encoder/image-encoder-worker.d.ts +24 -0
- package/dist/lib/image-encoder/index.d.ts +2 -0
- package/dist/lib/image-encoder/worker-pool.d.ts +61 -0
- package/dist/lib/orchestrator/index.d.ts +16 -0
- package/dist/lib/orchestrator/pdf-engine.d.ts +100 -0
- package/dist/lib/orchestrator/pdfium-native-runner.d.ts +65 -0
- package/dist/lib/orchestrator/remote-executor.d.ts +94 -0
- package/dist/lib/orchestrator/task-queue.d.ts +87 -0
- package/dist/lib/pdfium/engine.d.ts +50 -84
- package/dist/lib/pdfium/index.cjs +1 -1
- package/dist/lib/pdfium/index.cjs.map +1 -1
- package/dist/lib/pdfium/index.d.ts +5 -1
- package/dist/lib/pdfium/index.js +12 -7
- package/dist/lib/pdfium/index.js.map +1 -1
- package/dist/lib/pdfium/runner.d.ts +2 -2
- package/dist/lib/pdfium/web/direct-engine.cjs +1 -1
- package/dist/lib/pdfium/web/direct-engine.cjs.map +1 -1
- package/dist/lib/pdfium/web/direct-engine.d.ts +33 -2
- package/dist/lib/pdfium/web/direct-engine.js +5 -9
- package/dist/lib/pdfium/web/direct-engine.js.map +1 -1
- package/dist/lib/pdfium/web/worker-engine.cjs +1 -1
- package/dist/lib/pdfium/web/worker-engine.cjs.map +1 -1
- package/dist/lib/pdfium/web/worker-engine.d.ts +40 -4
- package/dist/lib/pdfium/web/worker-engine.js +415 -9
- package/dist/lib/pdfium/web/worker-engine.js.map +1 -1
- package/dist/lib/webworker/runner.d.ts +0 -12
- package/dist/pdf-engine-CrarIjJ6.cjs +2 -0
- package/dist/pdf-engine-CrarIjJ6.cjs.map +1 -0
- package/dist/pdf-engine-yZzBqL_l.js +798 -0
- package/dist/pdf-engine-yZzBqL_l.js.map +1 -0
- package/dist/preact/index.cjs +1 -1
- package/dist/preact/index.cjs.map +1 -1
- package/dist/preact/index.js +3 -3
- package/dist/preact/index.js.map +1 -1
- package/dist/react/index.cjs +1 -1
- package/dist/react/index.cjs.map +1 -1
- package/dist/react/index.js +3 -3
- package/dist/react/index.js.map +1 -1
- package/dist/shared-preact/hooks/use-pdfium-engine.d.ts +1 -0
- package/dist/shared-react/hooks/use-pdfium-engine.d.ts +1 -0
- package/dist/svelte/index.cjs +1 -1
- package/dist/svelte/index.cjs.map +1 -1
- package/dist/svelte/index.js +1 -1
- package/dist/svelte/index.js.map +1 -1
- package/dist/vue/index.cjs +1 -1
- package/dist/vue/index.cjs.map +1 -1
- package/dist/vue/index.js +2 -2
- package/dist/vue/index.js.map +1 -1
- package/package.json +3 -3
- package/dist/engine-B-RaFU77.js.map +0 -1
- package/dist/engine-CXnLqg_9.cjs +0 -2
- package/dist/engine-CXnLqg_9.cjs.map +0 -1
- package/dist/index-C3mv9vLs.js +0 -342
- package/dist/index-C3mv9vLs.js.map +0 -1
- package/dist/index-C4OBhnbs.cjs +0 -2
- package/dist/index-C4OBhnbs.cjs.map +0 -1
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";class e extends Error{constructor(e){super(e),this.name="OffscreenCanvasError"}}exports.OffscreenCanvasError=e,exports.browserImageDataToBlobConverter=(t,r="image/webp",a)=>{if("undefined"==typeof OffscreenCanvas)return Promise.reject(new e("OffscreenCanvas is not available in this environment. This converter is intended for browser use only. Falling back to WASM-based image encoding."));const n=t(),o=new ImageData(n.data,n.width,n.height),i=new OffscreenCanvas(o.width,o.height);return i.getContext("2d").putImageData(o,0,0),i.convertToBlob({type:r,quality:a})},exports.createHybridImageConverter=function(e,t){return async(r,a="image/webp",n)=>{const o=r();try{const t=new Uint8ClampedArray(o.data);return await e.encode({data:t,width:o.width,height:o.height},a,n)}catch(i){return console.warn("Worker pool encoding failed, falling back to WASM:",i),t({data:o.data,width:o.width,height:o.height},a,n)}}},exports.createWorkerPoolImageConverter=function(e){return(t,r="image/webp",a)=>{const n=t(),o=new Uint8ClampedArray(n.data);return e.encode({data:o,width:n.width,height:n.height},r,a)}};
|
|
2
|
+
//# sourceMappingURL=browser-B5Y-F6il.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"browser-B5Y-F6il.cjs","sources":["../src/lib/converters/browser.ts"],"sourcesContent":["import type { ImageConversionTypes } from '@embedpdf/models';\nimport type { ImageDataConverter, LazyImageData } from './types';\nimport { ImageEncoderWorkerPool } from '../image-encoder';\n\n// ============================================================================\n// Error Classes\n// ============================================================================\n\nexport class OffscreenCanvasError extends Error {\n constructor(message: string) {\n super(message);\n this.name = 'OffscreenCanvasError';\n }\n}\n\n// ============================================================================\n// Browser Converters\n// ============================================================================\n\n/**\n * Browser-based image converter using OffscreenCanvas in the same thread\n * This is the simplest approach but blocks the thread during encoding\n */\nexport const browserImageDataToBlobConverter: ImageDataConverter<Blob> = (\n getImageData: LazyImageData,\n imageType: ImageConversionTypes = 'image/webp',\n quality?: number,\n): Promise<Blob> => {\n // Check if we're in a browser environment\n if (typeof OffscreenCanvas === 'undefined') {\n return Promise.reject(\n new OffscreenCanvasError(\n 'OffscreenCanvas is not available in this environment. ' +\n 'This converter is intended for browser use only. ' +\n 'Falling back to WASM-based image encoding.',\n ),\n );\n }\n\n const pdfImage = getImageData();\n const imageData = new ImageData(pdfImage.data, pdfImage.width, pdfImage.height);\n const off = new OffscreenCanvas(imageData.width, imageData.height);\n off.getContext('2d')!.putImageData(imageData, 0, 0);\n return off.convertToBlob({ type: imageType, quality });\n};\n\n/**\n * Create an image converter that uses a dedicated worker pool for encoding\n * This prevents blocking the main/PDFium worker thread\n *\n * @param workerPool - Instance of ImageEncoderWorkerPool\n * @returns ImageDataConverter function\n */\nexport function createWorkerPoolImageConverter(\n workerPool: ImageEncoderWorkerPool,\n): ImageDataConverter<Blob> {\n return (\n getImageData: LazyImageData,\n imageType: ImageConversionTypes = 'image/webp',\n quality?: number,\n ): Promise<Blob> => {\n const pdfImage = getImageData();\n\n // Copy the data since we'll transfer it to another worker\n const dataCopy = new Uint8ClampedArray(pdfImage.data);\n\n return workerPool.encode(\n {\n data: dataCopy,\n width: pdfImage.width,\n height: pdfImage.height,\n },\n imageType,\n quality,\n );\n };\n}\n\n/**\n * Hybrid converter: tries worker pool first, falls back to WASM encoding\n * This provides the best performance with graceful degradation\n *\n * @param workerPool - Instance of ImageEncoderWorkerPool\n * @param wasmFallback - WASM-based encoding function\n * @returns ImageDataConverter function\n */\nexport function createHybridImageConverter(\n workerPool: ImageEncoderWorkerPool,\n wasmFallback: (\n imageData: { data: Uint8ClampedArray; width: number; height: number },\n imageType: ImageConversionTypes,\n quality?: number,\n ) => Blob,\n): ImageDataConverter<Blob> {\n return async (\n getImageData: LazyImageData,\n imageType: ImageConversionTypes = 'image/webp',\n quality?: number,\n ): Promise<Blob> => {\n const pdfImage = getImageData();\n\n try {\n // Try worker pool encoding first\n const dataCopy = new Uint8ClampedArray(pdfImage.data);\n return await workerPool.encode(\n {\n data: dataCopy,\n width: pdfImage.width,\n height: pdfImage.height,\n },\n imageType,\n quality,\n );\n } catch (error) {\n // Fallback to WASM encoding\n console.warn('Worker pool encoding failed, falling back to WASM:', error);\n return wasmFallback(\n {\n data: pdfImage.data,\n width: pdfImage.width,\n height: pdfImage.height,\n },\n imageType,\n quality,\n );\n }\n };\n}\n"],"names":["OffscreenCanvasError","Error","constructor","message","super","this","name","getImageData","imageType","quality","OffscreenCanvas","Promise","reject","pdfImage","imageData","ImageData","data","width","height","off","getContext","putImageData","convertToBlob","type","workerPool","wasmFallback","async","dataCopy","Uint8ClampedArray","encode","error","console","warn"],"mappings":"aAQO,MAAMA,UAA6BC,MACxC,WAAAC,CAAYC,GACVC,MAAMD,GACNE,KAAKC,KAAO,sBACd,yEAWuE,CACvEC,EACAC,EAAkC,aAClCC,KAGA,GAA+B,oBAApBC,gBACT,OAAOC,QAAQC,OACb,IAAIZ,EACF,sJAON,MAAMa,EAAWN,IACXO,EAAY,IAAIC,UAAUF,EAASG,KAAMH,EAASI,MAAOJ,EAASK,QAClEC,EAAM,IAAIT,gBAAgBI,EAAUG,MAAOH,EAAUI,QAE3D,OADAC,EAAIC,WAAW,MAAOC,aAAaP,EAAW,EAAG,GAC1CK,EAAIG,cAAc,CAAEC,KAAMf,EAAWC,gDA2CvC,SACLe,EACAC,GAMA,OAAOC,MACLnB,EACAC,EAAkC,aAClCC,KAEA,MAAMI,EAAWN,IAEjB,IAEE,MAAMoB,EAAW,IAAIC,kBAAkBf,EAASG,MAChD,aAAaQ,EAAWK,OACtB,CACEb,KAAMW,EACNV,MAAOJ,EAASI,MAChBC,OAAQL,EAASK,QAEnBV,EACAC,EAEJ,OAASqB,GAGP,OADAC,QAAQC,KAAK,qDAAsDF,GAC5DL,EACL,CACET,KAAMH,EAASG,KACfC,MAAOJ,EAASI,MAChBC,OAAQL,EAASK,QAEnBV,EACAC,EAEJ,EAEJ,yCA1EO,SACLe,GAEA,MAAO,CACLjB,EACAC,EAAkC,aAClCC,KAEA,MAAMI,EAAWN,IAGXoB,EAAW,IAAIC,kBAAkBf,EAASG,MAEhD,OAAOQ,EAAWK,OAChB,CACEb,KAAMW,EACNV,MAAOJ,EAASI,MAChBC,OAAQL,EAASK,QAEnBV,EACAC,GAGN"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
class OffscreenCanvasError extends Error {
|
|
2
|
+
constructor(message) {
|
|
3
|
+
super(message);
|
|
4
|
+
this.name = "OffscreenCanvasError";
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
const browserImageDataToBlobConverter = (getImageData, imageType = "image/webp", quality) => {
|
|
8
|
+
if (typeof OffscreenCanvas === "undefined") {
|
|
9
|
+
return Promise.reject(
|
|
10
|
+
new OffscreenCanvasError(
|
|
11
|
+
"OffscreenCanvas is not available in this environment. This converter is intended for browser use only. Falling back to WASM-based image encoding."
|
|
12
|
+
)
|
|
13
|
+
);
|
|
14
|
+
}
|
|
15
|
+
const pdfImage = getImageData();
|
|
16
|
+
const imageData = new ImageData(pdfImage.data, pdfImage.width, pdfImage.height);
|
|
17
|
+
const off = new OffscreenCanvas(imageData.width, imageData.height);
|
|
18
|
+
off.getContext("2d").putImageData(imageData, 0, 0);
|
|
19
|
+
return off.convertToBlob({ type: imageType, quality });
|
|
20
|
+
};
|
|
21
|
+
function createWorkerPoolImageConverter(workerPool) {
|
|
22
|
+
return (getImageData, imageType = "image/webp", quality) => {
|
|
23
|
+
const pdfImage = getImageData();
|
|
24
|
+
const dataCopy = new Uint8ClampedArray(pdfImage.data);
|
|
25
|
+
return workerPool.encode(
|
|
26
|
+
{
|
|
27
|
+
data: dataCopy,
|
|
28
|
+
width: pdfImage.width,
|
|
29
|
+
height: pdfImage.height
|
|
30
|
+
},
|
|
31
|
+
imageType,
|
|
32
|
+
quality
|
|
33
|
+
);
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
function createHybridImageConverter(workerPool, wasmFallback) {
|
|
37
|
+
return async (getImageData, imageType = "image/webp", quality) => {
|
|
38
|
+
const pdfImage = getImageData();
|
|
39
|
+
try {
|
|
40
|
+
const dataCopy = new Uint8ClampedArray(pdfImage.data);
|
|
41
|
+
return await workerPool.encode(
|
|
42
|
+
{
|
|
43
|
+
data: dataCopy,
|
|
44
|
+
width: pdfImage.width,
|
|
45
|
+
height: pdfImage.height
|
|
46
|
+
},
|
|
47
|
+
imageType,
|
|
48
|
+
quality
|
|
49
|
+
);
|
|
50
|
+
} catch (error) {
|
|
51
|
+
console.warn("Worker pool encoding failed, falling back to WASM:", error);
|
|
52
|
+
return wasmFallback(
|
|
53
|
+
{
|
|
54
|
+
data: pdfImage.data,
|
|
55
|
+
width: pdfImage.width,
|
|
56
|
+
height: pdfImage.height
|
|
57
|
+
},
|
|
58
|
+
imageType,
|
|
59
|
+
quality
|
|
60
|
+
);
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
export {
|
|
65
|
+
OffscreenCanvasError as O,
|
|
66
|
+
createHybridImageConverter as a,
|
|
67
|
+
browserImageDataToBlobConverter as b,
|
|
68
|
+
createWorkerPoolImageConverter as c
|
|
69
|
+
};
|
|
70
|
+
//# sourceMappingURL=browser-Cm3DA8l_.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"browser-Cm3DA8l_.js","sources":["../src/lib/converters/browser.ts"],"sourcesContent":["import type { ImageConversionTypes } from '@embedpdf/models';\nimport type { ImageDataConverter, LazyImageData } from './types';\nimport { ImageEncoderWorkerPool } from '../image-encoder';\n\n// ============================================================================\n// Error Classes\n// ============================================================================\n\nexport class OffscreenCanvasError extends Error {\n constructor(message: string) {\n super(message);\n this.name = 'OffscreenCanvasError';\n }\n}\n\n// ============================================================================\n// Browser Converters\n// ============================================================================\n\n/**\n * Browser-based image converter using OffscreenCanvas in the same thread\n * This is the simplest approach but blocks the thread during encoding\n */\nexport const browserImageDataToBlobConverter: ImageDataConverter<Blob> = (\n getImageData: LazyImageData,\n imageType: ImageConversionTypes = 'image/webp',\n quality?: number,\n): Promise<Blob> => {\n // Check if we're in a browser environment\n if (typeof OffscreenCanvas === 'undefined') {\n return Promise.reject(\n new OffscreenCanvasError(\n 'OffscreenCanvas is not available in this environment. ' +\n 'This converter is intended for browser use only. ' +\n 'Falling back to WASM-based image encoding.',\n ),\n );\n }\n\n const pdfImage = getImageData();\n const imageData = new ImageData(pdfImage.data, pdfImage.width, pdfImage.height);\n const off = new OffscreenCanvas(imageData.width, imageData.height);\n off.getContext('2d')!.putImageData(imageData, 0, 0);\n return off.convertToBlob({ type: imageType, quality });\n};\n\n/**\n * Create an image converter that uses a dedicated worker pool for encoding\n * This prevents blocking the main/PDFium worker thread\n *\n * @param workerPool - Instance of ImageEncoderWorkerPool\n * @returns ImageDataConverter function\n */\nexport function createWorkerPoolImageConverter(\n workerPool: ImageEncoderWorkerPool,\n): ImageDataConverter<Blob> {\n return (\n getImageData: LazyImageData,\n imageType: ImageConversionTypes = 'image/webp',\n quality?: number,\n ): Promise<Blob> => {\n const pdfImage = getImageData();\n\n // Copy the data since we'll transfer it to another worker\n const dataCopy = new Uint8ClampedArray(pdfImage.data);\n\n return workerPool.encode(\n {\n data: dataCopy,\n width: pdfImage.width,\n height: pdfImage.height,\n },\n imageType,\n quality,\n );\n };\n}\n\n/**\n * Hybrid converter: tries worker pool first, falls back to WASM encoding\n * This provides the best performance with graceful degradation\n *\n * @param workerPool - Instance of ImageEncoderWorkerPool\n * @param wasmFallback - WASM-based encoding function\n * @returns ImageDataConverter function\n */\nexport function createHybridImageConverter(\n workerPool: ImageEncoderWorkerPool,\n wasmFallback: (\n imageData: { data: Uint8ClampedArray; width: number; height: number },\n imageType: ImageConversionTypes,\n quality?: number,\n ) => Blob,\n): ImageDataConverter<Blob> {\n return async (\n getImageData: LazyImageData,\n imageType: ImageConversionTypes = 'image/webp',\n quality?: number,\n ): Promise<Blob> => {\n const pdfImage = getImageData();\n\n try {\n // Try worker pool encoding first\n const dataCopy = new Uint8ClampedArray(pdfImage.data);\n return await workerPool.encode(\n {\n data: dataCopy,\n width: pdfImage.width,\n height: pdfImage.height,\n },\n imageType,\n quality,\n );\n } catch (error) {\n // Fallback to WASM encoding\n console.warn('Worker pool encoding failed, falling back to WASM:', error);\n return wasmFallback(\n {\n data: pdfImage.data,\n width: pdfImage.width,\n height: pdfImage.height,\n },\n imageType,\n quality,\n );\n }\n };\n}\n"],"names":[],"mappings":"AAQO,MAAM,6BAA6B,MAAM;AAAA,EAC9C,YAAY,SAAiB;AAC3B,UAAM,OAAO;AACb,SAAK,OAAO;AAAA,EACd;AACF;AAUO,MAAM,kCAA4D,CACvE,cACA,YAAkC,cAClC,YACkB;AAElB,MAAI,OAAO,oBAAoB,aAAa;AAC1C,WAAO,QAAQ;AAAA,MACb,IAAI;AAAA,QACF;AAAA,MAAA;AAAA,IAGF;AAAA,EAEJ;AAEA,QAAM,WAAW,aAAA;AACjB,QAAM,YAAY,IAAI,UAAU,SAAS,MAAM,SAAS,OAAO,SAAS,MAAM;AAC9E,QAAM,MAAM,IAAI,gBAAgB,UAAU,OAAO,UAAU,MAAM;AACjE,MAAI,WAAW,IAAI,EAAG,aAAa,WAAW,GAAG,CAAC;AAClD,SAAO,IAAI,cAAc,EAAE,MAAM,WAAW,SAAS;AACvD;AASO,SAAS,+BACd,YAC0B;AAC1B,SAAO,CACL,cACA,YAAkC,cAClC,YACkB;AAClB,UAAM,WAAW,aAAA;AAGjB,UAAM,WAAW,IAAI,kBAAkB,SAAS,IAAI;AAEpD,WAAO,WAAW;AAAA,MAChB;AAAA,QACE,MAAM;AAAA,QACN,OAAO,SAAS;AAAA,QAChB,QAAQ,SAAS;AAAA,MAAA;AAAA,MAEnB;AAAA,MACA;AAAA,IAAA;AAAA,EAEJ;AACF;AAUO,SAAS,2BACd,YACA,cAK0B;AAC1B,SAAO,OACL,cACA,YAAkC,cAClC,YACkB;AAClB,UAAM,WAAW,aAAA;AAEjB,QAAI;AAEF,YAAM,WAAW,IAAI,kBAAkB,SAAS,IAAI;AACpD,aAAO,MAAM,WAAW;AAAA,QACtB;AAAA,UACE,MAAM;AAAA,UACN,OAAO,SAAS;AAAA,UAChB,QAAQ,SAAS;AAAA,QAAA;AAAA,QAEnB;AAAA,QACA;AAAA,MAAA;AAAA,IAEJ,SAAS,OAAO;AAEd,cAAQ,KAAK,sDAAsD,KAAK;AACxE,aAAO;AAAA,QACL;AAAA,UACE,MAAM,SAAS;AAAA,UACf,OAAO,SAAS;AAAA,UAChB,QAAQ,SAAS;AAAA,QAAA;AAAA,QAEnB;AAAA,QACA;AAAA,MAAA;AAAA,IAEJ;AAAA,EACF;AACF;"}
|