mineru-layout-viewer 0.1.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.
@@ -0,0 +1,2864 @@
1
+ "use strict";
2
+ var MineruViewer = (() => {
3
+ var __create = Object.create;
4
+ var __defProp = Object.defineProperty;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __getOwnPropNames = Object.getOwnPropertyNames;
7
+ var __getProtoOf = Object.getPrototypeOf;
8
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
9
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
10
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
11
+ }) : x)(function(x) {
12
+ if (typeof require !== "undefined") return require.apply(this, arguments);
13
+ throw Error('Dynamic require of "' + x + '" is not supported');
14
+ });
15
+ var __commonJS = (cb, mod) => function __require2() {
16
+ return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
17
+ };
18
+ var __export = (target, all) => {
19
+ for (var name in all)
20
+ __defProp(target, name, { get: all[name], enumerable: true });
21
+ };
22
+ var __copyProps = (to, from, except, desc) => {
23
+ if (from && typeof from === "object" || typeof from === "function") {
24
+ for (let key of __getOwnPropNames(from))
25
+ if (!__hasOwnProp.call(to, key) && key !== except)
26
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
27
+ }
28
+ return to;
29
+ };
30
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
31
+ // If the importer is in node compatibility mode or this is not an ESM
32
+ // file that has been converted to a CommonJS file using a Babel-
33
+ // compatible transform (i.e. "__esModule" has not been set), then set
34
+ // "default" to the CommonJS "module.exports" for node compatibility.
35
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
36
+ mod
37
+ ));
38
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
39
+
40
+ // node_modules/jszip/dist/jszip.min.js
41
+ var require_jszip_min = __commonJS({
42
+ "node_modules/jszip/dist/jszip.min.js"(exports, module) {
43
+ !function(e) {
44
+ if ("object" == typeof exports && "undefined" != typeof module) module.exports = e();
45
+ else if ("function" == typeof define && define.amd) define([], e);
46
+ else {
47
+ ("undefined" != typeof window ? window : "undefined" != typeof global ? global : "undefined" != typeof self ? self : this).JSZip = e();
48
+ }
49
+ }(function() {
50
+ return function s(a, o, h) {
51
+ function u(r, e2) {
52
+ if (!o[r]) {
53
+ if (!a[r]) {
54
+ var t = "function" == typeof __require && __require;
55
+ if (!e2 && t) return t(r, true);
56
+ if (l) return l(r, true);
57
+ var n = new Error("Cannot find module '" + r + "'");
58
+ throw n.code = "MODULE_NOT_FOUND", n;
59
+ }
60
+ var i = o[r] = { exports: {} };
61
+ a[r][0].call(i.exports, function(e3) {
62
+ var t2 = a[r][1][e3];
63
+ return u(t2 || e3);
64
+ }, i, i.exports, s, a, o, h);
65
+ }
66
+ return o[r].exports;
67
+ }
68
+ for (var l = "function" == typeof __require && __require, e = 0; e < h.length; e++) u(h[e]);
69
+ return u;
70
+ }({ 1: [function(e, t, r) {
71
+ "use strict";
72
+ var d = e("./utils"), c = e("./support"), p = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
73
+ r.encode = function(e2) {
74
+ for (var t2, r2, n, i, s, a, o, h = [], u = 0, l = e2.length, f = l, c2 = "string" !== d.getTypeOf(e2); u < e2.length; ) f = l - u, n = c2 ? (t2 = e2[u++], r2 = u < l ? e2[u++] : 0, u < l ? e2[u++] : 0) : (t2 = e2.charCodeAt(u++), r2 = u < l ? e2.charCodeAt(u++) : 0, u < l ? e2.charCodeAt(u++) : 0), i = t2 >> 2, s = (3 & t2) << 4 | r2 >> 4, a = 1 < f ? (15 & r2) << 2 | n >> 6 : 64, o = 2 < f ? 63 & n : 64, h.push(p.charAt(i) + p.charAt(s) + p.charAt(a) + p.charAt(o));
75
+ return h.join("");
76
+ }, r.decode = function(e2) {
77
+ var t2, r2, n, i, s, a, o = 0, h = 0, u = "data:";
78
+ if (e2.substr(0, u.length) === u) throw new Error("Invalid base64 input, it looks like a data url.");
79
+ var l, f = 3 * (e2 = e2.replace(/[^A-Za-z0-9+/=]/g, "")).length / 4;
80
+ if (e2.charAt(e2.length - 1) === p.charAt(64) && f--, e2.charAt(e2.length - 2) === p.charAt(64) && f--, f % 1 != 0) throw new Error("Invalid base64 input, bad content length.");
81
+ for (l = c.uint8array ? new Uint8Array(0 | f) : new Array(0 | f); o < e2.length; ) t2 = p.indexOf(e2.charAt(o++)) << 2 | (i = p.indexOf(e2.charAt(o++))) >> 4, r2 = (15 & i) << 4 | (s = p.indexOf(e2.charAt(o++))) >> 2, n = (3 & s) << 6 | (a = p.indexOf(e2.charAt(o++))), l[h++] = t2, 64 !== s && (l[h++] = r2), 64 !== a && (l[h++] = n);
82
+ return l;
83
+ };
84
+ }, { "./support": 30, "./utils": 32 }], 2: [function(e, t, r) {
85
+ "use strict";
86
+ var n = e("./external"), i = e("./stream/DataWorker"), s = e("./stream/Crc32Probe"), a = e("./stream/DataLengthProbe");
87
+ function o(e2, t2, r2, n2, i2) {
88
+ this.compressedSize = e2, this.uncompressedSize = t2, this.crc32 = r2, this.compression = n2, this.compressedContent = i2;
89
+ }
90
+ o.prototype = { getContentWorker: function() {
91
+ var e2 = new i(n.Promise.resolve(this.compressedContent)).pipe(this.compression.uncompressWorker()).pipe(new a("data_length")), t2 = this;
92
+ return e2.on("end", function() {
93
+ if (this.streamInfo.data_length !== t2.uncompressedSize) throw new Error("Bug : uncompressed data size mismatch");
94
+ }), e2;
95
+ }, getCompressedWorker: function() {
96
+ return new i(n.Promise.resolve(this.compressedContent)).withStreamInfo("compressedSize", this.compressedSize).withStreamInfo("uncompressedSize", this.uncompressedSize).withStreamInfo("crc32", this.crc32).withStreamInfo("compression", this.compression);
97
+ } }, o.createWorkerFrom = function(e2, t2, r2) {
98
+ return e2.pipe(new s()).pipe(new a("uncompressedSize")).pipe(t2.compressWorker(r2)).pipe(new a("compressedSize")).withStreamInfo("compression", t2);
99
+ }, t.exports = o;
100
+ }, { "./external": 6, "./stream/Crc32Probe": 25, "./stream/DataLengthProbe": 26, "./stream/DataWorker": 27 }], 3: [function(e, t, r) {
101
+ "use strict";
102
+ var n = e("./stream/GenericWorker");
103
+ r.STORE = { magic: "\0\0", compressWorker: function() {
104
+ return new n("STORE compression");
105
+ }, uncompressWorker: function() {
106
+ return new n("STORE decompression");
107
+ } }, r.DEFLATE = e("./flate");
108
+ }, { "./flate": 7, "./stream/GenericWorker": 28 }], 4: [function(e, t, r) {
109
+ "use strict";
110
+ var n = e("./utils");
111
+ var o = function() {
112
+ for (var e2, t2 = [], r2 = 0; r2 < 256; r2++) {
113
+ e2 = r2;
114
+ for (var n2 = 0; n2 < 8; n2++) e2 = 1 & e2 ? 3988292384 ^ e2 >>> 1 : e2 >>> 1;
115
+ t2[r2] = e2;
116
+ }
117
+ return t2;
118
+ }();
119
+ t.exports = function(e2, t2) {
120
+ return void 0 !== e2 && e2.length ? "string" !== n.getTypeOf(e2) ? function(e3, t3, r2, n2) {
121
+ var i = o, s = n2 + r2;
122
+ e3 ^= -1;
123
+ for (var a = n2; a < s; a++) e3 = e3 >>> 8 ^ i[255 & (e3 ^ t3[a])];
124
+ return -1 ^ e3;
125
+ }(0 | t2, e2, e2.length, 0) : function(e3, t3, r2, n2) {
126
+ var i = o, s = n2 + r2;
127
+ e3 ^= -1;
128
+ for (var a = n2; a < s; a++) e3 = e3 >>> 8 ^ i[255 & (e3 ^ t3.charCodeAt(a))];
129
+ return -1 ^ e3;
130
+ }(0 | t2, e2, e2.length, 0) : 0;
131
+ };
132
+ }, { "./utils": 32 }], 5: [function(e, t, r) {
133
+ "use strict";
134
+ r.base64 = false, r.binary = false, r.dir = false, r.createFolders = true, r.date = null, r.compression = null, r.compressionOptions = null, r.comment = null, r.unixPermissions = null, r.dosPermissions = null;
135
+ }, {}], 6: [function(e, t, r) {
136
+ "use strict";
137
+ var n = null;
138
+ n = "undefined" != typeof Promise ? Promise : e("lie"), t.exports = { Promise: n };
139
+ }, { lie: 37 }], 7: [function(e, t, r) {
140
+ "use strict";
141
+ var n = "undefined" != typeof Uint8Array && "undefined" != typeof Uint16Array && "undefined" != typeof Uint32Array, i = e("pako"), s = e("./utils"), a = e("./stream/GenericWorker"), o = n ? "uint8array" : "array";
142
+ function h(e2, t2) {
143
+ a.call(this, "FlateWorker/" + e2), this._pako = null, this._pakoAction = e2, this._pakoOptions = t2, this.meta = {};
144
+ }
145
+ r.magic = "\b\0", s.inherits(h, a), h.prototype.processChunk = function(e2) {
146
+ this.meta = e2.meta, null === this._pako && this._createPako(), this._pako.push(s.transformTo(o, e2.data), false);
147
+ }, h.prototype.flush = function() {
148
+ a.prototype.flush.call(this), null === this._pako && this._createPako(), this._pako.push([], true);
149
+ }, h.prototype.cleanUp = function() {
150
+ a.prototype.cleanUp.call(this), this._pako = null;
151
+ }, h.prototype._createPako = function() {
152
+ this._pako = new i[this._pakoAction]({ raw: true, level: this._pakoOptions.level || -1 });
153
+ var t2 = this;
154
+ this._pako.onData = function(e2) {
155
+ t2.push({ data: e2, meta: t2.meta });
156
+ };
157
+ }, r.compressWorker = function(e2) {
158
+ return new h("Deflate", e2);
159
+ }, r.uncompressWorker = function() {
160
+ return new h("Inflate", {});
161
+ };
162
+ }, { "./stream/GenericWorker": 28, "./utils": 32, pako: 38 }], 8: [function(e, t, r) {
163
+ "use strict";
164
+ function A(e2, t2) {
165
+ var r2, n2 = "";
166
+ for (r2 = 0; r2 < t2; r2++) n2 += String.fromCharCode(255 & e2), e2 >>>= 8;
167
+ return n2;
168
+ }
169
+ function n(e2, t2, r2, n2, i2, s2) {
170
+ var a, o, h = e2.file, u = e2.compression, l = s2 !== O.utf8encode, f = I.transformTo("string", s2(h.name)), c = I.transformTo("string", O.utf8encode(h.name)), d = h.comment, p = I.transformTo("string", s2(d)), m = I.transformTo("string", O.utf8encode(d)), _ = c.length !== h.name.length, g = m.length !== d.length, b = "", v = "", y = "", w = h.dir, k = h.date, x = { crc32: 0, compressedSize: 0, uncompressedSize: 0 };
171
+ t2 && !r2 || (x.crc32 = e2.crc32, x.compressedSize = e2.compressedSize, x.uncompressedSize = e2.uncompressedSize);
172
+ var S = 0;
173
+ t2 && (S |= 8), l || !_ && !g || (S |= 2048);
174
+ var z = 0, C = 0;
175
+ w && (z |= 16), "UNIX" === i2 ? (C = 798, z |= function(e3, t3) {
176
+ var r3 = e3;
177
+ return e3 || (r3 = t3 ? 16893 : 33204), (65535 & r3) << 16;
178
+ }(h.unixPermissions, w)) : (C = 20, z |= function(e3) {
179
+ return 63 & (e3 || 0);
180
+ }(h.dosPermissions)), a = k.getUTCHours(), a <<= 6, a |= k.getUTCMinutes(), a <<= 5, a |= k.getUTCSeconds() / 2, o = k.getUTCFullYear() - 1980, o <<= 4, o |= k.getUTCMonth() + 1, o <<= 5, o |= k.getUTCDate(), _ && (v = A(1, 1) + A(B(f), 4) + c, b += "up" + A(v.length, 2) + v), g && (y = A(1, 1) + A(B(p), 4) + m, b += "uc" + A(y.length, 2) + y);
181
+ var E = "";
182
+ return E += "\n\0", E += A(S, 2), E += u.magic, E += A(a, 2), E += A(o, 2), E += A(x.crc32, 4), E += A(x.compressedSize, 4), E += A(x.uncompressedSize, 4), E += A(f.length, 2), E += A(b.length, 2), { fileRecord: R.LOCAL_FILE_HEADER + E + f + b, dirRecord: R.CENTRAL_FILE_HEADER + A(C, 2) + E + A(p.length, 2) + "\0\0\0\0" + A(z, 4) + A(n2, 4) + f + b + p };
183
+ }
184
+ var I = e("../utils"), i = e("../stream/GenericWorker"), O = e("../utf8"), B = e("../crc32"), R = e("../signature");
185
+ function s(e2, t2, r2, n2) {
186
+ i.call(this, "ZipFileWorker"), this.bytesWritten = 0, this.zipComment = t2, this.zipPlatform = r2, this.encodeFileName = n2, this.streamFiles = e2, this.accumulate = false, this.contentBuffer = [], this.dirRecords = [], this.currentSourceOffset = 0, this.entriesCount = 0, this.currentFile = null, this._sources = [];
187
+ }
188
+ I.inherits(s, i), s.prototype.push = function(e2) {
189
+ var t2 = e2.meta.percent || 0, r2 = this.entriesCount, n2 = this._sources.length;
190
+ this.accumulate ? this.contentBuffer.push(e2) : (this.bytesWritten += e2.data.length, i.prototype.push.call(this, { data: e2.data, meta: { currentFile: this.currentFile, percent: r2 ? (t2 + 100 * (r2 - n2 - 1)) / r2 : 100 } }));
191
+ }, s.prototype.openedSource = function(e2) {
192
+ this.currentSourceOffset = this.bytesWritten, this.currentFile = e2.file.name;
193
+ var t2 = this.streamFiles && !e2.file.dir;
194
+ if (t2) {
195
+ var r2 = n(e2, t2, false, this.currentSourceOffset, this.zipPlatform, this.encodeFileName);
196
+ this.push({ data: r2.fileRecord, meta: { percent: 0 } });
197
+ } else this.accumulate = true;
198
+ }, s.prototype.closedSource = function(e2) {
199
+ this.accumulate = false;
200
+ var t2 = this.streamFiles && !e2.file.dir, r2 = n(e2, t2, true, this.currentSourceOffset, this.zipPlatform, this.encodeFileName);
201
+ if (this.dirRecords.push(r2.dirRecord), t2) this.push({ data: function(e3) {
202
+ return R.DATA_DESCRIPTOR + A(e3.crc32, 4) + A(e3.compressedSize, 4) + A(e3.uncompressedSize, 4);
203
+ }(e2), meta: { percent: 100 } });
204
+ else for (this.push({ data: r2.fileRecord, meta: { percent: 0 } }); this.contentBuffer.length; ) this.push(this.contentBuffer.shift());
205
+ this.currentFile = null;
206
+ }, s.prototype.flush = function() {
207
+ for (var e2 = this.bytesWritten, t2 = 0; t2 < this.dirRecords.length; t2++) this.push({ data: this.dirRecords[t2], meta: { percent: 100 } });
208
+ var r2 = this.bytesWritten - e2, n2 = function(e3, t3, r3, n3, i2) {
209
+ var s2 = I.transformTo("string", i2(n3));
210
+ return R.CENTRAL_DIRECTORY_END + "\0\0\0\0" + A(e3, 2) + A(e3, 2) + A(t3, 4) + A(r3, 4) + A(s2.length, 2) + s2;
211
+ }(this.dirRecords.length, r2, e2, this.zipComment, this.encodeFileName);
212
+ this.push({ data: n2, meta: { percent: 100 } });
213
+ }, s.prototype.prepareNextSource = function() {
214
+ this.previous = this._sources.shift(), this.openedSource(this.previous.streamInfo), this.isPaused ? this.previous.pause() : this.previous.resume();
215
+ }, s.prototype.registerPrevious = function(e2) {
216
+ this._sources.push(e2);
217
+ var t2 = this;
218
+ return e2.on("data", function(e3) {
219
+ t2.processChunk(e3);
220
+ }), e2.on("end", function() {
221
+ t2.closedSource(t2.previous.streamInfo), t2._sources.length ? t2.prepareNextSource() : t2.end();
222
+ }), e2.on("error", function(e3) {
223
+ t2.error(e3);
224
+ }), this;
225
+ }, s.prototype.resume = function() {
226
+ return !!i.prototype.resume.call(this) && (!this.previous && this._sources.length ? (this.prepareNextSource(), true) : this.previous || this._sources.length || this.generatedError ? void 0 : (this.end(), true));
227
+ }, s.prototype.error = function(e2) {
228
+ var t2 = this._sources;
229
+ if (!i.prototype.error.call(this, e2)) return false;
230
+ for (var r2 = 0; r2 < t2.length; r2++) try {
231
+ t2[r2].error(e2);
232
+ } catch (e3) {
233
+ }
234
+ return true;
235
+ }, s.prototype.lock = function() {
236
+ i.prototype.lock.call(this);
237
+ for (var e2 = this._sources, t2 = 0; t2 < e2.length; t2++) e2[t2].lock();
238
+ }, t.exports = s;
239
+ }, { "../crc32": 4, "../signature": 23, "../stream/GenericWorker": 28, "../utf8": 31, "../utils": 32 }], 9: [function(e, t, r) {
240
+ "use strict";
241
+ var u = e("../compressions"), n = e("./ZipFileWorker");
242
+ r.generateWorker = function(e2, a, t2) {
243
+ var o = new n(a.streamFiles, t2, a.platform, a.encodeFileName), h = 0;
244
+ try {
245
+ e2.forEach(function(e3, t3) {
246
+ h++;
247
+ var r2 = function(e4, t4) {
248
+ var r3 = e4 || t4, n3 = u[r3];
249
+ if (!n3) throw new Error(r3 + " is not a valid compression method !");
250
+ return n3;
251
+ }(t3.options.compression, a.compression), n2 = t3.options.compressionOptions || a.compressionOptions || {}, i = t3.dir, s = t3.date;
252
+ t3._compressWorker(r2, n2).withStreamInfo("file", { name: e3, dir: i, date: s, comment: t3.comment || "", unixPermissions: t3.unixPermissions, dosPermissions: t3.dosPermissions }).pipe(o);
253
+ }), o.entriesCount = h;
254
+ } catch (e3) {
255
+ o.error(e3);
256
+ }
257
+ return o;
258
+ };
259
+ }, { "../compressions": 3, "./ZipFileWorker": 8 }], 10: [function(e, t, r) {
260
+ "use strict";
261
+ function n() {
262
+ if (!(this instanceof n)) return new n();
263
+ if (arguments.length) throw new Error("The constructor with parameters has been removed in JSZip 3.0, please check the upgrade guide.");
264
+ this.files = /* @__PURE__ */ Object.create(null), this.comment = null, this.root = "", this.clone = function() {
265
+ var e2 = new n();
266
+ for (var t2 in this) "function" != typeof this[t2] && (e2[t2] = this[t2]);
267
+ return e2;
268
+ };
269
+ }
270
+ (n.prototype = e("./object")).loadAsync = e("./load"), n.support = e("./support"), n.defaults = e("./defaults"), n.version = "3.10.1", n.loadAsync = function(e2, t2) {
271
+ return new n().loadAsync(e2, t2);
272
+ }, n.external = e("./external"), t.exports = n;
273
+ }, { "./defaults": 5, "./external": 6, "./load": 11, "./object": 15, "./support": 30 }], 11: [function(e, t, r) {
274
+ "use strict";
275
+ var u = e("./utils"), i = e("./external"), n = e("./utf8"), s = e("./zipEntries"), a = e("./stream/Crc32Probe"), l = e("./nodejsUtils");
276
+ function f(n2) {
277
+ return new i.Promise(function(e2, t2) {
278
+ var r2 = n2.decompressed.getContentWorker().pipe(new a());
279
+ r2.on("error", function(e3) {
280
+ t2(e3);
281
+ }).on("end", function() {
282
+ r2.streamInfo.crc32 !== n2.decompressed.crc32 ? t2(new Error("Corrupted zip : CRC32 mismatch")) : e2();
283
+ }).resume();
284
+ });
285
+ }
286
+ t.exports = function(e2, o) {
287
+ var h = this;
288
+ return o = u.extend(o || {}, { base64: false, checkCRC32: false, optimizedBinaryString: false, createFolders: false, decodeFileName: n.utf8decode }), l.isNode && l.isStream(e2) ? i.Promise.reject(new Error("JSZip can't accept a stream when loading a zip file.")) : u.prepareContent("the loaded zip file", e2, true, o.optimizedBinaryString, o.base64).then(function(e3) {
289
+ var t2 = new s(o);
290
+ return t2.load(e3), t2;
291
+ }).then(function(e3) {
292
+ var t2 = [i.Promise.resolve(e3)], r2 = e3.files;
293
+ if (o.checkCRC32) for (var n2 = 0; n2 < r2.length; n2++) t2.push(f(r2[n2]));
294
+ return i.Promise.all(t2);
295
+ }).then(function(e3) {
296
+ for (var t2 = e3.shift(), r2 = t2.files, n2 = 0; n2 < r2.length; n2++) {
297
+ var i2 = r2[n2], s2 = i2.fileNameStr, a2 = u.resolve(i2.fileNameStr);
298
+ h.file(a2, i2.decompressed, { binary: true, optimizedBinaryString: true, date: i2.date, dir: i2.dir, comment: i2.fileCommentStr.length ? i2.fileCommentStr : null, unixPermissions: i2.unixPermissions, dosPermissions: i2.dosPermissions, createFolders: o.createFolders }), i2.dir || (h.file(a2).unsafeOriginalName = s2);
299
+ }
300
+ return t2.zipComment.length && (h.comment = t2.zipComment), h;
301
+ });
302
+ };
303
+ }, { "./external": 6, "./nodejsUtils": 14, "./stream/Crc32Probe": 25, "./utf8": 31, "./utils": 32, "./zipEntries": 33 }], 12: [function(e, t, r) {
304
+ "use strict";
305
+ var n = e("../utils"), i = e("../stream/GenericWorker");
306
+ function s(e2, t2) {
307
+ i.call(this, "Nodejs stream input adapter for " + e2), this._upstreamEnded = false, this._bindStream(t2);
308
+ }
309
+ n.inherits(s, i), s.prototype._bindStream = function(e2) {
310
+ var t2 = this;
311
+ (this._stream = e2).pause(), e2.on("data", function(e3) {
312
+ t2.push({ data: e3, meta: { percent: 0 } });
313
+ }).on("error", function(e3) {
314
+ t2.isPaused ? this.generatedError = e3 : t2.error(e3);
315
+ }).on("end", function() {
316
+ t2.isPaused ? t2._upstreamEnded = true : t2.end();
317
+ });
318
+ }, s.prototype.pause = function() {
319
+ return !!i.prototype.pause.call(this) && (this._stream.pause(), true);
320
+ }, s.prototype.resume = function() {
321
+ return !!i.prototype.resume.call(this) && (this._upstreamEnded ? this.end() : this._stream.resume(), true);
322
+ }, t.exports = s;
323
+ }, { "../stream/GenericWorker": 28, "../utils": 32 }], 13: [function(e, t, r) {
324
+ "use strict";
325
+ var i = e("readable-stream").Readable;
326
+ function n(e2, t2, r2) {
327
+ i.call(this, t2), this._helper = e2;
328
+ var n2 = this;
329
+ e2.on("data", function(e3, t3) {
330
+ n2.push(e3) || n2._helper.pause(), r2 && r2(t3);
331
+ }).on("error", function(e3) {
332
+ n2.emit("error", e3);
333
+ }).on("end", function() {
334
+ n2.push(null);
335
+ });
336
+ }
337
+ e("../utils").inherits(n, i), n.prototype._read = function() {
338
+ this._helper.resume();
339
+ }, t.exports = n;
340
+ }, { "../utils": 32, "readable-stream": 16 }], 14: [function(e, t, r) {
341
+ "use strict";
342
+ t.exports = { isNode: "undefined" != typeof Buffer, newBufferFrom: function(e2, t2) {
343
+ if (Buffer.from && Buffer.from !== Uint8Array.from) return Buffer.from(e2, t2);
344
+ if ("number" == typeof e2) throw new Error('The "data" argument must not be a number');
345
+ return new Buffer(e2, t2);
346
+ }, allocBuffer: function(e2) {
347
+ if (Buffer.alloc) return Buffer.alloc(e2);
348
+ var t2 = new Buffer(e2);
349
+ return t2.fill(0), t2;
350
+ }, isBuffer: function(e2) {
351
+ return Buffer.isBuffer(e2);
352
+ }, isStream: function(e2) {
353
+ return e2 && "function" == typeof e2.on && "function" == typeof e2.pause && "function" == typeof e2.resume;
354
+ } };
355
+ }, {}], 15: [function(e, t, r) {
356
+ "use strict";
357
+ function s(e2, t2, r2) {
358
+ var n2, i2 = u.getTypeOf(t2), s2 = u.extend(r2 || {}, f);
359
+ s2.date = s2.date || /* @__PURE__ */ new Date(), null !== s2.compression && (s2.compression = s2.compression.toUpperCase()), "string" == typeof s2.unixPermissions && (s2.unixPermissions = parseInt(s2.unixPermissions, 8)), s2.unixPermissions && 16384 & s2.unixPermissions && (s2.dir = true), s2.dosPermissions && 16 & s2.dosPermissions && (s2.dir = true), s2.dir && (e2 = g(e2)), s2.createFolders && (n2 = _(e2)) && b.call(this, n2, true);
360
+ var a2 = "string" === i2 && false === s2.binary && false === s2.base64;
361
+ r2 && void 0 !== r2.binary || (s2.binary = !a2), (t2 instanceof c && 0 === t2.uncompressedSize || s2.dir || !t2 || 0 === t2.length) && (s2.base64 = false, s2.binary = true, t2 = "", s2.compression = "STORE", i2 = "string");
362
+ var o2 = null;
363
+ o2 = t2 instanceof c || t2 instanceof l ? t2 : p.isNode && p.isStream(t2) ? new m(e2, t2) : u.prepareContent(e2, t2, s2.binary, s2.optimizedBinaryString, s2.base64);
364
+ var h2 = new d(e2, o2, s2);
365
+ this.files[e2] = h2;
366
+ }
367
+ var i = e("./utf8"), u = e("./utils"), l = e("./stream/GenericWorker"), a = e("./stream/StreamHelper"), f = e("./defaults"), c = e("./compressedObject"), d = e("./zipObject"), o = e("./generate"), p = e("./nodejsUtils"), m = e("./nodejs/NodejsStreamInputAdapter"), _ = function(e2) {
368
+ "/" === e2.slice(-1) && (e2 = e2.substring(0, e2.length - 1));
369
+ var t2 = e2.lastIndexOf("/");
370
+ return 0 < t2 ? e2.substring(0, t2) : "";
371
+ }, g = function(e2) {
372
+ return "/" !== e2.slice(-1) && (e2 += "/"), e2;
373
+ }, b = function(e2, t2) {
374
+ return t2 = void 0 !== t2 ? t2 : f.createFolders, e2 = g(e2), this.files[e2] || s.call(this, e2, null, { dir: true, createFolders: t2 }), this.files[e2];
375
+ };
376
+ function h(e2) {
377
+ return "[object RegExp]" === Object.prototype.toString.call(e2);
378
+ }
379
+ var n = { load: function() {
380
+ throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
381
+ }, forEach: function(e2) {
382
+ var t2, r2, n2;
383
+ for (t2 in this.files) n2 = this.files[t2], (r2 = t2.slice(this.root.length, t2.length)) && t2.slice(0, this.root.length) === this.root && e2(r2, n2);
384
+ }, filter: function(r2) {
385
+ var n2 = [];
386
+ return this.forEach(function(e2, t2) {
387
+ r2(e2, t2) && n2.push(t2);
388
+ }), n2;
389
+ }, file: function(e2, t2, r2) {
390
+ if (1 !== arguments.length) return e2 = this.root + e2, s.call(this, e2, t2, r2), this;
391
+ if (h(e2)) {
392
+ var n2 = e2;
393
+ return this.filter(function(e3, t3) {
394
+ return !t3.dir && n2.test(e3);
395
+ });
396
+ }
397
+ var i2 = this.files[this.root + e2];
398
+ return i2 && !i2.dir ? i2 : null;
399
+ }, folder: function(r2) {
400
+ if (!r2) return this;
401
+ if (h(r2)) return this.filter(function(e3, t3) {
402
+ return t3.dir && r2.test(e3);
403
+ });
404
+ var e2 = this.root + r2, t2 = b.call(this, e2), n2 = this.clone();
405
+ return n2.root = t2.name, n2;
406
+ }, remove: function(r2) {
407
+ r2 = this.root + r2;
408
+ var e2 = this.files[r2];
409
+ if (e2 || ("/" !== r2.slice(-1) && (r2 += "/"), e2 = this.files[r2]), e2 && !e2.dir) delete this.files[r2];
410
+ else for (var t2 = this.filter(function(e3, t3) {
411
+ return t3.name.slice(0, r2.length) === r2;
412
+ }), n2 = 0; n2 < t2.length; n2++) delete this.files[t2[n2].name];
413
+ return this;
414
+ }, generate: function() {
415
+ throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
416
+ }, generateInternalStream: function(e2) {
417
+ var t2, r2 = {};
418
+ try {
419
+ if ((r2 = u.extend(e2 || {}, { streamFiles: false, compression: "STORE", compressionOptions: null, type: "", platform: "DOS", comment: null, mimeType: "application/zip", encodeFileName: i.utf8encode })).type = r2.type.toLowerCase(), r2.compression = r2.compression.toUpperCase(), "binarystring" === r2.type && (r2.type = "string"), !r2.type) throw new Error("No output type specified.");
420
+ u.checkSupport(r2.type), "darwin" !== r2.platform && "freebsd" !== r2.platform && "linux" !== r2.platform && "sunos" !== r2.platform || (r2.platform = "UNIX"), "win32" === r2.platform && (r2.platform = "DOS");
421
+ var n2 = r2.comment || this.comment || "";
422
+ t2 = o.generateWorker(this, r2, n2);
423
+ } catch (e3) {
424
+ (t2 = new l("error")).error(e3);
425
+ }
426
+ return new a(t2, r2.type || "string", r2.mimeType);
427
+ }, generateAsync: function(e2, t2) {
428
+ return this.generateInternalStream(e2).accumulate(t2);
429
+ }, generateNodeStream: function(e2, t2) {
430
+ return (e2 = e2 || {}).type || (e2.type = "nodebuffer"), this.generateInternalStream(e2).toNodejsStream(t2);
431
+ } };
432
+ t.exports = n;
433
+ }, { "./compressedObject": 2, "./defaults": 5, "./generate": 9, "./nodejs/NodejsStreamInputAdapter": 12, "./nodejsUtils": 14, "./stream/GenericWorker": 28, "./stream/StreamHelper": 29, "./utf8": 31, "./utils": 32, "./zipObject": 35 }], 16: [function(e, t, r) {
434
+ "use strict";
435
+ t.exports = e("stream");
436
+ }, { stream: void 0 }], 17: [function(e, t, r) {
437
+ "use strict";
438
+ var n = e("./DataReader");
439
+ function i(e2) {
440
+ n.call(this, e2);
441
+ for (var t2 = 0; t2 < this.data.length; t2++) e2[t2] = 255 & e2[t2];
442
+ }
443
+ e("../utils").inherits(i, n), i.prototype.byteAt = function(e2) {
444
+ return this.data[this.zero + e2];
445
+ }, i.prototype.lastIndexOfSignature = function(e2) {
446
+ for (var t2 = e2.charCodeAt(0), r2 = e2.charCodeAt(1), n2 = e2.charCodeAt(2), i2 = e2.charCodeAt(3), s = this.length - 4; 0 <= s; --s) if (this.data[s] === t2 && this.data[s + 1] === r2 && this.data[s + 2] === n2 && this.data[s + 3] === i2) return s - this.zero;
447
+ return -1;
448
+ }, i.prototype.readAndCheckSignature = function(e2) {
449
+ var t2 = e2.charCodeAt(0), r2 = e2.charCodeAt(1), n2 = e2.charCodeAt(2), i2 = e2.charCodeAt(3), s = this.readData(4);
450
+ return t2 === s[0] && r2 === s[1] && n2 === s[2] && i2 === s[3];
451
+ }, i.prototype.readData = function(e2) {
452
+ if (this.checkOffset(e2), 0 === e2) return [];
453
+ var t2 = this.data.slice(this.zero + this.index, this.zero + this.index + e2);
454
+ return this.index += e2, t2;
455
+ }, t.exports = i;
456
+ }, { "../utils": 32, "./DataReader": 18 }], 18: [function(e, t, r) {
457
+ "use strict";
458
+ var n = e("../utils");
459
+ function i(e2) {
460
+ this.data = e2, this.length = e2.length, this.index = 0, this.zero = 0;
461
+ }
462
+ i.prototype = { checkOffset: function(e2) {
463
+ this.checkIndex(this.index + e2);
464
+ }, checkIndex: function(e2) {
465
+ if (this.length < this.zero + e2 || e2 < 0) throw new Error("End of data reached (data length = " + this.length + ", asked index = " + e2 + "). Corrupted zip ?");
466
+ }, setIndex: function(e2) {
467
+ this.checkIndex(e2), this.index = e2;
468
+ }, skip: function(e2) {
469
+ this.setIndex(this.index + e2);
470
+ }, byteAt: function() {
471
+ }, readInt: function(e2) {
472
+ var t2, r2 = 0;
473
+ for (this.checkOffset(e2), t2 = this.index + e2 - 1; t2 >= this.index; t2--) r2 = (r2 << 8) + this.byteAt(t2);
474
+ return this.index += e2, r2;
475
+ }, readString: function(e2) {
476
+ return n.transformTo("string", this.readData(e2));
477
+ }, readData: function() {
478
+ }, lastIndexOfSignature: function() {
479
+ }, readAndCheckSignature: function() {
480
+ }, readDate: function() {
481
+ var e2 = this.readInt(4);
482
+ return new Date(Date.UTC(1980 + (e2 >> 25 & 127), (e2 >> 21 & 15) - 1, e2 >> 16 & 31, e2 >> 11 & 31, e2 >> 5 & 63, (31 & e2) << 1));
483
+ } }, t.exports = i;
484
+ }, { "../utils": 32 }], 19: [function(e, t, r) {
485
+ "use strict";
486
+ var n = e("./Uint8ArrayReader");
487
+ function i(e2) {
488
+ n.call(this, e2);
489
+ }
490
+ e("../utils").inherits(i, n), i.prototype.readData = function(e2) {
491
+ this.checkOffset(e2);
492
+ var t2 = this.data.slice(this.zero + this.index, this.zero + this.index + e2);
493
+ return this.index += e2, t2;
494
+ }, t.exports = i;
495
+ }, { "../utils": 32, "./Uint8ArrayReader": 21 }], 20: [function(e, t, r) {
496
+ "use strict";
497
+ var n = e("./DataReader");
498
+ function i(e2) {
499
+ n.call(this, e2);
500
+ }
501
+ e("../utils").inherits(i, n), i.prototype.byteAt = function(e2) {
502
+ return this.data.charCodeAt(this.zero + e2);
503
+ }, i.prototype.lastIndexOfSignature = function(e2) {
504
+ return this.data.lastIndexOf(e2) - this.zero;
505
+ }, i.prototype.readAndCheckSignature = function(e2) {
506
+ return e2 === this.readData(4);
507
+ }, i.prototype.readData = function(e2) {
508
+ this.checkOffset(e2);
509
+ var t2 = this.data.slice(this.zero + this.index, this.zero + this.index + e2);
510
+ return this.index += e2, t2;
511
+ }, t.exports = i;
512
+ }, { "../utils": 32, "./DataReader": 18 }], 21: [function(e, t, r) {
513
+ "use strict";
514
+ var n = e("./ArrayReader");
515
+ function i(e2) {
516
+ n.call(this, e2);
517
+ }
518
+ e("../utils").inherits(i, n), i.prototype.readData = function(e2) {
519
+ if (this.checkOffset(e2), 0 === e2) return new Uint8Array(0);
520
+ var t2 = this.data.subarray(this.zero + this.index, this.zero + this.index + e2);
521
+ return this.index += e2, t2;
522
+ }, t.exports = i;
523
+ }, { "../utils": 32, "./ArrayReader": 17 }], 22: [function(e, t, r) {
524
+ "use strict";
525
+ var n = e("../utils"), i = e("../support"), s = e("./ArrayReader"), a = e("./StringReader"), o = e("./NodeBufferReader"), h = e("./Uint8ArrayReader");
526
+ t.exports = function(e2) {
527
+ var t2 = n.getTypeOf(e2);
528
+ return n.checkSupport(t2), "string" !== t2 || i.uint8array ? "nodebuffer" === t2 ? new o(e2) : i.uint8array ? new h(n.transformTo("uint8array", e2)) : new s(n.transformTo("array", e2)) : new a(e2);
529
+ };
530
+ }, { "../support": 30, "../utils": 32, "./ArrayReader": 17, "./NodeBufferReader": 19, "./StringReader": 20, "./Uint8ArrayReader": 21 }], 23: [function(e, t, r) {
531
+ "use strict";
532
+ r.LOCAL_FILE_HEADER = "PK", r.CENTRAL_FILE_HEADER = "PK", r.CENTRAL_DIRECTORY_END = "PK", r.ZIP64_CENTRAL_DIRECTORY_LOCATOR = "PK\x07", r.ZIP64_CENTRAL_DIRECTORY_END = "PK", r.DATA_DESCRIPTOR = "PK\x07\b";
533
+ }, {}], 24: [function(e, t, r) {
534
+ "use strict";
535
+ var n = e("./GenericWorker"), i = e("../utils");
536
+ function s(e2) {
537
+ n.call(this, "ConvertWorker to " + e2), this.destType = e2;
538
+ }
539
+ i.inherits(s, n), s.prototype.processChunk = function(e2) {
540
+ this.push({ data: i.transformTo(this.destType, e2.data), meta: e2.meta });
541
+ }, t.exports = s;
542
+ }, { "../utils": 32, "./GenericWorker": 28 }], 25: [function(e, t, r) {
543
+ "use strict";
544
+ var n = e("./GenericWorker"), i = e("../crc32");
545
+ function s() {
546
+ n.call(this, "Crc32Probe"), this.withStreamInfo("crc32", 0);
547
+ }
548
+ e("../utils").inherits(s, n), s.prototype.processChunk = function(e2) {
549
+ this.streamInfo.crc32 = i(e2.data, this.streamInfo.crc32 || 0), this.push(e2);
550
+ }, t.exports = s;
551
+ }, { "../crc32": 4, "../utils": 32, "./GenericWorker": 28 }], 26: [function(e, t, r) {
552
+ "use strict";
553
+ var n = e("../utils"), i = e("./GenericWorker");
554
+ function s(e2) {
555
+ i.call(this, "DataLengthProbe for " + e2), this.propName = e2, this.withStreamInfo(e2, 0);
556
+ }
557
+ n.inherits(s, i), s.prototype.processChunk = function(e2) {
558
+ if (e2) {
559
+ var t2 = this.streamInfo[this.propName] || 0;
560
+ this.streamInfo[this.propName] = t2 + e2.data.length;
561
+ }
562
+ i.prototype.processChunk.call(this, e2);
563
+ }, t.exports = s;
564
+ }, { "../utils": 32, "./GenericWorker": 28 }], 27: [function(e, t, r) {
565
+ "use strict";
566
+ var n = e("../utils"), i = e("./GenericWorker");
567
+ function s(e2) {
568
+ i.call(this, "DataWorker");
569
+ var t2 = this;
570
+ this.dataIsReady = false, this.index = 0, this.max = 0, this.data = null, this.type = "", this._tickScheduled = false, e2.then(function(e3) {
571
+ t2.dataIsReady = true, t2.data = e3, t2.max = e3 && e3.length || 0, t2.type = n.getTypeOf(e3), t2.isPaused || t2._tickAndRepeat();
572
+ }, function(e3) {
573
+ t2.error(e3);
574
+ });
575
+ }
576
+ n.inherits(s, i), s.prototype.cleanUp = function() {
577
+ i.prototype.cleanUp.call(this), this.data = null;
578
+ }, s.prototype.resume = function() {
579
+ return !!i.prototype.resume.call(this) && (!this._tickScheduled && this.dataIsReady && (this._tickScheduled = true, n.delay(this._tickAndRepeat, [], this)), true);
580
+ }, s.prototype._tickAndRepeat = function() {
581
+ this._tickScheduled = false, this.isPaused || this.isFinished || (this._tick(), this.isFinished || (n.delay(this._tickAndRepeat, [], this), this._tickScheduled = true));
582
+ }, s.prototype._tick = function() {
583
+ if (this.isPaused || this.isFinished) return false;
584
+ var e2 = null, t2 = Math.min(this.max, this.index + 16384);
585
+ if (this.index >= this.max) return this.end();
586
+ switch (this.type) {
587
+ case "string":
588
+ e2 = this.data.substring(this.index, t2);
589
+ break;
590
+ case "uint8array":
591
+ e2 = this.data.subarray(this.index, t2);
592
+ break;
593
+ case "array":
594
+ case "nodebuffer":
595
+ e2 = this.data.slice(this.index, t2);
596
+ }
597
+ return this.index = t2, this.push({ data: e2, meta: { percent: this.max ? this.index / this.max * 100 : 0 } });
598
+ }, t.exports = s;
599
+ }, { "../utils": 32, "./GenericWorker": 28 }], 28: [function(e, t, r) {
600
+ "use strict";
601
+ function n(e2) {
602
+ this.name = e2 || "default", this.streamInfo = {}, this.generatedError = null, this.extraStreamInfo = {}, this.isPaused = true, this.isFinished = false, this.isLocked = false, this._listeners = { data: [], end: [], error: [] }, this.previous = null;
603
+ }
604
+ n.prototype = { push: function(e2) {
605
+ this.emit("data", e2);
606
+ }, end: function() {
607
+ if (this.isFinished) return false;
608
+ this.flush();
609
+ try {
610
+ this.emit("end"), this.cleanUp(), this.isFinished = true;
611
+ } catch (e2) {
612
+ this.emit("error", e2);
613
+ }
614
+ return true;
615
+ }, error: function(e2) {
616
+ return !this.isFinished && (this.isPaused ? this.generatedError = e2 : (this.isFinished = true, this.emit("error", e2), this.previous && this.previous.error(e2), this.cleanUp()), true);
617
+ }, on: function(e2, t2) {
618
+ return this._listeners[e2].push(t2), this;
619
+ }, cleanUp: function() {
620
+ this.streamInfo = this.generatedError = this.extraStreamInfo = null, this._listeners = [];
621
+ }, emit: function(e2, t2) {
622
+ if (this._listeners[e2]) for (var r2 = 0; r2 < this._listeners[e2].length; r2++) this._listeners[e2][r2].call(this, t2);
623
+ }, pipe: function(e2) {
624
+ return e2.registerPrevious(this);
625
+ }, registerPrevious: function(e2) {
626
+ if (this.isLocked) throw new Error("The stream '" + this + "' has already been used.");
627
+ this.streamInfo = e2.streamInfo, this.mergeStreamInfo(), this.previous = e2;
628
+ var t2 = this;
629
+ return e2.on("data", function(e3) {
630
+ t2.processChunk(e3);
631
+ }), e2.on("end", function() {
632
+ t2.end();
633
+ }), e2.on("error", function(e3) {
634
+ t2.error(e3);
635
+ }), this;
636
+ }, pause: function() {
637
+ return !this.isPaused && !this.isFinished && (this.isPaused = true, this.previous && this.previous.pause(), true);
638
+ }, resume: function() {
639
+ if (!this.isPaused || this.isFinished) return false;
640
+ var e2 = this.isPaused = false;
641
+ return this.generatedError && (this.error(this.generatedError), e2 = true), this.previous && this.previous.resume(), !e2;
642
+ }, flush: function() {
643
+ }, processChunk: function(e2) {
644
+ this.push(e2);
645
+ }, withStreamInfo: function(e2, t2) {
646
+ return this.extraStreamInfo[e2] = t2, this.mergeStreamInfo(), this;
647
+ }, mergeStreamInfo: function() {
648
+ for (var e2 in this.extraStreamInfo) Object.prototype.hasOwnProperty.call(this.extraStreamInfo, e2) && (this.streamInfo[e2] = this.extraStreamInfo[e2]);
649
+ }, lock: function() {
650
+ if (this.isLocked) throw new Error("The stream '" + this + "' has already been used.");
651
+ this.isLocked = true, this.previous && this.previous.lock();
652
+ }, toString: function() {
653
+ var e2 = "Worker " + this.name;
654
+ return this.previous ? this.previous + " -> " + e2 : e2;
655
+ } }, t.exports = n;
656
+ }, {}], 29: [function(e, t, r) {
657
+ "use strict";
658
+ var h = e("../utils"), i = e("./ConvertWorker"), s = e("./GenericWorker"), u = e("../base64"), n = e("../support"), a = e("../external"), o = null;
659
+ if (n.nodestream) try {
660
+ o = e("../nodejs/NodejsStreamOutputAdapter");
661
+ } catch (e2) {
662
+ }
663
+ function l(e2, o2) {
664
+ return new a.Promise(function(t2, r2) {
665
+ var n2 = [], i2 = e2._internalType, s2 = e2._outputType, a2 = e2._mimeType;
666
+ e2.on("data", function(e3, t3) {
667
+ n2.push(e3), o2 && o2(t3);
668
+ }).on("error", function(e3) {
669
+ n2 = [], r2(e3);
670
+ }).on("end", function() {
671
+ try {
672
+ var e3 = function(e4, t3, r3) {
673
+ switch (e4) {
674
+ case "blob":
675
+ return h.newBlob(h.transformTo("arraybuffer", t3), r3);
676
+ case "base64":
677
+ return u.encode(t3);
678
+ default:
679
+ return h.transformTo(e4, t3);
680
+ }
681
+ }(s2, function(e4, t3) {
682
+ var r3, n3 = 0, i3 = null, s3 = 0;
683
+ for (r3 = 0; r3 < t3.length; r3++) s3 += t3[r3].length;
684
+ switch (e4) {
685
+ case "string":
686
+ return t3.join("");
687
+ case "array":
688
+ return Array.prototype.concat.apply([], t3);
689
+ case "uint8array":
690
+ for (i3 = new Uint8Array(s3), r3 = 0; r3 < t3.length; r3++) i3.set(t3[r3], n3), n3 += t3[r3].length;
691
+ return i3;
692
+ case "nodebuffer":
693
+ return Buffer.concat(t3);
694
+ default:
695
+ throw new Error("concat : unsupported type '" + e4 + "'");
696
+ }
697
+ }(i2, n2), a2);
698
+ t2(e3);
699
+ } catch (e4) {
700
+ r2(e4);
701
+ }
702
+ n2 = [];
703
+ }).resume();
704
+ });
705
+ }
706
+ function f(e2, t2, r2) {
707
+ var n2 = t2;
708
+ switch (t2) {
709
+ case "blob":
710
+ case "arraybuffer":
711
+ n2 = "uint8array";
712
+ break;
713
+ case "base64":
714
+ n2 = "string";
715
+ }
716
+ try {
717
+ this._internalType = n2, this._outputType = t2, this._mimeType = r2, h.checkSupport(n2), this._worker = e2.pipe(new i(n2)), e2.lock();
718
+ } catch (e3) {
719
+ this._worker = new s("error"), this._worker.error(e3);
720
+ }
721
+ }
722
+ f.prototype = { accumulate: function(e2) {
723
+ return l(this, e2);
724
+ }, on: function(e2, t2) {
725
+ var r2 = this;
726
+ return "data" === e2 ? this._worker.on(e2, function(e3) {
727
+ t2.call(r2, e3.data, e3.meta);
728
+ }) : this._worker.on(e2, function() {
729
+ h.delay(t2, arguments, r2);
730
+ }), this;
731
+ }, resume: function() {
732
+ return h.delay(this._worker.resume, [], this._worker), this;
733
+ }, pause: function() {
734
+ return this._worker.pause(), this;
735
+ }, toNodejsStream: function(e2) {
736
+ if (h.checkSupport("nodestream"), "nodebuffer" !== this._outputType) throw new Error(this._outputType + " is not supported by this method");
737
+ return new o(this, { objectMode: "nodebuffer" !== this._outputType }, e2);
738
+ } }, t.exports = f;
739
+ }, { "../base64": 1, "../external": 6, "../nodejs/NodejsStreamOutputAdapter": 13, "../support": 30, "../utils": 32, "./ConvertWorker": 24, "./GenericWorker": 28 }], 30: [function(e, t, r) {
740
+ "use strict";
741
+ if (r.base64 = true, r.array = true, r.string = true, r.arraybuffer = "undefined" != typeof ArrayBuffer && "undefined" != typeof Uint8Array, r.nodebuffer = "undefined" != typeof Buffer, r.uint8array = "undefined" != typeof Uint8Array, "undefined" == typeof ArrayBuffer) r.blob = false;
742
+ else {
743
+ var n = new ArrayBuffer(0);
744
+ try {
745
+ r.blob = 0 === new Blob([n], { type: "application/zip" }).size;
746
+ } catch (e2) {
747
+ try {
748
+ var i = new (self.BlobBuilder || self.WebKitBlobBuilder || self.MozBlobBuilder || self.MSBlobBuilder)();
749
+ i.append(n), r.blob = 0 === i.getBlob("application/zip").size;
750
+ } catch (e3) {
751
+ r.blob = false;
752
+ }
753
+ }
754
+ }
755
+ try {
756
+ r.nodestream = !!e("readable-stream").Readable;
757
+ } catch (e2) {
758
+ r.nodestream = false;
759
+ }
760
+ }, { "readable-stream": 16 }], 31: [function(e, t, s) {
761
+ "use strict";
762
+ for (var o = e("./utils"), h = e("./support"), r = e("./nodejsUtils"), n = e("./stream/GenericWorker"), u = new Array(256), i = 0; i < 256; i++) u[i] = 252 <= i ? 6 : 248 <= i ? 5 : 240 <= i ? 4 : 224 <= i ? 3 : 192 <= i ? 2 : 1;
763
+ u[254] = u[254] = 1;
764
+ function a() {
765
+ n.call(this, "utf-8 decode"), this.leftOver = null;
766
+ }
767
+ function l() {
768
+ n.call(this, "utf-8 encode");
769
+ }
770
+ s.utf8encode = function(e2) {
771
+ return h.nodebuffer ? r.newBufferFrom(e2, "utf-8") : function(e3) {
772
+ var t2, r2, n2, i2, s2, a2 = e3.length, o2 = 0;
773
+ for (i2 = 0; i2 < a2; i2++) 55296 == (64512 & (r2 = e3.charCodeAt(i2))) && i2 + 1 < a2 && 56320 == (64512 & (n2 = e3.charCodeAt(i2 + 1))) && (r2 = 65536 + (r2 - 55296 << 10) + (n2 - 56320), i2++), o2 += r2 < 128 ? 1 : r2 < 2048 ? 2 : r2 < 65536 ? 3 : 4;
774
+ for (t2 = h.uint8array ? new Uint8Array(o2) : new Array(o2), i2 = s2 = 0; s2 < o2; i2++) 55296 == (64512 & (r2 = e3.charCodeAt(i2))) && i2 + 1 < a2 && 56320 == (64512 & (n2 = e3.charCodeAt(i2 + 1))) && (r2 = 65536 + (r2 - 55296 << 10) + (n2 - 56320), i2++), r2 < 128 ? t2[s2++] = r2 : (r2 < 2048 ? t2[s2++] = 192 | r2 >>> 6 : (r2 < 65536 ? t2[s2++] = 224 | r2 >>> 12 : (t2[s2++] = 240 | r2 >>> 18, t2[s2++] = 128 | r2 >>> 12 & 63), t2[s2++] = 128 | r2 >>> 6 & 63), t2[s2++] = 128 | 63 & r2);
775
+ return t2;
776
+ }(e2);
777
+ }, s.utf8decode = function(e2) {
778
+ return h.nodebuffer ? o.transformTo("nodebuffer", e2).toString("utf-8") : function(e3) {
779
+ var t2, r2, n2, i2, s2 = e3.length, a2 = new Array(2 * s2);
780
+ for (t2 = r2 = 0; t2 < s2; ) if ((n2 = e3[t2++]) < 128) a2[r2++] = n2;
781
+ else if (4 < (i2 = u[n2])) a2[r2++] = 65533, t2 += i2 - 1;
782
+ else {
783
+ for (n2 &= 2 === i2 ? 31 : 3 === i2 ? 15 : 7; 1 < i2 && t2 < s2; ) n2 = n2 << 6 | 63 & e3[t2++], i2--;
784
+ 1 < i2 ? a2[r2++] = 65533 : n2 < 65536 ? a2[r2++] = n2 : (n2 -= 65536, a2[r2++] = 55296 | n2 >> 10 & 1023, a2[r2++] = 56320 | 1023 & n2);
785
+ }
786
+ return a2.length !== r2 && (a2.subarray ? a2 = a2.subarray(0, r2) : a2.length = r2), o.applyFromCharCode(a2);
787
+ }(e2 = o.transformTo(h.uint8array ? "uint8array" : "array", e2));
788
+ }, o.inherits(a, n), a.prototype.processChunk = function(e2) {
789
+ var t2 = o.transformTo(h.uint8array ? "uint8array" : "array", e2.data);
790
+ if (this.leftOver && this.leftOver.length) {
791
+ if (h.uint8array) {
792
+ var r2 = t2;
793
+ (t2 = new Uint8Array(r2.length + this.leftOver.length)).set(this.leftOver, 0), t2.set(r2, this.leftOver.length);
794
+ } else t2 = this.leftOver.concat(t2);
795
+ this.leftOver = null;
796
+ }
797
+ var n2 = function(e3, t3) {
798
+ var r3;
799
+ for ((t3 = t3 || e3.length) > e3.length && (t3 = e3.length), r3 = t3 - 1; 0 <= r3 && 128 == (192 & e3[r3]); ) r3--;
800
+ return r3 < 0 ? t3 : 0 === r3 ? t3 : r3 + u[e3[r3]] > t3 ? r3 : t3;
801
+ }(t2), i2 = t2;
802
+ n2 !== t2.length && (h.uint8array ? (i2 = t2.subarray(0, n2), this.leftOver = t2.subarray(n2, t2.length)) : (i2 = t2.slice(0, n2), this.leftOver = t2.slice(n2, t2.length))), this.push({ data: s.utf8decode(i2), meta: e2.meta });
803
+ }, a.prototype.flush = function() {
804
+ this.leftOver && this.leftOver.length && (this.push({ data: s.utf8decode(this.leftOver), meta: {} }), this.leftOver = null);
805
+ }, s.Utf8DecodeWorker = a, o.inherits(l, n), l.prototype.processChunk = function(e2) {
806
+ this.push({ data: s.utf8encode(e2.data), meta: e2.meta });
807
+ }, s.Utf8EncodeWorker = l;
808
+ }, { "./nodejsUtils": 14, "./stream/GenericWorker": 28, "./support": 30, "./utils": 32 }], 32: [function(e, t, a) {
809
+ "use strict";
810
+ var o = e("./support"), h = e("./base64"), r = e("./nodejsUtils"), u = e("./external");
811
+ function n(e2) {
812
+ return e2;
813
+ }
814
+ function l(e2, t2) {
815
+ for (var r2 = 0; r2 < e2.length; ++r2) t2[r2] = 255 & e2.charCodeAt(r2);
816
+ return t2;
817
+ }
818
+ e("setimmediate"), a.newBlob = function(t2, r2) {
819
+ a.checkSupport("blob");
820
+ try {
821
+ return new Blob([t2], { type: r2 });
822
+ } catch (e2) {
823
+ try {
824
+ var n2 = new (self.BlobBuilder || self.WebKitBlobBuilder || self.MozBlobBuilder || self.MSBlobBuilder)();
825
+ return n2.append(t2), n2.getBlob(r2);
826
+ } catch (e3) {
827
+ throw new Error("Bug : can't construct the Blob.");
828
+ }
829
+ }
830
+ };
831
+ var i = { stringifyByChunk: function(e2, t2, r2) {
832
+ var n2 = [], i2 = 0, s2 = e2.length;
833
+ if (s2 <= r2) return String.fromCharCode.apply(null, e2);
834
+ for (; i2 < s2; ) "array" === t2 || "nodebuffer" === t2 ? n2.push(String.fromCharCode.apply(null, e2.slice(i2, Math.min(i2 + r2, s2)))) : n2.push(String.fromCharCode.apply(null, e2.subarray(i2, Math.min(i2 + r2, s2)))), i2 += r2;
835
+ return n2.join("");
836
+ }, stringifyByChar: function(e2) {
837
+ for (var t2 = "", r2 = 0; r2 < e2.length; r2++) t2 += String.fromCharCode(e2[r2]);
838
+ return t2;
839
+ }, applyCanBeUsed: { uint8array: function() {
840
+ try {
841
+ return o.uint8array && 1 === String.fromCharCode.apply(null, new Uint8Array(1)).length;
842
+ } catch (e2) {
843
+ return false;
844
+ }
845
+ }(), nodebuffer: function() {
846
+ try {
847
+ return o.nodebuffer && 1 === String.fromCharCode.apply(null, r.allocBuffer(1)).length;
848
+ } catch (e2) {
849
+ return false;
850
+ }
851
+ }() } };
852
+ function s(e2) {
853
+ var t2 = 65536, r2 = a.getTypeOf(e2), n2 = true;
854
+ if ("uint8array" === r2 ? n2 = i.applyCanBeUsed.uint8array : "nodebuffer" === r2 && (n2 = i.applyCanBeUsed.nodebuffer), n2) for (; 1 < t2; ) try {
855
+ return i.stringifyByChunk(e2, r2, t2);
856
+ } catch (e3) {
857
+ t2 = Math.floor(t2 / 2);
858
+ }
859
+ return i.stringifyByChar(e2);
860
+ }
861
+ function f(e2, t2) {
862
+ for (var r2 = 0; r2 < e2.length; r2++) t2[r2] = e2[r2];
863
+ return t2;
864
+ }
865
+ a.applyFromCharCode = s;
866
+ var c = {};
867
+ c.string = { string: n, array: function(e2) {
868
+ return l(e2, new Array(e2.length));
869
+ }, arraybuffer: function(e2) {
870
+ return c.string.uint8array(e2).buffer;
871
+ }, uint8array: function(e2) {
872
+ return l(e2, new Uint8Array(e2.length));
873
+ }, nodebuffer: function(e2) {
874
+ return l(e2, r.allocBuffer(e2.length));
875
+ } }, c.array = { string: s, array: n, arraybuffer: function(e2) {
876
+ return new Uint8Array(e2).buffer;
877
+ }, uint8array: function(e2) {
878
+ return new Uint8Array(e2);
879
+ }, nodebuffer: function(e2) {
880
+ return r.newBufferFrom(e2);
881
+ } }, c.arraybuffer = { string: function(e2) {
882
+ return s(new Uint8Array(e2));
883
+ }, array: function(e2) {
884
+ return f(new Uint8Array(e2), new Array(e2.byteLength));
885
+ }, arraybuffer: n, uint8array: function(e2) {
886
+ return new Uint8Array(e2);
887
+ }, nodebuffer: function(e2) {
888
+ return r.newBufferFrom(new Uint8Array(e2));
889
+ } }, c.uint8array = { string: s, array: function(e2) {
890
+ return f(e2, new Array(e2.length));
891
+ }, arraybuffer: function(e2) {
892
+ return e2.buffer;
893
+ }, uint8array: n, nodebuffer: function(e2) {
894
+ return r.newBufferFrom(e2);
895
+ } }, c.nodebuffer = { string: s, array: function(e2) {
896
+ return f(e2, new Array(e2.length));
897
+ }, arraybuffer: function(e2) {
898
+ return c.nodebuffer.uint8array(e2).buffer;
899
+ }, uint8array: function(e2) {
900
+ return f(e2, new Uint8Array(e2.length));
901
+ }, nodebuffer: n }, a.transformTo = function(e2, t2) {
902
+ if (t2 = t2 || "", !e2) return t2;
903
+ a.checkSupport(e2);
904
+ var r2 = a.getTypeOf(t2);
905
+ return c[r2][e2](t2);
906
+ }, a.resolve = function(e2) {
907
+ for (var t2 = e2.split("/"), r2 = [], n2 = 0; n2 < t2.length; n2++) {
908
+ var i2 = t2[n2];
909
+ "." === i2 || "" === i2 && 0 !== n2 && n2 !== t2.length - 1 || (".." === i2 ? r2.pop() : r2.push(i2));
910
+ }
911
+ return r2.join("/");
912
+ }, a.getTypeOf = function(e2) {
913
+ return "string" == typeof e2 ? "string" : "[object Array]" === Object.prototype.toString.call(e2) ? "array" : o.nodebuffer && r.isBuffer(e2) ? "nodebuffer" : o.uint8array && e2 instanceof Uint8Array ? "uint8array" : o.arraybuffer && e2 instanceof ArrayBuffer ? "arraybuffer" : void 0;
914
+ }, a.checkSupport = function(e2) {
915
+ if (!o[e2.toLowerCase()]) throw new Error(e2 + " is not supported by this platform");
916
+ }, a.MAX_VALUE_16BITS = 65535, a.MAX_VALUE_32BITS = -1, a.pretty = function(e2) {
917
+ var t2, r2, n2 = "";
918
+ for (r2 = 0; r2 < (e2 || "").length; r2++) n2 += "\\x" + ((t2 = e2.charCodeAt(r2)) < 16 ? "0" : "") + t2.toString(16).toUpperCase();
919
+ return n2;
920
+ }, a.delay = function(e2, t2, r2) {
921
+ setImmediate(function() {
922
+ e2.apply(r2 || null, t2 || []);
923
+ });
924
+ }, a.inherits = function(e2, t2) {
925
+ function r2() {
926
+ }
927
+ r2.prototype = t2.prototype, e2.prototype = new r2();
928
+ }, a.extend = function() {
929
+ var e2, t2, r2 = {};
930
+ for (e2 = 0; e2 < arguments.length; e2++) for (t2 in arguments[e2]) Object.prototype.hasOwnProperty.call(arguments[e2], t2) && void 0 === r2[t2] && (r2[t2] = arguments[e2][t2]);
931
+ return r2;
932
+ }, a.prepareContent = function(r2, e2, n2, i2, s2) {
933
+ return u.Promise.resolve(e2).then(function(n3) {
934
+ return o.blob && (n3 instanceof Blob || -1 !== ["[object File]", "[object Blob]"].indexOf(Object.prototype.toString.call(n3))) && "undefined" != typeof FileReader ? new u.Promise(function(t2, r3) {
935
+ var e3 = new FileReader();
936
+ e3.onload = function(e4) {
937
+ t2(e4.target.result);
938
+ }, e3.onerror = function(e4) {
939
+ r3(e4.target.error);
940
+ }, e3.readAsArrayBuffer(n3);
941
+ }) : n3;
942
+ }).then(function(e3) {
943
+ var t2 = a.getTypeOf(e3);
944
+ return t2 ? ("arraybuffer" === t2 ? e3 = a.transformTo("uint8array", e3) : "string" === t2 && (s2 ? e3 = h.decode(e3) : n2 && true !== i2 && (e3 = function(e4) {
945
+ return l(e4, o.uint8array ? new Uint8Array(e4.length) : new Array(e4.length));
946
+ }(e3))), e3) : u.Promise.reject(new Error("Can't read the data of '" + r2 + "'. Is it in a supported JavaScript type (String, Blob, ArrayBuffer, etc) ?"));
947
+ });
948
+ };
949
+ }, { "./base64": 1, "./external": 6, "./nodejsUtils": 14, "./support": 30, setimmediate: 54 }], 33: [function(e, t, r) {
950
+ "use strict";
951
+ var n = e("./reader/readerFor"), i = e("./utils"), s = e("./signature"), a = e("./zipEntry"), o = e("./support");
952
+ function h(e2) {
953
+ this.files = [], this.loadOptions = e2;
954
+ }
955
+ h.prototype = { checkSignature: function(e2) {
956
+ if (!this.reader.readAndCheckSignature(e2)) {
957
+ this.reader.index -= 4;
958
+ var t2 = this.reader.readString(4);
959
+ throw new Error("Corrupted zip or bug: unexpected signature (" + i.pretty(t2) + ", expected " + i.pretty(e2) + ")");
960
+ }
961
+ }, isSignature: function(e2, t2) {
962
+ var r2 = this.reader.index;
963
+ this.reader.setIndex(e2);
964
+ var n2 = this.reader.readString(4) === t2;
965
+ return this.reader.setIndex(r2), n2;
966
+ }, readBlockEndOfCentral: function() {
967
+ this.diskNumber = this.reader.readInt(2), this.diskWithCentralDirStart = this.reader.readInt(2), this.centralDirRecordsOnThisDisk = this.reader.readInt(2), this.centralDirRecords = this.reader.readInt(2), this.centralDirSize = this.reader.readInt(4), this.centralDirOffset = this.reader.readInt(4), this.zipCommentLength = this.reader.readInt(2);
968
+ var e2 = this.reader.readData(this.zipCommentLength), t2 = o.uint8array ? "uint8array" : "array", r2 = i.transformTo(t2, e2);
969
+ this.zipComment = this.loadOptions.decodeFileName(r2);
970
+ }, readBlockZip64EndOfCentral: function() {
971
+ this.zip64EndOfCentralSize = this.reader.readInt(8), this.reader.skip(4), this.diskNumber = this.reader.readInt(4), this.diskWithCentralDirStart = this.reader.readInt(4), this.centralDirRecordsOnThisDisk = this.reader.readInt(8), this.centralDirRecords = this.reader.readInt(8), this.centralDirSize = this.reader.readInt(8), this.centralDirOffset = this.reader.readInt(8), this.zip64ExtensibleData = {};
972
+ for (var e2, t2, r2, n2 = this.zip64EndOfCentralSize - 44; 0 < n2; ) e2 = this.reader.readInt(2), t2 = this.reader.readInt(4), r2 = this.reader.readData(t2), this.zip64ExtensibleData[e2] = { id: e2, length: t2, value: r2 };
973
+ }, readBlockZip64EndOfCentralLocator: function() {
974
+ if (this.diskWithZip64CentralDirStart = this.reader.readInt(4), this.relativeOffsetEndOfZip64CentralDir = this.reader.readInt(8), this.disksCount = this.reader.readInt(4), 1 < this.disksCount) throw new Error("Multi-volumes zip are not supported");
975
+ }, readLocalFiles: function() {
976
+ var e2, t2;
977
+ for (e2 = 0; e2 < this.files.length; e2++) t2 = this.files[e2], this.reader.setIndex(t2.localHeaderOffset), this.checkSignature(s.LOCAL_FILE_HEADER), t2.readLocalPart(this.reader), t2.handleUTF8(), t2.processAttributes();
978
+ }, readCentralDir: function() {
979
+ var e2;
980
+ for (this.reader.setIndex(this.centralDirOffset); this.reader.readAndCheckSignature(s.CENTRAL_FILE_HEADER); ) (e2 = new a({ zip64: this.zip64 }, this.loadOptions)).readCentralPart(this.reader), this.files.push(e2);
981
+ if (this.centralDirRecords !== this.files.length && 0 !== this.centralDirRecords && 0 === this.files.length) throw new Error("Corrupted zip or bug: expected " + this.centralDirRecords + " records in central dir, got " + this.files.length);
982
+ }, readEndOfCentral: function() {
983
+ var e2 = this.reader.lastIndexOfSignature(s.CENTRAL_DIRECTORY_END);
984
+ if (e2 < 0) throw !this.isSignature(0, s.LOCAL_FILE_HEADER) ? new Error("Can't find end of central directory : is this a zip file ? If it is, see https://stuk.github.io/jszip/documentation/howto/read_zip.html") : new Error("Corrupted zip: can't find end of central directory");
985
+ this.reader.setIndex(e2);
986
+ var t2 = e2;
987
+ if (this.checkSignature(s.CENTRAL_DIRECTORY_END), this.readBlockEndOfCentral(), this.diskNumber === i.MAX_VALUE_16BITS || this.diskWithCentralDirStart === i.MAX_VALUE_16BITS || this.centralDirRecordsOnThisDisk === i.MAX_VALUE_16BITS || this.centralDirRecords === i.MAX_VALUE_16BITS || this.centralDirSize === i.MAX_VALUE_32BITS || this.centralDirOffset === i.MAX_VALUE_32BITS) {
988
+ if (this.zip64 = true, (e2 = this.reader.lastIndexOfSignature(s.ZIP64_CENTRAL_DIRECTORY_LOCATOR)) < 0) throw new Error("Corrupted zip: can't find the ZIP64 end of central directory locator");
989
+ if (this.reader.setIndex(e2), this.checkSignature(s.ZIP64_CENTRAL_DIRECTORY_LOCATOR), this.readBlockZip64EndOfCentralLocator(), !this.isSignature(this.relativeOffsetEndOfZip64CentralDir, s.ZIP64_CENTRAL_DIRECTORY_END) && (this.relativeOffsetEndOfZip64CentralDir = this.reader.lastIndexOfSignature(s.ZIP64_CENTRAL_DIRECTORY_END), this.relativeOffsetEndOfZip64CentralDir < 0)) throw new Error("Corrupted zip: can't find the ZIP64 end of central directory");
990
+ this.reader.setIndex(this.relativeOffsetEndOfZip64CentralDir), this.checkSignature(s.ZIP64_CENTRAL_DIRECTORY_END), this.readBlockZip64EndOfCentral();
991
+ }
992
+ var r2 = this.centralDirOffset + this.centralDirSize;
993
+ this.zip64 && (r2 += 20, r2 += 12 + this.zip64EndOfCentralSize);
994
+ var n2 = t2 - r2;
995
+ if (0 < n2) this.isSignature(t2, s.CENTRAL_FILE_HEADER) || (this.reader.zero = n2);
996
+ else if (n2 < 0) throw new Error("Corrupted zip: missing " + Math.abs(n2) + " bytes.");
997
+ }, prepareReader: function(e2) {
998
+ this.reader = n(e2);
999
+ }, load: function(e2) {
1000
+ this.prepareReader(e2), this.readEndOfCentral(), this.readCentralDir(), this.readLocalFiles();
1001
+ } }, t.exports = h;
1002
+ }, { "./reader/readerFor": 22, "./signature": 23, "./support": 30, "./utils": 32, "./zipEntry": 34 }], 34: [function(e, t, r) {
1003
+ "use strict";
1004
+ var n = e("./reader/readerFor"), s = e("./utils"), i = e("./compressedObject"), a = e("./crc32"), o = e("./utf8"), h = e("./compressions"), u = e("./support");
1005
+ function l(e2, t2) {
1006
+ this.options = e2, this.loadOptions = t2;
1007
+ }
1008
+ l.prototype = { isEncrypted: function() {
1009
+ return 1 == (1 & this.bitFlag);
1010
+ }, useUTF8: function() {
1011
+ return 2048 == (2048 & this.bitFlag);
1012
+ }, readLocalPart: function(e2) {
1013
+ var t2, r2;
1014
+ if (e2.skip(22), this.fileNameLength = e2.readInt(2), r2 = e2.readInt(2), this.fileName = e2.readData(this.fileNameLength), e2.skip(r2), -1 === this.compressedSize || -1 === this.uncompressedSize) throw new Error("Bug or corrupted zip : didn't get enough information from the central directory (compressedSize === -1 || uncompressedSize === -1)");
1015
+ if (null === (t2 = function(e3) {
1016
+ for (var t3 in h) if (Object.prototype.hasOwnProperty.call(h, t3) && h[t3].magic === e3) return h[t3];
1017
+ return null;
1018
+ }(this.compressionMethod))) throw new Error("Corrupted zip : compression " + s.pretty(this.compressionMethod) + " unknown (inner file : " + s.transformTo("string", this.fileName) + ")");
1019
+ this.decompressed = new i(this.compressedSize, this.uncompressedSize, this.crc32, t2, e2.readData(this.compressedSize));
1020
+ }, readCentralPart: function(e2) {
1021
+ this.versionMadeBy = e2.readInt(2), e2.skip(2), this.bitFlag = e2.readInt(2), this.compressionMethod = e2.readString(2), this.date = e2.readDate(), this.crc32 = e2.readInt(4), this.compressedSize = e2.readInt(4), this.uncompressedSize = e2.readInt(4);
1022
+ var t2 = e2.readInt(2);
1023
+ if (this.extraFieldsLength = e2.readInt(2), this.fileCommentLength = e2.readInt(2), this.diskNumberStart = e2.readInt(2), this.internalFileAttributes = e2.readInt(2), this.externalFileAttributes = e2.readInt(4), this.localHeaderOffset = e2.readInt(4), this.isEncrypted()) throw new Error("Encrypted zip are not supported");
1024
+ e2.skip(t2), this.readExtraFields(e2), this.parseZIP64ExtraField(e2), this.fileComment = e2.readData(this.fileCommentLength);
1025
+ }, processAttributes: function() {
1026
+ this.unixPermissions = null, this.dosPermissions = null;
1027
+ var e2 = this.versionMadeBy >> 8;
1028
+ this.dir = !!(16 & this.externalFileAttributes), 0 == e2 && (this.dosPermissions = 63 & this.externalFileAttributes), 3 == e2 && (this.unixPermissions = this.externalFileAttributes >> 16 & 65535), this.dir || "/" !== this.fileNameStr.slice(-1) || (this.dir = true);
1029
+ }, parseZIP64ExtraField: function() {
1030
+ if (this.extraFields[1]) {
1031
+ var e2 = n(this.extraFields[1].value);
1032
+ this.uncompressedSize === s.MAX_VALUE_32BITS && (this.uncompressedSize = e2.readInt(8)), this.compressedSize === s.MAX_VALUE_32BITS && (this.compressedSize = e2.readInt(8)), this.localHeaderOffset === s.MAX_VALUE_32BITS && (this.localHeaderOffset = e2.readInt(8)), this.diskNumberStart === s.MAX_VALUE_32BITS && (this.diskNumberStart = e2.readInt(4));
1033
+ }
1034
+ }, readExtraFields: function(e2) {
1035
+ var t2, r2, n2, i2 = e2.index + this.extraFieldsLength;
1036
+ for (this.extraFields || (this.extraFields = {}); e2.index + 4 < i2; ) t2 = e2.readInt(2), r2 = e2.readInt(2), n2 = e2.readData(r2), this.extraFields[t2] = { id: t2, length: r2, value: n2 };
1037
+ e2.setIndex(i2);
1038
+ }, handleUTF8: function() {
1039
+ var e2 = u.uint8array ? "uint8array" : "array";
1040
+ if (this.useUTF8()) this.fileNameStr = o.utf8decode(this.fileName), this.fileCommentStr = o.utf8decode(this.fileComment);
1041
+ else {
1042
+ var t2 = this.findExtraFieldUnicodePath();
1043
+ if (null !== t2) this.fileNameStr = t2;
1044
+ else {
1045
+ var r2 = s.transformTo(e2, this.fileName);
1046
+ this.fileNameStr = this.loadOptions.decodeFileName(r2);
1047
+ }
1048
+ var n2 = this.findExtraFieldUnicodeComment();
1049
+ if (null !== n2) this.fileCommentStr = n2;
1050
+ else {
1051
+ var i2 = s.transformTo(e2, this.fileComment);
1052
+ this.fileCommentStr = this.loadOptions.decodeFileName(i2);
1053
+ }
1054
+ }
1055
+ }, findExtraFieldUnicodePath: function() {
1056
+ var e2 = this.extraFields[28789];
1057
+ if (e2) {
1058
+ var t2 = n(e2.value);
1059
+ return 1 !== t2.readInt(1) ? null : a(this.fileName) !== t2.readInt(4) ? null : o.utf8decode(t2.readData(e2.length - 5));
1060
+ }
1061
+ return null;
1062
+ }, findExtraFieldUnicodeComment: function() {
1063
+ var e2 = this.extraFields[25461];
1064
+ if (e2) {
1065
+ var t2 = n(e2.value);
1066
+ return 1 !== t2.readInt(1) ? null : a(this.fileComment) !== t2.readInt(4) ? null : o.utf8decode(t2.readData(e2.length - 5));
1067
+ }
1068
+ return null;
1069
+ } }, t.exports = l;
1070
+ }, { "./compressedObject": 2, "./compressions": 3, "./crc32": 4, "./reader/readerFor": 22, "./support": 30, "./utf8": 31, "./utils": 32 }], 35: [function(e, t, r) {
1071
+ "use strict";
1072
+ function n(e2, t2, r2) {
1073
+ this.name = e2, this.dir = r2.dir, this.date = r2.date, this.comment = r2.comment, this.unixPermissions = r2.unixPermissions, this.dosPermissions = r2.dosPermissions, this._data = t2, this._dataBinary = r2.binary, this.options = { compression: r2.compression, compressionOptions: r2.compressionOptions };
1074
+ }
1075
+ var s = e("./stream/StreamHelper"), i = e("./stream/DataWorker"), a = e("./utf8"), o = e("./compressedObject"), h = e("./stream/GenericWorker");
1076
+ n.prototype = { internalStream: function(e2) {
1077
+ var t2 = null, r2 = "string";
1078
+ try {
1079
+ if (!e2) throw new Error("No output type specified.");
1080
+ var n2 = "string" === (r2 = e2.toLowerCase()) || "text" === r2;
1081
+ "binarystring" !== r2 && "text" !== r2 || (r2 = "string"), t2 = this._decompressWorker();
1082
+ var i2 = !this._dataBinary;
1083
+ i2 && !n2 && (t2 = t2.pipe(new a.Utf8EncodeWorker())), !i2 && n2 && (t2 = t2.pipe(new a.Utf8DecodeWorker()));
1084
+ } catch (e3) {
1085
+ (t2 = new h("error")).error(e3);
1086
+ }
1087
+ return new s(t2, r2, "");
1088
+ }, async: function(e2, t2) {
1089
+ return this.internalStream(e2).accumulate(t2);
1090
+ }, nodeStream: function(e2, t2) {
1091
+ return this.internalStream(e2 || "nodebuffer").toNodejsStream(t2);
1092
+ }, _compressWorker: function(e2, t2) {
1093
+ if (this._data instanceof o && this._data.compression.magic === e2.magic) return this._data.getCompressedWorker();
1094
+ var r2 = this._decompressWorker();
1095
+ return this._dataBinary || (r2 = r2.pipe(new a.Utf8EncodeWorker())), o.createWorkerFrom(r2, e2, t2);
1096
+ }, _decompressWorker: function() {
1097
+ return this._data instanceof o ? this._data.getContentWorker() : this._data instanceof h ? this._data : new i(this._data);
1098
+ } };
1099
+ for (var u = ["asText", "asBinary", "asNodeBuffer", "asUint8Array", "asArrayBuffer"], l = function() {
1100
+ throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
1101
+ }, f = 0; f < u.length; f++) n.prototype[u[f]] = l;
1102
+ t.exports = n;
1103
+ }, { "./compressedObject": 2, "./stream/DataWorker": 27, "./stream/GenericWorker": 28, "./stream/StreamHelper": 29, "./utf8": 31 }], 36: [function(e, l, t) {
1104
+ (function(t2) {
1105
+ "use strict";
1106
+ var r, n, e2 = t2.MutationObserver || t2.WebKitMutationObserver;
1107
+ if (e2) {
1108
+ var i = 0, s = new e2(u), a = t2.document.createTextNode("");
1109
+ s.observe(a, { characterData: true }), r = function() {
1110
+ a.data = i = ++i % 2;
1111
+ };
1112
+ } else if (t2.setImmediate || void 0 === t2.MessageChannel) r = "document" in t2 && "onreadystatechange" in t2.document.createElement("script") ? function() {
1113
+ var e3 = t2.document.createElement("script");
1114
+ e3.onreadystatechange = function() {
1115
+ u(), e3.onreadystatechange = null, e3.parentNode.removeChild(e3), e3 = null;
1116
+ }, t2.document.documentElement.appendChild(e3);
1117
+ } : function() {
1118
+ setTimeout(u, 0);
1119
+ };
1120
+ else {
1121
+ var o = new t2.MessageChannel();
1122
+ o.port1.onmessage = u, r = function() {
1123
+ o.port2.postMessage(0);
1124
+ };
1125
+ }
1126
+ var h = [];
1127
+ function u() {
1128
+ var e3, t3;
1129
+ n = true;
1130
+ for (var r2 = h.length; r2; ) {
1131
+ for (t3 = h, h = [], e3 = -1; ++e3 < r2; ) t3[e3]();
1132
+ r2 = h.length;
1133
+ }
1134
+ n = false;
1135
+ }
1136
+ l.exports = function(e3) {
1137
+ 1 !== h.push(e3) || n || r();
1138
+ };
1139
+ }).call(this, "undefined" != typeof global ? global : "undefined" != typeof self ? self : "undefined" != typeof window ? window : {});
1140
+ }, {}], 37: [function(e, t, r) {
1141
+ "use strict";
1142
+ var i = e("immediate");
1143
+ function u() {
1144
+ }
1145
+ var l = {}, s = ["REJECTED"], a = ["FULFILLED"], n = ["PENDING"];
1146
+ function o(e2) {
1147
+ if ("function" != typeof e2) throw new TypeError("resolver must be a function");
1148
+ this.state = n, this.queue = [], this.outcome = void 0, e2 !== u && d(this, e2);
1149
+ }
1150
+ function h(e2, t2, r2) {
1151
+ this.promise = e2, "function" == typeof t2 && (this.onFulfilled = t2, this.callFulfilled = this.otherCallFulfilled), "function" == typeof r2 && (this.onRejected = r2, this.callRejected = this.otherCallRejected);
1152
+ }
1153
+ function f(t2, r2, n2) {
1154
+ i(function() {
1155
+ var e2;
1156
+ try {
1157
+ e2 = r2(n2);
1158
+ } catch (e3) {
1159
+ return l.reject(t2, e3);
1160
+ }
1161
+ e2 === t2 ? l.reject(t2, new TypeError("Cannot resolve promise with itself")) : l.resolve(t2, e2);
1162
+ });
1163
+ }
1164
+ function c(e2) {
1165
+ var t2 = e2 && e2.then;
1166
+ if (e2 && ("object" == typeof e2 || "function" == typeof e2) && "function" == typeof t2) return function() {
1167
+ t2.apply(e2, arguments);
1168
+ };
1169
+ }
1170
+ function d(t2, e2) {
1171
+ var r2 = false;
1172
+ function n2(e3) {
1173
+ r2 || (r2 = true, l.reject(t2, e3));
1174
+ }
1175
+ function i2(e3) {
1176
+ r2 || (r2 = true, l.resolve(t2, e3));
1177
+ }
1178
+ var s2 = p(function() {
1179
+ e2(i2, n2);
1180
+ });
1181
+ "error" === s2.status && n2(s2.value);
1182
+ }
1183
+ function p(e2, t2) {
1184
+ var r2 = {};
1185
+ try {
1186
+ r2.value = e2(t2), r2.status = "success";
1187
+ } catch (e3) {
1188
+ r2.status = "error", r2.value = e3;
1189
+ }
1190
+ return r2;
1191
+ }
1192
+ (t.exports = o).prototype.finally = function(t2) {
1193
+ if ("function" != typeof t2) return this;
1194
+ var r2 = this.constructor;
1195
+ return this.then(function(e2) {
1196
+ return r2.resolve(t2()).then(function() {
1197
+ return e2;
1198
+ });
1199
+ }, function(e2) {
1200
+ return r2.resolve(t2()).then(function() {
1201
+ throw e2;
1202
+ });
1203
+ });
1204
+ }, o.prototype.catch = function(e2) {
1205
+ return this.then(null, e2);
1206
+ }, o.prototype.then = function(e2, t2) {
1207
+ if ("function" != typeof e2 && this.state === a || "function" != typeof t2 && this.state === s) return this;
1208
+ var r2 = new this.constructor(u);
1209
+ this.state !== n ? f(r2, this.state === a ? e2 : t2, this.outcome) : this.queue.push(new h(r2, e2, t2));
1210
+ return r2;
1211
+ }, h.prototype.callFulfilled = function(e2) {
1212
+ l.resolve(this.promise, e2);
1213
+ }, h.prototype.otherCallFulfilled = function(e2) {
1214
+ f(this.promise, this.onFulfilled, e2);
1215
+ }, h.prototype.callRejected = function(e2) {
1216
+ l.reject(this.promise, e2);
1217
+ }, h.prototype.otherCallRejected = function(e2) {
1218
+ f(this.promise, this.onRejected, e2);
1219
+ }, l.resolve = function(e2, t2) {
1220
+ var r2 = p(c, t2);
1221
+ if ("error" === r2.status) return l.reject(e2, r2.value);
1222
+ var n2 = r2.value;
1223
+ if (n2) d(e2, n2);
1224
+ else {
1225
+ e2.state = a, e2.outcome = t2;
1226
+ for (var i2 = -1, s2 = e2.queue.length; ++i2 < s2; ) e2.queue[i2].callFulfilled(t2);
1227
+ }
1228
+ return e2;
1229
+ }, l.reject = function(e2, t2) {
1230
+ e2.state = s, e2.outcome = t2;
1231
+ for (var r2 = -1, n2 = e2.queue.length; ++r2 < n2; ) e2.queue[r2].callRejected(t2);
1232
+ return e2;
1233
+ }, o.resolve = function(e2) {
1234
+ if (e2 instanceof this) return e2;
1235
+ return l.resolve(new this(u), e2);
1236
+ }, o.reject = function(e2) {
1237
+ var t2 = new this(u);
1238
+ return l.reject(t2, e2);
1239
+ }, o.all = function(e2) {
1240
+ var r2 = this;
1241
+ if ("[object Array]" !== Object.prototype.toString.call(e2)) return this.reject(new TypeError("must be an array"));
1242
+ var n2 = e2.length, i2 = false;
1243
+ if (!n2) return this.resolve([]);
1244
+ var s2 = new Array(n2), a2 = 0, t2 = -1, o2 = new this(u);
1245
+ for (; ++t2 < n2; ) h2(e2[t2], t2);
1246
+ return o2;
1247
+ function h2(e3, t3) {
1248
+ r2.resolve(e3).then(function(e4) {
1249
+ s2[t3] = e4, ++a2 !== n2 || i2 || (i2 = true, l.resolve(o2, s2));
1250
+ }, function(e4) {
1251
+ i2 || (i2 = true, l.reject(o2, e4));
1252
+ });
1253
+ }
1254
+ }, o.race = function(e2) {
1255
+ var t2 = this;
1256
+ if ("[object Array]" !== Object.prototype.toString.call(e2)) return this.reject(new TypeError("must be an array"));
1257
+ var r2 = e2.length, n2 = false;
1258
+ if (!r2) return this.resolve([]);
1259
+ var i2 = -1, s2 = new this(u);
1260
+ for (; ++i2 < r2; ) a2 = e2[i2], t2.resolve(a2).then(function(e3) {
1261
+ n2 || (n2 = true, l.resolve(s2, e3));
1262
+ }, function(e3) {
1263
+ n2 || (n2 = true, l.reject(s2, e3));
1264
+ });
1265
+ var a2;
1266
+ return s2;
1267
+ };
1268
+ }, { immediate: 36 }], 38: [function(e, t, r) {
1269
+ "use strict";
1270
+ var n = {};
1271
+ (0, e("./lib/utils/common").assign)(n, e("./lib/deflate"), e("./lib/inflate"), e("./lib/zlib/constants")), t.exports = n;
1272
+ }, { "./lib/deflate": 39, "./lib/inflate": 40, "./lib/utils/common": 41, "./lib/zlib/constants": 44 }], 39: [function(e, t, r) {
1273
+ "use strict";
1274
+ var a = e("./zlib/deflate"), o = e("./utils/common"), h = e("./utils/strings"), i = e("./zlib/messages"), s = e("./zlib/zstream"), u = Object.prototype.toString, l = 0, f = -1, c = 0, d = 8;
1275
+ function p(e2) {
1276
+ if (!(this instanceof p)) return new p(e2);
1277
+ this.options = o.assign({ level: f, method: d, chunkSize: 16384, windowBits: 15, memLevel: 8, strategy: c, to: "" }, e2 || {});
1278
+ var t2 = this.options;
1279
+ t2.raw && 0 < t2.windowBits ? t2.windowBits = -t2.windowBits : t2.gzip && 0 < t2.windowBits && t2.windowBits < 16 && (t2.windowBits += 16), this.err = 0, this.msg = "", this.ended = false, this.chunks = [], this.strm = new s(), this.strm.avail_out = 0;
1280
+ var r2 = a.deflateInit2(this.strm, t2.level, t2.method, t2.windowBits, t2.memLevel, t2.strategy);
1281
+ if (r2 !== l) throw new Error(i[r2]);
1282
+ if (t2.header && a.deflateSetHeader(this.strm, t2.header), t2.dictionary) {
1283
+ var n2;
1284
+ if (n2 = "string" == typeof t2.dictionary ? h.string2buf(t2.dictionary) : "[object ArrayBuffer]" === u.call(t2.dictionary) ? new Uint8Array(t2.dictionary) : t2.dictionary, (r2 = a.deflateSetDictionary(this.strm, n2)) !== l) throw new Error(i[r2]);
1285
+ this._dict_set = true;
1286
+ }
1287
+ }
1288
+ function n(e2, t2) {
1289
+ var r2 = new p(t2);
1290
+ if (r2.push(e2, true), r2.err) throw r2.msg || i[r2.err];
1291
+ return r2.result;
1292
+ }
1293
+ p.prototype.push = function(e2, t2) {
1294
+ var r2, n2, i2 = this.strm, s2 = this.options.chunkSize;
1295
+ if (this.ended) return false;
1296
+ n2 = t2 === ~~t2 ? t2 : true === t2 ? 4 : 0, "string" == typeof e2 ? i2.input = h.string2buf(e2) : "[object ArrayBuffer]" === u.call(e2) ? i2.input = new Uint8Array(e2) : i2.input = e2, i2.next_in = 0, i2.avail_in = i2.input.length;
1297
+ do {
1298
+ if (0 === i2.avail_out && (i2.output = new o.Buf8(s2), i2.next_out = 0, i2.avail_out = s2), 1 !== (r2 = a.deflate(i2, n2)) && r2 !== l) return this.onEnd(r2), !(this.ended = true);
1299
+ 0 !== i2.avail_out && (0 !== i2.avail_in || 4 !== n2 && 2 !== n2) || ("string" === this.options.to ? this.onData(h.buf2binstring(o.shrinkBuf(i2.output, i2.next_out))) : this.onData(o.shrinkBuf(i2.output, i2.next_out)));
1300
+ } while ((0 < i2.avail_in || 0 === i2.avail_out) && 1 !== r2);
1301
+ return 4 === n2 ? (r2 = a.deflateEnd(this.strm), this.onEnd(r2), this.ended = true, r2 === l) : 2 !== n2 || (this.onEnd(l), !(i2.avail_out = 0));
1302
+ }, p.prototype.onData = function(e2) {
1303
+ this.chunks.push(e2);
1304
+ }, p.prototype.onEnd = function(e2) {
1305
+ e2 === l && ("string" === this.options.to ? this.result = this.chunks.join("") : this.result = o.flattenChunks(this.chunks)), this.chunks = [], this.err = e2, this.msg = this.strm.msg;
1306
+ }, r.Deflate = p, r.deflate = n, r.deflateRaw = function(e2, t2) {
1307
+ return (t2 = t2 || {}).raw = true, n(e2, t2);
1308
+ }, r.gzip = function(e2, t2) {
1309
+ return (t2 = t2 || {}).gzip = true, n(e2, t2);
1310
+ };
1311
+ }, { "./utils/common": 41, "./utils/strings": 42, "./zlib/deflate": 46, "./zlib/messages": 51, "./zlib/zstream": 53 }], 40: [function(e, t, r) {
1312
+ "use strict";
1313
+ var c = e("./zlib/inflate"), d = e("./utils/common"), p = e("./utils/strings"), m = e("./zlib/constants"), n = e("./zlib/messages"), i = e("./zlib/zstream"), s = e("./zlib/gzheader"), _ = Object.prototype.toString;
1314
+ function a(e2) {
1315
+ if (!(this instanceof a)) return new a(e2);
1316
+ this.options = d.assign({ chunkSize: 16384, windowBits: 0, to: "" }, e2 || {});
1317
+ var t2 = this.options;
1318
+ t2.raw && 0 <= t2.windowBits && t2.windowBits < 16 && (t2.windowBits = -t2.windowBits, 0 === t2.windowBits && (t2.windowBits = -15)), !(0 <= t2.windowBits && t2.windowBits < 16) || e2 && e2.windowBits || (t2.windowBits += 32), 15 < t2.windowBits && t2.windowBits < 48 && 0 == (15 & t2.windowBits) && (t2.windowBits |= 15), this.err = 0, this.msg = "", this.ended = false, this.chunks = [], this.strm = new i(), this.strm.avail_out = 0;
1319
+ var r2 = c.inflateInit2(this.strm, t2.windowBits);
1320
+ if (r2 !== m.Z_OK) throw new Error(n[r2]);
1321
+ this.header = new s(), c.inflateGetHeader(this.strm, this.header);
1322
+ }
1323
+ function o(e2, t2) {
1324
+ var r2 = new a(t2);
1325
+ if (r2.push(e2, true), r2.err) throw r2.msg || n[r2.err];
1326
+ return r2.result;
1327
+ }
1328
+ a.prototype.push = function(e2, t2) {
1329
+ var r2, n2, i2, s2, a2, o2, h = this.strm, u = this.options.chunkSize, l = this.options.dictionary, f = false;
1330
+ if (this.ended) return false;
1331
+ n2 = t2 === ~~t2 ? t2 : true === t2 ? m.Z_FINISH : m.Z_NO_FLUSH, "string" == typeof e2 ? h.input = p.binstring2buf(e2) : "[object ArrayBuffer]" === _.call(e2) ? h.input = new Uint8Array(e2) : h.input = e2, h.next_in = 0, h.avail_in = h.input.length;
1332
+ do {
1333
+ if (0 === h.avail_out && (h.output = new d.Buf8(u), h.next_out = 0, h.avail_out = u), (r2 = c.inflate(h, m.Z_NO_FLUSH)) === m.Z_NEED_DICT && l && (o2 = "string" == typeof l ? p.string2buf(l) : "[object ArrayBuffer]" === _.call(l) ? new Uint8Array(l) : l, r2 = c.inflateSetDictionary(this.strm, o2)), r2 === m.Z_BUF_ERROR && true === f && (r2 = m.Z_OK, f = false), r2 !== m.Z_STREAM_END && r2 !== m.Z_OK) return this.onEnd(r2), !(this.ended = true);
1334
+ h.next_out && (0 !== h.avail_out && r2 !== m.Z_STREAM_END && (0 !== h.avail_in || n2 !== m.Z_FINISH && n2 !== m.Z_SYNC_FLUSH) || ("string" === this.options.to ? (i2 = p.utf8border(h.output, h.next_out), s2 = h.next_out - i2, a2 = p.buf2string(h.output, i2), h.next_out = s2, h.avail_out = u - s2, s2 && d.arraySet(h.output, h.output, i2, s2, 0), this.onData(a2)) : this.onData(d.shrinkBuf(h.output, h.next_out)))), 0 === h.avail_in && 0 === h.avail_out && (f = true);
1335
+ } while ((0 < h.avail_in || 0 === h.avail_out) && r2 !== m.Z_STREAM_END);
1336
+ return r2 === m.Z_STREAM_END && (n2 = m.Z_FINISH), n2 === m.Z_FINISH ? (r2 = c.inflateEnd(this.strm), this.onEnd(r2), this.ended = true, r2 === m.Z_OK) : n2 !== m.Z_SYNC_FLUSH || (this.onEnd(m.Z_OK), !(h.avail_out = 0));
1337
+ }, a.prototype.onData = function(e2) {
1338
+ this.chunks.push(e2);
1339
+ }, a.prototype.onEnd = function(e2) {
1340
+ e2 === m.Z_OK && ("string" === this.options.to ? this.result = this.chunks.join("") : this.result = d.flattenChunks(this.chunks)), this.chunks = [], this.err = e2, this.msg = this.strm.msg;
1341
+ }, r.Inflate = a, r.inflate = o, r.inflateRaw = function(e2, t2) {
1342
+ return (t2 = t2 || {}).raw = true, o(e2, t2);
1343
+ }, r.ungzip = o;
1344
+ }, { "./utils/common": 41, "./utils/strings": 42, "./zlib/constants": 44, "./zlib/gzheader": 47, "./zlib/inflate": 49, "./zlib/messages": 51, "./zlib/zstream": 53 }], 41: [function(e, t, r) {
1345
+ "use strict";
1346
+ var n = "undefined" != typeof Uint8Array && "undefined" != typeof Uint16Array && "undefined" != typeof Int32Array;
1347
+ r.assign = function(e2) {
1348
+ for (var t2 = Array.prototype.slice.call(arguments, 1); t2.length; ) {
1349
+ var r2 = t2.shift();
1350
+ if (r2) {
1351
+ if ("object" != typeof r2) throw new TypeError(r2 + "must be non-object");
1352
+ for (var n2 in r2) r2.hasOwnProperty(n2) && (e2[n2] = r2[n2]);
1353
+ }
1354
+ }
1355
+ return e2;
1356
+ }, r.shrinkBuf = function(e2, t2) {
1357
+ return e2.length === t2 ? e2 : e2.subarray ? e2.subarray(0, t2) : (e2.length = t2, e2);
1358
+ };
1359
+ var i = { arraySet: function(e2, t2, r2, n2, i2) {
1360
+ if (t2.subarray && e2.subarray) e2.set(t2.subarray(r2, r2 + n2), i2);
1361
+ else for (var s2 = 0; s2 < n2; s2++) e2[i2 + s2] = t2[r2 + s2];
1362
+ }, flattenChunks: function(e2) {
1363
+ var t2, r2, n2, i2, s2, a;
1364
+ for (t2 = n2 = 0, r2 = e2.length; t2 < r2; t2++) n2 += e2[t2].length;
1365
+ for (a = new Uint8Array(n2), t2 = i2 = 0, r2 = e2.length; t2 < r2; t2++) s2 = e2[t2], a.set(s2, i2), i2 += s2.length;
1366
+ return a;
1367
+ } }, s = { arraySet: function(e2, t2, r2, n2, i2) {
1368
+ for (var s2 = 0; s2 < n2; s2++) e2[i2 + s2] = t2[r2 + s2];
1369
+ }, flattenChunks: function(e2) {
1370
+ return [].concat.apply([], e2);
1371
+ } };
1372
+ r.setTyped = function(e2) {
1373
+ e2 ? (r.Buf8 = Uint8Array, r.Buf16 = Uint16Array, r.Buf32 = Int32Array, r.assign(r, i)) : (r.Buf8 = Array, r.Buf16 = Array, r.Buf32 = Array, r.assign(r, s));
1374
+ }, r.setTyped(n);
1375
+ }, {}], 42: [function(e, t, r) {
1376
+ "use strict";
1377
+ var h = e("./common"), i = true, s = true;
1378
+ try {
1379
+ String.fromCharCode.apply(null, [0]);
1380
+ } catch (e2) {
1381
+ i = false;
1382
+ }
1383
+ try {
1384
+ String.fromCharCode.apply(null, new Uint8Array(1));
1385
+ } catch (e2) {
1386
+ s = false;
1387
+ }
1388
+ for (var u = new h.Buf8(256), n = 0; n < 256; n++) u[n] = 252 <= n ? 6 : 248 <= n ? 5 : 240 <= n ? 4 : 224 <= n ? 3 : 192 <= n ? 2 : 1;
1389
+ function l(e2, t2) {
1390
+ if (t2 < 65537 && (e2.subarray && s || !e2.subarray && i)) return String.fromCharCode.apply(null, h.shrinkBuf(e2, t2));
1391
+ for (var r2 = "", n2 = 0; n2 < t2; n2++) r2 += String.fromCharCode(e2[n2]);
1392
+ return r2;
1393
+ }
1394
+ u[254] = u[254] = 1, r.string2buf = function(e2) {
1395
+ var t2, r2, n2, i2, s2, a = e2.length, o = 0;
1396
+ for (i2 = 0; i2 < a; i2++) 55296 == (64512 & (r2 = e2.charCodeAt(i2))) && i2 + 1 < a && 56320 == (64512 & (n2 = e2.charCodeAt(i2 + 1))) && (r2 = 65536 + (r2 - 55296 << 10) + (n2 - 56320), i2++), o += r2 < 128 ? 1 : r2 < 2048 ? 2 : r2 < 65536 ? 3 : 4;
1397
+ for (t2 = new h.Buf8(o), i2 = s2 = 0; s2 < o; i2++) 55296 == (64512 & (r2 = e2.charCodeAt(i2))) && i2 + 1 < a && 56320 == (64512 & (n2 = e2.charCodeAt(i2 + 1))) && (r2 = 65536 + (r2 - 55296 << 10) + (n2 - 56320), i2++), r2 < 128 ? t2[s2++] = r2 : (r2 < 2048 ? t2[s2++] = 192 | r2 >>> 6 : (r2 < 65536 ? t2[s2++] = 224 | r2 >>> 12 : (t2[s2++] = 240 | r2 >>> 18, t2[s2++] = 128 | r2 >>> 12 & 63), t2[s2++] = 128 | r2 >>> 6 & 63), t2[s2++] = 128 | 63 & r2);
1398
+ return t2;
1399
+ }, r.buf2binstring = function(e2) {
1400
+ return l(e2, e2.length);
1401
+ }, r.binstring2buf = function(e2) {
1402
+ for (var t2 = new h.Buf8(e2.length), r2 = 0, n2 = t2.length; r2 < n2; r2++) t2[r2] = e2.charCodeAt(r2);
1403
+ return t2;
1404
+ }, r.buf2string = function(e2, t2) {
1405
+ var r2, n2, i2, s2, a = t2 || e2.length, o = new Array(2 * a);
1406
+ for (r2 = n2 = 0; r2 < a; ) if ((i2 = e2[r2++]) < 128) o[n2++] = i2;
1407
+ else if (4 < (s2 = u[i2])) o[n2++] = 65533, r2 += s2 - 1;
1408
+ else {
1409
+ for (i2 &= 2 === s2 ? 31 : 3 === s2 ? 15 : 7; 1 < s2 && r2 < a; ) i2 = i2 << 6 | 63 & e2[r2++], s2--;
1410
+ 1 < s2 ? o[n2++] = 65533 : i2 < 65536 ? o[n2++] = i2 : (i2 -= 65536, o[n2++] = 55296 | i2 >> 10 & 1023, o[n2++] = 56320 | 1023 & i2);
1411
+ }
1412
+ return l(o, n2);
1413
+ }, r.utf8border = function(e2, t2) {
1414
+ var r2;
1415
+ for ((t2 = t2 || e2.length) > e2.length && (t2 = e2.length), r2 = t2 - 1; 0 <= r2 && 128 == (192 & e2[r2]); ) r2--;
1416
+ return r2 < 0 ? t2 : 0 === r2 ? t2 : r2 + u[e2[r2]] > t2 ? r2 : t2;
1417
+ };
1418
+ }, { "./common": 41 }], 43: [function(e, t, r) {
1419
+ "use strict";
1420
+ t.exports = function(e2, t2, r2, n) {
1421
+ for (var i = 65535 & e2 | 0, s = e2 >>> 16 & 65535 | 0, a = 0; 0 !== r2; ) {
1422
+ for (r2 -= a = 2e3 < r2 ? 2e3 : r2; s = s + (i = i + t2[n++] | 0) | 0, --a; ) ;
1423
+ i %= 65521, s %= 65521;
1424
+ }
1425
+ return i | s << 16 | 0;
1426
+ };
1427
+ }, {}], 44: [function(e, t, r) {
1428
+ "use strict";
1429
+ t.exports = { Z_NO_FLUSH: 0, Z_PARTIAL_FLUSH: 1, Z_SYNC_FLUSH: 2, Z_FULL_FLUSH: 3, Z_FINISH: 4, Z_BLOCK: 5, Z_TREES: 6, Z_OK: 0, Z_STREAM_END: 1, Z_NEED_DICT: 2, Z_ERRNO: -1, Z_STREAM_ERROR: -2, Z_DATA_ERROR: -3, Z_BUF_ERROR: -5, Z_NO_COMPRESSION: 0, Z_BEST_SPEED: 1, Z_BEST_COMPRESSION: 9, Z_DEFAULT_COMPRESSION: -1, Z_FILTERED: 1, Z_HUFFMAN_ONLY: 2, Z_RLE: 3, Z_FIXED: 4, Z_DEFAULT_STRATEGY: 0, Z_BINARY: 0, Z_TEXT: 1, Z_UNKNOWN: 2, Z_DEFLATED: 8 };
1430
+ }, {}], 45: [function(e, t, r) {
1431
+ "use strict";
1432
+ var o = function() {
1433
+ for (var e2, t2 = [], r2 = 0; r2 < 256; r2++) {
1434
+ e2 = r2;
1435
+ for (var n = 0; n < 8; n++) e2 = 1 & e2 ? 3988292384 ^ e2 >>> 1 : e2 >>> 1;
1436
+ t2[r2] = e2;
1437
+ }
1438
+ return t2;
1439
+ }();
1440
+ t.exports = function(e2, t2, r2, n) {
1441
+ var i = o, s = n + r2;
1442
+ e2 ^= -1;
1443
+ for (var a = n; a < s; a++) e2 = e2 >>> 8 ^ i[255 & (e2 ^ t2[a])];
1444
+ return -1 ^ e2;
1445
+ };
1446
+ }, {}], 46: [function(e, t, r) {
1447
+ "use strict";
1448
+ var h, c = e("../utils/common"), u = e("./trees"), d = e("./adler32"), p = e("./crc32"), n = e("./messages"), l = 0, f = 4, m = 0, _ = -2, g = -1, b = 4, i = 2, v = 8, y = 9, s = 286, a = 30, o = 19, w = 2 * s + 1, k = 15, x = 3, S = 258, z = S + x + 1, C = 42, E = 113, A = 1, I = 2, O = 3, B = 4;
1449
+ function R(e2, t2) {
1450
+ return e2.msg = n[t2], t2;
1451
+ }
1452
+ function T(e2) {
1453
+ return (e2 << 1) - (4 < e2 ? 9 : 0);
1454
+ }
1455
+ function D(e2) {
1456
+ for (var t2 = e2.length; 0 <= --t2; ) e2[t2] = 0;
1457
+ }
1458
+ function F(e2) {
1459
+ var t2 = e2.state, r2 = t2.pending;
1460
+ r2 > e2.avail_out && (r2 = e2.avail_out), 0 !== r2 && (c.arraySet(e2.output, t2.pending_buf, t2.pending_out, r2, e2.next_out), e2.next_out += r2, t2.pending_out += r2, e2.total_out += r2, e2.avail_out -= r2, t2.pending -= r2, 0 === t2.pending && (t2.pending_out = 0));
1461
+ }
1462
+ function N(e2, t2) {
1463
+ u._tr_flush_block(e2, 0 <= e2.block_start ? e2.block_start : -1, e2.strstart - e2.block_start, t2), e2.block_start = e2.strstart, F(e2.strm);
1464
+ }
1465
+ function U(e2, t2) {
1466
+ e2.pending_buf[e2.pending++] = t2;
1467
+ }
1468
+ function P(e2, t2) {
1469
+ e2.pending_buf[e2.pending++] = t2 >>> 8 & 255, e2.pending_buf[e2.pending++] = 255 & t2;
1470
+ }
1471
+ function L(e2, t2) {
1472
+ var r2, n2, i2 = e2.max_chain_length, s2 = e2.strstart, a2 = e2.prev_length, o2 = e2.nice_match, h2 = e2.strstart > e2.w_size - z ? e2.strstart - (e2.w_size - z) : 0, u2 = e2.window, l2 = e2.w_mask, f2 = e2.prev, c2 = e2.strstart + S, d2 = u2[s2 + a2 - 1], p2 = u2[s2 + a2];
1473
+ e2.prev_length >= e2.good_match && (i2 >>= 2), o2 > e2.lookahead && (o2 = e2.lookahead);
1474
+ do {
1475
+ if (u2[(r2 = t2) + a2] === p2 && u2[r2 + a2 - 1] === d2 && u2[r2] === u2[s2] && u2[++r2] === u2[s2 + 1]) {
1476
+ s2 += 2, r2++;
1477
+ do {
1478
+ } while (u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && u2[++s2] === u2[++r2] && s2 < c2);
1479
+ if (n2 = S - (c2 - s2), s2 = c2 - S, a2 < n2) {
1480
+ if (e2.match_start = t2, o2 <= (a2 = n2)) break;
1481
+ d2 = u2[s2 + a2 - 1], p2 = u2[s2 + a2];
1482
+ }
1483
+ }
1484
+ } while ((t2 = f2[t2 & l2]) > h2 && 0 != --i2);
1485
+ return a2 <= e2.lookahead ? a2 : e2.lookahead;
1486
+ }
1487
+ function j(e2) {
1488
+ var t2, r2, n2, i2, s2, a2, o2, h2, u2, l2, f2 = e2.w_size;
1489
+ do {
1490
+ if (i2 = e2.window_size - e2.lookahead - e2.strstart, e2.strstart >= f2 + (f2 - z)) {
1491
+ for (c.arraySet(e2.window, e2.window, f2, f2, 0), e2.match_start -= f2, e2.strstart -= f2, e2.block_start -= f2, t2 = r2 = e2.hash_size; n2 = e2.head[--t2], e2.head[t2] = f2 <= n2 ? n2 - f2 : 0, --r2; ) ;
1492
+ for (t2 = r2 = f2; n2 = e2.prev[--t2], e2.prev[t2] = f2 <= n2 ? n2 - f2 : 0, --r2; ) ;
1493
+ i2 += f2;
1494
+ }
1495
+ if (0 === e2.strm.avail_in) break;
1496
+ if (a2 = e2.strm, o2 = e2.window, h2 = e2.strstart + e2.lookahead, u2 = i2, l2 = void 0, l2 = a2.avail_in, u2 < l2 && (l2 = u2), r2 = 0 === l2 ? 0 : (a2.avail_in -= l2, c.arraySet(o2, a2.input, a2.next_in, l2, h2), 1 === a2.state.wrap ? a2.adler = d(a2.adler, o2, l2, h2) : 2 === a2.state.wrap && (a2.adler = p(a2.adler, o2, l2, h2)), a2.next_in += l2, a2.total_in += l2, l2), e2.lookahead += r2, e2.lookahead + e2.insert >= x) for (s2 = e2.strstart - e2.insert, e2.ins_h = e2.window[s2], e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[s2 + 1]) & e2.hash_mask; e2.insert && (e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[s2 + x - 1]) & e2.hash_mask, e2.prev[s2 & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = s2, s2++, e2.insert--, !(e2.lookahead + e2.insert < x)); ) ;
1497
+ } while (e2.lookahead < z && 0 !== e2.strm.avail_in);
1498
+ }
1499
+ function Z(e2, t2) {
1500
+ for (var r2, n2; ; ) {
1501
+ if (e2.lookahead < z) {
1502
+ if (j(e2), e2.lookahead < z && t2 === l) return A;
1503
+ if (0 === e2.lookahead) break;
1504
+ }
1505
+ if (r2 = 0, e2.lookahead >= x && (e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + x - 1]) & e2.hash_mask, r2 = e2.prev[e2.strstart & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = e2.strstart), 0 !== r2 && e2.strstart - r2 <= e2.w_size - z && (e2.match_length = L(e2, r2)), e2.match_length >= x) if (n2 = u._tr_tally(e2, e2.strstart - e2.match_start, e2.match_length - x), e2.lookahead -= e2.match_length, e2.match_length <= e2.max_lazy_match && e2.lookahead >= x) {
1506
+ for (e2.match_length--; e2.strstart++, e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + x - 1]) & e2.hash_mask, r2 = e2.prev[e2.strstart & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = e2.strstart, 0 != --e2.match_length; ) ;
1507
+ e2.strstart++;
1508
+ } else e2.strstart += e2.match_length, e2.match_length = 0, e2.ins_h = e2.window[e2.strstart], e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + 1]) & e2.hash_mask;
1509
+ else n2 = u._tr_tally(e2, 0, e2.window[e2.strstart]), e2.lookahead--, e2.strstart++;
1510
+ if (n2 && (N(e2, false), 0 === e2.strm.avail_out)) return A;
1511
+ }
1512
+ return e2.insert = e2.strstart < x - 1 ? e2.strstart : x - 1, t2 === f ? (N(e2, true), 0 === e2.strm.avail_out ? O : B) : e2.last_lit && (N(e2, false), 0 === e2.strm.avail_out) ? A : I;
1513
+ }
1514
+ function W(e2, t2) {
1515
+ for (var r2, n2, i2; ; ) {
1516
+ if (e2.lookahead < z) {
1517
+ if (j(e2), e2.lookahead < z && t2 === l) return A;
1518
+ if (0 === e2.lookahead) break;
1519
+ }
1520
+ if (r2 = 0, e2.lookahead >= x && (e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + x - 1]) & e2.hash_mask, r2 = e2.prev[e2.strstart & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = e2.strstart), e2.prev_length = e2.match_length, e2.prev_match = e2.match_start, e2.match_length = x - 1, 0 !== r2 && e2.prev_length < e2.max_lazy_match && e2.strstart - r2 <= e2.w_size - z && (e2.match_length = L(e2, r2), e2.match_length <= 5 && (1 === e2.strategy || e2.match_length === x && 4096 < e2.strstart - e2.match_start) && (e2.match_length = x - 1)), e2.prev_length >= x && e2.match_length <= e2.prev_length) {
1521
+ for (i2 = e2.strstart + e2.lookahead - x, n2 = u._tr_tally(e2, e2.strstart - 1 - e2.prev_match, e2.prev_length - x), e2.lookahead -= e2.prev_length - 1, e2.prev_length -= 2; ++e2.strstart <= i2 && (e2.ins_h = (e2.ins_h << e2.hash_shift ^ e2.window[e2.strstart + x - 1]) & e2.hash_mask, r2 = e2.prev[e2.strstart & e2.w_mask] = e2.head[e2.ins_h], e2.head[e2.ins_h] = e2.strstart), 0 != --e2.prev_length; ) ;
1522
+ if (e2.match_available = 0, e2.match_length = x - 1, e2.strstart++, n2 && (N(e2, false), 0 === e2.strm.avail_out)) return A;
1523
+ } else if (e2.match_available) {
1524
+ if ((n2 = u._tr_tally(e2, 0, e2.window[e2.strstart - 1])) && N(e2, false), e2.strstart++, e2.lookahead--, 0 === e2.strm.avail_out) return A;
1525
+ } else e2.match_available = 1, e2.strstart++, e2.lookahead--;
1526
+ }
1527
+ return e2.match_available && (n2 = u._tr_tally(e2, 0, e2.window[e2.strstart - 1]), e2.match_available = 0), e2.insert = e2.strstart < x - 1 ? e2.strstart : x - 1, t2 === f ? (N(e2, true), 0 === e2.strm.avail_out ? O : B) : e2.last_lit && (N(e2, false), 0 === e2.strm.avail_out) ? A : I;
1528
+ }
1529
+ function M(e2, t2, r2, n2, i2) {
1530
+ this.good_length = e2, this.max_lazy = t2, this.nice_length = r2, this.max_chain = n2, this.func = i2;
1531
+ }
1532
+ function H() {
1533
+ this.strm = null, this.status = 0, this.pending_buf = null, this.pending_buf_size = 0, this.pending_out = 0, this.pending = 0, this.wrap = 0, this.gzhead = null, this.gzindex = 0, this.method = v, this.last_flush = -1, this.w_size = 0, this.w_bits = 0, this.w_mask = 0, this.window = null, this.window_size = 0, this.prev = null, this.head = null, this.ins_h = 0, this.hash_size = 0, this.hash_bits = 0, this.hash_mask = 0, this.hash_shift = 0, this.block_start = 0, this.match_length = 0, this.prev_match = 0, this.match_available = 0, this.strstart = 0, this.match_start = 0, this.lookahead = 0, this.prev_length = 0, this.max_chain_length = 0, this.max_lazy_match = 0, this.level = 0, this.strategy = 0, this.good_match = 0, this.nice_match = 0, this.dyn_ltree = new c.Buf16(2 * w), this.dyn_dtree = new c.Buf16(2 * (2 * a + 1)), this.bl_tree = new c.Buf16(2 * (2 * o + 1)), D(this.dyn_ltree), D(this.dyn_dtree), D(this.bl_tree), this.l_desc = null, this.d_desc = null, this.bl_desc = null, this.bl_count = new c.Buf16(k + 1), this.heap = new c.Buf16(2 * s + 1), D(this.heap), this.heap_len = 0, this.heap_max = 0, this.depth = new c.Buf16(2 * s + 1), D(this.depth), this.l_buf = 0, this.lit_bufsize = 0, this.last_lit = 0, this.d_buf = 0, this.opt_len = 0, this.static_len = 0, this.matches = 0, this.insert = 0, this.bi_buf = 0, this.bi_valid = 0;
1534
+ }
1535
+ function G(e2) {
1536
+ var t2;
1537
+ return e2 && e2.state ? (e2.total_in = e2.total_out = 0, e2.data_type = i, (t2 = e2.state).pending = 0, t2.pending_out = 0, t2.wrap < 0 && (t2.wrap = -t2.wrap), t2.status = t2.wrap ? C : E, e2.adler = 2 === t2.wrap ? 0 : 1, t2.last_flush = l, u._tr_init(t2), m) : R(e2, _);
1538
+ }
1539
+ function K(e2) {
1540
+ var t2 = G(e2);
1541
+ return t2 === m && function(e3) {
1542
+ e3.window_size = 2 * e3.w_size, D(e3.head), e3.max_lazy_match = h[e3.level].max_lazy, e3.good_match = h[e3.level].good_length, e3.nice_match = h[e3.level].nice_length, e3.max_chain_length = h[e3.level].max_chain, e3.strstart = 0, e3.block_start = 0, e3.lookahead = 0, e3.insert = 0, e3.match_length = e3.prev_length = x - 1, e3.match_available = 0, e3.ins_h = 0;
1543
+ }(e2.state), t2;
1544
+ }
1545
+ function Y(e2, t2, r2, n2, i2, s2) {
1546
+ if (!e2) return _;
1547
+ var a2 = 1;
1548
+ if (t2 === g && (t2 = 6), n2 < 0 ? (a2 = 0, n2 = -n2) : 15 < n2 && (a2 = 2, n2 -= 16), i2 < 1 || y < i2 || r2 !== v || n2 < 8 || 15 < n2 || t2 < 0 || 9 < t2 || s2 < 0 || b < s2) return R(e2, _);
1549
+ 8 === n2 && (n2 = 9);
1550
+ var o2 = new H();
1551
+ return (e2.state = o2).strm = e2, o2.wrap = a2, o2.gzhead = null, o2.w_bits = n2, o2.w_size = 1 << o2.w_bits, o2.w_mask = o2.w_size - 1, o2.hash_bits = i2 + 7, o2.hash_size = 1 << o2.hash_bits, o2.hash_mask = o2.hash_size - 1, o2.hash_shift = ~~((o2.hash_bits + x - 1) / x), o2.window = new c.Buf8(2 * o2.w_size), o2.head = new c.Buf16(o2.hash_size), o2.prev = new c.Buf16(o2.w_size), o2.lit_bufsize = 1 << i2 + 6, o2.pending_buf_size = 4 * o2.lit_bufsize, o2.pending_buf = new c.Buf8(o2.pending_buf_size), o2.d_buf = 1 * o2.lit_bufsize, o2.l_buf = 3 * o2.lit_bufsize, o2.level = t2, o2.strategy = s2, o2.method = r2, K(e2);
1552
+ }
1553
+ h = [new M(0, 0, 0, 0, function(e2, t2) {
1554
+ var r2 = 65535;
1555
+ for (r2 > e2.pending_buf_size - 5 && (r2 = e2.pending_buf_size - 5); ; ) {
1556
+ if (e2.lookahead <= 1) {
1557
+ if (j(e2), 0 === e2.lookahead && t2 === l) return A;
1558
+ if (0 === e2.lookahead) break;
1559
+ }
1560
+ e2.strstart += e2.lookahead, e2.lookahead = 0;
1561
+ var n2 = e2.block_start + r2;
1562
+ if ((0 === e2.strstart || e2.strstart >= n2) && (e2.lookahead = e2.strstart - n2, e2.strstart = n2, N(e2, false), 0 === e2.strm.avail_out)) return A;
1563
+ if (e2.strstart - e2.block_start >= e2.w_size - z && (N(e2, false), 0 === e2.strm.avail_out)) return A;
1564
+ }
1565
+ return e2.insert = 0, t2 === f ? (N(e2, true), 0 === e2.strm.avail_out ? O : B) : (e2.strstart > e2.block_start && (N(e2, false), e2.strm.avail_out), A);
1566
+ }), new M(4, 4, 8, 4, Z), new M(4, 5, 16, 8, Z), new M(4, 6, 32, 32, Z), new M(4, 4, 16, 16, W), new M(8, 16, 32, 32, W), new M(8, 16, 128, 128, W), new M(8, 32, 128, 256, W), new M(32, 128, 258, 1024, W), new M(32, 258, 258, 4096, W)], r.deflateInit = function(e2, t2) {
1567
+ return Y(e2, t2, v, 15, 8, 0);
1568
+ }, r.deflateInit2 = Y, r.deflateReset = K, r.deflateResetKeep = G, r.deflateSetHeader = function(e2, t2) {
1569
+ return e2 && e2.state ? 2 !== e2.state.wrap ? _ : (e2.state.gzhead = t2, m) : _;
1570
+ }, r.deflate = function(e2, t2) {
1571
+ var r2, n2, i2, s2;
1572
+ if (!e2 || !e2.state || 5 < t2 || t2 < 0) return e2 ? R(e2, _) : _;
1573
+ if (n2 = e2.state, !e2.output || !e2.input && 0 !== e2.avail_in || 666 === n2.status && t2 !== f) return R(e2, 0 === e2.avail_out ? -5 : _);
1574
+ if (n2.strm = e2, r2 = n2.last_flush, n2.last_flush = t2, n2.status === C) if (2 === n2.wrap) e2.adler = 0, U(n2, 31), U(n2, 139), U(n2, 8), n2.gzhead ? (U(n2, (n2.gzhead.text ? 1 : 0) + (n2.gzhead.hcrc ? 2 : 0) + (n2.gzhead.extra ? 4 : 0) + (n2.gzhead.name ? 8 : 0) + (n2.gzhead.comment ? 16 : 0)), U(n2, 255 & n2.gzhead.time), U(n2, n2.gzhead.time >> 8 & 255), U(n2, n2.gzhead.time >> 16 & 255), U(n2, n2.gzhead.time >> 24 & 255), U(n2, 9 === n2.level ? 2 : 2 <= n2.strategy || n2.level < 2 ? 4 : 0), U(n2, 255 & n2.gzhead.os), n2.gzhead.extra && n2.gzhead.extra.length && (U(n2, 255 & n2.gzhead.extra.length), U(n2, n2.gzhead.extra.length >> 8 & 255)), n2.gzhead.hcrc && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending, 0)), n2.gzindex = 0, n2.status = 69) : (U(n2, 0), U(n2, 0), U(n2, 0), U(n2, 0), U(n2, 0), U(n2, 9 === n2.level ? 2 : 2 <= n2.strategy || n2.level < 2 ? 4 : 0), U(n2, 3), n2.status = E);
1575
+ else {
1576
+ var a2 = v + (n2.w_bits - 8 << 4) << 8;
1577
+ a2 |= (2 <= n2.strategy || n2.level < 2 ? 0 : n2.level < 6 ? 1 : 6 === n2.level ? 2 : 3) << 6, 0 !== n2.strstart && (a2 |= 32), a2 += 31 - a2 % 31, n2.status = E, P(n2, a2), 0 !== n2.strstart && (P(n2, e2.adler >>> 16), P(n2, 65535 & e2.adler)), e2.adler = 1;
1578
+ }
1579
+ if (69 === n2.status) if (n2.gzhead.extra) {
1580
+ for (i2 = n2.pending; n2.gzindex < (65535 & n2.gzhead.extra.length) && (n2.pending !== n2.pending_buf_size || (n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), F(e2), i2 = n2.pending, n2.pending !== n2.pending_buf_size)); ) U(n2, 255 & n2.gzhead.extra[n2.gzindex]), n2.gzindex++;
1581
+ n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), n2.gzindex === n2.gzhead.extra.length && (n2.gzindex = 0, n2.status = 73);
1582
+ } else n2.status = 73;
1583
+ if (73 === n2.status) if (n2.gzhead.name) {
1584
+ i2 = n2.pending;
1585
+ do {
1586
+ if (n2.pending === n2.pending_buf_size && (n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), F(e2), i2 = n2.pending, n2.pending === n2.pending_buf_size)) {
1587
+ s2 = 1;
1588
+ break;
1589
+ }
1590
+ s2 = n2.gzindex < n2.gzhead.name.length ? 255 & n2.gzhead.name.charCodeAt(n2.gzindex++) : 0, U(n2, s2);
1591
+ } while (0 !== s2);
1592
+ n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), 0 === s2 && (n2.gzindex = 0, n2.status = 91);
1593
+ } else n2.status = 91;
1594
+ if (91 === n2.status) if (n2.gzhead.comment) {
1595
+ i2 = n2.pending;
1596
+ do {
1597
+ if (n2.pending === n2.pending_buf_size && (n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), F(e2), i2 = n2.pending, n2.pending === n2.pending_buf_size)) {
1598
+ s2 = 1;
1599
+ break;
1600
+ }
1601
+ s2 = n2.gzindex < n2.gzhead.comment.length ? 255 & n2.gzhead.comment.charCodeAt(n2.gzindex++) : 0, U(n2, s2);
1602
+ } while (0 !== s2);
1603
+ n2.gzhead.hcrc && n2.pending > i2 && (e2.adler = p(e2.adler, n2.pending_buf, n2.pending - i2, i2)), 0 === s2 && (n2.status = 103);
1604
+ } else n2.status = 103;
1605
+ if (103 === n2.status && (n2.gzhead.hcrc ? (n2.pending + 2 > n2.pending_buf_size && F(e2), n2.pending + 2 <= n2.pending_buf_size && (U(n2, 255 & e2.adler), U(n2, e2.adler >> 8 & 255), e2.adler = 0, n2.status = E)) : n2.status = E), 0 !== n2.pending) {
1606
+ if (F(e2), 0 === e2.avail_out) return n2.last_flush = -1, m;
1607
+ } else if (0 === e2.avail_in && T(t2) <= T(r2) && t2 !== f) return R(e2, -5);
1608
+ if (666 === n2.status && 0 !== e2.avail_in) return R(e2, -5);
1609
+ if (0 !== e2.avail_in || 0 !== n2.lookahead || t2 !== l && 666 !== n2.status) {
1610
+ var o2 = 2 === n2.strategy ? function(e3, t3) {
1611
+ for (var r3; ; ) {
1612
+ if (0 === e3.lookahead && (j(e3), 0 === e3.lookahead)) {
1613
+ if (t3 === l) return A;
1614
+ break;
1615
+ }
1616
+ if (e3.match_length = 0, r3 = u._tr_tally(e3, 0, e3.window[e3.strstart]), e3.lookahead--, e3.strstart++, r3 && (N(e3, false), 0 === e3.strm.avail_out)) return A;
1617
+ }
1618
+ return e3.insert = 0, t3 === f ? (N(e3, true), 0 === e3.strm.avail_out ? O : B) : e3.last_lit && (N(e3, false), 0 === e3.strm.avail_out) ? A : I;
1619
+ }(n2, t2) : 3 === n2.strategy ? function(e3, t3) {
1620
+ for (var r3, n3, i3, s3, a3 = e3.window; ; ) {
1621
+ if (e3.lookahead <= S) {
1622
+ if (j(e3), e3.lookahead <= S && t3 === l) return A;
1623
+ if (0 === e3.lookahead) break;
1624
+ }
1625
+ if (e3.match_length = 0, e3.lookahead >= x && 0 < e3.strstart && (n3 = a3[i3 = e3.strstart - 1]) === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3]) {
1626
+ s3 = e3.strstart + S;
1627
+ do {
1628
+ } while (n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && n3 === a3[++i3] && i3 < s3);
1629
+ e3.match_length = S - (s3 - i3), e3.match_length > e3.lookahead && (e3.match_length = e3.lookahead);
1630
+ }
1631
+ if (e3.match_length >= x ? (r3 = u._tr_tally(e3, 1, e3.match_length - x), e3.lookahead -= e3.match_length, e3.strstart += e3.match_length, e3.match_length = 0) : (r3 = u._tr_tally(e3, 0, e3.window[e3.strstart]), e3.lookahead--, e3.strstart++), r3 && (N(e3, false), 0 === e3.strm.avail_out)) return A;
1632
+ }
1633
+ return e3.insert = 0, t3 === f ? (N(e3, true), 0 === e3.strm.avail_out ? O : B) : e3.last_lit && (N(e3, false), 0 === e3.strm.avail_out) ? A : I;
1634
+ }(n2, t2) : h[n2.level].func(n2, t2);
1635
+ if (o2 !== O && o2 !== B || (n2.status = 666), o2 === A || o2 === O) return 0 === e2.avail_out && (n2.last_flush = -1), m;
1636
+ if (o2 === I && (1 === t2 ? u._tr_align(n2) : 5 !== t2 && (u._tr_stored_block(n2, 0, 0, false), 3 === t2 && (D(n2.head), 0 === n2.lookahead && (n2.strstart = 0, n2.block_start = 0, n2.insert = 0))), F(e2), 0 === e2.avail_out)) return n2.last_flush = -1, m;
1637
+ }
1638
+ return t2 !== f ? m : n2.wrap <= 0 ? 1 : (2 === n2.wrap ? (U(n2, 255 & e2.adler), U(n2, e2.adler >> 8 & 255), U(n2, e2.adler >> 16 & 255), U(n2, e2.adler >> 24 & 255), U(n2, 255 & e2.total_in), U(n2, e2.total_in >> 8 & 255), U(n2, e2.total_in >> 16 & 255), U(n2, e2.total_in >> 24 & 255)) : (P(n2, e2.adler >>> 16), P(n2, 65535 & e2.adler)), F(e2), 0 < n2.wrap && (n2.wrap = -n2.wrap), 0 !== n2.pending ? m : 1);
1639
+ }, r.deflateEnd = function(e2) {
1640
+ var t2;
1641
+ return e2 && e2.state ? (t2 = e2.state.status) !== C && 69 !== t2 && 73 !== t2 && 91 !== t2 && 103 !== t2 && t2 !== E && 666 !== t2 ? R(e2, _) : (e2.state = null, t2 === E ? R(e2, -3) : m) : _;
1642
+ }, r.deflateSetDictionary = function(e2, t2) {
1643
+ var r2, n2, i2, s2, a2, o2, h2, u2, l2 = t2.length;
1644
+ if (!e2 || !e2.state) return _;
1645
+ if (2 === (s2 = (r2 = e2.state).wrap) || 1 === s2 && r2.status !== C || r2.lookahead) return _;
1646
+ for (1 === s2 && (e2.adler = d(e2.adler, t2, l2, 0)), r2.wrap = 0, l2 >= r2.w_size && (0 === s2 && (D(r2.head), r2.strstart = 0, r2.block_start = 0, r2.insert = 0), u2 = new c.Buf8(r2.w_size), c.arraySet(u2, t2, l2 - r2.w_size, r2.w_size, 0), t2 = u2, l2 = r2.w_size), a2 = e2.avail_in, o2 = e2.next_in, h2 = e2.input, e2.avail_in = l2, e2.next_in = 0, e2.input = t2, j(r2); r2.lookahead >= x; ) {
1647
+ for (n2 = r2.strstart, i2 = r2.lookahead - (x - 1); r2.ins_h = (r2.ins_h << r2.hash_shift ^ r2.window[n2 + x - 1]) & r2.hash_mask, r2.prev[n2 & r2.w_mask] = r2.head[r2.ins_h], r2.head[r2.ins_h] = n2, n2++, --i2; ) ;
1648
+ r2.strstart = n2, r2.lookahead = x - 1, j(r2);
1649
+ }
1650
+ return r2.strstart += r2.lookahead, r2.block_start = r2.strstart, r2.insert = r2.lookahead, r2.lookahead = 0, r2.match_length = r2.prev_length = x - 1, r2.match_available = 0, e2.next_in = o2, e2.input = h2, e2.avail_in = a2, r2.wrap = s2, m;
1651
+ }, r.deflateInfo = "pako deflate (from Nodeca project)";
1652
+ }, { "../utils/common": 41, "./adler32": 43, "./crc32": 45, "./messages": 51, "./trees": 52 }], 47: [function(e, t, r) {
1653
+ "use strict";
1654
+ t.exports = function() {
1655
+ this.text = 0, this.time = 0, this.xflags = 0, this.os = 0, this.extra = null, this.extra_len = 0, this.name = "", this.comment = "", this.hcrc = 0, this.done = false;
1656
+ };
1657
+ }, {}], 48: [function(e, t, r) {
1658
+ "use strict";
1659
+ t.exports = function(e2, t2) {
1660
+ var r2, n, i, s, a, o, h, u, l, f, c, d, p, m, _, g, b, v, y, w, k, x, S, z, C;
1661
+ r2 = e2.state, n = e2.next_in, z = e2.input, i = n + (e2.avail_in - 5), s = e2.next_out, C = e2.output, a = s - (t2 - e2.avail_out), o = s + (e2.avail_out - 257), h = r2.dmax, u = r2.wsize, l = r2.whave, f = r2.wnext, c = r2.window, d = r2.hold, p = r2.bits, m = r2.lencode, _ = r2.distcode, g = (1 << r2.lenbits) - 1, b = (1 << r2.distbits) - 1;
1662
+ e: do {
1663
+ p < 15 && (d += z[n++] << p, p += 8, d += z[n++] << p, p += 8), v = m[d & g];
1664
+ t: for (; ; ) {
1665
+ if (d >>>= y = v >>> 24, p -= y, 0 === (y = v >>> 16 & 255)) C[s++] = 65535 & v;
1666
+ else {
1667
+ if (!(16 & y)) {
1668
+ if (0 == (64 & y)) {
1669
+ v = m[(65535 & v) + (d & (1 << y) - 1)];
1670
+ continue t;
1671
+ }
1672
+ if (32 & y) {
1673
+ r2.mode = 12;
1674
+ break e;
1675
+ }
1676
+ e2.msg = "invalid literal/length code", r2.mode = 30;
1677
+ break e;
1678
+ }
1679
+ w = 65535 & v, (y &= 15) && (p < y && (d += z[n++] << p, p += 8), w += d & (1 << y) - 1, d >>>= y, p -= y), p < 15 && (d += z[n++] << p, p += 8, d += z[n++] << p, p += 8), v = _[d & b];
1680
+ r: for (; ; ) {
1681
+ if (d >>>= y = v >>> 24, p -= y, !(16 & (y = v >>> 16 & 255))) {
1682
+ if (0 == (64 & y)) {
1683
+ v = _[(65535 & v) + (d & (1 << y) - 1)];
1684
+ continue r;
1685
+ }
1686
+ e2.msg = "invalid distance code", r2.mode = 30;
1687
+ break e;
1688
+ }
1689
+ if (k = 65535 & v, p < (y &= 15) && (d += z[n++] << p, (p += 8) < y && (d += z[n++] << p, p += 8)), h < (k += d & (1 << y) - 1)) {
1690
+ e2.msg = "invalid distance too far back", r2.mode = 30;
1691
+ break e;
1692
+ }
1693
+ if (d >>>= y, p -= y, (y = s - a) < k) {
1694
+ if (l < (y = k - y) && r2.sane) {
1695
+ e2.msg = "invalid distance too far back", r2.mode = 30;
1696
+ break e;
1697
+ }
1698
+ if (S = c, (x = 0) === f) {
1699
+ if (x += u - y, y < w) {
1700
+ for (w -= y; C[s++] = c[x++], --y; ) ;
1701
+ x = s - k, S = C;
1702
+ }
1703
+ } else if (f < y) {
1704
+ if (x += u + f - y, (y -= f) < w) {
1705
+ for (w -= y; C[s++] = c[x++], --y; ) ;
1706
+ if (x = 0, f < w) {
1707
+ for (w -= y = f; C[s++] = c[x++], --y; ) ;
1708
+ x = s - k, S = C;
1709
+ }
1710
+ }
1711
+ } else if (x += f - y, y < w) {
1712
+ for (w -= y; C[s++] = c[x++], --y; ) ;
1713
+ x = s - k, S = C;
1714
+ }
1715
+ for (; 2 < w; ) C[s++] = S[x++], C[s++] = S[x++], C[s++] = S[x++], w -= 3;
1716
+ w && (C[s++] = S[x++], 1 < w && (C[s++] = S[x++]));
1717
+ } else {
1718
+ for (x = s - k; C[s++] = C[x++], C[s++] = C[x++], C[s++] = C[x++], 2 < (w -= 3); ) ;
1719
+ w && (C[s++] = C[x++], 1 < w && (C[s++] = C[x++]));
1720
+ }
1721
+ break;
1722
+ }
1723
+ }
1724
+ break;
1725
+ }
1726
+ } while (n < i && s < o);
1727
+ n -= w = p >> 3, d &= (1 << (p -= w << 3)) - 1, e2.next_in = n, e2.next_out = s, e2.avail_in = n < i ? i - n + 5 : 5 - (n - i), e2.avail_out = s < o ? o - s + 257 : 257 - (s - o), r2.hold = d, r2.bits = p;
1728
+ };
1729
+ }, {}], 49: [function(e, t, r) {
1730
+ "use strict";
1731
+ var I = e("../utils/common"), O = e("./adler32"), B = e("./crc32"), R = e("./inffast"), T = e("./inftrees"), D = 1, F = 2, N = 0, U = -2, P = 1, n = 852, i = 592;
1732
+ function L(e2) {
1733
+ return (e2 >>> 24 & 255) + (e2 >>> 8 & 65280) + ((65280 & e2) << 8) + ((255 & e2) << 24);
1734
+ }
1735
+ function s() {
1736
+ this.mode = 0, this.last = false, this.wrap = 0, this.havedict = false, this.flags = 0, this.dmax = 0, this.check = 0, this.total = 0, this.head = null, this.wbits = 0, this.wsize = 0, this.whave = 0, this.wnext = 0, this.window = null, this.hold = 0, this.bits = 0, this.length = 0, this.offset = 0, this.extra = 0, this.lencode = null, this.distcode = null, this.lenbits = 0, this.distbits = 0, this.ncode = 0, this.nlen = 0, this.ndist = 0, this.have = 0, this.next = null, this.lens = new I.Buf16(320), this.work = new I.Buf16(288), this.lendyn = null, this.distdyn = null, this.sane = 0, this.back = 0, this.was = 0;
1737
+ }
1738
+ function a(e2) {
1739
+ var t2;
1740
+ return e2 && e2.state ? (t2 = e2.state, e2.total_in = e2.total_out = t2.total = 0, e2.msg = "", t2.wrap && (e2.adler = 1 & t2.wrap), t2.mode = P, t2.last = 0, t2.havedict = 0, t2.dmax = 32768, t2.head = null, t2.hold = 0, t2.bits = 0, t2.lencode = t2.lendyn = new I.Buf32(n), t2.distcode = t2.distdyn = new I.Buf32(i), t2.sane = 1, t2.back = -1, N) : U;
1741
+ }
1742
+ function o(e2) {
1743
+ var t2;
1744
+ return e2 && e2.state ? ((t2 = e2.state).wsize = 0, t2.whave = 0, t2.wnext = 0, a(e2)) : U;
1745
+ }
1746
+ function h(e2, t2) {
1747
+ var r2, n2;
1748
+ return e2 && e2.state ? (n2 = e2.state, t2 < 0 ? (r2 = 0, t2 = -t2) : (r2 = 1 + (t2 >> 4), t2 < 48 && (t2 &= 15)), t2 && (t2 < 8 || 15 < t2) ? U : (null !== n2.window && n2.wbits !== t2 && (n2.window = null), n2.wrap = r2, n2.wbits = t2, o(e2))) : U;
1749
+ }
1750
+ function u(e2, t2) {
1751
+ var r2, n2;
1752
+ return e2 ? (n2 = new s(), (e2.state = n2).window = null, (r2 = h(e2, t2)) !== N && (e2.state = null), r2) : U;
1753
+ }
1754
+ var l, f, c = true;
1755
+ function j(e2) {
1756
+ if (c) {
1757
+ var t2;
1758
+ for (l = new I.Buf32(512), f = new I.Buf32(32), t2 = 0; t2 < 144; ) e2.lens[t2++] = 8;
1759
+ for (; t2 < 256; ) e2.lens[t2++] = 9;
1760
+ for (; t2 < 280; ) e2.lens[t2++] = 7;
1761
+ for (; t2 < 288; ) e2.lens[t2++] = 8;
1762
+ for (T(D, e2.lens, 0, 288, l, 0, e2.work, { bits: 9 }), t2 = 0; t2 < 32; ) e2.lens[t2++] = 5;
1763
+ T(F, e2.lens, 0, 32, f, 0, e2.work, { bits: 5 }), c = false;
1764
+ }
1765
+ e2.lencode = l, e2.lenbits = 9, e2.distcode = f, e2.distbits = 5;
1766
+ }
1767
+ function Z(e2, t2, r2, n2) {
1768
+ var i2, s2 = e2.state;
1769
+ return null === s2.window && (s2.wsize = 1 << s2.wbits, s2.wnext = 0, s2.whave = 0, s2.window = new I.Buf8(s2.wsize)), n2 >= s2.wsize ? (I.arraySet(s2.window, t2, r2 - s2.wsize, s2.wsize, 0), s2.wnext = 0, s2.whave = s2.wsize) : (n2 < (i2 = s2.wsize - s2.wnext) && (i2 = n2), I.arraySet(s2.window, t2, r2 - n2, i2, s2.wnext), (n2 -= i2) ? (I.arraySet(s2.window, t2, r2 - n2, n2, 0), s2.wnext = n2, s2.whave = s2.wsize) : (s2.wnext += i2, s2.wnext === s2.wsize && (s2.wnext = 0), s2.whave < s2.wsize && (s2.whave += i2))), 0;
1770
+ }
1771
+ r.inflateReset = o, r.inflateReset2 = h, r.inflateResetKeep = a, r.inflateInit = function(e2) {
1772
+ return u(e2, 15);
1773
+ }, r.inflateInit2 = u, r.inflate = function(e2, t2) {
1774
+ var r2, n2, i2, s2, a2, o2, h2, u2, l2, f2, c2, d, p, m, _, g, b, v, y, w, k, x, S, z, C = 0, E = new I.Buf8(4), A = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15];
1775
+ if (!e2 || !e2.state || !e2.output || !e2.input && 0 !== e2.avail_in) return U;
1776
+ 12 === (r2 = e2.state).mode && (r2.mode = 13), a2 = e2.next_out, i2 = e2.output, h2 = e2.avail_out, s2 = e2.next_in, n2 = e2.input, o2 = e2.avail_in, u2 = r2.hold, l2 = r2.bits, f2 = o2, c2 = h2, x = N;
1777
+ e: for (; ; ) switch (r2.mode) {
1778
+ case P:
1779
+ if (0 === r2.wrap) {
1780
+ r2.mode = 13;
1781
+ break;
1782
+ }
1783
+ for (; l2 < 16; ) {
1784
+ if (0 === o2) break e;
1785
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1786
+ }
1787
+ if (2 & r2.wrap && 35615 === u2) {
1788
+ E[r2.check = 0] = 255 & u2, E[1] = u2 >>> 8 & 255, r2.check = B(r2.check, E, 2, 0), l2 = u2 = 0, r2.mode = 2;
1789
+ break;
1790
+ }
1791
+ if (r2.flags = 0, r2.head && (r2.head.done = false), !(1 & r2.wrap) || (((255 & u2) << 8) + (u2 >> 8)) % 31) {
1792
+ e2.msg = "incorrect header check", r2.mode = 30;
1793
+ break;
1794
+ }
1795
+ if (8 != (15 & u2)) {
1796
+ e2.msg = "unknown compression method", r2.mode = 30;
1797
+ break;
1798
+ }
1799
+ if (l2 -= 4, k = 8 + (15 & (u2 >>>= 4)), 0 === r2.wbits) r2.wbits = k;
1800
+ else if (k > r2.wbits) {
1801
+ e2.msg = "invalid window size", r2.mode = 30;
1802
+ break;
1803
+ }
1804
+ r2.dmax = 1 << k, e2.adler = r2.check = 1, r2.mode = 512 & u2 ? 10 : 12, l2 = u2 = 0;
1805
+ break;
1806
+ case 2:
1807
+ for (; l2 < 16; ) {
1808
+ if (0 === o2) break e;
1809
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1810
+ }
1811
+ if (r2.flags = u2, 8 != (255 & r2.flags)) {
1812
+ e2.msg = "unknown compression method", r2.mode = 30;
1813
+ break;
1814
+ }
1815
+ if (57344 & r2.flags) {
1816
+ e2.msg = "unknown header flags set", r2.mode = 30;
1817
+ break;
1818
+ }
1819
+ r2.head && (r2.head.text = u2 >> 8 & 1), 512 & r2.flags && (E[0] = 255 & u2, E[1] = u2 >>> 8 & 255, r2.check = B(r2.check, E, 2, 0)), l2 = u2 = 0, r2.mode = 3;
1820
+ case 3:
1821
+ for (; l2 < 32; ) {
1822
+ if (0 === o2) break e;
1823
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1824
+ }
1825
+ r2.head && (r2.head.time = u2), 512 & r2.flags && (E[0] = 255 & u2, E[1] = u2 >>> 8 & 255, E[2] = u2 >>> 16 & 255, E[3] = u2 >>> 24 & 255, r2.check = B(r2.check, E, 4, 0)), l2 = u2 = 0, r2.mode = 4;
1826
+ case 4:
1827
+ for (; l2 < 16; ) {
1828
+ if (0 === o2) break e;
1829
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1830
+ }
1831
+ r2.head && (r2.head.xflags = 255 & u2, r2.head.os = u2 >> 8), 512 & r2.flags && (E[0] = 255 & u2, E[1] = u2 >>> 8 & 255, r2.check = B(r2.check, E, 2, 0)), l2 = u2 = 0, r2.mode = 5;
1832
+ case 5:
1833
+ if (1024 & r2.flags) {
1834
+ for (; l2 < 16; ) {
1835
+ if (0 === o2) break e;
1836
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1837
+ }
1838
+ r2.length = u2, r2.head && (r2.head.extra_len = u2), 512 & r2.flags && (E[0] = 255 & u2, E[1] = u2 >>> 8 & 255, r2.check = B(r2.check, E, 2, 0)), l2 = u2 = 0;
1839
+ } else r2.head && (r2.head.extra = null);
1840
+ r2.mode = 6;
1841
+ case 6:
1842
+ if (1024 & r2.flags && (o2 < (d = r2.length) && (d = o2), d && (r2.head && (k = r2.head.extra_len - r2.length, r2.head.extra || (r2.head.extra = new Array(r2.head.extra_len)), I.arraySet(r2.head.extra, n2, s2, d, k)), 512 & r2.flags && (r2.check = B(r2.check, n2, d, s2)), o2 -= d, s2 += d, r2.length -= d), r2.length)) break e;
1843
+ r2.length = 0, r2.mode = 7;
1844
+ case 7:
1845
+ if (2048 & r2.flags) {
1846
+ if (0 === o2) break e;
1847
+ for (d = 0; k = n2[s2 + d++], r2.head && k && r2.length < 65536 && (r2.head.name += String.fromCharCode(k)), k && d < o2; ) ;
1848
+ if (512 & r2.flags && (r2.check = B(r2.check, n2, d, s2)), o2 -= d, s2 += d, k) break e;
1849
+ } else r2.head && (r2.head.name = null);
1850
+ r2.length = 0, r2.mode = 8;
1851
+ case 8:
1852
+ if (4096 & r2.flags) {
1853
+ if (0 === o2) break e;
1854
+ for (d = 0; k = n2[s2 + d++], r2.head && k && r2.length < 65536 && (r2.head.comment += String.fromCharCode(k)), k && d < o2; ) ;
1855
+ if (512 & r2.flags && (r2.check = B(r2.check, n2, d, s2)), o2 -= d, s2 += d, k) break e;
1856
+ } else r2.head && (r2.head.comment = null);
1857
+ r2.mode = 9;
1858
+ case 9:
1859
+ if (512 & r2.flags) {
1860
+ for (; l2 < 16; ) {
1861
+ if (0 === o2) break e;
1862
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1863
+ }
1864
+ if (u2 !== (65535 & r2.check)) {
1865
+ e2.msg = "header crc mismatch", r2.mode = 30;
1866
+ break;
1867
+ }
1868
+ l2 = u2 = 0;
1869
+ }
1870
+ r2.head && (r2.head.hcrc = r2.flags >> 9 & 1, r2.head.done = true), e2.adler = r2.check = 0, r2.mode = 12;
1871
+ break;
1872
+ case 10:
1873
+ for (; l2 < 32; ) {
1874
+ if (0 === o2) break e;
1875
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1876
+ }
1877
+ e2.adler = r2.check = L(u2), l2 = u2 = 0, r2.mode = 11;
1878
+ case 11:
1879
+ if (0 === r2.havedict) return e2.next_out = a2, e2.avail_out = h2, e2.next_in = s2, e2.avail_in = o2, r2.hold = u2, r2.bits = l2, 2;
1880
+ e2.adler = r2.check = 1, r2.mode = 12;
1881
+ case 12:
1882
+ if (5 === t2 || 6 === t2) break e;
1883
+ case 13:
1884
+ if (r2.last) {
1885
+ u2 >>>= 7 & l2, l2 -= 7 & l2, r2.mode = 27;
1886
+ break;
1887
+ }
1888
+ for (; l2 < 3; ) {
1889
+ if (0 === o2) break e;
1890
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1891
+ }
1892
+ switch (r2.last = 1 & u2, l2 -= 1, 3 & (u2 >>>= 1)) {
1893
+ case 0:
1894
+ r2.mode = 14;
1895
+ break;
1896
+ case 1:
1897
+ if (j(r2), r2.mode = 20, 6 !== t2) break;
1898
+ u2 >>>= 2, l2 -= 2;
1899
+ break e;
1900
+ case 2:
1901
+ r2.mode = 17;
1902
+ break;
1903
+ case 3:
1904
+ e2.msg = "invalid block type", r2.mode = 30;
1905
+ }
1906
+ u2 >>>= 2, l2 -= 2;
1907
+ break;
1908
+ case 14:
1909
+ for (u2 >>>= 7 & l2, l2 -= 7 & l2; l2 < 32; ) {
1910
+ if (0 === o2) break e;
1911
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1912
+ }
1913
+ if ((65535 & u2) != (u2 >>> 16 ^ 65535)) {
1914
+ e2.msg = "invalid stored block lengths", r2.mode = 30;
1915
+ break;
1916
+ }
1917
+ if (r2.length = 65535 & u2, l2 = u2 = 0, r2.mode = 15, 6 === t2) break e;
1918
+ case 15:
1919
+ r2.mode = 16;
1920
+ case 16:
1921
+ if (d = r2.length) {
1922
+ if (o2 < d && (d = o2), h2 < d && (d = h2), 0 === d) break e;
1923
+ I.arraySet(i2, n2, s2, d, a2), o2 -= d, s2 += d, h2 -= d, a2 += d, r2.length -= d;
1924
+ break;
1925
+ }
1926
+ r2.mode = 12;
1927
+ break;
1928
+ case 17:
1929
+ for (; l2 < 14; ) {
1930
+ if (0 === o2) break e;
1931
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1932
+ }
1933
+ if (r2.nlen = 257 + (31 & u2), u2 >>>= 5, l2 -= 5, r2.ndist = 1 + (31 & u2), u2 >>>= 5, l2 -= 5, r2.ncode = 4 + (15 & u2), u2 >>>= 4, l2 -= 4, 286 < r2.nlen || 30 < r2.ndist) {
1934
+ e2.msg = "too many length or distance symbols", r2.mode = 30;
1935
+ break;
1936
+ }
1937
+ r2.have = 0, r2.mode = 18;
1938
+ case 18:
1939
+ for (; r2.have < r2.ncode; ) {
1940
+ for (; l2 < 3; ) {
1941
+ if (0 === o2) break e;
1942
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1943
+ }
1944
+ r2.lens[A[r2.have++]] = 7 & u2, u2 >>>= 3, l2 -= 3;
1945
+ }
1946
+ for (; r2.have < 19; ) r2.lens[A[r2.have++]] = 0;
1947
+ if (r2.lencode = r2.lendyn, r2.lenbits = 7, S = { bits: r2.lenbits }, x = T(0, r2.lens, 0, 19, r2.lencode, 0, r2.work, S), r2.lenbits = S.bits, x) {
1948
+ e2.msg = "invalid code lengths set", r2.mode = 30;
1949
+ break;
1950
+ }
1951
+ r2.have = 0, r2.mode = 19;
1952
+ case 19:
1953
+ for (; r2.have < r2.nlen + r2.ndist; ) {
1954
+ for (; g = (C = r2.lencode[u2 & (1 << r2.lenbits) - 1]) >>> 16 & 255, b = 65535 & C, !((_ = C >>> 24) <= l2); ) {
1955
+ if (0 === o2) break e;
1956
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1957
+ }
1958
+ if (b < 16) u2 >>>= _, l2 -= _, r2.lens[r2.have++] = b;
1959
+ else {
1960
+ if (16 === b) {
1961
+ for (z = _ + 2; l2 < z; ) {
1962
+ if (0 === o2) break e;
1963
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1964
+ }
1965
+ if (u2 >>>= _, l2 -= _, 0 === r2.have) {
1966
+ e2.msg = "invalid bit length repeat", r2.mode = 30;
1967
+ break;
1968
+ }
1969
+ k = r2.lens[r2.have - 1], d = 3 + (3 & u2), u2 >>>= 2, l2 -= 2;
1970
+ } else if (17 === b) {
1971
+ for (z = _ + 3; l2 < z; ) {
1972
+ if (0 === o2) break e;
1973
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1974
+ }
1975
+ l2 -= _, k = 0, d = 3 + (7 & (u2 >>>= _)), u2 >>>= 3, l2 -= 3;
1976
+ } else {
1977
+ for (z = _ + 7; l2 < z; ) {
1978
+ if (0 === o2) break e;
1979
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
1980
+ }
1981
+ l2 -= _, k = 0, d = 11 + (127 & (u2 >>>= _)), u2 >>>= 7, l2 -= 7;
1982
+ }
1983
+ if (r2.have + d > r2.nlen + r2.ndist) {
1984
+ e2.msg = "invalid bit length repeat", r2.mode = 30;
1985
+ break;
1986
+ }
1987
+ for (; d--; ) r2.lens[r2.have++] = k;
1988
+ }
1989
+ }
1990
+ if (30 === r2.mode) break;
1991
+ if (0 === r2.lens[256]) {
1992
+ e2.msg = "invalid code -- missing end-of-block", r2.mode = 30;
1993
+ break;
1994
+ }
1995
+ if (r2.lenbits = 9, S = { bits: r2.lenbits }, x = T(D, r2.lens, 0, r2.nlen, r2.lencode, 0, r2.work, S), r2.lenbits = S.bits, x) {
1996
+ e2.msg = "invalid literal/lengths set", r2.mode = 30;
1997
+ break;
1998
+ }
1999
+ if (r2.distbits = 6, r2.distcode = r2.distdyn, S = { bits: r2.distbits }, x = T(F, r2.lens, r2.nlen, r2.ndist, r2.distcode, 0, r2.work, S), r2.distbits = S.bits, x) {
2000
+ e2.msg = "invalid distances set", r2.mode = 30;
2001
+ break;
2002
+ }
2003
+ if (r2.mode = 20, 6 === t2) break e;
2004
+ case 20:
2005
+ r2.mode = 21;
2006
+ case 21:
2007
+ if (6 <= o2 && 258 <= h2) {
2008
+ e2.next_out = a2, e2.avail_out = h2, e2.next_in = s2, e2.avail_in = o2, r2.hold = u2, r2.bits = l2, R(e2, c2), a2 = e2.next_out, i2 = e2.output, h2 = e2.avail_out, s2 = e2.next_in, n2 = e2.input, o2 = e2.avail_in, u2 = r2.hold, l2 = r2.bits, 12 === r2.mode && (r2.back = -1);
2009
+ break;
2010
+ }
2011
+ for (r2.back = 0; g = (C = r2.lencode[u2 & (1 << r2.lenbits) - 1]) >>> 16 & 255, b = 65535 & C, !((_ = C >>> 24) <= l2); ) {
2012
+ if (0 === o2) break e;
2013
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2014
+ }
2015
+ if (g && 0 == (240 & g)) {
2016
+ for (v = _, y = g, w = b; g = (C = r2.lencode[w + ((u2 & (1 << v + y) - 1) >> v)]) >>> 16 & 255, b = 65535 & C, !(v + (_ = C >>> 24) <= l2); ) {
2017
+ if (0 === o2) break e;
2018
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2019
+ }
2020
+ u2 >>>= v, l2 -= v, r2.back += v;
2021
+ }
2022
+ if (u2 >>>= _, l2 -= _, r2.back += _, r2.length = b, 0 === g) {
2023
+ r2.mode = 26;
2024
+ break;
2025
+ }
2026
+ if (32 & g) {
2027
+ r2.back = -1, r2.mode = 12;
2028
+ break;
2029
+ }
2030
+ if (64 & g) {
2031
+ e2.msg = "invalid literal/length code", r2.mode = 30;
2032
+ break;
2033
+ }
2034
+ r2.extra = 15 & g, r2.mode = 22;
2035
+ case 22:
2036
+ if (r2.extra) {
2037
+ for (z = r2.extra; l2 < z; ) {
2038
+ if (0 === o2) break e;
2039
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2040
+ }
2041
+ r2.length += u2 & (1 << r2.extra) - 1, u2 >>>= r2.extra, l2 -= r2.extra, r2.back += r2.extra;
2042
+ }
2043
+ r2.was = r2.length, r2.mode = 23;
2044
+ case 23:
2045
+ for (; g = (C = r2.distcode[u2 & (1 << r2.distbits) - 1]) >>> 16 & 255, b = 65535 & C, !((_ = C >>> 24) <= l2); ) {
2046
+ if (0 === o2) break e;
2047
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2048
+ }
2049
+ if (0 == (240 & g)) {
2050
+ for (v = _, y = g, w = b; g = (C = r2.distcode[w + ((u2 & (1 << v + y) - 1) >> v)]) >>> 16 & 255, b = 65535 & C, !(v + (_ = C >>> 24) <= l2); ) {
2051
+ if (0 === o2) break e;
2052
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2053
+ }
2054
+ u2 >>>= v, l2 -= v, r2.back += v;
2055
+ }
2056
+ if (u2 >>>= _, l2 -= _, r2.back += _, 64 & g) {
2057
+ e2.msg = "invalid distance code", r2.mode = 30;
2058
+ break;
2059
+ }
2060
+ r2.offset = b, r2.extra = 15 & g, r2.mode = 24;
2061
+ case 24:
2062
+ if (r2.extra) {
2063
+ for (z = r2.extra; l2 < z; ) {
2064
+ if (0 === o2) break e;
2065
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2066
+ }
2067
+ r2.offset += u2 & (1 << r2.extra) - 1, u2 >>>= r2.extra, l2 -= r2.extra, r2.back += r2.extra;
2068
+ }
2069
+ if (r2.offset > r2.dmax) {
2070
+ e2.msg = "invalid distance too far back", r2.mode = 30;
2071
+ break;
2072
+ }
2073
+ r2.mode = 25;
2074
+ case 25:
2075
+ if (0 === h2) break e;
2076
+ if (d = c2 - h2, r2.offset > d) {
2077
+ if ((d = r2.offset - d) > r2.whave && r2.sane) {
2078
+ e2.msg = "invalid distance too far back", r2.mode = 30;
2079
+ break;
2080
+ }
2081
+ p = d > r2.wnext ? (d -= r2.wnext, r2.wsize - d) : r2.wnext - d, d > r2.length && (d = r2.length), m = r2.window;
2082
+ } else m = i2, p = a2 - r2.offset, d = r2.length;
2083
+ for (h2 < d && (d = h2), h2 -= d, r2.length -= d; i2[a2++] = m[p++], --d; ) ;
2084
+ 0 === r2.length && (r2.mode = 21);
2085
+ break;
2086
+ case 26:
2087
+ if (0 === h2) break e;
2088
+ i2[a2++] = r2.length, h2--, r2.mode = 21;
2089
+ break;
2090
+ case 27:
2091
+ if (r2.wrap) {
2092
+ for (; l2 < 32; ) {
2093
+ if (0 === o2) break e;
2094
+ o2--, u2 |= n2[s2++] << l2, l2 += 8;
2095
+ }
2096
+ if (c2 -= h2, e2.total_out += c2, r2.total += c2, c2 && (e2.adler = r2.check = r2.flags ? B(r2.check, i2, c2, a2 - c2) : O(r2.check, i2, c2, a2 - c2)), c2 = h2, (r2.flags ? u2 : L(u2)) !== r2.check) {
2097
+ e2.msg = "incorrect data check", r2.mode = 30;
2098
+ break;
2099
+ }
2100
+ l2 = u2 = 0;
2101
+ }
2102
+ r2.mode = 28;
2103
+ case 28:
2104
+ if (r2.wrap && r2.flags) {
2105
+ for (; l2 < 32; ) {
2106
+ if (0 === o2) break e;
2107
+ o2--, u2 += n2[s2++] << l2, l2 += 8;
2108
+ }
2109
+ if (u2 !== (4294967295 & r2.total)) {
2110
+ e2.msg = "incorrect length check", r2.mode = 30;
2111
+ break;
2112
+ }
2113
+ l2 = u2 = 0;
2114
+ }
2115
+ r2.mode = 29;
2116
+ case 29:
2117
+ x = 1;
2118
+ break e;
2119
+ case 30:
2120
+ x = -3;
2121
+ break e;
2122
+ case 31:
2123
+ return -4;
2124
+ case 32:
2125
+ default:
2126
+ return U;
2127
+ }
2128
+ return e2.next_out = a2, e2.avail_out = h2, e2.next_in = s2, e2.avail_in = o2, r2.hold = u2, r2.bits = l2, (r2.wsize || c2 !== e2.avail_out && r2.mode < 30 && (r2.mode < 27 || 4 !== t2)) && Z(e2, e2.output, e2.next_out, c2 - e2.avail_out) ? (r2.mode = 31, -4) : (f2 -= e2.avail_in, c2 -= e2.avail_out, e2.total_in += f2, e2.total_out += c2, r2.total += c2, r2.wrap && c2 && (e2.adler = r2.check = r2.flags ? B(r2.check, i2, c2, e2.next_out - c2) : O(r2.check, i2, c2, e2.next_out - c2)), e2.data_type = r2.bits + (r2.last ? 64 : 0) + (12 === r2.mode ? 128 : 0) + (20 === r2.mode || 15 === r2.mode ? 256 : 0), (0 == f2 && 0 === c2 || 4 === t2) && x === N && (x = -5), x);
2129
+ }, r.inflateEnd = function(e2) {
2130
+ if (!e2 || !e2.state) return U;
2131
+ var t2 = e2.state;
2132
+ return t2.window && (t2.window = null), e2.state = null, N;
2133
+ }, r.inflateGetHeader = function(e2, t2) {
2134
+ var r2;
2135
+ return e2 && e2.state ? 0 == (2 & (r2 = e2.state).wrap) ? U : ((r2.head = t2).done = false, N) : U;
2136
+ }, r.inflateSetDictionary = function(e2, t2) {
2137
+ var r2, n2 = t2.length;
2138
+ return e2 && e2.state ? 0 !== (r2 = e2.state).wrap && 11 !== r2.mode ? U : 11 === r2.mode && O(1, t2, n2, 0) !== r2.check ? -3 : Z(e2, t2, n2, n2) ? (r2.mode = 31, -4) : (r2.havedict = 1, N) : U;
2139
+ }, r.inflateInfo = "pako inflate (from Nodeca project)";
2140
+ }, { "../utils/common": 41, "./adler32": 43, "./crc32": 45, "./inffast": 48, "./inftrees": 50 }], 50: [function(e, t, r) {
2141
+ "use strict";
2142
+ var D = e("../utils/common"), F = [3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0], N = [16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18, 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78], U = [1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577, 0, 0], P = [16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22, 23, 23, 24, 24, 25, 25, 26, 26, 27, 27, 28, 28, 29, 29, 64, 64];
2143
+ t.exports = function(e2, t2, r2, n, i, s, a, o) {
2144
+ var h, u, l, f, c, d, p, m, _, g = o.bits, b = 0, v = 0, y = 0, w = 0, k = 0, x = 0, S = 0, z = 0, C = 0, E = 0, A = null, I = 0, O = new D.Buf16(16), B = new D.Buf16(16), R = null, T = 0;
2145
+ for (b = 0; b <= 15; b++) O[b] = 0;
2146
+ for (v = 0; v < n; v++) O[t2[r2 + v]]++;
2147
+ for (k = g, w = 15; 1 <= w && 0 === O[w]; w--) ;
2148
+ if (w < k && (k = w), 0 === w) return i[s++] = 20971520, i[s++] = 20971520, o.bits = 1, 0;
2149
+ for (y = 1; y < w && 0 === O[y]; y++) ;
2150
+ for (k < y && (k = y), b = z = 1; b <= 15; b++) if (z <<= 1, (z -= O[b]) < 0) return -1;
2151
+ if (0 < z && (0 === e2 || 1 !== w)) return -1;
2152
+ for (B[1] = 0, b = 1; b < 15; b++) B[b + 1] = B[b] + O[b];
2153
+ for (v = 0; v < n; v++) 0 !== t2[r2 + v] && (a[B[t2[r2 + v]]++] = v);
2154
+ if (d = 0 === e2 ? (A = R = a, 19) : 1 === e2 ? (A = F, I -= 257, R = N, T -= 257, 256) : (A = U, R = P, -1), b = y, c = s, S = v = E = 0, l = -1, f = (C = 1 << (x = k)) - 1, 1 === e2 && 852 < C || 2 === e2 && 592 < C) return 1;
2155
+ for (; ; ) {
2156
+ for (p = b - S, _ = a[v] < d ? (m = 0, a[v]) : a[v] > d ? (m = R[T + a[v]], A[I + a[v]]) : (m = 96, 0), h = 1 << b - S, y = u = 1 << x; i[c + (E >> S) + (u -= h)] = p << 24 | m << 16 | _ | 0, 0 !== u; ) ;
2157
+ for (h = 1 << b - 1; E & h; ) h >>= 1;
2158
+ if (0 !== h ? (E &= h - 1, E += h) : E = 0, v++, 0 == --O[b]) {
2159
+ if (b === w) break;
2160
+ b = t2[r2 + a[v]];
2161
+ }
2162
+ if (k < b && (E & f) !== l) {
2163
+ for (0 === S && (S = k), c += y, z = 1 << (x = b - S); x + S < w && !((z -= O[x + S]) <= 0); ) x++, z <<= 1;
2164
+ if (C += 1 << x, 1 === e2 && 852 < C || 2 === e2 && 592 < C) return 1;
2165
+ i[l = E & f] = k << 24 | x << 16 | c - s | 0;
2166
+ }
2167
+ }
2168
+ return 0 !== E && (i[c + E] = b - S << 24 | 64 << 16 | 0), o.bits = k, 0;
2169
+ };
2170
+ }, { "../utils/common": 41 }], 51: [function(e, t, r) {
2171
+ "use strict";
2172
+ t.exports = { 2: "need dictionary", 1: "stream end", 0: "", "-1": "file error", "-2": "stream error", "-3": "data error", "-4": "insufficient memory", "-5": "buffer error", "-6": "incompatible version" };
2173
+ }, {}], 52: [function(e, t, r) {
2174
+ "use strict";
2175
+ var i = e("../utils/common"), o = 0, h = 1;
2176
+ function n(e2) {
2177
+ for (var t2 = e2.length; 0 <= --t2; ) e2[t2] = 0;
2178
+ }
2179
+ var s = 0, a = 29, u = 256, l = u + 1 + a, f = 30, c = 19, _ = 2 * l + 1, g = 15, d = 16, p = 7, m = 256, b = 16, v = 17, y = 18, w = [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0], k = [0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13], x = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 3, 7], S = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15], z = new Array(2 * (l + 2));
2180
+ n(z);
2181
+ var C = new Array(2 * f);
2182
+ n(C);
2183
+ var E = new Array(512);
2184
+ n(E);
2185
+ var A = new Array(256);
2186
+ n(A);
2187
+ var I = new Array(a);
2188
+ n(I);
2189
+ var O, B, R, T = new Array(f);
2190
+ function D(e2, t2, r2, n2, i2) {
2191
+ this.static_tree = e2, this.extra_bits = t2, this.extra_base = r2, this.elems = n2, this.max_length = i2, this.has_stree = e2 && e2.length;
2192
+ }
2193
+ function F(e2, t2) {
2194
+ this.dyn_tree = e2, this.max_code = 0, this.stat_desc = t2;
2195
+ }
2196
+ function N(e2) {
2197
+ return e2 < 256 ? E[e2] : E[256 + (e2 >>> 7)];
2198
+ }
2199
+ function U(e2, t2) {
2200
+ e2.pending_buf[e2.pending++] = 255 & t2, e2.pending_buf[e2.pending++] = t2 >>> 8 & 255;
2201
+ }
2202
+ function P(e2, t2, r2) {
2203
+ e2.bi_valid > d - r2 ? (e2.bi_buf |= t2 << e2.bi_valid & 65535, U(e2, e2.bi_buf), e2.bi_buf = t2 >> d - e2.bi_valid, e2.bi_valid += r2 - d) : (e2.bi_buf |= t2 << e2.bi_valid & 65535, e2.bi_valid += r2);
2204
+ }
2205
+ function L(e2, t2, r2) {
2206
+ P(e2, r2[2 * t2], r2[2 * t2 + 1]);
2207
+ }
2208
+ function j(e2, t2) {
2209
+ for (var r2 = 0; r2 |= 1 & e2, e2 >>>= 1, r2 <<= 1, 0 < --t2; ) ;
2210
+ return r2 >>> 1;
2211
+ }
2212
+ function Z(e2, t2, r2) {
2213
+ var n2, i2, s2 = new Array(g + 1), a2 = 0;
2214
+ for (n2 = 1; n2 <= g; n2++) s2[n2] = a2 = a2 + r2[n2 - 1] << 1;
2215
+ for (i2 = 0; i2 <= t2; i2++) {
2216
+ var o2 = e2[2 * i2 + 1];
2217
+ 0 !== o2 && (e2[2 * i2] = j(s2[o2]++, o2));
2218
+ }
2219
+ }
2220
+ function W(e2) {
2221
+ var t2;
2222
+ for (t2 = 0; t2 < l; t2++) e2.dyn_ltree[2 * t2] = 0;
2223
+ for (t2 = 0; t2 < f; t2++) e2.dyn_dtree[2 * t2] = 0;
2224
+ for (t2 = 0; t2 < c; t2++) e2.bl_tree[2 * t2] = 0;
2225
+ e2.dyn_ltree[2 * m] = 1, e2.opt_len = e2.static_len = 0, e2.last_lit = e2.matches = 0;
2226
+ }
2227
+ function M(e2) {
2228
+ 8 < e2.bi_valid ? U(e2, e2.bi_buf) : 0 < e2.bi_valid && (e2.pending_buf[e2.pending++] = e2.bi_buf), e2.bi_buf = 0, e2.bi_valid = 0;
2229
+ }
2230
+ function H(e2, t2, r2, n2) {
2231
+ var i2 = 2 * t2, s2 = 2 * r2;
2232
+ return e2[i2] < e2[s2] || e2[i2] === e2[s2] && n2[t2] <= n2[r2];
2233
+ }
2234
+ function G(e2, t2, r2) {
2235
+ for (var n2 = e2.heap[r2], i2 = r2 << 1; i2 <= e2.heap_len && (i2 < e2.heap_len && H(t2, e2.heap[i2 + 1], e2.heap[i2], e2.depth) && i2++, !H(t2, n2, e2.heap[i2], e2.depth)); ) e2.heap[r2] = e2.heap[i2], r2 = i2, i2 <<= 1;
2236
+ e2.heap[r2] = n2;
2237
+ }
2238
+ function K(e2, t2, r2) {
2239
+ var n2, i2, s2, a2, o2 = 0;
2240
+ if (0 !== e2.last_lit) for (; n2 = e2.pending_buf[e2.d_buf + 2 * o2] << 8 | e2.pending_buf[e2.d_buf + 2 * o2 + 1], i2 = e2.pending_buf[e2.l_buf + o2], o2++, 0 === n2 ? L(e2, i2, t2) : (L(e2, (s2 = A[i2]) + u + 1, t2), 0 !== (a2 = w[s2]) && P(e2, i2 -= I[s2], a2), L(e2, s2 = N(--n2), r2), 0 !== (a2 = k[s2]) && P(e2, n2 -= T[s2], a2)), o2 < e2.last_lit; ) ;
2241
+ L(e2, m, t2);
2242
+ }
2243
+ function Y(e2, t2) {
2244
+ var r2, n2, i2, s2 = t2.dyn_tree, a2 = t2.stat_desc.static_tree, o2 = t2.stat_desc.has_stree, h2 = t2.stat_desc.elems, u2 = -1;
2245
+ for (e2.heap_len = 0, e2.heap_max = _, r2 = 0; r2 < h2; r2++) 0 !== s2[2 * r2] ? (e2.heap[++e2.heap_len] = u2 = r2, e2.depth[r2] = 0) : s2[2 * r2 + 1] = 0;
2246
+ for (; e2.heap_len < 2; ) s2[2 * (i2 = e2.heap[++e2.heap_len] = u2 < 2 ? ++u2 : 0)] = 1, e2.depth[i2] = 0, e2.opt_len--, o2 && (e2.static_len -= a2[2 * i2 + 1]);
2247
+ for (t2.max_code = u2, r2 = e2.heap_len >> 1; 1 <= r2; r2--) G(e2, s2, r2);
2248
+ for (i2 = h2; r2 = e2.heap[1], e2.heap[1] = e2.heap[e2.heap_len--], G(e2, s2, 1), n2 = e2.heap[1], e2.heap[--e2.heap_max] = r2, e2.heap[--e2.heap_max] = n2, s2[2 * i2] = s2[2 * r2] + s2[2 * n2], e2.depth[i2] = (e2.depth[r2] >= e2.depth[n2] ? e2.depth[r2] : e2.depth[n2]) + 1, s2[2 * r2 + 1] = s2[2 * n2 + 1] = i2, e2.heap[1] = i2++, G(e2, s2, 1), 2 <= e2.heap_len; ) ;
2249
+ e2.heap[--e2.heap_max] = e2.heap[1], function(e3, t3) {
2250
+ var r3, n3, i3, s3, a3, o3, h3 = t3.dyn_tree, u3 = t3.max_code, l2 = t3.stat_desc.static_tree, f2 = t3.stat_desc.has_stree, c2 = t3.stat_desc.extra_bits, d2 = t3.stat_desc.extra_base, p2 = t3.stat_desc.max_length, m2 = 0;
2251
+ for (s3 = 0; s3 <= g; s3++) e3.bl_count[s3] = 0;
2252
+ for (h3[2 * e3.heap[e3.heap_max] + 1] = 0, r3 = e3.heap_max + 1; r3 < _; r3++) p2 < (s3 = h3[2 * h3[2 * (n3 = e3.heap[r3]) + 1] + 1] + 1) && (s3 = p2, m2++), h3[2 * n3 + 1] = s3, u3 < n3 || (e3.bl_count[s3]++, a3 = 0, d2 <= n3 && (a3 = c2[n3 - d2]), o3 = h3[2 * n3], e3.opt_len += o3 * (s3 + a3), f2 && (e3.static_len += o3 * (l2[2 * n3 + 1] + a3)));
2253
+ if (0 !== m2) {
2254
+ do {
2255
+ for (s3 = p2 - 1; 0 === e3.bl_count[s3]; ) s3--;
2256
+ e3.bl_count[s3]--, e3.bl_count[s3 + 1] += 2, e3.bl_count[p2]--, m2 -= 2;
2257
+ } while (0 < m2);
2258
+ for (s3 = p2; 0 !== s3; s3--) for (n3 = e3.bl_count[s3]; 0 !== n3; ) u3 < (i3 = e3.heap[--r3]) || (h3[2 * i3 + 1] !== s3 && (e3.opt_len += (s3 - h3[2 * i3 + 1]) * h3[2 * i3], h3[2 * i3 + 1] = s3), n3--);
2259
+ }
2260
+ }(e2, t2), Z(s2, u2, e2.bl_count);
2261
+ }
2262
+ function X(e2, t2, r2) {
2263
+ var n2, i2, s2 = -1, a2 = t2[1], o2 = 0, h2 = 7, u2 = 4;
2264
+ for (0 === a2 && (h2 = 138, u2 = 3), t2[2 * (r2 + 1) + 1] = 65535, n2 = 0; n2 <= r2; n2++) i2 = a2, a2 = t2[2 * (n2 + 1) + 1], ++o2 < h2 && i2 === a2 || (o2 < u2 ? e2.bl_tree[2 * i2] += o2 : 0 !== i2 ? (i2 !== s2 && e2.bl_tree[2 * i2]++, e2.bl_tree[2 * b]++) : o2 <= 10 ? e2.bl_tree[2 * v]++ : e2.bl_tree[2 * y]++, s2 = i2, u2 = (o2 = 0) === a2 ? (h2 = 138, 3) : i2 === a2 ? (h2 = 6, 3) : (h2 = 7, 4));
2265
+ }
2266
+ function V(e2, t2, r2) {
2267
+ var n2, i2, s2 = -1, a2 = t2[1], o2 = 0, h2 = 7, u2 = 4;
2268
+ for (0 === a2 && (h2 = 138, u2 = 3), n2 = 0; n2 <= r2; n2++) if (i2 = a2, a2 = t2[2 * (n2 + 1) + 1], !(++o2 < h2 && i2 === a2)) {
2269
+ if (o2 < u2) for (; L(e2, i2, e2.bl_tree), 0 != --o2; ) ;
2270
+ else 0 !== i2 ? (i2 !== s2 && (L(e2, i2, e2.bl_tree), o2--), L(e2, b, e2.bl_tree), P(e2, o2 - 3, 2)) : o2 <= 10 ? (L(e2, v, e2.bl_tree), P(e2, o2 - 3, 3)) : (L(e2, y, e2.bl_tree), P(e2, o2 - 11, 7));
2271
+ s2 = i2, u2 = (o2 = 0) === a2 ? (h2 = 138, 3) : i2 === a2 ? (h2 = 6, 3) : (h2 = 7, 4);
2272
+ }
2273
+ }
2274
+ n(T);
2275
+ var q = false;
2276
+ function J(e2, t2, r2, n2) {
2277
+ P(e2, (s << 1) + (n2 ? 1 : 0), 3), function(e3, t3, r3, n3) {
2278
+ M(e3), n3 && (U(e3, r3), U(e3, ~r3)), i.arraySet(e3.pending_buf, e3.window, t3, r3, e3.pending), e3.pending += r3;
2279
+ }(e2, t2, r2, true);
2280
+ }
2281
+ r._tr_init = function(e2) {
2282
+ q || (function() {
2283
+ var e3, t2, r2, n2, i2, s2 = new Array(g + 1);
2284
+ for (n2 = r2 = 0; n2 < a - 1; n2++) for (I[n2] = r2, e3 = 0; e3 < 1 << w[n2]; e3++) A[r2++] = n2;
2285
+ for (A[r2 - 1] = n2, n2 = i2 = 0; n2 < 16; n2++) for (T[n2] = i2, e3 = 0; e3 < 1 << k[n2]; e3++) E[i2++] = n2;
2286
+ for (i2 >>= 7; n2 < f; n2++) for (T[n2] = i2 << 7, e3 = 0; e3 < 1 << k[n2] - 7; e3++) E[256 + i2++] = n2;
2287
+ for (t2 = 0; t2 <= g; t2++) s2[t2] = 0;
2288
+ for (e3 = 0; e3 <= 143; ) z[2 * e3 + 1] = 8, e3++, s2[8]++;
2289
+ for (; e3 <= 255; ) z[2 * e3 + 1] = 9, e3++, s2[9]++;
2290
+ for (; e3 <= 279; ) z[2 * e3 + 1] = 7, e3++, s2[7]++;
2291
+ for (; e3 <= 287; ) z[2 * e3 + 1] = 8, e3++, s2[8]++;
2292
+ for (Z(z, l + 1, s2), e3 = 0; e3 < f; e3++) C[2 * e3 + 1] = 5, C[2 * e3] = j(e3, 5);
2293
+ O = new D(z, w, u + 1, l, g), B = new D(C, k, 0, f, g), R = new D(new Array(0), x, 0, c, p);
2294
+ }(), q = true), e2.l_desc = new F(e2.dyn_ltree, O), e2.d_desc = new F(e2.dyn_dtree, B), e2.bl_desc = new F(e2.bl_tree, R), e2.bi_buf = 0, e2.bi_valid = 0, W(e2);
2295
+ }, r._tr_stored_block = J, r._tr_flush_block = function(e2, t2, r2, n2) {
2296
+ var i2, s2, a2 = 0;
2297
+ 0 < e2.level ? (2 === e2.strm.data_type && (e2.strm.data_type = function(e3) {
2298
+ var t3, r3 = 4093624447;
2299
+ for (t3 = 0; t3 <= 31; t3++, r3 >>>= 1) if (1 & r3 && 0 !== e3.dyn_ltree[2 * t3]) return o;
2300
+ if (0 !== e3.dyn_ltree[18] || 0 !== e3.dyn_ltree[20] || 0 !== e3.dyn_ltree[26]) return h;
2301
+ for (t3 = 32; t3 < u; t3++) if (0 !== e3.dyn_ltree[2 * t3]) return h;
2302
+ return o;
2303
+ }(e2)), Y(e2, e2.l_desc), Y(e2, e2.d_desc), a2 = function(e3) {
2304
+ var t3;
2305
+ for (X(e3, e3.dyn_ltree, e3.l_desc.max_code), X(e3, e3.dyn_dtree, e3.d_desc.max_code), Y(e3, e3.bl_desc), t3 = c - 1; 3 <= t3 && 0 === e3.bl_tree[2 * S[t3] + 1]; t3--) ;
2306
+ return e3.opt_len += 3 * (t3 + 1) + 5 + 5 + 4, t3;
2307
+ }(e2), i2 = e2.opt_len + 3 + 7 >>> 3, (s2 = e2.static_len + 3 + 7 >>> 3) <= i2 && (i2 = s2)) : i2 = s2 = r2 + 5, r2 + 4 <= i2 && -1 !== t2 ? J(e2, t2, r2, n2) : 4 === e2.strategy || s2 === i2 ? (P(e2, 2 + (n2 ? 1 : 0), 3), K(e2, z, C)) : (P(e2, 4 + (n2 ? 1 : 0), 3), function(e3, t3, r3, n3) {
2308
+ var i3;
2309
+ for (P(e3, t3 - 257, 5), P(e3, r3 - 1, 5), P(e3, n3 - 4, 4), i3 = 0; i3 < n3; i3++) P(e3, e3.bl_tree[2 * S[i3] + 1], 3);
2310
+ V(e3, e3.dyn_ltree, t3 - 1), V(e3, e3.dyn_dtree, r3 - 1);
2311
+ }(e2, e2.l_desc.max_code + 1, e2.d_desc.max_code + 1, a2 + 1), K(e2, e2.dyn_ltree, e2.dyn_dtree)), W(e2), n2 && M(e2);
2312
+ }, r._tr_tally = function(e2, t2, r2) {
2313
+ return e2.pending_buf[e2.d_buf + 2 * e2.last_lit] = t2 >>> 8 & 255, e2.pending_buf[e2.d_buf + 2 * e2.last_lit + 1] = 255 & t2, e2.pending_buf[e2.l_buf + e2.last_lit] = 255 & r2, e2.last_lit++, 0 === t2 ? e2.dyn_ltree[2 * r2]++ : (e2.matches++, t2--, e2.dyn_ltree[2 * (A[r2] + u + 1)]++, e2.dyn_dtree[2 * N(t2)]++), e2.last_lit === e2.lit_bufsize - 1;
2314
+ }, r._tr_align = function(e2) {
2315
+ P(e2, 2, 3), L(e2, m, z), function(e3) {
2316
+ 16 === e3.bi_valid ? (U(e3, e3.bi_buf), e3.bi_buf = 0, e3.bi_valid = 0) : 8 <= e3.bi_valid && (e3.pending_buf[e3.pending++] = 255 & e3.bi_buf, e3.bi_buf >>= 8, e3.bi_valid -= 8);
2317
+ }(e2);
2318
+ };
2319
+ }, { "../utils/common": 41 }], 53: [function(e, t, r) {
2320
+ "use strict";
2321
+ t.exports = function() {
2322
+ this.input = null, this.next_in = 0, this.avail_in = 0, this.total_in = 0, this.output = null, this.next_out = 0, this.avail_out = 0, this.total_out = 0, this.msg = "", this.state = null, this.data_type = 2, this.adler = 0;
2323
+ };
2324
+ }, {}], 54: [function(e, t, r) {
2325
+ (function(e2) {
2326
+ !function(r2, n) {
2327
+ "use strict";
2328
+ if (!r2.setImmediate) {
2329
+ var i, s, t2, a, o = 1, h = {}, u = false, l = r2.document, e3 = Object.getPrototypeOf && Object.getPrototypeOf(r2);
2330
+ e3 = e3 && e3.setTimeout ? e3 : r2, i = "[object process]" === {}.toString.call(r2.process) ? function(e4) {
2331
+ process.nextTick(function() {
2332
+ c(e4);
2333
+ });
2334
+ } : function() {
2335
+ if (r2.postMessage && !r2.importScripts) {
2336
+ var e4 = true, t3 = r2.onmessage;
2337
+ return r2.onmessage = function() {
2338
+ e4 = false;
2339
+ }, r2.postMessage("", "*"), r2.onmessage = t3, e4;
2340
+ }
2341
+ }() ? (a = "setImmediate$" + Math.random() + "$", r2.addEventListener ? r2.addEventListener("message", d, false) : r2.attachEvent("onmessage", d), function(e4) {
2342
+ r2.postMessage(a + e4, "*");
2343
+ }) : r2.MessageChannel ? ((t2 = new MessageChannel()).port1.onmessage = function(e4) {
2344
+ c(e4.data);
2345
+ }, function(e4) {
2346
+ t2.port2.postMessage(e4);
2347
+ }) : l && "onreadystatechange" in l.createElement("script") ? (s = l.documentElement, function(e4) {
2348
+ var t3 = l.createElement("script");
2349
+ t3.onreadystatechange = function() {
2350
+ c(e4), t3.onreadystatechange = null, s.removeChild(t3), t3 = null;
2351
+ }, s.appendChild(t3);
2352
+ }) : function(e4) {
2353
+ setTimeout(c, 0, e4);
2354
+ }, e3.setImmediate = function(e4) {
2355
+ "function" != typeof e4 && (e4 = new Function("" + e4));
2356
+ for (var t3 = new Array(arguments.length - 1), r3 = 0; r3 < t3.length; r3++) t3[r3] = arguments[r3 + 1];
2357
+ var n2 = { callback: e4, args: t3 };
2358
+ return h[o] = n2, i(o), o++;
2359
+ }, e3.clearImmediate = f;
2360
+ }
2361
+ function f(e4) {
2362
+ delete h[e4];
2363
+ }
2364
+ function c(e4) {
2365
+ if (u) setTimeout(c, 0, e4);
2366
+ else {
2367
+ var t3 = h[e4];
2368
+ if (t3) {
2369
+ u = true;
2370
+ try {
2371
+ !function(e5) {
2372
+ var t4 = e5.callback, r3 = e5.args;
2373
+ switch (r3.length) {
2374
+ case 0:
2375
+ t4();
2376
+ break;
2377
+ case 1:
2378
+ t4(r3[0]);
2379
+ break;
2380
+ case 2:
2381
+ t4(r3[0], r3[1]);
2382
+ break;
2383
+ case 3:
2384
+ t4(r3[0], r3[1], r3[2]);
2385
+ break;
2386
+ default:
2387
+ t4.apply(n, r3);
2388
+ }
2389
+ }(t3);
2390
+ } finally {
2391
+ f(e4), u = false;
2392
+ }
2393
+ }
2394
+ }
2395
+ }
2396
+ function d(e4) {
2397
+ e4.source === r2 && "string" == typeof e4.data && 0 === e4.data.indexOf(a) && c(+e4.data.slice(a.length));
2398
+ }
2399
+ }("undefined" == typeof self ? void 0 === e2 ? this : e2 : self);
2400
+ }).call(this, "undefined" != typeof global ? global : "undefined" != typeof self ? self : "undefined" != typeof window ? window : {});
2401
+ }, {}] }, {}, [10])(10);
2402
+ });
2403
+ }
2404
+ });
2405
+
2406
+ // src/mineru-viewer.ts
2407
+ var mineru_viewer_exports = {};
2408
+ __export(mineru_viewer_exports, {
2409
+ MineruLayoutViewer: () => MineruLayoutViewer
2410
+ });
2411
+
2412
+ // src/parse-blocks.ts
2413
+ function extractSpanText(block) {
2414
+ const lines = block.lines;
2415
+ if (!lines) return block.text || "";
2416
+ const texts = [];
2417
+ for (const line of lines) {
2418
+ const spans = line.spans;
2419
+ if (spans) {
2420
+ for (const span of spans) {
2421
+ if (span.content) texts.push(String(span.content));
2422
+ }
2423
+ }
2424
+ }
2425
+ return texts.join(" ") || block.text || "";
2426
+ }
2427
+ function parseBlocks(jsonStr) {
2428
+ const result = [];
2429
+ try {
2430
+ const data = JSON.parse(jsonStr);
2431
+ if (data.pdf_info && Array.isArray(data.pdf_info)) {
2432
+ const walkLayout = (items, pageIdx) => {
2433
+ for (const item of items) {
2434
+ if (!item.bbox) continue;
2435
+ const childBlocks = item.blocks;
2436
+ if (childBlocks && childBlocks.length > 0) {
2437
+ walkLayout(childBlocks, pageIdx);
2438
+ } else {
2439
+ result.push({
2440
+ page_idx: pageIdx,
2441
+ bbox: item.bbox,
2442
+ text: extractSpanText(item) || void 0,
2443
+ type: item.type
2444
+ });
2445
+ }
2446
+ }
2447
+ };
2448
+ for (let i = 0; i < data.pdf_info.length; i++) {
2449
+ const page = data.pdf_info[i];
2450
+ const blocks = page.preproc_blocks || page.para_blocks || [];
2451
+ walkLayout(blocks, i);
2452
+ }
2453
+ return result;
2454
+ }
2455
+ if (!Array.isArray(data)) return result;
2456
+ const walk = (items) => {
2457
+ for (const item of items) {
2458
+ const idx = item.page_idx ?? item.page_index;
2459
+ if (idx !== void 0 && item.bbox) {
2460
+ result.push({
2461
+ page_idx: idx,
2462
+ bbox: item.bbox,
2463
+ text: item.text || void 0,
2464
+ type: item.category || item.type
2465
+ });
2466
+ }
2467
+ if (Array.isArray(item.children)) walk(item.children);
2468
+ if (Array.isArray(item.blocks)) walk(item.blocks);
2469
+ }
2470
+ };
2471
+ walk(data);
2472
+ } catch {
2473
+ }
2474
+ return result;
2475
+ }
2476
+
2477
+ // src/match-markdown.ts
2478
+ function normalize(s) {
2479
+ return s.replace(/[#*\s\n\r\t`~|>\\[\]()]+/g, " ").replace(/\s{2,}/g, " ").trim().toLowerCase();
2480
+ }
2481
+ function lcsSimilarity(a, b) {
2482
+ const shorter = a.length < b.length ? a : b;
2483
+ const longer = a.length < b.length ? b : a;
2484
+ if (shorter.length === 0) return 0;
2485
+ let maxLen = 0;
2486
+ const window2 = Math.min(shorter.length, 30);
2487
+ for (let i = 0; i < shorter.length; i++) {
2488
+ if (shorter.length - i <= maxLen) break;
2489
+ for (let len = window2; len > maxLen; len--) {
2490
+ const sub = shorter.substring(i, i + len);
2491
+ if (sub.length < 4) continue;
2492
+ if (longer.includes(sub)) {
2493
+ maxLen = sub.length;
2494
+ break;
2495
+ }
2496
+ }
2497
+ }
2498
+ return maxLen / Math.max(shorter.length, 1);
2499
+ }
2500
+ function matchMarkdownToPdf(markdown, blocks) {
2501
+ const paragraphs = markdown.split(/\n+/).filter((p) => p.trim());
2502
+ const textBlocks = blocks.filter(
2503
+ (b) => b.text && b.text.trim().length > 1
2504
+ );
2505
+ if (textBlocks.length === 0) {
2506
+ return paragraphs.map((p) => ({ text: p, page: 1, bbox: null }));
2507
+ }
2508
+ return paragraphs.map((para) => {
2509
+ const norm = normalize(para);
2510
+ if (norm.length < 4) {
2511
+ return { text: para, page: textBlocks[0].page_idx + 1, bbox: textBlocks[0].bbox };
2512
+ }
2513
+ let best = null;
2514
+ let bestScore = 0;
2515
+ const topBlocks = textBlocks.filter(
2516
+ (b) => b.type !== "table-body" && b.type !== "table-row"
2517
+ );
2518
+ for (const b of topBlocks) {
2519
+ const s = lcsSimilarity(norm, normalize(b.text));
2520
+ if (s > bestScore) {
2521
+ bestScore = s;
2522
+ best = b;
2523
+ }
2524
+ }
2525
+ if (bestScore < 0.2) {
2526
+ for (const b of textBlocks) {
2527
+ const s = lcsSimilarity(norm, normalize(b.text));
2528
+ if (s > bestScore) {
2529
+ bestScore = s;
2530
+ best = b;
2531
+ }
2532
+ }
2533
+ }
2534
+ if (!best || bestScore < 0.1) {
2535
+ const ratio = paragraphs.indexOf(para) / Math.max(paragraphs.length, 1);
2536
+ const estPage = Math.floor(
2537
+ ratio * (blocks.length > 0 ? Math.max(...blocks.map((b) => b.page_idx)) + 1 : 1)
2538
+ );
2539
+ return { text: para, page: estPage + 1, bbox: null };
2540
+ }
2541
+ return { text: para, page: best.page_idx + 1, bbox: best.bbox };
2542
+ });
2543
+ }
2544
+
2545
+ // src/mineru-viewer.ts
2546
+ var RENDER_SCALE = 2;
2547
+ var STYLES = `
2548
+ :host { display: flex; flex-direction: column; height: 100%; font-family: system-ui, sans-serif; color-scheme: light dark; }
2549
+ .toolbar { display: flex; align-items: center; gap: 8px; padding: 6px 10px; border-bottom: 1px solid #e5e5e5; font-size: 12px; color: #888; flex-shrink: 0; flex-wrap: wrap; }
2550
+ .toolbar .sep { color: #ddd; }
2551
+ .toolbar .ok { color: #16a34a; }
2552
+ .toolbar .warn { color: #f59e0b; }
2553
+ @media (prefers-color-scheme: dark) {
2554
+ .toolbar { border-color: #333; }
2555
+ .toolbar .sep { color: #555; }
2556
+ }
2557
+ .split { flex: 1; display: grid; grid-template-columns: 1fr 1fr; min-height: 0; overflow: hidden; }
2558
+ .pane { overflow: auto; padding: 10px; }
2559
+ .pane-left { border-right: 1px solid #e5e5e5; }
2560
+ .pane-right { background: #f9f9f9; }
2561
+ @media (prefers-color-scheme: dark) {
2562
+ .pane-left { border-color: #333; }
2563
+ .pane-right { background: #1e1e1e; }
2564
+ }
2565
+ .pdf-page { position: relative; margin: 0 auto 12px; border: 1px solid #e5e5e5; border-radius: 4px; overflow: hidden; }
2566
+ .pdf-page img { display: block; width: 100%; }
2567
+ .pdf-page .page-num { position: absolute; bottom: 2px; right: 4px; font-size: 9px; color: #999; background: rgba(255,255,255,.85); padding: 1px 4px; border-radius: 3px; }
2568
+ @media (prefers-color-scheme: dark) { .pdf-page { border-color: #333; } .pdf-page .page-num { background: rgba(0,0,0,.7); } }
2569
+ .block-overlay { position: absolute; border: 1px solid transparent; cursor: pointer; transition: all .15s; }
2570
+ .block-overlay:hover { border-color: #f59e0b; background: rgba(245,158,11,.12); }
2571
+ .block-overlay.active { border-color: #3b82f6 !important; background: rgba(59,130,246,.2) !important; z-index: 10; box-shadow: 0 0 0 1px #3b82f6; }
2572
+ .md-line { display: block; cursor: pointer; padding: 2px 8px; border-radius: 4px; border-left: 2px solid transparent; font-size: 13px; line-height: 1.5; font-family: 'SF Mono', 'Cascadia Code', Consolas, monospace; white-space: pre-wrap; word-break: break-all; }
2573
+ .md-line.match { border-left-color: rgba(245,158,11,.4); }
2574
+ .md-line.match:hover { background: rgba(245,158,11,.08); }
2575
+ .md-line.no-match { color: #999; opacity: .6; }
2576
+ .md-line.active { background: rgba(59,130,246,.1); border-left-color: #3b82f6; box-shadow: inset 0 0 0 1px rgba(59,130,246,.3); }
2577
+ @media (prefers-color-scheme: dark) { .md-line.active { background: rgba(59,130,246,.15); } }
2578
+ .md-line .badge { font-size: 10px; color: #999; margin-left: 6px; }
2579
+ `;
2580
+ var MineruLayoutViewer = class extends HTMLElement {
2581
+ blocks = [];
2582
+ sections = [];
2583
+ pages = [];
2584
+ activeIdx = null;
2585
+ pdfUrl = null;
2586
+ layoutData = null;
2587
+ markdownText = null;
2588
+ static observedAttributes = ["pdf", "layout", "markdown"];
2589
+ constructor() {
2590
+ super();
2591
+ this.attachShadow({ mode: "open" });
2592
+ }
2593
+ connectedCallback() {
2594
+ this.render();
2595
+ this.setupResize();
2596
+ }
2597
+ attributeChangedCallback(name, _old, newVal) {
2598
+ if (name === "pdf" && newVal) {
2599
+ this.pdfUrl = newVal;
2600
+ this.loadPdf(newVal);
2601
+ }
2602
+ if (name === "layout" && newVal) {
2603
+ this.loadLayout(newVal);
2604
+ }
2605
+ if (name === "markdown" && newVal) {
2606
+ this.markdownText = newVal;
2607
+ this.rebuild();
2608
+ }
2609
+ }
2610
+ // ── Public API ──
2611
+ set pdf(value) {
2612
+ this.setAttribute("pdf", value);
2613
+ }
2614
+ get pdf() {
2615
+ return this.getAttribute("pdf") || "";
2616
+ }
2617
+ set layout(value) {
2618
+ this.setAttribute("layout", value);
2619
+ }
2620
+ get layout() {
2621
+ return this.getAttribute("layout") || "";
2622
+ }
2623
+ set markdown(value) {
2624
+ this.setAttribute("markdown", value);
2625
+ }
2626
+ get markdown() {
2627
+ return this.getAttribute("markdown") || "";
2628
+ }
2629
+ /** Programmatic API: load layout JSON directly */
2630
+ async loadLayoutFromJson(data) {
2631
+ const jsonStr = typeof data === "string" ? data : JSON.stringify(data);
2632
+ this.layoutData = jsonStr;
2633
+ if (this.pdfUrl) this.rebuild();
2634
+ }
2635
+ /** Programmatic API: load markdown text directly */
2636
+ async loadMarkdown(text) {
2637
+ this.markdownText = text;
2638
+ if (this.layoutData) this.rebuild();
2639
+ }
2640
+ /** Programmatic API: load PDF + layout from a MinerU zip Blob */
2641
+ async loadZip(zipBlob) {
2642
+ const JSZip = window.JSZip || await Promise.resolve().then(() => __toESM(require_jszip_min(), 1)).then((m) => m.default);
2643
+ const zip = await JSZip.loadAsync(zipBlob);
2644
+ let jsonStr = "";
2645
+ for (const name of ["layout.json", "middle.json"]) {
2646
+ const f = zip.file(name);
2647
+ if (f) {
2648
+ jsonStr = await f.async("text");
2649
+ break;
2650
+ }
2651
+ }
2652
+ if (!jsonStr) {
2653
+ for (const name of Object.keys(zip.files)) {
2654
+ if (name.endsWith("_layout.json") || name.endsWith("_middle.json")) {
2655
+ jsonStr = await zip.file(name).async("text");
2656
+ break;
2657
+ }
2658
+ }
2659
+ }
2660
+ if (!jsonStr) {
2661
+ for (const name of Object.keys(zip.files)) {
2662
+ if (name.endsWith("_content_list.json")) {
2663
+ jsonStr = await zip.file(name).async("text");
2664
+ break;
2665
+ }
2666
+ }
2667
+ }
2668
+ const mdFile = zip.file("full.md");
2669
+ if (mdFile) this.markdownText = await mdFile.async("text");
2670
+ this.layoutData = jsonStr;
2671
+ for (const name of Object.keys(zip.files)) {
2672
+ if (name.endsWith("_origin.pdf")) {
2673
+ const blob = await zip.file(name).async("blob");
2674
+ this.pdfUrl = URL.createObjectURL(blob);
2675
+ break;
2676
+ }
2677
+ }
2678
+ if (this.layoutData) this.rebuild();
2679
+ else throw new Error("zip \u7F3A\u5C11 layout.json \u6216 middle.json");
2680
+ }
2681
+ // ── Internal ──
2682
+ render() {
2683
+ if (!this.shadowRoot) return;
2684
+ this.shadowRoot.innerHTML = `<style>${STYLES}</style>
2685
+ <div class="toolbar">
2686
+ <span id="stat"></span><span class="flex-1" style="flex:1"></span>
2687
+ </div>
2688
+ <div class="split">
2689
+ <div class="pane pane-left" id="pdfPane"><slot name="loading">\u52A0\u8F7D PDF + layout.json \u4EE5\u5F00\u59CB</slot></div>
2690
+ <div class="pane pane-right" id="mdPane"></div>
2691
+ </div>`;
2692
+ }
2693
+ setupResize() {
2694
+ const ro = new ResizeObserver(() => this.buildPdfOverlays());
2695
+ const pane = this.shadowRoot?.getElementById("pdfPane");
2696
+ if (pane) ro.observe(pane);
2697
+ }
2698
+ async loadPdf(url) {
2699
+ this.pdfUrl = url;
2700
+ if (this.layoutData || this.markdownText) await this.rebuild();
2701
+ }
2702
+ async loadLayout(url) {
2703
+ const res = await fetch(url);
2704
+ this.layoutData = await res.text();
2705
+ if (this.pdfUrl) await this.rebuild();
2706
+ }
2707
+ async rebuild() {
2708
+ if (!this.layoutData) return;
2709
+ this.blocks = parseBlocks(this.layoutData);
2710
+ const md = this.markdownText || this.blocks.map((b) => b.text || "").filter(Boolean).join("\n");
2711
+ this.sections = matchMarkdownToPdf(md, this.blocks);
2712
+ if (this.pdfUrl) await this.renderPdfPages();
2713
+ this.buildUI();
2714
+ }
2715
+ async renderPdfPages() {
2716
+ if (!this.pdfUrl) return;
2717
+ const pdf = await pdfjsLib.getDocument(this.pdfUrl).promise;
2718
+ this.pages = [];
2719
+ for (let i = 1; i <= pdf.numPages; i++) {
2720
+ const page = await pdf.getPage(i);
2721
+ const vp = page.getViewport({ scale: RENDER_SCALE });
2722
+ const cvs = document.createElement("canvas");
2723
+ cvs.width = vp.width;
2724
+ cvs.height = vp.height;
2725
+ await page.render({ canvasContext: cvs.getContext("2d"), viewport: vp }).promise;
2726
+ this.pages.push({ p: i, w: vp.width, h: vp.height, src: cvs.toDataURL() });
2727
+ page.cleanup();
2728
+ }
2729
+ pdf.destroy();
2730
+ }
2731
+ buildUI() {
2732
+ const shadow = this.shadowRoot;
2733
+ const matched = this.sections.filter((s) => s.bbox).length;
2734
+ shadow.getElementById("stat").innerHTML = `${this.pages.length} \u9875 | ${this.sections.length} \u884C | <span class="${matched > 0 ? "ok" : "warn"}">\u5339\u914D ${matched}</span> | ${this.blocks.length} \u5757`;
2735
+ this.buildPdfOverlays();
2736
+ this.buildMarkdown();
2737
+ }
2738
+ buildPdfOverlays() {
2739
+ const pane = this.shadowRoot.getElementById("pdfPane");
2740
+ pane.innerHTML = "";
2741
+ const containerW = pane.clientWidth - 20;
2742
+ if (containerW <= 0 || this.pages.length === 0) return;
2743
+ for (const rp of this.pages) {
2744
+ const cssW = containerW;
2745
+ const cssH = rp.h * (containerW / rp.w);
2746
+ const pageBlocks = this.blocks.filter((b) => b.page_idx === rp.p - 1);
2747
+ const pageScale = containerW / rp.w;
2748
+ const s = RENDER_SCALE * pageScale;
2749
+ const wrapper = document.createElement("div");
2750
+ wrapper.className = "pdf-page";
2751
+ wrapper.style.width = cssW + "px";
2752
+ wrapper.style.height = cssH + "px";
2753
+ wrapper.dataset.page = String(rp.p);
2754
+ const img = document.createElement("img");
2755
+ img.src = rp.src;
2756
+ wrapper.appendChild(img);
2757
+ const label = document.createElement("span");
2758
+ label.className = "page-num";
2759
+ label.textContent = String(rp.p);
2760
+ wrapper.appendChild(label);
2761
+ for (const b of pageBlocks) {
2762
+ const [x0, y0, x1, y1] = b.bbox;
2763
+ const ov = document.createElement("div");
2764
+ ov.className = "block-overlay";
2765
+ ov.style.left = x0 * s + "px";
2766
+ ov.style.top = y0 * s + "px";
2767
+ ov.style.width = Math.max((x1 - x0) * s, 2) + "px";
2768
+ ov.style.height = Math.max((y1 - y0) * s, 2) + "px";
2769
+ ov.title = (b.text || "").slice(0, 120);
2770
+ ov.addEventListener("click", () => this.onBlockClick(b, ov));
2771
+ wrapper.appendChild(ov);
2772
+ }
2773
+ pane.appendChild(wrapper);
2774
+ }
2775
+ }
2776
+ buildMarkdown() {
2777
+ const pane = this.shadowRoot.getElementById("mdPane");
2778
+ pane.innerHTML = "";
2779
+ for (let i = 0; i < this.sections.length; i++) {
2780
+ const sec = this.sections[i];
2781
+ const el = document.createElement("span");
2782
+ el.className = "md-line" + (sec.bbox ? " match" : " no-match");
2783
+ el.dataset.idx = String(i);
2784
+ el.textContent = sec.text;
2785
+ if (sec.bbox) {
2786
+ const b = document.createElement("span");
2787
+ b.className = "badge";
2788
+ b.textContent = `p${sec.page}`;
2789
+ el.appendChild(b);
2790
+ }
2791
+ el.addEventListener("click", () => this.onMdClick(sec, i, el));
2792
+ pane.appendChild(el);
2793
+ }
2794
+ }
2795
+ onMdClick(sec, idx, el) {
2796
+ const shadow = this.shadowRoot;
2797
+ shadow.querySelectorAll(".md-line.active").forEach((e) => e.classList.remove("active"));
2798
+ shadow.querySelectorAll(".block-overlay.active").forEach((e) => e.classList.remove("active"));
2799
+ el.classList.add("active");
2800
+ this.activeIdx = idx;
2801
+ if (sec.bbox) {
2802
+ const pageEl = shadow.querySelector(`.pdf-page[data-page="${sec.page}"]`);
2803
+ if (pageEl) pageEl.scrollIntoView({ behavior: "smooth", block: "start" });
2804
+ const overlays = shadow.querySelectorAll(`.pdf-page[data-page="${sec.page}"] .block-overlay`);
2805
+ const page = this.pages[sec.page - 1];
2806
+ if (page) {
2807
+ const pw = shadow.getElementById("pdfPane").clientWidth - 20;
2808
+ const s = RENDER_SCALE * (pw / page.w);
2809
+ overlays.forEach((ov) => {
2810
+ const el2 = ov;
2811
+ if (Math.abs(parseFloat(el2.style.left) - sec.bbox[0] * s) < 4) {
2812
+ el2.classList.add("active");
2813
+ el2.scrollIntoView({ behavior: "smooth", block: "center" });
2814
+ }
2815
+ });
2816
+ }
2817
+ }
2818
+ }
2819
+ onBlockClick(block, ov) {
2820
+ const shadow = this.shadowRoot;
2821
+ shadow.querySelectorAll(".md-line.active").forEach((e) => e.classList.remove("active"));
2822
+ shadow.querySelectorAll(".block-overlay.active").forEach((e) => e.classList.remove("active"));
2823
+ ov.classList.add("active");
2824
+ const blockNorm = normalize(block.text || "");
2825
+ let bestIdx = -1, bestSim = 0;
2826
+ for (let i = 0; i < this.sections.length; i++) {
2827
+ if (!this.sections[i].bbox) continue;
2828
+ const sim = lcsSimilarity(blockNorm, normalize(this.sections[i].text));
2829
+ if (sim > bestSim && sim > 0.05) {
2830
+ bestSim = sim;
2831
+ bestIdx = i;
2832
+ }
2833
+ }
2834
+ if (bestIdx >= 0) {
2835
+ this.activeIdx = bestIdx;
2836
+ const el = shadow.querySelector(`[data-idx="${bestIdx}"]`);
2837
+ if (el) {
2838
+ el.classList.add("active");
2839
+ el.scrollIntoView({ behavior: "smooth", block: "center" });
2840
+ }
2841
+ }
2842
+ }
2843
+ };
2844
+ if (typeof customElements !== "undefined" && !customElements.get("mineru-layout-viewer")) {
2845
+ customElements.define("mineru-layout-viewer", MineruLayoutViewer);
2846
+ }
2847
+ return __toCommonJS(mineru_viewer_exports);
2848
+ })();
2849
+ /*! Bundled license information:
2850
+
2851
+ jszip/dist/jszip.min.js:
2852
+ (*!
2853
+
2854
+ JSZip v3.10.1 - A JavaScript class for generating and reading zip files
2855
+ <http://stuartk.com/jszip>
2856
+
2857
+ (c) 2009-2016 Stuart Knightley <stuart [at] stuartk.com>
2858
+ Dual licenced under the MIT license or GPLv3. See https://raw.github.com/Stuk/jszip/main/LICENSE.markdown.
2859
+
2860
+ JSZip uses the library pako released under the MIT license :
2861
+ https://github.com/nodeca/pako/blob/main/LICENSE
2862
+ *)
2863
+ */
2864
+ //# sourceMappingURL=mineru-layout-viewer.iife.js.map