@embedpdf/engines 1.3.16 → 1.4.0

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.
@@ -333,10 +333,10 @@ class PdfiumEngineRunner extends EngineRunner {
333
333
  this.ready();
334
334
  }
335
335
  }
336
- const DEFAULT_PDFIUM_WASM_URL = "https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.3.16/dist/pdfium.wasm";
336
+ const DEFAULT_PDFIUM_WASM_URL = "https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.4.0/dist/pdfium.wasm";
337
337
  export {
338
338
  DEFAULT_PDFIUM_WASM_URL as D,
339
339
  EngineRunner as E,
340
340
  PdfiumEngineRunner as P
341
341
  };
342
- //# sourceMappingURL=index-Xn48Fdud.js.map
342
+ //# sourceMappingURL=index-BSQFIEHs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-Xn48Fdud.js","sources":["../src/lib/webworker/runner.ts","../src/lib/pdfium/runner.ts","../src/lib/pdfium/index.ts"],"sourcesContent":["import {\n Logger,\n NoopLogger,\n PdfEngine,\n PdfEngineError,\n PdfEngineMethodArgs,\n PdfEngineMethodName,\n PdfEngineMethodReturnType,\n PdfErrorCode,\n Task,\n TaskReturn,\n} from '@embedpdf/models';\n\n/**\n * Request body that represent method calls of PdfEngine, it contains the\n * method name and arguments\n */\nexport type PdfEngineMethodRequestBody = {\n [P in PdfEngineMethodName]: {\n name: P;\n args: PdfEngineMethodArgs<P>;\n };\n}[PdfEngineMethodName];\n\n/**\n * Request body that represent method calls of PdfEngine, it contains the\n * method name and arguments\n */\nexport type SpecificExecuteRequest<M extends PdfEngineMethodName> = {\n id: string;\n type: 'ExecuteRequest';\n data: {\n name: M;\n args: PdfEngineMethodArgs<M>;\n };\n};\n\n/**\n * Response body that represent return value of PdfEngine\n */\nexport type PdfEngineMethodResponseBody = {\n [P in PdfEngineMethodName]: TaskReturn<PdfEngineMethodReturnType<P>>;\n}[PdfEngineMethodName];\n\n/**\n * Request that abort the specified task\n */\nexport interface AbortRequest {\n /**\n * message id\n */\n id: string;\n /**\n * request type\n */\n type: 'AbortRequest';\n}\n/**\n * Request that execute pdf engine method\n */\nexport interface ExecuteRequest {\n /**\n * message id\n */\n id: string;\n /**\n * request type\n */\n type: 'ExecuteRequest';\n /**\n * request body\n */\n data: PdfEngineMethodRequestBody;\n}\n/**\n * Response that execute pdf engine method\n */\nexport interface ExecuteResponse {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ExecuteResponse';\n /**\n * response body\n */\n data: PdfEngineMethodResponseBody;\n}\n\n/**\n * Response that indicate progress of the task\n */\nexport interface ExecuteProgress<T = unknown> {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ExecuteProgress';\n /**\n * response body\n */\n data: T;\n}\n\n/**\n * Response that indicate engine is ready\n */\nexport interface ReadyResponse {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ReadyResponse';\n}\n\n/**\n * Request type\n */\nexport type Request = ExecuteRequest | AbortRequest;\n/**\n * Response type\n */\nexport type Response = ExecuteResponse | ReadyResponse | ExecuteProgress;\n\nconst LOG_SOURCE = 'WebWorkerEngineRunner';\nconst LOG_CATEGORY = 'Engine';\n\n/**\n * Pdf engine runner, it will execute pdf engine based on the request it received and\n * send back the response with post message\n */\nexport class EngineRunner {\n engine: PdfEngine | undefined;\n\n /** All running tasks, keyed by the message-id coming from the UI */\n private tasks = new Map<string, Task<any, any>>();\n\n /**\n * Last time we yielded to the event loop\n */\n private lastYield = 0;\n /**\n * Ids of tasks that have been cancelled\n */\n private cancelledIds = new Set<string>();\n\n /**\n * Create instance of EngineRunnder\n * @param logger - logger instance\n */\n constructor(public logger: Logger = new NoopLogger()) {}\n\n /**\n * Listening on post message\n */\n listen() {\n self.onmessage = (evt: MessageEvent<Request>) => {\n return this.handle(evt);\n };\n }\n\n /**\n * Handle post message\n */\n handle(evt: MessageEvent<Request>) {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'webworker receive message event: ', evt.data);\n try {\n const request = evt.data as Request;\n switch (request.type) {\n case 'ExecuteRequest':\n this.execute(request);\n break;\n case 'AbortRequest':\n this.abort(request);\n break;\n }\n } catch (e) {\n this.logger.info(\n LOG_SOURCE,\n LOG_CATEGORY,\n 'webworker met error when processing message event:',\n e,\n );\n }\n }\n\n /**\n * Send the ready response when pdf engine is ready\n * @returns\n *\n * @protected\n */\n ready() {\n this.listen();\n\n this.respond({\n id: '0',\n type: 'ReadyResponse',\n });\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner is ready');\n }\n\n private abort(request: AbortRequest) {\n const t = this.tasks.get(request.id);\n\n // Always record the abort id\n this.cancelledIds.add(request.id);\n\n if (!t) {\n // nothing to cancel (already finished or wrong id) – just ignore\n return;\n }\n\n t.abort({\n code: PdfErrorCode.Cancelled,\n message: 'aborted by client',\n });\n\n // we won’t hear from that task again\n this.tasks.delete(request.id);\n }\n\n private async maybeYield() {\n const now = performance.now();\n // give the event loop a breath roughly every ~8ms (tune as you like)\n if (now - this.lastYield > 8) {\n await new Promise((r) => setTimeout(r, 0));\n this.lastYield = performance.now();\n }\n }\n\n /**\n * Execute the request\n * @param request - request that represent the pdf engine call\n * @returns\n *\n * @protected\n */\n execute = async (request: ExecuteRequest) => {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner start exeucte request');\n if (!this.engine) {\n const error: PdfEngineError = {\n type: 'reject',\n reason: {\n code: PdfErrorCode.NotReady,\n message: 'engine has not started yet',\n },\n };\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n return;\n }\n\n // let AbortRequest messages land and pre-cancel flags get set\n await this.maybeYield();\n\n if (this.cancelledIds.has(request.id)) {\n this.respond({\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: {\n type: 'reject',\n reason: { code: PdfErrorCode.Cancelled, message: 'aborted by client (pre-cancelled)' },\n },\n },\n });\n return;\n }\n\n const engine = this.engine;\n const { name, args } = request.data;\n if (!engine[name]) {\n const error: PdfEngineError = {\n type: 'reject',\n reason: {\n code: PdfErrorCode.NotSupport,\n message: `engine method ${name} is not supported yet`,\n },\n };\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n return;\n }\n\n let task: PdfEngineMethodReturnType<typeof name>;\n switch (name) {\n case 'isSupport':\n task = this.engine[name]!(...args);\n break;\n case 'initialize':\n task = this.engine[name]!(...args);\n break;\n case 'destroy':\n task = this.engine[name]!(...args);\n break;\n case 'openDocumentUrl':\n task = this.engine[name]!(...args);\n break;\n case 'openDocumentBuffer':\n task = this.engine[name]!(...args);\n break;\n case 'getDocPermissions':\n task = this.engine[name]!(...args);\n break;\n case 'getDocUserPermissions':\n task = this.engine[name]!(...args);\n break;\n case 'getMetadata':\n task = this.engine[name]!(...args);\n break;\n case 'setMetadata':\n task = this.engine[name]!(...args);\n break;\n case 'getBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'setBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'deleteBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'getSignatures':\n task = this.engine[name]!(...args);\n break;\n case 'renderPage':\n task = this.engine[name]!(...args);\n break;\n case 'renderPageRect':\n task = this.engine[name]!(...args);\n break;\n case 'renderPageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'renderThumbnail':\n task = this.engine[name]!(...args);\n break;\n case 'getAllAnnotations':\n task = this.engine[name]!(...args);\n break;\n case 'getPageAnnotations':\n task = this.engine[name]!(...args);\n break;\n case 'createPageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'updatePageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'removePageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'getPageTextRects':\n task = this.engine[name]!(...args);\n break;\n case 'searchAllPages':\n task = this.engine[name]!(...args);\n break;\n case 'closeDocument':\n task = this.engine[name]!(...args);\n break;\n case 'closeAllDocuments':\n task = this.engine[name]!(...args);\n break;\n case 'saveAsCopy':\n task = this.engine[name]!(...args);\n break;\n case 'getAttachments':\n task = this.engine[name]!(...args);\n break;\n case 'addAttachment':\n task = this.engine[name]!(...args);\n break;\n case 'removeAttachment':\n task = this.engine[name]!(...args);\n break;\n case 'readAttachmentContent':\n task = this.engine[name]!(...args);\n break;\n case 'setFormFieldValue':\n task = this.engine[name]!(...args);\n break;\n case 'flattenPage':\n task = this.engine[name]!(...args);\n break;\n case 'extractPages':\n task = this.engine[name]!(...args);\n break;\n case 'extractText':\n task = this.engine[name]!(...args);\n break;\n case 'redactTextInRects':\n task = this.engine[name]!(...args);\n break;\n case 'getTextSlices':\n task = this.engine[name]!(...args);\n break;\n case 'getPageGlyphs':\n task = this.engine[name]!(...args);\n break;\n case 'getPageGeometry':\n task = this.engine[name]!(...args);\n break;\n case 'merge':\n task = this.engine[name]!(...args);\n break;\n case 'mergePages':\n task = this.engine[name]!(...args);\n break;\n case 'preparePrintDocument':\n task = this.engine[name]!(...args);\n break;\n }\n\n this.tasks.set(request.id, task);\n\n task.onProgress((progress) => {\n const response: ExecuteProgress = {\n id: request.id,\n type: 'ExecuteProgress',\n data: progress,\n };\n this.respond(response);\n });\n\n task.wait(\n (result) => {\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'result',\n value: result,\n },\n };\n this.respond(response);\n this.tasks.delete(request.id);\n this.cancelledIds.delete(request.id);\n },\n (error) => {\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n this.tasks.delete(request.id);\n this.cancelledIds.delete(request.id);\n },\n );\n };\n\n /**\n * Send back the response\n * @param response - response that needs sent back\n *\n * @protected\n */\n respond(response: Response) {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner respond: ', response);\n self.postMessage(response);\n }\n}\n","import { init } from '@embedpdf/pdfium';\nimport { EngineRunner } from '../webworker/runner';\nimport { PdfiumEngine } from './engine';\nimport { Logger } from '@embedpdf/models';\n\n/**\n * EngineRunner for pdfium-based wasm engine\n */\nexport class PdfiumEngineRunner extends EngineRunner {\n /**\n * Create an instance of PdfiumEngineRunner\n * @param wasmBinary - wasm binary that contains the pdfium wasm file\n */\n constructor(\n private wasmBinary: ArrayBuffer,\n logger?: Logger,\n ) {\n super(logger);\n }\n\n /**\n * Initialize runner\n */\n async prepare() {\n const wasmBinary = this.wasmBinary;\n const wasmModule = await init({ wasmBinary });\n this.engine = new PdfiumEngine(wasmModule, { logger: this.logger });\n this.ready();\n }\n}\n","export * from './engine';\nexport * from './helper';\nexport * from './runner';\n\nexport const DEFAULT_PDFIUM_WASM_URL: string =\n 'https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm';\n"],"names":[],"mappings":";;;AAqIA,MAAM,aAAa;AACnB,MAAM,eAAe;AAMd,MAAM,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,EAmBxB,YAAmB,SAAiB,IAAI,cAAc;AAAnC,SAAA,SAAA;AAfX,SAAA,4BAAY,IAA4B;AAKhD,SAAQ,YAAY;AAIZ,SAAA,mCAAmB,IAAY;AA8FvC,SAAA,UAAU,OAAO,YAA4B;AAC3C,WAAK,OAAO,MAAM,YAAY,cAAc,8BAA8B;AACtE,UAAA,CAAC,KAAK,QAAQ;AAChB,cAAM,QAAwB;AAAA,UAC5B,MAAM;AAAA,UACN,QAAQ;AAAA,YACN,MAAM,aAAa;AAAA,YACnB,SAAS;AAAA,UAAA;AAAA,QAEb;AACA,cAAM,WAA4B;AAAA,UAChC,IAAI,QAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,OAAO;AAAA,UAAA;AAAA,QAEX;AACA,aAAK,QAAQ,QAAQ;AACrB;AAAA,MAAA;AAIF,YAAM,KAAK,WAAW;AAEtB,UAAI,KAAK,aAAa,IAAI,QAAQ,EAAE,GAAG;AACrC,aAAK,QAAQ;AAAA,UACX,IAAI,QAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,OAAO;AAAA,cACL,MAAM;AAAA,cACN,QAAQ,EAAE,MAAM,aAAa,WAAW,SAAS,oCAAoC;AAAA,YAAA;AAAA,UACvF;AAAA,QACF,CACD;AACD;AAAA,MAAA;AAGF,YAAM,SAAS,KAAK;AACpB,YAAM,EAAE,MAAM,KAAK,IAAI,QAAQ;AAC3B,UAAA,CAAC,OAAO,IAAI,GAAG;AACjB,cAAM,QAAwB;AAAA,UAC5B,MAAM;AAAA,UACN,QAAQ;AAAA,YACN,MAAM,aAAa;AAAA,YACnB,SAAS,iBAAiB,IAAI;AAAA,UAAA;AAAA,QAElC;AACA,cAAM,WAA4B;AAAA,UAChC,IAAI,QAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,OAAO;AAAA,UAAA;AAAA,QAEX;AACA,aAAK,QAAQ,QAAQ;AACrB;AAAA,MAAA;AAGE,UAAA;AACJ,cAAQ,MAAM;AAAA,QACZ,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,MAAA;AAGJ,WAAK,MAAM,IAAI,QAAQ,IAAI,IAAI;AAE1B,WAAA,WAAW,CAAC,aAAa;AAC5B,cAAM,WAA4B;AAAA,UAChC,IAAI,QAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM;AAAA,QACR;AACA,aAAK,QAAQ,QAAQ;AAAA,MAAA,CACtB;AAEI,WAAA;AAAA,QACH,CAAC,WAAW;AACV,gBAAM,WAA4B;AAAA,YAChC,IAAI,QAAQ;AAAA,YACZ,MAAM;AAAA,YACN,MAAM;AAAA,cACJ,MAAM;AAAA,cACN,OAAO;AAAA,YAAA;AAAA,UAEX;AACA,eAAK,QAAQ,QAAQ;AAChB,eAAA,MAAM,OAAO,QAAQ,EAAE;AACvB,eAAA,aAAa,OAAO,QAAQ,EAAE;AAAA,QACrC;AAAA,QACA,CAAC,UAAU;AACT,gBAAM,WAA4B;AAAA,YAChC,IAAI,QAAQ;AAAA,YACZ,MAAM;AAAA,YACN,MAAM;AAAA,cACJ,MAAM;AAAA,cACN,OAAO;AAAA,YAAA;AAAA,UAEX;AACA,eAAK,QAAQ,QAAQ;AAChB,eAAA,MAAM,OAAO,QAAQ,EAAE;AACvB,eAAA,aAAa,OAAO,QAAQ,EAAE;AAAA,QAAA;AAAA,MAEvC;AAAA,IACF;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EA1TA,SAAS;AACF,SAAA,YAAY,CAAC,QAA+B;AACxC,aAAA,KAAK,OAAO,GAAG;AAAA,IACxB;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EAMF,OAAO,KAA4B;AACjC,SAAK,OAAO,MAAM,YAAY,cAAc,qCAAqC,IAAI,IAAI;AACrF,QAAA;AACF,YAAM,UAAU,IAAI;AACpB,cAAQ,QAAQ,MAAM;AAAA,QACpB,KAAK;AACH,eAAK,QAAQ,OAAO;AACpB;AAAA,QACF,KAAK;AACH,eAAK,MAAM,OAAO;AAClB;AAAA,MAAA;AAAA,aAEG,GAAG;AACV,WAAK,OAAO;AAAA,QACV;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,IAAA;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASF,QAAQ;AACN,SAAK,OAAO;AAEZ,SAAK,QAAQ;AAAA,MACX,IAAI;AAAA,MACJ,MAAM;AAAA,IAAA,CACP;AACD,SAAK,OAAO,MAAM,YAAY,cAAc,iBAAiB;AAAA,EAAA;AAAA,EAGvD,MAAM,SAAuB;AACnC,UAAM,IAAI,KAAK,MAAM,IAAI,QAAQ,EAAE;AAG9B,SAAA,aAAa,IAAI,QAAQ,EAAE;AAEhC,QAAI,CAAC,GAAG;AAEN;AAAA,IAAA;AAGF,MAAE,MAAM;AAAA,MACN,MAAM,aAAa;AAAA,MACnB,SAAS;AAAA,IAAA,CACV;AAGI,SAAA,MAAM,OAAO,QAAQ,EAAE;AAAA,EAAA;AAAA,EAG9B,MAAc,aAAa;AACnB,UAAA,MAAM,YAAY,IAAI;AAExB,QAAA,MAAM,KAAK,YAAY,GAAG;AAC5B,YAAM,IAAI,QAAQ,CAAC,MAAM,WAAW,GAAG,CAAC,CAAC;AACpC,WAAA,YAAY,YAAY,IAAI;AAAA,IAAA;AAAA,EACnC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAyPF,QAAQ,UAAoB;AAC1B,SAAK,OAAO,MAAM,YAAY,cAAc,oBAAoB,QAAQ;AACxE,SAAK,YAAY,QAAQ;AAAA,EAAA;AAE7B;ACleO,MAAM,2BAA2B,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,EAKnD,YACU,YACR,QACA;AACA,UAAM,MAAM;AAHJ,SAAA,aAAA;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EASV,MAAM,UAAU;AACd,UAAM,aAAa,KAAK;AACxB,UAAM,aAAa,MAAM,KAAK,EAAE,YAAY;AACvC,SAAA,SAAS,IAAI,aAAa,YAAY,EAAE,QAAQ,KAAK,QAAQ;AAClE,SAAK,MAAM;AAAA,EAAA;AAEf;ACzBO,MAAM,0BACX;"}
1
+ {"version":3,"file":"index-BSQFIEHs.js","sources":["../src/lib/webworker/runner.ts","../src/lib/pdfium/runner.ts","../src/lib/pdfium/index.ts"],"sourcesContent":["import {\n Logger,\n NoopLogger,\n PdfEngine,\n PdfEngineError,\n PdfEngineMethodArgs,\n PdfEngineMethodName,\n PdfEngineMethodReturnType,\n PdfErrorCode,\n Task,\n TaskReturn,\n} from '@embedpdf/models';\n\n/**\n * Request body that represent method calls of PdfEngine, it contains the\n * method name and arguments\n */\nexport type PdfEngineMethodRequestBody = {\n [P in PdfEngineMethodName]: {\n name: P;\n args: PdfEngineMethodArgs<P>;\n };\n}[PdfEngineMethodName];\n\n/**\n * Request body that represent method calls of PdfEngine, it contains the\n * method name and arguments\n */\nexport type SpecificExecuteRequest<M extends PdfEngineMethodName> = {\n id: string;\n type: 'ExecuteRequest';\n data: {\n name: M;\n args: PdfEngineMethodArgs<M>;\n };\n};\n\n/**\n * Response body that represent return value of PdfEngine\n */\nexport type PdfEngineMethodResponseBody = {\n [P in PdfEngineMethodName]: TaskReturn<PdfEngineMethodReturnType<P>>;\n}[PdfEngineMethodName];\n\n/**\n * Request that abort the specified task\n */\nexport interface AbortRequest {\n /**\n * message id\n */\n id: string;\n /**\n * request type\n */\n type: 'AbortRequest';\n}\n/**\n * Request that execute pdf engine method\n */\nexport interface ExecuteRequest {\n /**\n * message id\n */\n id: string;\n /**\n * request type\n */\n type: 'ExecuteRequest';\n /**\n * request body\n */\n data: PdfEngineMethodRequestBody;\n}\n/**\n * Response that execute pdf engine method\n */\nexport interface ExecuteResponse {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ExecuteResponse';\n /**\n * response body\n */\n data: PdfEngineMethodResponseBody;\n}\n\n/**\n * Response that indicate progress of the task\n */\nexport interface ExecuteProgress<T = unknown> {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ExecuteProgress';\n /**\n * response body\n */\n data: T;\n}\n\n/**\n * Response that indicate engine is ready\n */\nexport interface ReadyResponse {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ReadyResponse';\n}\n\n/**\n * Request type\n */\nexport type Request = ExecuteRequest | AbortRequest;\n/**\n * Response type\n */\nexport type Response = ExecuteResponse | ReadyResponse | ExecuteProgress;\n\nconst LOG_SOURCE = 'WebWorkerEngineRunner';\nconst LOG_CATEGORY = 'Engine';\n\n/**\n * Pdf engine runner, it will execute pdf engine based on the request it received and\n * send back the response with post message\n */\nexport class EngineRunner {\n engine: PdfEngine | undefined;\n\n /** All running tasks, keyed by the message-id coming from the UI */\n private tasks = new Map<string, Task<any, any>>();\n\n /**\n * Last time we yielded to the event loop\n */\n private lastYield = 0;\n /**\n * Ids of tasks that have been cancelled\n */\n private cancelledIds = new Set<string>();\n\n /**\n * Create instance of EngineRunnder\n * @param logger - logger instance\n */\n constructor(public logger: Logger = new NoopLogger()) {}\n\n /**\n * Listening on post message\n */\n listen() {\n self.onmessage = (evt: MessageEvent<Request>) => {\n return this.handle(evt);\n };\n }\n\n /**\n * Handle post message\n */\n handle(evt: MessageEvent<Request>) {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'webworker receive message event: ', evt.data);\n try {\n const request = evt.data as Request;\n switch (request.type) {\n case 'ExecuteRequest':\n this.execute(request);\n break;\n case 'AbortRequest':\n this.abort(request);\n break;\n }\n } catch (e) {\n this.logger.info(\n LOG_SOURCE,\n LOG_CATEGORY,\n 'webworker met error when processing message event:',\n e,\n );\n }\n }\n\n /**\n * Send the ready response when pdf engine is ready\n * @returns\n *\n * @protected\n */\n ready() {\n this.listen();\n\n this.respond({\n id: '0',\n type: 'ReadyResponse',\n });\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner is ready');\n }\n\n private abort(request: AbortRequest) {\n const t = this.tasks.get(request.id);\n\n // Always record the abort id\n this.cancelledIds.add(request.id);\n\n if (!t) {\n // nothing to cancel (already finished or wrong id) – just ignore\n return;\n }\n\n t.abort({\n code: PdfErrorCode.Cancelled,\n message: 'aborted by client',\n });\n\n // we won’t hear from that task again\n this.tasks.delete(request.id);\n }\n\n private async maybeYield() {\n const now = performance.now();\n // give the event loop a breath roughly every ~8ms (tune as you like)\n if (now - this.lastYield > 8) {\n await new Promise((r) => setTimeout(r, 0));\n this.lastYield = performance.now();\n }\n }\n\n /**\n * Execute the request\n * @param request - request that represent the pdf engine call\n * @returns\n *\n * @protected\n */\n execute = async (request: ExecuteRequest) => {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner start exeucte request');\n if (!this.engine) {\n const error: PdfEngineError = {\n type: 'reject',\n reason: {\n code: PdfErrorCode.NotReady,\n message: 'engine has not started yet',\n },\n };\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n return;\n }\n\n // let AbortRequest messages land and pre-cancel flags get set\n await this.maybeYield();\n\n if (this.cancelledIds.has(request.id)) {\n this.respond({\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: {\n type: 'reject',\n reason: { code: PdfErrorCode.Cancelled, message: 'aborted by client (pre-cancelled)' },\n },\n },\n });\n return;\n }\n\n const engine = this.engine;\n const { name, args } = request.data;\n if (!engine[name]) {\n const error: PdfEngineError = {\n type: 'reject',\n reason: {\n code: PdfErrorCode.NotSupport,\n message: `engine method ${name} is not supported yet`,\n },\n };\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n return;\n }\n\n let task: PdfEngineMethodReturnType<typeof name>;\n switch (name) {\n case 'isSupport':\n task = this.engine[name]!(...args);\n break;\n case 'initialize':\n task = this.engine[name]!(...args);\n break;\n case 'destroy':\n task = this.engine[name]!(...args);\n break;\n case 'openDocumentUrl':\n task = this.engine[name]!(...args);\n break;\n case 'openDocumentBuffer':\n task = this.engine[name]!(...args);\n break;\n case 'getDocPermissions':\n task = this.engine[name]!(...args);\n break;\n case 'getDocUserPermissions':\n task = this.engine[name]!(...args);\n break;\n case 'getMetadata':\n task = this.engine[name]!(...args);\n break;\n case 'setMetadata':\n task = this.engine[name]!(...args);\n break;\n case 'getBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'setBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'deleteBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'getSignatures':\n task = this.engine[name]!(...args);\n break;\n case 'renderPage':\n task = this.engine[name]!(...args);\n break;\n case 'renderPageRect':\n task = this.engine[name]!(...args);\n break;\n case 'renderPageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'renderThumbnail':\n task = this.engine[name]!(...args);\n break;\n case 'getAllAnnotations':\n task = this.engine[name]!(...args);\n break;\n case 'getPageAnnotations':\n task = this.engine[name]!(...args);\n break;\n case 'createPageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'updatePageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'removePageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'getPageTextRects':\n task = this.engine[name]!(...args);\n break;\n case 'searchAllPages':\n task = this.engine[name]!(...args);\n break;\n case 'closeDocument':\n task = this.engine[name]!(...args);\n break;\n case 'closeAllDocuments':\n task = this.engine[name]!(...args);\n break;\n case 'saveAsCopy':\n task = this.engine[name]!(...args);\n break;\n case 'getAttachments':\n task = this.engine[name]!(...args);\n break;\n case 'addAttachment':\n task = this.engine[name]!(...args);\n break;\n case 'removeAttachment':\n task = this.engine[name]!(...args);\n break;\n case 'readAttachmentContent':\n task = this.engine[name]!(...args);\n break;\n case 'setFormFieldValue':\n task = this.engine[name]!(...args);\n break;\n case 'flattenPage':\n task = this.engine[name]!(...args);\n break;\n case 'extractPages':\n task = this.engine[name]!(...args);\n break;\n case 'extractText':\n task = this.engine[name]!(...args);\n break;\n case 'redactTextInRects':\n task = this.engine[name]!(...args);\n break;\n case 'getTextSlices':\n task = this.engine[name]!(...args);\n break;\n case 'getPageGlyphs':\n task = this.engine[name]!(...args);\n break;\n case 'getPageGeometry':\n task = this.engine[name]!(...args);\n break;\n case 'merge':\n task = this.engine[name]!(...args);\n break;\n case 'mergePages':\n task = this.engine[name]!(...args);\n break;\n case 'preparePrintDocument':\n task = this.engine[name]!(...args);\n break;\n }\n\n this.tasks.set(request.id, task);\n\n task.onProgress((progress) => {\n const response: ExecuteProgress = {\n id: request.id,\n type: 'ExecuteProgress',\n data: progress,\n };\n this.respond(response);\n });\n\n task.wait(\n (result) => {\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'result',\n value: result,\n },\n };\n this.respond(response);\n this.tasks.delete(request.id);\n this.cancelledIds.delete(request.id);\n },\n (error) => {\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n this.tasks.delete(request.id);\n this.cancelledIds.delete(request.id);\n },\n );\n };\n\n /**\n * Send back the response\n * @param response - response that needs sent back\n *\n * @protected\n */\n respond(response: Response) {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner respond: ', response);\n self.postMessage(response);\n }\n}\n","import { init } from '@embedpdf/pdfium';\nimport { EngineRunner } from '../webworker/runner';\nimport { PdfiumEngine } from './engine';\nimport { Logger } from '@embedpdf/models';\n\n/**\n * EngineRunner for pdfium-based wasm engine\n */\nexport class PdfiumEngineRunner extends EngineRunner {\n /**\n * Create an instance of PdfiumEngineRunner\n * @param wasmBinary - wasm binary that contains the pdfium wasm file\n */\n constructor(\n private wasmBinary: ArrayBuffer,\n logger?: Logger,\n ) {\n super(logger);\n }\n\n /**\n * Initialize runner\n */\n async prepare() {\n const wasmBinary = this.wasmBinary;\n const wasmModule = await init({ wasmBinary });\n this.engine = new PdfiumEngine(wasmModule, { logger: this.logger });\n this.ready();\n }\n}\n","export * from './engine';\nexport * from './helper';\nexport * from './runner';\n\nexport const DEFAULT_PDFIUM_WASM_URL: string =\n 'https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm';\n"],"names":[],"mappings":";;;AAqIA,MAAM,aAAa;AACnB,MAAM,eAAe;AAMd,MAAM,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,EAmBxB,YAAmB,SAAiB,IAAI,cAAc;AAAnC,SAAA,SAAA;AAfX,SAAA,4BAAY,IAA4B;AAKhD,SAAQ,YAAY;AAIZ,SAAA,mCAAmB,IAAY;AA8FvC,SAAA,UAAU,OAAO,YAA4B;AAC3C,WAAK,OAAO,MAAM,YAAY,cAAc,8BAA8B;AACtE,UAAA,CAAC,KAAK,QAAQ;AAChB,cAAM,QAAwB;AAAA,UAC5B,MAAM;AAAA,UACN,QAAQ;AAAA,YACN,MAAM,aAAa;AAAA,YACnB,SAAS;AAAA,UAAA;AAAA,QAEb;AACA,cAAM,WAA4B;AAAA,UAChC,IAAI,QAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,OAAO;AAAA,UAAA;AAAA,QAEX;AACA,aAAK,QAAQ,QAAQ;AACrB;AAAA,MAAA;AAIF,YAAM,KAAK,WAAW;AAEtB,UAAI,KAAK,aAAa,IAAI,QAAQ,EAAE,GAAG;AACrC,aAAK,QAAQ;AAAA,UACX,IAAI,QAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,OAAO;AAAA,cACL,MAAM;AAAA,cACN,QAAQ,EAAE,MAAM,aAAa,WAAW,SAAS,oCAAoC;AAAA,YAAA;AAAA,UACvF;AAAA,QACF,CACD;AACD;AAAA,MAAA;AAGF,YAAM,SAAS,KAAK;AACpB,YAAM,EAAE,MAAM,KAAK,IAAI,QAAQ;AAC3B,UAAA,CAAC,OAAO,IAAI,GAAG;AACjB,cAAM,QAAwB;AAAA,UAC5B,MAAM;AAAA,UACN,QAAQ;AAAA,YACN,MAAM,aAAa;AAAA,YACnB,SAAS,iBAAiB,IAAI;AAAA,UAAA;AAAA,QAElC;AACA,cAAM,WAA4B;AAAA,UAChC,IAAI,QAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM;AAAA,YACJ,MAAM;AAAA,YACN,OAAO;AAAA,UAAA;AAAA,QAEX;AACA,aAAK,QAAQ,QAAQ;AACrB;AAAA,MAAA;AAGE,UAAA;AACJ,cAAQ,MAAM;AAAA,QACZ,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,QACF,KAAK;AACH,iBAAO,KAAK,OAAO,IAAI,EAAG,GAAG,IAAI;AACjC;AAAA,MAAA;AAGJ,WAAK,MAAM,IAAI,QAAQ,IAAI,IAAI;AAE1B,WAAA,WAAW,CAAC,aAAa;AAC5B,cAAM,WAA4B;AAAA,UAChC,IAAI,QAAQ;AAAA,UACZ,MAAM;AAAA,UACN,MAAM;AAAA,QACR;AACA,aAAK,QAAQ,QAAQ;AAAA,MAAA,CACtB;AAEI,WAAA;AAAA,QACH,CAAC,WAAW;AACV,gBAAM,WAA4B;AAAA,YAChC,IAAI,QAAQ;AAAA,YACZ,MAAM;AAAA,YACN,MAAM;AAAA,cACJ,MAAM;AAAA,cACN,OAAO;AAAA,YAAA;AAAA,UAEX;AACA,eAAK,QAAQ,QAAQ;AAChB,eAAA,MAAM,OAAO,QAAQ,EAAE;AACvB,eAAA,aAAa,OAAO,QAAQ,EAAE;AAAA,QACrC;AAAA,QACA,CAAC,UAAU;AACT,gBAAM,WAA4B;AAAA,YAChC,IAAI,QAAQ;AAAA,YACZ,MAAM;AAAA,YACN,MAAM;AAAA,cACJ,MAAM;AAAA,cACN,OAAO;AAAA,YAAA;AAAA,UAEX;AACA,eAAK,QAAQ,QAAQ;AAChB,eAAA,MAAM,OAAO,QAAQ,EAAE;AACvB,eAAA,aAAa,OAAO,QAAQ,EAAE;AAAA,QAAA;AAAA,MAEvC;AAAA,IACF;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EA1TA,SAAS;AACF,SAAA,YAAY,CAAC,QAA+B;AACxC,aAAA,KAAK,OAAO,GAAG;AAAA,IACxB;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EAMF,OAAO,KAA4B;AACjC,SAAK,OAAO,MAAM,YAAY,cAAc,qCAAqC,IAAI,IAAI;AACrF,QAAA;AACF,YAAM,UAAU,IAAI;AACpB,cAAQ,QAAQ,MAAM;AAAA,QACpB,KAAK;AACH,eAAK,QAAQ,OAAO;AACpB;AAAA,QACF,KAAK;AACH,eAAK,MAAM,OAAO;AAClB;AAAA,MAAA;AAAA,aAEG,GAAG;AACV,WAAK,OAAO;AAAA,QACV;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,IAAA;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASF,QAAQ;AACN,SAAK,OAAO;AAEZ,SAAK,QAAQ;AAAA,MACX,IAAI;AAAA,MACJ,MAAM;AAAA,IAAA,CACP;AACD,SAAK,OAAO,MAAM,YAAY,cAAc,iBAAiB;AAAA,EAAA;AAAA,EAGvD,MAAM,SAAuB;AACnC,UAAM,IAAI,KAAK,MAAM,IAAI,QAAQ,EAAE;AAG9B,SAAA,aAAa,IAAI,QAAQ,EAAE;AAEhC,QAAI,CAAC,GAAG;AAEN;AAAA,IAAA;AAGF,MAAE,MAAM;AAAA,MACN,MAAM,aAAa;AAAA,MACnB,SAAS;AAAA,IAAA,CACV;AAGI,SAAA,MAAM,OAAO,QAAQ,EAAE;AAAA,EAAA;AAAA,EAG9B,MAAc,aAAa;AACnB,UAAA,MAAM,YAAY,IAAI;AAExB,QAAA,MAAM,KAAK,YAAY,GAAG;AAC5B,YAAM,IAAI,QAAQ,CAAC,MAAM,WAAW,GAAG,CAAC,CAAC;AACpC,WAAA,YAAY,YAAY,IAAI;AAAA,IAAA;AAAA,EACnC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAyPF,QAAQ,UAAoB;AAC1B,SAAK,OAAO,MAAM,YAAY,cAAc,oBAAoB,QAAQ;AACxE,SAAK,YAAY,QAAQ;AAAA,EAAA;AAE7B;ACleO,MAAM,2BAA2B,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA,EAKnD,YACU,YACR,QACA;AACA,UAAM,MAAM;AAHJ,SAAA,aAAA;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EASV,MAAM,UAAU;AACd,UAAM,aAAa,KAAK;AACxB,UAAM,aAAa,MAAM,KAAK,EAAE,YAAY;AACvC,SAAA,SAAS,IAAI,aAAa,YAAY,EAAE,QAAQ,KAAK,QAAQ;AAClE,SAAK,MAAM;AAAA,EAAA;AAEf;ACzBO,MAAM,0BACX;"}
@@ -1,2 +1,2 @@
1
- "use strict";const e=require("./engine-Z4iXwySK.cjs"),s=require("@embedpdf/pdfium"),t=require("@embedpdf/models"),a="WebWorkerEngineRunner",r="Engine";class n{constructor(e=new t.NoopLogger){this.logger=e,this.tasks=new Map,this.lastYield=0,this.cancelledIds=new Set,this.execute=async e=>{if(this.logger.debug(a,r,"runner start exeucte request"),!this.engine){const s={type:"reject",reason:{code:t.PdfErrorCode.NotReady,message:"engine has not started yet"}},a={id:e.id,type:"ExecuteResponse",data:{type:"error",value:s}};return void this.respond(a)}if(await this.maybeYield(),this.cancelledIds.has(e.id))return void this.respond({id:e.id,type:"ExecuteResponse",data:{type:"error",value:{type:"reject",reason:{code:t.PdfErrorCode.Cancelled,message:"aborted by client (pre-cancelled)"}}}});const s=this.engine,{name:n,args:i}=e.data;if(!s[n]){const s={type:"reject",reason:{code:t.PdfErrorCode.NotSupport,message:`engine method ${n} is not supported yet`}},a={id:e.id,type:"ExecuteResponse",data:{type:"error",value:s}};return void this.respond(a)}let o;switch(n){case"isSupport":case"initialize":case"destroy":case"openDocumentUrl":case"openDocumentBuffer":case"getDocPermissions":case"getDocUserPermissions":case"getMetadata":case"setMetadata":case"getBookmarks":case"setBookmarks":case"deleteBookmarks":case"getSignatures":case"renderPage":case"renderPageRect":case"renderPageAnnotation":case"renderThumbnail":case"getAllAnnotations":case"getPageAnnotations":case"createPageAnnotation":case"updatePageAnnotation":case"removePageAnnotation":case"getPageTextRects":case"searchAllPages":case"closeDocument":case"closeAllDocuments":case"saveAsCopy":case"getAttachments":case"addAttachment":case"removeAttachment":case"readAttachmentContent":case"setFormFieldValue":case"flattenPage":case"extractPages":case"extractText":case"redactTextInRects":case"getTextSlices":case"getPageGlyphs":case"getPageGeometry":case"merge":case"mergePages":case"preparePrintDocument":o=this.engine[n](...i)}this.tasks.set(e.id,o),o.onProgress((s=>{const t={id:e.id,type:"ExecuteProgress",data:s};this.respond(t)})),o.wait((s=>{const t={id:e.id,type:"ExecuteResponse",data:{type:"result",value:s}};this.respond(t),this.tasks.delete(e.id),this.cancelledIds.delete(e.id)}),(s=>{const t={id:e.id,type:"ExecuteResponse",data:{type:"error",value:s}};this.respond(t),this.tasks.delete(e.id),this.cancelledIds.delete(e.id)}))}}listen(){self.onmessage=e=>this.handle(e)}handle(e){this.logger.debug(a,r,"webworker receive message event: ",e.data);try{const s=e.data;switch(s.type){case"ExecuteRequest":this.execute(s);break;case"AbortRequest":this.abort(s)}}catch(s){this.logger.info(a,r,"webworker met error when processing message event:",s)}}ready(){this.listen(),this.respond({id:"0",type:"ReadyResponse"}),this.logger.debug(a,r,"runner is ready")}abort(e){const s=this.tasks.get(e.id);this.cancelledIds.add(e.id),s&&(s.abort({code:t.PdfErrorCode.Cancelled,message:"aborted by client"}),this.tasks.delete(e.id))}async maybeYield(){performance.now()-this.lastYield>8&&(await new Promise((e=>setTimeout(e,0))),this.lastYield=performance.now())}respond(e){this.logger.debug(a,r,"runner respond: ",e),self.postMessage(e)}}exports.DEFAULT_PDFIUM_WASM_URL="https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.3.16/dist/pdfium.wasm",exports.EngineRunner=n,exports.PdfiumEngineRunner=class extends n{constructor(e,s){super(s),this.wasmBinary=e}async prepare(){const t=this.wasmBinary,a=await s.init({wasmBinary:t});this.engine=new e.PdfiumEngine(a,{logger:this.logger}),this.ready()}};
2
- //# sourceMappingURL=index-D0i_Y0hT.cjs.map
1
+ "use strict";const e=require("./engine-Z4iXwySK.cjs"),s=require("@embedpdf/pdfium"),t=require("@embedpdf/models"),a="WebWorkerEngineRunner",r="Engine";class n{constructor(e=new t.NoopLogger){this.logger=e,this.tasks=new Map,this.lastYield=0,this.cancelledIds=new Set,this.execute=async e=>{if(this.logger.debug(a,r,"runner start exeucte request"),!this.engine){const s={type:"reject",reason:{code:t.PdfErrorCode.NotReady,message:"engine has not started yet"}},a={id:e.id,type:"ExecuteResponse",data:{type:"error",value:s}};return void this.respond(a)}if(await this.maybeYield(),this.cancelledIds.has(e.id))return void this.respond({id:e.id,type:"ExecuteResponse",data:{type:"error",value:{type:"reject",reason:{code:t.PdfErrorCode.Cancelled,message:"aborted by client (pre-cancelled)"}}}});const s=this.engine,{name:n,args:i}=e.data;if(!s[n]){const s={type:"reject",reason:{code:t.PdfErrorCode.NotSupport,message:`engine method ${n} is not supported yet`}},a={id:e.id,type:"ExecuteResponse",data:{type:"error",value:s}};return void this.respond(a)}let o;switch(n){case"isSupport":case"initialize":case"destroy":case"openDocumentUrl":case"openDocumentBuffer":case"getDocPermissions":case"getDocUserPermissions":case"getMetadata":case"setMetadata":case"getBookmarks":case"setBookmarks":case"deleteBookmarks":case"getSignatures":case"renderPage":case"renderPageRect":case"renderPageAnnotation":case"renderThumbnail":case"getAllAnnotations":case"getPageAnnotations":case"createPageAnnotation":case"updatePageAnnotation":case"removePageAnnotation":case"getPageTextRects":case"searchAllPages":case"closeDocument":case"closeAllDocuments":case"saveAsCopy":case"getAttachments":case"addAttachment":case"removeAttachment":case"readAttachmentContent":case"setFormFieldValue":case"flattenPage":case"extractPages":case"extractText":case"redactTextInRects":case"getTextSlices":case"getPageGlyphs":case"getPageGeometry":case"merge":case"mergePages":case"preparePrintDocument":o=this.engine[n](...i)}this.tasks.set(e.id,o),o.onProgress((s=>{const t={id:e.id,type:"ExecuteProgress",data:s};this.respond(t)})),o.wait((s=>{const t={id:e.id,type:"ExecuteResponse",data:{type:"result",value:s}};this.respond(t),this.tasks.delete(e.id),this.cancelledIds.delete(e.id)}),(s=>{const t={id:e.id,type:"ExecuteResponse",data:{type:"error",value:s}};this.respond(t),this.tasks.delete(e.id),this.cancelledIds.delete(e.id)}))}}listen(){self.onmessage=e=>this.handle(e)}handle(e){this.logger.debug(a,r,"webworker receive message event: ",e.data);try{const s=e.data;switch(s.type){case"ExecuteRequest":this.execute(s);break;case"AbortRequest":this.abort(s)}}catch(s){this.logger.info(a,r,"webworker met error when processing message event:",s)}}ready(){this.listen(),this.respond({id:"0",type:"ReadyResponse"}),this.logger.debug(a,r,"runner is ready")}abort(e){const s=this.tasks.get(e.id);this.cancelledIds.add(e.id),s&&(s.abort({code:t.PdfErrorCode.Cancelled,message:"aborted by client"}),this.tasks.delete(e.id))}async maybeYield(){performance.now()-this.lastYield>8&&(await new Promise((e=>setTimeout(e,0))),this.lastYield=performance.now())}respond(e){this.logger.debug(a,r,"runner respond: ",e),self.postMessage(e)}}exports.DEFAULT_PDFIUM_WASM_URL="https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.4.0/dist/pdfium.wasm",exports.EngineRunner=n,exports.PdfiumEngineRunner=class extends n{constructor(e,s){super(s),this.wasmBinary=e}async prepare(){const t=this.wasmBinary,a=await s.init({wasmBinary:t});this.engine=new e.PdfiumEngine(a,{logger:this.logger}),this.ready()}};
2
+ //# sourceMappingURL=index-DtwU4yb7.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-D0i_Y0hT.cjs","sources":["../src/lib/webworker/runner.ts","../src/lib/pdfium/index.ts","../src/lib/pdfium/runner.ts"],"sourcesContent":["import {\n Logger,\n NoopLogger,\n PdfEngine,\n PdfEngineError,\n PdfEngineMethodArgs,\n PdfEngineMethodName,\n PdfEngineMethodReturnType,\n PdfErrorCode,\n Task,\n TaskReturn,\n} from '@embedpdf/models';\n\n/**\n * Request body that represent method calls of PdfEngine, it contains the\n * method name and arguments\n */\nexport type PdfEngineMethodRequestBody = {\n [P in PdfEngineMethodName]: {\n name: P;\n args: PdfEngineMethodArgs<P>;\n };\n}[PdfEngineMethodName];\n\n/**\n * Request body that represent method calls of PdfEngine, it contains the\n * method name and arguments\n */\nexport type SpecificExecuteRequest<M extends PdfEngineMethodName> = {\n id: string;\n type: 'ExecuteRequest';\n data: {\n name: M;\n args: PdfEngineMethodArgs<M>;\n };\n};\n\n/**\n * Response body that represent return value of PdfEngine\n */\nexport type PdfEngineMethodResponseBody = {\n [P in PdfEngineMethodName]: TaskReturn<PdfEngineMethodReturnType<P>>;\n}[PdfEngineMethodName];\n\n/**\n * Request that abort the specified task\n */\nexport interface AbortRequest {\n /**\n * message id\n */\n id: string;\n /**\n * request type\n */\n type: 'AbortRequest';\n}\n/**\n * Request that execute pdf engine method\n */\nexport interface ExecuteRequest {\n /**\n * message id\n */\n id: string;\n /**\n * request type\n */\n type: 'ExecuteRequest';\n /**\n * request body\n */\n data: PdfEngineMethodRequestBody;\n}\n/**\n * Response that execute pdf engine method\n */\nexport interface ExecuteResponse {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ExecuteResponse';\n /**\n * response body\n */\n data: PdfEngineMethodResponseBody;\n}\n\n/**\n * Response that indicate progress of the task\n */\nexport interface ExecuteProgress<T = unknown> {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ExecuteProgress';\n /**\n * response body\n */\n data: T;\n}\n\n/**\n * Response that indicate engine is ready\n */\nexport interface ReadyResponse {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ReadyResponse';\n}\n\n/**\n * Request type\n */\nexport type Request = ExecuteRequest | AbortRequest;\n/**\n * Response type\n */\nexport type Response = ExecuteResponse | ReadyResponse | ExecuteProgress;\n\nconst LOG_SOURCE = 'WebWorkerEngineRunner';\nconst LOG_CATEGORY = 'Engine';\n\n/**\n * Pdf engine runner, it will execute pdf engine based on the request it received and\n * send back the response with post message\n */\nexport class EngineRunner {\n engine: PdfEngine | undefined;\n\n /** All running tasks, keyed by the message-id coming from the UI */\n private tasks = new Map<string, Task<any, any>>();\n\n /**\n * Last time we yielded to the event loop\n */\n private lastYield = 0;\n /**\n * Ids of tasks that have been cancelled\n */\n private cancelledIds = new Set<string>();\n\n /**\n * Create instance of EngineRunnder\n * @param logger - logger instance\n */\n constructor(public logger: Logger = new NoopLogger()) {}\n\n /**\n * Listening on post message\n */\n listen() {\n self.onmessage = (evt: MessageEvent<Request>) => {\n return this.handle(evt);\n };\n }\n\n /**\n * Handle post message\n */\n handle(evt: MessageEvent<Request>) {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'webworker receive message event: ', evt.data);\n try {\n const request = evt.data as Request;\n switch (request.type) {\n case 'ExecuteRequest':\n this.execute(request);\n break;\n case 'AbortRequest':\n this.abort(request);\n break;\n }\n } catch (e) {\n this.logger.info(\n LOG_SOURCE,\n LOG_CATEGORY,\n 'webworker met error when processing message event:',\n e,\n );\n }\n }\n\n /**\n * Send the ready response when pdf engine is ready\n * @returns\n *\n * @protected\n */\n ready() {\n this.listen();\n\n this.respond({\n id: '0',\n type: 'ReadyResponse',\n });\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner is ready');\n }\n\n private abort(request: AbortRequest) {\n const t = this.tasks.get(request.id);\n\n // Always record the abort id\n this.cancelledIds.add(request.id);\n\n if (!t) {\n // nothing to cancel (already finished or wrong id) – just ignore\n return;\n }\n\n t.abort({\n code: PdfErrorCode.Cancelled,\n message: 'aborted by client',\n });\n\n // we won’t hear from that task again\n this.tasks.delete(request.id);\n }\n\n private async maybeYield() {\n const now = performance.now();\n // give the event loop a breath roughly every ~8ms (tune as you like)\n if (now - this.lastYield > 8) {\n await new Promise((r) => setTimeout(r, 0));\n this.lastYield = performance.now();\n }\n }\n\n /**\n * Execute the request\n * @param request - request that represent the pdf engine call\n * @returns\n *\n * @protected\n */\n execute = async (request: ExecuteRequest) => {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner start exeucte request');\n if (!this.engine) {\n const error: PdfEngineError = {\n type: 'reject',\n reason: {\n code: PdfErrorCode.NotReady,\n message: 'engine has not started yet',\n },\n };\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n return;\n }\n\n // let AbortRequest messages land and pre-cancel flags get set\n await this.maybeYield();\n\n if (this.cancelledIds.has(request.id)) {\n this.respond({\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: {\n type: 'reject',\n reason: { code: PdfErrorCode.Cancelled, message: 'aborted by client (pre-cancelled)' },\n },\n },\n });\n return;\n }\n\n const engine = this.engine;\n const { name, args } = request.data;\n if (!engine[name]) {\n const error: PdfEngineError = {\n type: 'reject',\n reason: {\n code: PdfErrorCode.NotSupport,\n message: `engine method ${name} is not supported yet`,\n },\n };\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n return;\n }\n\n let task: PdfEngineMethodReturnType<typeof name>;\n switch (name) {\n case 'isSupport':\n task = this.engine[name]!(...args);\n break;\n case 'initialize':\n task = this.engine[name]!(...args);\n break;\n case 'destroy':\n task = this.engine[name]!(...args);\n break;\n case 'openDocumentUrl':\n task = this.engine[name]!(...args);\n break;\n case 'openDocumentBuffer':\n task = this.engine[name]!(...args);\n break;\n case 'getDocPermissions':\n task = this.engine[name]!(...args);\n break;\n case 'getDocUserPermissions':\n task = this.engine[name]!(...args);\n break;\n case 'getMetadata':\n task = this.engine[name]!(...args);\n break;\n case 'setMetadata':\n task = this.engine[name]!(...args);\n break;\n case 'getBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'setBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'deleteBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'getSignatures':\n task = this.engine[name]!(...args);\n break;\n case 'renderPage':\n task = this.engine[name]!(...args);\n break;\n case 'renderPageRect':\n task = this.engine[name]!(...args);\n break;\n case 'renderPageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'renderThumbnail':\n task = this.engine[name]!(...args);\n break;\n case 'getAllAnnotations':\n task = this.engine[name]!(...args);\n break;\n case 'getPageAnnotations':\n task = this.engine[name]!(...args);\n break;\n case 'createPageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'updatePageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'removePageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'getPageTextRects':\n task = this.engine[name]!(...args);\n break;\n case 'searchAllPages':\n task = this.engine[name]!(...args);\n break;\n case 'closeDocument':\n task = this.engine[name]!(...args);\n break;\n case 'closeAllDocuments':\n task = this.engine[name]!(...args);\n break;\n case 'saveAsCopy':\n task = this.engine[name]!(...args);\n break;\n case 'getAttachments':\n task = this.engine[name]!(...args);\n break;\n case 'addAttachment':\n task = this.engine[name]!(...args);\n break;\n case 'removeAttachment':\n task = this.engine[name]!(...args);\n break;\n case 'readAttachmentContent':\n task = this.engine[name]!(...args);\n break;\n case 'setFormFieldValue':\n task = this.engine[name]!(...args);\n break;\n case 'flattenPage':\n task = this.engine[name]!(...args);\n break;\n case 'extractPages':\n task = this.engine[name]!(...args);\n break;\n case 'extractText':\n task = this.engine[name]!(...args);\n break;\n case 'redactTextInRects':\n task = this.engine[name]!(...args);\n break;\n case 'getTextSlices':\n task = this.engine[name]!(...args);\n break;\n case 'getPageGlyphs':\n task = this.engine[name]!(...args);\n break;\n case 'getPageGeometry':\n task = this.engine[name]!(...args);\n break;\n case 'merge':\n task = this.engine[name]!(...args);\n break;\n case 'mergePages':\n task = this.engine[name]!(...args);\n break;\n case 'preparePrintDocument':\n task = this.engine[name]!(...args);\n break;\n }\n\n this.tasks.set(request.id, task);\n\n task.onProgress((progress) => {\n const response: ExecuteProgress = {\n id: request.id,\n type: 'ExecuteProgress',\n data: progress,\n };\n this.respond(response);\n });\n\n task.wait(\n (result) => {\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'result',\n value: result,\n },\n };\n this.respond(response);\n this.tasks.delete(request.id);\n this.cancelledIds.delete(request.id);\n },\n (error) => {\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n this.tasks.delete(request.id);\n this.cancelledIds.delete(request.id);\n },\n );\n };\n\n /**\n * Send back the response\n * @param response - response that needs sent back\n *\n * @protected\n */\n respond(response: Response) {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner respond: ', response);\n self.postMessage(response);\n }\n}\n","export * from './engine';\nexport * from './helper';\nexport * from './runner';\n\nexport const DEFAULT_PDFIUM_WASM_URL: string =\n 'https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm';\n","import { init } from '@embedpdf/pdfium';\nimport { EngineRunner } from '../webworker/runner';\nimport { PdfiumEngine } from './engine';\nimport { Logger } from '@embedpdf/models';\n\n/**\n * EngineRunner for pdfium-based wasm engine\n */\nexport class PdfiumEngineRunner extends EngineRunner {\n /**\n * Create an instance of PdfiumEngineRunner\n * @param wasmBinary - wasm binary that contains the pdfium wasm file\n */\n constructor(\n private wasmBinary: ArrayBuffer,\n logger?: Logger,\n ) {\n super(logger);\n }\n\n /**\n * Initialize runner\n */\n async prepare() {\n const wasmBinary = this.wasmBinary;\n const wasmModule = await init({ wasmBinary });\n this.engine = new PdfiumEngine(wasmModule, { logger: this.logger });\n this.ready();\n }\n}\n"],"names":["LOG_SOURCE","LOG_CATEGORY","EngineRunner","constructor","logger","NoopLogger","this","tasks","Map","lastYield","cancelledIds","Set","execute","async","request","debug","engine","error","type","reason","code","PdfErrorCode","NotReady","message","response","id","data","value","respond","maybeYield","has","Cancelled","name","args","NotSupport","task","set","onProgress","progress","wait","result","delete","listen","self","onmessage","evt","handle","abort","e","info","ready","t","get","add","performance","now","Promise","r","setTimeout","postMessage","wasmBinary","super","prepare","wasmModule","init","PdfiumEngine"],"mappings":"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"}
1
+ {"version":3,"file":"index-DtwU4yb7.cjs","sources":["../src/lib/webworker/runner.ts","../src/lib/pdfium/index.ts","../src/lib/pdfium/runner.ts"],"sourcesContent":["import {\n Logger,\n NoopLogger,\n PdfEngine,\n PdfEngineError,\n PdfEngineMethodArgs,\n PdfEngineMethodName,\n PdfEngineMethodReturnType,\n PdfErrorCode,\n Task,\n TaskReturn,\n} from '@embedpdf/models';\n\n/**\n * Request body that represent method calls of PdfEngine, it contains the\n * method name and arguments\n */\nexport type PdfEngineMethodRequestBody = {\n [P in PdfEngineMethodName]: {\n name: P;\n args: PdfEngineMethodArgs<P>;\n };\n}[PdfEngineMethodName];\n\n/**\n * Request body that represent method calls of PdfEngine, it contains the\n * method name and arguments\n */\nexport type SpecificExecuteRequest<M extends PdfEngineMethodName> = {\n id: string;\n type: 'ExecuteRequest';\n data: {\n name: M;\n args: PdfEngineMethodArgs<M>;\n };\n};\n\n/**\n * Response body that represent return value of PdfEngine\n */\nexport type PdfEngineMethodResponseBody = {\n [P in PdfEngineMethodName]: TaskReturn<PdfEngineMethodReturnType<P>>;\n}[PdfEngineMethodName];\n\n/**\n * Request that abort the specified task\n */\nexport interface AbortRequest {\n /**\n * message id\n */\n id: string;\n /**\n * request type\n */\n type: 'AbortRequest';\n}\n/**\n * Request that execute pdf engine method\n */\nexport interface ExecuteRequest {\n /**\n * message id\n */\n id: string;\n /**\n * request type\n */\n type: 'ExecuteRequest';\n /**\n * request body\n */\n data: PdfEngineMethodRequestBody;\n}\n/**\n * Response that execute pdf engine method\n */\nexport interface ExecuteResponse {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ExecuteResponse';\n /**\n * response body\n */\n data: PdfEngineMethodResponseBody;\n}\n\n/**\n * Response that indicate progress of the task\n */\nexport interface ExecuteProgress<T = unknown> {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ExecuteProgress';\n /**\n * response body\n */\n data: T;\n}\n\n/**\n * Response that indicate engine is ready\n */\nexport interface ReadyResponse {\n /**\n * message id\n */\n id: string;\n /**\n * response type\n */\n type: 'ReadyResponse';\n}\n\n/**\n * Request type\n */\nexport type Request = ExecuteRequest | AbortRequest;\n/**\n * Response type\n */\nexport type Response = ExecuteResponse | ReadyResponse | ExecuteProgress;\n\nconst LOG_SOURCE = 'WebWorkerEngineRunner';\nconst LOG_CATEGORY = 'Engine';\n\n/**\n * Pdf engine runner, it will execute pdf engine based on the request it received and\n * send back the response with post message\n */\nexport class EngineRunner {\n engine: PdfEngine | undefined;\n\n /** All running tasks, keyed by the message-id coming from the UI */\n private tasks = new Map<string, Task<any, any>>();\n\n /**\n * Last time we yielded to the event loop\n */\n private lastYield = 0;\n /**\n * Ids of tasks that have been cancelled\n */\n private cancelledIds = new Set<string>();\n\n /**\n * Create instance of EngineRunnder\n * @param logger - logger instance\n */\n constructor(public logger: Logger = new NoopLogger()) {}\n\n /**\n * Listening on post message\n */\n listen() {\n self.onmessage = (evt: MessageEvent<Request>) => {\n return this.handle(evt);\n };\n }\n\n /**\n * Handle post message\n */\n handle(evt: MessageEvent<Request>) {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'webworker receive message event: ', evt.data);\n try {\n const request = evt.data as Request;\n switch (request.type) {\n case 'ExecuteRequest':\n this.execute(request);\n break;\n case 'AbortRequest':\n this.abort(request);\n break;\n }\n } catch (e) {\n this.logger.info(\n LOG_SOURCE,\n LOG_CATEGORY,\n 'webworker met error when processing message event:',\n e,\n );\n }\n }\n\n /**\n * Send the ready response when pdf engine is ready\n * @returns\n *\n * @protected\n */\n ready() {\n this.listen();\n\n this.respond({\n id: '0',\n type: 'ReadyResponse',\n });\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner is ready');\n }\n\n private abort(request: AbortRequest) {\n const t = this.tasks.get(request.id);\n\n // Always record the abort id\n this.cancelledIds.add(request.id);\n\n if (!t) {\n // nothing to cancel (already finished or wrong id) – just ignore\n return;\n }\n\n t.abort({\n code: PdfErrorCode.Cancelled,\n message: 'aborted by client',\n });\n\n // we won’t hear from that task again\n this.tasks.delete(request.id);\n }\n\n private async maybeYield() {\n const now = performance.now();\n // give the event loop a breath roughly every ~8ms (tune as you like)\n if (now - this.lastYield > 8) {\n await new Promise((r) => setTimeout(r, 0));\n this.lastYield = performance.now();\n }\n }\n\n /**\n * Execute the request\n * @param request - request that represent the pdf engine call\n * @returns\n *\n * @protected\n */\n execute = async (request: ExecuteRequest) => {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner start exeucte request');\n if (!this.engine) {\n const error: PdfEngineError = {\n type: 'reject',\n reason: {\n code: PdfErrorCode.NotReady,\n message: 'engine has not started yet',\n },\n };\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n return;\n }\n\n // let AbortRequest messages land and pre-cancel flags get set\n await this.maybeYield();\n\n if (this.cancelledIds.has(request.id)) {\n this.respond({\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: {\n type: 'reject',\n reason: { code: PdfErrorCode.Cancelled, message: 'aborted by client (pre-cancelled)' },\n },\n },\n });\n return;\n }\n\n const engine = this.engine;\n const { name, args } = request.data;\n if (!engine[name]) {\n const error: PdfEngineError = {\n type: 'reject',\n reason: {\n code: PdfErrorCode.NotSupport,\n message: `engine method ${name} is not supported yet`,\n },\n };\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n return;\n }\n\n let task: PdfEngineMethodReturnType<typeof name>;\n switch (name) {\n case 'isSupport':\n task = this.engine[name]!(...args);\n break;\n case 'initialize':\n task = this.engine[name]!(...args);\n break;\n case 'destroy':\n task = this.engine[name]!(...args);\n break;\n case 'openDocumentUrl':\n task = this.engine[name]!(...args);\n break;\n case 'openDocumentBuffer':\n task = this.engine[name]!(...args);\n break;\n case 'getDocPermissions':\n task = this.engine[name]!(...args);\n break;\n case 'getDocUserPermissions':\n task = this.engine[name]!(...args);\n break;\n case 'getMetadata':\n task = this.engine[name]!(...args);\n break;\n case 'setMetadata':\n task = this.engine[name]!(...args);\n break;\n case 'getBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'setBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'deleteBookmarks':\n task = this.engine[name]!(...args);\n break;\n case 'getSignatures':\n task = this.engine[name]!(...args);\n break;\n case 'renderPage':\n task = this.engine[name]!(...args);\n break;\n case 'renderPageRect':\n task = this.engine[name]!(...args);\n break;\n case 'renderPageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'renderThumbnail':\n task = this.engine[name]!(...args);\n break;\n case 'getAllAnnotations':\n task = this.engine[name]!(...args);\n break;\n case 'getPageAnnotations':\n task = this.engine[name]!(...args);\n break;\n case 'createPageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'updatePageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'removePageAnnotation':\n task = this.engine[name]!(...args);\n break;\n case 'getPageTextRects':\n task = this.engine[name]!(...args);\n break;\n case 'searchAllPages':\n task = this.engine[name]!(...args);\n break;\n case 'closeDocument':\n task = this.engine[name]!(...args);\n break;\n case 'closeAllDocuments':\n task = this.engine[name]!(...args);\n break;\n case 'saveAsCopy':\n task = this.engine[name]!(...args);\n break;\n case 'getAttachments':\n task = this.engine[name]!(...args);\n break;\n case 'addAttachment':\n task = this.engine[name]!(...args);\n break;\n case 'removeAttachment':\n task = this.engine[name]!(...args);\n break;\n case 'readAttachmentContent':\n task = this.engine[name]!(...args);\n break;\n case 'setFormFieldValue':\n task = this.engine[name]!(...args);\n break;\n case 'flattenPage':\n task = this.engine[name]!(...args);\n break;\n case 'extractPages':\n task = this.engine[name]!(...args);\n break;\n case 'extractText':\n task = this.engine[name]!(...args);\n break;\n case 'redactTextInRects':\n task = this.engine[name]!(...args);\n break;\n case 'getTextSlices':\n task = this.engine[name]!(...args);\n break;\n case 'getPageGlyphs':\n task = this.engine[name]!(...args);\n break;\n case 'getPageGeometry':\n task = this.engine[name]!(...args);\n break;\n case 'merge':\n task = this.engine[name]!(...args);\n break;\n case 'mergePages':\n task = this.engine[name]!(...args);\n break;\n case 'preparePrintDocument':\n task = this.engine[name]!(...args);\n break;\n }\n\n this.tasks.set(request.id, task);\n\n task.onProgress((progress) => {\n const response: ExecuteProgress = {\n id: request.id,\n type: 'ExecuteProgress',\n data: progress,\n };\n this.respond(response);\n });\n\n task.wait(\n (result) => {\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'result',\n value: result,\n },\n };\n this.respond(response);\n this.tasks.delete(request.id);\n this.cancelledIds.delete(request.id);\n },\n (error) => {\n const response: ExecuteResponse = {\n id: request.id,\n type: 'ExecuteResponse',\n data: {\n type: 'error',\n value: error,\n },\n };\n this.respond(response);\n this.tasks.delete(request.id);\n this.cancelledIds.delete(request.id);\n },\n );\n };\n\n /**\n * Send back the response\n * @param response - response that needs sent back\n *\n * @protected\n */\n respond(response: Response) {\n this.logger.debug(LOG_SOURCE, LOG_CATEGORY, 'runner respond: ', response);\n self.postMessage(response);\n }\n}\n","export * from './engine';\nexport * from './helper';\nexport * from './runner';\n\nexport const DEFAULT_PDFIUM_WASM_URL: string =\n 'https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm';\n","import { init } from '@embedpdf/pdfium';\nimport { EngineRunner } from '../webworker/runner';\nimport { PdfiumEngine } from './engine';\nimport { Logger } from '@embedpdf/models';\n\n/**\n * EngineRunner for pdfium-based wasm engine\n */\nexport class PdfiumEngineRunner extends EngineRunner {\n /**\n * Create an instance of PdfiumEngineRunner\n * @param wasmBinary - wasm binary that contains the pdfium wasm file\n */\n constructor(\n private wasmBinary: ArrayBuffer,\n logger?: Logger,\n ) {\n super(logger);\n }\n\n /**\n * Initialize runner\n */\n async prepare() {\n const wasmBinary = this.wasmBinary;\n const wasmModule = await init({ wasmBinary });\n this.engine = new PdfiumEngine(wasmModule, { logger: this.logger });\n this.ready();\n }\n}\n"],"names":["LOG_SOURCE","LOG_CATEGORY","EngineRunner","constructor","logger","NoopLogger","this","tasks","Map","lastYield","cancelledIds","Set","execute","async","request","debug","engine","error","type","reason","code","PdfErrorCode","NotReady","message","response","id","data","value","respond","maybeYield","has","Cancelled","name","args","NotSupport","task","set","onProgress","progress","wait","result","delete","listen","self","onmessage","evt","handle","abort","e","info","ready","t","get","add","performance","now","Promise","r","setTimeout","postMessage","wasmBinary","super","prepare","wasmModule","init","PdfiumEngine"],"mappings":"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"}
package/dist/index.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./index-D0i_Y0hT.cjs"),r=require("./lib/webworker/engine.cjs"),t=require("@embedpdf/models"),o=require("./engine-Z4iXwySK.cjs");exports.DEFAULT_PDFIUM_WASM_URL=e.DEFAULT_PDFIUM_WASM_URL,exports.EngineRunner=e.EngineRunner,exports.PdfiumEngineRunner=e.PdfiumEngineRunner,exports.WebWorkerEngine=r.WebWorkerEngine,exports.WorkerTask=r.WorkerTask,exports.BitmapFormat=o.BitmapFormat,exports.OffscreenCanvasError=o.OffscreenCanvasError,exports.PdfiumEngine=o.PdfiumEngine,exports.PdfiumErrorCode=o.PdfiumErrorCode,exports.RenderFlag=o.RenderFlag,exports.browserImageDataToBlobConverter=o.browserImageDataToBlobConverter,exports.isValidCustomKey=o.isValidCustomKey,exports.readArrayBuffer=o.readArrayBuffer,exports.readString=o.readString,exports.createMockPdfDocument=function(e){const r=[];for(let o=0;o<10;o++)r.push({index:o,size:{width:100,height:200},rotation:t.Rotation.Degree0});return{id:"id",pageCount:10,pages:r,...e}},exports.createMockPdfEngine=function(e){return{openDocumentUrl:jest.fn(((e,r)=>t.PdfTaskHelper.create())),openDocumentBuffer:jest.fn(((e,r)=>t.PdfTaskHelper.create())),getMetadata:e=>{const r={title:"title",author:"author",subject:"subject",keywords:"keywords",producer:"producer",creator:"creator",creationDate:new Date,modificationDate:new Date,trapped:t.PdfTrappedStatus.NotSet};return t.PdfTaskHelper.resolve(r)},setMetadata:(e,r)=>t.PdfTaskHelper.resolve(!0),getDocPermissions:e=>t.PdfTaskHelper.resolve(4294967295),getDocUserPermissions:e=>t.PdfTaskHelper.resolve(4294967295),getSignatures:e=>t.PdfTaskHelper.resolve([]),getBookmarks:e=>{const r=[];return r.push({title:"Page 1",target:{type:"destination",destination:{pageIndex:1,zoom:{mode:t.PdfZoomMode.FitPage},view:[]}}},{title:"Page 2",target:{type:"destination",destination:{pageIndex:2,zoom:{mode:t.PdfZoomMode.FitPage},view:[]}},children:[{title:"Page 3",target:{type:"destination",destination:{pageIndex:3,zoom:{mode:t.PdfZoomMode.FitPage},view:[]}}}]}),t.PdfTaskHelper.resolve({bookmarks:r})},setBookmarks:jest.fn(((e,r)=>t.PdfTaskHelper.resolve(!0))),deleteBookmarks:jest.fn((e=>t.PdfTaskHelper.resolve(!0))),renderPage:jest.fn(((e,r,o)=>{const{scaleFactor:n=1,rotation:a=t.Rotation.Degree0,dpr:s=1}=o??{},i=a%2==0?r.size:t.swap(r.size),d=Math.ceil(i.width*n)*Math.ceil(i.height*n),l=new Uint8ClampedArray(4*d),f=r.index%255;for(let t=0;t<d;t++){for(let e=0;e<3;e++){l[4*t+e]=f}l[4*t+3]=255}const p=l.buffer,c=p instanceof ArrayBuffer?p:new Uint8Array(l).buffer,g=new Blob([c],{type:"application/octet-stream"});return t.PdfTaskHelper.resolve(g)})),renderPageRect:jest.fn(((e,r,o,n)=>{const{scaleFactor:a=1,rotation:s=t.Rotation.Degree0,dpr:i=1}=n??{},d=s%2==0?r.size:t.swap(r.size),l=Math.ceil(d.width*a)*Math.ceil(d.height*a),f=new Uint8ClampedArray(4*l),p=r.index%255;for(let t=0;t<l;t++){for(let e=0;e<3;e++){f[4*t+e]=p}f[4*t+3]=255}const c=f.buffer,g=c instanceof ArrayBuffer?c:new Uint8Array(f).buffer,u=new Blob([g],{type:"application/octet-stream"});return t.PdfTaskHelper.resolve(u)})),renderThumbnail:jest.fn(((e,r)=>{const o=r.size.width/4*(r.size.height/4),n=new Uint8ClampedArray(4*o),a=r.index%255;for(let t=0;t<o;t++){for(let e=0;e<3;e++){n[4*t+e]=a}n[4*t+3]=255}const s=n.buffer,i=s instanceof ArrayBuffer?s:new Uint8Array(n).buffer,d=new Blob([i],{type:"image/png"});return t.PdfTaskHelper.resolve(d)})),renderPageAnnotation:jest.fn(((e,r,o,n)=>t.PdfTaskHelper.resolve(new Blob([],{type:"image/png"})))),getAllAnnotations:jest.fn((e=>t.PdfTaskHelper.resolve({}))),getPageAnnotations:jest.fn(((e,r)=>{const o={pageIndex:r.index,id:"1",type:t.PdfAnnotationSubtype.LINK,target:{type:"action",action:{type:t.PdfActionType.URI,uri:"https://localhost"}},rect:{origin:{x:0,y:0},size:{width:100,height:100}}},n=[];return n.push(o),t.PdfTaskHelper.resolve(n)})),createPageAnnotation:jest.fn((()=>t.PdfTaskHelper.resolve(t.uuidV4()))),updatePageAnnotation:jest.fn((()=>t.PdfTaskHelper.resolve(!0))),removePageAnnotation:jest.fn((()=>t.PdfTaskHelper.resolve(!0))),getPageTextRects:jest.fn(((e,r)=>t.PdfTaskHelper.resolve([{content:"pdf text",font:{family:"sans-serif",size:12},rect:{origin:{x:0,y:0},size:{width:100,height:100}}}]))),closeDocument:e=>t.PdfTaskHelper.resolve(!0),closeAllDocuments:()=>t.PdfTaskHelper.resolve(!0),saveAsCopy:e=>t.PdfTaskHelper.resolve(new ArrayBuffer(0)),flattenPage:(e,r,o)=>t.PdfTaskHelper.resolve(t.PdfPageFlattenResult.Success),extractPages:(e,r)=>t.PdfTaskHelper.resolve(new ArrayBuffer(0)),extractText:(e,r)=>t.PdfTaskHelper.resolve(""),redactTextInRects:(e,r,o,n)=>t.PdfTaskHelper.resolve(!0),getTextSlices:(e,r)=>t.PdfTaskHelper.resolve([]),getPageGlyphs:(e,r)=>t.PdfTaskHelper.resolve([]),getPageGeometry:(e,r)=>t.PdfTaskHelper.resolve({runs:[]}),merge:e=>t.PdfTaskHelper.resolve({id:"id",content:new ArrayBuffer(0)}),mergePages:e=>t.PdfTaskHelper.resolve({id:"id",content:new ArrayBuffer(0)}),preparePrintDocument:(e,r)=>t.PdfTaskHelper.resolve(new ArrayBuffer(0)),searchAllPages:(e,r,o)=>{const n={pageIndex:0,charIndex:0,charCount:r.length,rects:[{origin:{x:0,y:0},size:{width:50,height:20}}],context:{before:"",match:"",after:"",truncatedLeft:!1,truncatedRight:!1}};return t.PdfTaskHelper.resolve({results:[n],total:1})},getAttachments:e=>t.PdfTaskHelper.resolve([]),addAttachment:(e,r)=>t.PdfTaskHelper.resolve(!0),removeAttachment:(e,r)=>t.PdfTaskHelper.resolve(!0),readAttachmentContent:(e,r)=>t.PdfTaskHelper.resolve(new ArrayBuffer(0)),setFormFieldValue:(e,r,o,n)=>t.PdfTaskHelper.resolve(!0),...e}},exports.createMockPdfFile=function(e){return{id:"id",content:new ArrayBuffer(0)}};
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./index-DtwU4yb7.cjs"),r=require("./lib/webworker/engine.cjs"),o=require("./engine-Z4iXwySK.cjs");exports.DEFAULT_PDFIUM_WASM_URL=e.DEFAULT_PDFIUM_WASM_URL,exports.EngineRunner=e.EngineRunner,exports.PdfiumEngineRunner=e.PdfiumEngineRunner,exports.WebWorkerEngine=r.WebWorkerEngine,exports.WorkerTask=r.WorkerTask,exports.BitmapFormat=o.BitmapFormat,exports.OffscreenCanvasError=o.OffscreenCanvasError,exports.PdfiumEngine=o.PdfiumEngine,exports.PdfiumErrorCode=o.PdfiumErrorCode,exports.RenderFlag=o.RenderFlag,exports.browserImageDataToBlobConverter=o.browserImageDataToBlobConverter,exports.isValidCustomKey=o.isValidCustomKey,exports.readArrayBuffer=o.readArrayBuffer,exports.readString=o.readString;
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../src/lib/mock/index.ts"],"sourcesContent":["import {\n PdfDocumentObject,\n PdfEngine,\n PdfPageObject,\n PdfAnnotationSubtype,\n PdfLinkAnnoObject,\n Rotation,\n swap,\n PdfZoomMode,\n PdfActionType,\n PdfAnnotationObject,\n PdfBookmarkObject,\n PdfTextRectObject,\n SearchResult,\n PdfAttachmentObject,\n PdfSignatureObject,\n Rect,\n PdfFile,\n PdfWidgetAnnoObject,\n FormFieldValue,\n PdfTaskHelper,\n PdfPageFlattenResult,\n SearchAllPagesResult,\n PdfOpenDocumentUrlOptions,\n PdfFileUrl,\n PdfGlyphObject,\n PdfPageGeometry,\n PageTextSlice,\n PdfPageSearchProgress,\n PdfRenderPageOptions,\n PdfRenderPageAnnotationOptions,\n PdfFlattenPageOptions,\n PdfRedactTextOptions,\n PdfSearchAllPagesOptions,\n PdfOpenDocumentBufferOptions,\n uuidV4,\n PdfMetadataObject,\n PdfTask,\n PdfPrintOptions,\n PdfTrappedStatus,\n PdfAddAttachmentParams,\n} from '@embedpdf/models';\n\n/**\n * Create mock of pdf engine\n * @param partialEngine - partial configuration of engine\n * @returns - mock of pdf engine\n *\n * @public\n */\nexport function createMockPdfEngine(partialEngine?: Partial<PdfEngine>): PdfEngine {\n const engine: PdfEngine = {\n openDocumentUrl: jest.fn((file: PdfFileUrl, options?: PdfOpenDocumentUrlOptions) => {\n return PdfTaskHelper.create();\n }),\n openDocumentBuffer: jest.fn((file: PdfFile, options?: PdfOpenDocumentBufferOptions) => {\n return PdfTaskHelper.create();\n }),\n getMetadata: (doc: PdfDocumentObject) => {\n const metadata: PdfMetadataObject = {\n title: 'title',\n author: 'author',\n subject: 'subject',\n keywords: 'keywords',\n producer: 'producer',\n creator: 'creator',\n creationDate: new Date(),\n modificationDate: new Date(),\n trapped: PdfTrappedStatus.NotSet,\n };\n return PdfTaskHelper.resolve(metadata);\n },\n setMetadata: (doc: PdfDocumentObject, metadata: Partial<PdfMetadataObject>) => {\n return PdfTaskHelper.resolve(true);\n },\n getDocPermissions: (doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(0xffffffff);\n },\n getDocUserPermissions: (doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(0xffffffff);\n },\n getSignatures: (doc: PdfDocumentObject) => {\n const signatures: PdfSignatureObject[] = [];\n return PdfTaskHelper.resolve(signatures);\n },\n getBookmarks: (doc: PdfDocumentObject) => {\n const bookmarks: PdfBookmarkObject[] = [];\n bookmarks.push(\n {\n title: 'Page 1',\n target: {\n type: 'destination',\n destination: {\n pageIndex: 1,\n zoom: {\n mode: PdfZoomMode.FitPage,\n },\n view: [],\n },\n },\n },\n {\n title: 'Page 2',\n target: {\n type: 'destination',\n destination: {\n pageIndex: 2,\n zoom: {\n mode: PdfZoomMode.FitPage,\n },\n view: [],\n },\n },\n children: [\n {\n title: 'Page 3',\n target: {\n type: 'destination',\n destination: {\n pageIndex: 3,\n zoom: {\n mode: PdfZoomMode.FitPage,\n },\n view: [],\n },\n },\n },\n ],\n },\n );\n return PdfTaskHelper.resolve({\n bookmarks,\n });\n },\n setBookmarks: jest.fn((doc: PdfDocumentObject, payload: PdfBookmarkObject[]) => {\n return PdfTaskHelper.resolve(true);\n }),\n deleteBookmarks: jest.fn((doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(true);\n }),\n renderPage: jest.fn(\n (doc: PdfDocumentObject, page: PdfPageObject, options?: PdfRenderPageOptions) => {\n const { scaleFactor = 1, rotation = Rotation.Degree0, dpr = 1 } = options ?? {};\n const pageSize = rotation % 2 === 0 ? page.size : swap(page.size);\n const imageSize = {\n width: Math.ceil(pageSize.width * scaleFactor),\n height: Math.ceil(pageSize.height * scaleFactor),\n };\n const pixelCount = imageSize.width * imageSize.height;\n const array = new Uint8ClampedArray(pixelCount * 4);\n const rgbValue = page.index % 255;\n const alphaValue = 255;\n for (let i = 0; i < pixelCount; i++) {\n for (let j = 0; j < 3; j++) {\n const index = i * 4 + j;\n array[index] = rgbValue;\n }\n array[i * 4 + 3] = alphaValue;\n }\n\n const ab = array.buffer;\n const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;\n const blob = new Blob([realBuffer], { type: 'application/octet-stream' });\n return PdfTaskHelper.resolve(blob);\n },\n ),\n renderPageRect: jest.fn(\n (doc: PdfDocumentObject, page: PdfPageObject, rect: Rect, options?: PdfRenderPageOptions) => {\n const { scaleFactor = 1, rotation = Rotation.Degree0, dpr = 1 } = options ?? {};\n const pageSize = rotation % 2 === 0 ? page.size : swap(page.size);\n const imageSize = {\n width: Math.ceil(pageSize.width * scaleFactor),\n height: Math.ceil(pageSize.height * scaleFactor),\n };\n const pixelCount = imageSize.width * imageSize.height;\n const array = new Uint8ClampedArray(pixelCount * 4);\n const rgbValue = page.index % 255;\n const alphaValue = 255;\n for (let i = 0; i < pixelCount; i++) {\n for (let j = 0; j < 3; j++) {\n const index = i * 4 + j;\n array[index] = rgbValue;\n }\n array[i * 4 + 3] = alphaValue;\n }\n\n const ab = array.buffer;\n const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;\n const blob = new Blob([realBuffer], { type: 'application/octet-stream' });\n return PdfTaskHelper.resolve(blob);\n },\n ),\n renderThumbnail: jest.fn((doc: PdfDocumentObject, page: PdfPageObject) => {\n const thumbnailWidth = page.size.width / 4;\n const thumbnailHeight = page.size.height / 4;\n const pixelCount = thumbnailWidth * thumbnailHeight;\n const array = new Uint8ClampedArray(pixelCount * 4);\n const rgbValue = page.index % 255;\n const alphaValue = 255;\n for (let i = 0; i < pixelCount; i++) {\n for (let j = 0; j < 3; j++) {\n const index = i * 4 + j;\n array[index] = rgbValue;\n }\n array[i * 4 + 3] = alphaValue;\n }\n\n const ab = array.buffer;\n const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;\n const blob = new Blob([realBuffer], { type: 'image/png' });\n\n return PdfTaskHelper.resolve(blob);\n }),\n renderPageAnnotation: jest.fn(\n (\n doc: PdfDocumentObject,\n page: PdfPageObject,\n annotation: PdfAnnotationObject,\n options?: PdfRenderPageAnnotationOptions,\n ) => {\n return PdfTaskHelper.resolve(new Blob([], { type: 'image/png' }));\n },\n ),\n getAllAnnotations: jest.fn((doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve({});\n }),\n getPageAnnotations: jest.fn((doc: PdfDocumentObject, page: PdfPageObject) => {\n const link: PdfLinkAnnoObject = {\n pageIndex: page.index,\n id: '1',\n type: PdfAnnotationSubtype.LINK,\n target: {\n type: 'action',\n action: {\n type: PdfActionType.URI,\n uri: 'https://localhost',\n },\n },\n rect: {\n origin: {\n x: 0,\n y: 0,\n },\n size: {\n width: 100,\n height: 100,\n },\n },\n };\n const annotations: PdfAnnotationObject[] = [];\n annotations.push(link);\n return PdfTaskHelper.resolve(annotations);\n }),\n createPageAnnotation: jest.fn(() => {\n return PdfTaskHelper.resolve(uuidV4());\n }),\n updatePageAnnotation: jest.fn(() => {\n return PdfTaskHelper.resolve(true);\n }),\n removePageAnnotation: jest.fn(() => {\n return PdfTaskHelper.resolve(true);\n }),\n getPageTextRects: jest.fn((doc: PdfDocumentObject, page: PdfPageObject) => {\n const textRects: PdfTextRectObject[] = [\n {\n content: 'pdf text',\n font: {\n family: 'sans-serif',\n size: 12,\n },\n rect: {\n origin: {\n x: 0,\n y: 0,\n },\n size: {\n width: 100,\n height: 100,\n },\n },\n },\n ];\n return PdfTaskHelper.resolve(textRects);\n }),\n closeDocument: (pdf: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(true);\n },\n closeAllDocuments: () => {\n return PdfTaskHelper.resolve(true);\n },\n saveAsCopy: (pdf: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(new ArrayBuffer(0));\n },\n flattenPage: (pdf: PdfDocumentObject, page: PdfPageObject, options?: PdfFlattenPageOptions) => {\n return PdfTaskHelper.resolve<PdfPageFlattenResult>(PdfPageFlattenResult.Success);\n },\n extractPages: (pdf: PdfDocumentObject, pageIndexes: number[]) => {\n return PdfTaskHelper.resolve(new ArrayBuffer(0));\n },\n extractText: (pdf: PdfDocumentObject, pageIndexes: number[]) => {\n return PdfTaskHelper.resolve('');\n },\n redactTextInRects: (\n pdf: PdfDocumentObject,\n page: PdfPageObject,\n rects: Rect[],\n options?: PdfRedactTextOptions,\n ) => {\n return PdfTaskHelper.resolve(true);\n },\n getTextSlices: (doc: PdfDocumentObject, slices: PageTextSlice[]) => {\n return PdfTaskHelper.resolve([] as string[]);\n },\n getPageGlyphs: (doc: PdfDocumentObject, page: PdfPageObject) => {\n return PdfTaskHelper.resolve([] as PdfGlyphObject[]);\n },\n getPageGeometry: (doc: PdfDocumentObject, page: PdfPageObject) => {\n return PdfTaskHelper.resolve({\n runs: [],\n } as PdfPageGeometry);\n },\n merge: (files: PdfFile[]) => {\n return PdfTaskHelper.resolve({\n id: 'id',\n content: new ArrayBuffer(0),\n });\n },\n mergePages: (mergeConfigs: Array<{ docId: string; pageIndices: number[] }>) => {\n return PdfTaskHelper.resolve({\n id: 'id',\n content: new ArrayBuffer(0),\n });\n },\n preparePrintDocument: (doc: PdfDocumentObject, options?: PdfPrintOptions) => {\n return PdfTaskHelper.resolve(new ArrayBuffer(0));\n },\n searchAllPages: (\n doc: PdfDocumentObject,\n keyword: string,\n options?: PdfSearchAllPagesOptions,\n ) => {\n // Create a mock search result\n const mockResult: SearchResult = {\n pageIndex: 0,\n charIndex: 0,\n charCount: keyword.length,\n rects: [\n {\n origin: {\n x: 0,\n y: 0,\n },\n size: {\n width: 50,\n height: 20,\n },\n },\n ],\n context: {\n before: '',\n match: '',\n after: '',\n truncatedLeft: false,\n truncatedRight: false,\n },\n };\n\n // Return a mock SearchAllPagesResult with a single result\n return PdfTaskHelper.resolve<SearchAllPagesResult, PdfPageSearchProgress>({\n results: [mockResult],\n total: 1,\n });\n },\n getAttachments: (doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve([] as PdfAttachmentObject[]);\n },\n addAttachment: (doc: PdfDocumentObject, params: PdfAddAttachmentParams) => {\n return PdfTaskHelper.resolve(true);\n },\n removeAttachment: (doc: PdfDocumentObject, attachment: PdfAttachmentObject) => {\n return PdfTaskHelper.resolve(true);\n },\n readAttachmentContent: (doc: PdfDocumentObject, attachment: PdfAttachmentObject) => {\n return PdfTaskHelper.resolve(new ArrayBuffer(0));\n },\n setFormFieldValue: (\n doc: PdfDocumentObject,\n page: PdfPageObject,\n annotation: PdfWidgetAnnoObject,\n text: FormFieldValue,\n ) => {\n return PdfTaskHelper.resolve(true);\n },\n ...partialEngine,\n };\n\n return engine;\n}\n/**\n * Create mock of pdf document\n * @param doc - partial configuration of document\n * @returns mock of pdf document\n *\n * @public\n */\nexport function createMockPdfDocument(doc?: Partial<PdfDocumentObject>): PdfDocumentObject {\n const pageCount = 10;\n const pageWidth = 100;\n const pageHeight = 200;\n const pages = [];\n for (let i = 0; i < pageCount; i++) {\n pages.push({\n index: i,\n size: {\n width: pageWidth,\n height: pageHeight,\n },\n rotation: Rotation.Degree0,\n });\n }\n\n return {\n id: 'id',\n pageCount: pageCount,\n pages: pages,\n ...doc,\n };\n}\n\n/**\n * Create mock of pdf file\n * @param file - partial configuration of file\n * @returns mock of pdf file\n *\n * @public\n */\nexport function createMockPdfFile(file?: Partial<PdfFile>): PdfFile {\n return {\n id: 'id',\n content: new ArrayBuffer(0),\n };\n}\n"],"names":["doc","pages","i","push","index","size","width","height","rotation","Rotation","Degree0","id","pageCount","partialEngine","engine","openDocumentUrl","jest","fn","file","options","PdfTaskHelper","create","openDocumentBuffer","getMetadata","metadata","title","author","subject","keywords","producer","creator","creationDate","Date","modificationDate","trapped","PdfTrappedStatus","NotSet","resolve","setMetadata","getDocPermissions","getDocUserPermissions","getSignatures","getBookmarks","bookmarks","target","type","destination","pageIndex","zoom","mode","PdfZoomMode","FitPage","view","children","setBookmarks","payload","deleteBookmarks","renderPage","page","scaleFactor","dpr","pageSize","swap","pixelCount","Math","ceil","array","Uint8ClampedArray","rgbValue","j","ab","buffer","realBuffer","ArrayBuffer","Uint8Array","blob","Blob","renderPageRect","rect","renderThumbnail","renderPageAnnotation","annotation","getAllAnnotations","getPageAnnotations","link","PdfAnnotationSubtype","LINK","action","PdfActionType","URI","uri","origin","x","y","annotations","createPageAnnotation","uuidV4","updatePageAnnotation","removePageAnnotation","getPageTextRects","content","font","family","closeDocument","pdf","closeAllDocuments","saveAsCopy","flattenPage","PdfPageFlattenResult","Success","extractPages","pageIndexes","extractText","redactTextInRects","rects","getTextSlices","slices","getPageGlyphs","getPageGeometry","runs","merge","files","mergePages","mergeConfigs","preparePrintDocument","searchAllPages","keyword","mockResult","charIndex","charCount","length","context","before","match","after","truncatedLeft","truncatedRight","results","total","getAttachments","addAttachment","params","removeAttachment","attachment","readAttachmentContent","setFormFieldValue","text"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
package/dist/index.js CHANGED
@@ -1,356 +1,6 @@
1
- import { D, E, P } from "./index-Xn48Fdud.js";
1
+ import { D, E, P } from "./index-BSQFIEHs.js";
2
2
  import { WebWorkerEngine, WorkerTask } from "./lib/webworker/engine.js";
3
- import { PdfTaskHelper, uuidV4, PdfActionType, PdfAnnotationSubtype, Rotation, swap, PdfPageFlattenResult, PdfZoomMode, PdfTrappedStatus } from "@embedpdf/models";
4
3
  import { B, O, a, P as P2, R, b, i, c, r } from "./engine-N_GwaBxA.js";
5
- function createMockPdfEngine(partialEngine) {
6
- const engine = {
7
- openDocumentUrl: jest.fn((file, options) => {
8
- return PdfTaskHelper.create();
9
- }),
10
- openDocumentBuffer: jest.fn((file, options) => {
11
- return PdfTaskHelper.create();
12
- }),
13
- getMetadata: (doc) => {
14
- const metadata = {
15
- title: "title",
16
- author: "author",
17
- subject: "subject",
18
- keywords: "keywords",
19
- producer: "producer",
20
- creator: "creator",
21
- creationDate: /* @__PURE__ */ new Date(),
22
- modificationDate: /* @__PURE__ */ new Date(),
23
- trapped: PdfTrappedStatus.NotSet
24
- };
25
- return PdfTaskHelper.resolve(metadata);
26
- },
27
- setMetadata: (doc, metadata) => {
28
- return PdfTaskHelper.resolve(true);
29
- },
30
- getDocPermissions: (doc) => {
31
- return PdfTaskHelper.resolve(4294967295);
32
- },
33
- getDocUserPermissions: (doc) => {
34
- return PdfTaskHelper.resolve(4294967295);
35
- },
36
- getSignatures: (doc) => {
37
- const signatures = [];
38
- return PdfTaskHelper.resolve(signatures);
39
- },
40
- getBookmarks: (doc) => {
41
- const bookmarks = [];
42
- bookmarks.push(
43
- {
44
- title: "Page 1",
45
- target: {
46
- type: "destination",
47
- destination: {
48
- pageIndex: 1,
49
- zoom: {
50
- mode: PdfZoomMode.FitPage
51
- },
52
- view: []
53
- }
54
- }
55
- },
56
- {
57
- title: "Page 2",
58
- target: {
59
- type: "destination",
60
- destination: {
61
- pageIndex: 2,
62
- zoom: {
63
- mode: PdfZoomMode.FitPage
64
- },
65
- view: []
66
- }
67
- },
68
- children: [
69
- {
70
- title: "Page 3",
71
- target: {
72
- type: "destination",
73
- destination: {
74
- pageIndex: 3,
75
- zoom: {
76
- mode: PdfZoomMode.FitPage
77
- },
78
- view: []
79
- }
80
- }
81
- }
82
- ]
83
- }
84
- );
85
- return PdfTaskHelper.resolve({
86
- bookmarks
87
- });
88
- },
89
- setBookmarks: jest.fn((doc, payload) => {
90
- return PdfTaskHelper.resolve(true);
91
- }),
92
- deleteBookmarks: jest.fn((doc) => {
93
- return PdfTaskHelper.resolve(true);
94
- }),
95
- renderPage: jest.fn(
96
- (doc, page, options) => {
97
- const { scaleFactor = 1, rotation = Rotation.Degree0, dpr = 1 } = options ?? {};
98
- const pageSize = rotation % 2 === 0 ? page.size : swap(page.size);
99
- const imageSize = {
100
- width: Math.ceil(pageSize.width * scaleFactor),
101
- height: Math.ceil(pageSize.height * scaleFactor)
102
- };
103
- const pixelCount = imageSize.width * imageSize.height;
104
- const array = new Uint8ClampedArray(pixelCount * 4);
105
- const rgbValue = page.index % 255;
106
- const alphaValue = 255;
107
- for (let i2 = 0; i2 < pixelCount; i2++) {
108
- for (let j = 0; j < 3; j++) {
109
- const index = i2 * 4 + j;
110
- array[index] = rgbValue;
111
- }
112
- array[i2 * 4 + 3] = alphaValue;
113
- }
114
- const ab = array.buffer;
115
- const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;
116
- const blob = new Blob([realBuffer], { type: "application/octet-stream" });
117
- return PdfTaskHelper.resolve(blob);
118
- }
119
- ),
120
- renderPageRect: jest.fn(
121
- (doc, page, rect, options) => {
122
- const { scaleFactor = 1, rotation = Rotation.Degree0, dpr = 1 } = options ?? {};
123
- const pageSize = rotation % 2 === 0 ? page.size : swap(page.size);
124
- const imageSize = {
125
- width: Math.ceil(pageSize.width * scaleFactor),
126
- height: Math.ceil(pageSize.height * scaleFactor)
127
- };
128
- const pixelCount = imageSize.width * imageSize.height;
129
- const array = new Uint8ClampedArray(pixelCount * 4);
130
- const rgbValue = page.index % 255;
131
- const alphaValue = 255;
132
- for (let i2 = 0; i2 < pixelCount; i2++) {
133
- for (let j = 0; j < 3; j++) {
134
- const index = i2 * 4 + j;
135
- array[index] = rgbValue;
136
- }
137
- array[i2 * 4 + 3] = alphaValue;
138
- }
139
- const ab = array.buffer;
140
- const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;
141
- const blob = new Blob([realBuffer], { type: "application/octet-stream" });
142
- return PdfTaskHelper.resolve(blob);
143
- }
144
- ),
145
- renderThumbnail: jest.fn((doc, page) => {
146
- const thumbnailWidth = page.size.width / 4;
147
- const thumbnailHeight = page.size.height / 4;
148
- const pixelCount = thumbnailWidth * thumbnailHeight;
149
- const array = new Uint8ClampedArray(pixelCount * 4);
150
- const rgbValue = page.index % 255;
151
- const alphaValue = 255;
152
- for (let i2 = 0; i2 < pixelCount; i2++) {
153
- for (let j = 0; j < 3; j++) {
154
- const index = i2 * 4 + j;
155
- array[index] = rgbValue;
156
- }
157
- array[i2 * 4 + 3] = alphaValue;
158
- }
159
- const ab = array.buffer;
160
- const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;
161
- const blob = new Blob([realBuffer], { type: "image/png" });
162
- return PdfTaskHelper.resolve(blob);
163
- }),
164
- renderPageAnnotation: jest.fn(
165
- (doc, page, annotation, options) => {
166
- return PdfTaskHelper.resolve(new Blob([], { type: "image/png" }));
167
- }
168
- ),
169
- getAllAnnotations: jest.fn((doc) => {
170
- return PdfTaskHelper.resolve({});
171
- }),
172
- getPageAnnotations: jest.fn((doc, page) => {
173
- const link = {
174
- pageIndex: page.index,
175
- id: "1",
176
- type: PdfAnnotationSubtype.LINK,
177
- target: {
178
- type: "action",
179
- action: {
180
- type: PdfActionType.URI,
181
- uri: "https://localhost"
182
- }
183
- },
184
- rect: {
185
- origin: {
186
- x: 0,
187
- y: 0
188
- },
189
- size: {
190
- width: 100,
191
- height: 100
192
- }
193
- }
194
- };
195
- const annotations = [];
196
- annotations.push(link);
197
- return PdfTaskHelper.resolve(annotations);
198
- }),
199
- createPageAnnotation: jest.fn(() => {
200
- return PdfTaskHelper.resolve(uuidV4());
201
- }),
202
- updatePageAnnotation: jest.fn(() => {
203
- return PdfTaskHelper.resolve(true);
204
- }),
205
- removePageAnnotation: jest.fn(() => {
206
- return PdfTaskHelper.resolve(true);
207
- }),
208
- getPageTextRects: jest.fn((doc, page) => {
209
- const textRects = [
210
- {
211
- content: "pdf text",
212
- font: {
213
- family: "sans-serif",
214
- size: 12
215
- },
216
- rect: {
217
- origin: {
218
- x: 0,
219
- y: 0
220
- },
221
- size: {
222
- width: 100,
223
- height: 100
224
- }
225
- }
226
- }
227
- ];
228
- return PdfTaskHelper.resolve(textRects);
229
- }),
230
- closeDocument: (pdf) => {
231
- return PdfTaskHelper.resolve(true);
232
- },
233
- closeAllDocuments: () => {
234
- return PdfTaskHelper.resolve(true);
235
- },
236
- saveAsCopy: (pdf) => {
237
- return PdfTaskHelper.resolve(new ArrayBuffer(0));
238
- },
239
- flattenPage: (pdf, page, options) => {
240
- return PdfTaskHelper.resolve(PdfPageFlattenResult.Success);
241
- },
242
- extractPages: (pdf, pageIndexes) => {
243
- return PdfTaskHelper.resolve(new ArrayBuffer(0));
244
- },
245
- extractText: (pdf, pageIndexes) => {
246
- return PdfTaskHelper.resolve("");
247
- },
248
- redactTextInRects: (pdf, page, rects, options) => {
249
- return PdfTaskHelper.resolve(true);
250
- },
251
- getTextSlices: (doc, slices) => {
252
- return PdfTaskHelper.resolve([]);
253
- },
254
- getPageGlyphs: (doc, page) => {
255
- return PdfTaskHelper.resolve([]);
256
- },
257
- getPageGeometry: (doc, page) => {
258
- return PdfTaskHelper.resolve({
259
- runs: []
260
- });
261
- },
262
- merge: (files) => {
263
- return PdfTaskHelper.resolve({
264
- id: "id",
265
- content: new ArrayBuffer(0)
266
- });
267
- },
268
- mergePages: (mergeConfigs) => {
269
- return PdfTaskHelper.resolve({
270
- id: "id",
271
- content: new ArrayBuffer(0)
272
- });
273
- },
274
- preparePrintDocument: (doc, options) => {
275
- return PdfTaskHelper.resolve(new ArrayBuffer(0));
276
- },
277
- searchAllPages: (doc, keyword, options) => {
278
- const mockResult = {
279
- pageIndex: 0,
280
- charIndex: 0,
281
- charCount: keyword.length,
282
- rects: [
283
- {
284
- origin: {
285
- x: 0,
286
- y: 0
287
- },
288
- size: {
289
- width: 50,
290
- height: 20
291
- }
292
- }
293
- ],
294
- context: {
295
- before: "",
296
- match: "",
297
- after: "",
298
- truncatedLeft: false,
299
- truncatedRight: false
300
- }
301
- };
302
- return PdfTaskHelper.resolve({
303
- results: [mockResult],
304
- total: 1
305
- });
306
- },
307
- getAttachments: (doc) => {
308
- return PdfTaskHelper.resolve([]);
309
- },
310
- addAttachment: (doc, params) => {
311
- return PdfTaskHelper.resolve(true);
312
- },
313
- removeAttachment: (doc, attachment) => {
314
- return PdfTaskHelper.resolve(true);
315
- },
316
- readAttachmentContent: (doc, attachment) => {
317
- return PdfTaskHelper.resolve(new ArrayBuffer(0));
318
- },
319
- setFormFieldValue: (doc, page, annotation, text) => {
320
- return PdfTaskHelper.resolve(true);
321
- },
322
- ...partialEngine
323
- };
324
- return engine;
325
- }
326
- function createMockPdfDocument(doc) {
327
- const pageCount = 10;
328
- const pageWidth = 100;
329
- const pageHeight = 200;
330
- const pages = [];
331
- for (let i2 = 0; i2 < pageCount; i2++) {
332
- pages.push({
333
- index: i2,
334
- size: {
335
- width: pageWidth,
336
- height: pageHeight
337
- },
338
- rotation: Rotation.Degree0
339
- });
340
- }
341
- return {
342
- id: "id",
343
- pageCount,
344
- pages,
345
- ...doc
346
- };
347
- }
348
- function createMockPdfFile(file) {
349
- return {
350
- id: "id",
351
- content: new ArrayBuffer(0)
352
- };
353
- }
354
4
  export {
355
5
  B as BitmapFormat,
356
6
  D as DEFAULT_PDFIUM_WASM_URL,
@@ -363,9 +13,6 @@ export {
363
13
  WebWorkerEngine,
364
14
  WorkerTask,
365
15
  b as browserImageDataToBlobConverter,
366
- createMockPdfDocument,
367
- createMockPdfEngine,
368
- createMockPdfFile,
369
16
  i as isValidCustomKey,
370
17
  c as readArrayBuffer,
371
18
  r as readString
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/lib/mock/index.ts"],"sourcesContent":["import {\n PdfDocumentObject,\n PdfEngine,\n PdfPageObject,\n PdfAnnotationSubtype,\n PdfLinkAnnoObject,\n Rotation,\n swap,\n PdfZoomMode,\n PdfActionType,\n PdfAnnotationObject,\n PdfBookmarkObject,\n PdfTextRectObject,\n SearchResult,\n PdfAttachmentObject,\n PdfSignatureObject,\n Rect,\n PdfFile,\n PdfWidgetAnnoObject,\n FormFieldValue,\n PdfTaskHelper,\n PdfPageFlattenResult,\n SearchAllPagesResult,\n PdfOpenDocumentUrlOptions,\n PdfFileUrl,\n PdfGlyphObject,\n PdfPageGeometry,\n PageTextSlice,\n PdfPageSearchProgress,\n PdfRenderPageOptions,\n PdfRenderPageAnnotationOptions,\n PdfFlattenPageOptions,\n PdfRedactTextOptions,\n PdfSearchAllPagesOptions,\n PdfOpenDocumentBufferOptions,\n uuidV4,\n PdfMetadataObject,\n PdfTask,\n PdfPrintOptions,\n PdfTrappedStatus,\n PdfAddAttachmentParams,\n} from '@embedpdf/models';\n\n/**\n * Create mock of pdf engine\n * @param partialEngine - partial configuration of engine\n * @returns - mock of pdf engine\n *\n * @public\n */\nexport function createMockPdfEngine(partialEngine?: Partial<PdfEngine>): PdfEngine {\n const engine: PdfEngine = {\n openDocumentUrl: jest.fn((file: PdfFileUrl, options?: PdfOpenDocumentUrlOptions) => {\n return PdfTaskHelper.create();\n }),\n openDocumentBuffer: jest.fn((file: PdfFile, options?: PdfOpenDocumentBufferOptions) => {\n return PdfTaskHelper.create();\n }),\n getMetadata: (doc: PdfDocumentObject) => {\n const metadata: PdfMetadataObject = {\n title: 'title',\n author: 'author',\n subject: 'subject',\n keywords: 'keywords',\n producer: 'producer',\n creator: 'creator',\n creationDate: new Date(),\n modificationDate: new Date(),\n trapped: PdfTrappedStatus.NotSet,\n };\n return PdfTaskHelper.resolve(metadata);\n },\n setMetadata: (doc: PdfDocumentObject, metadata: Partial<PdfMetadataObject>) => {\n return PdfTaskHelper.resolve(true);\n },\n getDocPermissions: (doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(0xffffffff);\n },\n getDocUserPermissions: (doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(0xffffffff);\n },\n getSignatures: (doc: PdfDocumentObject) => {\n const signatures: PdfSignatureObject[] = [];\n return PdfTaskHelper.resolve(signatures);\n },\n getBookmarks: (doc: PdfDocumentObject) => {\n const bookmarks: PdfBookmarkObject[] = [];\n bookmarks.push(\n {\n title: 'Page 1',\n target: {\n type: 'destination',\n destination: {\n pageIndex: 1,\n zoom: {\n mode: PdfZoomMode.FitPage,\n },\n view: [],\n },\n },\n },\n {\n title: 'Page 2',\n target: {\n type: 'destination',\n destination: {\n pageIndex: 2,\n zoom: {\n mode: PdfZoomMode.FitPage,\n },\n view: [],\n },\n },\n children: [\n {\n title: 'Page 3',\n target: {\n type: 'destination',\n destination: {\n pageIndex: 3,\n zoom: {\n mode: PdfZoomMode.FitPage,\n },\n view: [],\n },\n },\n },\n ],\n },\n );\n return PdfTaskHelper.resolve({\n bookmarks,\n });\n },\n setBookmarks: jest.fn((doc: PdfDocumentObject, payload: PdfBookmarkObject[]) => {\n return PdfTaskHelper.resolve(true);\n }),\n deleteBookmarks: jest.fn((doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(true);\n }),\n renderPage: jest.fn(\n (doc: PdfDocumentObject, page: PdfPageObject, options?: PdfRenderPageOptions) => {\n const { scaleFactor = 1, rotation = Rotation.Degree0, dpr = 1 } = options ?? {};\n const pageSize = rotation % 2 === 0 ? page.size : swap(page.size);\n const imageSize = {\n width: Math.ceil(pageSize.width * scaleFactor),\n height: Math.ceil(pageSize.height * scaleFactor),\n };\n const pixelCount = imageSize.width * imageSize.height;\n const array = new Uint8ClampedArray(pixelCount * 4);\n const rgbValue = page.index % 255;\n const alphaValue = 255;\n for (let i = 0; i < pixelCount; i++) {\n for (let j = 0; j < 3; j++) {\n const index = i * 4 + j;\n array[index] = rgbValue;\n }\n array[i * 4 + 3] = alphaValue;\n }\n\n const ab = array.buffer;\n const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;\n const blob = new Blob([realBuffer], { type: 'application/octet-stream' });\n return PdfTaskHelper.resolve(blob);\n },\n ),\n renderPageRect: jest.fn(\n (doc: PdfDocumentObject, page: PdfPageObject, rect: Rect, options?: PdfRenderPageOptions) => {\n const { scaleFactor = 1, rotation = Rotation.Degree0, dpr = 1 } = options ?? {};\n const pageSize = rotation % 2 === 0 ? page.size : swap(page.size);\n const imageSize = {\n width: Math.ceil(pageSize.width * scaleFactor),\n height: Math.ceil(pageSize.height * scaleFactor),\n };\n const pixelCount = imageSize.width * imageSize.height;\n const array = new Uint8ClampedArray(pixelCount * 4);\n const rgbValue = page.index % 255;\n const alphaValue = 255;\n for (let i = 0; i < pixelCount; i++) {\n for (let j = 0; j < 3; j++) {\n const index = i * 4 + j;\n array[index] = rgbValue;\n }\n array[i * 4 + 3] = alphaValue;\n }\n\n const ab = array.buffer;\n const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;\n const blob = new Blob([realBuffer], { type: 'application/octet-stream' });\n return PdfTaskHelper.resolve(blob);\n },\n ),\n renderThumbnail: jest.fn((doc: PdfDocumentObject, page: PdfPageObject) => {\n const thumbnailWidth = page.size.width / 4;\n const thumbnailHeight = page.size.height / 4;\n const pixelCount = thumbnailWidth * thumbnailHeight;\n const array = new Uint8ClampedArray(pixelCount * 4);\n const rgbValue = page.index % 255;\n const alphaValue = 255;\n for (let i = 0; i < pixelCount; i++) {\n for (let j = 0; j < 3; j++) {\n const index = i * 4 + j;\n array[index] = rgbValue;\n }\n array[i * 4 + 3] = alphaValue;\n }\n\n const ab = array.buffer;\n const realBuffer = ab instanceof ArrayBuffer ? ab : new Uint8Array(array).buffer;\n const blob = new Blob([realBuffer], { type: 'image/png' });\n\n return PdfTaskHelper.resolve(blob);\n }),\n renderPageAnnotation: jest.fn(\n (\n doc: PdfDocumentObject,\n page: PdfPageObject,\n annotation: PdfAnnotationObject,\n options?: PdfRenderPageAnnotationOptions,\n ) => {\n return PdfTaskHelper.resolve(new Blob([], { type: 'image/png' }));\n },\n ),\n getAllAnnotations: jest.fn((doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve({});\n }),\n getPageAnnotations: jest.fn((doc: PdfDocumentObject, page: PdfPageObject) => {\n const link: PdfLinkAnnoObject = {\n pageIndex: page.index,\n id: '1',\n type: PdfAnnotationSubtype.LINK,\n target: {\n type: 'action',\n action: {\n type: PdfActionType.URI,\n uri: 'https://localhost',\n },\n },\n rect: {\n origin: {\n x: 0,\n y: 0,\n },\n size: {\n width: 100,\n height: 100,\n },\n },\n };\n const annotations: PdfAnnotationObject[] = [];\n annotations.push(link);\n return PdfTaskHelper.resolve(annotations);\n }),\n createPageAnnotation: jest.fn(() => {\n return PdfTaskHelper.resolve(uuidV4());\n }),\n updatePageAnnotation: jest.fn(() => {\n return PdfTaskHelper.resolve(true);\n }),\n removePageAnnotation: jest.fn(() => {\n return PdfTaskHelper.resolve(true);\n }),\n getPageTextRects: jest.fn((doc: PdfDocumentObject, page: PdfPageObject) => {\n const textRects: PdfTextRectObject[] = [\n {\n content: 'pdf text',\n font: {\n family: 'sans-serif',\n size: 12,\n },\n rect: {\n origin: {\n x: 0,\n y: 0,\n },\n size: {\n width: 100,\n height: 100,\n },\n },\n },\n ];\n return PdfTaskHelper.resolve(textRects);\n }),\n closeDocument: (pdf: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(true);\n },\n closeAllDocuments: () => {\n return PdfTaskHelper.resolve(true);\n },\n saveAsCopy: (pdf: PdfDocumentObject) => {\n return PdfTaskHelper.resolve(new ArrayBuffer(0));\n },\n flattenPage: (pdf: PdfDocumentObject, page: PdfPageObject, options?: PdfFlattenPageOptions) => {\n return PdfTaskHelper.resolve<PdfPageFlattenResult>(PdfPageFlattenResult.Success);\n },\n extractPages: (pdf: PdfDocumentObject, pageIndexes: number[]) => {\n return PdfTaskHelper.resolve(new ArrayBuffer(0));\n },\n extractText: (pdf: PdfDocumentObject, pageIndexes: number[]) => {\n return PdfTaskHelper.resolve('');\n },\n redactTextInRects: (\n pdf: PdfDocumentObject,\n page: PdfPageObject,\n rects: Rect[],\n options?: PdfRedactTextOptions,\n ) => {\n return PdfTaskHelper.resolve(true);\n },\n getTextSlices: (doc: PdfDocumentObject, slices: PageTextSlice[]) => {\n return PdfTaskHelper.resolve([] as string[]);\n },\n getPageGlyphs: (doc: PdfDocumentObject, page: PdfPageObject) => {\n return PdfTaskHelper.resolve([] as PdfGlyphObject[]);\n },\n getPageGeometry: (doc: PdfDocumentObject, page: PdfPageObject) => {\n return PdfTaskHelper.resolve({\n runs: [],\n } as PdfPageGeometry);\n },\n merge: (files: PdfFile[]) => {\n return PdfTaskHelper.resolve({\n id: 'id',\n content: new ArrayBuffer(0),\n });\n },\n mergePages: (mergeConfigs: Array<{ docId: string; pageIndices: number[] }>) => {\n return PdfTaskHelper.resolve({\n id: 'id',\n content: new ArrayBuffer(0),\n });\n },\n preparePrintDocument: (doc: PdfDocumentObject, options?: PdfPrintOptions) => {\n return PdfTaskHelper.resolve(new ArrayBuffer(0));\n },\n searchAllPages: (\n doc: PdfDocumentObject,\n keyword: string,\n options?: PdfSearchAllPagesOptions,\n ) => {\n // Create a mock search result\n const mockResult: SearchResult = {\n pageIndex: 0,\n charIndex: 0,\n charCount: keyword.length,\n rects: [\n {\n origin: {\n x: 0,\n y: 0,\n },\n size: {\n width: 50,\n height: 20,\n },\n },\n ],\n context: {\n before: '',\n match: '',\n after: '',\n truncatedLeft: false,\n truncatedRight: false,\n },\n };\n\n // Return a mock SearchAllPagesResult with a single result\n return PdfTaskHelper.resolve<SearchAllPagesResult, PdfPageSearchProgress>({\n results: [mockResult],\n total: 1,\n });\n },\n getAttachments: (doc: PdfDocumentObject) => {\n return PdfTaskHelper.resolve([] as PdfAttachmentObject[]);\n },\n addAttachment: (doc: PdfDocumentObject, params: PdfAddAttachmentParams) => {\n return PdfTaskHelper.resolve(true);\n },\n removeAttachment: (doc: PdfDocumentObject, attachment: PdfAttachmentObject) => {\n return PdfTaskHelper.resolve(true);\n },\n readAttachmentContent: (doc: PdfDocumentObject, attachment: PdfAttachmentObject) => {\n return PdfTaskHelper.resolve(new ArrayBuffer(0));\n },\n setFormFieldValue: (\n doc: PdfDocumentObject,\n page: PdfPageObject,\n annotation: PdfWidgetAnnoObject,\n text: FormFieldValue,\n ) => {\n return PdfTaskHelper.resolve(true);\n },\n ...partialEngine,\n };\n\n return engine;\n}\n/**\n * Create mock of pdf document\n * @param doc - partial configuration of document\n * @returns mock of pdf document\n *\n * @public\n */\nexport function createMockPdfDocument(doc?: Partial<PdfDocumentObject>): PdfDocumentObject {\n const pageCount = 10;\n const pageWidth = 100;\n const pageHeight = 200;\n const pages = [];\n for (let i = 0; i < pageCount; i++) {\n pages.push({\n index: i,\n size: {\n width: pageWidth,\n height: pageHeight,\n },\n rotation: Rotation.Degree0,\n });\n }\n\n return {\n id: 'id',\n pageCount: pageCount,\n pages: pages,\n ...doc,\n };\n}\n\n/**\n * Create mock of pdf file\n * @param file - partial configuration of file\n * @returns mock of pdf file\n *\n * @public\n */\nexport function createMockPdfFile(file?: Partial<PdfFile>): PdfFile {\n return {\n id: 'id',\n content: new ArrayBuffer(0),\n };\n}\n"],"names":["i"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;"}
@@ -4,4 +4,3 @@
4
4
  */
5
5
  export * from './pdfium';
6
6
  export * from './webworker';
7
- export * from './mock';
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("../../engine-Z4iXwySK.cjs"),e=require("../../index-D0i_Y0hT.cjs");exports.BitmapFormat=r.BitmapFormat,exports.OffscreenCanvasError=r.OffscreenCanvasError,exports.PdfiumEngine=r.PdfiumEngine,exports.PdfiumErrorCode=r.PdfiumErrorCode,exports.RenderFlag=r.RenderFlag,exports.browserImageDataToBlobConverter=r.browserImageDataToBlobConverter,exports.isValidCustomKey=r.isValidCustomKey,exports.readArrayBuffer=r.readArrayBuffer,exports.readString=r.readString,exports.DEFAULT_PDFIUM_WASM_URL=e.DEFAULT_PDFIUM_WASM_URL,exports.PdfiumEngineRunner=e.PdfiumEngineRunner;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("../../engine-Z4iXwySK.cjs"),e=require("../../index-DtwU4yb7.cjs");exports.BitmapFormat=r.BitmapFormat,exports.OffscreenCanvasError=r.OffscreenCanvasError,exports.PdfiumEngine=r.PdfiumEngine,exports.PdfiumErrorCode=r.PdfiumErrorCode,exports.RenderFlag=r.RenderFlag,exports.browserImageDataToBlobConverter=r.browserImageDataToBlobConverter,exports.isValidCustomKey=r.isValidCustomKey,exports.readArrayBuffer=r.readArrayBuffer,exports.readString=r.readString,exports.DEFAULT_PDFIUM_WASM_URL=e.DEFAULT_PDFIUM_WASM_URL,exports.PdfiumEngineRunner=e.PdfiumEngineRunner;
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1,5 +1,5 @@
1
1
  import { B, O, a, P, R, b, i, c, r } from "../../engine-N_GwaBxA.js";
2
- import { D, P as P2 } from "../../index-Xn48Fdud.js";
2
+ import { D, P as P2 } from "../../index-BSQFIEHs.js";
3
3
  export {
4
4
  B as BitmapFormat,
5
5
  D as DEFAULT_PDFIUM_WASM_URL,
@@ -1,2 +1,2 @@
1
- "use strict";Object.create,Object.defineProperty,Object.getOwnPropertyDescriptor,Object.getOwnPropertyNames,Object.getPrototypeOf,Object.prototype.hasOwnProperty;Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("preact/hooks"),r=require("preact"),t=require("@embedpdf/models"),n=require("preact/jsx-runtime"),i="https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.3.16/dist/pdfium.wasm";const o=r.createContext(void 0);function s(){const r=e.useContext(o);if(void 0===r)throw new Error("useEngineContext must be used within a PdfEngineProvider");return r}exports.PdfEngineProvider=function({children:e,engine:r,isLoading:t,error:i}){const s={engine:r,isLoading:t,error:i};return n.jsx(o.Provider,{value:s,children:e})},exports.useEngine=function(){const{engine:e,error:r}=s();if(r)throw r;return e},exports.useEngineContext=s,exports.usePdfiumEngine=function(r){const{wasmUrl:n=i,worker:o=!0,logger:s}=r??{},[u,c]=e.useState(null),[d,a]=e.useState(!0),[l,p]=e.useState(null),g=e.useRef(null);return e.useEffect((()=>{let e=!1;return(async()=>{try{const{createPdfiumEngine:e}=o?await import("@embedpdf/engines/pdfium-worker-engine"):await import("@embedpdf/engines/pdfium-direct-engine"),r=await e(n,s);g.current=r,r.initialize().wait((()=>{c(r),a(!1)}),(e=>{p(new Error(e.reason.message)),a(!1)}))}catch(r){e||(p(r),a(!1))}})(),()=>{var r,n;e=!0,null==(n=null==(r=g.current)?void 0:r.closeAllDocuments)||n.call(r).wait((()=>{var e,r;null==(r=null==(e=g.current)?void 0:e.destroy)||r.call(e),g.current=null}),t.ignore)}}),[n,o,s]),{engine:u,isLoading:d,error:l}};
1
+ "use strict";Object.create,Object.defineProperty,Object.getOwnPropertyDescriptor,Object.getOwnPropertyNames,Object.getPrototypeOf,Object.prototype.hasOwnProperty;Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("preact/hooks"),r=require("preact"),t=require("@embedpdf/models"),n=require("preact/jsx-runtime"),i="https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.4.0/dist/pdfium.wasm";const o=r.createContext(void 0);function s(){const r=e.useContext(o);if(void 0===r)throw new Error("useEngineContext must be used within a PdfEngineProvider");return r}exports.PdfEngineProvider=function({children:e,engine:r,isLoading:t,error:i}){const s={engine:r,isLoading:t,error:i};return n.jsx(o.Provider,{value:s,children:e})},exports.useEngine=function(){const{engine:e,error:r}=s();if(r)throw r;return e},exports.useEngineContext=s,exports.usePdfiumEngine=function(r){const{wasmUrl:n=i,worker:o=!0,logger:s}=r??{},[u,c]=e.useState(null),[d,a]=e.useState(!0),[l,p]=e.useState(null),g=e.useRef(null);return e.useEffect((()=>{let e=!1;return(async()=>{try{const{createPdfiumEngine:e}=o?await import("@embedpdf/engines/pdfium-worker-engine"):await import("@embedpdf/engines/pdfium-direct-engine"),r=await e(n,s);g.current=r,r.initialize().wait((()=>{c(r),a(!1)}),(e=>{p(new Error(e.reason.message)),a(!1)}))}catch(r){e||(p(r),a(!1))}})(),()=>{var r,n;e=!0,null==(n=null==(r=g.current)?void 0:r.closeAllDocuments)||n.call(r).wait((()=>{var e,r;null==(r=null==(e=g.current)?void 0:e.destroy)||r.call(e),g.current=null}),t.ignore)}}),[n,o,s]),{engine:u,isLoading:d,error:l}};
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../src/shared/hooks/use-pdfium-engine.ts","../../src/shared/context/pdf-engine-context.ts","../../src/shared/hooks/use-engine-context.ts","../../src/shared/components/pdf-engine-provider.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from '@framework';\nimport { ignore, Logger, PdfEngine } from '@embedpdf/models';\n\nconst defaultWasmUrl = `https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm`;\n\ninterface UsePdfiumEngineProps {\n wasmUrl?: string;\n worker?: boolean;\n logger?: Logger;\n}\n\nexport function usePdfiumEngine(config?: UsePdfiumEngineProps) {\n const { wasmUrl = defaultWasmUrl, worker = true, logger } = config ?? {};\n\n const [engine, setEngine] = useState<PdfEngine | null>(null);\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<Error | null>(null);\n const engineRef = useRef<PdfEngine | null>(null);\n\n useEffect(() => {\n let cancelled = false;\n\n (async () => {\n try {\n const { createPdfiumEngine } = worker\n ? await import('@embedpdf/engines/pdfium-worker-engine')\n : await import('@embedpdf/engines/pdfium-direct-engine');\n\n const pdfEngine = await createPdfiumEngine(wasmUrl, logger);\n engineRef.current = pdfEngine;\n pdfEngine.initialize().wait(\n () => {\n setEngine(pdfEngine);\n setLoading(false);\n },\n (e) => {\n setError(new Error(e.reason.message));\n setLoading(false);\n },\n );\n } catch (e) {\n if (!cancelled) {\n setError(e as Error);\n setLoading(false);\n }\n }\n })();\n\n return () => {\n cancelled = true;\n engineRef.current?.closeAllDocuments?.().wait(() => {\n engineRef.current?.destroy?.();\n engineRef.current = null;\n }, ignore);\n };\n }, [wasmUrl, worker, logger]);\n\n return { engine, isLoading: loading, error };\n}\n","import { createContext } from '@framework';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineContextState {\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\nexport const PdfEngineContext = createContext<PdfEngineContextState | undefined>(undefined);\n","import { useContext } from '@framework';\nimport { PdfEngineContext, PdfEngineContextState } from '../context';\n\n/**\n * Hook to access the PDF engine from context.\n * @returns The PDF engine context state\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function useEngineContext(): PdfEngineContextState {\n const contextValue = useContext(PdfEngineContext);\n\n if (contextValue === undefined) {\n throw new Error('useEngineContext must be used within a PdfEngineProvider');\n }\n\n return contextValue;\n}\n\n/**\n * Hook to access the PDF engine, with a more convenient API.\n * @returns The PDF engine or null if loading/error\n */\nexport function useEngine() {\n const { engine, error } = useEngineContext();\n\n if (error) {\n throw error;\n }\n\n return engine;\n}\n","import { ReactNode } from '@framework';\nimport { PdfEngineContext } from '../context';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineProviderProps {\n children: ReactNode;\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\n/**\n * Provider component that makes a PDF engine instance available\n * to all child components via context.\n *\n * This provider is completely engine-agnostic - it accepts any engine\n * and its loading state from the parent component.\n */\nexport function PdfEngineProvider({ children, engine, isLoading, error }: PdfEngineProviderProps) {\n const contextValue = {\n engine,\n isLoading,\n error,\n };\n\n return <PdfEngineContext.Provider value={contextValue}>{children}</PdfEngineContext.Provider>;\n}\n"],"names":["defaultWasmUrl","PdfEngineContext","createContext","useEngineContext","contextValue","useContext","Error","children","engine","isLoading","error","Provider","value","config","wasmUrl","worker","logger","setEngine","useState","loading","setLoading","setError","engineRef","useRef","useEffect","cancelled","createPdfiumEngine","import","pdfEngine","current","initialize","wait","e","reason","message","_b","_a","closeAllDocuments","call","destroy","ignore"],"mappings":"uVAGMA,EAAiB,wECMV,MAAAC,EAAmBC,qBAAiD,GCD1E,SAASC,IACR,MAAAC,EAAeC,aAAWJ,GAEhC,QAAqB,IAAjBG,EACI,MAAA,IAAIE,MAAM,4DAGX,OAAAF,CACT,2BCEO,UAA2BG,SAAEA,EAAAC,OAAUA,EAAQC,UAAAA,EAAAC,MAAWA,IAC/D,MAAMN,EAAe,CACnBI,SACAC,YACAC,sBAGMT,EAAiBU,SAAjB,CAA0BC,MAAOR,EAAeG,YAC1D,oBDJO,WACL,MAAMC,OAAEA,EAAAE,MAAQA,GAAUP,IAE1B,GAAIO,EACI,MAAAA,EAGD,OAAAF,CACT,qDFnBO,SAAyBK,GACxB,MAAAC,QAAEA,EAAUd,EAAgBe,OAAAA,GAAS,SAAMC,GAAWH,GAAU,CAAC,GAEhEL,EAAQS,GAAaC,EAAAA,SAA2B,OAChDC,EAASC,GAAcF,EAAAA,UAAS,IAChCR,EAAOW,GAAYH,EAAAA,SAAuB,MAC3CI,EAAYC,SAAyB,MAwC3C,OAtCAC,EAAAA,WAAU,KACR,IAAIC,GAAY,EA4BhB,MA1BA,WACM,IACI,MAAAC,mBAAEA,GAAuBX,QACrBY,OAAO,gDACPA,OAAO,0CAEXC,QAAkBF,EAAmBZ,EAASE,GACpDM,EAAUO,QAAUD,EACpBA,EAAUE,aAAaC,MACrB,KACEd,EAAUW,GACVR,GAAW,EAAK,IAEjBY,IACCX,EAAS,IAAIf,MAAM0B,EAAEC,OAAOC,UAC5Bd,GAAW,EAAK,UAGbY,GACFP,IACHJ,EAASW,GACTZ,GAAW,GACb,CAED,EAxBH,GA0BO,aACOK,GAAA,EACZ,OAAAU,EAAA,OAAAC,EAAAd,EAAUO,cAAV,EAAAO,EAAmBC,oBAAnBF,EAAAG,KAAAF,GAAyCL,MAAK,aAC5C,OAAAI,EAAA,OAAAC,EAAAd,EAAUO,gBAAVO,EAAmBG,UAAnBJ,EAAAG,KAAAF,GACAd,EAAUO,QAAU,IAAA,GACnBW,UACL,GACC,CAAC1B,EAASC,EAAQC,IAEd,CAAER,SAAQC,UAAWU,EAAST,QACvC"}
1
+ {"version":3,"file":"index.cjs","sources":["../../src/shared/hooks/use-pdfium-engine.ts","../../src/shared/context/pdf-engine-context.ts","../../src/shared/hooks/use-engine-context.ts","../../src/shared/components/pdf-engine-provider.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from '@framework';\nimport { ignore, Logger, PdfEngine } from '@embedpdf/models';\n\nconst defaultWasmUrl = `https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm`;\n\ninterface UsePdfiumEngineProps {\n wasmUrl?: string;\n worker?: boolean;\n logger?: Logger;\n}\n\nexport function usePdfiumEngine(config?: UsePdfiumEngineProps) {\n const { wasmUrl = defaultWasmUrl, worker = true, logger } = config ?? {};\n\n const [engine, setEngine] = useState<PdfEngine | null>(null);\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<Error | null>(null);\n const engineRef = useRef<PdfEngine | null>(null);\n\n useEffect(() => {\n let cancelled = false;\n\n (async () => {\n try {\n const { createPdfiumEngine } = worker\n ? await import('@embedpdf/engines/pdfium-worker-engine')\n : await import('@embedpdf/engines/pdfium-direct-engine');\n\n const pdfEngine = await createPdfiumEngine(wasmUrl, logger);\n engineRef.current = pdfEngine;\n pdfEngine.initialize().wait(\n () => {\n setEngine(pdfEngine);\n setLoading(false);\n },\n (e) => {\n setError(new Error(e.reason.message));\n setLoading(false);\n },\n );\n } catch (e) {\n if (!cancelled) {\n setError(e as Error);\n setLoading(false);\n }\n }\n })();\n\n return () => {\n cancelled = true;\n engineRef.current?.closeAllDocuments?.().wait(() => {\n engineRef.current?.destroy?.();\n engineRef.current = null;\n }, ignore);\n };\n }, [wasmUrl, worker, logger]);\n\n return { engine, isLoading: loading, error };\n}\n","import { createContext } from '@framework';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineContextState {\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\nexport const PdfEngineContext = createContext<PdfEngineContextState | undefined>(undefined);\n","import { useContext } from '@framework';\nimport { PdfEngineContext, PdfEngineContextState } from '../context';\n\n/**\n * Hook to access the PDF engine from context.\n * @returns The PDF engine context state\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function useEngineContext(): PdfEngineContextState {\n const contextValue = useContext(PdfEngineContext);\n\n if (contextValue === undefined) {\n throw new Error('useEngineContext must be used within a PdfEngineProvider');\n }\n\n return contextValue;\n}\n\n/**\n * Hook to access the PDF engine, with a more convenient API.\n * @returns The PDF engine or null if loading/error\n */\nexport function useEngine() {\n const { engine, error } = useEngineContext();\n\n if (error) {\n throw error;\n }\n\n return engine;\n}\n","import { ReactNode } from '@framework';\nimport { PdfEngineContext } from '../context';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineProviderProps {\n children: ReactNode;\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\n/**\n * Provider component that makes a PDF engine instance available\n * to all child components via context.\n *\n * This provider is completely engine-agnostic - it accepts any engine\n * and its loading state from the parent component.\n */\nexport function PdfEngineProvider({ children, engine, isLoading, error }: PdfEngineProviderProps) {\n const contextValue = {\n engine,\n isLoading,\n error,\n };\n\n return <PdfEngineContext.Provider value={contextValue}>{children}</PdfEngineContext.Provider>;\n}\n"],"names":["defaultWasmUrl","PdfEngineContext","createContext","useEngineContext","contextValue","useContext","Error","children","engine","isLoading","error","Provider","value","config","wasmUrl","worker","logger","setEngine","useState","loading","setLoading","setError","engineRef","useRef","useEffect","cancelled","createPdfiumEngine","import","pdfEngine","current","initialize","wait","e","reason","message","_b","_a","closeAllDocuments","call","destroy","ignore"],"mappings":"uVAGMA,EAAiB,uECMV,MAAAC,EAAmBC,qBAAiD,GCD1E,SAASC,IACR,MAAAC,EAAeC,aAAWJ,GAEhC,QAAqB,IAAjBG,EACI,MAAA,IAAIE,MAAM,4DAGX,OAAAF,CACT,2BCEO,UAA2BG,SAAEA,EAAAC,OAAUA,EAAQC,UAAAA,EAAAC,MAAWA,IAC/D,MAAMN,EAAe,CACnBI,SACAC,YACAC,sBAGMT,EAAiBU,SAAjB,CAA0BC,MAAOR,EAAeG,YAC1D,oBDJO,WACL,MAAMC,OAAEA,EAAAE,MAAQA,GAAUP,IAE1B,GAAIO,EACI,MAAAA,EAGD,OAAAF,CACT,qDFnBO,SAAyBK,GACxB,MAAAC,QAAEA,EAAUd,EAAgBe,OAAAA,GAAS,SAAMC,GAAWH,GAAU,CAAC,GAEhEL,EAAQS,GAAaC,EAAAA,SAA2B,OAChDC,EAASC,GAAcF,EAAAA,UAAS,IAChCR,EAAOW,GAAYH,EAAAA,SAAuB,MAC3CI,EAAYC,SAAyB,MAwC3C,OAtCAC,EAAAA,WAAU,KACR,IAAIC,GAAY,EA4BhB,MA1BA,WACM,IACI,MAAAC,mBAAEA,GAAuBX,QACrBY,OAAO,gDACPA,OAAO,0CAEXC,QAAkBF,EAAmBZ,EAASE,GACpDM,EAAUO,QAAUD,EACpBA,EAAUE,aAAaC,MACrB,KACEd,EAAUW,GACVR,GAAW,EAAK,IAEjBY,IACCX,EAAS,IAAIf,MAAM0B,EAAEC,OAAOC,UAC5Bd,GAAW,EAAK,UAGbY,GACFP,IACHJ,EAASW,GACTZ,GAAW,GACb,CAED,EAxBH,GA0BO,aACOK,GAAA,EACZ,OAAAU,EAAA,OAAAC,EAAAd,EAAUO,cAAV,EAAAO,EAAmBC,oBAAnBF,EAAAG,KAAAF,GAAyCL,MAAK,aAC5C,OAAAI,EAAA,OAAAC,EAAAd,EAAUO,gBAAVO,EAAmBG,UAAnBJ,EAAAG,KAAAF,GACAd,EAAUO,QAAU,IAAA,GACnBW,UACL,GACC,CAAC1B,EAASC,EAAQC,IAEd,CAAER,SAAQC,UAAWU,EAAST,QACvC"}
@@ -2,7 +2,7 @@ import { useState, useRef, useEffect, useContext } from "preact/hooks";
2
2
  import { createContext } from "preact";
3
3
  import { ignore } from "@embedpdf/models";
4
4
  import { jsx } from "preact/jsx-runtime";
5
- const defaultWasmUrl = `https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.3.16/dist/pdfium.wasm`;
5
+ const defaultWasmUrl = `https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.4.0/dist/pdfium.wasm`;
6
6
  function usePdfiumEngine(config) {
7
7
  const { wasmUrl = defaultWasmUrl, worker = true, logger } = config ?? {};
8
8
  const [engine, setEngine] = useState(null);
@@ -1,2 +1,2 @@
1
- "use strict";Object.create,Object.defineProperty,Object.getOwnPropertyDescriptor,Object.getOwnPropertyNames,Object.getPrototypeOf,Object.prototype.hasOwnProperty;Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),r=require("@embedpdf/models"),t=require("react/jsx-runtime"),n="https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.3.16/dist/pdfium.wasm";const i=e.createContext(void 0);function o(){const r=e.useContext(i);if(void 0===r)throw new Error("useEngineContext must be used within a PdfEngineProvider");return r}exports.PdfEngineProvider=function({children:e,engine:r,isLoading:n,error:o}){const s={engine:r,isLoading:n,error:o};return t.jsx(i.Provider,{value:s,children:e})},exports.useEngine=function(){const{engine:e,error:r}=o();if(r)throw r;return e},exports.useEngineContext=o,exports.usePdfiumEngine=function(t){const{wasmUrl:i=n,worker:o=!0,logger:s}=t??{},[u,c]=e.useState(null),[d,a]=e.useState(!0),[l,g]=e.useState(null),p=e.useRef(null);return e.useEffect((()=>{let e=!1;return(async()=>{try{const{createPdfiumEngine:e}=o?await import("@embedpdf/engines/pdfium-worker-engine"):await import("@embedpdf/engines/pdfium-direct-engine"),r=await e(i,s);p.current=r,r.initialize().wait((()=>{c(r),a(!1)}),(e=>{g(new Error(e.reason.message)),a(!1)}))}catch(r){e||(g(r),a(!1))}})(),()=>{var t,n;e=!0,null==(n=null==(t=p.current)?void 0:t.closeAllDocuments)||n.call(t).wait((()=>{var e,r;null==(r=null==(e=p.current)?void 0:e.destroy)||r.call(e),p.current=null}),r.ignore)}}),[i,o,s]),{engine:u,isLoading:d,error:l}};
1
+ "use strict";Object.create,Object.defineProperty,Object.getOwnPropertyDescriptor,Object.getOwnPropertyNames,Object.getPrototypeOf,Object.prototype.hasOwnProperty;Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),r=require("@embedpdf/models"),t=require("react/jsx-runtime"),n="https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.4.0/dist/pdfium.wasm";const i=e.createContext(void 0);function o(){const r=e.useContext(i);if(void 0===r)throw new Error("useEngineContext must be used within a PdfEngineProvider");return r}exports.PdfEngineProvider=function({children:e,engine:r,isLoading:n,error:o}){const s={engine:r,isLoading:n,error:o};return t.jsx(i.Provider,{value:s,children:e})},exports.useEngine=function(){const{engine:e,error:r}=o();if(r)throw r;return e},exports.useEngineContext=o,exports.usePdfiumEngine=function(t){const{wasmUrl:i=n,worker:o=!0,logger:s}=t??{},[u,c]=e.useState(null),[d,a]=e.useState(!0),[l,g]=e.useState(null),p=e.useRef(null);return e.useEffect((()=>{let e=!1;return(async()=>{try{const{createPdfiumEngine:e}=o?await import("@embedpdf/engines/pdfium-worker-engine"):await import("@embedpdf/engines/pdfium-direct-engine"),r=await e(i,s);p.current=r,r.initialize().wait((()=>{c(r),a(!1)}),(e=>{g(new Error(e.reason.message)),a(!1)}))}catch(r){e||(g(r),a(!1))}})(),()=>{var t,n;e=!0,null==(n=null==(t=p.current)?void 0:t.closeAllDocuments)||n.call(t).wait((()=>{var e,r;null==(r=null==(e=p.current)?void 0:e.destroy)||r.call(e),p.current=null}),r.ignore)}}),[i,o,s]),{engine:u,isLoading:d,error:l}};
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../src/shared/hooks/use-pdfium-engine.ts","../../src/shared/context/pdf-engine-context.ts","../../src/shared/hooks/use-engine-context.ts","../../src/shared/components/pdf-engine-provider.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from '@framework';\nimport { ignore, Logger, PdfEngine } from '@embedpdf/models';\n\nconst defaultWasmUrl = `https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm`;\n\ninterface UsePdfiumEngineProps {\n wasmUrl?: string;\n worker?: boolean;\n logger?: Logger;\n}\n\nexport function usePdfiumEngine(config?: UsePdfiumEngineProps) {\n const { wasmUrl = defaultWasmUrl, worker = true, logger } = config ?? {};\n\n const [engine, setEngine] = useState<PdfEngine | null>(null);\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<Error | null>(null);\n const engineRef = useRef<PdfEngine | null>(null);\n\n useEffect(() => {\n let cancelled = false;\n\n (async () => {\n try {\n const { createPdfiumEngine } = worker\n ? await import('@embedpdf/engines/pdfium-worker-engine')\n : await import('@embedpdf/engines/pdfium-direct-engine');\n\n const pdfEngine = await createPdfiumEngine(wasmUrl, logger);\n engineRef.current = pdfEngine;\n pdfEngine.initialize().wait(\n () => {\n setEngine(pdfEngine);\n setLoading(false);\n },\n (e) => {\n setError(new Error(e.reason.message));\n setLoading(false);\n },\n );\n } catch (e) {\n if (!cancelled) {\n setError(e as Error);\n setLoading(false);\n }\n }\n })();\n\n return () => {\n cancelled = true;\n engineRef.current?.closeAllDocuments?.().wait(() => {\n engineRef.current?.destroy?.();\n engineRef.current = null;\n }, ignore);\n };\n }, [wasmUrl, worker, logger]);\n\n return { engine, isLoading: loading, error };\n}\n","import { createContext } from '@framework';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineContextState {\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\nexport const PdfEngineContext = createContext<PdfEngineContextState | undefined>(undefined);\n","import { useContext } from '@framework';\nimport { PdfEngineContext, PdfEngineContextState } from '../context';\n\n/**\n * Hook to access the PDF engine from context.\n * @returns The PDF engine context state\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function useEngineContext(): PdfEngineContextState {\n const contextValue = useContext(PdfEngineContext);\n\n if (contextValue === undefined) {\n throw new Error('useEngineContext must be used within a PdfEngineProvider');\n }\n\n return contextValue;\n}\n\n/**\n * Hook to access the PDF engine, with a more convenient API.\n * @returns The PDF engine or null if loading/error\n */\nexport function useEngine() {\n const { engine, error } = useEngineContext();\n\n if (error) {\n throw error;\n }\n\n return engine;\n}\n","import { ReactNode } from '@framework';\nimport { PdfEngineContext } from '../context';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineProviderProps {\n children: ReactNode;\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\n/**\n * Provider component that makes a PDF engine instance available\n * to all child components via context.\n *\n * This provider is completely engine-agnostic - it accepts any engine\n * and its loading state from the parent component.\n */\nexport function PdfEngineProvider({ children, engine, isLoading, error }: PdfEngineProviderProps) {\n const contextValue = {\n engine,\n isLoading,\n error,\n };\n\n return <PdfEngineContext.Provider value={contextValue}>{children}</PdfEngineContext.Provider>;\n}\n"],"names":["defaultWasmUrl","PdfEngineContext","createContext","useEngineContext","contextValue","useContext","Error","children","engine","isLoading","error","Provider","value","config","wasmUrl","worker","logger","setEngine","useState","loading","setLoading","setError","engineRef","useRef","useEffect","cancelled","createPdfiumEngine","import","pdfEngine","current","initialize","wait","e","reason","message","_b","_a","closeAllDocuments","call","destroy","ignore"],"mappings":"2TAGMA,EAAiB,wECMV,MAAAC,EAAmBC,qBAAiD,GCD1E,SAASC,IACR,MAAAC,EAAeC,aAAWJ,GAEhC,QAAqB,IAAjBG,EACI,MAAA,IAAIE,MAAM,4DAGX,OAAAF,CACT,2BCEO,UAA2BG,SAAEA,EAAAC,OAAUA,EAAQC,UAAAA,EAAAC,MAAWA,IAC/D,MAAMN,EAAe,CACnBI,SACAC,YACAC,sBAGMT,EAAiBU,SAAjB,CAA0BC,MAAOR,EAAeG,YAC1D,oBDJO,WACL,MAAMC,OAAEA,EAAAE,MAAQA,GAAUP,IAE1B,GAAIO,EACI,MAAAA,EAGD,OAAAF,CACT,qDFnBO,SAAyBK,GACxB,MAAAC,QAAEA,EAAUd,EAAgBe,OAAAA,GAAS,SAAMC,GAAWH,GAAU,CAAC,GAEhEL,EAAQS,GAAaC,EAAAA,SAA2B,OAChDC,EAASC,GAAcF,EAAAA,UAAS,IAChCR,EAAOW,GAAYH,EAAAA,SAAuB,MAC3CI,EAAYC,SAAyB,MAwC3C,OAtCAC,EAAAA,WAAU,KACR,IAAIC,GAAY,EA4BhB,MA1BA,WACM,IACI,MAAAC,mBAAEA,GAAuBX,QACrBY,OAAO,gDACPA,OAAO,0CAEXC,QAAkBF,EAAmBZ,EAASE,GACpDM,EAAUO,QAAUD,EACpBA,EAAUE,aAAaC,MACrB,KACEd,EAAUW,GACVR,GAAW,EAAK,IAEjBY,IACCX,EAAS,IAAIf,MAAM0B,EAAEC,OAAOC,UAC5Bd,GAAW,EAAK,UAGbY,GACFP,IACHJ,EAASW,GACTZ,GAAW,GACb,CAED,EAxBH,GA0BO,aACOK,GAAA,EACZ,OAAAU,EAAA,OAAAC,EAAAd,EAAUO,cAAV,EAAAO,EAAmBC,oBAAnBF,EAAAG,KAAAF,GAAyCL,MAAK,aAC5C,OAAAI,EAAA,OAAAC,EAAAd,EAAUO,gBAAVO,EAAmBG,UAAnBJ,EAAAG,KAAAF,GACAd,EAAUO,QAAU,IAAA,GACnBW,UACL,GACC,CAAC1B,EAASC,EAAQC,IAEd,CAAER,SAAQC,UAAWU,EAAST,QACvC"}
1
+ {"version":3,"file":"index.cjs","sources":["../../src/shared/hooks/use-pdfium-engine.ts","../../src/shared/context/pdf-engine-context.ts","../../src/shared/hooks/use-engine-context.ts","../../src/shared/components/pdf-engine-provider.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from '@framework';\nimport { ignore, Logger, PdfEngine } from '@embedpdf/models';\n\nconst defaultWasmUrl = `https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm`;\n\ninterface UsePdfiumEngineProps {\n wasmUrl?: string;\n worker?: boolean;\n logger?: Logger;\n}\n\nexport function usePdfiumEngine(config?: UsePdfiumEngineProps) {\n const { wasmUrl = defaultWasmUrl, worker = true, logger } = config ?? {};\n\n const [engine, setEngine] = useState<PdfEngine | null>(null);\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<Error | null>(null);\n const engineRef = useRef<PdfEngine | null>(null);\n\n useEffect(() => {\n let cancelled = false;\n\n (async () => {\n try {\n const { createPdfiumEngine } = worker\n ? await import('@embedpdf/engines/pdfium-worker-engine')\n : await import('@embedpdf/engines/pdfium-direct-engine');\n\n const pdfEngine = await createPdfiumEngine(wasmUrl, logger);\n engineRef.current = pdfEngine;\n pdfEngine.initialize().wait(\n () => {\n setEngine(pdfEngine);\n setLoading(false);\n },\n (e) => {\n setError(new Error(e.reason.message));\n setLoading(false);\n },\n );\n } catch (e) {\n if (!cancelled) {\n setError(e as Error);\n setLoading(false);\n }\n }\n })();\n\n return () => {\n cancelled = true;\n engineRef.current?.closeAllDocuments?.().wait(() => {\n engineRef.current?.destroy?.();\n engineRef.current = null;\n }, ignore);\n };\n }, [wasmUrl, worker, logger]);\n\n return { engine, isLoading: loading, error };\n}\n","import { createContext } from '@framework';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineContextState {\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\nexport const PdfEngineContext = createContext<PdfEngineContextState | undefined>(undefined);\n","import { useContext } from '@framework';\nimport { PdfEngineContext, PdfEngineContextState } from '../context';\n\n/**\n * Hook to access the PDF engine from context.\n * @returns The PDF engine context state\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function useEngineContext(): PdfEngineContextState {\n const contextValue = useContext(PdfEngineContext);\n\n if (contextValue === undefined) {\n throw new Error('useEngineContext must be used within a PdfEngineProvider');\n }\n\n return contextValue;\n}\n\n/**\n * Hook to access the PDF engine, with a more convenient API.\n * @returns The PDF engine or null if loading/error\n */\nexport function useEngine() {\n const { engine, error } = useEngineContext();\n\n if (error) {\n throw error;\n }\n\n return engine;\n}\n","import { ReactNode } from '@framework';\nimport { PdfEngineContext } from '../context';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineProviderProps {\n children: ReactNode;\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\n/**\n * Provider component that makes a PDF engine instance available\n * to all child components via context.\n *\n * This provider is completely engine-agnostic - it accepts any engine\n * and its loading state from the parent component.\n */\nexport function PdfEngineProvider({ children, engine, isLoading, error }: PdfEngineProviderProps) {\n const contextValue = {\n engine,\n isLoading,\n error,\n };\n\n return <PdfEngineContext.Provider value={contextValue}>{children}</PdfEngineContext.Provider>;\n}\n"],"names":["defaultWasmUrl","PdfEngineContext","createContext","useEngineContext","contextValue","useContext","Error","children","engine","isLoading","error","Provider","value","config","wasmUrl","worker","logger","setEngine","useState","loading","setLoading","setError","engineRef","useRef","useEffect","cancelled","createPdfiumEngine","import","pdfEngine","current","initialize","wait","e","reason","message","_b","_a","closeAllDocuments","call","destroy","ignore"],"mappings":"2TAGMA,EAAiB,uECMV,MAAAC,EAAmBC,qBAAiD,GCD1E,SAASC,IACR,MAAAC,EAAeC,aAAWJ,GAEhC,QAAqB,IAAjBG,EACI,MAAA,IAAIE,MAAM,4DAGX,OAAAF,CACT,2BCEO,UAA2BG,SAAEA,EAAAC,OAAUA,EAAQC,UAAAA,EAAAC,MAAWA,IAC/D,MAAMN,EAAe,CACnBI,SACAC,YACAC,sBAGMT,EAAiBU,SAAjB,CAA0BC,MAAOR,EAAeG,YAC1D,oBDJO,WACL,MAAMC,OAAEA,EAAAE,MAAQA,GAAUP,IAE1B,GAAIO,EACI,MAAAA,EAGD,OAAAF,CACT,qDFnBO,SAAyBK,GACxB,MAAAC,QAAEA,EAAUd,EAAgBe,OAAAA,GAAS,SAAMC,GAAWH,GAAU,CAAC,GAEhEL,EAAQS,GAAaC,EAAAA,SAA2B,OAChDC,EAASC,GAAcF,EAAAA,UAAS,IAChCR,EAAOW,GAAYH,EAAAA,SAAuB,MAC3CI,EAAYC,SAAyB,MAwC3C,OAtCAC,EAAAA,WAAU,KACR,IAAIC,GAAY,EA4BhB,MA1BA,WACM,IACI,MAAAC,mBAAEA,GAAuBX,QACrBY,OAAO,gDACPA,OAAO,0CAEXC,QAAkBF,EAAmBZ,EAASE,GACpDM,EAAUO,QAAUD,EACpBA,EAAUE,aAAaC,MACrB,KACEd,EAAUW,GACVR,GAAW,EAAK,IAEjBY,IACCX,EAAS,IAAIf,MAAM0B,EAAEC,OAAOC,UAC5Bd,GAAW,EAAK,UAGbY,GACFP,IACHJ,EAASW,GACTZ,GAAW,GACb,CAED,EAxBH,GA0BO,aACOK,GAAA,EACZ,OAAAU,EAAA,OAAAC,EAAAd,EAAUO,cAAV,EAAAO,EAAmBC,oBAAnBF,EAAAG,KAAAF,GAAyCL,MAAK,aAC5C,OAAAI,EAAA,OAAAC,EAAAd,EAAUO,gBAAVO,EAAmBG,UAAnBJ,EAAAG,KAAAF,GACAd,EAAUO,QAAU,IAAA,GACnBW,UACL,GACC,CAAC1B,EAASC,EAAQC,IAEd,CAAER,SAAQC,UAAWU,EAAST,QACvC"}
@@ -1,7 +1,7 @@
1
1
  import { useState, useRef, useEffect, createContext, useContext } from "react";
2
2
  import { ignore } from "@embedpdf/models";
3
3
  import { jsx } from "react/jsx-runtime";
4
- const defaultWasmUrl = `https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.3.16/dist/pdfium.wasm`;
4
+ const defaultWasmUrl = `https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.4.0/dist/pdfium.wasm`;
5
5
  function usePdfiumEngine(config) {
6
6
  const { wasmUrl = defaultWasmUrl, worker = true, logger } = config ?? {};
7
7
  const [engine, setEngine] = useState(null);
@@ -0,0 +1,11 @@
1
+ import { Snippet } from 'svelte';
2
+ import { PdfEngine } from '@embedpdf/models';
3
+ interface Props {
4
+ children: Snippet;
5
+ engine: PdfEngine | null;
6
+ isLoading: boolean;
7
+ error: Error | null;
8
+ }
9
+ declare const PdfEngineProvider: import('svelte', { with: { "resolution-mode": "import" } }).Component<Props, {}, "">;
10
+ type PdfEngineProvider = ReturnType<typeof PdfEngineProvider>;
11
+ export default PdfEngineProvider;
@@ -0,0 +1 @@
1
+ export { default as PdfEngineProvider } from './PdfEngineProvider.svelte';
@@ -0,0 +1 @@
1
+ export * from './pdf-engine-context.svelte';
@@ -0,0 +1,15 @@
1
+ import { PdfEngine } from '@embedpdf/models';
2
+ export interface PdfEngineContextState {
3
+ engine: PdfEngine | null;
4
+ isLoading: boolean;
5
+ error: Error | null;
6
+ }
7
+ /**
8
+ * Set the PDF engine context (used by PdfEngineProvider)
9
+ */
10
+ export declare function setPdfEngineContext(value: PdfEngineContextState): void;
11
+ /**
12
+ * Get the PDF engine context
13
+ * @throws Error if used outside of PdfEngineProvider
14
+ */
15
+ export declare function getPdfEngineContext(): PdfEngineContextState;
@@ -0,0 +1,2 @@
1
+ export * from './use-engine-context';
2
+ export * from './use-pdfium-engine.svelte';
@@ -0,0 +1,12 @@
1
+ import { PdfEngineContextState } from '../context/pdf-engine-context.svelte';
2
+ /**
3
+ * Hook to access the PDF engine from context.
4
+ * @returns The PDF engine context state
5
+ * @throws Error if used outside of PdfEngineProvider
6
+ */
7
+ export declare function useEngineContext(): PdfEngineContextState;
8
+ /**
9
+ * Hook to access the PDF engine, with a more convenient API.
10
+ * @returns The PDF engine or null if loading/error
11
+ */
12
+ export declare function useEngine(): import('@embedpdf/models').PdfEngine<Blob> | null;
@@ -0,0 +1,11 @@
1
+ import { Logger, PdfEngine } from '@embedpdf/models';
2
+ export interface UsePdfiumEngineProps {
3
+ wasmUrl?: string;
4
+ worker?: boolean;
5
+ logger?: Logger;
6
+ }
7
+ export declare function usePdfiumEngine(config?: UsePdfiumEngineProps): {
8
+ readonly engine: PdfEngine<Blob> | null;
9
+ readonly isLoading: boolean;
10
+ readonly error: Error | null;
11
+ };
@@ -0,0 +1,2 @@
1
+ "use strict";Object.create,Object.defineProperty,Object.getOwnPropertyDescriptor,Object.getOwnPropertyNames,Object.getPrototypeOf,Object.prototype.hasOwnProperty;Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("svelte/internal/client"),t=require("svelte"),n=require("@embedpdf/models"),r=require("@embedpdf/engines");function i(e){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e)for(const n in e)if("default"!==n){const r=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,r.get?r:{enumerable:!0,get:()=>e[n]})}return t.default=e,Object.freeze(t)}require("svelte/internal/disclose-version");const o=i(e),s=Symbol("pdfEngineContext");function u(){const e=t.getContext(s);if(void 0===e)throw new Error("getPdfEngineContext must be used within a PdfEngineProvider");return e}exports.PdfEngineProvider=function(e,n){o.push(n,!0),o.user_effect((()=>{var e;e={engine:n.engine,isLoading:n.isLoading,error:n.error},t.setContext(s,e)}));var r=o.comment(),i=o.first_child(r);o.snippet(i,(()=>n.children)),o.append(e,r),o.pop()},exports.useEngine=function(){const{engine:e,error:t}=u();if(t)throw t;return e},exports.useEngineContext=function(){const e=u();if(void 0===e)throw new Error("useEngineContext must be used within a PdfEngineProvider");return e},exports.usePdfiumEngine=function(e){const{wasmUrl:t=r.DEFAULT_PDFIUM_WASM_URL,worker:i=!0,logger:s}=e??{};let u=o.state(null),c=o.state(!0),l=o.state(null),d=o.state(void 0);return"undefined"!=typeof window&&o.user_effect((()=>{let e=!1;return(async()=>{try{const{createPdfiumEngine:e}=i?await import("@embedpdf/engines/pdfium-worker-engine"):await import("@embedpdf/engines/pdfium-direct-engine"),n=await e(t,s);o.set(d,n,!0),n.initialize().wait((()=>{o.set(u,n,!0),o.set(c,!1)}),(e=>{o.set(l,new Error(e.reason.message),!0),o.set(c,!1)}))}catch(n){e||(o.set(l,n,!0),o.set(c,!1))}})(),()=>{var t,r;e=!0,null==(r=null==(t=o.get(d))?void 0:t.closeAllDocuments)||r.call(t).wait((()=>{var e,t;null==(t=null==(e=o.get(d))?void 0:e.destroy)||t.call(e),o.set(d,null)}),n.ignore)}})),{get engine(){return o.get(u)},get isLoading(){return o.get(c)},get error(){return o.get(l)}}};
2
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../src/svelte/context/pdf-engine-context.svelte.ts","../../src/svelte/components/PdfEngineProvider.svelte","../../src/svelte/hooks/use-engine-context.ts","../../src/svelte/hooks/use-pdfium-engine.svelte.ts"],"sourcesContent":["import { getContext, setContext } from 'svelte';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineContextState {\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\n\nconst PDF_ENGINE_CONTEXT_KEY = Symbol('pdfEngineContext');\n\n/**\n * Set the PDF engine context (used by PdfEngineProvider)\n */\nexport function setPdfEngineContext(value: PdfEngineContextState) {\n setContext(PDF_ENGINE_CONTEXT_KEY, value);\n}\n\n/**\n * Get the PDF engine context\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function getPdfEngineContext(): PdfEngineContextState {\n const context = getContext<PdfEngineContextState | undefined>(PDF_ENGINE_CONTEXT_KEY);\n \n if (context === undefined) {\n throw new Error('getPdfEngineContext must be used within a PdfEngineProvider');\n }\n \n return context;\n}\n","<script lang=\"ts\">\n import type { Snippet } from 'svelte';\n import type { PdfEngine } from '@embedpdf/models';\n import { setPdfEngineContext } from '../context';\n\n interface Props {\n children: Snippet;\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n }\n\n let { children, engine, isLoading, error }: Props = $props();\n\n // Update context reactively whenever props change\n $effect(() => {\n setPdfEngineContext({\n engine,\n isLoading,\n error,\n });\n });\n</script>\n\n{@render children()}\n","import { getPdfEngineContext, type PdfEngineContextState } from '../context/pdf-engine-context.svelte';\n\n/**\n * Hook to access the PDF engine from context.\n * @returns The PDF engine context state\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function useEngineContext(): PdfEngineContextState {\n const contextValue = getPdfEngineContext();\n\n if (contextValue === undefined) {\n throw new Error('useEngineContext must be used within a PdfEngineProvider');\n }\n\n return contextValue;\n}\n\n/**\n * Hook to access the PDF engine, with a more convenient API.\n * @returns The PDF engine or null if loading/error\n */\nexport function useEngine() {\n const { engine, error } = getPdfEngineContext();\n\n if (error) {\n throw error;\n }\n\n return engine;\n}\n\n","import { ignore, Logger, PdfEngine } from '@embedpdf/models';\nimport { DEFAULT_PDFIUM_WASM_URL } from '@embedpdf/engines';\n\nexport interface UsePdfiumEngineProps {\n wasmUrl?: string;\n worker?: boolean;\n logger?: Logger;\n}\n\nexport function usePdfiumEngine(config?: UsePdfiumEngineProps) {\n const { wasmUrl = DEFAULT_PDFIUM_WASM_URL, worker = true, logger } = config ?? {};\n\n let engine = $state<PdfEngine | null>(null);\n let loading = $state(true);\n let error = $state<Error | null>(null);\n let engineRef = $state<PdfEngine | null>();\n\n // Check if we're in browser environment\n const isBrowser = typeof window !== 'undefined';\n\n if (isBrowser) {\n $effect(() => {\n let cancelled = false;\n\n (async () => {\n try {\n const { createPdfiumEngine } = worker\n ? await import('@embedpdf/engines/pdfium-worker-engine')\n : await import('@embedpdf/engines/pdfium-direct-engine');\n\n const pdfEngine = await createPdfiumEngine(wasmUrl, logger);\n engineRef = pdfEngine;\n pdfEngine.initialize().wait(\n () => {\n engine = pdfEngine;\n loading = false;\n },\n (e) => {\n error = new Error(e.reason.message);\n loading = false;\n },\n );\n } catch (e) {\n if (!cancelled) {\n error = e as Error;\n loading = false;\n }\n }\n })();\n\n return () => {\n cancelled = true;\n engineRef?.closeAllDocuments?.().wait(() => {\n engineRef?.destroy?.();\n engineRef = null;\n }, ignore);\n };\n });\n }\n\n // IMPORTANT: expose *getters* so consumers read live state\n return {\n get engine() {\n return engine;\n },\n get isLoading() {\n return loading;\n },\n get error() {\n return error;\n },\n };\n}\n"],"names":["PDF_ENGINE_CONTEXT_KEY","Symbol","getPdfEngineContext","context","getContext","Error","$","user_effect","value","engine","$$props","isLoading","error","svelte","setContext","contextValue","config","wasmUrl","DEFAULT_PDFIUM_WASM_URL","worker","logger","loading","engineRef","window","cancelled","createPdfiumEngine","pdfEngine","$__namespace","set","initialize","wait","e","reason","message","closeAllDocuments","_b","call","_a","get","destroy","ignore"],"mappings":"oqBAUMA,EAAyBC,OAAO,oBAatB,SAAAC,IACR,MAAAC,EAAUC,aAA8CJ,eAE1DG,EACQ,MAAA,IAAAE,MAAM,+DAGX,OAAAF,CACT,sDChBEG,EAAAC,aAAc,SDAoBC,ICCb,CACjBC,OAAMC,EAAAD,OACNE,UAASD,EAAAC,UACTC,MAAKF,EAAAE,ODHTC,EAAAC,WAAWd,EAAwBQ,8FCMrC,oBCDO,WACL,MAAMC,OAAEA,EAAAG,MAAQA,GAAUV,IAE1B,GAAIU,EACI,MAAAA,EAGD,OAAAH,CACT,2BAtBO,WACL,MAAMM,EAAeb,IAErB,QAAqB,IAAjBa,EACI,MAAA,IAAIV,MAAM,4DAGX,OAAAU,CACT,mCCNgCC,iBACtBC,EAAUC,iCAAyBC,GAAS,EAAMC,OAAAA,GAAWJ,MAEjE,IAAAP,UAAkC,MAClCY,WAAiB,GACjBT,UAA6B,MAC7BU,wBAGgC,oBAAXC,QAGvBjB,EAAAC,kBACM,IAAAiB,GAAY,mBAGV,IACM,MAAAC,mBAAAA,GAAuBN,eACd,uDACA,0CAEXO,QAAkBD,EAAmBR,EAASG,GACxCO,EAAAC,IAAAN,EAAAI,GAAA,GACZA,EAAUG,aAAaC,WAEVH,EAAAC,IAAAnB,EAAAiB,GAAA,GACCC,EAAAC,IAAAP,GAAA,EAAA,IAEXU,IACCJ,EAAAC,IAAAhB,MAAYP,MAAM0B,EAAEC,OAAOC,UAAO,GACxBN,EAAAC,IAAAP,GAAA,EAAA,UAGPU,GACFP,IACKG,EAAAC,IAAAhB,EAAAmB,GAAA,GACEJ,EAAAC,IAAAP,GAAA,IAGb,kBAGWG,GAAA,0BACDF,aAAAY,oBAAsBC,EAAAC,KAAAC,GAAAP,mBAC/BxB,OAAAA,EAAAA,OAAAA,EAAAA,EAAAgC,IAAAhB,SAAAhB,EAAAA,EAAWiC,UAAXjC,EAAAA,KAAAA,GACYqB,EAAAC,IAAAN,EAAA,KAAA,GACXkB,EAAAA,OAAAA,CACL,KAME,UAAA/B,gBACKA,EACT,EACI,aAAAE,gBACKU,EACT,EACI,SAAAT,gBACKA,IAGb"}
@@ -0,0 +1,2 @@
1
+ export * from './hooks';
2
+ export * from './components';
@@ -0,0 +1,110 @@
1
+ import * as $ from "svelte/internal/client";
2
+ import { setContext, getContext } from "svelte";
3
+ import { ignore } from "@embedpdf/models";
4
+ import { DEFAULT_PDFIUM_WASM_URL } from "@embedpdf/engines";
5
+ import "svelte/internal/disclose-version";
6
+ const PDF_ENGINE_CONTEXT_KEY = Symbol("pdfEngineContext");
7
+ function setPdfEngineContext(value) {
8
+ setContext(PDF_ENGINE_CONTEXT_KEY, value);
9
+ }
10
+ function getPdfEngineContext() {
11
+ const context = getContext(PDF_ENGINE_CONTEXT_KEY);
12
+ if (context === void 0) {
13
+ throw new Error("getPdfEngineContext must be used within a PdfEngineProvider");
14
+ }
15
+ return context;
16
+ }
17
+ function useEngineContext() {
18
+ const contextValue = getPdfEngineContext();
19
+ if (contextValue === void 0) {
20
+ throw new Error("useEngineContext must be used within a PdfEngineProvider");
21
+ }
22
+ return contextValue;
23
+ }
24
+ function useEngine() {
25
+ const { engine, error } = getPdfEngineContext();
26
+ if (error) {
27
+ throw error;
28
+ }
29
+ return engine;
30
+ }
31
+ function usePdfiumEngine(config) {
32
+ const { wasmUrl = DEFAULT_PDFIUM_WASM_URL, worker = true, logger } = config ?? {};
33
+ let engine = $.state(null);
34
+ let loading = $.state(true);
35
+ let error = $.state(null);
36
+ let engineRef = $.state(void 0);
37
+ const isBrowser = typeof window !== "undefined";
38
+ if (isBrowser) {
39
+ $.user_effect(() => {
40
+ let cancelled = false;
41
+ (async () => {
42
+ try {
43
+ const { createPdfiumEngine } = worker ? await import("@embedpdf/engines/pdfium-worker-engine") : await import("@embedpdf/engines/pdfium-direct-engine");
44
+ const pdfEngine = await createPdfiumEngine(wasmUrl, logger);
45
+ $.set(engineRef, pdfEngine, true);
46
+ pdfEngine.initialize().wait(
47
+ () => {
48
+ $.set(engine, pdfEngine, true);
49
+ $.set(loading, false);
50
+ },
51
+ (e) => {
52
+ $.set(error, new Error(e.reason.message), true);
53
+ $.set(loading, false);
54
+ }
55
+ );
56
+ } catch (e) {
57
+ if (!cancelled) {
58
+ $.set(error, e, true);
59
+ $.set(loading, false);
60
+ }
61
+ }
62
+ })();
63
+ return () => {
64
+ var _a, _b;
65
+ cancelled = true;
66
+ (_b = (_a = $.get(engineRef)) == null ? void 0 : _a.closeAllDocuments) == null ? void 0 : _b.call(_a).wait(
67
+ () => {
68
+ var _a2, _b2;
69
+ (_b2 = (_a2 = $.get(engineRef)) == null ? void 0 : _a2.destroy) == null ? void 0 : _b2.call(_a2);
70
+ $.set(engineRef, null);
71
+ },
72
+ ignore
73
+ );
74
+ };
75
+ });
76
+ }
77
+ return {
78
+ get engine() {
79
+ return $.get(engine);
80
+ },
81
+ get isLoading() {
82
+ return $.get(loading);
83
+ },
84
+ get error() {
85
+ return $.get(error);
86
+ }
87
+ };
88
+ }
89
+ function PdfEngineProvider($$anchor, $$props) {
90
+ $.push($$props, true);
91
+ $.user_effect(() => {
92
+ setPdfEngineContext({
93
+ engine: $$props.engine,
94
+ isLoading: $$props.isLoading,
95
+ error: $$props.error
96
+ });
97
+ });
98
+ var fragment = $.comment();
99
+ var node = $.first_child(fragment);
100
+ $.snippet(node, () => $$props.children);
101
+ $.append($$anchor, fragment);
102
+ $.pop();
103
+ }
104
+ export {
105
+ PdfEngineProvider,
106
+ useEngine,
107
+ useEngineContext,
108
+ usePdfiumEngine
109
+ };
110
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/svelte/context/pdf-engine-context.svelte.ts","../../src/svelte/hooks/use-engine-context.ts","../../src/svelte/hooks/use-pdfium-engine.svelte.ts","../../src/svelte/components/PdfEngineProvider.svelte"],"sourcesContent":["import { getContext, setContext } from 'svelte';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineContextState {\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\n\nconst PDF_ENGINE_CONTEXT_KEY = Symbol('pdfEngineContext');\n\n/**\n * Set the PDF engine context (used by PdfEngineProvider)\n */\nexport function setPdfEngineContext(value: PdfEngineContextState) {\n setContext(PDF_ENGINE_CONTEXT_KEY, value);\n}\n\n/**\n * Get the PDF engine context\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function getPdfEngineContext(): PdfEngineContextState {\n const context = getContext<PdfEngineContextState | undefined>(PDF_ENGINE_CONTEXT_KEY);\n \n if (context === undefined) {\n throw new Error('getPdfEngineContext must be used within a PdfEngineProvider');\n }\n \n return context;\n}\n","import { getPdfEngineContext, type PdfEngineContextState } from '../context/pdf-engine-context.svelte';\n\n/**\n * Hook to access the PDF engine from context.\n * @returns The PDF engine context state\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function useEngineContext(): PdfEngineContextState {\n const contextValue = getPdfEngineContext();\n\n if (contextValue === undefined) {\n throw new Error('useEngineContext must be used within a PdfEngineProvider');\n }\n\n return contextValue;\n}\n\n/**\n * Hook to access the PDF engine, with a more convenient API.\n * @returns The PDF engine or null if loading/error\n */\nexport function useEngine() {\n const { engine, error } = getPdfEngineContext();\n\n if (error) {\n throw error;\n }\n\n return engine;\n}\n\n","import { ignore, Logger, PdfEngine } from '@embedpdf/models';\nimport { DEFAULT_PDFIUM_WASM_URL } from '@embedpdf/engines';\n\nexport interface UsePdfiumEngineProps {\n wasmUrl?: string;\n worker?: boolean;\n logger?: Logger;\n}\n\nexport function usePdfiumEngine(config?: UsePdfiumEngineProps) {\n const { wasmUrl = DEFAULT_PDFIUM_WASM_URL, worker = true, logger } = config ?? {};\n\n let engine = $state<PdfEngine | null>(null);\n let loading = $state(true);\n let error = $state<Error | null>(null);\n let engineRef = $state<PdfEngine | null>();\n\n // Check if we're in browser environment\n const isBrowser = typeof window !== 'undefined';\n\n if (isBrowser) {\n $effect(() => {\n let cancelled = false;\n\n (async () => {\n try {\n const { createPdfiumEngine } = worker\n ? await import('@embedpdf/engines/pdfium-worker-engine')\n : await import('@embedpdf/engines/pdfium-direct-engine');\n\n const pdfEngine = await createPdfiumEngine(wasmUrl, logger);\n engineRef = pdfEngine;\n pdfEngine.initialize().wait(\n () => {\n engine = pdfEngine;\n loading = false;\n },\n (e) => {\n error = new Error(e.reason.message);\n loading = false;\n },\n );\n } catch (e) {\n if (!cancelled) {\n error = e as Error;\n loading = false;\n }\n }\n })();\n\n return () => {\n cancelled = true;\n engineRef?.closeAllDocuments?.().wait(() => {\n engineRef?.destroy?.();\n engineRef = null;\n }, ignore);\n };\n });\n }\n\n // IMPORTANT: expose *getters* so consumers read live state\n return {\n get engine() {\n return engine;\n },\n get isLoading() {\n return loading;\n },\n get error() {\n return error;\n },\n };\n}\n","<script lang=\"ts\">\n import type { Snippet } from 'svelte';\n import type { PdfEngine } from '@embedpdf/models';\n import { setPdfEngineContext } from '../context';\n\n interface Props {\n children: Snippet;\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n }\n\n let { children, engine, isLoading, error }: Props = $props();\n\n // Update context reactively whenever props change\n $effect(() => {\n setPdfEngineContext({\n engine,\n isLoading,\n error,\n });\n });\n</script>\n\n{@render children()}\n"],"names":["_b","_a"],"mappings":";;;;;MAUM,yBAAyB,OAAO,kBAAkB;SAKxC,oBAAoB,OAA8B;AAChE,aAAW,wBAAwB,KAAK;AAC1C;AAMgB,SAAA,sBAA6C;QACrD,UAAU,WAA8C,sBAAsB;MAEhF,oBAAuB;AACf,UAAA,IAAA,MAAM,6DAA6D;AAAA;SAGxE;AACT;ACxBO,SAAS,mBAA0C;AACxD,QAAM,eAAe,oBAAoB;AAEzC,MAAI,iBAAiB,QAAW;AACxB,UAAA,IAAI,MAAM,0DAA0D;AAAA,EAAA;AAGrE,SAAA;AACT;AAMO,SAAS,YAAY;AAC1B,QAAM,EAAE,QAAQ,MAAM,IAAI,oBAAoB;AAE9C,MAAI,OAAO;AACH,UAAA;AAAA,EAAA;AAGD,SAAA;AACT;SCpBgB,gBAAgB,QAA+B;UACrD,UAAU,yBAAyB,SAAS,MAAM,OAAO,IAAI;AAEjE,MAAA,iBAAkC,IAAI;AACtC,MAAA,kBAAiB,IAAI;AACrB,MAAA,gBAA6B,IAAI;MACjC;QAGE,YAAA,OAAmB,WAAW;AAEhC,MAAA,WAAW;AACb,MAAA,kBAAc;AACR,UAAA,YAAY;mBAEH;YACP;AACM,gBAAA,EAAA,mBAAmB,IAAI,sBACd,wCAAwC,iBACxC,wCAAwC;AAEnD,gBAAA,YAAkB,MAAA,mBAAmB,SAAS,MAAM;AAC9C,YAAA,IAAA,WAAA,WAAA,IAAA;AACZ,oBAAU,aAAa;AAAA,kBACf;AACK,gBAAA,IAAA,QAAA,WAAA,IAAA;AACC,gBAAA,IAAA,SAAA,KAAA;AAAA,YACZ;AAAA,YACC,CAAA,MAAM;AACL,gBAAA,IAAA,WAAY,MAAM,EAAE,OAAO,OAAO,GAAA,IAAA;AACxB,gBAAA,IAAA,SAAA,KAAA;AAAA;;iBAGP,GAAG;AACL,cAAA,CAAA,WAAW;AACN,cAAA,IAAA,OAAA,GAAA,IAAA;AACE,cAAA,IAAA,SAAA,KAAA;AAAA;;SAGb;mBAEU;;AACC,oBAAA;0BACD,SAAA,yBAAA,kDAAsB;AAAA,gBAAW;;AAC1C,aAAAA,OAAAC,MAAA,EAAA,IAAA,SAAA,MAAA,gBAAAA,IAAW,YAAX,gBAAAD,IAAA,KAAAC;AACY,cAAA,IAAA,WAAA,IAAA;AAAA;UACX;AAAA;AAAA,MACL;AAAA,KACD;AAAA;;IAKG,IAAA,SAAS;mBACJ,MAAA;AAAA,IACT;AAAA,IACI,IAAA,YAAY;mBACP,OAAA;AAAA,IACT;AAAA,IACI,IAAA,QAAQ;mBACH,KAAA;AAAA;;AAGb;8CCxEA;;AAeE,IAAA,YAAc,MAAA;AACZ,wBAAmB;AAAA,MACjB,QAAM,QAAA;AAAA,MACN,WAAS,QAAA;AAAA,MACT,OAAK,QAAA;AAAA;GAER;;;;;;AACH;"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.create,Object.defineProperty,Object.getOwnPropertyDescriptor,Object.getOwnPropertyNames,Object.getPrototypeOf,Object.prototype.hasOwnProperty;Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),n=require("@embedpdf/models"),r=Symbol("pdfEngineKey");function t(){const n=e.inject(r);if(!n)throw new Error("useEngineContext must be used within a PdfEngineProvider");return n}const o="https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.3.16/dist/pdfium.wasm";const i=e.defineComponent({__name:"pdf-engine-provider",props:{engine:{},isLoading:{type:Boolean},error:{}},setup(n){const t=n,{engine:o,isLoading:i,error:u}=e.toRefs(t);return e.provide(r,{engine:o,isLoading:i,error:u}),(n,r)=>e.renderSlot(n.$slots,"default")}});exports.PdfEngineProvider=i,exports.useEngine=function(){const{engine:e,error:n}=t();if(n.value)throw n.value;return e},exports.useEngineContext=t,exports.usePdfiumEngine=function(r={}){const{wasmUrl:t=o,worker:i=!0,logger:u}=r,s=e.ref(null),a=e.ref(!0),l=e.ref(null);async function d(){try{const{createPdfiumEngine:e}=i?await import("@embedpdf/engines/pdfium-worker-engine"):await import("@embedpdf/engines/pdfium-direct-engine"),n=await e(t,u);n.initialize().wait((()=>{a.value=!1,s.value=n}),(e=>{l.value=new Error(e.reason.message),a.value=!1})),a.value=!1}catch(e){l.value=e,a.value=!1}}function c(){var e,r;null==(r=null==(e=s.value)?void 0:e.closeAllDocuments)||r.call(e).wait((()=>{var e,n;null==(n=null==(e=s.value)?void 0:e.destroy)||n.call(e),s.value=null}),n.ignore)}return e.onMounted(d),e.onBeforeUnmount(c),e.watch((()=>[t,i,u]),(()=>{c(),d()})),{engine:s,isLoading:a,error:l}};
1
+ "use strict";Object.create,Object.defineProperty,Object.getOwnPropertyDescriptor,Object.getOwnPropertyNames,Object.getPrototypeOf,Object.prototype.hasOwnProperty;Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue"),n=require("@embedpdf/models"),r=Symbol("pdfEngineKey");function t(){const n=e.inject(r);if(!n)throw new Error("useEngineContext must be used within a PdfEngineProvider");return n}const o="https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.4.0/dist/pdfium.wasm";const i=e.defineComponent({__name:"pdf-engine-provider",props:{engine:{},isLoading:{type:Boolean},error:{}},setup(n){const t=n,{engine:o,isLoading:i,error:u}=e.toRefs(t);return e.provide(r,{engine:o,isLoading:i,error:u}),(n,r)=>e.renderSlot(n.$slots,"default")}});exports.PdfEngineProvider=i,exports.useEngine=function(){const{engine:e,error:n}=t();if(n.value)throw n.value;return e},exports.useEngineContext=t,exports.usePdfiumEngine=function(r={}){const{wasmUrl:t=o,worker:i=!0,logger:u}=r,s=e.ref(null),a=e.ref(!0),l=e.ref(null);async function d(){try{const{createPdfiumEngine:e}=i?await import("@embedpdf/engines/pdfium-worker-engine"):await import("@embedpdf/engines/pdfium-direct-engine"),n=await e(t,u);n.initialize().wait((()=>{a.value=!1,s.value=n}),(e=>{l.value=new Error(e.reason.message),a.value=!1})),a.value=!1}catch(e){l.value=e,a.value=!1}}function c(){var e,r;null==(r=null==(e=s.value)?void 0:e.closeAllDocuments)||r.call(e).wait((()=>{var e,n;null==(n=null==(e=s.value)?void 0:e.destroy)||n.call(e),s.value=null}),n.ignore)}return e.onMounted(d),e.onBeforeUnmount(c),e.watch((()=>[t,i,u]),(()=>{c(),d()})),{engine:s,isLoading:a,error:l}};
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../src/vue/context/pdf-engine-context.ts","../../src/vue/composables/use-engine-context.ts","../../src/vue/composables/use-pdfium-engine.ts","../../src/vue/components/pdf-engine-provider.vue"],"sourcesContent":["import { InjectionKey, Ref } from 'vue';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineContextState {\n engine: Ref<PdfEngine | null>;\n isLoading: Ref<boolean>;\n error: Ref<Error | null>;\n}\n\nexport const pdfEngineKey: InjectionKey<PdfEngineContextState> = Symbol('pdfEngineKey');\n","import { inject } from 'vue';\nimport { pdfEngineKey, PdfEngineContextState } from '../context/pdf-engine-context';\n\n/**\n * Composable to access the PDF engine from context.\n * @returns The PDF engine context state\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function useEngineContext(): PdfEngineContextState {\n const contextValue = inject(pdfEngineKey);\n\n if (!contextValue) {\n throw new Error('useEngineContext must be used within a PdfEngineProvider');\n }\n\n return contextValue;\n}\n\n/**\n * Composable to access the PDF engine, with a more convenient API.\n * @returns The PDF engine or null if loading/error\n */\nexport function useEngine() {\n const { engine, error } = useEngineContext();\n\n if (error.value) {\n throw error.value;\n }\n\n return engine;\n}\n","import { ref, onMounted, onBeforeUnmount, watch, Ref } from 'vue';\nimport { ignore, type Logger, type PdfEngine } from '@embedpdf/models';\n\nconst defaultWasmUrl =\n 'https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm';\n\ninterface UsePdfiumEngineProps {\n wasmUrl?: string;\n worker?: boolean;\n logger?: Logger;\n}\n\ninterface UsePdfiumEngineResult {\n engine: Ref<PdfEngine | null>;\n isLoading: Ref<boolean>;\n error: Ref<Error | null>;\n}\n\n/**\n * Vue composable that loads a PdfiumEngine (worker or direct)\n * and keeps its lifetime tied to the component.\n */\nexport function usePdfiumEngine(props: UsePdfiumEngineProps = {}): UsePdfiumEngineResult {\n const { wasmUrl = defaultWasmUrl, worker = true, logger } = props;\n\n const engine = ref<PdfEngine | null>(null);\n const isLoading = ref(true);\n const error = ref<Error | null>(null);\n\n /* create / destroy tied to component lifecycle ----------------- */\n onMounted(loadEngine);\n onBeforeUnmount(destroyEngine);\n\n /* re‑load if reactive props change ----------------------------- */\n watch(\n () => [wasmUrl, worker, logger] as const,\n () => {\n destroyEngine();\n loadEngine();\n },\n );\n\n async function loadEngine() {\n try {\n const { createPdfiumEngine } = worker\n ? await import('@embedpdf/engines/pdfium-worker-engine')\n : await import('@embedpdf/engines/pdfium-direct-engine');\n\n const pdfEngine = await createPdfiumEngine(wasmUrl, logger);\n pdfEngine.initialize().wait(\n () => {\n isLoading.value = false;\n engine.value = pdfEngine;\n },\n (e) => {\n error.value = new Error(e.reason.message);\n isLoading.value = false;\n },\n );\n isLoading.value = false;\n } catch (e) {\n error.value = e as Error;\n isLoading.value = false;\n }\n }\n\n function destroyEngine() {\n engine.value?.closeAllDocuments?.().wait(() => {\n engine.value?.destroy?.();\n engine.value = null;\n }, ignore);\n }\n\n return { engine, isLoading, error };\n}\n","<script setup lang=\"ts\">\nimport { provide, toRefs } from 'vue';\nimport { pdfEngineKey } from '../context/pdf-engine-context';\nimport type { PdfEngine } from '@embedpdf/models';\n\ninterface Props {\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\nconst props = defineProps<Props>();\n\n// Convert props to refs and provide them\nconst { engine, isLoading, error } = toRefs(props);\n\nprovide(pdfEngineKey, {\n engine,\n isLoading,\n error,\n});\n</script>\n\n<template>\n <slot />\n</template>\n"],"names":["pdfEngineKey","Symbol","useEngineContext","contextValue","inject","Error","defaultWasmUrl","props","__props","engine","isLoading","error","toRefs","provide","_renderSlot","_ctx","$slots","value","wasmUrl","worker","logger","ref","async","loadEngine","createPdfiumEngine","import","pdfEngine","initialize","wait","e","reason","message","destroyEngine","_b","_a","closeAllDocuments","call","destroy","ignore","onMounted","onBeforeUnmount","vue","watch"],"mappings":"0RASaA,EAAoDC,OAAO,gBCDjE,SAASC,IACR,MAAAC,EAAeC,SAAOJ,GAE5B,IAAKG,EACG,MAAA,IAAIE,MAAM,4DAGX,OAAAF,CACT,CCbA,MAAMG,EACJ,6LCOF,MAAMC,EAAQC,GAGRC,OAAEA,EAAQC,UAAAA,EAAAC,MAAWA,GAAUC,EAAAA,OAAOL,UAE5CM,EAAAA,QAAQb,EAAc,CACpBS,SACAC,YACAC,iBAKAG,aAAQC,EAAAC,OAAA,4DFFH,WACL,MAAMP,OAAEA,EAAAE,MAAQA,GAAUT,IAE1B,GAAIS,EAAMM,MACR,MAAMN,EAAMM,MAGP,OAAAR,CACT,qDCRgB,SAAgBF,EAA8B,IAC5D,MAAMW,QAAEA,EAAUZ,EAAAa,OAAgBA,GAAS,EAAAC,OAAMA,GAAWb,EAEtDE,EAASY,MAAsB,MAC/BX,EAAYW,OAAI,GAChBV,EAAQU,MAAkB,MAehCC,eAAeC,IACT,IACI,MAAAC,mBAAEA,GAAuBL,QACrBM,OAAO,gDACPA,OAAO,0CAEXC,QAAkBF,EAAmBN,EAASE,GACpDM,EAAUC,aAAaC,MACrB,KACElB,EAAUO,OAAQ,EAClBR,EAAOQ,MAAQS,CAAA,IAEhBG,IACClB,EAAMM,MAAQ,IAAIZ,MAAMwB,EAAEC,OAAOC,SACjCrB,EAAUO,OAAQ,CAAA,IAGtBP,EAAUO,OAAQ,QACXY,GACPlB,EAAMM,MAAQY,EACdnB,EAAUO,OAAQ,CAAA,CACpB,CAGF,SAASe,YACP,OAAAC,EAAA,OAAAC,EAAAzB,EAAOQ,YAAP,EAAAiB,EAAcC,oBAAdF,EAAAG,KAAAF,GAAoCN,MAAK,aACvC,OAAAK,EAAA,OAAAC,EAAAzB,EAAOQ,cAAPiB,EAAcG,UAAdJ,EAAAG,KAAAF,GACAzB,EAAOQ,MAAQ,IAAA,GACdqB,SAAM,CAGJ,OA3CPC,EAAAA,UAAUhB,GACViB,EAAAA,gBAAgBR,GAGhBS,EAAAC,OACE,IAAM,CAACxB,EAASC,EAAQC,KACxB,KACgBY,IACHT,GAAA,IAmCR,CAAEd,SAAQC,YAAWC,QAC9B"}
1
+ {"version":3,"file":"index.cjs","sources":["../../src/vue/context/pdf-engine-context.ts","../../src/vue/composables/use-engine-context.ts","../../src/vue/composables/use-pdfium-engine.ts","../../src/vue/components/pdf-engine-provider.vue"],"sourcesContent":["import { InjectionKey, Ref } from 'vue';\nimport type { PdfEngine } from '@embedpdf/models';\n\nexport interface PdfEngineContextState {\n engine: Ref<PdfEngine | null>;\n isLoading: Ref<boolean>;\n error: Ref<Error | null>;\n}\n\nexport const pdfEngineKey: InjectionKey<PdfEngineContextState> = Symbol('pdfEngineKey');\n","import { inject } from 'vue';\nimport { pdfEngineKey, PdfEngineContextState } from '../context/pdf-engine-context';\n\n/**\n * Composable to access the PDF engine from context.\n * @returns The PDF engine context state\n * @throws Error if used outside of PdfEngineProvider\n */\nexport function useEngineContext(): PdfEngineContextState {\n const contextValue = inject(pdfEngineKey);\n\n if (!contextValue) {\n throw new Error('useEngineContext must be used within a PdfEngineProvider');\n }\n\n return contextValue;\n}\n\n/**\n * Composable to access the PDF engine, with a more convenient API.\n * @returns The PDF engine or null if loading/error\n */\nexport function useEngine() {\n const { engine, error } = useEngineContext();\n\n if (error.value) {\n throw error.value;\n }\n\n return engine;\n}\n","import { ref, onMounted, onBeforeUnmount, watch, Ref } from 'vue';\nimport { ignore, type Logger, type PdfEngine } from '@embedpdf/models';\n\nconst defaultWasmUrl =\n 'https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@__PDFIUM_VERSION__/dist/pdfium.wasm';\n\ninterface UsePdfiumEngineProps {\n wasmUrl?: string;\n worker?: boolean;\n logger?: Logger;\n}\n\ninterface UsePdfiumEngineResult {\n engine: Ref<PdfEngine | null>;\n isLoading: Ref<boolean>;\n error: Ref<Error | null>;\n}\n\n/**\n * Vue composable that loads a PdfiumEngine (worker or direct)\n * and keeps its lifetime tied to the component.\n */\nexport function usePdfiumEngine(props: UsePdfiumEngineProps = {}): UsePdfiumEngineResult {\n const { wasmUrl = defaultWasmUrl, worker = true, logger } = props;\n\n const engine = ref<PdfEngine | null>(null);\n const isLoading = ref(true);\n const error = ref<Error | null>(null);\n\n /* create / destroy tied to component lifecycle ----------------- */\n onMounted(loadEngine);\n onBeforeUnmount(destroyEngine);\n\n /* re‑load if reactive props change ----------------------------- */\n watch(\n () => [wasmUrl, worker, logger] as const,\n () => {\n destroyEngine();\n loadEngine();\n },\n );\n\n async function loadEngine() {\n try {\n const { createPdfiumEngine } = worker\n ? await import('@embedpdf/engines/pdfium-worker-engine')\n : await import('@embedpdf/engines/pdfium-direct-engine');\n\n const pdfEngine = await createPdfiumEngine(wasmUrl, logger);\n pdfEngine.initialize().wait(\n () => {\n isLoading.value = false;\n engine.value = pdfEngine;\n },\n (e) => {\n error.value = new Error(e.reason.message);\n isLoading.value = false;\n },\n );\n isLoading.value = false;\n } catch (e) {\n error.value = e as Error;\n isLoading.value = false;\n }\n }\n\n function destroyEngine() {\n engine.value?.closeAllDocuments?.().wait(() => {\n engine.value?.destroy?.();\n engine.value = null;\n }, ignore);\n }\n\n return { engine, isLoading, error };\n}\n","<script setup lang=\"ts\">\nimport { provide, toRefs } from 'vue';\nimport { pdfEngineKey } from '../context/pdf-engine-context';\nimport type { PdfEngine } from '@embedpdf/models';\n\ninterface Props {\n engine: PdfEngine | null;\n isLoading: boolean;\n error: Error | null;\n}\n\nconst props = defineProps<Props>();\n\n// Convert props to refs and provide them\nconst { engine, isLoading, error } = toRefs(props);\n\nprovide(pdfEngineKey, {\n engine,\n isLoading,\n error,\n});\n</script>\n\n<template>\n <slot />\n</template>\n"],"names":["pdfEngineKey","Symbol","useEngineContext","contextValue","inject","Error","defaultWasmUrl","props","__props","engine","isLoading","error","toRefs","provide","_renderSlot","_ctx","$slots","value","wasmUrl","worker","logger","ref","async","loadEngine","createPdfiumEngine","import","pdfEngine","initialize","wait","e","reason","message","destroyEngine","_b","_a","closeAllDocuments","call","destroy","ignore","onMounted","onBeforeUnmount","vue","watch"],"mappings":"0RASaA,EAAoDC,OAAO,gBCDjE,SAASC,IACR,MAAAC,EAAeC,SAAOJ,GAE5B,IAAKG,EACG,MAAA,IAAIE,MAAM,4DAGX,OAAAF,CACT,CCbA,MAAMG,EACJ,4LCOF,MAAMC,EAAQC,GAGRC,OAAEA,EAAQC,UAAAA,EAAAC,MAAWA,GAAUC,EAAAA,OAAOL,UAE5CM,EAAAA,QAAQb,EAAc,CACpBS,SACAC,YACAC,iBAKAG,aAAQC,EAAAC,OAAA,4DFFH,WACL,MAAMP,OAAEA,EAAAE,MAAQA,GAAUT,IAE1B,GAAIS,EAAMM,MACR,MAAMN,EAAMM,MAGP,OAAAR,CACT,qDCRgB,SAAgBF,EAA8B,IAC5D,MAAMW,QAAEA,EAAUZ,EAAAa,OAAgBA,GAAS,EAAAC,OAAMA,GAAWb,EAEtDE,EAASY,MAAsB,MAC/BX,EAAYW,OAAI,GAChBV,EAAQU,MAAkB,MAehCC,eAAeC,IACT,IACI,MAAAC,mBAAEA,GAAuBL,QACrBM,OAAO,gDACPA,OAAO,0CAEXC,QAAkBF,EAAmBN,EAASE,GACpDM,EAAUC,aAAaC,MACrB,KACElB,EAAUO,OAAQ,EAClBR,EAAOQ,MAAQS,CAAA,IAEhBG,IACClB,EAAMM,MAAQ,IAAIZ,MAAMwB,EAAEC,OAAOC,SACjCrB,EAAUO,OAAQ,CAAA,IAGtBP,EAAUO,OAAQ,QACXY,GACPlB,EAAMM,MAAQY,EACdnB,EAAUO,OAAQ,CAAA,CACpB,CAGF,SAASe,YACP,OAAAC,EAAA,OAAAC,EAAAzB,EAAOQ,YAAP,EAAAiB,EAAcC,oBAAdF,EAAAG,KAAAF,GAAoCN,MAAK,aACvC,OAAAK,EAAA,OAAAC,EAAAzB,EAAOQ,cAAPiB,EAAcG,UAAdJ,EAAAG,KAAAF,GACAzB,EAAOQ,MAAQ,IAAA,GACdqB,SAAM,CAGJ,OA3CPC,EAAAA,UAAUhB,GACViB,EAAAA,gBAAgBR,GAGhBS,EAAAC,OACE,IAAM,CAACxB,EAASC,EAAQC,KACxB,KACgBY,IACHT,GAAA,IAmCR,CAAEd,SAAQC,YAAWC,QAC9B"}
package/dist/vue/index.js CHANGED
@@ -15,7 +15,7 @@ function useEngine() {
15
15
  }
16
16
  return engine;
17
17
  }
18
- const defaultWasmUrl = "https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.3.16/dist/pdfium.wasm";
18
+ const defaultWasmUrl = "https://cdn.jsdelivr.net/npm/@embedpdf/pdfium@1.4.0/dist/pdfium.wasm";
19
19
  function usePdfiumEngine(props = {}) {
20
20
  const { wasmUrl = defaultWasmUrl, worker = true, logger } = props;
21
21
  const engine = ref(null);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@embedpdf/engines",
3
- "version": "1.3.16",
3
+ "version": "1.4.0",
4
4
  "description": "Pluggable runtime layer that abstracts over multiple PDF engines (PDF-ium, Web Workers, mocks, etc.) to provide a unified API for rendering, search, annotation, and other document-level operations in EmbedPDF.",
5
5
  "type": "module",
6
6
  "main": "./dist/index.cjs",
@@ -51,6 +51,12 @@
51
51
  "types": "./dist/vue/index.d.ts",
52
52
  "import": "./dist/vue/index.js",
53
53
  "require": "./dist/vue/index.cjs"
54
+ },
55
+ "./svelte": {
56
+ "types": "./dist/svelte/index.d.ts",
57
+ "svelte": "./dist/svelte/index.js",
58
+ "import": "./dist/svelte/index.js",
59
+ "require": "./dist/svelte/index.cjs"
54
60
  }
55
61
  },
56
62
  "keywords": [
@@ -79,16 +85,17 @@
79
85
  "jest": "^29.7.0",
80
86
  "ts-jest": "^29.2.5",
81
87
  "typescript": "^5.0.0",
82
- "@embedpdf/build": "1.0.1"
88
+ "@embedpdf/build": "1.1.0"
83
89
  },
84
90
  "dependencies": {
85
- "@embedpdf/models": "1.3.16",
86
- "@embedpdf/pdfium": "1.3.16"
91
+ "@embedpdf/models": "1.4.0",
92
+ "@embedpdf/pdfium": "1.4.0"
87
93
  },
88
94
  "peerDependencies": {
95
+ "preact": "^10.26.4",
89
96
  "react": ">=16.8.0",
90
97
  "react-dom": ">=16.8.0",
91
- "preact": "^10.26.4",
98
+ "svelte": ">=5 <6",
92
99
  "vue": ">=3.2.0"
93
100
  },
94
101
  "publishConfig": {
@@ -99,7 +106,8 @@
99
106
  "build:react": "vite build --mode react",
100
107
  "build:preact": "vite build --mode preact",
101
108
  "build:vue": "vite build --mode vue",
102
- "build": "pnpm run clean && concurrently -c auto -n base,react,preact,vue \"vite build --mode base\" \"vite build --mode react\" \"vite build --mode preact\" \"vite build --mode vue\"",
109
+ "build:svelte": "vite build --mode svelte",
110
+ "build": "pnpm run clean && concurrently -c auto -n base,react,preact,vue,svelte \"vite build --mode base\" \"vite build --mode react\" \"vite build --mode preact\" \"vite build --mode vue\" \"vite build --mode svelte\"",
103
111
  "clean": "rimraf dist",
104
112
  "lint": "eslint src --color",
105
113
  "lint:fix": "eslint src --color --fix"
@@ -1,25 +0,0 @@
1
- import { PdfDocumentObject, PdfEngine, PdfFile } from '@embedpdf/models';
2
- /**
3
- * Create mock of pdf engine
4
- * @param partialEngine - partial configuration of engine
5
- * @returns - mock of pdf engine
6
- *
7
- * @public
8
- */
9
- export declare function createMockPdfEngine(partialEngine?: Partial<PdfEngine>): PdfEngine;
10
- /**
11
- * Create mock of pdf document
12
- * @param doc - partial configuration of document
13
- * @returns mock of pdf document
14
- *
15
- * @public
16
- */
17
- export declare function createMockPdfDocument(doc?: Partial<PdfDocumentObject>): PdfDocumentObject;
18
- /**
19
- * Create mock of pdf file
20
- * @param file - partial configuration of file
21
- * @returns mock of pdf file
22
- *
23
- * @public
24
- */
25
- export declare function createMockPdfFile(file?: Partial<PdfFile>): PdfFile;