precision-dashwidgets 0.5.0 → 0.5.2

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.
Files changed (32) hide show
  1. package/dist/basedecoder-PoXbLGBV-BL0bCGZI.mjs +88 -0
  2. package/dist/core-l0sNRNKZ.mjs +1 -0
  3. package/dist/deflate-BQVLA3Ul.mjs +10 -0
  4. package/dist/deflate-DbhbvOaP-D8NSBt31.mjs +10 -0
  5. package/dist/{duckdb-browser-CI2dpY-v-CoCsU0kJ.mjs → duckdb-browser-CI2dpY-v-D1qQUOov.mjs} +14 -19
  6. package/dist/index-BHHg5z03.mjs +47215 -0
  7. package/dist/index-CRAkqt4--8ZLRoGIu.mjs +4 -0
  8. package/dist/index-GF8k2nCC-DnpFPSAr.mjs +4 -0
  9. package/dist/index-Hx8PFhs9.mjs +27802 -0
  10. package/dist/index-Oh_goZGT-H9AAGZr8.mjs +9 -0
  11. package/dist/index-UOUUzHJY-DJVMXBUa.mjs +61 -0
  12. package/dist/index-dhOjlnSX-Biz-kopS.mjs +278 -0
  13. package/dist/index-u1qleOVs-ZJVnnKAV.mjs +8 -0
  14. package/dist/jpeg-CqPRbuRp-D8jmb2jk.mjs +514 -0
  15. package/dist/jpeg-l5M1J8Gh.mjs +514 -0
  16. package/dist/lerc-BipMr5R9.mjs +1034 -0
  17. package/dist/lerc-XufrP0FH-SNCeY3ab.mjs +1029 -0
  18. package/dist/lzw-DQ6ibF74-B90aSslP.mjs +84 -0
  19. package/dist/lzw-u9cBMr9g.mjs +84 -0
  20. package/dist/packbits-BuzK6gM3-6Um4hupZ.mjs +24 -0
  21. package/dist/packbits-dQba4PyI.mjs +24 -0
  22. package/dist/pako.esm-Bx5X36Wo-CzWah3nf.mjs +1053 -0
  23. package/dist/pako.esm-D_m2s4NW.mjs +1053 -0
  24. package/dist/precision-dashwidgets.es.js +7 -23222
  25. package/dist/precision-dashwidgets.umd.js +4801 -63
  26. package/dist/raw-CaSL8pVO-AR0tnXz4.mjs +9 -0
  27. package/dist/raw-KFPBw5cQ.mjs +9 -0
  28. package/dist/style.css +1 -1
  29. package/dist/webimage--SJddlky-F_hESl4q.mjs +19 -0
  30. package/dist/webimage-CBOAIeUr.mjs +19 -0
  31. package/package.json +6 -5
  32. package/dist/useGetToken-DaxIvkvl-BZdrKpSJ.mjs +0 -18
