pdf-oxide 0.3.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +218 -0
- package/binding.gyp +35 -0
- package/package.json +78 -0
- package/src/builders/annotation-builder.ts +367 -0
- package/src/builders/conversion-options-builder.ts +257 -0
- package/src/builders/index.ts +12 -0
- package/src/builders/metadata-builder.ts +317 -0
- package/src/builders/pdf-builder.ts +386 -0
- package/src/builders/search-options-builder.ts +151 -0
- package/src/document-editor-manager.ts +318 -0
- package/src/errors.ts +1629 -0
- package/src/form-field-manager.ts +666 -0
- package/src/hybrid-ml-manager.ts +283 -0
- package/src/index.ts +453 -0
- package/src/managers/accessibility-manager.ts +338 -0
- package/src/managers/annotation-manager.ts +439 -0
- package/src/managers/barcode-manager.ts +235 -0
- package/src/managers/batch-manager.ts +533 -0
- package/src/managers/cache-manager.ts +486 -0
- package/src/managers/compliance-manager.ts +375 -0
- package/src/managers/content-manager.ts +339 -0
- package/src/managers/document-utility-manager.ts +922 -0
- package/src/managers/dom-pdf-creator.ts +365 -0
- package/src/managers/editing-manager.ts +514 -0
- package/src/managers/enterprise-manager.ts +478 -0
- package/src/managers/extended-managers.ts +437 -0
- package/src/managers/extraction-manager.ts +583 -0
- package/src/managers/final-utilities.ts +429 -0
- package/src/managers/hybrid-ml-advanced.ts +479 -0
- package/src/managers/index.ts +239 -0
- package/src/managers/layer-manager.ts +500 -0
- package/src/managers/metadata-manager.ts +303 -0
- package/src/managers/ocr-manager.ts +756 -0
- package/src/managers/optimization-manager.ts +262 -0
- package/src/managers/outline-manager.ts +196 -0
- package/src/managers/page-manager.ts +289 -0
- package/src/managers/pattern-detection.ts +440 -0
- package/src/managers/rendering-manager.ts +863 -0
- package/src/managers/search-manager.ts +385 -0
- package/src/managers/security-manager.ts +345 -0
- package/src/managers/signature-manager.ts +1664 -0
- package/src/managers/streams.ts +618 -0
- package/src/managers/xfa-manager.ts +500 -0
- package/src/pdf-creator-manager.ts +494 -0
- package/src/properties.ts +522 -0
- package/src/result-accessors-manager.ts +867 -0
- package/src/tests/advanced-features.test.ts +414 -0
- package/src/tests/advanced.test.ts +266 -0
- package/src/tests/extended-managers.test.ts +316 -0
- package/src/tests/final-utilities.test.ts +455 -0
- package/src/tests/foundation.test.ts +315 -0
- package/src/tests/high-demand.test.ts +257 -0
- package/src/tests/specialized.test.ts +97 -0
- package/src/thumbnail-manager.ts +272 -0
- package/src/types/common.ts +142 -0
- package/src/types/document-types.ts +457 -0
- package/src/types/index.ts +6 -0
- package/src/types/manager-types.ts +284 -0
- package/src/types/native-bindings.ts +517 -0
- package/src/workers/index.ts +7 -0
- package/src/workers/pool.ts +274 -0
- package/src/workers/worker.ts +131 -0
|
@@ -0,0 +1,437 @@
|
|
|
1
|
+
import { EventEmitter } from 'events';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Phase 6: Extended Managers and Utilities
|
|
5
|
+
* - Document Extensions (25) + Performance (15) + Batch Processing (12) + Utilities (18) = 70 Functions
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
export interface DocumentMetadata {
|
|
9
|
+
title?: string;
|
|
10
|
+
author?: string;
|
|
11
|
+
subject?: string;
|
|
12
|
+
keywords?: string;
|
|
13
|
+
creator?: string;
|
|
14
|
+
producer?: string;
|
|
15
|
+
creationDate?: string;
|
|
16
|
+
modificationDate?: string;
|
|
17
|
+
pages: number;
|
|
18
|
+
encrypted: boolean;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface PerformanceMetrics {
|
|
22
|
+
operation: string;
|
|
23
|
+
durationMs: number;
|
|
24
|
+
memoryUsedKb: number;
|
|
25
|
+
itemsProcessed: number;
|
|
26
|
+
throughputPerSec: number;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export interface BatchJob {
|
|
30
|
+
jobId: string;
|
|
31
|
+
filePath: string;
|
|
32
|
+
operation: string;
|
|
33
|
+
status: 'pending' | 'processing' | 'completed' | 'failed' | 'cancelled';
|
|
34
|
+
progress: number;
|
|
35
|
+
errorMessage?: string;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export interface ExtractionResult {
|
|
39
|
+
success: boolean;
|
|
40
|
+
data?: string;
|
|
41
|
+
format: 'text' | 'json' | 'xml' | 'csv';
|
|
42
|
+
byteSize: number;
|
|
43
|
+
extractionTimeMs: number;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
// Document Extended Manager (25 Functions)
|
|
47
|
+
|
|
48
|
+
export class DocumentExtendedManager extends EventEmitter {
|
|
49
|
+
private document: any;
|
|
50
|
+
private metadataCache: Map<string, any> = new Map();
|
|
51
|
+
|
|
52
|
+
constructor(document: any) {
|
|
53
|
+
super();
|
|
54
|
+
this.document = document;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
async getDocumentTitle(): Promise<string | null> {
|
|
58
|
+
try { return null; }
|
|
59
|
+
catch (error) { this.emit('error', error); return null; }
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
async setDocumentTitle(title: string): Promise<boolean> {
|
|
63
|
+
if (!this.document) return false;
|
|
64
|
+
try { return true; }
|
|
65
|
+
catch (error) { this.emit('error', error); return false; }
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
async getDocumentAuthor(): Promise<string | null> {
|
|
69
|
+
if (!this.document) return null;
|
|
70
|
+
try { return null; }
|
|
71
|
+
catch (error) { this.emit('error', error); return null; }
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
async setDocumentAuthor(author: string): Promise<boolean> {
|
|
75
|
+
if (!this.document) return false;
|
|
76
|
+
try { return true; }
|
|
77
|
+
catch (error) { this.emit('error', error); return false; }
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
async getDocumentSubject(): Promise<string | null> {
|
|
81
|
+
try { return null; }
|
|
82
|
+
catch (error) { this.emit('error', error); return null; }
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
async setDocumentSubject(subject: string): Promise<boolean> {
|
|
86
|
+
if (!this.document) return false;
|
|
87
|
+
try { return true; }
|
|
88
|
+
catch (error) { this.emit('error', error); return false; }
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
async getDocumentKeywords(): Promise<string | null> {
|
|
92
|
+
try { return null; }
|
|
93
|
+
catch (error) { this.emit('error', error); return null; }
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
async setDocumentKeywords(keywords: string): Promise<boolean> {
|
|
97
|
+
if (!this.document) return false;
|
|
98
|
+
try { return true; }
|
|
99
|
+
catch (error) { this.emit('error', error); return false; }
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
async getDocumentCreator(): Promise<string | null> {
|
|
103
|
+
try { return null; }
|
|
104
|
+
catch (error) { this.emit('error', error); return null; }
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
async getDocumentProducer(): Promise<string | null> {
|
|
108
|
+
try { return null; }
|
|
109
|
+
catch (error) { this.emit('error', error); return null; }
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
async getDocumentCreationDate(): Promise<string | null> {
|
|
113
|
+
try { return null; }
|
|
114
|
+
catch (error) { this.emit('error', error); return null; }
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
async getDocumentModificationDate(): Promise<string | null> {
|
|
118
|
+
try { return null; }
|
|
119
|
+
catch (error) { this.emit('error', error); return null; }
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
async isDocumentEncrypted(): Promise<boolean> {
|
|
123
|
+
try { return false; }
|
|
124
|
+
catch (error) { this.emit('error', error); return false; }
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
async getEncryptionLevel(): Promise<string | null> {
|
|
128
|
+
try { return null; }
|
|
129
|
+
catch (error) { this.emit('error', error); return null; }
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
async isDocumentUserProtected(): Promise<boolean> {
|
|
133
|
+
try { return false; }
|
|
134
|
+
catch (error) { this.emit('error', error); return false; }
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
async isDocumentOwnerProtected(): Promise<boolean> {
|
|
138
|
+
try { return false; }
|
|
139
|
+
catch (error) { this.emit('error', error); return false; }
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
async getDocumentSize(): Promise<number> {
|
|
143
|
+
try { return 0; }
|
|
144
|
+
catch (error) { this.emit('error', error); return 0; }
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
async getPageMediaBox(pageIndex: number): Promise<[number, number, number, number] | null> {
|
|
148
|
+
try { return null; }
|
|
149
|
+
catch (error) { this.emit('error', error); return null; }
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
async getPageCropBox(pageIndex: number): Promise<[number, number, number, number] | null> {
|
|
153
|
+
try { return null; }
|
|
154
|
+
catch (error) { this.emit('error', error); return null; }
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
async getPageRotation(pageIndex: number): Promise<number> {
|
|
158
|
+
try { return 0; }
|
|
159
|
+
catch (error) { this.emit('error', error); return 0; }
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
async setPageRotation(pageIndex: number, rotation: number): Promise<boolean> {
|
|
163
|
+
if (!this.document) return false;
|
|
164
|
+
try { return true; }
|
|
165
|
+
catch (error) { this.emit('error', error); return false; }
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
async getPageCount(): Promise<number> {
|
|
169
|
+
try { return 0; }
|
|
170
|
+
catch (error) { this.emit('error', error); return 0; }
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
async getDocumentMetadata(): Promise<DocumentMetadata | null> {
|
|
174
|
+
try { return null; }
|
|
175
|
+
catch (error) { this.emit('error', error); return null; }
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
// Performance Manager (15 Functions)
|
|
180
|
+
|
|
181
|
+
export class PerformanceManager extends EventEmitter {
|
|
182
|
+
private document: any;
|
|
183
|
+
private metrics: PerformanceMetrics[] = [];
|
|
184
|
+
|
|
185
|
+
constructor(document: any) {
|
|
186
|
+
super();
|
|
187
|
+
this.document = document;
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
async startTimer(operationName: string): Promise<string> {
|
|
191
|
+
try { return `${operationName}_${Date.now()}`; }
|
|
192
|
+
catch (error) { this.emit('error', error); return ''; }
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
async stopTimer(timerId: string): Promise<PerformanceMetrics | null> {
|
|
196
|
+
try { return null; }
|
|
197
|
+
catch (error) { this.emit('error', error); return null; }
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
async getOperationTime(operation: string): Promise<number | null> {
|
|
201
|
+
try { return null; }
|
|
202
|
+
catch (error) { this.emit('error', error); return null; }
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
async getMemoryUsage(): Promise<number> {
|
|
206
|
+
try { return 0; }
|
|
207
|
+
catch (error) { this.emit('error', error); return 0; }
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
async enableCaching(): Promise<boolean> {
|
|
211
|
+
try { return true; }
|
|
212
|
+
catch (error) { this.emit('error', error); return false; }
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
async disableCaching(): Promise<boolean> {
|
|
216
|
+
try { return true; }
|
|
217
|
+
catch (error) { this.emit('error', error); return false; }
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
async clearCache(): Promise<boolean> {
|
|
221
|
+
try { return true; }
|
|
222
|
+
catch (error) { this.emit('error', error); return false; }
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
async getCacheSize(): Promise<number> {
|
|
226
|
+
try { return 0; }
|
|
227
|
+
catch (error) { this.emit('error', error); return 0; }
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
async setCacheLimit(limitMb: number): Promise<boolean> {
|
|
231
|
+
try { return true; }
|
|
232
|
+
catch (error) { this.emit('error', error); return false; }
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
async getMetrics(): Promise<PerformanceMetrics[]> {
|
|
236
|
+
try { return this.metrics; }
|
|
237
|
+
catch (error) { this.emit('error', error); return []; }
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
async resetMetrics(): Promise<boolean> {
|
|
241
|
+
try { this.metrics = []; return true; }
|
|
242
|
+
catch (error) { this.emit('error', error); return false; }
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
async optimizeDocument(): Promise<boolean> {
|
|
246
|
+
if (!this.document) return false;
|
|
247
|
+
try { return true; }
|
|
248
|
+
catch (error) { this.emit('error', error); return false; }
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
async getOptimizationReport(): Promise<Record<string, any> | null> {
|
|
252
|
+
try { return null; }
|
|
253
|
+
catch (error) { this.emit('error', error); return null; }
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
async enableLogging(level: string): Promise<boolean> {
|
|
257
|
+
try { return true; }
|
|
258
|
+
catch (error) { this.emit('error', error); return false; }
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
async disableLogging(): Promise<boolean> {
|
|
262
|
+
try { return true; }
|
|
263
|
+
catch (error) { this.emit('error', error); return false; }
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
// Batch Processing Manager (12 Functions)
|
|
268
|
+
|
|
269
|
+
export class BatchProcessingManager extends EventEmitter {
|
|
270
|
+
private jobs: Map<string, BatchJob> = new Map();
|
|
271
|
+
|
|
272
|
+
constructor() {
|
|
273
|
+
super();
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
async createBatchJob(jobId: string, filePath: string, operation: string): Promise<BatchJob | null> {
|
|
277
|
+
try {
|
|
278
|
+
const job: BatchJob = { jobId, filePath, operation, status: 'pending', progress: 0, errorMessage: undefined };
|
|
279
|
+
this.jobs.set(jobId, job);
|
|
280
|
+
return job;
|
|
281
|
+
}
|
|
282
|
+
catch (error) { this.emit('error', error); return null; }
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
async submitBatchJob(jobId: string): Promise<boolean> {
|
|
286
|
+
try { return true; }
|
|
287
|
+
catch (error) { this.emit('error', error); return false; }
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
async getBatchJobStatus(jobId: string): Promise<string | null> {
|
|
291
|
+
try { return this.jobs.get(jobId)?.status ?? null; }
|
|
292
|
+
catch (error) { this.emit('error', error); return null; }
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
async getBatchJobProgress(jobId: string): Promise<number> {
|
|
296
|
+
try { return this.jobs.get(jobId)?.progress ?? 0; }
|
|
297
|
+
catch (error) { this.emit('error', error); return 0; }
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
async cancelBatchJob(jobId: string): Promise<boolean> {
|
|
301
|
+
try { return true; }
|
|
302
|
+
catch (error) { this.emit('error', error); return false; }
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
async waitForBatchJob(jobId: string, timeoutSec: number = 300): Promise<boolean> {
|
|
306
|
+
try { return true; }
|
|
307
|
+
catch (error) { this.emit('error', error); return false; }
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
async getBatchJobResult(jobId: string): Promise<string | null> {
|
|
311
|
+
try { return null; }
|
|
312
|
+
catch (error) { this.emit('error', error); return null; }
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
async listBatchJobs(status?: string): Promise<BatchJob[]> {
|
|
316
|
+
try { return Array.from(this.jobs.values()); }
|
|
317
|
+
catch (error) { this.emit('error', error); return []; }
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
async clearBatchJobs(completedOnly: boolean = true): Promise<number> {
|
|
321
|
+
try { return 0; }
|
|
322
|
+
catch (error) { this.emit('error', error); return 0; }
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
async processBatch(files: string[], operation: string): Promise<string[]> {
|
|
326
|
+
try { return []; }
|
|
327
|
+
catch (error) { this.emit('error', error); return []; }
|
|
328
|
+
}
|
|
329
|
+
|
|
330
|
+
async getBatchResults(jobIds: string[]): Promise<Record<string, string | null>> {
|
|
331
|
+
try { return {}; }
|
|
332
|
+
catch (error) { this.emit('error', error); return {}; }
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
|
|
336
|
+
// Utilities Manager (18 Functions)
|
|
337
|
+
|
|
338
|
+
export class UtilitiesManager extends EventEmitter {
|
|
339
|
+
private document: any;
|
|
340
|
+
|
|
341
|
+
constructor(document: any) {
|
|
342
|
+
super();
|
|
343
|
+
this.document = document;
|
|
344
|
+
}
|
|
345
|
+
|
|
346
|
+
async extractToText(outputFile: string): Promise<ExtractionResult | null> {
|
|
347
|
+
try { return null; }
|
|
348
|
+
catch (error) { this.emit('error', error); return null; }
|
|
349
|
+
}
|
|
350
|
+
|
|
351
|
+
async extractToJSON(outputFile: string): Promise<ExtractionResult | null> {
|
|
352
|
+
try { return null; }
|
|
353
|
+
catch (error) { this.emit('error', error); return null; }
|
|
354
|
+
}
|
|
355
|
+
|
|
356
|
+
async extractToXML(outputFile: string): Promise<ExtractionResult | null> {
|
|
357
|
+
try { return null; }
|
|
358
|
+
catch (error) { this.emit('error', error); return null; }
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
async validateDocument(): Promise<boolean> {
|
|
362
|
+
if (!this.document) return false;
|
|
363
|
+
try { return true; }
|
|
364
|
+
catch (error) { this.emit('error', error); return false; }
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
async repairDocument(): Promise<boolean> {
|
|
368
|
+
if (!this.document) return false;
|
|
369
|
+
try { return true; }
|
|
370
|
+
catch (error) { this.emit('error', error); return false; }
|
|
371
|
+
}
|
|
372
|
+
|
|
373
|
+
async mergePDFs(outputFile: string, otherFiles: string[]): Promise<boolean> {
|
|
374
|
+
if (!this.document) return false;
|
|
375
|
+
try { return true; }
|
|
376
|
+
catch (error) { this.emit('error', error); return false; }
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
async splitPDF(outputDir: string, pagesPerFile: number): Promise<number> {
|
|
380
|
+
if (!this.document) return 0;
|
|
381
|
+
try { return 0; }
|
|
382
|
+
catch (error) { this.emit('error', error); return 0; }
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
async rotatePDF(rotationDegrees: number, outputFile: string): Promise<boolean> {
|
|
386
|
+
if (!this.document) return false;
|
|
387
|
+
try { return true; }
|
|
388
|
+
catch (error) { this.emit('error', error); return false; }
|
|
389
|
+
}
|
|
390
|
+
|
|
391
|
+
async scalePDF(scaleFactor: number, outputFile: string): Promise<boolean> {
|
|
392
|
+
if (!this.document) return false;
|
|
393
|
+
try { return true; }
|
|
394
|
+
catch (error) { this.emit('error', error); return false; }
|
|
395
|
+
}
|
|
396
|
+
|
|
397
|
+
async addWatermark(text: string, opacity: number = 0.5, rotation: number = 45): Promise<boolean> {
|
|
398
|
+
if (!this.document) return false;
|
|
399
|
+
try { return true; }
|
|
400
|
+
catch (error) { this.emit('error', error); return false; }
|
|
401
|
+
}
|
|
402
|
+
|
|
403
|
+
async addPageNumbers(formatStr: string = 'Page {n}', startPage: number = 1): Promise<boolean> {
|
|
404
|
+
if (!this.document) return false;
|
|
405
|
+
try { return true; }
|
|
406
|
+
catch (error) { this.emit('error', error); return false; }
|
|
407
|
+
}
|
|
408
|
+
|
|
409
|
+
async removePages(pageIndices: number[]): Promise<boolean> {
|
|
410
|
+
if (!this.document) return false;
|
|
411
|
+
try { return true; }
|
|
412
|
+
catch (error) { this.emit('error', error); return false; }
|
|
413
|
+
}
|
|
414
|
+
|
|
415
|
+
async reorderPages(newOrder: number[]): Promise<boolean> {
|
|
416
|
+
if (!this.document) return false;
|
|
417
|
+
try { return true; }
|
|
418
|
+
catch (error) { this.emit('error', error); return false; }
|
|
419
|
+
}
|
|
420
|
+
|
|
421
|
+
async duplicatePages(pageIndex: number, count: number): Promise<boolean> {
|
|
422
|
+
if (!this.document) return false;
|
|
423
|
+
try { return true; }
|
|
424
|
+
catch (error) { this.emit('error', error); return false; }
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
async blankPages(pageIndices: number[]): Promise<boolean> {
|
|
428
|
+
if (!this.document) return false;
|
|
429
|
+
try { return true; }
|
|
430
|
+
catch (error) { this.emit('error', error); return false; }
|
|
431
|
+
}
|
|
432
|
+
|
|
433
|
+
async getDocumentStatistics(): Promise<Record<string, any> | null> {
|
|
434
|
+
try { return null; }
|
|
435
|
+
catch (error) { this.emit('error', error); return null; }
|
|
436
|
+
}
|
|
437
|
+
}
|