@chialab/pdfjs-lib 1.0.0-alpha.2 → 1.0.0-alpha.20
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 +15 -7
- package/dist/browser/NodeCanvasFactory-ONRE5YYL.js +58 -0
- package/dist/browser/chunk-5IWODJWD.js +801 -0
- package/dist/browser/chunk-ELOUEWKT.js +1142 -0
- package/dist/browser/chunk-NJUB3B5A.js +1207 -0
- package/dist/browser/index.js +2641 -3053
- package/dist/browser/openjpeg-K2XBCFFN.js +9 -0
- package/dist/browser/qcms_bg-Q7BRLLZG.js +9 -0
- package/dist/browser/worker.js +7307 -6457
- package/dist/index.d.ts +3 -0
- package/dist/lib/AnnotationData.d.ts +8 -8
- package/dist/lib/AnnotationOperatorsList.d.ts +21 -0
- package/dist/lib/CanvasGraphics.d.ts +1 -0
- package/dist/lib/NodeCanvasFactory.d.ts +9 -0
- package/dist/lib/NodeFilterFactory.d.ts +10 -0
- package/dist/lib/Path2D.d.ts +1 -1
- package/dist/lib/StandardFontDataFactory.d.ts +2 -2
- package/dist/lib/Svg.d.ts +143 -0
- package/dist/lib/SvgCanvasContext.d.ts +31 -22
- package/dist/lib/TextLayer.d.ts +12 -5
- package/dist/lib/WasmFactory.d.ts +5 -0
- package/dist/lib/utils.d.ts +29 -3
- package/dist/node/NodeCanvasFactory-YRBSQ5MH.js +8 -0
- package/dist/node/chunk-3XZOTLLE.js +1439 -0
- package/dist/node/chunk-XMKSLA4K.js +1207 -0
- package/dist/node/chunk-ZKUTXCS2.js +801 -0
- package/dist/node/index.js +2659 -3102
- package/dist/node/openjpeg-B2WN24QZ.js +9 -0
- package/dist/node/qcms_bg-T4RSHPOQ.js +9 -0
- package/dist/node/worker.js +7307 -6457
- package/dist/pdf.js/src/display/annotation_layer.d.ts +1 -2
- package/dist/pdf.js/src/display/annotation_storage.d.ts +1 -8
- package/dist/pdf.js/src/display/api.d.ts +38 -72
- package/dist/pdf.js/src/display/api_utils.d.ts +13 -0
- package/dist/pdf.js/src/display/canvas.d.ts +21 -29
- package/dist/pdf.js/src/display/display_utils.d.ts +12 -1
- package/dist/pdf.js/src/display/draw_layer.d.ts +2 -2
- package/dist/pdf.js/src/display/editor/alt_text.d.ts +1 -1
- package/dist/pdf.js/src/display/editor/annotation_editor_layer.d.ts +5 -5
- package/dist/pdf.js/src/display/editor/color_picker.d.ts +1 -1
- package/dist/pdf.js/src/display/editor/draw.d.ts +7 -7
- package/dist/pdf.js/src/display/editor/drawers/freedraw.d.ts +3 -3
- package/dist/pdf.js/src/display/editor/drawers/signaturedraw.d.ts +13 -13
- package/dist/pdf.js/src/display/editor/editor.d.ts +30 -6
- package/dist/pdf.js/src/display/editor/freetext.d.ts +4 -7
- package/dist/pdf.js/src/display/editor/highlight.d.ts +6 -3
- package/dist/pdf.js/src/display/editor/ink.d.ts +1 -0
- package/dist/pdf.js/src/display/editor/signature.d.ts +3 -0
- package/dist/pdf.js/src/display/editor/stamp.d.ts +4 -3
- package/dist/pdf.js/src/display/editor/toolbar.d.ts +4 -2
- package/dist/pdf.js/src/display/editor/tools.d.ts +7 -9
- package/dist/pdf.js/src/display/metadata.d.ts +1 -2
- package/dist/pdf.js/src/display/optional_content_config.d.ts +1 -1
- package/dist/pdf.js/src/display/pattern_helper.d.ts +4 -2
- package/dist/pdf.js/src/display/pdf_objects.d.ts +40 -0
- package/dist/pdf.js/src/display/text_layer.d.ts +9 -9
- package/dist/pdf.js/src/display/touch_manager.d.ts +5 -1
- package/dist/pdf.js/src/display/worker_options.d.ts +2 -2
- package/dist/pdf.js/src/pdf.d.ts +4 -1
- package/dist/pdf.js/src/shared/scripting_utils.d.ts +2 -0
- package/dist/pdf.js/src/shared/util.d.ts +123 -100
- package/dist/pdf.js/web/text_accessibility.d.ts +1 -1
- package/package.json +7 -4
- package/dist/browser/chunk-DYHYQ33L.js +0 -1775
- package/dist/node/chunk-KTTVPO2G.js +0 -1775
- package/dist/pdf.js/src/display/cmap_reader_factory.d.ts +0 -25
- package/dist/pdf.js/src/display/node_utils.d.ts +0 -32
- package/dist/pdf.js/src/display/wasm_factory.d.ts +0 -20
|
@@ -0,0 +1,801 @@
|
|
|
1
|
+
import {
|
|
2
|
+
AbortException,
|
|
3
|
+
FeatureTest,
|
|
4
|
+
ImageKind,
|
|
5
|
+
InvalidPDFException,
|
|
6
|
+
PasswordException,
|
|
7
|
+
ResponseException,
|
|
8
|
+
UnknownErrorException,
|
|
9
|
+
assert,
|
|
10
|
+
unreachable
|
|
11
|
+
} from "./chunk-XMKSLA4K.js";
|
|
12
|
+
import {
|
|
13
|
+
__privateAdd,
|
|
14
|
+
__privateGet,
|
|
15
|
+
__privateMethod,
|
|
16
|
+
__privateSet
|
|
17
|
+
} from "./chunk-7MW5RQZ5.js";
|
|
18
|
+
|
|
19
|
+
// src/lib/polyfills.ts
|
|
20
|
+
if (!Array.prototype.at) {
|
|
21
|
+
Object.defineProperty(Array.prototype, "at", {
|
|
22
|
+
value: function at(index) {
|
|
23
|
+
return this[index >= 0 ? index : this.length + index];
|
|
24
|
+
},
|
|
25
|
+
enumerable: false
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
if (!Promise.withResolvers) {
|
|
29
|
+
Promise.withResolvers = function withResolvers() {
|
|
30
|
+
let resolve;
|
|
31
|
+
let reject;
|
|
32
|
+
const promise = new this((res, rej) => {
|
|
33
|
+
resolve = res;
|
|
34
|
+
reject = rej;
|
|
35
|
+
});
|
|
36
|
+
return {
|
|
37
|
+
resolve,
|
|
38
|
+
reject,
|
|
39
|
+
promise
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
if (!("try" in Promise)) {
|
|
44
|
+
Object.defineProperty(Promise, "try", {
|
|
45
|
+
value: function tryFn(fn, ...args) {
|
|
46
|
+
return new this(
|
|
47
|
+
(resolve, reject) => {
|
|
48
|
+
try {
|
|
49
|
+
resolve(fn(...args));
|
|
50
|
+
} catch (error) {
|
|
51
|
+
reject(error);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
);
|
|
55
|
+
},
|
|
56
|
+
enumerable: false
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// src/pdf.js/src/shared/message_handler.js
|
|
61
|
+
var CallbackKind = {
|
|
62
|
+
DATA: 1,
|
|
63
|
+
ERROR: 2
|
|
64
|
+
};
|
|
65
|
+
var StreamKind = {
|
|
66
|
+
CANCEL: 1,
|
|
67
|
+
CANCEL_COMPLETE: 2,
|
|
68
|
+
CLOSE: 3,
|
|
69
|
+
ENQUEUE: 4,
|
|
70
|
+
ERROR: 5,
|
|
71
|
+
PULL: 6,
|
|
72
|
+
PULL_COMPLETE: 7,
|
|
73
|
+
START_COMPLETE: 8
|
|
74
|
+
};
|
|
75
|
+
function onFn() {
|
|
76
|
+
}
|
|
77
|
+
function wrapReason(ex) {
|
|
78
|
+
if (ex instanceof AbortException || ex instanceof InvalidPDFException || ex instanceof PasswordException || ex instanceof ResponseException || ex instanceof UnknownErrorException) {
|
|
79
|
+
return ex;
|
|
80
|
+
}
|
|
81
|
+
if (!(ex instanceof Error || typeof ex === "object" && ex !== null)) {
|
|
82
|
+
unreachable(
|
|
83
|
+
'wrapReason: Expected "reason" to be a (possibly cloned) Error.'
|
|
84
|
+
);
|
|
85
|
+
}
|
|
86
|
+
switch (ex.name) {
|
|
87
|
+
case "AbortException":
|
|
88
|
+
return new AbortException(ex.message);
|
|
89
|
+
case "InvalidPDFException":
|
|
90
|
+
return new InvalidPDFException(ex.message);
|
|
91
|
+
case "PasswordException":
|
|
92
|
+
return new PasswordException(ex.message, ex.code);
|
|
93
|
+
case "ResponseException":
|
|
94
|
+
return new ResponseException(ex.message, ex.status, ex.missing);
|
|
95
|
+
case "UnknownErrorException":
|
|
96
|
+
return new UnknownErrorException(ex.message, ex.details);
|
|
97
|
+
}
|
|
98
|
+
return new UnknownErrorException(ex.message, ex.toString());
|
|
99
|
+
}
|
|
100
|
+
var _messageAC, _MessageHandler_instances, onMessage_fn, createStreamSink_fn, processStreamMessage_fn, deleteStreamController_fn;
|
|
101
|
+
var MessageHandler = class {
|
|
102
|
+
constructor(sourceName, targetName, comObj) {
|
|
103
|
+
__privateAdd(this, _MessageHandler_instances);
|
|
104
|
+
__privateAdd(this, _messageAC, new AbortController());
|
|
105
|
+
this.sourceName = sourceName;
|
|
106
|
+
this.targetName = targetName;
|
|
107
|
+
this.comObj = comObj;
|
|
108
|
+
this.callbackId = 1;
|
|
109
|
+
this.streamId = 1;
|
|
110
|
+
this.streamSinks = /* @__PURE__ */ Object.create(null);
|
|
111
|
+
this.streamControllers = /* @__PURE__ */ Object.create(null);
|
|
112
|
+
this.callbackCapabilities = /* @__PURE__ */ Object.create(null);
|
|
113
|
+
this.actionHandler = /* @__PURE__ */ Object.create(null);
|
|
114
|
+
comObj.addEventListener("message", __privateMethod(this, _MessageHandler_instances, onMessage_fn).bind(this), {
|
|
115
|
+
signal: __privateGet(this, _messageAC).signal
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
on(actionName, handler) {
|
|
119
|
+
if (false) {
|
|
120
|
+
assert(
|
|
121
|
+
typeof handler === "function",
|
|
122
|
+
'MessageHandler.on: Expected "handler" to be a function.'
|
|
123
|
+
);
|
|
124
|
+
}
|
|
125
|
+
const ah = this.actionHandler;
|
|
126
|
+
if (ah[actionName]) {
|
|
127
|
+
throw new Error(`There is already an actionName called "${actionName}"`);
|
|
128
|
+
}
|
|
129
|
+
ah[actionName] = handler;
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Sends a message to the comObj to invoke the action with the supplied data.
|
|
133
|
+
* @param {string} actionName - Action to call.
|
|
134
|
+
* @param {JSON} data - JSON data to send.
|
|
135
|
+
* @param {Array} [transfers] - List of transfers/ArrayBuffers.
|
|
136
|
+
*/
|
|
137
|
+
send(actionName, data, transfers) {
|
|
138
|
+
this.comObj.postMessage(
|
|
139
|
+
{
|
|
140
|
+
sourceName: this.sourceName,
|
|
141
|
+
targetName: this.targetName,
|
|
142
|
+
action: actionName,
|
|
143
|
+
data
|
|
144
|
+
},
|
|
145
|
+
transfers
|
|
146
|
+
);
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Sends a message to the comObj to invoke the action with the supplied data.
|
|
150
|
+
* Expects that the other side will callback with the response.
|
|
151
|
+
* @param {string} actionName - Action to call.
|
|
152
|
+
* @param {JSON} data - JSON data to send.
|
|
153
|
+
* @param {Array} [transfers] - List of transfers/ArrayBuffers.
|
|
154
|
+
* @returns {Promise} Promise to be resolved with response data.
|
|
155
|
+
*/
|
|
156
|
+
sendWithPromise(actionName, data, transfers) {
|
|
157
|
+
const callbackId = this.callbackId++;
|
|
158
|
+
const capability = Promise.withResolvers();
|
|
159
|
+
this.callbackCapabilities[callbackId] = capability;
|
|
160
|
+
try {
|
|
161
|
+
this.comObj.postMessage(
|
|
162
|
+
{
|
|
163
|
+
sourceName: this.sourceName,
|
|
164
|
+
targetName: this.targetName,
|
|
165
|
+
action: actionName,
|
|
166
|
+
callbackId,
|
|
167
|
+
data
|
|
168
|
+
},
|
|
169
|
+
transfers
|
|
170
|
+
);
|
|
171
|
+
} catch (ex) {
|
|
172
|
+
capability.reject(ex);
|
|
173
|
+
}
|
|
174
|
+
return capability.promise;
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Sends a message to the comObj to invoke the action with the supplied data.
|
|
178
|
+
* Expect that the other side will callback to signal 'start_complete'.
|
|
179
|
+
* @param {string} actionName - Action to call.
|
|
180
|
+
* @param {JSON} data - JSON data to send.
|
|
181
|
+
* @param {Object} queueingStrategy - Strategy to signal backpressure based on
|
|
182
|
+
* internal queue.
|
|
183
|
+
* @param {Array} [transfers] - List of transfers/ArrayBuffers.
|
|
184
|
+
* @returns {ReadableStream} ReadableStream to read data in chunks.
|
|
185
|
+
*/
|
|
186
|
+
sendWithStream(actionName, data, queueingStrategy, transfers) {
|
|
187
|
+
const streamId = this.streamId++, sourceName = this.sourceName, targetName = this.targetName, comObj = this.comObj;
|
|
188
|
+
return new ReadableStream(
|
|
189
|
+
{
|
|
190
|
+
start: (controller) => {
|
|
191
|
+
const startCapability = Promise.withResolvers();
|
|
192
|
+
this.streamControllers[streamId] = {
|
|
193
|
+
controller,
|
|
194
|
+
startCall: startCapability,
|
|
195
|
+
pullCall: null,
|
|
196
|
+
cancelCall: null,
|
|
197
|
+
isClosed: false
|
|
198
|
+
};
|
|
199
|
+
comObj.postMessage(
|
|
200
|
+
{
|
|
201
|
+
sourceName,
|
|
202
|
+
targetName,
|
|
203
|
+
action: actionName,
|
|
204
|
+
streamId,
|
|
205
|
+
data,
|
|
206
|
+
desiredSize: controller.desiredSize
|
|
207
|
+
},
|
|
208
|
+
transfers
|
|
209
|
+
);
|
|
210
|
+
return startCapability.promise;
|
|
211
|
+
},
|
|
212
|
+
pull: (controller) => {
|
|
213
|
+
const pullCapability = Promise.withResolvers();
|
|
214
|
+
this.streamControllers[streamId].pullCall = pullCapability;
|
|
215
|
+
comObj.postMessage({
|
|
216
|
+
sourceName,
|
|
217
|
+
targetName,
|
|
218
|
+
stream: StreamKind.PULL,
|
|
219
|
+
streamId,
|
|
220
|
+
desiredSize: controller.desiredSize
|
|
221
|
+
});
|
|
222
|
+
return pullCapability.promise;
|
|
223
|
+
},
|
|
224
|
+
cancel: (reason) => {
|
|
225
|
+
assert(reason instanceof Error, "cancel must have a valid reason");
|
|
226
|
+
const cancelCapability = Promise.withResolvers();
|
|
227
|
+
this.streamControllers[streamId].cancelCall = cancelCapability;
|
|
228
|
+
this.streamControllers[streamId].isClosed = true;
|
|
229
|
+
comObj.postMessage({
|
|
230
|
+
sourceName,
|
|
231
|
+
targetName,
|
|
232
|
+
stream: StreamKind.CANCEL,
|
|
233
|
+
streamId,
|
|
234
|
+
reason: wrapReason(reason)
|
|
235
|
+
});
|
|
236
|
+
return cancelCapability.promise;
|
|
237
|
+
}
|
|
238
|
+
},
|
|
239
|
+
queueingStrategy
|
|
240
|
+
);
|
|
241
|
+
}
|
|
242
|
+
destroy() {
|
|
243
|
+
__privateGet(this, _messageAC)?.abort();
|
|
244
|
+
__privateSet(this, _messageAC, null);
|
|
245
|
+
}
|
|
246
|
+
};
|
|
247
|
+
_messageAC = new WeakMap();
|
|
248
|
+
_MessageHandler_instances = new WeakSet();
|
|
249
|
+
onMessage_fn = function({ data }) {
|
|
250
|
+
if (data.targetName !== this.sourceName) {
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
if (data.stream) {
|
|
254
|
+
__privateMethod(this, _MessageHandler_instances, processStreamMessage_fn).call(this, data);
|
|
255
|
+
return;
|
|
256
|
+
}
|
|
257
|
+
if (data.callback) {
|
|
258
|
+
const callbackId = data.callbackId;
|
|
259
|
+
const capability = this.callbackCapabilities[callbackId];
|
|
260
|
+
if (!capability) {
|
|
261
|
+
throw new Error(`Cannot resolve callback ${callbackId}`);
|
|
262
|
+
}
|
|
263
|
+
delete this.callbackCapabilities[callbackId];
|
|
264
|
+
if (data.callback === CallbackKind.DATA) {
|
|
265
|
+
capability.resolve(data.data);
|
|
266
|
+
} else if (data.callback === CallbackKind.ERROR) {
|
|
267
|
+
capability.reject(wrapReason(data.reason));
|
|
268
|
+
} else {
|
|
269
|
+
throw new Error("Unexpected callback case");
|
|
270
|
+
}
|
|
271
|
+
return;
|
|
272
|
+
}
|
|
273
|
+
const action = this.actionHandler[data.action];
|
|
274
|
+
if (!action) {
|
|
275
|
+
throw new Error(`Unknown action from worker: ${data.action}`);
|
|
276
|
+
}
|
|
277
|
+
if (data.callbackId) {
|
|
278
|
+
const sourceName = this.sourceName, targetName = data.sourceName, comObj = this.comObj;
|
|
279
|
+
Promise.try(action, data.data).then(
|
|
280
|
+
function(result) {
|
|
281
|
+
comObj.postMessage({
|
|
282
|
+
sourceName,
|
|
283
|
+
targetName,
|
|
284
|
+
callback: CallbackKind.DATA,
|
|
285
|
+
callbackId: data.callbackId,
|
|
286
|
+
data: result
|
|
287
|
+
});
|
|
288
|
+
},
|
|
289
|
+
function(reason) {
|
|
290
|
+
comObj.postMessage({
|
|
291
|
+
sourceName,
|
|
292
|
+
targetName,
|
|
293
|
+
callback: CallbackKind.ERROR,
|
|
294
|
+
callbackId: data.callbackId,
|
|
295
|
+
reason: wrapReason(reason)
|
|
296
|
+
});
|
|
297
|
+
}
|
|
298
|
+
);
|
|
299
|
+
return;
|
|
300
|
+
}
|
|
301
|
+
if (data.streamId) {
|
|
302
|
+
__privateMethod(this, _MessageHandler_instances, createStreamSink_fn).call(this, data);
|
|
303
|
+
return;
|
|
304
|
+
}
|
|
305
|
+
action(data.data);
|
|
306
|
+
};
|
|
307
|
+
createStreamSink_fn = function(data) {
|
|
308
|
+
const streamId = data.streamId, sourceName = this.sourceName, targetName = data.sourceName, comObj = this.comObj;
|
|
309
|
+
const self = this, action = this.actionHandler[data.action];
|
|
310
|
+
const streamSink = {
|
|
311
|
+
enqueue(chunk, size = 1, transfers) {
|
|
312
|
+
if (this.isCancelled) {
|
|
313
|
+
return;
|
|
314
|
+
}
|
|
315
|
+
const lastDesiredSize = this.desiredSize;
|
|
316
|
+
this.desiredSize -= size;
|
|
317
|
+
if (lastDesiredSize > 0 && this.desiredSize <= 0) {
|
|
318
|
+
this.sinkCapability = Promise.withResolvers();
|
|
319
|
+
this.ready = this.sinkCapability.promise;
|
|
320
|
+
}
|
|
321
|
+
comObj.postMessage(
|
|
322
|
+
{
|
|
323
|
+
sourceName,
|
|
324
|
+
targetName,
|
|
325
|
+
stream: StreamKind.ENQUEUE,
|
|
326
|
+
streamId,
|
|
327
|
+
chunk
|
|
328
|
+
},
|
|
329
|
+
transfers
|
|
330
|
+
);
|
|
331
|
+
},
|
|
332
|
+
close() {
|
|
333
|
+
if (this.isCancelled) {
|
|
334
|
+
return;
|
|
335
|
+
}
|
|
336
|
+
this.isCancelled = true;
|
|
337
|
+
comObj.postMessage({
|
|
338
|
+
sourceName,
|
|
339
|
+
targetName,
|
|
340
|
+
stream: StreamKind.CLOSE,
|
|
341
|
+
streamId
|
|
342
|
+
});
|
|
343
|
+
delete self.streamSinks[streamId];
|
|
344
|
+
},
|
|
345
|
+
error(reason) {
|
|
346
|
+
assert(reason instanceof Error, "error must have a valid reason");
|
|
347
|
+
if (this.isCancelled) {
|
|
348
|
+
return;
|
|
349
|
+
}
|
|
350
|
+
this.isCancelled = true;
|
|
351
|
+
comObj.postMessage({
|
|
352
|
+
sourceName,
|
|
353
|
+
targetName,
|
|
354
|
+
stream: StreamKind.ERROR,
|
|
355
|
+
streamId,
|
|
356
|
+
reason: wrapReason(reason)
|
|
357
|
+
});
|
|
358
|
+
},
|
|
359
|
+
sinkCapability: Promise.withResolvers(),
|
|
360
|
+
onPull: null,
|
|
361
|
+
onCancel: null,
|
|
362
|
+
isCancelled: false,
|
|
363
|
+
desiredSize: data.desiredSize,
|
|
364
|
+
ready: null
|
|
365
|
+
};
|
|
366
|
+
streamSink.sinkCapability.resolve();
|
|
367
|
+
streamSink.ready = streamSink.sinkCapability.promise;
|
|
368
|
+
this.streamSinks[streamId] = streamSink;
|
|
369
|
+
Promise.try(action, data.data, streamSink).then(
|
|
370
|
+
function() {
|
|
371
|
+
comObj.postMessage({
|
|
372
|
+
sourceName,
|
|
373
|
+
targetName,
|
|
374
|
+
stream: StreamKind.START_COMPLETE,
|
|
375
|
+
streamId,
|
|
376
|
+
success: true
|
|
377
|
+
});
|
|
378
|
+
},
|
|
379
|
+
function(reason) {
|
|
380
|
+
comObj.postMessage({
|
|
381
|
+
sourceName,
|
|
382
|
+
targetName,
|
|
383
|
+
stream: StreamKind.START_COMPLETE,
|
|
384
|
+
streamId,
|
|
385
|
+
reason: wrapReason(reason)
|
|
386
|
+
});
|
|
387
|
+
}
|
|
388
|
+
);
|
|
389
|
+
};
|
|
390
|
+
processStreamMessage_fn = function(data) {
|
|
391
|
+
const streamId = data.streamId, sourceName = this.sourceName, targetName = data.sourceName, comObj = this.comObj;
|
|
392
|
+
const streamController = this.streamControllers[streamId], streamSink = this.streamSinks[streamId];
|
|
393
|
+
switch (data.stream) {
|
|
394
|
+
case StreamKind.START_COMPLETE:
|
|
395
|
+
if (data.success) {
|
|
396
|
+
streamController.startCall.resolve();
|
|
397
|
+
} else {
|
|
398
|
+
streamController.startCall.reject(wrapReason(data.reason));
|
|
399
|
+
}
|
|
400
|
+
break;
|
|
401
|
+
case StreamKind.PULL_COMPLETE:
|
|
402
|
+
if (data.success) {
|
|
403
|
+
streamController.pullCall.resolve();
|
|
404
|
+
} else {
|
|
405
|
+
streamController.pullCall.reject(wrapReason(data.reason));
|
|
406
|
+
}
|
|
407
|
+
break;
|
|
408
|
+
case StreamKind.PULL:
|
|
409
|
+
if (!streamSink) {
|
|
410
|
+
comObj.postMessage({
|
|
411
|
+
sourceName,
|
|
412
|
+
targetName,
|
|
413
|
+
stream: StreamKind.PULL_COMPLETE,
|
|
414
|
+
streamId,
|
|
415
|
+
success: true
|
|
416
|
+
});
|
|
417
|
+
break;
|
|
418
|
+
}
|
|
419
|
+
if (streamSink.desiredSize <= 0 && data.desiredSize > 0) {
|
|
420
|
+
streamSink.sinkCapability.resolve();
|
|
421
|
+
}
|
|
422
|
+
streamSink.desiredSize = data.desiredSize;
|
|
423
|
+
Promise.try(streamSink.onPull || onFn).then(
|
|
424
|
+
function() {
|
|
425
|
+
comObj.postMessage({
|
|
426
|
+
sourceName,
|
|
427
|
+
targetName,
|
|
428
|
+
stream: StreamKind.PULL_COMPLETE,
|
|
429
|
+
streamId,
|
|
430
|
+
success: true
|
|
431
|
+
});
|
|
432
|
+
},
|
|
433
|
+
function(reason) {
|
|
434
|
+
comObj.postMessage({
|
|
435
|
+
sourceName,
|
|
436
|
+
targetName,
|
|
437
|
+
stream: StreamKind.PULL_COMPLETE,
|
|
438
|
+
streamId,
|
|
439
|
+
reason: wrapReason(reason)
|
|
440
|
+
});
|
|
441
|
+
}
|
|
442
|
+
);
|
|
443
|
+
break;
|
|
444
|
+
case StreamKind.ENQUEUE:
|
|
445
|
+
assert(streamController, "enqueue should have stream controller");
|
|
446
|
+
if (streamController.isClosed) {
|
|
447
|
+
break;
|
|
448
|
+
}
|
|
449
|
+
streamController.controller.enqueue(data.chunk);
|
|
450
|
+
break;
|
|
451
|
+
case StreamKind.CLOSE:
|
|
452
|
+
assert(streamController, "close should have stream controller");
|
|
453
|
+
if (streamController.isClosed) {
|
|
454
|
+
break;
|
|
455
|
+
}
|
|
456
|
+
streamController.isClosed = true;
|
|
457
|
+
streamController.controller.close();
|
|
458
|
+
__privateMethod(this, _MessageHandler_instances, deleteStreamController_fn).call(this, streamController, streamId);
|
|
459
|
+
break;
|
|
460
|
+
case StreamKind.ERROR:
|
|
461
|
+
assert(streamController, "error should have stream controller");
|
|
462
|
+
streamController.controller.error(wrapReason(data.reason));
|
|
463
|
+
__privateMethod(this, _MessageHandler_instances, deleteStreamController_fn).call(this, streamController, streamId);
|
|
464
|
+
break;
|
|
465
|
+
case StreamKind.CANCEL_COMPLETE:
|
|
466
|
+
if (data.success) {
|
|
467
|
+
streamController.cancelCall.resolve();
|
|
468
|
+
} else {
|
|
469
|
+
streamController.cancelCall.reject(wrapReason(data.reason));
|
|
470
|
+
}
|
|
471
|
+
__privateMethod(this, _MessageHandler_instances, deleteStreamController_fn).call(this, streamController, streamId);
|
|
472
|
+
break;
|
|
473
|
+
case StreamKind.CANCEL:
|
|
474
|
+
if (!streamSink) {
|
|
475
|
+
break;
|
|
476
|
+
}
|
|
477
|
+
const dataReason = wrapReason(data.reason);
|
|
478
|
+
Promise.try(streamSink.onCancel || onFn, dataReason).then(
|
|
479
|
+
function() {
|
|
480
|
+
comObj.postMessage({
|
|
481
|
+
sourceName,
|
|
482
|
+
targetName,
|
|
483
|
+
stream: StreamKind.CANCEL_COMPLETE,
|
|
484
|
+
streamId,
|
|
485
|
+
success: true
|
|
486
|
+
});
|
|
487
|
+
},
|
|
488
|
+
function(reason) {
|
|
489
|
+
comObj.postMessage({
|
|
490
|
+
sourceName,
|
|
491
|
+
targetName,
|
|
492
|
+
stream: StreamKind.CANCEL_COMPLETE,
|
|
493
|
+
streamId,
|
|
494
|
+
reason: wrapReason(reason)
|
|
495
|
+
});
|
|
496
|
+
}
|
|
497
|
+
);
|
|
498
|
+
streamSink.sinkCapability.reject(dataReason);
|
|
499
|
+
streamSink.isCancelled = true;
|
|
500
|
+
delete this.streamSinks[streamId];
|
|
501
|
+
break;
|
|
502
|
+
default:
|
|
503
|
+
throw new Error("Unexpected stream case");
|
|
504
|
+
}
|
|
505
|
+
};
|
|
506
|
+
deleteStreamController_fn = async function(streamController, streamId) {
|
|
507
|
+
await Promise.allSettled([
|
|
508
|
+
streamController.startCall?.promise,
|
|
509
|
+
streamController.pullCall?.promise,
|
|
510
|
+
streamController.cancelCall?.promise
|
|
511
|
+
]);
|
|
512
|
+
delete this.streamControllers[streamId];
|
|
513
|
+
};
|
|
514
|
+
|
|
515
|
+
// src/pdf.js/src/shared/scripting_utils.js
|
|
516
|
+
function makeColorComp(n) {
|
|
517
|
+
return Math.floor(Math.max(0, Math.min(1, n)) * 255).toString(16).padStart(2, "0");
|
|
518
|
+
}
|
|
519
|
+
function scaleAndClamp(x) {
|
|
520
|
+
return Math.max(0, Math.min(255, 255 * x));
|
|
521
|
+
}
|
|
522
|
+
var ColorConverters = class {
|
|
523
|
+
static CMYK_G([c, y, m, k]) {
|
|
524
|
+
return ["G", 1 - Math.min(1, 0.3 * c + 0.59 * m + 0.11 * y + k)];
|
|
525
|
+
}
|
|
526
|
+
static G_CMYK([g]) {
|
|
527
|
+
return ["CMYK", 0, 0, 0, 1 - g];
|
|
528
|
+
}
|
|
529
|
+
static G_RGB([g]) {
|
|
530
|
+
return ["RGB", g, g, g];
|
|
531
|
+
}
|
|
532
|
+
static G_rgb([g]) {
|
|
533
|
+
g = scaleAndClamp(g);
|
|
534
|
+
return [g, g, g];
|
|
535
|
+
}
|
|
536
|
+
static G_HTML([g]) {
|
|
537
|
+
const G = makeColorComp(g);
|
|
538
|
+
return `#${G}${G}${G}`;
|
|
539
|
+
}
|
|
540
|
+
static RGB_G([r, g, b]) {
|
|
541
|
+
return ["G", 0.3 * r + 0.59 * g + 0.11 * b];
|
|
542
|
+
}
|
|
543
|
+
static RGB_rgb(color) {
|
|
544
|
+
return color.map(scaleAndClamp);
|
|
545
|
+
}
|
|
546
|
+
static RGB_HTML(color) {
|
|
547
|
+
return `#${color.map(makeColorComp).join("")}`;
|
|
548
|
+
}
|
|
549
|
+
static T_HTML() {
|
|
550
|
+
return "#00000000";
|
|
551
|
+
}
|
|
552
|
+
static T_rgb() {
|
|
553
|
+
return [null];
|
|
554
|
+
}
|
|
555
|
+
static CMYK_RGB([c, y, m, k]) {
|
|
556
|
+
return [
|
|
557
|
+
"RGB",
|
|
558
|
+
1 - Math.min(1, c + k),
|
|
559
|
+
1 - Math.min(1, m + k),
|
|
560
|
+
1 - Math.min(1, y + k)
|
|
561
|
+
];
|
|
562
|
+
}
|
|
563
|
+
static CMYK_rgb([c, y, m, k]) {
|
|
564
|
+
return [
|
|
565
|
+
scaleAndClamp(1 - Math.min(1, c + k)),
|
|
566
|
+
scaleAndClamp(1 - Math.min(1, m + k)),
|
|
567
|
+
scaleAndClamp(1 - Math.min(1, y + k))
|
|
568
|
+
];
|
|
569
|
+
}
|
|
570
|
+
static CMYK_HTML(components) {
|
|
571
|
+
const rgb = this.CMYK_RGB(components).slice(1);
|
|
572
|
+
return this.RGB_HTML(rgb);
|
|
573
|
+
}
|
|
574
|
+
static RGB_CMYK([r, g, b]) {
|
|
575
|
+
const c = 1 - r;
|
|
576
|
+
const m = 1 - g;
|
|
577
|
+
const y = 1 - b;
|
|
578
|
+
const k = Math.min(c, m, y);
|
|
579
|
+
return ["CMYK", c, m, y, k];
|
|
580
|
+
}
|
|
581
|
+
};
|
|
582
|
+
var DateFormats = [
|
|
583
|
+
"m/d",
|
|
584
|
+
"m/d/yy",
|
|
585
|
+
"mm/dd/yy",
|
|
586
|
+
"mm/yy",
|
|
587
|
+
"d-mmm",
|
|
588
|
+
"d-mmm-yy",
|
|
589
|
+
"dd-mmm-yy",
|
|
590
|
+
"yy-mm-dd",
|
|
591
|
+
"mmm-yy",
|
|
592
|
+
"mmmm-yy",
|
|
593
|
+
"mmm d, yyyy",
|
|
594
|
+
"mmmm d, yyyy",
|
|
595
|
+
"m/d/yy h:MM tt",
|
|
596
|
+
"m/d/yy HH:MM"
|
|
597
|
+
];
|
|
598
|
+
var TimeFormats = ["HH:MM", "h:MM tt", "HH:MM:ss", "h:MM:ss tt"];
|
|
599
|
+
|
|
600
|
+
// src/pdf.js/src/shared/murmurhash3.js
|
|
601
|
+
var SEED = 3285377520;
|
|
602
|
+
var MASK_HIGH = 4294901760;
|
|
603
|
+
var MASK_LOW = 65535;
|
|
604
|
+
var MurmurHash3_64 = class {
|
|
605
|
+
constructor(seed) {
|
|
606
|
+
this.h1 = seed ? seed & 4294967295 : SEED;
|
|
607
|
+
this.h2 = seed ? seed & 4294967295 : SEED;
|
|
608
|
+
}
|
|
609
|
+
update(input) {
|
|
610
|
+
let data, length;
|
|
611
|
+
if (typeof input === "string") {
|
|
612
|
+
data = new Uint8Array(input.length * 2);
|
|
613
|
+
length = 0;
|
|
614
|
+
for (let i = 0, ii = input.length; i < ii; i++) {
|
|
615
|
+
const code = input.charCodeAt(i);
|
|
616
|
+
if (code <= 255) {
|
|
617
|
+
data[length++] = code;
|
|
618
|
+
} else {
|
|
619
|
+
data[length++] = code >>> 8;
|
|
620
|
+
data[length++] = code & 255;
|
|
621
|
+
}
|
|
622
|
+
}
|
|
623
|
+
} else if (ArrayBuffer.isView(input)) {
|
|
624
|
+
data = input.slice();
|
|
625
|
+
length = data.byteLength;
|
|
626
|
+
} else {
|
|
627
|
+
throw new Error("Invalid data format, must be a string or TypedArray.");
|
|
628
|
+
}
|
|
629
|
+
const blockCounts = length >> 2;
|
|
630
|
+
const tailLength = length - blockCounts * 4;
|
|
631
|
+
const dataUint32 = new Uint32Array(data.buffer, 0, blockCounts);
|
|
632
|
+
let k1 = 0, k2 = 0;
|
|
633
|
+
let h1 = this.h1, h2 = this.h2;
|
|
634
|
+
const C1 = 3432918353, C2 = 461845907;
|
|
635
|
+
const C1_LOW = C1 & MASK_LOW, C2_LOW = C2 & MASK_LOW;
|
|
636
|
+
for (let i = 0; i < blockCounts; i++) {
|
|
637
|
+
if (i & 1) {
|
|
638
|
+
k1 = dataUint32[i];
|
|
639
|
+
k1 = k1 * C1 & MASK_HIGH | k1 * C1_LOW & MASK_LOW;
|
|
640
|
+
k1 = k1 << 15 | k1 >>> 17;
|
|
641
|
+
k1 = k1 * C2 & MASK_HIGH | k1 * C2_LOW & MASK_LOW;
|
|
642
|
+
h1 ^= k1;
|
|
643
|
+
h1 = h1 << 13 | h1 >>> 19;
|
|
644
|
+
h1 = h1 * 5 + 3864292196;
|
|
645
|
+
} else {
|
|
646
|
+
k2 = dataUint32[i];
|
|
647
|
+
k2 = k2 * C1 & MASK_HIGH | k2 * C1_LOW & MASK_LOW;
|
|
648
|
+
k2 = k2 << 15 | k2 >>> 17;
|
|
649
|
+
k2 = k2 * C2 & MASK_HIGH | k2 * C2_LOW & MASK_LOW;
|
|
650
|
+
h2 ^= k2;
|
|
651
|
+
h2 = h2 << 13 | h2 >>> 19;
|
|
652
|
+
h2 = h2 * 5 + 3864292196;
|
|
653
|
+
}
|
|
654
|
+
}
|
|
655
|
+
k1 = 0;
|
|
656
|
+
switch (tailLength) {
|
|
657
|
+
case 3:
|
|
658
|
+
k1 ^= data[blockCounts * 4 + 2] << 16;
|
|
659
|
+
/* falls through */
|
|
660
|
+
case 2:
|
|
661
|
+
k1 ^= data[blockCounts * 4 + 1] << 8;
|
|
662
|
+
/* falls through */
|
|
663
|
+
case 1:
|
|
664
|
+
k1 ^= data[blockCounts * 4];
|
|
665
|
+
k1 = k1 * C1 & MASK_HIGH | k1 * C1_LOW & MASK_LOW;
|
|
666
|
+
k1 = k1 << 15 | k1 >>> 17;
|
|
667
|
+
k1 = k1 * C2 & MASK_HIGH | k1 * C2_LOW & MASK_LOW;
|
|
668
|
+
if (blockCounts & 1) {
|
|
669
|
+
h1 ^= k1;
|
|
670
|
+
} else {
|
|
671
|
+
h2 ^= k1;
|
|
672
|
+
}
|
|
673
|
+
}
|
|
674
|
+
this.h1 = h1;
|
|
675
|
+
this.h2 = h2;
|
|
676
|
+
}
|
|
677
|
+
hexdigest() {
|
|
678
|
+
let h1 = this.h1, h2 = this.h2;
|
|
679
|
+
h1 ^= h2 >>> 1;
|
|
680
|
+
h1 = h1 * 3981806797 & MASK_HIGH | h1 * 36045 & MASK_LOW;
|
|
681
|
+
h2 = h2 * 4283543511 & MASK_HIGH | ((h2 << 16 | h1 >>> 16) * 2950163797 & MASK_HIGH) >>> 16;
|
|
682
|
+
h1 ^= h2 >>> 1;
|
|
683
|
+
h1 = h1 * 444984403 & MASK_HIGH | h1 * 60499 & MASK_LOW;
|
|
684
|
+
h2 = h2 * 3301882366 & MASK_HIGH | ((h2 << 16 | h1 >>> 16) * 3120437893 & MASK_HIGH) >>> 16;
|
|
685
|
+
h1 ^= h2 >>> 1;
|
|
686
|
+
return (h1 >>> 0).toString(16).padStart(8, "0") + (h2 >>> 0).toString(16).padStart(8, "0");
|
|
687
|
+
}
|
|
688
|
+
};
|
|
689
|
+
|
|
690
|
+
// src/pdf.js/src/shared/image_utils.js
|
|
691
|
+
function convertToRGBA(params) {
|
|
692
|
+
switch (params.kind) {
|
|
693
|
+
case ImageKind.GRAYSCALE_1BPP:
|
|
694
|
+
return convertBlackAndWhiteToRGBA(params);
|
|
695
|
+
case ImageKind.RGB_24BPP:
|
|
696
|
+
return convertRGBToRGBA(params);
|
|
697
|
+
}
|
|
698
|
+
return null;
|
|
699
|
+
}
|
|
700
|
+
function convertBlackAndWhiteToRGBA({
|
|
701
|
+
src,
|
|
702
|
+
srcPos = 0,
|
|
703
|
+
dest,
|
|
704
|
+
width,
|
|
705
|
+
height,
|
|
706
|
+
nonBlackColor = 4294967295,
|
|
707
|
+
inverseDecode = false
|
|
708
|
+
}) {
|
|
709
|
+
const black = FeatureTest.isLittleEndian ? 4278190080 : 255;
|
|
710
|
+
const [zeroMapping, oneMapping] = inverseDecode ? [nonBlackColor, black] : [black, nonBlackColor];
|
|
711
|
+
const widthInSource = width >> 3;
|
|
712
|
+
const widthRemainder = width & 7;
|
|
713
|
+
const srcLength = src.length;
|
|
714
|
+
dest = new Uint32Array(dest.buffer);
|
|
715
|
+
let destPos = 0;
|
|
716
|
+
for (let i = 0; i < height; i++) {
|
|
717
|
+
for (const max = srcPos + widthInSource; srcPos < max; srcPos++) {
|
|
718
|
+
const elem2 = srcPos < srcLength ? src[srcPos] : 255;
|
|
719
|
+
dest[destPos++] = elem2 & 128 ? oneMapping : zeroMapping;
|
|
720
|
+
dest[destPos++] = elem2 & 64 ? oneMapping : zeroMapping;
|
|
721
|
+
dest[destPos++] = elem2 & 32 ? oneMapping : zeroMapping;
|
|
722
|
+
dest[destPos++] = elem2 & 16 ? oneMapping : zeroMapping;
|
|
723
|
+
dest[destPos++] = elem2 & 8 ? oneMapping : zeroMapping;
|
|
724
|
+
dest[destPos++] = elem2 & 4 ? oneMapping : zeroMapping;
|
|
725
|
+
dest[destPos++] = elem2 & 2 ? oneMapping : zeroMapping;
|
|
726
|
+
dest[destPos++] = elem2 & 1 ? oneMapping : zeroMapping;
|
|
727
|
+
}
|
|
728
|
+
if (widthRemainder === 0) {
|
|
729
|
+
continue;
|
|
730
|
+
}
|
|
731
|
+
const elem = srcPos < srcLength ? src[srcPos++] : 255;
|
|
732
|
+
for (let j = 0; j < widthRemainder; j++) {
|
|
733
|
+
dest[destPos++] = elem & 1 << 7 - j ? oneMapping : zeroMapping;
|
|
734
|
+
}
|
|
735
|
+
}
|
|
736
|
+
return { srcPos, destPos };
|
|
737
|
+
}
|
|
738
|
+
function convertRGBToRGBA({
|
|
739
|
+
src,
|
|
740
|
+
srcPos = 0,
|
|
741
|
+
dest,
|
|
742
|
+
destPos = 0,
|
|
743
|
+
width,
|
|
744
|
+
height
|
|
745
|
+
}) {
|
|
746
|
+
let i = 0;
|
|
747
|
+
const len = width * height * 3;
|
|
748
|
+
const len32 = len >> 2;
|
|
749
|
+
const src32 = new Uint32Array(src.buffer, srcPos, len32);
|
|
750
|
+
if (FeatureTest.isLittleEndian) {
|
|
751
|
+
for (; i < len32 - 2; i += 3, destPos += 4) {
|
|
752
|
+
const s1 = src32[i];
|
|
753
|
+
const s2 = src32[i + 1];
|
|
754
|
+
const s3 = src32[i + 2];
|
|
755
|
+
dest[destPos] = s1 | 4278190080;
|
|
756
|
+
dest[destPos + 1] = s1 >>> 24 | s2 << 8 | 4278190080;
|
|
757
|
+
dest[destPos + 2] = s2 >>> 16 | s3 << 16 | 4278190080;
|
|
758
|
+
dest[destPos + 3] = s3 >>> 8 | 4278190080;
|
|
759
|
+
}
|
|
760
|
+
for (let j = i * 4, jj = srcPos + len; j < jj; j += 3) {
|
|
761
|
+
dest[destPos++] = src[j] | src[j + 1] << 8 | src[j + 2] << 16 | 4278190080;
|
|
762
|
+
}
|
|
763
|
+
} else {
|
|
764
|
+
for (; i < len32 - 2; i += 3, destPos += 4) {
|
|
765
|
+
const s1 = src32[i];
|
|
766
|
+
const s2 = src32[i + 1];
|
|
767
|
+
const s3 = src32[i + 2];
|
|
768
|
+
dest[destPos] = s1 | 255;
|
|
769
|
+
dest[destPos + 1] = s1 << 24 | s2 >>> 8 | 255;
|
|
770
|
+
dest[destPos + 2] = s2 << 16 | s3 >>> 16 | 255;
|
|
771
|
+
dest[destPos + 3] = s3 << 8 | 255;
|
|
772
|
+
}
|
|
773
|
+
for (let j = i * 4, jj = srcPos + len; j < jj; j += 3) {
|
|
774
|
+
dest[destPos++] = src[j] << 24 | src[j + 1] << 16 | src[j + 2] << 8 | 255;
|
|
775
|
+
}
|
|
776
|
+
}
|
|
777
|
+
return { srcPos: srcPos + len, destPos };
|
|
778
|
+
}
|
|
779
|
+
function grayToRGBA(src, dest) {
|
|
780
|
+
if (FeatureTest.isLittleEndian) {
|
|
781
|
+
for (let i = 0, ii = src.length; i < ii; i++) {
|
|
782
|
+
dest[i] = src[i] * 65793 | 4278190080;
|
|
783
|
+
}
|
|
784
|
+
} else {
|
|
785
|
+
for (let i = 0, ii = src.length; i < ii; i++) {
|
|
786
|
+
dest[i] = src[i] * 16843008 | 255;
|
|
787
|
+
}
|
|
788
|
+
}
|
|
789
|
+
}
|
|
790
|
+
|
|
791
|
+
export {
|
|
792
|
+
MurmurHash3_64,
|
|
793
|
+
wrapReason,
|
|
794
|
+
MessageHandler,
|
|
795
|
+
convertToRGBA,
|
|
796
|
+
convertBlackAndWhiteToRGBA,
|
|
797
|
+
grayToRGBA,
|
|
798
|
+
ColorConverters,
|
|
799
|
+
DateFormats,
|
|
800
|
+
TimeFormats
|
|
801
|
+
};
|