@@ -0,0 +1,1029 @@
1
+ import { w as sA } from "./pako.esm-Bx5X36Wo-CzWah3nf.mjs";
2
+ import { w as rA, x as gA, S as DA } from "./index-BHHg5z03.mjs";
3
+ import { g as nA } from "./basedecoder-PoXbLGBV-BL0bCGZI.mjs";
4
+ var EA = { exports: {} }, iA;
5
+ function wA() {
6
+ return iA || (iA = 1, function(W) {
7
+ /* Copyright 2015-2021 Esri. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 @preserve */
8
+ (function() {
9
+ var N = function() {
10
+ var L = {};
11
+ L.defaultNoDataValue = -34027999387901484e22, L.decode = function(I, a) {
12
+ a = a || {};
13
+ var Q = a.encodedMaskData || a.encodedMaskData === null, g = E(I, a.inputOffset || 0, Q), r = a.noDataValue !== null ? a.noDataValue : L.defaultNoDataValue, B = u(
14
+ g,
15
+ a.pixelType || Float32Array,
16
+ a.encodedMaskData,
17
+ r,
18
+ a.returnMask
19
+ ), C = {
20
+ width: g.width,
21
+ height: g.height,
22
+ pixelData: B.resultPixels,
23
+ minValue: B.minValue,
24
+ maxValue: g.pixels.maxValue,
25
+ noDataValue: r
26
+ };
27
+ return B.resultMask && (C.maskData = B.resultMask), a.returnEncodedMask && g.mask && (C.encodedMaskData = g.mask.bitset ? g.mask.bitset : null), a.returnFileInfo && (C.fileInfo = m(g), a.computeUsedBitDepths && (C.fileInfo.bitDepths = z(g))), C;
28
+ };
29
+ var u = function(I, a, Q, g, r) {
30
+ var B = 0, C = I.pixels.numBlocksX, t = I.pixels.numBlocksY, o = Math.floor(I.width / C), s = Math.floor(I.height / t), n = 2 * I.maxZError, e = Number.MAX_VALUE, i;
31
+ Q = Q || (I.mask ? I.mask.bitset : null);
32
+ var w, y;
33
+ w = new a(I.width * I.height), r && Q && (y = new Uint8Array(I.width * I.height));
34
+ for (var S = new Float32Array(o * s), f, k, G = 0; G <= t; G++) {
35
+ var R = G !== t ? s : I.height % t;
36
+ if (R !== 0)
37
+ for (var h = 0; h <= C; h++) {
38
+ var D = h !== C ? o : I.width % C;
39
+ if (D !== 0) {
40
+ var l = G * I.width * s + h * o, F = I.width - D, c = I.pixels.blocks[B], d, U, M;
41
+ c.encoding < 2 ? (c.encoding === 0 ? d = c.rawData : (A(c.stuffedData, c.bitsPerPixel, c.numValidPixels, c.offset, n, S, I.pixels.maxValue), d = S), U = 0) : c.encoding === 2 ? M = 0 : M = c.offset;
42
+ var J;
43
+ if (Q)
44
+ for (k = 0; k < R; k++) {
45
+ for (l & 7 && (J = Q[l >> 3], J <<= l & 7), f = 0; f < D; f++)
46
+ l & 7 || (J = Q[l >> 3]), J & 128 ? (y && (y[l] = 1), i = c.encoding < 2 ? d[U++] : M, e = e > i ? i : e, w[l++] = i) : (y && (y[l] = 0), w[l++] = g), J <<= 1;
47
+ l += F;
48
+ }
49
+ else if (c.encoding < 2)
50
+ for (k = 0; k < R; k++) {
51
+ for (f = 0; f < D; f++)
52
+ i = d[U++], e = e > i ? i : e, w[l++] = i;
53
+ l += F;
54
+ }
55
+ else
56
+ for (e = e > M ? M : e, k = 0; k < R; k++) {
57
+ for (f = 0; f < D; f++)
58
+ w[l++] = M;
59
+ l += F;
60
+ }
61
+ if (c.encoding === 1 && U !== c.numValidPixels)
62
+ throw "Block and Mask do not match";
63
+ B++;
64
+ }
65
+ }
66
+ }
67
+ return {
68
+ resultPixels: w,
69
+ resultMask: y,
70
+ minValue: e
71
+ };
72
+ }, m = function(I) {
73
+ return {
74
+ fileIdentifierString: I.fileIdentifierString,
75
+ fileVersion: I.fileVersion,
76
+ imageType: I.imageType,
77
+ height: I.height,
78
+ width: I.width,
79
+ maxZError: I.maxZError,
80
+ eofOffset: I.eofOffset,
81
+ mask: I.mask ? {
82
+ numBlocksX: I.mask.numBlocksX,
83
+ numBlocksY: I.mask.numBlocksY,
84
+ numBytes: I.mask.numBytes,
85
+ maxValue: I.mask.maxValue
86
+ } : null,
87
+ pixels: {
88
+ numBlocksX: I.pixels.numBlocksX,
89
+ numBlocksY: I.pixels.numBlocksY,
90
+ numBytes: I.pixels.numBytes,
91
+ maxValue: I.pixels.maxValue,
92
+ noDataValue: I.noDataValue
93
+ }
94
+ };
95
+ }, z = function(I) {
96
+ for (var a = I.pixels.numBlocksX * I.pixels.numBlocksY, Q = {}, g = 0; g < a; g++) {
97
+ var r = I.pixels.blocks[g];
98
+ r.encoding === 0 ? Q.float32 = !0 : r.encoding === 1 ? Q[r.bitsPerPixel] = !0 : Q[0] = !0;
99
+ }
100
+ return Object.keys(Q);
101
+ }, E = function(I, a, Q) {
102
+ var g = {}, r = new Uint8Array(I, a, 10);
103
+ if (g.fileIdentifierString = String.fromCharCode.apply(null, r), g.fileIdentifierString.trim() !== "CntZImage")
104
+ throw "Unexpected file identifier string: " + g.fileIdentifierString;
105
+ a += 10;
106
+ var B = new DataView(I, a, 24);
107
+ if (g.fileVersion = B.getInt32(0, !0), g.imageType = B.getInt32(4, !0), g.height = B.getUint32(8, !0), g.width = B.getUint32(12, !0), g.maxZError = B.getFloat64(16, !0), a += 24, !Q)
108
+ if (B = new DataView(I, a, 16), g.mask = {}, g.mask.numBlocksY = B.getUint32(0, !0), g.mask.numBlocksX = B.getUint32(4, !0), g.mask.numBytes = B.getUint32(8, !0), g.mask.maxValue = B.getFloat32(12, !0), a += 16, g.mask.numBytes > 0) {
109
+ var C = new Uint8Array(Math.ceil(g.width * g.height / 8));
110
+ B = new DataView(I, a, g.mask.numBytes);
111
+ var t = B.getInt16(0, !0), o = 2, s = 0;
112
+ do {
113
+ if (t > 0)
114
+ for (; t--; )
115
+ C[s++] = B.getUint8(o++);
116
+ else {
117
+ var n = B.getUint8(o++);
118
+ for (t = -t; t--; )
119
+ C[s++] = n;
120
+ }
121
+ t = B.getInt16(o, !0), o += 2;
122
+ } while (o < g.mask.numBytes);
123
+ if (t !== -32768 || s < C.length)
124
+ throw "Unexpected end of mask RLE encoding";
125
+ g.mask.bitset = C, a += g.mask.numBytes;
126
+ } else !(g.mask.numBytes | g.mask.numBlocksY | g.mask.maxValue) && (g.mask.bitset = new Uint8Array(Math.ceil(g.width * g.height / 8)));
127
+ B = new DataView(I, a, 16), g.pixels = {}, g.pixels.numBlocksY = B.getUint32(0, !0), g.pixels.numBlocksX = B.getUint32(4, !0), g.pixels.numBytes = B.getUint32(8, !0), g.pixels.maxValue = B.getFloat32(12, !0), a += 16;
128
+ var e = g.pixels.numBlocksX, i = g.pixels.numBlocksY, w = e + (g.width % e > 0 ? 1 : 0), y = i + (g.height % i > 0 ? 1 : 0);
129
+ g.pixels.blocks = new Array(w * y);
130
+ for (var S = 0, f = 0; f < y; f++)
131
+ for (var k = 0; k < w; k++) {
132
+ var G = 0, R = I.byteLength - a;
133
+ B = new DataView(I, a, Math.min(10, R));
134
+ var h = {};
135
+ g.pixels.blocks[S++] = h;
136
+ var D = B.getUint8(0);
137
+ if (G++, h.encoding = D & 63, h.encoding > 3)
138
+ throw "Invalid block encoding (" + h.encoding + ")";
139
+ if (h.encoding === 2) {
140
+ a++;
141
+ continue;
142
+ }
143
+ if (D !== 0 && D !== 2) {
144
+ if (D >>= 6, h.offsetType = D, D === 2)
145
+ h.offset = B.getInt8(1), G++;
146
+ else if (D === 1)
147
+ h.offset = B.getInt16(1, !0), G += 2;
148
+ else if (D === 0)
149
+ h.offset = B.getFloat32(1, !0), G += 4;
150
+ else
151
+ throw "Invalid block offset type";
152
+ if (h.encoding === 1)
153
+ if (D = B.getUint8(G), G++, h.bitsPerPixel = D & 63, D >>= 6, h.numValidPixelsType = D, D === 2)
154
+ h.numValidPixels = B.getUint8(G), G++;
155
+ else if (D === 1)
156
+ h.numValidPixels = B.getUint16(G, !0), G += 2;
157
+ else if (D === 0)
158
+ h.numValidPixels = B.getUint32(G, !0), G += 4;
159
+ else
160
+ throw "Invalid valid pixel count type";
161
+ }
162
+ if (a += G, h.encoding !== 3) {
163
+ var l, F;
164
+ if (h.encoding === 0) {
165
+ var c = (g.pixels.numBytes - 1) / 4;
166
+ if (c !== Math.floor(c))
167
+ throw "uncompressed block has invalid length";
168
+ l = new ArrayBuffer(c * 4), F = new Uint8Array(l), F.set(new Uint8Array(I, a, c * 4));
169
+ var d = new Float32Array(l);
170
+ h.rawData = d, a += c * 4;
171
+ } else if (h.encoding === 1) {
172
+ var U = Math.ceil(h.numValidPixels * h.bitsPerPixel / 8), M = Math.ceil(U / 4);
173
+ l = new ArrayBuffer(M * 4), F = new Uint8Array(l), F.set(new Uint8Array(I, a, U)), h.stuffedData = new Uint32Array(l), a += U;
174
+ }
175
+ }
176
+ }
177
+ return g.eofOffset = a, g;
178
+ }, A = function(I, a, Q, g, r, B, C) {
179
+ var t = (1 << a) - 1, o = 0, s, n = 0, e, i, w = Math.ceil((C - g) / r), y = I.length * 4 - Math.ceil(a * Q / 8);
180
+ for (I[I.length - 1] <<= 8 * y, s = 0; s < Q; s++) {
181
+ if (n === 0 && (i = I[o++], n = 32), n >= a)
182
+ e = i >>> n - a & t, n -= a;
183
+ else {
184
+ var S = a - n;
185
+ e = (i & t) << S & t, i = I[o++], n = 32 - S, e += i >>> n;
186
+ }
187
+ B[s] = e < w ? g + e * r : C;
188
+ }
189
+ return B;
190
+ };
191
+ return L;
192
+ }(), P = /* @__PURE__ */ function() {
193
+ var L = {
194
+ //methods ending with 2 are for the new byte order used by Lerc2.3 and above.
195
+ //originalUnstuff is used to unpack Huffman code table. code is duplicated to unstuffx for performance reasons.
196
+ unstuff: function(E, A, I, a, Q, g, r, B) {
197
+ var C = (1 << I) - 1, t = 0, o, s = 0, n, e, i, w, y = E.length * 4 - Math.ceil(I * a / 8);
198
+ if (E[E.length - 1] <<= 8 * y, Q)
199
+ for (o = 0; o < a; o++)
200
+ s === 0 && (e = E[t++], s = 32), s >= I ? (n = e >>> s - I & C, s -= I) : (i = I - s, n = (e & C) << i & C, e = E[t++], s = 32 - i, n += e >>> s), A[o] = Q[n];
201
+ else
202
+ for (w = Math.ceil((B - g) / r), o = 0; o < a; o++)
203
+ s === 0 && (e = E[t++], s = 32), s >= I ? (n = e >>> s - I & C, s -= I) : (i = I - s, n = (e & C) << i & C, e = E[t++], s = 32 - i, n += e >>> s), A[o] = n < w ? g + n * r : B;
204
+ },
205
+ unstuffLUT: function(E, A, I, a, Q, g) {
206
+ var r = (1 << A) - 1, B = 0, C = 0, t = 0, o = 0, s = 0, n, e = [], i = E.length * 4 - Math.ceil(A * I / 8);
207
+ E[E.length - 1] <<= 8 * i;
208
+ var w = Math.ceil((g - a) / Q);
209
+ for (C = 0; C < I; C++)
210
+ o === 0 && (n = E[B++], o = 32), o >= A ? (s = n >>> o - A & r, o -= A) : (t = A - o, s = (n & r) << t & r, n = E[B++], o = 32 - t, s += n >>> o), e[C] = s < w ? a + s * Q : g;
211
+ return e.unshift(a), e;
212
+ },
213
+ unstuff2: function(E, A, I, a, Q, g, r, B) {
214
+ var C = (1 << I) - 1, t = 0, o, s = 0, n = 0, e, i, w;
215
+ if (Q)
216
+ for (o = 0; o < a; o++)
217
+ s === 0 && (i = E[t++], s = 32, n = 0), s >= I ? (e = i >>> n & C, s -= I, n += I) : (w = I - s, e = i >>> n & C, i = E[t++], s = 32 - w, e |= (i & (1 << w) - 1) << I - w, n = w), A[o] = Q[e];
218
+ else {
219
+ var y = Math.ceil((B - g) / r);
220
+ for (o = 0; o < a; o++)
221
+ s === 0 && (i = E[t++], s = 32, n = 0), s >= I ? (e = i >>> n & C, s -= I, n += I) : (w = I - s, e = i >>> n & C, i = E[t++], s = 32 - w, e |= (i & (1 << w) - 1) << I - w, n = w), A[o] = e < y ? g + e * r : B;
222
+ }
223
+ return A;
224
+ },
225
+ unstuffLUT2: function(E, A, I, a, Q, g) {
226
+ var r = (1 << A) - 1, B = 0, C = 0, t = 0, o = 0, s = 0, n = 0, e, i = [], w = Math.ceil((g - a) / Q);
227
+ for (C = 0; C < I; C++)
228
+ o === 0 && (e = E[B++], o = 32, n = 0), o >= A ? (s = e >>> n & r, o -= A, n += A) : (t = A - o, s = e >>> n & r, e = E[B++], o = 32 - t, s |= (e & (1 << t) - 1) << A - t, n = t), i[C] = s < w ? a + s * Q : g;
229
+ return i.unshift(a), i;
230
+ },
231
+ originalUnstuff: function(E, A, I, a) {
232
+ var Q = (1 << I) - 1, g = 0, r, B = 0, C, t, o, s = E.length * 4 - Math.ceil(I * a / 8);
233
+ for (E[E.length - 1] <<= 8 * s, r = 0; r < a; r++)
234
+ B === 0 && (t = E[g++], B = 32), B >= I ? (C = t >>> B - I & Q, B -= I) : (o = I - B, C = (t & Q) << o & Q, t = E[g++], B = 32 - o, C += t >>> B), A[r] = C;
235
+ return A;
236
+ },
237
+ originalUnstuff2: function(E, A, I, a) {
238
+ var Q = (1 << I) - 1, g = 0, r, B = 0, C = 0, t, o, s;
239
+ for (r = 0; r < a; r++)
240
+ B === 0 && (o = E[g++], B = 32, C = 0), B >= I ? (t = o >>> C & Q, B -= I, C += I) : (s = I - B, t = o >>> C & Q, o = E[g++], B = 32 - s, t |= (o & (1 << s) - 1) << I - s, C = s), A[r] = t;
241
+ return A;
242
+ }
243
+ }, u = {
244
+ HUFFMAN_LUT_BITS_MAX: 12,
245
+ //use 2^12 lut, treat it like constant
246
+ computeChecksumFletcher32: function(E) {
247
+ for (var A = 65535, I = 65535, a = E.length, Q = Math.floor(a / 2), g = 0; Q; ) {
248
+ var r = Q >= 359 ? 359 : Q;
249
+ Q -= r;
250
+ do
251
+ A += E[g++] << 8, I += A += E[g++];
252
+ while (--r);
253
+ A = (A & 65535) + (A >>> 16), I = (I & 65535) + (I >>> 16);
254
+ }
255
+ return a & 1 && (I += A += E[g] << 8), A = (A & 65535) + (A >>> 16), I = (I & 65535) + (I >>> 16), (I << 16 | A) >>> 0;
256
+ },
257
+ readHeaderInfo: function(E, A) {
258
+ var I = A.ptr, a = new Uint8Array(E, I, 6), Q = {};
259
+ if (Q.fileIdentifierString = String.fromCharCode.apply(null, a), Q.fileIdentifierString.lastIndexOf("Lerc2", 0) !== 0)
260
+ throw "Unexpected file identifier string (expect Lerc2 ): " + Q.fileIdentifierString;
261
+ I += 6;
262
+ var g = new DataView(E, I, 8), r = g.getInt32(0, !0);
263
+ Q.fileVersion = r, I += 4, r >= 3 && (Q.checksum = g.getUint32(4, !0), I += 4), g = new DataView(E, I, 12), Q.height = g.getUint32(0, !0), Q.width = g.getUint32(4, !0), I += 8, r >= 4 ? (Q.numDims = g.getUint32(8, !0), I += 4) : Q.numDims = 1, g = new DataView(E, I, 40), Q.numValidPixel = g.getUint32(0, !0), Q.microBlockSize = g.getInt32(4, !0), Q.blobSize = g.getInt32(8, !0), Q.imageType = g.getInt32(12, !0), Q.maxZError = g.getFloat64(16, !0), Q.zMin = g.getFloat64(24, !0), Q.zMax = g.getFloat64(32, !0), I += 40, A.headerInfo = Q, A.ptr = I;
264
+ var B, C;
265
+ if (r >= 3 && (C = r >= 4 ? 52 : 48, B = this.computeChecksumFletcher32(new Uint8Array(E, I - C, Q.blobSize - 14)), B !== Q.checksum))
266
+ throw "Checksum failed.";
267
+ return !0;
268
+ },
269
+ checkMinMaxRanges: function(E, A) {
270
+ var I = A.headerInfo, a = this.getDataTypeArray(I.imageType), Q = I.numDims * this.getDataTypeSize(I.imageType), g = this.readSubArray(E, A.ptr, a, Q), r = this.readSubArray(E, A.ptr + Q, a, Q);
271
+ A.ptr += 2 * Q;
272
+ var B, C = !0;
273
+ for (B = 0; B < I.numDims; B++)
274
+ if (g[B] !== r[B]) {
275
+ C = !1;
276
+ break;
277
+ }
278
+ return I.minValues = g, I.maxValues = r, C;
279
+ },
280
+ readSubArray: function(E, A, I, a) {
281
+ var Q;
282
+ if (I === Uint8Array)
283
+ Q = new Uint8Array(E, A, a);
284
+ else {
285
+ var g = new ArrayBuffer(a), r = new Uint8Array(g);
286
+ r.set(new Uint8Array(E, A, a)), Q = new I(g);
287
+ }
288
+ return Q;
289
+ },
290
+ readMask: function(E, A) {
291
+ var I = A.ptr, a = A.headerInfo, Q = a.width * a.height, g = a.numValidPixel, r = new DataView(E, I, 4), B = {};
292
+ if (B.numBytes = r.getUint32(0, !0), I += 4, (g === 0 || Q === g) && B.numBytes !== 0)
293
+ throw "invalid mask";
294
+ var C, t;
295
+ if (g === 0)
296
+ C = new Uint8Array(Math.ceil(Q / 8)), B.bitset = C, t = new Uint8Array(Q), A.pixels.resultMask = t, I += B.numBytes;
297
+ else if (B.numBytes > 0) {
298
+ C = new Uint8Array(Math.ceil(Q / 8)), r = new DataView(E, I, B.numBytes);
299
+ var o = r.getInt16(0, !0), s = 2, n = 0, e = 0;
300
+ do {
301
+ if (o > 0)
302
+ for (; o--; )
303
+ C[n++] = r.getUint8(s++);
304
+ else
305
+ for (e = r.getUint8(s++), o = -o; o--; )
306
+ C[n++] = e;
307
+ o = r.getInt16(s, !0), s += 2;
308
+ } while (s < B.numBytes);
309
+ if (o !== -32768 || n < C.length)
310
+ throw "Unexpected end of mask RLE encoding";
311
+ t = new Uint8Array(Q);
312
+ var i = 0, w = 0;
313
+ for (w = 0; w < Q; w++)
314
+ w & 7 ? (i = C[w >> 3], i <<= w & 7) : i = C[w >> 3], i & 128 && (t[w] = 1);
315
+ A.pixels.resultMask = t, B.bitset = C, I += B.numBytes;
316
+ }
317
+ return A.ptr = I, A.mask = B, !0;
318
+ },
319
+ readDataOneSweep: function(E, A, I, a) {
320
+ var Q = A.ptr, g = A.headerInfo, r = g.numDims, B = g.width * g.height, C = g.imageType, t = g.numValidPixel * u.getDataTypeSize(C) * r, o, s = A.pixels.resultMask;
321
+ if (I === Uint8Array)
322
+ o = new Uint8Array(E, Q, t);
323
+ else {
324
+ var n = new ArrayBuffer(t), e = new Uint8Array(n);
325
+ e.set(new Uint8Array(E, Q, t)), o = new I(n);
326
+ }
327
+ if (o.length === B * r)
328
+ a ? A.pixels.resultPixels = u.swapDimensionOrder(o, B, r, I, !0) : A.pixels.resultPixels = o;
329
+ else {
330
+ A.pixels.resultPixels = new I(B * r);
331
+ var i = 0, w = 0, y = 0, S = 0;
332
+ if (r > 1) {
333
+ if (a) {
334
+ for (w = 0; w < B; w++)
335
+ if (s[w])
336
+ for (S = w, y = 0; y < r; y++, S += B)
337
+ A.pixels.resultPixels[S] = o[i++];
338
+ } else
339
+ for (w = 0; w < B; w++)
340
+ if (s[w])
341
+ for (S = w * r, y = 0; y < r; y++)
342
+ A.pixels.resultPixels[S + y] = o[i++];
343
+ } else
344
+ for (w = 0; w < B; w++)
345
+ s[w] && (A.pixels.resultPixels[w] = o[i++]);
346
+ }
347
+ return Q += t, A.ptr = Q, !0;
348
+ },
349
+ readHuffmanTree: function(E, A) {
350
+ var I = this.HUFFMAN_LUT_BITS_MAX, a = new DataView(E, A.ptr, 16);
351
+ A.ptr += 16;
352
+ var Q = a.getInt32(0, !0);
353
+ if (Q < 2)
354
+ throw "unsupported Huffman version";
355
+ var g = a.getInt32(4, !0), r = a.getInt32(8, !0), B = a.getInt32(12, !0);
356
+ if (r >= B)
357
+ return !1;
358
+ var C = new Uint32Array(B - r);
359
+ u.decodeBits(E, A, C);
360
+ var t = [], o, s, n, e;
361
+ for (o = r; o < B; o++)
362
+ s = o - (o < g ? 0 : g), t[s] = { first: C[o - r], second: null };
363
+ var i = E.byteLength - A.ptr, w = Math.ceil(i / 4), y = new ArrayBuffer(w * 4), S = new Uint8Array(y);
364
+ S.set(new Uint8Array(E, A.ptr, i));
365
+ var f = new Uint32Array(y), k = 0, G, R = 0;
366
+ for (G = f[0], o = r; o < B; o++)
367
+ s = o - (o < g ? 0 : g), e = t[s].first, e > 0 && (t[s].second = G << k >>> 32 - e, 32 - k >= e ? (k += e, k === 32 && (k = 0, R++, G = f[R])) : (k += e - 32, R++, G = f[R], t[s].second |= G >>> 32 - k));
368
+ var h = 0, D = 0, l = new m();
369
+ for (o = 0; o < t.length; o++)
370
+ t[o] !== void 0 && (h = Math.max(h, t[o].first));
371
+ h >= I ? D = I : D = h;
372
+ var F = [], c, d, U, M, J, q;
373
+ for (o = r; o < B; o++)
374
+ if (s = o - (o < g ? 0 : g), e = t[s].first, e > 0)
375
+ if (c = [e, s], e <= D)
376
+ for (d = t[s].second << D - e, U = 1 << D - e, n = 0; n < U; n++)
377
+ F[d | n] = c;
378
+ else
379
+ for (d = t[s].second, q = l, M = e - 1; M >= 0; M--)
380
+ J = d >>> M & 1, J ? (q.right || (q.right = new m()), q = q.right) : (q.left || (q.left = new m()), q = q.left), M === 0 && !q.val && (q.val = c[1]);
381
+ return {
382
+ decodeLut: F,
383
+ numBitsLUTQick: D,
384
+ numBitsLUT: h,
385
+ tree: l,
386
+ stuffedData: f,
387
+ srcPtr: R,
388
+ bitPos: k
389
+ };
390
+ },
391
+ readHuffman: function(E, A, I, a) {
392
+ var Q = A.headerInfo, g = Q.numDims, r = A.headerInfo.height, B = A.headerInfo.width, C = B * r, t = this.readHuffmanTree(E, A), o = t.decodeLut, s = t.tree, n = t.stuffedData, e = t.srcPtr, i = t.bitPos, w = t.numBitsLUTQick, y = t.numBitsLUT, S = A.headerInfo.imageType === 0 ? 128 : 0, f, k, G, R = A.pixels.resultMask, h, D, l, F, c, d, U, M = 0;
393
+ i > 0 && (e++, i = 0);
394
+ var J = n[e], q = A.encodeMode === 1, O = new I(C * g), p = O, Y;
395
+ if (g < 2 || q) {
396
+ for (Y = 0; Y < g; Y++)
397
+ if (g > 1 && (p = new I(O.buffer, C * Y, C), M = 0), A.headerInfo.numValidPixel === B * r)
398
+ for (d = 0, F = 0; F < r; F++)
399
+ for (c = 0; c < B; c++, d++) {
400
+ if (k = 0, h = J << i >>> 32 - w, D = h, 32 - i < w && (h |= n[e + 1] >>> 64 - i - w, D = h), o[D])
401
+ k = o[D][1], i += o[D][0];
402
+ else
403
+ for (h = J << i >>> 32 - y, D = h, 32 - i < y && (h |= n[e + 1] >>> 64 - i - y, D = h), f = s, U = 0; U < y; U++)
404
+ if (l = h >>> y - U - 1 & 1, f = l ? f.right : f.left, !(f.left || f.right)) {
405
+ k = f.val, i = i + U + 1;
406
+ break;
407
+ }
408
+ i >= 32 && (i -= 32, e++, J = n[e]), G = k - S, q ? (c > 0 ? G += M : F > 0 ? G += p[d - B] : G += M, G &= 255, p[d] = G, M = G) : p[d] = G;
409
+ }
410
+ else
411
+ for (d = 0, F = 0; F < r; F++)
412
+ for (c = 0; c < B; c++, d++)
413
+ if (R[d]) {
414
+ if (k = 0, h = J << i >>> 32 - w, D = h, 32 - i < w && (h |= n[e + 1] >>> 64 - i - w, D = h), o[D])
415
+ k = o[D][1], i += o[D][0];
416
+ else
417
+ for (h = J << i >>> 32 - y, D = h, 32 - i < y && (h |= n[e + 1] >>> 64 - i - y, D = h), f = s, U = 0; U < y; U++)
418
+ if (l = h >>> y - U - 1 & 1, f = l ? f.right : f.left, !(f.left || f.right)) {
419
+ k = f.val, i = i + U + 1;
420
+ break;
421
+ }
422
+ i >= 32 && (i -= 32, e++, J = n[e]), G = k - S, q ? (c > 0 && R[d - 1] ? G += M : F > 0 && R[d - B] ? G += p[d - B] : G += M, G &= 255, p[d] = G, M = G) : p[d] = G;
423
+ }
424
+ } else
425
+ for (d = 0, F = 0; F < r; F++)
426
+ for (c = 0; c < B; c++)
427
+ if (d = F * B + c, !R || R[d])
428
+ for (Y = 0; Y < g; Y++, d += C) {
429
+ if (k = 0, h = J << i >>> 32 - w, D = h, 32 - i < w && (h |= n[e + 1] >>> 64 - i - w, D = h), o[D])
430
+ k = o[D][1], i += o[D][0];
431
+ else
432
+ for (h = J << i >>> 32 - y, D = h, 32 - i < y && (h |= n[e + 1] >>> 64 - i - y, D = h), f = s, U = 0; U < y; U++)
433
+ if (l = h >>> y - U - 1 & 1, f = l ? f.right : f.left, !(f.left || f.right)) {
434
+ k = f.val, i = i + U + 1;
435
+ break;
436
+ }
437
+ i >= 32 && (i -= 32, e++, J = n[e]), G = k - S, p[d] = G;
438
+ }
439
+ A.ptr = A.ptr + (e + 1) * 4 + (i > 0 ? 4 : 0), A.pixels.resultPixels = O, g > 1 && !a && (A.pixels.resultPixels = u.swapDimensionOrder(O, C, g, I));
440
+ },
441
+ decodeBits: function(E, A, I, a, Q) {
442
+ {
443
+ var g = A.headerInfo, r = g.fileVersion, B = 0, C = E.byteLength - A.ptr >= 5 ? 5 : E.byteLength - A.ptr, t = new DataView(E, A.ptr, C), o = t.getUint8(0);
444
+ B++;
445
+ var s = o >> 6, n = s === 0 ? 4 : 3 - s, e = (o & 32) > 0, i = o & 31, w = 0;
446
+ if (n === 1)
447
+ w = t.getUint8(B), B++;
448
+ else if (n === 2)
449
+ w = t.getUint16(B, !0), B += 2;
450
+ else if (n === 4)
451
+ w = t.getUint32(B, !0), B += 4;
452
+ else
453
+ throw "Invalid valid pixel count type";
454
+ var y = 2 * g.maxZError, S, f, k, G, R, h, D, l, F, c = g.numDims > 1 ? g.maxValues[Q] : g.zMax;
455
+ if (e) {
456
+ for (A.counter.lut++, l = t.getUint8(B), B++, G = Math.ceil((l - 1) * i / 8), R = Math.ceil(G / 4), f = new ArrayBuffer(R * 4), k = new Uint8Array(f), A.ptr += B, k.set(new Uint8Array(E, A.ptr, G)), D = new Uint32Array(f), A.ptr += G, F = 0; l - 1 >>> F; )
457
+ F++;
458
+ G = Math.ceil(w * F / 8), R = Math.ceil(G / 4), f = new ArrayBuffer(R * 4), k = new Uint8Array(f), k.set(new Uint8Array(E, A.ptr, G)), S = new Uint32Array(f), A.ptr += G, r >= 3 ? h = L.unstuffLUT2(D, i, l - 1, a, y, c) : h = L.unstuffLUT(D, i, l - 1, a, y, c), r >= 3 ? L.unstuff2(S, I, F, w, h) : L.unstuff(S, I, F, w, h);
459
+ } else
460
+ A.counter.bitstuffer++, F = i, A.ptr += B, F > 0 && (G = Math.ceil(w * F / 8), R = Math.ceil(G / 4), f = new ArrayBuffer(R * 4), k = new Uint8Array(f), k.set(new Uint8Array(E, A.ptr, G)), S = new Uint32Array(f), A.ptr += G, r >= 3 ? a == null ? L.originalUnstuff2(S, I, F, w) : L.unstuff2(S, I, F, w, !1, a, y, c) : a == null ? L.originalUnstuff(S, I, F, w) : L.unstuff(S, I, F, w, !1, a, y, c));
461
+ }
462
+ },
463
+ readTiles: function(E, A, I, a) {
464
+ var Q = A.headerInfo, g = Q.width, r = Q.height, B = g * r, C = Q.microBlockSize, t = Q.imageType, o = u.getDataTypeSize(t), s = Math.ceil(g / C), n = Math.ceil(r / C);
465
+ A.pixels.numBlocksY = n, A.pixels.numBlocksX = s, A.pixels.ptr = 0;
466
+ var e = 0, i = 0, w = 0, y = 0, S = 0, f = 0, k = 0, G = 0, R = 0, h = 0, D = 0, l = 0, F = 0, c = 0, d = 0, U = 0, M, J, q, O, p, Y, j = new I(C * C), aA = r % C || C, oA = g % C || C, AA, T, _ = Q.numDims, X, H = A.pixels.resultMask, x = A.pixels.resultPixels, tA = Q.fileVersion, CA = tA >= 5 ? 14 : 15, V, IA = Q.zMax, b;
467
+ for (w = 0; w < n; w++)
468
+ for (S = w !== n - 1 ? C : aA, y = 0; y < s; y++)
469
+ for (f = y !== s - 1 ? C : oA, D = w * g * C + y * C, l = g - f, X = 0; X < _; X++) {
470
+ if (_ > 1 ? (b = x, D = w * g * C + y * C, x = new I(A.pixels.resultPixels.buffer, B * X * o, B), IA = Q.maxValues[X]) : b = null, k = E.byteLength - A.ptr, M = new DataView(E, A.ptr, Math.min(10, k)), J = {}, U = 0, G = M.getUint8(0), U++, V = Q.fileVersion >= 5 ? G & 4 : 0, R = G >> 6 & 255, h = G >> 2 & CA, h !== (y * C >> 3 & CA) || V && X === 0)
471
+ throw "integrity issue";
472
+ if (Y = G & 3, Y > 3)
473
+ throw A.ptr += U, "Invalid block encoding (" + Y + ")";
474
+ if (Y === 2) {
475
+ if (V)
476
+ if (H)
477
+ for (e = 0; e < S; e++)
478
+ for (i = 0; i < f; i++)
479
+ H[D] && (x[D] = b[D]), D++;
480
+ else
481
+ for (e = 0; e < S; e++)
482
+ for (i = 0; i < f; i++)
483
+ x[D] = b[D], D++;
484
+ A.counter.constant++, A.ptr += U;
485
+ continue;
486
+ } else if (Y === 0) {
487
+ if (V)
488
+ throw "integrity issue";
489
+ if (A.counter.uncompressed++, A.ptr += U, F = S * f * o, c = E.byteLength - A.ptr, F = F < c ? F : c, q = new ArrayBuffer(F % o === 0 ? F : F + o - F % o), O = new Uint8Array(q), O.set(new Uint8Array(E, A.ptr, F)), p = new I(q), d = 0, H)
490
+ for (e = 0; e < S; e++) {
491
+ for (i = 0; i < f; i++)
492
+ H[D] && (x[D] = p[d++]), D++;
493
+ D += l;
494
+ }
495
+ else
496
+ for (e = 0; e < S; e++) {
497
+ for (i = 0; i < f; i++)
498
+ x[D++] = p[d++];
499
+ D += l;
500
+ }
501
+ A.ptr += d * o;
502
+ } else if (AA = u.getDataTypeUsed(V && t < 6 ? 4 : t, R), T = u.getOnePixel(J, U, AA, M), U += u.getDataTypeSize(AA), Y === 3)
503
+ if (A.ptr += U, A.counter.constantoffset++, H)
504
+ for (e = 0; e < S; e++) {
505
+ for (i = 0; i < f; i++)
506
+ H[D] && (x[D] = V ? Math.min(IA, b[D] + T) : T), D++;
507
+ D += l;
508
+ }
509
+ else
510
+ for (e = 0; e < S; e++) {
511
+ for (i = 0; i < f; i++)
512
+ x[D] = V ? Math.min(IA, b[D] + T) : T, D++;
513
+ D += l;
514
+ }
515
+ else if (A.ptr += U, u.decodeBits(E, A, j, T, X), U = 0, V)
516
+ if (H)
517
+ for (e = 0; e < S; e++) {
518
+ for (i = 0; i < f; i++)
519
+ H[D] && (x[D] = j[U++] + b[D]), D++;
520
+ D += l;
521
+ }
522
+ else
523
+ for (e = 0; e < S; e++) {
524
+ for (i = 0; i < f; i++)
525
+ x[D] = j[U++] + b[D], D++;
526
+ D += l;
527
+ }
528
+ else if (H)
529
+ for (e = 0; e < S; e++) {
530
+ for (i = 0; i < f; i++)
531
+ H[D] && (x[D] = j[U++]), D++;
532
+ D += l;
533
+ }
534
+ else
535
+ for (e = 0; e < S; e++) {
536
+ for (i = 0; i < f; i++)
537
+ x[D++] = j[U++];
538
+ D += l;
539
+ }
540
+ }
541
+ _ > 1 && !a && (A.pixels.resultPixels = u.swapDimensionOrder(A.pixels.resultPixels, B, _, I));
542
+ },
543
+ /*****************
544
+ * private methods (helper methods)
545
+ *****************/
546
+ formatFileInfo: function(E) {
547
+ return {
548
+ fileIdentifierString: E.headerInfo.fileIdentifierString,
549
+ fileVersion: E.headerInfo.fileVersion,
550
+ imageType: E.headerInfo.imageType,
551
+ height: E.headerInfo.height,
552
+ width: E.headerInfo.width,
553
+ numValidPixel: E.headerInfo.numValidPixel,
554
+ microBlockSize: E.headerInfo.microBlockSize,
555
+ blobSize: E.headerInfo.blobSize,
556
+ maxZError: E.headerInfo.maxZError,
557
+ pixelType: u.getPixelType(E.headerInfo.imageType),
558
+ eofOffset: E.eofOffset,
559
+ mask: E.mask ? {
560
+ numBytes: E.mask.numBytes
561
+ } : null,
562
+ pixels: {
563
+ numBlocksX: E.pixels.numBlocksX,
564
+ numBlocksY: E.pixels.numBlocksY,
565
+ //"numBytes": data.pixels.numBytes,
566
+ maxValue: E.headerInfo.zMax,
567
+ minValue: E.headerInfo.zMin,
568
+ noDataValue: E.noDataValue
569
+ }
570
+ };
571
+ },
572
+ constructConstantSurface: function(E, A) {
573
+ var I = E.headerInfo.zMax, a = E.headerInfo.zMin, Q = E.headerInfo.maxValues, g = E.headerInfo.numDims, r = E.headerInfo.height * E.headerInfo.width, B = 0, C = 0, t = 0, o = E.pixels.resultMask, s = E.pixels.resultPixels;
574
+ if (o)
575
+ if (g > 1) {
576
+ if (A)
577
+ for (B = 0; B < g; B++)
578
+ for (t = B * r, I = Q[B], C = 0; C < r; C++)
579
+ o[C] && (s[t + C] = I);
580
+ else
581
+ for (C = 0; C < r; C++)
582
+ if (o[C])
583
+ for (t = C * g, B = 0; B < g; B++)
584
+ s[t + g] = Q[B];
585
+ } else
586
+ for (C = 0; C < r; C++)
587
+ o[C] && (s[C] = I);
588
+ else if (g > 1 && a !== I)
589
+ if (A)
590
+ for (B = 0; B < g; B++)
591
+ for (t = B * r, I = Q[B], C = 0; C < r; C++)
592
+ s[t + C] = I;
593
+ else
594
+ for (C = 0; C < r; C++)
595
+ for (t = C * g, B = 0; B < g; B++)
596
+ s[t + B] = Q[B];
597
+ else
598
+ for (C = 0; C < r * g; C++)
599
+ s[C] = I;
600
+ },
601
+ getDataTypeArray: function(E) {
602
+ var A;
603
+ switch (E) {
604
+ case 0:
605
+ A = Int8Array;
606
+ break;
607
+ case 1:
608
+ A = Uint8Array;
609
+ break;
610
+ case 2:
611
+ A = Int16Array;
612
+ break;
613
+ case 3:
614
+ A = Uint16Array;
615
+ break;
616
+ case 4:
617
+ A = Int32Array;
618
+ break;
619
+ case 5:
620
+ A = Uint32Array;
621
+ break;
622
+ case 6:
623
+ A = Float32Array;
624
+ break;
625
+ case 7:
626
+ A = Float64Array;
627
+ break;
628
+ default:
629
+ A = Float32Array;
630
+ }
631
+ return A;
632
+ },
633
+ getPixelType: function(E) {
634
+ var A;
635
+ switch (E) {
636
+ case 0:
637
+ A = "S8";
638
+ break;
639
+ case 1:
640
+ A = "U8";
641
+ break;
642
+ case 2:
643
+ A = "S16";
644
+ break;
645
+ case 3:
646
+ A = "U16";
647
+ break;
648
+ case 4:
649
+ A = "S32";
650
+ break;
651
+ case 5:
652
+ A = "U32";
653
+ break;
654
+ case 6:
655
+ A = "F32";
656
+ break;
657
+ case 7:
658
+ A = "F64";
659
+ break;
660
+ default:
661
+ A = "F32";
662
+ }
663
+ return A;
664
+ },
665
+ isValidPixelValue: function(E, A) {
666
+ if (A == null)
667
+ return !1;
668
+ var I;
669
+ switch (E) {
670
+ case 0:
671
+ I = A >= -128 && A <= 127;
672
+ break;
673
+ case 1:
674
+ I = A >= 0 && A <= 255;
675
+ break;
676
+ case 2:
677
+ I = A >= -32768 && A <= 32767;
678
+ break;
679
+ case 3:
680
+ I = A >= 0 && A <= 65536;
681
+ break;
682
+ case 4:
683
+ I = A >= -2147483648 && A <= 2147483647;
684
+ break;
685
+ case 5:
686
+ I = A >= 0 && A <= 4294967296;
687
+ break;
688
+ case 6:
689
+ I = A >= -34027999387901484e22 && A <= 34027999387901484e22;
690
+ break;
691
+ case 7:
692
+ I = A >= -17976931348623157e292 && A <= 17976931348623157e292;
693
+ break;
694
+ default:
695
+ I = !1;
696
+ }
697
+ return I;
698
+ },
699
+ getDataTypeSize: function(E) {
700
+ var A = 0;
701
+ switch (E) {
702
+ case 0:
703
+ case 1:
704
+ A = 1;
705
+ break;
706
+ case 2:
707
+ case 3:
708
+ A = 2;
709
+ break;
710
+ case 4:
711
+ case 5:
712
+ case 6:
713
+ A = 4;
714
+ break;
715
+ case 7:
716
+ A = 8;
717
+ break;
718
+ default:
719
+ A = E;
720
+ }
721
+ return A;
722
+ },
723
+ getDataTypeUsed: function(E, A) {
724
+ var I = E;
725
+ switch (E) {
726
+ case 2:
727
+ case 4:
728
+ I = E - A;
729
+ break;
730
+ case 3:
731
+ case 5:
732
+ I = E - 2 * A;
733
+ break;
734
+ case 6:
735
+ A === 0 ? I = E : A === 1 ? I = 2 : I = 1;
736
+ break;
737
+ case 7:
738
+ A === 0 ? I = E : I = E - 2 * A + 1;
739
+ break;
740
+ default:
741
+ I = E;
742
+ break;
743
+ }
744
+ return I;
745
+ },
746
+ getOnePixel: function(E, A, I, a) {
747
+ var Q = 0;
748
+ switch (I) {
749
+ case 0:
750
+ Q = a.getInt8(A);
751
+ break;
752
+ case 1:
753
+ Q = a.getUint8(A);
754
+ break;
755
+ case 2:
756
+ Q = a.getInt16(A, !0);
757
+ break;
758
+ case 3:
759
+ Q = a.getUint16(A, !0);
760
+ break;
761
+ case 4:
762
+ Q = a.getInt32(A, !0);
763
+ break;
764
+ case 5:
765
+ Q = a.getUInt32(A, !0);
766
+ break;
767
+ case 6:
768
+ Q = a.getFloat32(A, !0);
769
+ break;
770
+ case 7:
771
+ Q = a.getFloat64(A, !0);
772
+ break;
773
+ default:
774
+ throw "the decoder does not understand this pixel type";
775
+ }
776
+ return Q;
777
+ },
778
+ swapDimensionOrder: function(E, A, I, a, Q) {
779
+ var g = 0, r = 0, B = 0, C = 0, t = E;
780
+ if (I > 1)
781
+ if (t = new a(A * I), Q)
782
+ for (g = 0; g < A; g++)
783
+ for (C = g, B = 0; B < I; B++, C += A)
784
+ t[C] = E[r++];
785
+ else
786
+ for (g = 0; g < A; g++)
787
+ for (C = g, B = 0; B < I; B++, C += A)
788
+ t[r++] = E[C];
789
+ return t;
790
+ }
791
+ }, m = function(E, A, I) {
792
+ this.val = E, this.left = A, this.right = I;
793
+ }, z = {
794
+ /*
795
+ * ********removed options compared to LERC1. We can bring some of them back if needed.
796
+ * removed pixel type. LERC2 is typed and doesn't require user to give pixel type
797
+ * changed encodedMaskData to maskData. LERC2 's js version make it faster to use maskData directly.
798
+ * removed returnMask. mask is used by LERC2 internally and is cost free. In case of user input mask, it's returned as well and has neglible cost.
799
+ * removed nodatavalue. Because LERC2 pixels are typed, nodatavalue will sacrify a useful value for many types (8bit, 16bit) etc,
800
+ * user has to be knowledgable enough about raster and their data to avoid usability issues. so nodata value is simply removed now.
801
+ * We can add it back later if their's a clear requirement.
802
+ * removed encodedMask. This option was not implemented in LercDecode. It can be done after decoding (less efficient)
803
+ * removed computeUsedBitDepths.
804
+ *
805
+ *
806
+ * response changes compared to LERC1
807
+ * 1. encodedMaskData is not available
808
+ * 2. noDataValue is optional (returns only if user's noDataValue is with in the valid data type range)
809
+ * 3. maskData is always available
810
+ */
811
+ /*****************
812
+ * public properties
813
+ ******************/
814
+ //HUFFMAN_LUT_BITS_MAX: 12, //use 2^12 lut, not configurable
815
+ /*****************
816
+ * public methods
817
+ *****************/
818
+ /**
819
+ * Decode a LERC2 byte stream and return an object containing the pixel data and optional metadata.
820
+ *
821
+ * @param {ArrayBuffer} input The LERC input byte stream
822
+ * @param {object} [options] options Decoding options
823
+ * @param {number} [options.inputOffset] The number of bytes to skip in the input byte stream. A valid LERC file is expected at that position
824
+ * @param {boolean} [options.returnFileInfo] If true, the return value will have a fileInfo property that contains metadata obtained from the LERC headers and the decoding process
825
+ * @param {boolean} [options.returnPixelInterleavedDims] If true, returned dimensions are pixel-interleaved, a.k.a [p1_dim0, p1_dim1, p1_dimn, p2_dim0...], default is [p1_dim0, p2_dim0, ..., p1_dim1, p2_dim1...]
826
+ */
827
+ decode: function(E, A) {
828
+ A = A || {};
829
+ var I = A.noDataValue, a = 0, Q = {};
830
+ if (Q.ptr = A.inputOffset || 0, Q.pixels = {}, !!u.readHeaderInfo(E, Q)) {
831
+ var g = Q.headerInfo, r = g.fileVersion, B = u.getDataTypeArray(g.imageType);
832
+ if (r > 5)
833
+ throw "unsupported lerc version 2." + r;
834
+ u.readMask(E, Q), g.numValidPixel !== g.width * g.height && !Q.pixels.resultMask && (Q.pixels.resultMask = A.maskData);
835
+ var C = g.width * g.height;
836
+ Q.pixels.resultPixels = new B(C * g.numDims), Q.counter = {
837
+ onesweep: 0,
838
+ uncompressed: 0,
839
+ lut: 0,
840
+ bitstuffer: 0,
841
+ constant: 0,
842
+ constantoffset: 0
843
+ };
844
+ var t = !A.returnPixelInterleavedDims;
845
+ if (g.numValidPixel !== 0)
846
+ if (g.zMax === g.zMin)
847
+ u.constructConstantSurface(Q, t);
848
+ else if (r >= 4 && u.checkMinMaxRanges(E, Q))
849
+ u.constructConstantSurface(Q, t);
850
+ else {
851
+ var o = new DataView(E, Q.ptr, 2), s = o.getUint8(0);
852
+ if (Q.ptr++, s)
853
+ u.readDataOneSweep(E, Q, B, t);
854
+ else if (r > 1 && g.imageType <= 1 && Math.abs(g.maxZError - 0.5) < 1e-5) {
855
+ var n = o.getUint8(1);
856
+ if (Q.ptr++, Q.encodeMode = n, n > 2 || r < 4 && n > 1)
857
+ throw "Invalid Huffman flag " + n;
858
+ n ? u.readHuffman(E, Q, B, t) : u.readTiles(E, Q, B, t);
859
+ } else
860
+ u.readTiles(E, Q, B, t);
861
+ }
862
+ Q.eofOffset = Q.ptr;
863
+ var e;
864
+ A.inputOffset ? (e = Q.headerInfo.blobSize + A.inputOffset - Q.ptr, Math.abs(e) >= 1 && (Q.eofOffset = A.inputOffset + Q.headerInfo.blobSize)) : (e = Q.headerInfo.blobSize - Q.ptr, Math.abs(e) >= 1 && (Q.eofOffset = Q.headerInfo.blobSize));
865
+ var i = {
866
+ width: g.width,
867
+ height: g.height,
868
+ pixelData: Q.pixels.resultPixels,
869
+ minValue: g.zMin,
870
+ maxValue: g.zMax,
871
+ validPixelCount: g.numValidPixel,
872
+ dimCount: g.numDims,
873
+ dimStats: {
874
+ minValues: g.minValues,
875
+ maxValues: g.maxValues
876
+ },
877
+ maskData: Q.pixels.resultMask
878
+ //noDataValue: noDataValue
879
+ };
880
+ if (Q.pixels.resultMask && u.isValidPixelValue(g.imageType, I)) {
881
+ var w = Q.pixels.resultMask;
882
+ for (a = 0; a < C; a++)
883
+ w[a] || (i.pixelData[a] = I);
884
+ i.noDataValue = I;
885
+ }
886
+ return Q.noDataValue = I, A.returnFileInfo && (i.fileInfo = u.formatFileInfo(Q)), i;
887
+ }
888
+ },
889
+ getBandCount: function(E) {
890
+ var A = 0, I = 0, a = {};
891
+ for (a.ptr = 0, a.pixels = {}; I < E.byteLength - 58; )
892
+ u.readHeaderInfo(E, a), I += a.headerInfo.blobSize, A++, a.ptr = I;
893
+ return A;
894
+ }
895
+ };
896
+ return z;
897
+ }(), Z = function() {
898
+ var L = new ArrayBuffer(4), u = new Uint8Array(L), m = new Uint32Array(L);
899
+ return m[0] = 1, u[0] === 1;
900
+ }(), v = {
901
+ /************wrapper**********************************************/
902
+ /**
903
+ * A wrapper for decoding both LERC1 and LERC2 byte streams capable of handling multiband pixel blocks for various pixel types.
904
+ *
905
+ * @alias module:Lerc
906
+ * @param {ArrayBuffer} input The LERC input byte stream
907
+ * @param {object} [options] The decoding options below are optional.
908
+ * @param {number} [options.inputOffset] The number of bytes to skip in the input byte stream. A valid Lerc file is expected at that position.
909
+ * @param {string} [options.pixelType] (LERC1 only) Default value is F32. Valid pixel types for input are U8/S8/S16/U16/S32/U32/F32.
910
+ * @param {number} [options.noDataValue] (LERC1 only). It is recommended to use the returned mask instead of setting this value.
911
+ * @param {boolean} [options.returnPixelInterleavedDims] (nDim LERC2 only) If true, returned dimensions are pixel-interleaved, a.k.a [p1_dim0, p1_dim1, p1_dimn, p2_dim0...], default is [p1_dim0, p2_dim0, ..., p1_dim1, p2_dim1...]
912
+ * @returns {{width, height, pixels, pixelType, mask, statistics}}
913
+ * @property {number} width Width of decoded image.
914
+ * @property {number} height Height of decoded image.
915
+ * @property {array} pixels [band1, band2, …] Each band is a typed array of width*height.
916
+ * @property {string} pixelType The type of pixels represented in the output.
917
+ * @property {mask} mask Typed array with a size of width*height, or null if all pixels are valid.
918
+ * @property {array} statistics [statistics_band1, statistics_band2, …] Each element is a statistics object representing min and max values
919
+ **/
920
+ decode: function(L, u) {
921
+ if (!Z)
922
+ throw "Big endian system is not supported.";
923
+ u = u || {};
924
+ var m = u.inputOffset || 0, z = new Uint8Array(L, m, 10), E = String.fromCharCode.apply(null, z), A, I;
925
+ if (E.trim() === "CntZImage")
926
+ A = N, I = 1;
927
+ else if (E.substring(0, 5) === "Lerc2")
928
+ A = P, I = 2;
929
+ else
930
+ throw "Unexpected file identifier string: " + E;
931
+ for (var a = 0, Q = L.byteLength - 10, g, r = [], B, C, t = {
932
+ width: 0,
933
+ height: 0,
934
+ pixels: [],
935
+ pixelType: u.pixelType,
936
+ mask: null,
937
+ statistics: []
938
+ }, o = 0; m < Q; ) {
939
+ var s = A.decode(L, {
940
+ inputOffset: m,
941
+ //for both lerc1 and lerc2
942
+ encodedMaskData: g,
943
+ //lerc1 only
944
+ maskData: C,
945
+ //lerc2 only
946
+ returnMask: a === 0,
947
+ //lerc1 only
948
+ returnEncodedMask: a === 0,
949
+ //lerc1 only
950
+ returnFileInfo: !0,
951
+ //for both lerc1 and lerc2
952
+ returnPixelInterleavedDims: u.returnPixelInterleavedDims,
953
+ //for ndim lerc2 only
954
+ pixelType: u.pixelType || null,
955
+ //lerc1 only
956
+ noDataValue: u.noDataValue || null
957
+ //lerc1 only
958
+ });
959
+ m = s.fileInfo.eofOffset, C = s.maskData, a === 0 && (g = s.encodedMaskData, t.width = s.width, t.height = s.height, t.dimCount = s.dimCount || 1, t.pixelType = s.pixelType || s.fileInfo.pixelType, t.mask = C), I > 1 && (C && r.push(C), s.fileInfo.mask && s.fileInfo.mask.numBytes > 0 && o++), a++, t.pixels.push(s.pixelData), t.statistics.push({
960
+ minValue: s.minValue,
961
+ maxValue: s.maxValue,
962
+ noDataValue: s.noDataValue,
963
+ dimStats: s.dimStats
964
+ });
965
+ }
966
+ var n, e, i;
967
+ if (I > 1 && o > 1) {
968
+ for (i = t.width * t.height, t.bandMasks = r, C = new Uint8Array(i), C.set(r[0]), n = 1; n < r.length; n++)
969
+ for (B = r[n], e = 0; e < i; e++)
970
+ C[e] = C[e] & B[e];
971
+ t.maskData = C;
972
+ }
973
+ return t;
974
+ }
975
+ };
976
+ W.exports ? W.exports = v : this.Lerc = v;
977
+ })();
978
+ }(EA)), EA.exports;
979
+ }
980
+ var hA = wA();
981
+ const fA = /* @__PURE__ */ DA(hA);
982
+ let $, K, QA;
983
+ const BA = {
984
+ env: {
985
+ emscripten_notify_memory_growth: function(W) {
986
+ QA = new Uint8Array(K.exports.memory.buffer);
987
+ }
988
+ }
989
+ };
990
+ class GA {
991
+ init() {
992
+ return $ || (typeof fetch < "u" ? $ = fetch("data:application/wasm;base64," + eA).then((N) => N.arrayBuffer()).then((N) => WebAssembly.instantiate(N, BA)).then(this._init) : $ = WebAssembly.instantiate(Buffer.from(eA, "base64"), BA).then(this._init), $);
993
+ }
994
+ _init(N) {
995
+ K = N.instance, BA.env.emscripten_notify_memory_growth(0);
996
+ }
997
+ decode(N, P = 0) {
998
+ if (!K) throw new Error("ZSTDDecoder: Await .init() before decoding.");
999
+ const Z = N.byteLength, v = K.exports.malloc(Z);
1000
+ QA.set(N, v), P = P || Number(K.exports.ZSTD_findDecompressedSize(v, Z));
1001
+ const L = K.exports.malloc(P), u = K.exports.ZSTD_decompress(L, P, v, Z), m = QA.slice(L, L + u);
1002
+ return K.exports.free(v), K.exports.free(L), m;
1003
+ }
1004
+ }
1005
+ const eA = "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IAMNACAEQQNxBEADQCACRQ0FIAAgAkF/aiICaiIDIAEgAmotAAA6AAAgA0EDcQ0ACwsgAkEDTQ0AA0AgACACQXxqIgJqIAEgAmooAgA2AgAgAkEDSw0ACwsgAkUNAgNAIAAgAkF/aiICaiABIAJqLQAAOgAAIAINAAsMAgsgAkEDTQ0AIAIhBANAIAMgASgCADYCACABQQRqIQEgA0EEaiEDIARBfGoiBEEDSw0ACyACQQNxIQILIAJFDQADQCADIAEtAAA6AAAgA0EBaiEDIAFBAWohASACQX9qIgINAAsLIAAL8wICAn8BfgJAIAJFDQAgACACaiIDQX9qIAE6AAAgACABOgAAIAJBA0kNACADQX5qIAE6AAAgACABOgABIANBfWogAToAACAAIAE6AAIgAkEHSQ0AIANBfGogAToAACAAIAE6AAMgAkEJSQ0AIABBACAAa0EDcSIEaiIDIAFB/wFxQYGChAhsIgE2AgAgAyACIARrQXxxIgRqIgJBfGogATYCACAEQQlJDQAgAyABNgIIIAMgATYCBCACQXhqIAE2AgAgAkF0aiABNgIAIARBGUkNACADIAE2AhggAyABNgIUIAMgATYCECADIAE2AgwgAkFwaiABNgIAIAJBbGogATYCACACQWhqIAE2AgAgAkFkaiABNgIAIAQgA0EEcUEYciIEayICQSBJDQAgAa0iBUIghiAFhCEFIAMgBGohAQNAIAEgBTcDGCABIAU3AxAgASAFNwMIIAEgBTcDACABQSBqIQEgAkFgaiICQR9LDQALCyAACy8BAn8gACgCBCAAKAIAQQJ0aiICLQACIQMgACACLwEAIAEgAi0AAxAIajYCACADCy8BAn8gACgCBCAAKAIAQQJ0aiICLQACIQMgACACLwEAIAEgAi0AAxAFajYCACADCx8AIAAgASACKAIEEAg2AgAgARAEGiAAIAJBCGo2AgQLCAAgAGdBH3MLugUBDX8jAEEQayIKJAACfyAEQQNNBEAgCkEANgIMIApBDGogAyAEEAsaIAAgASACIApBDGpBBBAVIgBBbCAAEAMbIAAgACAESxsMAQsgAEEAIAEoAgBBAXRBAmoQECENQVQgAygAACIGQQ9xIgBBCksNABogAiAAQQVqNgIAIAMgBGoiAkF8aiEMIAJBeWohDiACQXtqIRAgAEEGaiELQQQh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ASIDNgLE4AEgACgCvOABIQQgACABNgK84AEgACABIAJqNgK44AEgACABIAQgA2tqNgLA4AELpgEBAX8gACAAKALs4QEQFjYCyOABIABCADcD+OABIABCADcDuOABIABBwOABakIANwMAIABBqNAAaiIBQYyAgOAANgIAIABBADYCmOIBIABCADcDiOEBIABCAzcDgOEBIABBrNABakHgEikCADcCACAAQbTQAWpB6BIoAgA2AgAgACABNgIMIAAgAEGYIGo2AgggACAAQaAwajYCBCAAIABBEGo2AgALYQEBf0G4fyEDAkAgAUEDSQ0AIAIgABAhIgFBA3YiADYCCCACIAFBAXE2AgQgAiABQQF2QQNxIgM2AgACQCADQX9qIgFBAksNAAJAIAFBAWsOAgEAAgtBbA8LIAAhAwsgAwsMACAAIAEgAkEAEC4LiAQCA38CfiADEBYhBCAAQQBBKBAQIQAgBCACSwRAIAQPCyABRQRAQX8PCwJAAkAgA0EBRg0AIAEoAAAiBkGo6r5pRg0AQXYhAyAGQXBxQdDUtMIBRw0BQQghAyACQQhJDQEgAEEAQSgQECEAIAEoAAQhASAAQQE2AhQgACABrTcDAEEADwsgASACIAMQLyIDIAJLDQAgACADNgIYQXIhAyABIARqIgVBf2otAAAiAkEIcQ0AIAJBIHEiBkUEQEFwIQMgBS0AACIFQacBSw0BIAVBB3GtQgEgBUEDdkEKaq2GIgdCA4h+IAd8IQggBEEBaiEECyACQQZ2IQMgAkECdiEFAkAgAkEDcUF/aiICQQJLBEBBACECDAELAkACQAJAIAJBAWsOAgECAAsgASAEai0AACECIARBAWohBAwCCyABIARqLwAAIQIgBEECaiEEDAELIAEgBGooAAAhAiAEQQRqIQQLIAVBAXEhBQJ+AkACQAJAIANBf2oiA0ECTQRAIANBAWsOAgIDAQtCfyAGRQ0DGiABIARqMQAADAMLIAEgBGovAACtQoACfAwCCyABIARqKAAArQwBCyABIARqKQAACyEHIAAgBTYCICAAIAI2AhwgACAHNwMAQQAhAyAAQQA2AhQgACAHIAggBhsiBzcDCCAAIAdCgIAIIAdCgIAIVBs+AhALIAMLWwEBf0G4fyEDIAIQFiICIAFNBH8gACACakF/ai0AACIAQQNxQQJ0QaAeaigCACACaiAAQQZ2IgFBAnRBsB5qKAIAaiAAQSBxIgBFaiABRSAAQQV2cWoFQbh/CwsdACAAKAKQ4gEQWiAAQQA2AqDiASAAQgA3A5DiAQu1AwEFfyMAQZACayIKJABBuH8hBgJAIAVFDQAgBCwAACIIQf8BcSEHAkAgCEF/TARAIAdBgn9qQQF2IgggBU8NAkFsIQYgB0GBf2oiBUGAAk8NAiAEQQFqIQdBACEGA0AgBiAFTwRAIAUhBiAIIQcMAwUgACAGaiAHIAZBAXZqIgQtAABBBHY6AAAgACAGQQFyaiAELQAAQQ9xOgAAIAZBAmohBgwBCwAACwALIAcgBU8NASAAIARBAWogByAKEFMiBhADDQELIAYhBEEAIQYgAUEAQTQQECEJQQAhBQNAIAQgBkcEQCAAIAZqIggtAAAiAUELSwRAQWwhBgwDBSAJIAFBAnRqIgEgASgCAEEBajYCACAGQQFqIQZBASAILQAAdEEBdSAFaiEFDAILAAsLQWwhBiAFRQ0AIAUQFEEBaiIBQQxLDQAgAyABNgIAQQFBASABdCAFayIDEBQiAXQgA0cNACAAIARqIAFBAWoiADoAACAJIABBAnRqIgAgACgCAEEBajYCACAJKAIEIgBBAkkgAEEBcXINACACIARBAWo2AgAgB0EBaiEGCyAKQZACaiQAIAYLxhEBDH8jAEHwAGsiBSQAQWwhCwJAIANBCkkNACACLwAAIQogAi8AAiEJIAIvAAQhByAFQQhqIAQQDgJAIAMgByAJIApqakEGaiIMSQ0AIAUtAAohCCAFQdgAaiACQQZqIgIgChAGIgsQAw0BIAVBQGsgAiAKaiICIAkQBiILEAMNASAFQShqIAIgCWoiAiAHEAYiCxADDQEgBUEQaiACIAdqIAMgDGsQBiILEAMNASAAIAFqIg9BfWohECAEQQRqIQZBASELIAAgAUEDakECdiIDaiIMIANqIgIgA2oiDiEDIAIhBCAMIQcDQCALIAMgEElxBEAgACAGIAVB2ABqIAgQAkECdGoiCS8BADsAACAFQdgAaiAJLQACEAEgCS0AAyELIAcgBiAFQUBrIAgQAkECdGoiCS8BADsAACAFQUBrIAktAAIQASAJLQADIQogBCAGIAVBKGogCBACQQJ0aiIJLwEAOwAAIAVBKGogCS0AAhABIAktAAMhCSADIAYgBUEQaiAIEAJBAnRqIg0vAQA7AAAgBUEQaiANLQACEAEgDS0AAyENIAAgC2oiCyAGIAVB2ABqIAgQAkECdGoiAC8BADsAACAFQdgAaiAALQACEAEgAC0AAyEAIAcgCmoiCiAGIAVBQGsgCBACQQJ0aiIHLwEAOwAAIAVBQGsgBy0AAhABIActAAMhByAEIAlqIgkgBiAFQShqIAgQAkECdGoiBC8BADsAACAFQShqIAQtAAIQASAELQADIQQgAyANaiIDIAYgBUEQaiAIEAJBAnRqIg0vAQA7AAAgBUEQaiANLQACEAEgACALaiEAIAcgCmohByAEIAlqIQQgAyANLQADaiEDIAVB2ABqEA0gBUFAaxANciAFQShqEA1yIAVBEGoQDXJFIQsMAQsLIAQgDksgByACS3INAEFsIQsgACAMSw0BIAxBfWohCQNAQQAgACAJSSAFQdgAahAEGwRAIAAgBiAFQdgAaiAIEAJBAnRqIgovAQA7AAAgBUHYAGogCi0AAhABIAAgCi0AA2oiACAGIAVB2ABqIAgQAkECdGoiCi8BADsAACAFQdgAaiAKLQACEAEgACAKLQADaiEADAEFIAxBfmohCgNAIAVB2ABqEAQgACAKS3JFBEAgACAGIAVB2ABqIAgQAkECdGoiCS8BADsAACAFQdgAaiAJLQACEAEgACAJLQADaiEADAELCwNAIAAgCk0EQCAAIAYgBUHYAGogCBACQQJ0aiIJLwEAOwAAIAVB2ABqIAktAAIQASAAIAktAANqIQAMAQsLAkAgACAMTw0AIAAgBiAFQdgAaiAIEAIiAEECdGoiDC0AADoAACAMLQADQQFGBEAgBUHYAGogDC0AAhABDAELIAUoAlxBH0sNACAFQdgAaiAGIABBAnRqLQACEAEgBSgCXEEhSQ0AIAVBIDYCXAsgAkF9aiEMA0BBACAHIAxJIAVBQGsQBBsEQCAHIAYgBUFAayAIEAJBAnRqIgAvAQA7AAAgBUFAayAALQACEAEgByAALQADaiIAIAYgBUFAayAIEAJBAnRqIgcvAQA7AAAgBUFAayAHLQACEAEgACAHLQADaiEHDAEFIAJBfmohDANAIAVBQGsQBCAHIAxLckUEQCAHIAYgBUFAayAIEAJBAnRqIgAvAQA7AAAgBUFAayAALQACEAEgByAALQADaiEHDAELCwNAIAcgDE0EQCAHIAYgBUFAayAIEAJBAnRqIgAvAQA7AAAgBUFAayAALQACEAEgByAALQADaiEHDAELCwJAIAcgAk8NACAHIAYgBUFAayAIEAIiAEECdGoiAi0AADoAACACLQADQQFGBEAgBUFAayACLQACEAEMAQsgBSgCREEfSw0AIAVBQGsgBiAAQQJ0ai0AAhABIAUoAkRBIUkNACAFQSA2AkQLIA5BfWohAgNAQQAgBCACSSAFQShqEAQbBEAgBCAGIAVBKGogCBACQQJ0aiIALwEAOwAAIAVBKGogAC0AAhABIAQgAC0AA2oiACAGIAVBKGogCBACQQJ0aiIELwEAOwAAIAVBKGogBC0AAhABIAAgBC0AA2ohBAwBBSAOQX5qIQIDQCAFQShqEAQgBCACS3JFBEAgBCAGIAVBKGogCBACQQJ0aiIALwEAOwAAIAVBKGogAC0AAhABIAQgAC0AA2ohBAwBCwsDQCAEIAJNBEAgBCAGIAVBKGogCBACQQJ0aiIALwEAOwAAIAVBKGogAC0AAhABIAQgAC0AA2ohBAwBCwsCQCAEIA5PDQAgBCAGIAVBKGogCBACIgBBAnRqIgItAAA6AAAgAi0AA0EBRgRAIAVBKGogAi0AAhABDAELIAUoAixBH0sNACAFQShqIAYgAEECdGotAAIQASAFKAIsQSFJDQAgBUEgNgIsCwNAQQAgAyAQSSAFQRBqEAQbBEAgAyAGIAVBEGogCBACQQJ0aiIALwEAOwAAIAVBEGogAC0AAhABIAMgAC0AA2oiACAGIAVBEGogCBACQQJ0aiICLwEAOwAAIAVBEGogAi0AAhABIAAgAi0AA2ohAwwBBSAPQX5qIQIDQCAFQRBqEAQgAyACS3JFBEAgAyAGIAVBEGogCBACQQJ0aiIALwEAOwAAIAVBEGogAC0AAhABIAMgAC0AA2ohAwwBCwsDQCADIAJNBEAgAyAGIAVBEGogCBACQQJ0aiIALwEAOwAAIAVBEGogAC0AAhABIAMgAC0AA2ohAwwBCwsCQCADIA9PDQAgAyAGIAVBEGogCBACIgBBAnRqIgItAAA6AAAgAi0AA0EBRgRAIAVBEGogAi0AAhABDAELIAUoAhRBH0sNACAFQRBqIAYgAEECdGotAAIQASAFKAIUQSFJDQAgBUEgNgIUCyABQWwgBUHYAGoQCiAFQUBrEApxIAVBKGoQCnEgBUEQahAKcRshCwwJCwAACwALAAALAAsAAAsACwAACwALQWwhCwsgBUHwAGokACALC7UEAQ5/IwBBEGsiBiQAIAZBBGogABAOQVQhBQJAIARB3AtJDQAgBi0ABCEHIANB8ARqQQBB7AAQECEIIAdBDEsNACADQdwJaiIJIAggBkEIaiAGQQxqIAEgAhAxIhAQA0UEQCAGKAIMIgQgB0sNASADQdwFaiEPIANBpAVqIREgAEEEaiESIANBqAVqIQEgBCEFA0AgBSICQX9qIQUgCCACQQJ0aigCAEUNAAsgAkEBaiEOQQEhBQNAIAUgDk9FBEAgCCAFQQJ0IgtqKAIAIQwgASALaiAKNgIAIAVBAWohBSAKIAxqIQoMAQsLIAEgCjYCAEEAIQUgBigCCCELA0AgBSALRkUEQCABIAUgCWotAAAiDEECdGoiDSANKAIAIg1BAWo2AgAgDyANQQF0aiINIAw6AAEgDSAFOgAAIAVBAWohBQwBCwtBACEBIANBADYCqAUgBEF/cyAHaiEJQQEhBQNAIAUgDk9FBEAgCCAFQQJ0IgtqKAIAIQwgAyALaiABNgIAIAwgBSAJanQgAWohASAFQQFqIQUMAQsLIAcgBEEBaiIBIAJrIgRrQQFqIQgDQEEBIQUgBCAIT0UEQANAIAUgDk9FBEAgBUECdCIJIAMgBEE0bGpqIAMgCWooAgAgBHY2AgAgBUEBaiEFDAELCyAEQQFqIQQMAQsLIBIgByAPIAogESADIAIgARBkIAZBAToABSAGIAc6AAYgACAGKAIENgIACyAQIQULIAZBEGokACAFC8ENAQt/IwBB8ABrIgUkAEFsIQkCQCADQQpJDQAgAi8AACEKIAIvAAIhDCACLwAEIQYgBUEIaiAEEA4CQCADIAYgCiAMampBBmoiDUkNACAFLQAKIQcgBUHYAGogAkEGaiICIAoQBiIJEAMNASAFQUBrIAIgCmoiAiAMEAYiCRADDQEgBUEoaiACIAxqIgIgBhAGIgkQAw0BIAVBEGogAiAGaiADIA1rEAYiCRADDQEgACABaiIOQX1qIQ8gBEEEaiEGQQEhCSAAIAFBA2pBAnYiAmoiCiACaiIMIAJqIg0hAyAMIQQgCiECA0AgCSADIA9JcQRAIAYgBUHYAGogBxACQQF0aiIILQAAIQsgBUHYAGogCC0AARABIAAgCzoAACAGIAVBQGsgBxACQQF0aiIILQAAIQsgBUFAayAILQABEAEgAiALOgAAIAYgBUEoaiAHEAJBAXRqIggtAAAhCyAFQShqIAgtAAEQASAEIAs6AAAgBiAFQRBqIAcQAkEBdGoiCC0AACELIAVBEGogCC0AARABIAMgCzoAACAGIAVB2ABqIAcQAkEBdGoiCC0AACELIAVB2ABqIAgtAAEQASAAIAs6AAEgBiAFQUBrIAcQAkEBdGoiCC0AACELIAVBQGsgCC0AARABIAIgCzoAASAGIAVBKGogBxACQQF0aiIILQAAIQsgBUEoaiAILQABEAEgBCALOgABIAYgBUEQaiAHEAJBAXRqIggtAAAhCyAFQRBqIAgtAAEQASADIAs6AAEgA0ECaiEDIARBAmohBCACQQJqIQIgAEECaiEAIAkgBUHYAGoQDUVxIAVBQGsQDUVxIAVBKGoQDUVxIAVBEGoQDUVxIQkMAQsLIAQgDUsgAiAMS3INAEFsIQkgACAKSw0BIApBfWohCQNAIAVB2ABqEAQgACAJT3JFBEAgBiAFQdgAaiAHEAJBAXRqIggtAAAhCyAFQdgAaiAILQABEAEgACALOgAAIAYgBUHYAGogBxACQQF0aiIILQAAIQsgBUHYAGogCC0AARABIAAgCzoAASAAQQJqIQAMAQsLA0AgBUHYAGoQBCAAIApPckUEQCAGIAVB2ABqIAcQAkEBdGoiCS0AACEIIAVB2ABqIAktAAEQASAAIAg6AAAgAEEBaiEADAELCwNAIAAgCkkEQCAGIAVB2ABqIAcQAkEBdGoiCS0AACEIIAVB2ABqIAktAAEQASAAIAg6AAAgAEEBaiEADAELCyAMQX1qIQADQCAFQUBrEAQgAiAAT3JFBEAgBiAFQUBrIAcQAkEBdGoiCi0AACEJIAVBQGsgCi0AARABIAIgCToAACAGIAVBQGsgBxACQQF0aiIKLQAAIQkgBUFAayAKLQABEAEgAiAJOgABIAJBAmohAgwBCwsDQCAFQUBrEAQgAiAMT3JFBEAgBiAFQUBrIAcQAkEBdGoiAC0AACEKIAVBQGsgAC0AARABIAIgCjoAACACQQFqIQIMAQsLA0AgAiAMSQRAIAYgBUFAayAHEAJBAXRqIgAtAAAhCiAFQUBrIAAtAAEQASACIAo6AAAgAkEBaiECDAELCyANQX1qIQADQCAFQShqEAQgBCAAT3JFBEAgBiAFQShqIAcQAkEBdGoiAi0AACEKIAVBKGogAi0AARABIAQgCjoAACAGIAVBKGogBxACQQF0aiICLQAAIQogBUEoaiACLQABEAEgBCAKOgABIARBAmohBAwBCwsDQCAFQShqEAQgBCANT3JFBEAgBiAFQShqIAcQAkEBdGoiAC0AACECIAVBKGogAC0AARABIAQgAjoAACAEQQFqIQQMAQsLA0AgBCANSQRAIAYgBUEoaiAHEAJBAXRqIgAtAAAhAiAFQShqIAAtAAEQASAEIAI6AAAgBEEBaiEEDAELCwNAIAVBEGoQBCADIA9PckUEQCAGIAVBEGogBxACQQF0aiIALQAAIQIgBUEQaiAALQABEAEgAyACOgAAIAYgBUEQaiAHEAJBAXRqIgAtAAAhAiAFQRBqIAAtAAEQASADIAI6AAEgA0ECaiEDDAELCwNAIAVBEGoQBCADIA5PckUEQCAGIAVBEGogBxACQQF0aiIALQAAIQIgBUEQaiAALQABEAEgAyACOgAAIANBAWohAwwBCwsDQCADIA5JBEAgBiAFQRBqIAcQAkEBdGoiAC0AACECIAVBEGogAC0AARABIAMgAjoAACADQQFqIQMMAQsLIAFBbCAFQdgAahAKIAVBQGsQCnEgBUEoahAKcSAFQRBqEApxGyEJDAELQWwhCQsgBUHwAGokACAJC8oCAQR/IwBBIGsiBSQAIAUgBBAOIAUtAAIhByAFQQhqIAIgAxAGIgIQA0UEQCAEQQRqIQIgACABaiIDQX1qIQQDQCAFQQhqEAQgACAET3JFBEAgAiAFQQhqIAcQAkEBdGoiBi0AACEIIAVBCGogBi0AARABIAAgCDoAACACIAVBCGogBxACQQF0aiIGLQAAIQggBUEIaiAGLQABEAEgACAIOgABIABBAmohAAwBCwsDQCAFQQhqEAQgACADT3JFBEAgAiAFQQhqIAcQAkEBdGoiBC0AACEGIAVBCGogBC0AARABIAAgBjoAACAAQQFqIQAMAQsLA0AgACADT0UEQCACIAVBCGogBxACQQF0aiIELQAAIQYgBUEIaiAELQABEAEgACAGOgAAIABBAWohAAwBCwsgAUFsIAVBCGoQChshAgsgBUEgaiQAIAILtgMBCX8jAEEQayIGJAAgBkEANgIMIAZBADYCCEFUIQQCQAJAIANBQGsiDCADIAZBCGogBkEMaiABIAIQMSICEAMNACAGQQRqIAAQDiAGKAIMIgcgBi0ABEEBaksNASAAQQRqIQogBkEAOgAFIAYgBzoABiAAIAYoAgQ2AgAgB0EBaiEJQQEhBANAIAQgCUkEQCADIARBAnRqIgEoAgAhACABIAU2AgAgACAEQX9qdCAFaiEFIARBAWohBAwBCwsgB0EBaiEHQQAhBSAGKAIIIQkDQCAFIAlGDQEgAyAFIAxqLQAAIgRBAnRqIgBBASAEdEEBdSILIAAoAgAiAWoiADYCACAHIARrIQhBACEEAkAgC0EDTQRAA0AgBCALRg0CIAogASAEakEBdGoiACAIOgABIAAgBToAACAEQQFqIQQMAAALAAsDQCABIABPDQEgCiABQQF0aiIEIAg6AAEgBCAFOgAAIAQgCDoAAyAEIAU6AAIgBCAIOgAFIAQgBToABCAEIAg6AAcgBCAFOgAGIAFBBGohAQwAAAsACyAFQQFqIQUMAAALAAsgAiEECyAGQRBqJAAgBAutAQECfwJAQYQgKAIAIABHIAAoAgBBAXYiAyABa0F4aiICQXhxQQhHcgR/IAIFIAMQJ0UNASACQQhqC0EQSQ0AIAAgACgCACICQQFxIAAgAWpBD2pBeHEiASAAa0EBdHI2AgAgASAANgIEIAEgASgCAEEBcSAAIAJBAXZqIAFrIgJBAXRyNgIAQYQgIAEgAkH/////B3FqQQRqQYQgKAIAIABGGyABNgIAIAEQJQsLygIBBX8CQAJAAkAgAEEIIABBCEsbZ0EfcyAAaUEBR2oiAUEESSAAIAF2cg0AIAFBAnRB/B5qKAIAIgJFDQADQCACQXhqIgMoAgBBAXZBeGoiBSAATwRAIAIgBUEIIAVBCEsbZ0Efc0ECdEGAH2oiASgCAEYEQCABIAIoAgQ2AgALDAMLIARBHksNASAEQQFqIQQgAigCBCICDQALC0EAIQMgAUEgTw0BA0AgAUECdEGAH2ooAgAiAkUEQCABQR5LIQIgAUEBaiEBIAJFDQEMAwsLIAIgAkF4aiIDKAIAQQF2QXhqIgFBCCABQQhLG2dBH3NBAnRBgB9qIgEoAgBGBEAgASACKAIENgIACwsgAigCACIBBEAgASACKAIENgIECyACKAIEIgEEQCABIAIoAgA2AgALIAMgAygCAEEBcjYCACADIAAQNwsgAwvhCwINfwV+IwBB8ABrIgckACAHIAAoAvDhASIINgJcIAEgAmohDSAIIAAoAoDiAWohDwJAAkAgBUUEQCABIQQMAQsgACgCxOABIRAgACgCwOABIREgACgCvOABIQ4gAEEBNgKM4QFBACEIA0AgCEEDRwRAIAcgCEECdCICaiAAIAJqQazQAWooAgA2AkQgCEEBaiEIDAELC0FsIQwgB0EYaiADIAQQBhADDQEgB0EsaiAHQRhqIAAoAgAQEyAHQTRqIAdBGGogACgCCBATIAdBPGogB0EYaiAAKAIEEBMgDUFgaiESIAEhBEEAIQwDQCAHKAIwIAcoAixBA3RqKQIAIhRCEIinQf8BcSEIIAcoAkAgBygCPEEDdGopAgAiFUIQiKdB/wFxIQsgBygCOCAHKAI0QQN0aikCACIWQiCIpyEJIBVCIIghFyAUQiCIpyECAkAgFkIQiKdB/wFxIgNBAk8EQAJAIAZFIANBGUlyRQRAIAkgB0EYaiADQSAgBygCHGsiCiAKIANLGyIKEAUgAyAKayIDdGohCSAHQRhqEAQaIANFDQEgB0EYaiADEAUgCWohCQwBCyAHQRhqIAMQBSAJaiEJIAdBGGoQBBoLIAcpAkQhGCAHIAk2AkQgByAYNwNIDAELAkAgA0UEQCACBEAgBygCRCEJDAMLIAcoAkghCQwBCwJAAkAgB0EYakEBEAUgCSACRWpqIgNBA0YEQCAHKAJEQX9qIgMgA0VqIQkMAQsgA0ECdCAHaigCRCIJIAlFaiEJIANBAUYNAQsgByAHKAJINgJMCwsgByAHKAJENgJIIAcgCTYCRAsgF6chAyALBEAgB0EYaiALEAUgA2ohAwsgCCALakEUTwRAIAdBGGoQBBoLIAgEQCAHQRhqIAgQBSACaiECCyAHQRhqEAQaIAcgB0EYaiAUQhiIp0H/AXEQCCAUp0H//wNxajYCLCAHIAdBGGogFUIYiKdB/wFxEAggFadB//8DcWo2AjwgB0EYahAEGiAHIAdBGGogFkIYiKdB/wFxEAggFqdB//8DcWo2AjQgByACNgJgIAcoAlwhCiAHIAk2AmggByADNgJkAkACQAJAIAQgAiADaiILaiASSw0AIAIgCmoiEyAPSw0AIA0gBGsgC0Egak8NAQsgByAHKQNoNwMQIAcgBykDYDcDCCAEIA0gB0EIaiAHQdwAaiAPIA4gESAQEB4hCwwBCyACIARqIQggBCAKEAcgAkERTwRAIARBEGohAgNAIAIgCkEQaiIKEAcgAkEQaiICIAhJDQALCyAIIAlrIQIgByATNgJcIAkgCCAOa0sEQCAJIAggEWtLBEBBbCELDAILIBAgAiAOayICaiIKIANqIBBNBEAgCCAKIAMQDxoMAgsgCCAKQQAgAmsQDyEIIAcgAiADaiIDNgJkIAggAmshCCAOIQILIAlBEE8EQCADIAhqIQMDQCAIIAIQByACQRBqIQIgCEEQaiIIIANJDQALDAELAkAgCUEHTQRAIAggAi0AADoAACAIIAItAAE6AAEgCCACLQACOgACIAggAi0AAzoAAyAIQQRqIAIgCUECdCIDQcAeaigCAGoiAhAXIAIgA0HgHmooAgBrIQIgBygCZCEDDAELIAggAhAMCyADQQlJDQAgAyAIaiEDIAhBCGoiCCACQQhqIgJrQQ9MBEADQCAIIAIQDCACQQhqIQIgCEEIaiIIIANJDQAMAgALAAsDQCAIIAIQByACQRBqIQIgCEEQaiIIIANJDQALCyAHQRhqEAQaIAsgDCALEAMiAhshDCAEIAQgC2ogAhshBCAFQX9qIgUNAAsgDBADDQFBbCEMIAdBGGoQBEECSQ0BQQAhCANAIAhBA0cEQCAAIAhBAnQiAmpBrNABaiACIAdqKAJENgIAIAhBAWohCAwBCwsgBygCXCEIC0G6fyEMIA8gCGsiACANIARrSw0AIAQEfyAEIAggABALIABqBUEACyABayEMCyAHQfAAaiQAIAwLkRcCFn8FfiMAQdABayIHJAAgByAAKALw4QEiCDYCvAEgASACaiESIAggACgCgOIBaiETAkACQCAFRQRAIAEhAwwBCyAAKALE4AEhESAAKALA4AEhFSAAKAK84AEhDyAAQQE2AozhAUEAIQgDQCAIQQNHBEAgByAIQQJ0IgJqIAAgAmpBrNABaigCADYCVCAIQQFqIQgMAQsLIAcgETYCZCAHIA82AmAgByABIA9rNgJoQWwhECAHQShqIAMgBBAGEAMNASAFQQQgBUEESBshFyAHQTxqIAdBKGogACgCABATIAdBxABqIAdBKGogACgCCBATIAdBzABqIAdB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IAdB0AFqJAAgEAslACAAQgA3AgAgAEEAOwEIIABBADoACyAAIAE2AgwgACACOgAKC7QFAQN/IwBBMGsiBCQAIABB/wFqIgVBfWohBgJAIAMvAQIEQCAEQRhqIAEgAhAGIgIQAw0BIARBEGogBEEYaiADEBwgBEEIaiAEQRhqIAMQHCAAIQMDQAJAIARBGGoQBCADIAZPckUEQCADIARBEGogBEEYahASOgAAIAMgBEEIaiAEQRhqEBI6AAEgBEEYahAERQ0BIANBAmohAwsgBUF+aiEFAn8DQEG6fyECIAMiASAFSw0FIAEgBEEQaiAEQRhqEBI6AAAgAUEBaiEDIARBGGoQBEEDRgRAQQIhAiAEQQhqDAILIAMgBUsNBSABIARBCGogBEEYahASOgABIAFBAmohA0EDIQIgBEEYahAEQQNHDQALIARBEGoLIQUgAyAFIARBGGoQEjoAACABIAJqIABrIQIMAwsgAyAEQRBqIARBGGoQEjoAAiADIARBCGogBEEYahASOgADIANBBGohAwwAAAsACyAEQRhqIAEgAhAGIgIQAw0AIARBEGogBEEYaiADEBwgBEEIaiAEQRhqIAMQHCAAIQMDQAJAIARBGGoQBCADIAZPckUEQCADIARBEGogBEEYahAROgAAIAMgBEEIaiAEQRhqEBE6AAEgBEEYahAERQ0BIANBAmohAwsgBUF+aiEFAn8DQEG6fyECIAMiASAFSw0EIAEgBEEQaiAEQRhqEBE6AAAgAUEBaiEDIARBGGoQBEEDRgRAQQIhAiAEQQhqDAILIAMgBUsNBCABIARBCGogBEEYahAROgABIAFBAmohA0EDIQIgBEEYahAEQQNHDQALIARBEGoLIQUgAyAFIARBGGoQEToAACABIAJqIABrIQIMAgsgAyAEQRBqIARBGGoQEToAAiADIARBCGogBEEYahAROgADIANBBGohAwwAAAsACyAEQTBqJAAgAgtpAQF/An8CQAJAIAJBB00NACABKAAAQbfIwuF+Rw0AIAAgASgABDYCmOIBQWIgAEEQaiABIAIQPiIDEAMNAhogAEKBgICAEDcDiOEBIAAgASADaiACIANrECoMAQsgACABIAIQKgtBAAsLrQMBBn8jAEGAAWsiAyQAQWIhCAJAIAJBCUkNACAAQZjQAGogAUEIaiIEIAJBeGogAEGY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wOABCwutAgIEfwF+IwBBQGoiBCQAAkACQCACQQhJDQAgASgAAEFwcUHQ1LTCAUcNACABIAIQIiEBIABCADcDCCAAQQA2AgQgACABNgIADAELIARBGGogASACEC0iAxADBEAgACADEBoMAQsgAwRAIABBuH8QGgwBCyACIAQoAjAiA2shAiABIANqIQMDQAJAIAAgAyACIARBCGoQLCIFEAMEfyAFBSACIAVBA2oiBU8NAUG4fwsQGgwCCyAGQQFqIQYgAiAFayECIAMgBWohAyAEKAIMRQ0ACyAEKAI4BEAgAkEDTQRAIABBuH8QGgwCCyADQQRqIQMLIAQoAighAiAEKQMYIQcgAEEANgIEIAAgAyABazYCACAAIAIgBmytIAcgB0J/URs3AwgLIARBQGskAAslAQF/IwBBEGsiAiQAIAIgACABEFEgAigCACEAIAJBEGokACAAC30BBH8jAEGQBGsiBCQAIARB/wE2AggCQCAEQRBqIARBCGogBEEMaiABIAIQFSIGEAMEQCAGIQUMAQtBVCEFIAQoAgwiB0EGSw0AIAMgBEEQaiAEKAIIIAcQQSIFEAMNACAAIAEgBmogAiAGayADEDwhBQsgBEGQBGokACAFC4cBAgJ/An5BABAWIQMCQANAIAEgA08EQAJAIAAoAABBcHFB0NS0wgFGBEAgACABECIiAhADRQ0BQn4PCyAAIAEQVSIEQn1WDQMgBCAFfCIFIARUIQJCfiEEIAINAyAAIAEQUiICEAMNAwsgASACayEBIAAgAmohAAwBCwtCfiAFIAEbIQQLIAQLPwIBfwF+IwBBMGsiAiQAAn5CfiACQQhqIAAgARAtDQAaQgAgAigCHEEBRg0AGiACKQMICyEDIAJBMGokACADC40BAQJ/IwBBMGsiASQAAkAgAEUNACAAKAKI4gENACABIABB/OEBaigCADYCKCABIAApAvThATcDICAAEDAgACgCqOIBIQIgASABKAIoNgIYIAEgASkDIDcDECACIAFBEGoQGyAAQQA2AqjiASABIAEoAig2AgggASABKQMgNwMAIAAgARAbCyABQTBqJAALKgECfyMAQRBrIgAkACAAQQA2AgggAEIANwMAIAAQWCEBIABBEGokACABC4cBAQN/IwBBEGsiAiQAAkAgACgCAEUgACgCBEVzDQAgAiAAKAIINgIIIAIgACkCADcDAAJ/IAIoAgAiAQRAIAIoAghBqOMJIAERBQAMAQtBqOMJECgLIgFFDQAgASAAKQIANwL04QEgAUH84QFqIAAoAgg2AgAgARBZIAEhAwsgAkEQaiQAIAMLywEBAn8jAEEgayIBJAAgAEGBgIDAADYCtOIBIABBADYCiOIBIABBADYC7OEBIABCADcDkOIBIABBADYCpOMJIABBADYC3OIBIABCADcCzOIBIABBADYCvOIBIABBADYCxOABIABCADcCnOIBIABBpOIBakIANwIAIABBrOIBakEANgIAIAFCADcCECABQgA3AhggASABKQMYNwMIIAEgASkDEDcDACABKAIIQQh2QQFxIQIgAEEANgLg4gEgACACNgKM4gEgAUEgaiQAC3YBA38jAEEwayIBJAAgAARAIAEgAEHE0AFqIgIoAgA2AiggASAAKQK80AE3AyAgACgCACEDIAEgAigCADYCGCABIAApArzQATcDECADIAFBEGoQGyABIAEoAig2AgggASABKQMgNwMAIAAgARAbCyABQTBqJAALzAEBAX8gACABKAK00AE2ApjiASAAIAEoAgQiAjYCwOABIAAgAjYCvOABIAAgAiABKAIIaiICNgK44AEgACACNgLE4AEgASgCuNABBEAgAEKBgICAEDcDiOEBIAAgAUGk0ABqNgIMIAAgAUGUIGo2AgggACABQZwwajYCBCAAIAFBDGo2AgAgAEGs0AFqIAFBqNABaigCADYCACAAQbDQAWogAUGs0AFqKAIANgIAIABBtNABaiABQbDQAWooAgA2AgAPCyAAQgA3A4jhAQs7ACACRQRAQbp/DwsgBEUEQEFsDwsgAiAEEGAEQCAAIAEgAiADIAQgBRBhDwsgACABIAIgAyAEIAUQZQtGAQF/IwBBEGsiBSQAIAVBCGogBBAOAn8gBS0ACQRAIAAgASACIAMgBBAyDAELIAAgASACIAMgBBA0CyEAIAVBEGokACAACzQAIAAgAyAEIAUQNiIFEAMEQCAFDwsgBSAESQR/IAEgAiADIAVqIAQgBWsgABA1BUG4fwsLRgEBfyMAQRBrIgUkACAFQQhqIAQQDgJ/IAUtAAkEQCAAIAEgAiADIAQQYgwBCyAAIAEgAiADIAQQNQshACAFQRBqJAAgAAtZAQF/QQ8hAiABIABJBEAgAUEE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", yA = new GA();
1006
+ class kA extends nA {
1007
+ constructor(N) {
1008
+ super(), this.planarConfiguration = typeof N.PlanarConfiguration < "u" ? N.PlanarConfiguration : 1, this.samplesPerPixel = typeof N.SamplesPerPixel < "u" ? N.SamplesPerPixel : 1, this.addCompression = N.LercParameters[rA.AddCompression];
1009
+ }
1010
+ decodeBlock(N) {
1011
+ switch (this.addCompression) {
1012
+ case gA.None:
1013
+ break;
1014
+ case gA.Deflate:
1015
+ N = sA(new Uint8Array(N)).buffer;
1016
+ break;
1017
+ case gA.Zstandard:
1018
+ N = yA.decode(new Uint8Array(N)).buffer;
1019
+ break;
1020
+ default:
1021
+ throw new Error(`Unsupported LERC additional compression method identifier: ${this.addCompression}`);
1022
+ }
1023
+ return fA.decode(N, { returnPixelInterleavedDims: this.planarConfiguration === 1 }).pixels[0].buffer;
1024
+ }
1025
+ }
1026
+ export {
1027
+ kA as default,
1028
+ yA as zstd
1029
+ };