@uwrl/qc-utils 0.0.20 → 0.0.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +1205 -1008
- package/dist/index.umd.cjs +14 -14
- package/dist/types/index.d.ts +35 -1
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/plotting/__tests__/script.spec.d.ts +1 -0
- package/dist/utils/plotting/observation-record.d.ts +87 -5
- package/dist/utils/plotting/script.d.ts +67 -0
- package/package.json +3 -2
package/dist/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
var
|
|
2
|
-
class
|
|
1
|
+
var x = /* @__PURE__ */ ((e) => (e.SECOND = "s", e.MINUTE = "m", e.HOUR = "h", e.DAY = "D", e.WEEK = "W", e.MONTH = "M", e.YEAR = "Y", e))(x || {}), E = /* @__PURE__ */ ((e) => (e.ADD_POINTS = "ADD_POINTS", e.CHANGE_VALUES = "CHANGE_VALUES", e.ASSIGN_VALUES_BULK = "ASSIGN_VALUES_BULK", e.DELETE_POINTS = "DELETE_POINTS", e.DRIFT_CORRECTION = "DRIFT_CORRECTION", e.INTERPOLATE = "INTERPOLATE", e.SHIFT_DATETIMES = "SHIFT_DATETIMES", e.ASSIGN_DATETIMES_BULK = "ASSIGN_DATETIMES_BULK", e.FILL_GAPS = "FILL_GAPS", e))(E || {}), A = /* @__PURE__ */ ((e) => (e.FIND_GAPS = "FIND_GAPS", e.PERSISTENCE = "PERSISTENCE", e.CHANGE = "CHANGE", e.RATE_OF_CHANGE = "RATE_OF_CHANGE", e.VALUE_THRESHOLD = "VALUE_THRESHOLD", e.DATETIME_RANGE = "DATETIME_RANGE", e.SELECTION = "SELECTION", e))(A || {}), K = /* @__PURE__ */ ((e) => (e.LT = "Less than", e.LTE = "Less than or equal to", e.GT = "Greater than", e.GTE = "Greater than or equal to", e.E = "Equal", e))(K || {}), jt = /* @__PURE__ */ ((e) => (e.ADD = "ADD", e.SUB = "SUB", e.MULT = "MULT", e.DIV = "DIV", e.ASSIGN = "ASSIGN", e))(jt || {}), Wt = /* @__PURE__ */ ((e) => (e.LT = "Less than", e.LTE = "Less than or equal to", e.GT = "Greater than", e.GTE = "Greater than or equal to", e.E = "Equal", e))(Wt || {});
|
|
2
|
+
class Yt {
|
|
3
3
|
id;
|
|
4
4
|
thingId;
|
|
5
5
|
link;
|
|
@@ -11,7 +11,7 @@ class Wt {
|
|
|
11
11
|
this.id = "", this.thingId = "", this.link = "", this.frequency = null, this.path = "HydroShare", this.datastreamIds = [], this.publicResource = !1;
|
|
12
12
|
}
|
|
13
13
|
}
|
|
14
|
-
class
|
|
14
|
+
class Kr extends Yt {
|
|
15
15
|
resourceTitle;
|
|
16
16
|
resourceAbstract;
|
|
17
17
|
resourceKeywords;
|
|
@@ -31,7 +31,7 @@ class Gt {
|
|
|
31
31
|
this.elevationDatum = "WGS84", this.state = "", this.county = "", this.country = "";
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
|
-
class
|
|
34
|
+
class Zr {
|
|
35
35
|
id;
|
|
36
36
|
workspaceId;
|
|
37
37
|
name;
|
|
@@ -48,7 +48,7 @@ class qr {
|
|
|
48
48
|
this.id = "", this.workspaceId = "", this.name = "", this.tags = [], this.siteType = "", this.samplingFeatureCode = "", this.isPrivate = !1, this.description = "", this.samplingFeatureType = "Site", this.dataDisclaimer = "";
|
|
49
49
|
}
|
|
50
50
|
}
|
|
51
|
-
class
|
|
51
|
+
class es {
|
|
52
52
|
id;
|
|
53
53
|
workspaceId;
|
|
54
54
|
name;
|
|
@@ -78,7 +78,7 @@ class Jr {
|
|
|
78
78
|
this.id = "", this.workspaceId = "", this.name = "", this.description = "", this.thingId = t || "", this.observationType = "OM_Measurement", this.resultType = "Time Series Coverage", this.sampledMedium = "", this.noDataValue = -9999, this.aggregationStatistic = "", this.unitId = "", this.observedPropertyId = "", this.sensorId = "", this.processingLevelId = "", this.timeAggregationInterval = null, this.timeAggregationIntervalUnit = "seconds", this.isPrivate = !0, this.isVisible = !0, this.valueCount = 0;
|
|
79
79
|
}
|
|
80
80
|
}
|
|
81
|
-
class
|
|
81
|
+
class ts {
|
|
82
82
|
id;
|
|
83
83
|
workspaceId;
|
|
84
84
|
name;
|
|
@@ -89,7 +89,7 @@ class Kr {
|
|
|
89
89
|
this.id = "", this.workspaceId = "", this.name = "", this.symbol = "", this.definition = "", this.type = "";
|
|
90
90
|
}
|
|
91
91
|
}
|
|
92
|
-
class
|
|
92
|
+
class rs {
|
|
93
93
|
id;
|
|
94
94
|
workspaceId;
|
|
95
95
|
name;
|
|
@@ -105,7 +105,7 @@ class Qr {
|
|
|
105
105
|
this.id = "", this.workspaceId = "", this.name = "", this.description = "", this.manufacturer = "", this.model = "", this.methodType = "Instrument Deployment", this.methodCode = "", this.methodLink = "", this.encodingType = "application/json", this.modelLink = "";
|
|
106
106
|
}
|
|
107
107
|
}
|
|
108
|
-
class
|
|
108
|
+
class ss {
|
|
109
109
|
id;
|
|
110
110
|
workspaceId;
|
|
111
111
|
name;
|
|
@@ -117,7 +117,7 @@ class Zr {
|
|
|
117
117
|
this.id = "", this.workspaceId = "", this.name = "", this.definition = "", this.description = "", this.type = "Hydrology", this.code = "";
|
|
118
118
|
}
|
|
119
119
|
}
|
|
120
|
-
class
|
|
120
|
+
class ns {
|
|
121
121
|
id;
|
|
122
122
|
workspaceId;
|
|
123
123
|
code;
|
|
@@ -127,7 +127,7 @@ class es {
|
|
|
127
127
|
this.id = "", this.workspaceId = "", this.code = "", this.definition = "", this.explanation = "";
|
|
128
128
|
}
|
|
129
129
|
}
|
|
130
|
-
class
|
|
130
|
+
class os {
|
|
131
131
|
id;
|
|
132
132
|
workspaceId;
|
|
133
133
|
code;
|
|
@@ -136,7 +136,7 @@ class ts {
|
|
|
136
136
|
this.id = "", this.workspaceId = "", this.code = "", this.description = "";
|
|
137
137
|
}
|
|
138
138
|
}
|
|
139
|
-
class
|
|
139
|
+
class as {
|
|
140
140
|
name;
|
|
141
141
|
code;
|
|
142
142
|
type;
|
|
@@ -145,7 +145,7 @@ class rs {
|
|
|
145
145
|
constructor() {
|
|
146
146
|
}
|
|
147
147
|
}
|
|
148
|
-
class
|
|
148
|
+
class is {
|
|
149
149
|
id;
|
|
150
150
|
email;
|
|
151
151
|
password;
|
|
@@ -163,7 +163,7 @@ class ss {
|
|
|
163
163
|
this.id = "", this.email = "", this.password = "", this.firstName = "", this.middleName = "", this.lastName = "", this.phone = "", this.address = "", this.type = "", this.link = "", this.accountType = "standard", this.hydroShareConnected = !1;
|
|
164
164
|
}
|
|
165
165
|
}
|
|
166
|
-
class
|
|
166
|
+
class cs {
|
|
167
167
|
id;
|
|
168
168
|
name;
|
|
169
169
|
iconLink;
|
|
@@ -173,8 +173,8 @@ class ns {
|
|
|
173
173
|
this.id = "", this.name = "", this.iconLink = "", this.signupEnabled = !0, this.connectEnabled = !0;
|
|
174
174
|
}
|
|
175
175
|
}
|
|
176
|
-
var
|
|
177
|
-
class
|
|
176
|
+
var Ht = /* @__PURE__ */ ((e) => (e.Global = "*", e.View = "view", e.Create = "create", e.Edit = "edit", e.Delete = "delete", e))(Ht || {}), zt = /* @__PURE__ */ ((e) => (e.Global = "*", e.Workspace = "Workspace", e.Collaborator = "Collaborator", e.Thing = "Thing", e.Datastream = "Datastream", e.Sensor = "Sensor", e.Unit = "Unit", e.ObservedProperty = "ObservedProperty", e.ProcessingLevel = "ProcessingLevel", e.Observation = "Observation", e))(zt || {});
|
|
177
|
+
class ls {
|
|
178
178
|
id = "";
|
|
179
179
|
key = "";
|
|
180
180
|
name = "";
|
|
@@ -189,7 +189,7 @@ class os {
|
|
|
189
189
|
Object.assign(this, t);
|
|
190
190
|
}
|
|
191
191
|
}
|
|
192
|
-
class
|
|
192
|
+
class us {
|
|
193
193
|
id;
|
|
194
194
|
name;
|
|
195
195
|
isPrivate;
|
|
@@ -200,7 +200,7 @@ class as {
|
|
|
200
200
|
this.id = "", this.name = "", this.isPrivate = !1, this.owner = null, this.collaboratorRole = null, this.pendingTransferTo = null;
|
|
201
201
|
}
|
|
202
202
|
}
|
|
203
|
-
class
|
|
203
|
+
class hs {
|
|
204
204
|
user;
|
|
205
205
|
role;
|
|
206
206
|
constructor() {
|
|
@@ -223,7 +223,7 @@ class is {
|
|
|
223
223
|
};
|
|
224
224
|
}
|
|
225
225
|
}
|
|
226
|
-
function
|
|
226
|
+
function ft() {
|
|
227
227
|
const e = "csrftoken=", r = decodeURIComponent(document.cookie).split(";");
|
|
228
228
|
for (const s of r) {
|
|
229
229
|
const n = s.trim();
|
|
@@ -232,16 +232,16 @@ function ht() {
|
|
|
232
232
|
}
|
|
233
233
|
return null;
|
|
234
234
|
}
|
|
235
|
-
function
|
|
235
|
+
function dt(e) {
|
|
236
236
|
let t = e.headers ? { ...e.headers } : {}, r;
|
|
237
|
-
return e.body !== void 0 && (r = typeof e.body == "string" || e.body instanceof FormData ? e.body : JSON.stringify(e.body)), t["X-CSRFToken"] =
|
|
237
|
+
return e.body !== void 0 && (r = typeof e.body == "string" || e.body instanceof FormData ? e.body : JSON.stringify(e.body)), t["X-CSRFToken"] = ft() || "", {
|
|
238
238
|
...e,
|
|
239
239
|
headers: t,
|
|
240
240
|
body: r,
|
|
241
241
|
credentials: "omit"
|
|
242
242
|
};
|
|
243
243
|
}
|
|
244
|
-
function
|
|
244
|
+
function Xt(e) {
|
|
245
245
|
if (Array.isArray(e?.errors) && e.errors.length && (e = e.errors[0]), typeof e != "object" || e === null)
|
|
246
246
|
return "An unknown error occurred.";
|
|
247
247
|
const t = ["message", "detail", "error"];
|
|
@@ -249,7 +249,7 @@ function zt(e) {
|
|
|
249
249
|
if (e[r]) return e[r];
|
|
250
250
|
return "An unknown error occurred.";
|
|
251
251
|
}
|
|
252
|
-
async function
|
|
252
|
+
async function pt(e) {
|
|
253
253
|
if (e.headers.get("Content-Length") === "0" || e.statusText === "No Content")
|
|
254
254
|
return null;
|
|
255
255
|
const t = e.headers.get("content-type") || "";
|
|
@@ -269,27 +269,27 @@ async function dt(e) {
|
|
|
269
269
|
if (e.ok || e.status === 401) return r;
|
|
270
270
|
const s = {
|
|
271
271
|
status: e.status,
|
|
272
|
-
message:
|
|
272
|
+
message: Xt(r)
|
|
273
273
|
};
|
|
274
274
|
throw console.error("API response not OK:", s.message), s;
|
|
275
275
|
}
|
|
276
|
-
var
|
|
277
|
-
return
|
|
276
|
+
var _e = function(e, t) {
|
|
277
|
+
return _e = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(r, s) {
|
|
278
278
|
r.__proto__ = s;
|
|
279
279
|
} || function(r, s) {
|
|
280
280
|
for (var n in s) Object.prototype.hasOwnProperty.call(s, n) && (r[n] = s[n]);
|
|
281
|
-
},
|
|
281
|
+
}, _e(e, t);
|
|
282
282
|
};
|
|
283
|
-
function
|
|
283
|
+
function fe(e, t) {
|
|
284
284
|
if (typeof t != "function" && t !== null)
|
|
285
285
|
throw new TypeError("Class extends value " + String(t) + " is not a constructor or null");
|
|
286
|
-
|
|
286
|
+
_e(e, t);
|
|
287
287
|
function r() {
|
|
288
288
|
this.constructor = e;
|
|
289
289
|
}
|
|
290
290
|
e.prototype = t === null ? Object.create(t) : (r.prototype = t.prototype, new r());
|
|
291
291
|
}
|
|
292
|
-
function
|
|
292
|
+
function Ae(e) {
|
|
293
293
|
var t = typeof Symbol == "function" && Symbol.iterator, r = t && e[t], s = 0;
|
|
294
294
|
if (r) return r.call(e);
|
|
295
295
|
if (e && typeof e.length == "number") return {
|
|
@@ -299,38 +299,38 @@ function _e(e) {
|
|
|
299
299
|
};
|
|
300
300
|
throw new TypeError(t ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
301
301
|
}
|
|
302
|
-
function
|
|
302
|
+
function Te(e, t) {
|
|
303
303
|
var r = typeof Symbol == "function" && e[Symbol.iterator];
|
|
304
304
|
if (!r) return e;
|
|
305
|
-
var s = r.call(e), n,
|
|
305
|
+
var s = r.call(e), n, o = [], a;
|
|
306
306
|
try {
|
|
307
|
-
for (; (t === void 0 || t-- > 0) && !(n = s.next()).done; )
|
|
307
|
+
for (; (t === void 0 || t-- > 0) && !(n = s.next()).done; ) o.push(n.value);
|
|
308
308
|
} catch (i) {
|
|
309
|
-
|
|
309
|
+
a = { error: i };
|
|
310
310
|
} finally {
|
|
311
311
|
try {
|
|
312
312
|
n && !n.done && (r = s.return) && r.call(s);
|
|
313
313
|
} finally {
|
|
314
|
-
if (
|
|
314
|
+
if (a) throw a.error;
|
|
315
315
|
}
|
|
316
316
|
}
|
|
317
|
-
return
|
|
317
|
+
return o;
|
|
318
318
|
}
|
|
319
|
-
function
|
|
320
|
-
if (r || arguments.length === 2) for (var s = 0, n = t.length,
|
|
321
|
-
(
|
|
322
|
-
return e.concat(
|
|
319
|
+
function Le(e, t, r) {
|
|
320
|
+
if (r || arguments.length === 2) for (var s = 0, n = t.length, o; s < n; s++)
|
|
321
|
+
(o || !(s in t)) && (o || (o = Array.prototype.slice.call(t, 0, s)), o[s] = t[s]);
|
|
322
|
+
return e.concat(o || Array.prototype.slice.call(t));
|
|
323
323
|
}
|
|
324
|
-
function
|
|
324
|
+
function B(e) {
|
|
325
325
|
return typeof e == "function";
|
|
326
326
|
}
|
|
327
|
-
function
|
|
327
|
+
function yt(e) {
|
|
328
328
|
var t = function(s) {
|
|
329
329
|
Error.call(s), s.stack = new Error().stack;
|
|
330
330
|
}, r = e(t);
|
|
331
331
|
return r.prototype = Object.create(Error.prototype), r.prototype.constructor = r, r;
|
|
332
332
|
}
|
|
333
|
-
var
|
|
333
|
+
var ge = yt(function(e) {
|
|
334
334
|
return function(r) {
|
|
335
335
|
e(this), this.message = r ? r.length + ` errors occurred during unsubscription:
|
|
336
336
|
` + r.map(function(s, n) {
|
|
@@ -339,30 +339,30 @@ var pe = pt(function(e) {
|
|
|
339
339
|
`) : "", this.name = "UnsubscriptionError", this.errors = r;
|
|
340
340
|
};
|
|
341
341
|
});
|
|
342
|
-
function
|
|
342
|
+
function $e(e, t) {
|
|
343
343
|
if (e) {
|
|
344
344
|
var r = e.indexOf(t);
|
|
345
345
|
0 <= r && e.splice(r, 1);
|
|
346
346
|
}
|
|
347
347
|
}
|
|
348
|
-
var
|
|
348
|
+
var de = (function() {
|
|
349
349
|
function e(t) {
|
|
350
350
|
this.initialTeardown = t, this.closed = !1, this._parentage = null, this._finalizers = null;
|
|
351
351
|
}
|
|
352
352
|
return e.prototype.unsubscribe = function() {
|
|
353
|
-
var t, r, s, n,
|
|
353
|
+
var t, r, s, n, o;
|
|
354
354
|
if (!this.closed) {
|
|
355
355
|
this.closed = !0;
|
|
356
|
-
var
|
|
357
|
-
if (
|
|
358
|
-
if (this._parentage = null, Array.isArray(
|
|
356
|
+
var a = this._parentage;
|
|
357
|
+
if (a)
|
|
358
|
+
if (this._parentage = null, Array.isArray(a))
|
|
359
359
|
try {
|
|
360
|
-
for (var i =
|
|
360
|
+
for (var i = Ae(a), l = i.next(); !l.done; l = i.next()) {
|
|
361
361
|
var f = l.value;
|
|
362
362
|
f.remove(this);
|
|
363
363
|
}
|
|
364
|
-
} catch (
|
|
365
|
-
t = { error:
|
|
364
|
+
} catch (u) {
|
|
365
|
+
t = { error: u };
|
|
366
366
|
} finally {
|
|
367
367
|
try {
|
|
368
368
|
l && !l.done && (r = i.return) && r.call(i);
|
|
@@ -371,44 +371,44 @@ var he = (function() {
|
|
|
371
371
|
}
|
|
372
372
|
}
|
|
373
373
|
else
|
|
374
|
-
|
|
375
|
-
var
|
|
376
|
-
if (
|
|
374
|
+
a.remove(this);
|
|
375
|
+
var h = this.initialTeardown;
|
|
376
|
+
if (B(h))
|
|
377
377
|
try {
|
|
378
|
-
|
|
379
|
-
} catch (
|
|
380
|
-
|
|
378
|
+
h();
|
|
379
|
+
} catch (u) {
|
|
380
|
+
o = u instanceof ge ? u.errors : [u];
|
|
381
381
|
}
|
|
382
|
-
var
|
|
383
|
-
if (
|
|
382
|
+
var y = this._finalizers;
|
|
383
|
+
if (y) {
|
|
384
384
|
this._finalizers = null;
|
|
385
385
|
try {
|
|
386
|
-
for (var
|
|
387
|
-
var d =
|
|
386
|
+
for (var p = Ae(y), g = p.next(); !g.done; g = p.next()) {
|
|
387
|
+
var d = g.value;
|
|
388
388
|
try {
|
|
389
|
-
|
|
390
|
-
} catch (
|
|
391
|
-
|
|
389
|
+
Be(d);
|
|
390
|
+
} catch (u) {
|
|
391
|
+
o = o ?? [], u instanceof ge ? o = Le(Le([], Te(o)), Te(u.errors)) : o.push(u);
|
|
392
392
|
}
|
|
393
393
|
}
|
|
394
|
-
} catch (
|
|
395
|
-
s = { error:
|
|
394
|
+
} catch (u) {
|
|
395
|
+
s = { error: u };
|
|
396
396
|
} finally {
|
|
397
397
|
try {
|
|
398
|
-
|
|
398
|
+
g && !g.done && (n = p.return) && n.call(p);
|
|
399
399
|
} finally {
|
|
400
400
|
if (s) throw s.error;
|
|
401
401
|
}
|
|
402
402
|
}
|
|
403
403
|
}
|
|
404
|
-
if (
|
|
405
|
-
throw new
|
|
404
|
+
if (o)
|
|
405
|
+
throw new ge(o);
|
|
406
406
|
}
|
|
407
407
|
}, e.prototype.add = function(t) {
|
|
408
408
|
var r;
|
|
409
409
|
if (t && t !== this)
|
|
410
410
|
if (this.closed)
|
|
411
|
-
|
|
411
|
+
Be(t);
|
|
412
412
|
else {
|
|
413
413
|
if (t instanceof e) {
|
|
414
414
|
if (t.closed || t._hasParent(this))
|
|
@@ -425,52 +425,52 @@ var he = (function() {
|
|
|
425
425
|
this._parentage = Array.isArray(r) ? (r.push(t), r) : r ? [r, t] : t;
|
|
426
426
|
}, e.prototype._removeParent = function(t) {
|
|
427
427
|
var r = this._parentage;
|
|
428
|
-
r === t ? this._parentage = null : Array.isArray(r) &&
|
|
428
|
+
r === t ? this._parentage = null : Array.isArray(r) && $e(r, t);
|
|
429
429
|
}, e.prototype.remove = function(t) {
|
|
430
430
|
var r = this._finalizers;
|
|
431
|
-
r &&
|
|
431
|
+
r && $e(r, t), t instanceof e && t._removeParent(this);
|
|
432
432
|
}, e.EMPTY = (function() {
|
|
433
433
|
var t = new e();
|
|
434
434
|
return t.closed = !0, t;
|
|
435
435
|
})(), e;
|
|
436
|
-
})(),
|
|
437
|
-
function
|
|
438
|
-
return e instanceof
|
|
436
|
+
})(), gt = de.EMPTY;
|
|
437
|
+
function mt(e) {
|
|
438
|
+
return e instanceof de || e && "closed" in e && B(e.remove) && B(e.add) && B(e.unsubscribe);
|
|
439
439
|
}
|
|
440
|
-
function
|
|
441
|
-
|
|
440
|
+
function Be(e) {
|
|
441
|
+
B(e) ? e() : e.unsubscribe();
|
|
442
442
|
}
|
|
443
|
-
var
|
|
443
|
+
var Vt = {
|
|
444
444
|
Promise: void 0
|
|
445
|
-
},
|
|
445
|
+
}, qt = {
|
|
446
446
|
setTimeout: function(e, t) {
|
|
447
447
|
for (var r = [], s = 2; s < arguments.length; s++)
|
|
448
448
|
r[s - 2] = arguments[s];
|
|
449
|
-
return setTimeout.apply(void 0,
|
|
449
|
+
return setTimeout.apply(void 0, Le([e, t], Te(r)));
|
|
450
450
|
},
|
|
451
451
|
clearTimeout: function(e) {
|
|
452
452
|
return clearTimeout(e);
|
|
453
453
|
},
|
|
454
454
|
delegate: void 0
|
|
455
455
|
};
|
|
456
|
-
function
|
|
457
|
-
|
|
456
|
+
function Jt(e) {
|
|
457
|
+
qt.setTimeout(function() {
|
|
458
458
|
throw e;
|
|
459
459
|
});
|
|
460
460
|
}
|
|
461
|
-
function
|
|
461
|
+
function je() {
|
|
462
462
|
}
|
|
463
|
-
function
|
|
463
|
+
function ie(e) {
|
|
464
464
|
e();
|
|
465
465
|
}
|
|
466
|
-
var
|
|
467
|
-
|
|
466
|
+
var wt = (function(e) {
|
|
467
|
+
fe(t, e);
|
|
468
468
|
function t(r) {
|
|
469
469
|
var s = e.call(this) || this;
|
|
470
|
-
return s.isStopped = !1, r ? (s.destination = r,
|
|
470
|
+
return s.isStopped = !1, r ? (s.destination = r, mt(r) && r.add(s)) : s.destination = Zt, s;
|
|
471
471
|
}
|
|
472
472
|
return t.create = function(r, s, n) {
|
|
473
|
-
return new
|
|
473
|
+
return new Re(r, s, n);
|
|
474
474
|
}, t.prototype.next = function(r) {
|
|
475
475
|
this.isStopped || this._next(r);
|
|
476
476
|
}, t.prototype.error = function(r) {
|
|
@@ -494,7 +494,7 @@ var mt = (function(e) {
|
|
|
494
494
|
this.unsubscribe();
|
|
495
495
|
}
|
|
496
496
|
}, t;
|
|
497
|
-
})(
|
|
497
|
+
})(de), Qt = (function() {
|
|
498
498
|
function e(t) {
|
|
499
499
|
this.partialObserver = t;
|
|
500
500
|
}
|
|
@@ -504,7 +504,7 @@ var mt = (function(e) {
|
|
|
504
504
|
try {
|
|
505
505
|
r.next(t);
|
|
506
506
|
} catch (s) {
|
|
507
|
-
|
|
507
|
+
se(s);
|
|
508
508
|
}
|
|
509
509
|
}, e.prototype.error = function(t) {
|
|
510
510
|
var r = this.partialObserver;
|
|
@@ -512,56 +512,56 @@ var mt = (function(e) {
|
|
|
512
512
|
try {
|
|
513
513
|
r.error(t);
|
|
514
514
|
} catch (s) {
|
|
515
|
-
|
|
515
|
+
se(s);
|
|
516
516
|
}
|
|
517
517
|
else
|
|
518
|
-
|
|
518
|
+
se(t);
|
|
519
519
|
}, e.prototype.complete = function() {
|
|
520
520
|
var t = this.partialObserver;
|
|
521
521
|
if (t.complete)
|
|
522
522
|
try {
|
|
523
523
|
t.complete();
|
|
524
524
|
} catch (r) {
|
|
525
|
-
|
|
525
|
+
se(r);
|
|
526
526
|
}
|
|
527
527
|
}, e;
|
|
528
|
-
})(),
|
|
529
|
-
|
|
528
|
+
})(), Re = (function(e) {
|
|
529
|
+
fe(t, e);
|
|
530
530
|
function t(r, s, n) {
|
|
531
|
-
var
|
|
532
|
-
return
|
|
531
|
+
var o = e.call(this) || this, a;
|
|
532
|
+
return B(r) || !r ? a = {
|
|
533
533
|
next: r ?? void 0,
|
|
534
534
|
error: s ?? void 0,
|
|
535
535
|
complete: n ?? void 0
|
|
536
|
-
} :
|
|
536
|
+
} : a = r, o.destination = new Qt(a), o;
|
|
537
537
|
}
|
|
538
538
|
return t;
|
|
539
|
-
})(
|
|
540
|
-
function
|
|
541
|
-
|
|
539
|
+
})(wt);
|
|
540
|
+
function se(e) {
|
|
541
|
+
Jt(e);
|
|
542
542
|
}
|
|
543
543
|
function Kt(e) {
|
|
544
544
|
throw e;
|
|
545
545
|
}
|
|
546
|
-
var
|
|
546
|
+
var Zt = {
|
|
547
547
|
closed: !0,
|
|
548
|
-
next:
|
|
548
|
+
next: je,
|
|
549
549
|
error: Kt,
|
|
550
|
-
complete:
|
|
551
|
-
},
|
|
550
|
+
complete: je
|
|
551
|
+
}, er = (function() {
|
|
552
552
|
return typeof Symbol == "function" && Symbol.observable || "@@observable";
|
|
553
553
|
})();
|
|
554
|
-
function
|
|
554
|
+
function tr(e) {
|
|
555
555
|
return e;
|
|
556
556
|
}
|
|
557
|
-
function
|
|
558
|
-
return e.length === 0 ?
|
|
557
|
+
function rr(e) {
|
|
558
|
+
return e.length === 0 ? tr : e.length === 1 ? e[0] : function(r) {
|
|
559
559
|
return e.reduce(function(s, n) {
|
|
560
560
|
return n(s);
|
|
561
561
|
}, r);
|
|
562
562
|
};
|
|
563
563
|
}
|
|
564
|
-
var
|
|
564
|
+
var We = (function() {
|
|
565
565
|
function e(t) {
|
|
566
566
|
t && (this._subscribe = t);
|
|
567
567
|
}
|
|
@@ -569,11 +569,11 @@ var je = (function() {
|
|
|
569
569
|
var r = new e();
|
|
570
570
|
return r.source = this, r.operator = t, r;
|
|
571
571
|
}, e.prototype.subscribe = function(t, r, s) {
|
|
572
|
-
var n = this,
|
|
573
|
-
return
|
|
574
|
-
var
|
|
575
|
-
|
|
576
|
-
}),
|
|
572
|
+
var n = this, o = nr(t) ? t : new Re(t, r, s);
|
|
573
|
+
return ie(function() {
|
|
574
|
+
var a = n, i = a.operator, l = a.source;
|
|
575
|
+
o.add(i ? i.call(o, l) : l ? n._subscribe(o) : n._trySubscribe(o));
|
|
576
|
+
}), o;
|
|
577
577
|
}, e.prototype._trySubscribe = function(t) {
|
|
578
578
|
try {
|
|
579
579
|
return this._subscribe(t);
|
|
@@ -582,61 +582,61 @@ var je = (function() {
|
|
|
582
582
|
}
|
|
583
583
|
}, e.prototype.forEach = function(t, r) {
|
|
584
584
|
var s = this;
|
|
585
|
-
return r =
|
|
586
|
-
var
|
|
585
|
+
return r = Ye(r), new r(function(n, o) {
|
|
586
|
+
var a = new Re({
|
|
587
587
|
next: function(i) {
|
|
588
588
|
try {
|
|
589
589
|
t(i);
|
|
590
590
|
} catch (l) {
|
|
591
|
-
|
|
591
|
+
o(l), a.unsubscribe();
|
|
592
592
|
}
|
|
593
593
|
},
|
|
594
|
-
error:
|
|
594
|
+
error: o,
|
|
595
595
|
complete: n
|
|
596
596
|
});
|
|
597
|
-
s.subscribe(
|
|
597
|
+
s.subscribe(a);
|
|
598
598
|
});
|
|
599
599
|
}, e.prototype._subscribe = function(t) {
|
|
600
600
|
var r;
|
|
601
601
|
return (r = this.source) === null || r === void 0 ? void 0 : r.subscribe(t);
|
|
602
|
-
}, e.prototype[
|
|
602
|
+
}, e.prototype[er] = function() {
|
|
603
603
|
return this;
|
|
604
604
|
}, e.prototype.pipe = function() {
|
|
605
605
|
for (var t = [], r = 0; r < arguments.length; r++)
|
|
606
606
|
t[r] = arguments[r];
|
|
607
|
-
return
|
|
607
|
+
return rr(t)(this);
|
|
608
608
|
}, e.prototype.toPromise = function(t) {
|
|
609
609
|
var r = this;
|
|
610
|
-
return t =
|
|
611
|
-
var
|
|
612
|
-
r.subscribe(function(
|
|
613
|
-
return
|
|
614
|
-
}, function(
|
|
615
|
-
return n(
|
|
610
|
+
return t = Ye(t), new t(function(s, n) {
|
|
611
|
+
var o;
|
|
612
|
+
r.subscribe(function(a) {
|
|
613
|
+
return o = a;
|
|
614
|
+
}, function(a) {
|
|
615
|
+
return n(a);
|
|
616
616
|
}, function() {
|
|
617
|
-
return s(
|
|
617
|
+
return s(o);
|
|
618
618
|
});
|
|
619
619
|
});
|
|
620
620
|
}, e.create = function(t) {
|
|
621
621
|
return new e(t);
|
|
622
622
|
}, e;
|
|
623
623
|
})();
|
|
624
|
-
function
|
|
624
|
+
function Ye(e) {
|
|
625
625
|
var t;
|
|
626
|
-
return (t = e ??
|
|
627
|
-
}
|
|
628
|
-
function rr(e) {
|
|
629
|
-
return e && N(e.next) && N(e.error) && N(e.complete);
|
|
626
|
+
return (t = e ?? Vt.Promise) !== null && t !== void 0 ? t : Promise;
|
|
630
627
|
}
|
|
631
628
|
function sr(e) {
|
|
632
|
-
return e && e
|
|
629
|
+
return e && B(e.next) && B(e.error) && B(e.complete);
|
|
633
630
|
}
|
|
634
|
-
|
|
631
|
+
function nr(e) {
|
|
632
|
+
return e && e instanceof wt || sr(e) && mt(e);
|
|
633
|
+
}
|
|
634
|
+
var or = yt(function(e) {
|
|
635
635
|
return function() {
|
|
636
636
|
e(this), this.name = "ObjectUnsubscribedError", this.message = "object unsubscribed";
|
|
637
637
|
};
|
|
638
|
-
}),
|
|
639
|
-
|
|
638
|
+
}), bt = (function(e) {
|
|
639
|
+
fe(t, e);
|
|
640
640
|
function t() {
|
|
641
641
|
var r = e.call(this) || this;
|
|
642
642
|
return r.closed = !1, r.currentObservers = null, r.observers = [], r.isStopped = !1, r.hasError = !1, r.thrownError = null, r;
|
|
@@ -646,15 +646,15 @@ var nr = pt(function(e) {
|
|
|
646
646
|
return s.operator = r, s;
|
|
647
647
|
}, t.prototype._throwIfClosed = function() {
|
|
648
648
|
if (this.closed)
|
|
649
|
-
throw new
|
|
649
|
+
throw new or();
|
|
650
650
|
}, t.prototype.next = function(r) {
|
|
651
651
|
var s = this;
|
|
652
|
-
|
|
653
|
-
var n,
|
|
652
|
+
ie(function() {
|
|
653
|
+
var n, o;
|
|
654
654
|
if (s._throwIfClosed(), !s.isStopped) {
|
|
655
655
|
s.currentObservers || (s.currentObservers = Array.from(s.observers));
|
|
656
656
|
try {
|
|
657
|
-
for (var
|
|
657
|
+
for (var a = Ae(s.currentObservers), i = a.next(); !i.done; i = a.next()) {
|
|
658
658
|
var l = i.value;
|
|
659
659
|
l.next(r);
|
|
660
660
|
}
|
|
@@ -662,7 +662,7 @@ var nr = pt(function(e) {
|
|
|
662
662
|
n = { error: f };
|
|
663
663
|
} finally {
|
|
664
664
|
try {
|
|
665
|
-
i && !i.done && (
|
|
665
|
+
i && !i.done && (o = a.return) && o.call(a);
|
|
666
666
|
} finally {
|
|
667
667
|
if (n) throw n.error;
|
|
668
668
|
}
|
|
@@ -671,7 +671,7 @@ var nr = pt(function(e) {
|
|
|
671
671
|
});
|
|
672
672
|
}, t.prototype.error = function(r) {
|
|
673
673
|
var s = this;
|
|
674
|
-
|
|
674
|
+
ie(function() {
|
|
675
675
|
if (s._throwIfClosed(), !s.isStopped) {
|
|
676
676
|
s.hasError = s.isStopped = !0, s.thrownError = r;
|
|
677
677
|
for (var n = s.observers; n.length; )
|
|
@@ -680,7 +680,7 @@ var nr = pt(function(e) {
|
|
|
680
680
|
});
|
|
681
681
|
}, t.prototype.complete = function() {
|
|
682
682
|
var r = this;
|
|
683
|
-
|
|
683
|
+
ie(function() {
|
|
684
684
|
if (r._throwIfClosed(), !r.isStopped) {
|
|
685
685
|
r.isStopped = !0;
|
|
686
686
|
for (var s = r.observers; s.length; )
|
|
@@ -701,21 +701,21 @@ var nr = pt(function(e) {
|
|
|
701
701
|
}, t.prototype._subscribe = function(r) {
|
|
702
702
|
return this._throwIfClosed(), this._checkFinalizedStatuses(r), this._innerSubscribe(r);
|
|
703
703
|
}, t.prototype._innerSubscribe = function(r) {
|
|
704
|
-
var s = this, n = this,
|
|
705
|
-
return
|
|
706
|
-
s.currentObservers = null,
|
|
704
|
+
var s = this, n = this, o = n.hasError, a = n.isStopped, i = n.observers;
|
|
705
|
+
return o || a ? gt : (this.currentObservers = null, i.push(r), new de(function() {
|
|
706
|
+
s.currentObservers = null, $e(i, r);
|
|
707
707
|
}));
|
|
708
708
|
}, t.prototype._checkFinalizedStatuses = function(r) {
|
|
709
|
-
var s = this, n = s.hasError,
|
|
710
|
-
n ? r.error(
|
|
709
|
+
var s = this, n = s.hasError, o = s.thrownError, a = s.isStopped;
|
|
710
|
+
n ? r.error(o) : a && r.complete();
|
|
711
711
|
}, t.prototype.asObservable = function() {
|
|
712
|
-
var r = new
|
|
712
|
+
var r = new We();
|
|
713
713
|
return r.source = this, r;
|
|
714
714
|
}, t.create = function(r, s) {
|
|
715
715
|
return new Ge(r, s);
|
|
716
716
|
}, t;
|
|
717
|
-
})(
|
|
718
|
-
|
|
717
|
+
})(We), Ge = (function(e) {
|
|
718
|
+
fe(t, e);
|
|
719
719
|
function t(r, s) {
|
|
720
720
|
var n = e.call(this) || this;
|
|
721
721
|
return n.destination = r, n.source = s, n;
|
|
@@ -731,29 +731,29 @@ var nr = pt(function(e) {
|
|
|
731
731
|
(s = (r = this.destination) === null || r === void 0 ? void 0 : r.complete) === null || s === void 0 || s.call(r);
|
|
732
732
|
}, t.prototype._subscribe = function(r) {
|
|
733
733
|
var s, n;
|
|
734
|
-
return (n = (s = this.source) === null || s === void 0 ? void 0 : s.subscribe(r)) !== null && n !== void 0 ? n :
|
|
734
|
+
return (n = (s = this.source) === null || s === void 0 ? void 0 : s.subscribe(r)) !== null && n !== void 0 ? n : gt;
|
|
735
735
|
}, t;
|
|
736
|
-
})(
|
|
737
|
-
const
|
|
738
|
-
var
|
|
739
|
-
class
|
|
740
|
-
constructor(t = "", r = "info", s = "none", n = "Info",
|
|
741
|
-
this.message = t, this.color = r, this.icon = s, this.title = n, this.timeout =
|
|
736
|
+
})(bt);
|
|
737
|
+
const St = 3e3;
|
|
738
|
+
var Et = /* @__PURE__ */ ((e) => (e.Warning = "warning", e.Success = "success", e.Error = "error", e.Info = "info", e))(Et || {}), vt = /* @__PURE__ */ ((e) => (e.Success = "mdi-checkbox-marked-circle", e.Warning = "mdi-alert", e.Error = "mdi-alert-circle", e.Info = "mdi-information", e.None = "none", e))(vt || {}), kt = /* @__PURE__ */ ((e) => (e.Warning = "Warning", e.Success = "Success", e.Error = "Error", e.Info = "Info", e))(kt || {}), ar = /* @__PURE__ */ ((e) => (e.Center = "center", e.Left = "left", e.Right = "right", e.Bottom = "bottom", e.Top = "top", e))(ar || {});
|
|
739
|
+
class ir {
|
|
740
|
+
constructor(t = "", r = "info", s = "none", n = "Info", o = St, a = "center", i = !1) {
|
|
741
|
+
this.message = t, this.color = r, this.icon = s, this.title = n, this.timeout = o, this.position = a, this.visible = i;
|
|
742
742
|
}
|
|
743
743
|
}
|
|
744
|
-
class
|
|
745
|
-
static subject = new
|
|
744
|
+
class cr {
|
|
745
|
+
static subject = new bt();
|
|
746
746
|
static get snack$() {
|
|
747
747
|
return this.subject.asObservable();
|
|
748
748
|
}
|
|
749
749
|
static createSnackbar(t, r) {
|
|
750
750
|
this.subject.next(
|
|
751
|
-
new
|
|
751
|
+
new ir(
|
|
752
752
|
t,
|
|
753
|
-
St[r],
|
|
754
753
|
Et[r],
|
|
754
|
+
vt[r],
|
|
755
755
|
kt[r],
|
|
756
|
-
|
|
756
|
+
St,
|
|
757
757
|
"bottom",
|
|
758
758
|
!0
|
|
759
759
|
)
|
|
@@ -788,24 +788,24 @@ class ir {
|
|
|
788
788
|
);
|
|
789
789
|
}
|
|
790
790
|
}
|
|
791
|
-
function
|
|
791
|
+
function _t(e, t) {
|
|
792
792
|
const r = {};
|
|
793
793
|
for (let s in t)
|
|
794
794
|
if (Array.isArray(t[s]))
|
|
795
795
|
JSON.stringify(e[s]) !== JSON.stringify(t[s]) && (r[s] = t[s]);
|
|
796
796
|
else if (e[s] && typeof e[s] == "object" && t[s] && typeof t[s] == "object") {
|
|
797
|
-
const n =
|
|
797
|
+
const n = _t(e[s], t[s]);
|
|
798
798
|
Object.keys(n).length > 0 && (r[s] = n);
|
|
799
799
|
} else JSON.stringify(e[s]) !== JSON.stringify(t[s]) && (r[s] = t[s]);
|
|
800
800
|
return r;
|
|
801
801
|
}
|
|
802
|
-
function
|
|
802
|
+
function lr(e) {
|
|
803
803
|
return e && e.__esModule && Object.prototype.hasOwnProperty.call(e, "default") ? e.default : e;
|
|
804
804
|
}
|
|
805
|
-
var
|
|
806
|
-
function
|
|
807
|
-
if (
|
|
808
|
-
|
|
805
|
+
var me, He;
|
|
806
|
+
function ur() {
|
|
807
|
+
if (He) return me;
|
|
808
|
+
He = 1;
|
|
809
809
|
class e {
|
|
810
810
|
/// value;
|
|
811
811
|
/// next;
|
|
@@ -842,33 +842,33 @@ function lr() {
|
|
|
842
842
|
yield s.value, s = s.next;
|
|
843
843
|
}
|
|
844
844
|
}
|
|
845
|
-
return
|
|
845
|
+
return me = t, me;
|
|
846
846
|
}
|
|
847
|
-
var
|
|
848
|
-
function
|
|
849
|
-
if (
|
|
850
|
-
|
|
851
|
-
const e =
|
|
852
|
-
return
|
|
847
|
+
var we, ze;
|
|
848
|
+
function hr() {
|
|
849
|
+
if (ze) return we;
|
|
850
|
+
ze = 1;
|
|
851
|
+
const e = ur();
|
|
852
|
+
return we = (r) => {
|
|
853
853
|
if (!((Number.isInteger(r) || r === 1 / 0) && r > 0))
|
|
854
854
|
throw new TypeError("Expected `concurrency` to be a number from 1 and up");
|
|
855
855
|
const s = new e();
|
|
856
856
|
let n = 0;
|
|
857
|
-
const
|
|
857
|
+
const o = () => {
|
|
858
858
|
n--, s.size > 0 && s.dequeue()();
|
|
859
|
-
},
|
|
859
|
+
}, a = async (f, h, ...y) => {
|
|
860
860
|
n++;
|
|
861
|
-
const
|
|
862
|
-
|
|
861
|
+
const p = (async () => f(...y))();
|
|
862
|
+
h(p);
|
|
863
863
|
try {
|
|
864
|
-
await
|
|
864
|
+
await p;
|
|
865
865
|
} catch {
|
|
866
866
|
}
|
|
867
|
-
|
|
868
|
-
}, i = (f,
|
|
869
|
-
s.enqueue(
|
|
870
|
-
}, l = (f, ...
|
|
871
|
-
i(f,
|
|
867
|
+
o();
|
|
868
|
+
}, i = (f, h, ...y) => {
|
|
869
|
+
s.enqueue(a.bind(null, f, h, ...y)), (async () => (await Promise.resolve(), n < r && s.size > 0 && s.dequeue()()))();
|
|
870
|
+
}, l = (f, ...h) => new Promise((y) => {
|
|
871
|
+
i(f, y, ...h);
|
|
872
872
|
});
|
|
873
873
|
return Object.defineProperties(l, {
|
|
874
874
|
activeCount: {
|
|
@@ -883,45 +883,45 @@ function ur() {
|
|
|
883
883
|
}
|
|
884
884
|
}
|
|
885
885
|
}), l;
|
|
886
|
-
},
|
|
886
|
+
}, we;
|
|
887
887
|
}
|
|
888
|
-
var
|
|
889
|
-
const
|
|
890
|
-
async function
|
|
891
|
-
const r =
|
|
888
|
+
var fr = hr();
|
|
889
|
+
const dr = /* @__PURE__ */ lr(fr), G = dr(10), pr = 1e3;
|
|
890
|
+
async function V(e, t) {
|
|
891
|
+
const r = dt(t);
|
|
892
892
|
try {
|
|
893
893
|
const s = await fetch(e, r);
|
|
894
|
-
return await
|
|
894
|
+
return await pt(s);
|
|
895
895
|
} catch (s) {
|
|
896
|
-
throw s instanceof TypeError &&
|
|
896
|
+
throw s instanceof TypeError && cr.error("Network error. Please check your connection."), s;
|
|
897
897
|
}
|
|
898
898
|
}
|
|
899
899
|
const c = {
|
|
900
900
|
async fetch(e, t = {}) {
|
|
901
|
-
return t.method = "GET", await
|
|
901
|
+
return t.method = "GET", await G(() => V(e, t));
|
|
902
902
|
},
|
|
903
903
|
async patch(e, t, r = null, s = {}) {
|
|
904
|
-
if (s.method = "PATCH", s.body = r ?
|
|
905
|
-
return await
|
|
904
|
+
if (s.method = "PATCH", s.body = r ? _t(r, t) : t, Object.keys(s.body).length !== 0)
|
|
905
|
+
return await G(() => V(e, s));
|
|
906
906
|
},
|
|
907
907
|
async post(e, t = void 0, r = {}) {
|
|
908
|
-
return r.method = "POST", r.body = t, await
|
|
908
|
+
return r.method = "POST", r.body = t, await G(() => V(e, r));
|
|
909
909
|
},
|
|
910
910
|
async put(e, t = void 0, r = {}) {
|
|
911
|
-
return r.method = "PUT", r.body = t, await
|
|
911
|
+
return r.method = "PUT", r.body = t, await G(() => V(e, r));
|
|
912
912
|
},
|
|
913
913
|
async delete(e, t = void 0, r = {}) {
|
|
914
|
-
return r.method = "DELETE", r.body = t, await
|
|
914
|
+
return r.method = "DELETE", r.body = t, await G(() => V(e, r));
|
|
915
915
|
},
|
|
916
916
|
async paginatedFetch(e, t) {
|
|
917
|
-
const r = t ??
|
|
918
|
-
for (let
|
|
919
|
-
const
|
|
920
|
-
f.push(...
|
|
917
|
+
const r = t ?? pr, s = e.includes("?") ? "&" : "?", n = `${e}${s}page_size=${r}&page=1`, o = dt({ method: "GET" }), a = await G(() => fetch(n, o)), i = Number(a.headers.get("x-total-pages")) || 1, f = [...await pt(a)];
|
|
918
|
+
for (let h = 2; h <= i; h++) {
|
|
919
|
+
const y = `${e}${s}page_size=${r}&page=${h}`, p = await G(() => V(y, { method: "GET" }));
|
|
920
|
+
f.push(...p);
|
|
921
921
|
}
|
|
922
922
|
return f;
|
|
923
923
|
}
|
|
924
|
-
},
|
|
924
|
+
}, Xe = {
|
|
925
925
|
HTTP: {
|
|
926
926
|
type: "HTTP",
|
|
927
927
|
sourceUri: "",
|
|
@@ -932,7 +932,7 @@ const c = {
|
|
|
932
932
|
sourceUri: "",
|
|
933
933
|
placeholderVariables: []
|
|
934
934
|
}
|
|
935
|
-
},
|
|
935
|
+
}, Ve = {
|
|
936
936
|
JSON: {
|
|
937
937
|
type: "JSON",
|
|
938
938
|
timestamp: {
|
|
@@ -955,18 +955,18 @@ const c = {
|
|
|
955
955
|
identifierType: "name"
|
|
956
956
|
/* Name */
|
|
957
957
|
}
|
|
958
|
-
},
|
|
958
|
+
}, qe = {
|
|
959
959
|
HydroServer: {
|
|
960
960
|
type: "HydroServer"
|
|
961
961
|
}
|
|
962
962
|
};
|
|
963
|
-
class
|
|
963
|
+
class fs {
|
|
964
964
|
name = "";
|
|
965
965
|
settings = {
|
|
966
966
|
type: "SDL",
|
|
967
|
-
extractor: JSON.parse(JSON.stringify(
|
|
968
|
-
transformer: JSON.parse(JSON.stringify(
|
|
969
|
-
loader: JSON.parse(JSON.stringify(
|
|
967
|
+
extractor: JSON.parse(JSON.stringify(Xe.local)),
|
|
968
|
+
transformer: JSON.parse(JSON.stringify(Ve.CSV)),
|
|
969
|
+
loader: JSON.parse(JSON.stringify(qe.HydroServer)),
|
|
970
970
|
payloads: []
|
|
971
971
|
};
|
|
972
972
|
id = "";
|
|
@@ -988,19 +988,19 @@ class cs {
|
|
|
988
988
|
}
|
|
989
989
|
switchExtractor(t) {
|
|
990
990
|
this.settings.extractor = JSON.parse(
|
|
991
|
-
JSON.stringify(
|
|
991
|
+
JSON.stringify(Xe[t])
|
|
992
992
|
);
|
|
993
993
|
}
|
|
994
994
|
switchTransformer(t) {
|
|
995
995
|
this.settings.transformer = JSON.parse(
|
|
996
|
-
JSON.stringify(
|
|
996
|
+
JSON.stringify(Ve[t])
|
|
997
997
|
);
|
|
998
998
|
}
|
|
999
999
|
switchLoader(t) {
|
|
1000
|
-
this.settings.loader = JSON.parse(JSON.stringify(
|
|
1000
|
+
this.settings.loader = JSON.parse(JSON.stringify(qe[t]));
|
|
1001
1001
|
}
|
|
1002
1002
|
}
|
|
1003
|
-
function
|
|
1003
|
+
function Je(e) {
|
|
1004
1004
|
return {
|
|
1005
1005
|
name: e.name,
|
|
1006
1006
|
settings: e.settings,
|
|
@@ -1010,28 +1010,28 @@ function qe(e) {
|
|
|
1010
1010
|
status: e.status
|
|
1011
1011
|
};
|
|
1012
1012
|
}
|
|
1013
|
-
const
|
|
1014
|
-
let
|
|
1015
|
-
return
|
|
1016
|
-
},
|
|
1013
|
+
const F = "https://lro.hydroserver.org/api", Ue = `${F}/auth`, C = `${Ue}/browser/account`, be = `${Ue}/browser/session`, ce = `${Ue}/browser/provider`, $ = `${F}/data/workspaces`, Se = `${F}/data/roles`, I = `${F}/data/datastreams`, W = `${F}/data/sensors`, _ = `${F}/data/things`, Qe = `${_}/tags`, q = `${F}/data/orchestration-systems`, N = `${F}/data/data-sources`, H = `${F}/data/observed-properties`, J = `${F}/data/processing-levels`, Z = `${F}/data/result-qualifiers`, z = `${F}/data/units`, ds = (e, t, r, s, n) => {
|
|
1014
|
+
let o = `${I}/${e}/observations?format=column`;
|
|
1015
|
+
return o += `&order_by=phenomenonTime&page_size=${t}`, o += `&phenomenon_time_min=${encodeURIComponent(r)}`, s && (o += `&phenomenon_time_max=${encodeURIComponent(s)}`), n && (o += `&page=${n}`), o;
|
|
1016
|
+
}, yr = (e, t, r) => {
|
|
1017
1017
|
const s = {
|
|
1018
1018
|
provider: e,
|
|
1019
1019
|
callback_url: t,
|
|
1020
1020
|
process: r
|
|
1021
|
-
}, n =
|
|
1022
|
-
if (
|
|
1023
|
-
const
|
|
1024
|
-
|
|
1021
|
+
}, n = ft(), o = document.createElement("form");
|
|
1022
|
+
if (o.method = "POST", o.action = `${ce}/redirect`, n) {
|
|
1023
|
+
const a = document.createElement("input");
|
|
1024
|
+
a.type = "hidden", a.name = "csrfmiddlewaretoken", a.value = n, o.appendChild(a);
|
|
1025
1025
|
}
|
|
1026
|
-
for (const
|
|
1026
|
+
for (const a in s) {
|
|
1027
1027
|
const i = document.createElement("input");
|
|
1028
|
-
i.type = "hidden", i.name =
|
|
1028
|
+
i.type = "hidden", i.name = a, i.value = s[a] || "", o.appendChild(i);
|
|
1029
1029
|
}
|
|
1030
|
-
document.body.appendChild(
|
|
1031
|
-
},
|
|
1032
|
-
fetchSession: async () => c.fetch(`${
|
|
1033
|
-
login: async (e, t) => c.post(`${
|
|
1034
|
-
logout: async () => c.delete(`${
|
|
1030
|
+
document.body.appendChild(o), o.submit();
|
|
1031
|
+
}, ps = {
|
|
1032
|
+
fetchSession: async () => c.fetch(`${be}`),
|
|
1033
|
+
login: async (e, t) => c.post(`${be}`, { email: e, password: t }),
|
|
1034
|
+
logout: async () => c.delete(`${be}`),
|
|
1035
1035
|
fetchUser: async () => c.fetch(`${C}`),
|
|
1036
1036
|
signup: async (e) => c.post(`${C}`, e),
|
|
1037
1037
|
updateUser: async (e, t) => c.patch(`${C}`, e, t),
|
|
@@ -1060,9 +1060,9 @@ const D = "https://lro.hydroserver.org/api", Ue = `${D}/auth`, C = `${Ue}/browse
|
|
|
1060
1060
|
transferWorkspace: async (e, t) => c.post(`${$}/${e}/transfer`, { newOwner: t }),
|
|
1061
1061
|
acceptWorkspaceTransfer: async (e) => c.put(`${$}/${e}/transfer`),
|
|
1062
1062
|
rejectWorkspaceTransfer: async (e) => c.delete(`${$}/${e}/transfer`),
|
|
1063
|
-
getCollaboratorRoles: async (e) => c.paginatedFetch(`${
|
|
1064
|
-
getAPIKeyRoles: async (e) => c.paginatedFetch(`${
|
|
1065
|
-
getRole: async (e) => c.fetch(`${
|
|
1063
|
+
getCollaboratorRoles: async (e) => c.paginatedFetch(`${Se}?is_user_role=true`),
|
|
1064
|
+
getAPIKeyRoles: async (e) => c.paginatedFetch(`${Se}?is_apikey_role=true`),
|
|
1065
|
+
getRole: async (e) => c.fetch(`${Se}/${e}`),
|
|
1066
1066
|
getCollaborators: async (e) => c.paginatedFetch(`${$}/${e}/collaborators`),
|
|
1067
1067
|
addCollaborator: async (e, t, r) => c.post(`${$}/${e}/collaborators`, {
|
|
1068
1068
|
email: t,
|
|
@@ -1107,10 +1107,10 @@ const D = "https://lro.hydroserver.org/api", Ue = `${D}/auth`, C = `${Ue}/browse
|
|
|
1107
1107
|
`${$}/${e}/api-keys/${t}/regenerate?expand_related=true`
|
|
1108
1108
|
),
|
|
1109
1109
|
deleteApiKey: async (e, t) => c.delete(`${$}/${e}/api-keys/${t}`),
|
|
1110
|
-
fetchConnectedProviders: async () => c.fetch(`${
|
|
1111
|
-
providerRedirect:
|
|
1112
|
-
providerSignup: async (e) => c.post(`${
|
|
1113
|
-
deleteProvider: async (e, t) => c.delete(`${
|
|
1110
|
+
fetchConnectedProviders: async () => c.fetch(`${ce}/connections`),
|
|
1111
|
+
providerRedirect: yr,
|
|
1112
|
+
providerSignup: async (e) => c.post(`${ce}/signup`, e),
|
|
1113
|
+
deleteProvider: async (e, t) => c.delete(`${ce}/connections`, {
|
|
1114
1114
|
provider: e,
|
|
1115
1115
|
account: t
|
|
1116
1116
|
}),
|
|
@@ -1150,9 +1150,9 @@ const D = "https://lro.hydroserver.org/api", Ue = `${D}/auth`, C = `${Ue}/browse
|
|
|
1150
1150
|
createSiteTag: async (e, t) => c.post(`${_}/${e}/tags`, t),
|
|
1151
1151
|
editSiteTag: async (e, t) => c.put(`${_}/${e}/tags`, t),
|
|
1152
1152
|
fetchSiteTags: async (e) => c.fetch(`${_}/${e}/tags`),
|
|
1153
|
-
fetchUsersSiteTags: async () => c.fetch(`${
|
|
1153
|
+
fetchUsersSiteTags: async () => c.fetch(`${Qe}`),
|
|
1154
1154
|
deleteSiteTag: async (e, t) => c.delete(`${_}/${e}/tags`, t),
|
|
1155
|
-
fetchWorkspaceTags: async (e) => c.fetch(`${
|
|
1155
|
+
fetchWorkspaceTags: async (e) => c.fetch(`${Qe}/keys?workspace_id=${e}`),
|
|
1156
1156
|
createHydroShareArchive: async (e) => c.post(`${_}/${e.thingId}/archive`, e),
|
|
1157
1157
|
updateHydroShareArchive: async (e, t) => c.patch(
|
|
1158
1158
|
`${_}/${e.thingId}/archive`,
|
|
@@ -1162,85 +1162,85 @@ const D = "https://lro.hydroserver.org/api", Ue = `${D}/auth`, C = `${Ue}/browse
|
|
|
1162
1162
|
fetchHydroShareArchive: async (e) => c.fetch(`${_}/${e}/archive`),
|
|
1163
1163
|
deleteHydroShareArchive: async (e) => c.delete(`${_}/${e}/archive`),
|
|
1164
1164
|
archiveToHydroShare: async (e) => c.post(`${_}/${e}/archive/trigger`),
|
|
1165
|
-
createDatastream: async (e) => c.post(
|
|
1165
|
+
createDatastream: async (e) => c.post(I, e),
|
|
1166
1166
|
fetchDatastreams: async (e) => {
|
|
1167
1167
|
const t = [];
|
|
1168
1168
|
if (e)
|
|
1169
1169
|
for (const [s, n] of Object.entries(e))
|
|
1170
1170
|
t.push(`${encodeURIComponent(s)}=${encodeURIComponent(n)}`);
|
|
1171
1171
|
const r = t.length ? `?${t.join("&")}` : "";
|
|
1172
|
-
return c.paginatedFetch(`${
|
|
1172
|
+
return c.paginatedFetch(`${I}${r}`);
|
|
1173
1173
|
},
|
|
1174
|
-
fetchDatastreamsForThing: async (e) => c.paginatedFetch(`${
|
|
1174
|
+
fetchDatastreamsForThing: async (e) => c.paginatedFetch(`${I}?thing_id=${e}`),
|
|
1175
1175
|
fetchExpandedDatastreamsForThing: async (e) => c.paginatedFetch(
|
|
1176
|
-
`${
|
|
1176
|
+
`${I}?thing_id=${e}&expand_related=true`
|
|
1177
1177
|
),
|
|
1178
|
-
fetchDatastreamsForDataSource: async (e) => c.paginatedFetch(`${
|
|
1179
|
-
fetchDatastream: async (e) => c.fetch(`${
|
|
1180
|
-
fetchDatastreamExpanded: async (e) => c.fetch(`${
|
|
1181
|
-
fetchUsersDatastreams: async () => c.paginatedFetch(`${
|
|
1182
|
-
updateDatastream: async (e, t = null) => c.patch(`${
|
|
1183
|
-
deleteDatastream: async (e) => c.delete(`${
|
|
1184
|
-
downloadDatastreamCSV: async (e) => c.fetch(`${
|
|
1178
|
+
fetchDatastreamsForDataSource: async (e) => c.paginatedFetch(`${I}?data_source_id=${e}`),
|
|
1179
|
+
fetchDatastream: async (e) => c.fetch(`${I}/${e}`),
|
|
1180
|
+
fetchDatastreamExpanded: async (e) => c.fetch(`${I}/${e}?expand_related=true`),
|
|
1181
|
+
fetchUsersDatastreams: async () => c.paginatedFetch(`${I}?exclude_unowned=true`),
|
|
1182
|
+
updateDatastream: async (e, t = null) => c.patch(`${I}/${e.id}`, e, t),
|
|
1183
|
+
deleteDatastream: async (e) => c.delete(`${I}/${e}`),
|
|
1184
|
+
downloadDatastreamCSV: async (e) => c.fetch(`${I}/${e}/csv`),
|
|
1185
1185
|
createObservedProperty: async (e) => c.post(H, e),
|
|
1186
1186
|
fetchObservedProperty: async (e) => c.fetch(`${H}/${e}`),
|
|
1187
1187
|
fetchObservedProperties: async () => c.paginatedFetch(`${H}`),
|
|
1188
1188
|
fetchWorkspaceObservedProperties: async (e) => c.paginatedFetch(`${H}?workspace_id=${e}`),
|
|
1189
1189
|
updateObservedProperty: async (e, t = null) => c.patch(`${H}/${e.id}`, e, t),
|
|
1190
1190
|
deleteObservedProperty: async (e) => c.delete(`${H}/${e}`),
|
|
1191
|
-
createProcessingLevel: async (e) => c.post(
|
|
1192
|
-
fetchProcessingLevels: async () => c.paginatedFetch(`${
|
|
1193
|
-
fetchProcessingLevel: async (e) => c.fetch(`${
|
|
1194
|
-
fetchWorkspaceProcessingLevels: async (e) => c.paginatedFetch(`${
|
|
1195
|
-
updateProcessingLevel: async (e, t = null) => c.patch(`${
|
|
1196
|
-
deleteProcessingLevel: async (e) => c.delete(`${
|
|
1197
|
-
createSensor: async (e) => c.post(
|
|
1198
|
-
fetchSensors: async () => c.paginatedFetch(`${
|
|
1199
|
-
fetchSensor: async (e) => c.fetch(`${
|
|
1200
|
-
fetchWorkspaceSensors: async (e) => c.paginatedFetch(`${
|
|
1201
|
-
updateSensor: async (e, t = null) => c.patch(`${
|
|
1202
|
-
deleteSensor: async (e) => c.delete(`${
|
|
1203
|
-
createResultQualifier: async (e) => c.post(
|
|
1204
|
-
fetchResultQualifiers: async () => c.paginatedFetch(`${
|
|
1205
|
-
fetchWorkspaceResultQualifiers: async (e) => c.paginatedFetch(`${
|
|
1191
|
+
createProcessingLevel: async (e) => c.post(J, e),
|
|
1192
|
+
fetchProcessingLevels: async () => c.paginatedFetch(`${J}`),
|
|
1193
|
+
fetchProcessingLevel: async (e) => c.fetch(`${J}/${e}`),
|
|
1194
|
+
fetchWorkspaceProcessingLevels: async (e) => c.paginatedFetch(`${J}?workspace_id=${e}`),
|
|
1195
|
+
updateProcessingLevel: async (e, t = null) => c.patch(`${J}/${e.id}`, e, t),
|
|
1196
|
+
deleteProcessingLevel: async (e) => c.delete(`${J}/${e}`),
|
|
1197
|
+
createSensor: async (e) => c.post(W, e),
|
|
1198
|
+
fetchSensors: async () => c.paginatedFetch(`${W}`),
|
|
1199
|
+
fetchSensor: async (e) => c.fetch(`${W}/${e}`),
|
|
1200
|
+
fetchWorkspaceSensors: async (e) => c.paginatedFetch(`${W}?workspace_id=${e}`),
|
|
1201
|
+
updateSensor: async (e, t = null) => c.patch(`${W}/${e.id}`, e, t),
|
|
1202
|
+
deleteSensor: async (e) => c.delete(`${W}/${e}`),
|
|
1203
|
+
createResultQualifier: async (e) => c.post(Z, e),
|
|
1204
|
+
fetchResultQualifiers: async () => c.paginatedFetch(`${Z}`),
|
|
1205
|
+
fetchWorkspaceResultQualifiers: async (e) => c.paginatedFetch(`${Z}?workspace_id=${e}`),
|
|
1206
1206
|
updateResultQualifier: async (e, t = null) => c.patch(
|
|
1207
|
-
`${
|
|
1207
|
+
`${Z}/${e.id}`,
|
|
1208
1208
|
e,
|
|
1209
1209
|
t
|
|
1210
1210
|
),
|
|
1211
|
-
deleteResultQualifier: async (e) => c.delete(`${
|
|
1212
|
-
createOrchestrationSystem: async (e) => c.post(
|
|
1213
|
-
fetchOrchestrationSystems: async () => c.paginatedFetch(
|
|
1214
|
-
fetchWorkspaceOrchestrationSystems: async (e) => c.paginatedFetch(`${
|
|
1215
|
-
fetchOrchestrationSystem: async (e) => c.fetch(`${
|
|
1216
|
-
updateOrchestrationSystem: async (e, t) => c.patch(`${
|
|
1217
|
-
deleteOrchestrationSystem: async (e) => c.delete(`${
|
|
1211
|
+
deleteResultQualifier: async (e) => c.delete(`${Z}/${e}`),
|
|
1212
|
+
createOrchestrationSystem: async (e) => c.post(q, e),
|
|
1213
|
+
fetchOrchestrationSystems: async () => c.paginatedFetch(q),
|
|
1214
|
+
fetchWorkspaceOrchestrationSystems: async (e) => c.paginatedFetch(`${q}?workspace_id=${e}`),
|
|
1215
|
+
fetchOrchestrationSystem: async (e) => c.fetch(`${q}/${e}`),
|
|
1216
|
+
updateOrchestrationSystem: async (e, t) => c.patch(`${q}/${e}`, t),
|
|
1217
|
+
deleteOrchestrationSystem: async (e) => c.delete(`${q}/${e}`),
|
|
1218
1218
|
createDataSource: async (e) => c.post(
|
|
1219
|
-
`${
|
|
1220
|
-
|
|
1219
|
+
`${N}?expand_related=true`,
|
|
1220
|
+
Je(e)
|
|
1221
1221
|
),
|
|
1222
|
-
fetchDataSources: async () => c.paginatedFetch(`${
|
|
1222
|
+
fetchDataSources: async () => c.paginatedFetch(`${N}?expand_related=true`),
|
|
1223
1223
|
fetchWorkspaceDataSources: async (e) => c.paginatedFetch(
|
|
1224
|
-
`${
|
|
1224
|
+
`${N}?workspace_id=${e}&expand_related=true`
|
|
1225
1225
|
),
|
|
1226
|
-
fetchDataSource: async (e) => c.fetch(`${
|
|
1226
|
+
fetchDataSource: async (e) => c.fetch(`${N}/${e}?expand_related=true`),
|
|
1227
1227
|
updateDataSource: async (e) => c.patch(
|
|
1228
|
-
`${
|
|
1229
|
-
|
|
1228
|
+
`${N}/${e.id}?expand_related=true`,
|
|
1229
|
+
Je(e)
|
|
1230
1230
|
),
|
|
1231
1231
|
updateDataSourcePartial: async (e) => c.patch(
|
|
1232
|
-
`${
|
|
1232
|
+
`${N}/${e.id}?expand_related=true`,
|
|
1233
1233
|
e
|
|
1234
1234
|
),
|
|
1235
|
-
deleteDataSource: async (e) => c.delete(`${
|
|
1235
|
+
deleteDataSource: async (e) => c.delete(`${N}/${e}`),
|
|
1236
1236
|
linkDatastreamToDataSource: async (e, t) => c.post(
|
|
1237
|
-
`${
|
|
1237
|
+
`${N}/${e}/datastreams/${t}`
|
|
1238
1238
|
),
|
|
1239
1239
|
unlinkDatastreamFromDataSource: async (e, t) => c.delete(
|
|
1240
|
-
`${
|
|
1240
|
+
`${N}/${e}/datastreams/${t}`
|
|
1241
1241
|
),
|
|
1242
1242
|
fetchObservations: async (e) => c.fetch(e),
|
|
1243
|
-
deleteObservationsForDatastream: async (e) => c.post(`${
|
|
1243
|
+
deleteObservationsForDatastream: async (e) => c.post(`${I}/${e}/observations/bulk-delete`, {
|
|
1244
1244
|
phenomenonTimeStart: null,
|
|
1245
1245
|
phenomenonTimeEnd: null
|
|
1246
1246
|
}),
|
|
@@ -1248,15 +1248,15 @@ const D = "https://lro.hydroserver.org/api", Ue = `${D}/auth`, C = `${Ue}/browse
|
|
|
1248
1248
|
fetchOrganizationTypes: async () => c.fetch(`${C}/organization-types`),
|
|
1249
1249
|
fetchSiteTypes: async () => c.fetch(`${_}/site-types`),
|
|
1250
1250
|
fetchSamplingFeatureTypes: async () => c.paginatedFetch(`${_}/sampling-feature-types`),
|
|
1251
|
-
fetchSensorEncodingTypes: async () => c.paginatedFetch(`${
|
|
1252
|
-
fetchMethodTypes: async () => c.paginatedFetch(`${
|
|
1251
|
+
fetchSensorEncodingTypes: async () => c.paginatedFetch(`${W}/encoding-types`),
|
|
1252
|
+
fetchMethodTypes: async () => c.paginatedFetch(`${W}/method-types`),
|
|
1253
1253
|
fetchVariableTypes: async () => c.paginatedFetch(`${H}/variable-types`),
|
|
1254
1254
|
fetchUnitTypes: async () => c.paginatedFetch(`${z}/types`),
|
|
1255
|
-
fetchDatastreamStatuses: async () => c.paginatedFetch(`${
|
|
1256
|
-
fetchDatastreamAggregations: async () => c.paginatedFetch(`${
|
|
1257
|
-
fetchSampledMediums: async () => c.paginatedFetch(`${
|
|
1255
|
+
fetchDatastreamStatuses: async () => c.paginatedFetch(`${I}/statuses`),
|
|
1256
|
+
fetchDatastreamAggregations: async () => c.paginatedFetch(`${I}/aggregation-statistics`),
|
|
1257
|
+
fetchSampledMediums: async () => c.paginatedFetch(`${I}/sampled-mediums`)
|
|
1258
1258
|
};
|
|
1259
|
-
class
|
|
1259
|
+
class ys {
|
|
1260
1260
|
name = "";
|
|
1261
1261
|
mappings = [];
|
|
1262
1262
|
extractorVariables = {};
|
|
@@ -1264,15 +1264,15 @@ class hs {
|
|
|
1264
1264
|
Object.assign(this, t);
|
|
1265
1265
|
}
|
|
1266
1266
|
}
|
|
1267
|
-
const
|
|
1268
|
-
[
|
|
1269
|
-
[
|
|
1270
|
-
[
|
|
1271
|
-
[
|
|
1272
|
-
[
|
|
1273
|
-
[
|
|
1274
|
-
[
|
|
1275
|
-
},
|
|
1267
|
+
const At = 1, ue = At * 60, De = ue * 60, Fe = De * 24, gr = Fe * 7, mr = De * 30, wr = Fe * 365, ne = {
|
|
1268
|
+
[x.SECOND]: At,
|
|
1269
|
+
[x.MINUTE]: ue,
|
|
1270
|
+
[x.HOUR]: De,
|
|
1271
|
+
[x.DAY]: Fe,
|
|
1272
|
+
[x.WEEK]: gr,
|
|
1273
|
+
[x.MONTH]: mr,
|
|
1274
|
+
[x.YEAR]: wr
|
|
1275
|
+
}, gs = (e) => e.toLocaleString(void 0, {
|
|
1276
1276
|
year: "numeric",
|
|
1277
1277
|
month: "short",
|
|
1278
1278
|
day: "2-digit",
|
|
@@ -1280,63 +1280,40 @@ const _t = 1, ce = _t * 60, Oe = ce * 60, De = Oe * 24, yr = De * 7, gr = Oe * 3
|
|
|
1280
1280
|
hour12: !1,
|
|
1281
1281
|
minute: "2-digit",
|
|
1282
1282
|
second: "2-digit"
|
|
1283
|
-
}),
|
|
1283
|
+
}), ms = (e) => {
|
|
1284
1284
|
let t, r;
|
|
1285
|
-
e >=
|
|
1285
|
+
e >= ue * 1e3 ? (t = e / (ue * 1e3), r = "m") : e >= 1e3 ? (t = e / 1e3, r = "s") : (t = e, r = "ms");
|
|
1286
1286
|
let s;
|
|
1287
1287
|
return r === "ms" ? s = Math.round(t).toString() : s = t.toFixed(2), `${s} ${r}`;
|
|
1288
|
-
},
|
|
1288
|
+
}, Ee = async (e, t) => {
|
|
1289
1289
|
t && console.info(t);
|
|
1290
|
-
const r = performance.now(), s = await e(),
|
|
1291
|
-
|
|
1292
|
-
const a = +(n - r);
|
|
1293
|
-
return { response: s, duration: a };
|
|
1290
|
+
const r = performance.now(), s = await e(), o = +(performance.now() - r);
|
|
1291
|
+
return { response: s, duration: o };
|
|
1294
1292
|
};
|
|
1295
|
-
function
|
|
1293
|
+
function ws(e, t) {
|
|
1296
1294
|
const r = new Date(e);
|
|
1297
1295
|
return r.setHours(r.getHours() - t), r.toISOString();
|
|
1298
1296
|
}
|
|
1299
|
-
const
|
|
1297
|
+
const X = (e, t) => {
|
|
1300
1298
|
let r = 0, s = e.length;
|
|
1301
1299
|
for (; r < s; ) {
|
|
1302
1300
|
const n = r + s >> 1;
|
|
1303
1301
|
e[n] < t ? r = n + 1 : s = n;
|
|
1304
1302
|
}
|
|
1305
1303
|
return r;
|
|
1306
|
-
},
|
|
1304
|
+
}, Q = (e, t) => {
|
|
1307
1305
|
let r = 0, s = e.length;
|
|
1308
1306
|
for (; r < s; ) {
|
|
1309
1307
|
const n = r + s >> 1;
|
|
1310
1308
|
e[n] > t ? s = n : r = n + 1;
|
|
1311
1309
|
}
|
|
1312
1310
|
return r - 1;
|
|
1313
|
-
},
|
|
1314
|
-
`, Ke = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);",
|
|
1315
|
-
function wr(e) {
|
|
1316
|
-
let t;
|
|
1317
|
-
try {
|
|
1318
|
-
if (t = Ke && (self.URL || self.webkitURL).createObjectURL(Ke), !t) throw "";
|
|
1319
|
-
const r = new Worker(t, {
|
|
1320
|
-
name: e?.name
|
|
1321
|
-
});
|
|
1322
|
-
return r.addEventListener("error", () => {
|
|
1323
|
-
(self.URL || self.webkitURL).revokeObjectURL(t);
|
|
1324
|
-
}), r;
|
|
1325
|
-
} catch {
|
|
1326
|
-
return new Worker(
|
|
1327
|
-
"data:text/javascript;charset=utf-8," + encodeURIComponent(At),
|
|
1328
|
-
{
|
|
1329
|
-
name: e?.name
|
|
1330
|
-
}
|
|
1331
|
-
);
|
|
1332
|
-
}
|
|
1333
|
-
}
|
|
1334
|
-
const Tt = `(function(){"use strict";function F(n,l,a,o,s,y,g,f,i,w,A){let e=0,t=f;for(let r=y;r<=g;r++)if(o[t]=n[r],s[t]=l[r],t++,e<a.length&&r===a[e][0]){const u=a[e][0],c=a[e][1],d=n[u],h=n[c],m=l[u],D=l[c],x=h-d,P=D-m;let p=d+i;for(;p<h;)o[t]=p,s[t]=w?m+(p-d)*P/x:A,t++,p+=i;e++}return t-f}self.onmessage=n=>{const{bufferX:l,bufferY:a,outputBufferX:o,outputBufferY:s,start:y,end:g,gapsSegment:f,startTarget:i,fillDelta:w,interpolate:A,fillValue:e}=n.data,t=new Float64Array(l),r=new Float32Array(a),u=new Float64Array(o),c=new Float32Array(s);F(t,r,f,u,c,y,g,i,w,A,e),self.postMessage("Done")}})();
|
|
1335
|
-
`, Qe = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Tt], { type: "text/javascript;charset=utf-8" });
|
|
1311
|
+
}, Tt = `(function(){"use strict";function c(n,s,a,u,f,l,y,o){let r=0,e=o;for(let t=l;t<=y;t++)r<a.length&&t===a[r]?r++:(u[e]=n[t],f[e]=s[t],e++);return e-o}self.onmessage=n=>{const{bufferX:s,bufferY:a,outputBufferX:u,outputBufferY:f,start:l,end:y,deleteSegment:o,startTarget:r}=n.data,e=new Float64Array(s),t=new Float32Array(a),A=new Float64Array(u),g=new Float32Array(f);c(e,t,o,A,g,l,y,r),self.postMessage("Done")}})();
|
|
1312
|
+
`, Ke = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Tt], { type: "text/javascript;charset=utf-8" });
|
|
1336
1313
|
function br(e) {
|
|
1337
1314
|
let t;
|
|
1338
1315
|
try {
|
|
1339
|
-
if (t =
|
|
1316
|
+
if (t = Ke && (self.URL || self.webkitURL).createObjectURL(Ke), !t) throw "";
|
|
1340
1317
|
const r = new Worker(t, {
|
|
1341
1318
|
name: e?.name
|
|
1342
1319
|
});
|
|
@@ -1352,7 +1329,7 @@ function br(e) {
|
|
|
1352
1329
|
);
|
|
1353
1330
|
}
|
|
1354
1331
|
}
|
|
1355
|
-
const Lt = `(function(){"use strict";function
|
|
1332
|
+
const Lt = `(function(){"use strict";function F(n,l,a,o,s,y,g,f,i,w,A){let e=0,t=f;for(let r=y;r<=g;r++)if(o[t]=n[r],s[t]=l[r],t++,e<a.length&&r===a[e][0]){const u=a[e][0],c=a[e][1],d=n[u],h=n[c],m=l[u],D=l[c],x=h-d,P=D-m;let p=d+i;for(;p<h;)o[t]=p,s[t]=w?m+(p-d)*P/x:A,t++,p+=i;e++}return t-f}self.onmessage=n=>{const{bufferX:l,bufferY:a,outputBufferX:o,outputBufferY:s,start:y,end:g,gapsSegment:f,startTarget:i,fillDelta:w,interpolate:A,fillValue:e}=n.data,t=new Float64Array(l),r=new Float32Array(a),u=new Float64Array(o),c=new Float32Array(s);F(t,r,f,u,c,y,g,i,w,A,e),self.postMessage("Done")}})();
|
|
1356
1333
|
`, Ze = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Lt], { type: "text/javascript;charset=utf-8" });
|
|
1357
1334
|
function Sr(e) {
|
|
1358
1335
|
let t;
|
|
@@ -1373,7 +1350,7 @@ function Sr(e) {
|
|
|
1373
1350
|
);
|
|
1374
1351
|
}
|
|
1375
1352
|
}
|
|
1376
|
-
const $t = `(function(){"use strict";
|
|
1353
|
+
const $t = `(function(){"use strict";function g(o,n,c){for(let s=0;s<c.length;s++){const{indexes:t,lowerIdx:l,upperIdx:r}=c[s],i=o[l],f=n[l],a=o[r],d=n[r],p=a-i,w=d-f;if(p===0){for(let e=0;e<t.length;e++)n[t[e]]=f;continue}for(let e=0;e<t.length;e++){const u=t[e];n[u]=f+(o[u]-i)*w/p}}}self.onmessage=o=>{const{bufferX:n,bufferY:c,groups:s}=o.data,t=new Float64Array(n),l=new Float32Array(c);g(t,l,s),self.postMessage("Done")}})();
|
|
1377
1354
|
`, et = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", $t], { type: "text/javascript;charset=utf-8" });
|
|
1378
1355
|
function Er(e) {
|
|
1379
1356
|
let t;
|
|
@@ -1394,9 +1371,9 @@ function Er(e) {
|
|
|
1394
1371
|
);
|
|
1395
1372
|
}
|
|
1396
1373
|
}
|
|
1397
|
-
const Rt = `(function(){"use strict";
|
|
1374
|
+
const Rt = `(function(){"use strict";self.onmessage=r=>{const{bufferX:s,bufferY:o,jobs:a}=r.data,f=new Float64Array(s),n=new Float32Array(o);for(let e=0;e<a.length;e++){const{chunkStart:c,chunkEnd:l,startDatetime:u,value:i,extent:y}=a[e];for(let t=c;t<l;t++)n[t]=n[t]+i*((f[t]-u)/y)}self.postMessage("Done")}})();
|
|
1398
1375
|
`, tt = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Rt], { type: "text/javascript;charset=utf-8" });
|
|
1399
|
-
function
|
|
1376
|
+
function vr(e) {
|
|
1400
1377
|
let t;
|
|
1401
1378
|
try {
|
|
1402
1379
|
if (t = tt && (self.URL || self.webkitURL).createObjectURL(tt), !t) throw "";
|
|
@@ -1415,9 +1392,9 @@ function kr(e) {
|
|
|
1415
1392
|
);
|
|
1416
1393
|
}
|
|
1417
1394
|
}
|
|
1418
|
-
const It = `(function(){"use strict";
|
|
1395
|
+
const It = `(function(){"use strict";function u(f,o,a,n,l,c,s,i){let r=c,e=0,t=i;const w=a.length;for(;r<s&&e<w;){const y=a[e][0];f[r]<=y?(n[t]=f[r],l[t]=o[r],r++):(n[t]=y,l[t]=a[e][1],e++),t++}for(;r<s;)n[t]=f[r],l[t]=o[r],r++,t++;for(;e<w;)n[t]=a[e][0],l[t]=a[e][1],e++,t++;return t-i}self.onmessage=f=>{const{bufferX:o,bufferY:a,outputBufferX:n,outputBufferY:l,origStart:c,origEnd:s,insertions:i,outStart:r}=f.data,e=new Float64Array(o),t=new Float32Array(a),w=new Float64Array(n),y=new Float32Array(l);u(e,t,i,w,y,c,s,r),self.postMessage("Done")}})();
|
|
1419
1396
|
`, rt = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", It], { type: "text/javascript;charset=utf-8" });
|
|
1420
|
-
function
|
|
1397
|
+
function kr(e) {
|
|
1421
1398
|
let t;
|
|
1422
1399
|
try {
|
|
1423
1400
|
if (t = rt && (self.URL || self.webkitURL).createObjectURL(rt), !t) throw "";
|
|
@@ -1436,8 +1413,8 @@ function vr(e) {
|
|
|
1436
1413
|
);
|
|
1437
1414
|
}
|
|
1438
1415
|
}
|
|
1439
|
-
const
|
|
1440
|
-
`, st = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);",
|
|
1416
|
+
const Ot = `(function(){"use strict";self.onmessage=i=>{const{bufferX:c,bufferY:g,outputBufferX:d,outputBufferY:y,indexes:n,outStart:r,amount:f,isMonth:Y,isYear:h,deltaMs:w}=i.data,s=new Float64Array(c),a=new Float32Array(g),l=new Float64Array(d),u=new Float32Array(y);if(Y)for(let t=0;t<n.length;t++){const e=n[t],o=new Date(s[e]);o.setMonth(o.getMonth()+f),l[r+t]=o.getTime(),u[r+t]=a[e]}else if(h)for(let t=0;t<n.length;t++){const e=n[t],o=new Date(s[e]);o.setFullYear(o.getFullYear()+f),l[r+t]=o.getTime(),u[r+t]=a[e]}else for(let t=0;t<n.length;t++){const e=n[t];l[r+t]=s[e]+w,u[r+t]=a[e]}self.postMessage("Done")}})();
|
|
1417
|
+
`, st = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Ot], { type: "text/javascript;charset=utf-8" });
|
|
1441
1418
|
function _r(e) {
|
|
1442
1419
|
let t;
|
|
1443
1420
|
try {
|
|
@@ -1450,15 +1427,15 @@ function _r(e) {
|
|
|
1450
1427
|
}), r;
|
|
1451
1428
|
} catch {
|
|
1452
1429
|
return new Worker(
|
|
1453
|
-
"data:text/javascript;charset=utf-8," + encodeURIComponent(
|
|
1430
|
+
"data:text/javascript;charset=utf-8," + encodeURIComponent(Ot),
|
|
1454
1431
|
{
|
|
1455
1432
|
name: e?.name
|
|
1456
1433
|
}
|
|
1457
1434
|
);
|
|
1458
1435
|
}
|
|
1459
1436
|
}
|
|
1460
|
-
const
|
|
1461
|
-
`, nt = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);",
|
|
1437
|
+
const Mt = `(function(){"use strict";function a(e,t,o,c){const n=[];let r=e[t];for(let s=t+1;s<=o;s++){const f=e[s];f-r>c&&n.push(s-1,s),r=f}return n}self.onmessage=e=>{const{bufferX:t,start:o,endInclusive:c,threshold:n}=e.data,r=new Float64Array(t);self.postMessage(a(r,o,c,n))}})();
|
|
1438
|
+
`, nt = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Mt], { type: "text/javascript;charset=utf-8" });
|
|
1462
1439
|
function Ar(e) {
|
|
1463
1440
|
let t;
|
|
1464
1441
|
try {
|
|
@@ -1471,15 +1448,15 @@ function Ar(e) {
|
|
|
1471
1448
|
}), r;
|
|
1472
1449
|
} catch {
|
|
1473
1450
|
return new Worker(
|
|
1474
|
-
"data:text/javascript;charset=utf-8," + encodeURIComponent(
|
|
1451
|
+
"data:text/javascript;charset=utf-8," + encodeURIComponent(Mt),
|
|
1475
1452
|
{
|
|
1476
1453
|
name: e?.name
|
|
1477
1454
|
}
|
|
1478
1455
|
);
|
|
1479
1456
|
}
|
|
1480
1457
|
}
|
|
1481
|
-
const
|
|
1482
|
-
`, ot = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);",
|
|
1458
|
+
const Ut = `(function(){"use strict";function c(u,s,t){const n=[];if(s>=t)return n;let e=s,o=u[s];for(let r=s+1;r<t;r++){const f=u[r];f!==o&&(n.push(e,r-e,o),e=r,o=f)}return n.push(e,t-e,o),n}self.onmessage=u=>{const{bufferY:s,start:t,end:n}=u.data,e=new Float32Array(s);self.postMessage(c(e,t,n))}})();
|
|
1459
|
+
`, ot = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Ut], { type: "text/javascript;charset=utf-8" });
|
|
1483
1460
|
function Tr(e) {
|
|
1484
1461
|
let t;
|
|
1485
1462
|
try {
|
|
@@ -1492,14 +1469,14 @@ function Tr(e) {
|
|
|
1492
1469
|
}), r;
|
|
1493
1470
|
} catch {
|
|
1494
1471
|
return new Worker(
|
|
1495
|
-
"data:text/javascript;charset=utf-8," + encodeURIComponent(
|
|
1472
|
+
"data:text/javascript;charset=utf-8," + encodeURIComponent(Ut),
|
|
1496
1473
|
{
|
|
1497
1474
|
name: e?.name
|
|
1498
1475
|
}
|
|
1499
1476
|
);
|
|
1500
1477
|
}
|
|
1501
1478
|
}
|
|
1502
|
-
const Dt = `(function(){"use strict";function
|
|
1479
|
+
const Dt = `(function(){"use strict";function o(s,i,t,n,l){const f=[];if(n==="Less than")for(let e=i;e<t;e++)s[e]-s[e-1]<l&&f.push(e);else if(n==="Less than or equal to")for(let e=i;e<t;e++)s[e]-s[e-1]<=l&&f.push(e);else if(n==="Greater than")for(let e=i;e<t;e++)s[e]-s[e-1]>l&&f.push(e);else if(n==="Greater than or equal to")for(let e=i;e<t;e++)s[e]-s[e-1]>=l&&f.push(e);else if(n==="Equal")for(let e=i;e<t;e++)s[e]-s[e-1]==l&&f.push(e);return f}self.onmessage=s=>{const{bufferY:i,start:t,end:n,comparator:l,value:f}=s.data,e=new Float32Array(i);self.postMessage(o(e,t,n,l,f))}})();
|
|
1503
1480
|
`, at = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Dt], { type: "text/javascript;charset=utf-8" });
|
|
1504
1481
|
function Lr(e) {
|
|
1505
1482
|
let t;
|
|
@@ -1520,9 +1497,9 @@ function Lr(e) {
|
|
|
1520
1497
|
);
|
|
1521
1498
|
}
|
|
1522
1499
|
}
|
|
1523
|
-
const
|
|
1524
|
-
`, it = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);",
|
|
1525
|
-
function
|
|
1500
|
+
const Ft = `(function(){"use strict";function l(t,i,n,o,h){const f=[];if(o==="Less than")for(let e=i;e<n;e++){const s=t[e-1];(t[e]-s)/Math.abs(s)<h&&f.push(e)}else if(o==="Less than or equal to")for(let e=i;e<n;e++){const s=t[e-1];(t[e]-s)/Math.abs(s)<=h&&f.push(e)}else if(o==="Greater than")for(let e=i;e<n;e++){const s=t[e-1];(t[e]-s)/Math.abs(s)>h&&f.push(e)}else if(o==="Greater than or equal to")for(let e=i;e<n;e++){const s=t[e-1];(t[e]-s)/Math.abs(s)>=h&&f.push(e)}else if(o==="Equal")for(let e=i;e<n;e++){const s=t[e-1];(t[e]-s)/Math.abs(s)==h&&f.push(e)}return f}self.onmessage=t=>{const{bufferY:i,start:n,end:o,comparator:h,value:f}=t.data,e=new Float32Array(i);self.postMessage(l(e,n,o,h,f))}})();
|
|
1501
|
+
`, it = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Ft], { type: "text/javascript;charset=utf-8" });
|
|
1502
|
+
function $r(e) {
|
|
1526
1503
|
let t;
|
|
1527
1504
|
try {
|
|
1528
1505
|
if (t = it && (self.URL || self.webkitURL).createObjectURL(it), !t) throw "";
|
|
@@ -1534,16 +1511,16 @@ function Re(e) {
|
|
|
1534
1511
|
}), r;
|
|
1535
1512
|
} catch {
|
|
1536
1513
|
return new Worker(
|
|
1537
|
-
"data:text/javascript;charset=utf-8," + encodeURIComponent(
|
|
1514
|
+
"data:text/javascript;charset=utf-8," + encodeURIComponent(Ft),
|
|
1538
1515
|
{
|
|
1539
1516
|
name: e?.name
|
|
1540
1517
|
}
|
|
1541
1518
|
);
|
|
1542
1519
|
}
|
|
1543
1520
|
}
|
|
1544
|
-
const
|
|
1545
|
-
`, ct = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);",
|
|
1546
|
-
function
|
|
1521
|
+
const Ct = `(function(){"use strict";function k(i,l,u,r,c){const f=[],b=r.length;for(let a=l;a<u;a++){const t=i[a];let e=!1;for(let n=0;n<b;n++){const o=r[n],s=c[n];if(o===0){if(t<s){e=!0;break}}else if(o===1){if(t<=s){e=!0;break}}else if(o===2){if(t>s){e=!0;break}}else if(o===3){if(t>=s){e=!0;break}}else if(t==s){e=!0;break}}e&&f.push(a)}return f}self.onmessage=i=>{const{bufferY:l,start:u,end:r,ops:c,values:f}=i.data,b=new Float32Array(l);self.postMessage(k(b,u,r,c,f))}})();
|
|
1522
|
+
`, ct = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Ct], { type: "text/javascript;charset=utf-8" });
|
|
1523
|
+
function Ie(e) {
|
|
1547
1524
|
let t;
|
|
1548
1525
|
try {
|
|
1549
1526
|
if (t = ct && (self.URL || self.webkitURL).createObjectURL(ct), !t) throw "";
|
|
@@ -1555,7 +1532,28 @@ function $r(e) {
|
|
|
1555
1532
|
}), r;
|
|
1556
1533
|
} catch {
|
|
1557
1534
|
return new Worker(
|
|
1558
|
-
"data:text/javascript;charset=utf-8," + encodeURIComponent(
|
|
1535
|
+
"data:text/javascript;charset=utf-8," + encodeURIComponent(Ct),
|
|
1536
|
+
{
|
|
1537
|
+
name: e?.name
|
|
1538
|
+
}
|
|
1539
|
+
);
|
|
1540
|
+
}
|
|
1541
|
+
}
|
|
1542
|
+
const xt = `(function(){"use strict";function e(l,t,o,s){const c=t.length;if(o==="ADD")for(let f=0;f<c;f++)l[t[f]]=l[t[f]]+s;else if(o==="SUB")for(let f=0;f<c;f++)l[t[f]]=l[t[f]]-s;else if(o==="MULT")for(let f=0;f<c;f++)l[t[f]]=l[t[f]]*s;else if(o==="DIV")for(let f=0;f<c;f++)l[t[f]]=l[t[f]]/s;else if(o==="ASSIGN")for(let f=0;f<c;f++)l[t[f]]=s}self.onmessage=l=>{const{bufferY:t,indexes:o,operator:s,value:c}=l.data,f=new Float32Array(t);e(f,o,s,c),self.postMessage("Done")}})();
|
|
1543
|
+
`, lt = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", xt], { type: "text/javascript;charset=utf-8" });
|
|
1544
|
+
function Rr(e) {
|
|
1545
|
+
let t;
|
|
1546
|
+
try {
|
|
1547
|
+
if (t = lt && (self.URL || self.webkitURL).createObjectURL(lt), !t) throw "";
|
|
1548
|
+
const r = new Worker(t, {
|
|
1549
|
+
name: e?.name
|
|
1550
|
+
});
|
|
1551
|
+
return r.addEventListener("error", () => {
|
|
1552
|
+
(self.URL || self.webkitURL).revokeObjectURL(t);
|
|
1553
|
+
}), r;
|
|
1554
|
+
} catch {
|
|
1555
|
+
return new Worker(
|
|
1556
|
+
"data:text/javascript;charset=utf-8," + encodeURIComponent(xt),
|
|
1559
1557
|
{
|
|
1560
1558
|
name: e?.name
|
|
1561
1559
|
}
|
|
@@ -1563,195 +1561,195 @@ function $r(e) {
|
|
|
1563
1561
|
}
|
|
1564
1562
|
}
|
|
1565
1563
|
function Pt(e, t, r, s, n) {
|
|
1566
|
-
const
|
|
1564
|
+
const o = [], a = s.length;
|
|
1567
1565
|
for (let i = t; i < r; i++) {
|
|
1568
1566
|
const l = e[i];
|
|
1569
1567
|
let f = !1;
|
|
1570
|
-
for (let
|
|
1571
|
-
const
|
|
1572
|
-
if (
|
|
1573
|
-
if (l <
|
|
1568
|
+
for (let h = 0; h < a; h++) {
|
|
1569
|
+
const y = s[h], p = n[h];
|
|
1570
|
+
if (y === 0) {
|
|
1571
|
+
if (l < p) {
|
|
1574
1572
|
f = !0;
|
|
1575
1573
|
break;
|
|
1576
1574
|
}
|
|
1577
|
-
} else if (
|
|
1578
|
-
if (l <=
|
|
1575
|
+
} else if (y === 1) {
|
|
1576
|
+
if (l <= p) {
|
|
1579
1577
|
f = !0;
|
|
1580
1578
|
break;
|
|
1581
1579
|
}
|
|
1582
|
-
} else if (
|
|
1583
|
-
if (l >
|
|
1580
|
+
} else if (y === 2) {
|
|
1581
|
+
if (l > p) {
|
|
1584
1582
|
f = !0;
|
|
1585
1583
|
break;
|
|
1586
1584
|
}
|
|
1587
|
-
} else if (
|
|
1588
|
-
if (l >=
|
|
1585
|
+
} else if (y === 3) {
|
|
1586
|
+
if (l >= p) {
|
|
1589
1587
|
f = !0;
|
|
1590
1588
|
break;
|
|
1591
1589
|
}
|
|
1592
|
-
} else if (l ==
|
|
1590
|
+
} else if (l == p) {
|
|
1593
1591
|
f = !0;
|
|
1594
1592
|
break;
|
|
1595
1593
|
}
|
|
1596
1594
|
}
|
|
1597
|
-
f &&
|
|
1595
|
+
f && o.push(i);
|
|
1598
1596
|
}
|
|
1599
|
-
return
|
|
1597
|
+
return o;
|
|
1600
1598
|
}
|
|
1601
|
-
function
|
|
1602
|
-
const
|
|
1599
|
+
function Ir(e, t, r, s, n) {
|
|
1600
|
+
const o = [];
|
|
1603
1601
|
if (s === "Less than")
|
|
1604
|
-
for (let
|
|
1605
|
-
e[
|
|
1602
|
+
for (let a = t; a < r; a++)
|
|
1603
|
+
e[a] - e[a - 1] < n && o.push(a);
|
|
1606
1604
|
else if (s === "Less than or equal to")
|
|
1607
|
-
for (let
|
|
1608
|
-
e[
|
|
1605
|
+
for (let a = t; a < r; a++)
|
|
1606
|
+
e[a] - e[a - 1] <= n && o.push(a);
|
|
1609
1607
|
else if (s === "Greater than")
|
|
1610
|
-
for (let
|
|
1611
|
-
e[
|
|
1608
|
+
for (let a = t; a < r; a++)
|
|
1609
|
+
e[a] - e[a - 1] > n && o.push(a);
|
|
1612
1610
|
else if (s === "Greater than or equal to")
|
|
1613
|
-
for (let
|
|
1614
|
-
e[
|
|
1611
|
+
for (let a = t; a < r; a++)
|
|
1612
|
+
e[a] - e[a - 1] >= n && o.push(a);
|
|
1615
1613
|
else if (s === "Equal")
|
|
1616
|
-
for (let
|
|
1617
|
-
e[
|
|
1618
|
-
return
|
|
1614
|
+
for (let a = t; a < r; a++)
|
|
1615
|
+
e[a] - e[a - 1] == n && o.push(a);
|
|
1616
|
+
return o;
|
|
1619
1617
|
}
|
|
1620
|
-
function
|
|
1621
|
-
const
|
|
1618
|
+
function Or(e, t, r, s, n) {
|
|
1619
|
+
const o = [];
|
|
1622
1620
|
if (s === "Less than")
|
|
1623
|
-
for (let
|
|
1624
|
-
const i = e[
|
|
1625
|
-
(e[
|
|
1621
|
+
for (let a = t; a < r; a++) {
|
|
1622
|
+
const i = e[a - 1];
|
|
1623
|
+
(e[a] - i) / Math.abs(i) < n && o.push(a);
|
|
1626
1624
|
}
|
|
1627
1625
|
else if (s === "Less than or equal to")
|
|
1628
|
-
for (let
|
|
1629
|
-
const i = e[
|
|
1630
|
-
(e[
|
|
1626
|
+
for (let a = t; a < r; a++) {
|
|
1627
|
+
const i = e[a - 1];
|
|
1628
|
+
(e[a] - i) / Math.abs(i) <= n && o.push(a);
|
|
1631
1629
|
}
|
|
1632
1630
|
else if (s === "Greater than")
|
|
1633
|
-
for (let
|
|
1634
|
-
const i = e[
|
|
1635
|
-
(e[
|
|
1631
|
+
for (let a = t; a < r; a++) {
|
|
1632
|
+
const i = e[a - 1];
|
|
1633
|
+
(e[a] - i) / Math.abs(i) > n && o.push(a);
|
|
1636
1634
|
}
|
|
1637
1635
|
else if (s === "Greater than or equal to")
|
|
1638
|
-
for (let
|
|
1639
|
-
const i = e[
|
|
1640
|
-
(e[
|
|
1636
|
+
for (let a = t; a < r; a++) {
|
|
1637
|
+
const i = e[a - 1];
|
|
1638
|
+
(e[a] - i) / Math.abs(i) >= n && o.push(a);
|
|
1641
1639
|
}
|
|
1642
1640
|
else if (s === "Equal")
|
|
1643
|
-
for (let
|
|
1644
|
-
const i = e[
|
|
1645
|
-
(e[
|
|
1641
|
+
for (let a = t; a < r; a++) {
|
|
1642
|
+
const i = e[a - 1];
|
|
1643
|
+
(e[a] - i) / Math.abs(i) == n && o.push(a);
|
|
1646
1644
|
}
|
|
1647
|
-
return
|
|
1645
|
+
return o;
|
|
1648
1646
|
}
|
|
1649
1647
|
function Mr(e, t, r, s) {
|
|
1650
1648
|
const n = [];
|
|
1651
|
-
let
|
|
1652
|
-
for (let
|
|
1653
|
-
const i = e[
|
|
1654
|
-
i -
|
|
1649
|
+
let o = e[t];
|
|
1650
|
+
for (let a = t + 1; a <= r; a++) {
|
|
1651
|
+
const i = e[a];
|
|
1652
|
+
i - o > s && n.push(a - 1, a), o = i;
|
|
1655
1653
|
}
|
|
1656
1654
|
return n;
|
|
1657
1655
|
}
|
|
1658
1656
|
function Ur(e, t, r) {
|
|
1659
1657
|
const s = [];
|
|
1660
1658
|
if (t >= r) return s;
|
|
1661
|
-
let n = t,
|
|
1662
|
-
for (let
|
|
1663
|
-
const i = e[
|
|
1664
|
-
i !==
|
|
1665
|
-
}
|
|
1666
|
-
return s.push(n, r - n,
|
|
1667
|
-
}
|
|
1668
|
-
function
|
|
1669
|
-
let
|
|
1670
|
-
for (let
|
|
1671
|
-
if (s[
|
|
1672
|
-
const d = r[
|
|
1673
|
-
let L =
|
|
1674
|
-
for (; L <
|
|
1675
|
-
s[
|
|
1676
|
-
|
|
1677
|
-
}
|
|
1678
|
-
return
|
|
1679
|
-
}
|
|
1680
|
-
function
|
|
1681
|
-
let l =
|
|
1682
|
-
const
|
|
1683
|
-
for (; l <
|
|
1684
|
-
const
|
|
1685
|
-
e[l] <=
|
|
1686
|
-
}
|
|
1687
|
-
for (; l <
|
|
1688
|
-
s[
|
|
1689
|
-
for (; f <
|
|
1690
|
-
s[
|
|
1691
|
-
return
|
|
1692
|
-
}
|
|
1693
|
-
function Cr(e, t, r, s, n,
|
|
1659
|
+
let n = t, o = e[t];
|
|
1660
|
+
for (let a = t + 1; a < r; a++) {
|
|
1661
|
+
const i = e[a];
|
|
1662
|
+
i !== o && (s.push(n, a - n, o), n = a, o = i);
|
|
1663
|
+
}
|
|
1664
|
+
return s.push(n, r - n, o), s;
|
|
1665
|
+
}
|
|
1666
|
+
function Dr(e, t, r, s, n, o, a, i, l, f, h) {
|
|
1667
|
+
let y = 0, p = i;
|
|
1668
|
+
for (let g = o; g <= a; g++)
|
|
1669
|
+
if (s[p] = e[g], n[p] = t[g], p++, y < r.length && g === r[y][0]) {
|
|
1670
|
+
const d = r[y][0], u = r[y][1], w = e[d], b = e[u], m = t[d], S = t[u], v = b - w, T = S - m;
|
|
1671
|
+
let L = w + l;
|
|
1672
|
+
for (; L < b; )
|
|
1673
|
+
s[p] = L, n[p] = f ? m + (L - w) * T / v : h, p++, L += l;
|
|
1674
|
+
y++;
|
|
1675
|
+
}
|
|
1676
|
+
return p - i;
|
|
1677
|
+
}
|
|
1678
|
+
function Fr(e, t, r, s, n, o, a, i) {
|
|
1679
|
+
let l = o, f = 0, h = i;
|
|
1680
|
+
const y = r.length;
|
|
1681
|
+
for (; l < a && f < y; ) {
|
|
1682
|
+
const p = r[f][0];
|
|
1683
|
+
e[l] <= p ? (s[h] = e[l], n[h] = t[l], l++) : (s[h] = p, n[h] = r[f][1], f++), h++;
|
|
1684
|
+
}
|
|
1685
|
+
for (; l < a; )
|
|
1686
|
+
s[h] = e[l], n[h] = t[l], l++, h++;
|
|
1687
|
+
for (; f < y; )
|
|
1688
|
+
s[h] = r[f][0], n[h] = r[f][1], f++, h++;
|
|
1689
|
+
return h - i;
|
|
1690
|
+
}
|
|
1691
|
+
function Cr(e, t, r, s, n, o, a, i) {
|
|
1694
1692
|
let l = 0, f = i;
|
|
1695
|
-
for (let
|
|
1696
|
-
l < r.length &&
|
|
1693
|
+
for (let h = o; h <= a; h++)
|
|
1694
|
+
l < r.length && h === r[l] ? l++ : (s[f] = e[h], n[f] = t[h], f++);
|
|
1697
1695
|
return f - i;
|
|
1698
1696
|
}
|
|
1699
|
-
function
|
|
1700
|
-
const n = r.length,
|
|
1697
|
+
function xr(e, t, r, s) {
|
|
1698
|
+
const n = r.length, o = new Array(n);
|
|
1701
1699
|
if (s.isMonth)
|
|
1702
|
-
for (let
|
|
1703
|
-
const i = r[
|
|
1704
|
-
l.setMonth(l.getMonth() + s.amount), a
|
|
1700
|
+
for (let a = 0; a < n; a++) {
|
|
1701
|
+
const i = r[a], l = new Date(e[i]);
|
|
1702
|
+
l.setMonth(l.getMonth() + s.amount), o[a] = [l.getTime(), t[i]];
|
|
1705
1703
|
}
|
|
1706
1704
|
else if (s.isYear)
|
|
1707
|
-
for (let
|
|
1708
|
-
const i = r[
|
|
1709
|
-
l.setFullYear(l.getFullYear() + s.amount), a
|
|
1705
|
+
for (let a = 0; a < n; a++) {
|
|
1706
|
+
const i = r[a], l = new Date(e[i]);
|
|
1707
|
+
l.setFullYear(l.getFullYear() + s.amount), o[a] = [l.getTime(), t[i]];
|
|
1710
1708
|
}
|
|
1711
1709
|
else
|
|
1712
|
-
for (let
|
|
1713
|
-
const i = r[
|
|
1714
|
-
a
|
|
1710
|
+
for (let a = 0; a < n; a++) {
|
|
1711
|
+
const i = r[a];
|
|
1712
|
+
o[a] = [e[i] + s.deltaMs, t[i]];
|
|
1715
1713
|
}
|
|
1716
|
-
return
|
|
1714
|
+
return o;
|
|
1717
1715
|
}
|
|
1718
1716
|
function Pr(e, t, r) {
|
|
1719
1717
|
for (let s = 0; s < r.length; s++) {
|
|
1720
|
-
const { indexes: n, lowerIdx:
|
|
1721
|
-
if (
|
|
1722
|
-
for (let
|
|
1718
|
+
const { indexes: n, lowerIdx: o, upperIdx: a } = r[s], i = e[o], l = t[o], f = e[a], h = t[a], y = f - i, p = h - l;
|
|
1719
|
+
if (y === 0) {
|
|
1720
|
+
for (let g = 0; g < n.length; g++) t[n[g]] = l;
|
|
1723
1721
|
continue;
|
|
1724
1722
|
}
|
|
1725
|
-
for (let
|
|
1726
|
-
const d = n[
|
|
1727
|
-
t[d] = l + (e[d] - i) *
|
|
1723
|
+
for (let g = 0; g < n.length; g++) {
|
|
1724
|
+
const d = n[g];
|
|
1725
|
+
t[d] = l + (e[d] - i) * p / y;
|
|
1728
1726
|
}
|
|
1729
1727
|
}
|
|
1730
1728
|
}
|
|
1731
|
-
function
|
|
1729
|
+
function Nr(e, t, r) {
|
|
1732
1730
|
for (let s = 0; s < r.length; s++) {
|
|
1733
|
-
const n = r[s][0],
|
|
1734
|
-
if (
|
|
1735
|
-
const i = e[n], l = e[
|
|
1731
|
+
const n = r[s][0], o = r[s][1], a = r[s][2];
|
|
1732
|
+
if (o <= n) continue;
|
|
1733
|
+
const i = e[n], l = e[o] - i;
|
|
1736
1734
|
if (l !== 0)
|
|
1737
|
-
for (let f = n; f <
|
|
1738
|
-
t[f] = t[f] +
|
|
1735
|
+
for (let f = n; f < o; f++)
|
|
1736
|
+
t[f] = t[f] + a * ((e[f] - i) / l);
|
|
1739
1737
|
}
|
|
1740
1738
|
}
|
|
1741
|
-
function
|
|
1739
|
+
function ut(e, t, r, s) {
|
|
1742
1740
|
const n = t.length;
|
|
1743
1741
|
if (r === "ADD")
|
|
1744
|
-
for (let
|
|
1742
|
+
for (let o = 0; o < n; o++) e[t[o]] = e[t[o]] + s;
|
|
1745
1743
|
else if (r === "SUB")
|
|
1746
|
-
for (let
|
|
1744
|
+
for (let o = 0; o < n; o++) e[t[o]] = e[t[o]] - s;
|
|
1747
1745
|
else if (r === "MULT")
|
|
1748
|
-
for (let
|
|
1746
|
+
for (let o = 0; o < n; o++) e[t[o]] = e[t[o]] * s;
|
|
1749
1747
|
else if (r === "DIV")
|
|
1750
|
-
for (let
|
|
1748
|
+
for (let o = 0; o < n; o++) e[t[o]] = e[t[o]] / s;
|
|
1751
1749
|
else if (r === "ASSIGN")
|
|
1752
|
-
for (let
|
|
1750
|
+
for (let o = 0; o < n; o++) e[t[o]] = s;
|
|
1753
1751
|
}
|
|
1754
|
-
const
|
|
1752
|
+
const Br = 1, Ce = `qc-utils:calibration:v${Br}`, jr = 720 * 60 * 60 * 1e3, oe = 5e4, ae = 2e5, he = {
|
|
1755
1753
|
spawnOverheadMs: 50,
|
|
1756
1754
|
// worst-case Windows
|
|
1757
1755
|
inlineThroughput: 5e4,
|
|
@@ -1762,40 +1760,40 @@ const Nr = 1, Ce = `qc-utils:calibration:v${Nr}`, Br = 720 * 60 * 60 * 1e3, ne =
|
|
|
1762
1760
|
measuredAt: 0,
|
|
1763
1761
|
userAgent: "default"
|
|
1764
1762
|
};
|
|
1765
|
-
let
|
|
1766
|
-
const
|
|
1763
|
+
let O = Gr() ?? he, xe = null, ee = null;
|
|
1764
|
+
const Oe = /* @__PURE__ */ new Set(), Me = {
|
|
1767
1765
|
// Filter ops — read-only scans, cheap kernels
|
|
1768
|
-
[
|
|
1766
|
+
[A.VALUE_THRESHOLD]: {
|
|
1769
1767
|
mode: "calibrated",
|
|
1770
1768
|
weight: 1,
|
|
1771
1769
|
rationale: "O(n) single-pass scan; baseline reference"
|
|
1772
1770
|
},
|
|
1773
|
-
[
|
|
1771
|
+
[A.CHANGE]: {
|
|
1774
1772
|
mode: "calibrated",
|
|
1775
1773
|
weight: 1.1,
|
|
1776
1774
|
rationale: "O(n) with one subtraction per step"
|
|
1777
1775
|
},
|
|
1778
|
-
[
|
|
1776
|
+
[A.RATE_OF_CHANGE]: {
|
|
1779
1777
|
mode: "calibrated",
|
|
1780
1778
|
weight: 1.4,
|
|
1781
1779
|
rationale: "O(n) with division + abs per step"
|
|
1782
1780
|
},
|
|
1783
|
-
[
|
|
1781
|
+
[A.FIND_GAPS]: {
|
|
1784
1782
|
mode: "calibrated",
|
|
1785
1783
|
weight: 0.9,
|
|
1786
1784
|
rationale: "O(n) on X only, mostly empty output"
|
|
1787
1785
|
},
|
|
1788
|
-
[
|
|
1786
|
+
[A.PERSISTENCE]: {
|
|
1789
1787
|
mode: "calibrated",
|
|
1790
1788
|
weight: 1.3,
|
|
1791
1789
|
rationale: "O(n) + chunk-boundary stitch"
|
|
1792
1790
|
},
|
|
1793
|
-
[
|
|
1791
|
+
[A.DATETIME_RANGE]: {
|
|
1794
1792
|
mode: "always-inline",
|
|
1795
1793
|
weight: 0,
|
|
1796
1794
|
rationale: "O(log n) binary search; never worth the worker hop"
|
|
1797
1795
|
},
|
|
1798
|
-
[
|
|
1796
|
+
[A.SELECTION]: {
|
|
1799
1797
|
mode: "always-inline",
|
|
1800
1798
|
weight: 0,
|
|
1801
1799
|
rationale: "Pure history bookkeeping"
|
|
@@ -1847,7 +1845,7 @@ const Ie = /* @__PURE__ */ new Set(), Me = {
|
|
|
1847
1845
|
rationale: "Single copy-with-fills pass; fresh SAB sized to newLength"
|
|
1848
1846
|
}
|
|
1849
1847
|
};
|
|
1850
|
-
function
|
|
1848
|
+
function D(e, t) {
|
|
1851
1849
|
const r = Me[e];
|
|
1852
1850
|
if (!r)
|
|
1853
1851
|
return {
|
|
@@ -1877,29 +1875,29 @@ function O(e, t) {
|
|
|
1877
1875
|
predictedWorkerMs: 0,
|
|
1878
1876
|
reason: r.rationale
|
|
1879
1877
|
};
|
|
1880
|
-
const s =
|
|
1878
|
+
const s = Wr(e, t);
|
|
1881
1879
|
if (s <= 0)
|
|
1882
1880
|
return {
|
|
1883
1881
|
useWorker: !1,
|
|
1884
1882
|
predictedInlineMs: 0,
|
|
1885
|
-
predictedWorkerMs:
|
|
1883
|
+
predictedWorkerMs: O.spawnOverheadMs,
|
|
1886
1884
|
reason: "zero work units"
|
|
1887
1885
|
};
|
|
1888
1886
|
const n = Math.max(
|
|
1889
1887
|
1,
|
|
1890
1888
|
Math.min(
|
|
1891
|
-
t.parallelism ??
|
|
1892
|
-
|
|
1889
|
+
t.parallelism ?? O.hwConcurrency,
|
|
1890
|
+
O.hwConcurrency
|
|
1893
1891
|
)
|
|
1894
|
-
),
|
|
1892
|
+
), o = r.weight * s / O.inlineThroughput, a = O.spawnOverheadMs + r.weight * s / (O.workerThroughput * n), i = o > a;
|
|
1895
1893
|
return {
|
|
1896
1894
|
useWorker: i,
|
|
1897
|
-
predictedInlineMs:
|
|
1898
|
-
predictedWorkerMs:
|
|
1899
|
-
reason: i ? `worker faster (${
|
|
1895
|
+
predictedInlineMs: o,
|
|
1896
|
+
predictedWorkerMs: a,
|
|
1897
|
+
reason: i ? `worker faster (${a.toFixed(1)} vs ${o.toFixed(1)} ms)` : `inline faster (${o.toFixed(1)} vs ${a.toFixed(1)} ms)`
|
|
1900
1898
|
};
|
|
1901
1899
|
}
|
|
1902
|
-
function
|
|
1900
|
+
function Wr(e, t) {
|
|
1903
1901
|
switch (e) {
|
|
1904
1902
|
case E.CHANGE_VALUES:
|
|
1905
1903
|
case E.INTERPOLATE:
|
|
@@ -1916,90 +1914,90 @@ function jr(e, t) {
|
|
|
1916
1914
|
return t.datasetSize;
|
|
1917
1915
|
}
|
|
1918
1916
|
}
|
|
1919
|
-
function
|
|
1920
|
-
return
|
|
1917
|
+
function bs(e) {
|
|
1918
|
+
return Oe.add(e), () => Oe.delete(e);
|
|
1921
1919
|
}
|
|
1922
|
-
function
|
|
1923
|
-
return
|
|
1920
|
+
function Ss() {
|
|
1921
|
+
return O;
|
|
1924
1922
|
}
|
|
1925
|
-
function
|
|
1926
|
-
return
|
|
1923
|
+
function Es() {
|
|
1924
|
+
return xe;
|
|
1927
1925
|
}
|
|
1928
|
-
function
|
|
1926
|
+
function vs() {
|
|
1929
1927
|
return Object.keys(Me).map((e) => ({ op: e, ...Me[e] }));
|
|
1930
1928
|
}
|
|
1931
|
-
function
|
|
1932
|
-
|
|
1929
|
+
function ks() {
|
|
1930
|
+
O = he, xe = null;
|
|
1933
1931
|
try {
|
|
1934
1932
|
localStorage.removeItem(Ce);
|
|
1935
1933
|
} catch {
|
|
1936
1934
|
}
|
|
1937
1935
|
}
|
|
1938
|
-
async function
|
|
1939
|
-
if (typeof window > "u" || !(e.force ||
|
|
1940
|
-
if (
|
|
1936
|
+
async function _s(e = {}) {
|
|
1937
|
+
if (typeof window > "u" || !(e.force || O.measuredAt === 0 || Date.now() - O.measuredAt > jr)) return O;
|
|
1938
|
+
if (ee) await ee;
|
|
1941
1939
|
else {
|
|
1942
|
-
|
|
1943
|
-
|
|
1940
|
+
ee = Yr().finally(() => {
|
|
1941
|
+
ee = null;
|
|
1944
1942
|
});
|
|
1945
|
-
const r = await
|
|
1946
|
-
|
|
1947
|
-
for (const s of
|
|
1943
|
+
const r = await ee;
|
|
1944
|
+
O = r, Hr(r), xe = r;
|
|
1945
|
+
for (const s of Oe) s(O);
|
|
1948
1946
|
}
|
|
1949
|
-
return
|
|
1947
|
+
return O;
|
|
1950
1948
|
}
|
|
1951
|
-
async function
|
|
1949
|
+
async function Yr() {
|
|
1952
1950
|
if (!(typeof SharedArrayBuffer < "u"))
|
|
1953
1951
|
return {
|
|
1954
|
-
...
|
|
1952
|
+
...he,
|
|
1955
1953
|
measuredAt: Date.now(),
|
|
1956
1954
|
userAgent: navigator.userAgent,
|
|
1957
|
-
hwConcurrency: navigator.hardwareConcurrency ||
|
|
1955
|
+
hwConcurrency: navigator.hardwareConcurrency || he.hwConcurrency,
|
|
1958
1956
|
sharedArrayBufferAvailable: !1,
|
|
1959
1957
|
samples: { spawnRoundtripMs: [], inlineScanMs: [], workerScanMs: [] }
|
|
1960
1958
|
};
|
|
1961
|
-
const t = navigator.hardwareConcurrency || 4, r = new Float32Array(
|
|
1962
|
-
for (let
|
|
1963
|
-
const s = await
|
|
1964
|
-
const
|
|
1965
|
-
return Pt(r, 0,
|
|
1966
|
-
}), n = ke(s),
|
|
1967
|
-
const
|
|
1968
|
-
return await new Promise((
|
|
1969
|
-
const
|
|
1970
|
-
|
|
1971
|
-
|
|
1972
|
-
},
|
|
1973
|
-
bufferY:
|
|
1959
|
+
const t = navigator.hardwareConcurrency || 4, r = new Float32Array(oe);
|
|
1960
|
+
for (let u = 0; u < oe; u++) r[u] = Math.sin(u);
|
|
1961
|
+
const s = await ve(3, () => {
|
|
1962
|
+
const u = performance.now();
|
|
1963
|
+
return Pt(r, 0, oe, [2], [0.5]), performance.now() - u;
|
|
1964
|
+
}), n = ke(s), o = oe / Math.max(n, 1e-3), a = new SharedArrayBuffer(256 * Float32Array.BYTES_PER_ELEMENT), i = await ve(3, async () => {
|
|
1965
|
+
const u = performance.now();
|
|
1966
|
+
return await new Promise((w) => {
|
|
1967
|
+
const b = new Ie();
|
|
1968
|
+
b.onmessage = () => {
|
|
1969
|
+
b.terminate(), w();
|
|
1970
|
+
}, b.postMessage({
|
|
1971
|
+
bufferY: a,
|
|
1974
1972
|
start: 0,
|
|
1975
1973
|
end: 256,
|
|
1976
1974
|
ops: [2],
|
|
1977
1975
|
values: [0.5]
|
|
1978
1976
|
});
|
|
1979
|
-
}), performance.now() -
|
|
1977
|
+
}), performance.now() - u;
|
|
1980
1978
|
}), l = ke(i), f = new SharedArrayBuffer(
|
|
1981
|
-
|
|
1982
|
-
),
|
|
1983
|
-
for (let
|
|
1984
|
-
const
|
|
1985
|
-
const
|
|
1986
|
-
return await new Promise((
|
|
1987
|
-
const
|
|
1988
|
-
|
|
1989
|
-
|
|
1990
|
-
},
|
|
1979
|
+
ae * Float32Array.BYTES_PER_ELEMENT
|
|
1980
|
+
), h = new Float32Array(f);
|
|
1981
|
+
for (let u = 0; u < ae; u++) h[u] = Math.sin(u);
|
|
1982
|
+
const y = await ve(3, async () => {
|
|
1983
|
+
const u = performance.now();
|
|
1984
|
+
return await new Promise((w) => {
|
|
1985
|
+
const b = new Ie();
|
|
1986
|
+
b.onmessage = () => {
|
|
1987
|
+
b.terminate(), w();
|
|
1988
|
+
}, b.postMessage({
|
|
1991
1989
|
bufferY: f,
|
|
1992
1990
|
start: 0,
|
|
1993
|
-
end:
|
|
1991
|
+
end: ae,
|
|
1994
1992
|
ops: [2],
|
|
1995
1993
|
values: [0.5]
|
|
1996
1994
|
});
|
|
1997
|
-
}), performance.now() -
|
|
1998
|
-
}),
|
|
1995
|
+
}), performance.now() - u;
|
|
1996
|
+
}), p = Math.max(ke(y) - l, 0.1), g = ae / p;
|
|
1999
1997
|
return {
|
|
2000
1998
|
spawnOverheadMs: l,
|
|
2001
|
-
inlineThroughput:
|
|
2002
|
-
workerThroughput:
|
|
1999
|
+
inlineThroughput: o,
|
|
2000
|
+
workerThroughput: g,
|
|
2003
2001
|
hwConcurrency: t,
|
|
2004
2002
|
measuredAt: Date.now(),
|
|
2005
2003
|
userAgent: navigator.userAgent,
|
|
@@ -2007,11 +2005,11 @@ async function Wr() {
|
|
|
2007
2005
|
samples: {
|
|
2008
2006
|
spawnRoundtripMs: i,
|
|
2009
2007
|
inlineScanMs: s,
|
|
2010
|
-
workerScanMs:
|
|
2008
|
+
workerScanMs: y
|
|
2011
2009
|
}
|
|
2012
2010
|
};
|
|
2013
2011
|
}
|
|
2014
|
-
async function
|
|
2012
|
+
async function ve(e, t) {
|
|
2015
2013
|
const r = [];
|
|
2016
2014
|
for (let s = 0; s < e; s++)
|
|
2017
2015
|
await new Promise((n) => setTimeout(n, 0)), r.push(await t());
|
|
@@ -2033,7 +2031,7 @@ function Gr() {
|
|
|
2033
2031
|
return null;
|
|
2034
2032
|
}
|
|
2035
2033
|
}
|
|
2036
|
-
function
|
|
2034
|
+
function Hr(e) {
|
|
2037
2035
|
if (!(typeof localStorage > "u"))
|
|
2038
2036
|
try {
|
|
2039
2037
|
const t = {
|
|
@@ -2048,29 +2046,44 @@ function Yr(e) {
|
|
|
2048
2046
|
} catch {
|
|
2049
2047
|
}
|
|
2050
2048
|
}
|
|
2051
|
-
const
|
|
2052
|
-
function
|
|
2053
|
-
return
|
|
2049
|
+
const te = 20 * 1e3, zr = 1024, Xr = ["date", "value", "qualifier"], Vr = typeof SharedArrayBuffer < "u";
|
|
2050
|
+
function M(e, t) {
|
|
2051
|
+
return Vr ? t !== void 0 ? new SharedArrayBuffer(e, { maxByteLength: t }) : new SharedArrayBuffer(e) : t !== void 0 ? new ArrayBuffer(e, { maxByteLength: t }) : new ArrayBuffer(e);
|
|
2054
2052
|
}
|
|
2055
|
-
function
|
|
2053
|
+
function ht(e, t) {
|
|
2056
2054
|
const r = e;
|
|
2057
2055
|
typeof r.grow == "function" ? r.grow(t) : typeof r.resize == "function" && r.resize(t);
|
|
2058
2056
|
}
|
|
2059
|
-
|
|
2057
|
+
function qr(e, t) {
|
|
2058
|
+
if (e.length !== t.length) return !1;
|
|
2059
|
+
for (let r = 0; r < e.length; r++)
|
|
2060
|
+
if (e[r] !== t[r]) return !1;
|
|
2061
|
+
return !0;
|
|
2062
|
+
}
|
|
2063
|
+
function Jr(e, t) {
|
|
2064
|
+
switch (e) {
|
|
2065
|
+
case E.ADD_POINTS:
|
|
2066
|
+
case E.FILL_GAPS:
|
|
2067
|
+
return !1;
|
|
2068
|
+
default:
|
|
2069
|
+
return !0;
|
|
2070
|
+
}
|
|
2071
|
+
}
|
|
2072
|
+
class As {
|
|
2060
2073
|
/** The generated dataset to be used for plotting */
|
|
2061
2074
|
dataset = {
|
|
2062
|
-
dimensions:
|
|
2075
|
+
dimensions: Xr,
|
|
2063
2076
|
source: {
|
|
2064
2077
|
x: new Float64Array(
|
|
2065
|
-
|
|
2066
|
-
|
|
2067
|
-
|
|
2078
|
+
M(
|
|
2079
|
+
te * Float64Array.BYTES_PER_ELEMENT,
|
|
2080
|
+
te * Float64Array.BYTES_PER_ELEMENT
|
|
2068
2081
|
)
|
|
2069
2082
|
),
|
|
2070
2083
|
y: new Float32Array(
|
|
2071
|
-
|
|
2072
|
-
|
|
2073
|
-
|
|
2084
|
+
M(
|
|
2085
|
+
te * Float32Array.BYTES_PER_ELEMENT,
|
|
2086
|
+
te * Float32Array.BYTES_PER_ELEMENT
|
|
2074
2087
|
)
|
|
2075
2088
|
)
|
|
2076
2089
|
}
|
|
@@ -2110,7 +2123,7 @@ class Es {
|
|
|
2110
2123
|
if (!t)
|
|
2111
2124
|
return;
|
|
2112
2125
|
this.isLoading = !0;
|
|
2113
|
-
const r = await
|
|
2126
|
+
const r = await Ee(() => {
|
|
2114
2127
|
this._growBuffer(t.datetimes.length), this._resizeTo(t.datetimes.length), this.dataX.set(t.datetimes), this.dataY.set(t.dataValues);
|
|
2115
2128
|
});
|
|
2116
2129
|
this.loadingTime = r.duration, this.history.length = 0, this.isLoading = !1;
|
|
@@ -2141,18 +2154,18 @@ class Es {
|
|
|
2141
2154
|
const r = t * Float64Array.BYTES_PER_ELEMENT;
|
|
2142
2155
|
let s = this.dataX.buffer.byteLength;
|
|
2143
2156
|
for (; r > s; )
|
|
2144
|
-
s +=
|
|
2157
|
+
s += te * Float64Array.BYTES_PER_ELEMENT;
|
|
2145
2158
|
if (s * Float64Array.BYTES_PER_ELEMENT > this.dataX.buffer.maxByteLength) {
|
|
2146
|
-
const n =
|
|
2159
|
+
const n = M(
|
|
2147
2160
|
this.dataX.buffer.byteLength,
|
|
2148
2161
|
s * Float64Array.BYTES_PER_ELEMENT
|
|
2149
|
-
),
|
|
2162
|
+
), o = M(
|
|
2150
2163
|
this.dataY.buffer.byteLength,
|
|
2151
2164
|
s * Float32Array.BYTES_PER_ELEMENT
|
|
2152
|
-
),
|
|
2153
|
-
|
|
2165
|
+
), a = new Float64Array(n), i = new Float32Array(o);
|
|
2166
|
+
a.set(this.dataX), i.set(this.dataY), this.dataset.source.x = a, this.dataset.source.y = i;
|
|
2154
2167
|
}
|
|
2155
|
-
this.dataX.buffer.byteLength < t * Float64Array.BYTES_PER_ELEMENT && (
|
|
2168
|
+
this.dataX.buffer.byteLength < t * Float64Array.BYTES_PER_ELEMENT && (ht(this.dataX.buffer, t * Float64Array.BYTES_PER_ELEMENT), ht(this.dataY.buffer, t * Float32Array.BYTES_PER_ELEMENT));
|
|
2156
2169
|
}
|
|
2157
2170
|
/**
|
|
2158
2171
|
* Reloads the dataset with the raw data
|
|
@@ -2213,60 +2226,60 @@ class Es {
|
|
|
2213
2226
|
get endTime() {
|
|
2214
2227
|
return this.dataset.source.x.length ? new Date(this.dataset.source.x[this.dataset.source.x.length - 1]) : null;
|
|
2215
2228
|
}
|
|
2216
|
-
/**
|
|
2229
|
+
/**
|
|
2230
|
+
* Dispatch an operation and log its signature in history.
|
|
2231
|
+
*
|
|
2232
|
+
* The selection-consuming entries below (DELETE_POINTS, INTERPOLATE,
|
|
2233
|
+
* SHIFT_DATETIMES, DRIFT_CORRECTION) route to thin
|
|
2234
|
+
* `*FromSelection` wrappers that read the target indices off
|
|
2235
|
+
* `history[length - 2].selected` at dispatch time, mirroring the
|
|
2236
|
+
* pattern CHANGE_VALUES already uses. The internal handlers
|
|
2237
|
+
* (`_deleteDataPoints`, `_shift`, etc.) keep their explicit-
|
|
2238
|
+
* indices signatures so other internal callers (e.g.
|
|
2239
|
+
* `_assignDatetimesBulk` → `_deleteDataPoints` + `_addDataPoints`)
|
|
2240
|
+
* can pass locally-computed indices without going through history.
|
|
2241
|
+
*/
|
|
2217
2242
|
async dispatchAction(t, ...r) {
|
|
2218
2243
|
const s = {
|
|
2219
2244
|
[E.ADD_POINTS]: this._addDataPoints,
|
|
2220
2245
|
[E.CHANGE_VALUES]: this._changeValues,
|
|
2221
2246
|
[E.ASSIGN_VALUES_BULK]: this._assignValuesBulk,
|
|
2222
|
-
[E.DELETE_POINTS]: this.
|
|
2223
|
-
[E.DRIFT_CORRECTION]: this.
|
|
2224
|
-
[E.INTERPOLATE]: this.
|
|
2225
|
-
[E.SHIFT_DATETIMES]: this.
|
|
2247
|
+
[E.DELETE_POINTS]: this._deleteDataPointsFromSelection,
|
|
2248
|
+
[E.DRIFT_CORRECTION]: this._driftCorrectionFromSelection,
|
|
2249
|
+
[E.INTERPOLATE]: this._interpolateFromSelection,
|
|
2250
|
+
[E.SHIFT_DATETIMES]: this._shiftFromSelection,
|
|
2226
2251
|
[E.ASSIGN_DATETIMES_BULK]: this._assignDatetimesBulk,
|
|
2227
2252
|
[E.FILL_GAPS]: this._fillGaps
|
|
2228
|
-
}, n = {
|
|
2229
|
-
[E.ADD_POINTS]: "mdi-plus",
|
|
2230
|
-
[E.CHANGE_VALUES]: "mdi-pencil",
|
|
2231
|
-
[E.ASSIGN_VALUES_BULK]: "mdi-pencil",
|
|
2232
|
-
[E.DELETE_POINTS]: "mdi-trash-can",
|
|
2233
|
-
[E.DRIFT_CORRECTION]: "mdi-chart-sankey",
|
|
2234
|
-
[E.INTERPOLATE]: "mdi-transit-connection-horizontal",
|
|
2235
|
-
[E.SHIFT_DATETIMES]: "mdi-calendar",
|
|
2236
|
-
[E.ASSIGN_DATETIMES_BULK]: "mdi-calendar",
|
|
2237
|
-
[E.FILL_GAPS]: "mdi-keyboard-space"
|
|
2238
2253
|
};
|
|
2239
|
-
let
|
|
2254
|
+
let n = [], o = null;
|
|
2240
2255
|
try {
|
|
2241
|
-
this._isReplaying || (this.redoStack.length = 0)
|
|
2242
|
-
const o = {
|
|
2256
|
+
this._isReplaying || (this.redoStack.length = 0), o = {
|
|
2243
2257
|
method: t,
|
|
2244
2258
|
args: r,
|
|
2245
|
-
icon: n[t],
|
|
2246
2259
|
isLoading: !0
|
|
2247
|
-
};
|
|
2248
|
-
|
|
2249
|
-
|
|
2250
|
-
this.
|
|
2251
|
-
|
|
2252
|
-
|
|
2253
|
-
|
|
2254
|
-
f && (f.duration = l.duration, f.executionMode = this._pendingExecutionMode, f.isLoading = !1);
|
|
2255
|
-
} catch (o) {
|
|
2256
|
-
console.log(
|
|
2260
|
+
}, this.history.push(o), Jr(t, r) || this.history[this.history.length - 2]?.method === A.SELECTION && this.history.splice(this.history.length - 2, 1), this._pendingExecutionMode = "inline";
|
|
2261
|
+
const a = await Ee(async () => await s[t].apply(this, r));
|
|
2262
|
+
n = a.response;
|
|
2263
|
+
const i = this.history.indexOf(o), l = i >= 0 ? this.history[i] : void 0;
|
|
2264
|
+
l && (l.duration = a.duration, l.executionMode = this._pendingExecutionMode, l.status = "success", l.isLoading = !1);
|
|
2265
|
+
} catch (a) {
|
|
2266
|
+
if (console.log(
|
|
2257
2267
|
`Failed to execute operation: ${t} with arguments: `,
|
|
2258
2268
|
r
|
|
2259
|
-
), console.log(o)
|
|
2269
|
+
), console.log(a), o) {
|
|
2270
|
+
const i = this.history.indexOf(o), l = i >= 0 ? this.history[i] : void 0;
|
|
2271
|
+
l && (l.status = "failed", l.isLoading = !1);
|
|
2272
|
+
}
|
|
2260
2273
|
}
|
|
2261
|
-
return
|
|
2274
|
+
return n;
|
|
2262
2275
|
}
|
|
2263
2276
|
async dispatch(t, ...r) {
|
|
2264
|
-
const s = async (n,
|
|
2277
|
+
const s = async (n, o) => A[n] ? await this.dispatchFilter(n, ...o) : await this.dispatchAction(n, ...o);
|
|
2265
2278
|
if (Array.isArray(t)) {
|
|
2266
2279
|
let n = [];
|
|
2267
|
-
for (let
|
|
2268
|
-
const
|
|
2269
|
-
n = await s(
|
|
2280
|
+
for (let o = 0; o < t.length; o++) {
|
|
2281
|
+
const a = t[o][0], i = t[o].slice(1, t[o].length);
|
|
2282
|
+
n = await s(a, i);
|
|
2270
2283
|
}
|
|
2271
2284
|
return n;
|
|
2272
2285
|
} else
|
|
@@ -2275,44 +2288,39 @@ class Es {
|
|
|
2275
2288
|
/** Filter operations do not transform the data and return a selection */
|
|
2276
2289
|
async dispatchFilter(t, ...r) {
|
|
2277
2290
|
const s = {
|
|
2278
|
-
[
|
|
2279
|
-
[
|
|
2280
|
-
[
|
|
2281
|
-
[
|
|
2282
|
-
[
|
|
2283
|
-
[
|
|
2284
|
-
[
|
|
2285
|
-
}, n = {
|
|
2286
|
-
[v.FIND_GAPS]: "mdi-plus",
|
|
2287
|
-
[v.PERSISTENCE]: "mdi-plus",
|
|
2288
|
-
[v.CHANGE]: "mdi-plus",
|
|
2289
|
-
[v.RATE_OF_CHANGE]: "mdi-plus",
|
|
2290
|
-
[v.VALUE_THRESHOLD]: "mdi-plus",
|
|
2291
|
-
[v.DATETIME_RANGE]: "mdi-plus",
|
|
2292
|
-
[v.SELECTION]: "mdi-plus"
|
|
2291
|
+
[A.FIND_GAPS]: this._findGaps,
|
|
2292
|
+
[A.VALUE_THRESHOLD]: this._valueThreshold,
|
|
2293
|
+
[A.DATETIME_RANGE]: this._datetimeRange,
|
|
2294
|
+
[A.PERSISTENCE]: this._persistence,
|
|
2295
|
+
[A.CHANGE]: this._change,
|
|
2296
|
+
[A.RATE_OF_CHANGE]: this._rateOfChange,
|
|
2297
|
+
[A.SELECTION]: this._selection
|
|
2293
2298
|
};
|
|
2294
|
-
let
|
|
2299
|
+
let n = [], o = null;
|
|
2295
2300
|
try {
|
|
2296
|
-
|
|
2297
|
-
|
|
2301
|
+
const a = t === A.SELECTION, i = a && (!r[0] || Array.isArray(r[0]) && r[0].length === 0);
|
|
2302
|
+
!this._isReplaying && !i && (this.redoStack.length = 0), o = {
|
|
2298
2303
|
method: t,
|
|
2299
2304
|
args: r,
|
|
2300
|
-
icon: n[t],
|
|
2301
2305
|
isLoading: !0
|
|
2302
|
-
}
|
|
2303
|
-
|
|
2304
|
-
|
|
2305
|
-
|
|
2306
|
-
|
|
2307
|
-
|
|
2308
|
-
|
|
2309
|
-
|
|
2310
|
-
|
|
2306
|
+
};
|
|
2307
|
+
const l = this.history[this.history.length - 1], f = !!A[l?.method], h = l?.method === t || f && !a;
|
|
2308
|
+
let y;
|
|
2309
|
+
h ? (y = this.history.length - 1, this.history[y] = o) : (this.history.push(o), y = this.history.length - 1), this._pendingExecutionMode = "inline";
|
|
2310
|
+
const p = await Ee(async () => await s[t].apply(this, r));
|
|
2311
|
+
n = p.response;
|
|
2312
|
+
const g = this.history.indexOf(o), d = g >= 0 ? this.history[g] : void 0;
|
|
2313
|
+
d && (d.duration = p.duration, d.executionMode = this._pendingExecutionMode, d.selected = p.response, d.status = "success", d.isLoading = !1);
|
|
2314
|
+
} catch (a) {
|
|
2315
|
+
if (console.log(
|
|
2311
2316
|
`Failed to execute filter operation: ${t} with arguments: `,
|
|
2312
2317
|
r
|
|
2313
|
-
), console.log(o)
|
|
2318
|
+
), console.log(a), o) {
|
|
2319
|
+
const i = this.history.indexOf(o), l = i >= 0 ? this.history[i] : void 0;
|
|
2320
|
+
l && (l.status = "failed", l.isLoading = !1);
|
|
2321
|
+
}
|
|
2314
2322
|
}
|
|
2315
|
-
return
|
|
2323
|
+
return n;
|
|
2316
2324
|
}
|
|
2317
2325
|
/**
|
|
2318
2326
|
* @param index An array containing the list of index of values to perform the operations on.
|
|
@@ -2330,32 +2338,32 @@ class Es {
|
|
|
2330
2338
|
const s = this.history[this.history.length - 2]?.selected;
|
|
2331
2339
|
if (!s || s.length === 0) return [];
|
|
2332
2340
|
const n = s.length;
|
|
2333
|
-
if (!
|
|
2341
|
+
if (!D(E.CHANGE_VALUES, {
|
|
2334
2342
|
datasetSize: this.dataset.source.y.length,
|
|
2335
2343
|
selectionSize: n
|
|
2336
|
-
}).useWorker || n <
|
|
2337
|
-
return
|
|
2344
|
+
}).useWorker || n < zr)
|
|
2345
|
+
return ut(this.dataY, s, t, r), [];
|
|
2338
2346
|
this._pendingExecutionMode = "worker";
|
|
2339
|
-
const
|
|
2340
|
-
for (let
|
|
2341
|
-
const
|
|
2342
|
-
if (
|
|
2343
|
-
const
|
|
2347
|
+
const a = Math.min(navigator.hardwareConcurrency || 1, n), i = Math.ceil(n / a), l = [], f = [];
|
|
2348
|
+
for (let h = 0; h < a; h++) {
|
|
2349
|
+
const y = h * i, p = Math.min((h + 1) * i, n);
|
|
2350
|
+
if (y >= p) break;
|
|
2351
|
+
const g = s.slice(y, p);
|
|
2344
2352
|
f.push(
|
|
2345
2353
|
new Promise((d) => {
|
|
2346
|
-
const
|
|
2347
|
-
l.push(
|
|
2354
|
+
const u = new Rr();
|
|
2355
|
+
l.push(u), u.postMessage({
|
|
2348
2356
|
bufferY: this.dataY.buffer,
|
|
2349
|
-
indexes:
|
|
2357
|
+
indexes: g,
|
|
2350
2358
|
operator: t,
|
|
2351
2359
|
value: r
|
|
2352
|
-
}),
|
|
2353
|
-
d(
|
|
2360
|
+
}), u.onmessage = (w) => {
|
|
2361
|
+
d(w.data);
|
|
2354
2362
|
};
|
|
2355
2363
|
})
|
|
2356
2364
|
);
|
|
2357
2365
|
}
|
|
2358
|
-
return await Promise.all(f), l.forEach((
|
|
2366
|
+
return await Promise.all(f), l.forEach((h) => h.terminate()), [];
|
|
2359
2367
|
}
|
|
2360
2368
|
/**
|
|
2361
2369
|
* Apply an arithmetic operator to Y in-place on the main thread. Thin
|
|
@@ -2364,7 +2372,7 @@ class Es {
|
|
|
2364
2372
|
* CHANGE_VALUES fast path does.
|
|
2365
2373
|
*/
|
|
2366
2374
|
_applyOperatorInPlace(t, r, s) {
|
|
2367
|
-
|
|
2375
|
+
ut(this.dataY, t, r, s);
|
|
2368
2376
|
}
|
|
2369
2377
|
/**
|
|
2370
2378
|
* One-shot assignment of distinct Y-values at the indices logged by the
|
|
@@ -2382,7 +2390,7 @@ class Es {
|
|
|
2382
2390
|
const r = this.history[this.history.length - 2]?.selected;
|
|
2383
2391
|
if (!r || !r.length || !t?.length) return [];
|
|
2384
2392
|
const s = Math.min(r.length, t.length), n = this.dataY;
|
|
2385
|
-
for (let
|
|
2393
|
+
for (let o = 0; o < s; o++) n[r[o]] = t[o];
|
|
2386
2394
|
return [];
|
|
2387
2395
|
}
|
|
2388
2396
|
/**
|
|
@@ -2397,10 +2405,22 @@ class Es {
|
|
|
2397
2405
|
async _assignDatetimesBulk(t) {
|
|
2398
2406
|
const r = this.history[this.history.length - 2]?.selected;
|
|
2399
2407
|
if (!r || !r.length || !t?.length) return [];
|
|
2400
|
-
const s = Math.min(r.length, t.length), n = new Array(s),
|
|
2401
|
-
for (let
|
|
2402
|
-
n[
|
|
2403
|
-
return
|
|
2408
|
+
const s = Math.min(r.length, t.length), n = new Array(s), o = new Array(s);
|
|
2409
|
+
for (let a = 0; a < s; a++)
|
|
2410
|
+
n[a] = [t[a], this.dataY[r[a]]], o[a] = r[a];
|
|
2411
|
+
return o.sort((a, i) => a - i), await this._deleteDataPoints(o), await this._addDataPoints(n), [];
|
|
2412
|
+
}
|
|
2413
|
+
/**
|
|
2414
|
+
* Dispatch wrapper around `_interpolate` — reads target indices
|
|
2415
|
+
* from `history[length - 2].selected` (the SELECTION the caller
|
|
2416
|
+
* dispatched immediately before this op). External callers go
|
|
2417
|
+
* through here; internal callers can keep using `_interpolate`
|
|
2418
|
+
* directly with explicit indices.
|
|
2419
|
+
*/
|
|
2420
|
+
async _interpolateFromSelection() {
|
|
2421
|
+
const t = this.history[this.history.length - 2]?.selected;
|
|
2422
|
+
if (!(!t || t.length === 0))
|
|
2423
|
+
return this._interpolate(t);
|
|
2404
2424
|
}
|
|
2405
2425
|
/**
|
|
2406
2426
|
* Multi-threaded linear interpolation over the selected indexes.
|
|
@@ -2411,12 +2431,12 @@ class Es {
|
|
|
2411
2431
|
async _interpolate(t) {
|
|
2412
2432
|
const r = this._getConsecutiveGroups(t);
|
|
2413
2433
|
if (r.length === 0 || r[0].length === 0) return;
|
|
2414
|
-
const s = this.dataset.source.y.length, n = r.map((
|
|
2415
|
-
indexes:
|
|
2416
|
-
lowerIdx: Math.max(0,
|
|
2417
|
-
upperIdx: Math.min(s - 1,
|
|
2434
|
+
const s = this.dataset.source.y.length, n = r.map((h) => ({
|
|
2435
|
+
indexes: h,
|
|
2436
|
+
lowerIdx: Math.max(0, h[0] - 1),
|
|
2437
|
+
upperIdx: Math.min(s - 1, h[h.length - 1] + 1)
|
|
2418
2438
|
}));
|
|
2419
|
-
if (!
|
|
2439
|
+
if (!D(E.INTERPOLATE, {
|
|
2420
2440
|
datasetSize: s,
|
|
2421
2441
|
selectionSize: t.length
|
|
2422
2442
|
}).useWorker) {
|
|
@@ -2424,30 +2444,30 @@ class Es {
|
|
|
2424
2444
|
return;
|
|
2425
2445
|
}
|
|
2426
2446
|
this._pendingExecutionMode = "worker";
|
|
2427
|
-
const
|
|
2447
|
+
const a = Math.min(
|
|
2428
2448
|
navigator.hardwareConcurrency || 1,
|
|
2429
2449
|
n.length
|
|
2430
|
-
), i = Math.ceil(n.length /
|
|
2431
|
-
for (let
|
|
2432
|
-
const
|
|
2433
|
-
|
|
2434
|
-
(
|
|
2450
|
+
), i = Math.ceil(n.length / a), l = [], f = [];
|
|
2451
|
+
for (let h = 0; h < a; h++) {
|
|
2452
|
+
const y = n.slice(
|
|
2453
|
+
h * i,
|
|
2454
|
+
(h + 1) * i
|
|
2435
2455
|
);
|
|
2436
|
-
if (
|
|
2456
|
+
if (y.length === 0) break;
|
|
2437
2457
|
f.push(
|
|
2438
|
-
new Promise((
|
|
2439
|
-
const
|
|
2440
|
-
l.push(
|
|
2458
|
+
new Promise((p) => {
|
|
2459
|
+
const g = new Er();
|
|
2460
|
+
l.push(g), g.postMessage({
|
|
2441
2461
|
bufferX: this.dataX.buffer,
|
|
2442
2462
|
bufferY: this.dataY.buffer,
|
|
2443
|
-
groups:
|
|
2444
|
-
}),
|
|
2445
|
-
|
|
2463
|
+
groups: y
|
|
2464
|
+
}), g.onmessage = (d) => {
|
|
2465
|
+
p(d.data);
|
|
2446
2466
|
};
|
|
2447
2467
|
})
|
|
2448
2468
|
);
|
|
2449
2469
|
}
|
|
2450
|
-
await Promise.all(f), l.forEach((
|
|
2470
|
+
await Promise.all(f), l.forEach((h) => h.terminate());
|
|
2451
2471
|
}
|
|
2452
2472
|
/** Interpolate existing values in the data source */
|
|
2453
2473
|
// private _interpolateLinear(
|
|
@@ -2463,6 +2483,16 @@ class Es {
|
|
|
2463
2483
|
// (upperDatetime - lowerDatetime);
|
|
2464
2484
|
// return interpolatedValue;
|
|
2465
2485
|
// }
|
|
2486
|
+
/**
|
|
2487
|
+
* Dispatch wrapper around `_shift` — reads target indices from
|
|
2488
|
+
* `history[length - 2].selected`. The `amount` and `unit` args
|
|
2489
|
+
* stay parametric on the public dispatch signature.
|
|
2490
|
+
*/
|
|
2491
|
+
async _shiftFromSelection(t, r) {
|
|
2492
|
+
const s = this.history[this.history.length - 2]?.selected;
|
|
2493
|
+
if (!(!s || s.length === 0))
|
|
2494
|
+
return this._shift(s, t, r);
|
|
2495
|
+
}
|
|
2466
2496
|
/**
|
|
2467
2497
|
* Shifts the selected indexes by specified amount of units. Elements are reinserted according to their datetime.
|
|
2468
2498
|
* @param index The index of the elements to shift
|
|
@@ -2472,51 +2502,51 @@ class Es {
|
|
|
2472
2502
|
*/
|
|
2473
2503
|
async _shift(t, r, s) {
|
|
2474
2504
|
if (t.length === 0) return;
|
|
2475
|
-
const n = s ===
|
|
2476
|
-
if (!
|
|
2505
|
+
const n = s === x.MONTH, o = s === x.YEAR, a = !n && !o ? r * ne[s] * 1e3 : 0, i = t.length;
|
|
2506
|
+
if (!D(E.SHIFT_DATETIMES, {
|
|
2477
2507
|
datasetSize: this.dataset.source.x.length,
|
|
2478
2508
|
selectionSize: i
|
|
2479
2509
|
}).useWorker) {
|
|
2480
|
-
const m =
|
|
2510
|
+
const m = xr(
|
|
2481
2511
|
this.dataX,
|
|
2482
2512
|
this.dataY,
|
|
2483
2513
|
t,
|
|
2484
|
-
{ amount: r, isMonth: n, isYear:
|
|
2514
|
+
{ amount: r, isMonth: n, isYear: o, deltaMs: a }
|
|
2485
2515
|
);
|
|
2486
2516
|
await this._deleteDataPoints(t), await this._addDataPoints(m);
|
|
2487
2517
|
return;
|
|
2488
2518
|
}
|
|
2489
2519
|
this._pendingExecutionMode = "worker";
|
|
2490
|
-
const f =
|
|
2491
|
-
for (let m = 0; m <
|
|
2492
|
-
const S = m *
|
|
2493
|
-
if (S >=
|
|
2494
|
-
const T = t.slice(S,
|
|
2520
|
+
const f = M(i * Float64Array.BYTES_PER_ELEMENT), h = M(i * Float32Array.BYTES_PER_ELEMENT), y = Math.min(navigator.hardwareConcurrency || 1, i), p = Math.ceil(i / y), g = [], d = [];
|
|
2521
|
+
for (let m = 0; m < y; m++) {
|
|
2522
|
+
const S = m * p, v = Math.min((m + 1) * p, i);
|
|
2523
|
+
if (S >= v) break;
|
|
2524
|
+
const T = t.slice(S, v);
|
|
2495
2525
|
d.push(
|
|
2496
2526
|
new Promise((L) => {
|
|
2497
|
-
const
|
|
2498
|
-
|
|
2527
|
+
const R = new _r();
|
|
2528
|
+
g.push(R), R.postMessage({
|
|
2499
2529
|
bufferX: this.dataX.buffer,
|
|
2500
2530
|
bufferY: this.dataY.buffer,
|
|
2501
2531
|
outputBufferX: f,
|
|
2502
|
-
outputBufferY:
|
|
2532
|
+
outputBufferY: h,
|
|
2503
2533
|
indexes: T,
|
|
2504
2534
|
outStart: S,
|
|
2505
2535
|
amount: r,
|
|
2506
2536
|
isMonth: n,
|
|
2507
|
-
isYear:
|
|
2508
|
-
deltaMs:
|
|
2509
|
-
}),
|
|
2510
|
-
L(
|
|
2537
|
+
isYear: o,
|
|
2538
|
+
deltaMs: a
|
|
2539
|
+
}), R.onmessage = (U) => {
|
|
2540
|
+
L(U.data);
|
|
2511
2541
|
};
|
|
2512
2542
|
})
|
|
2513
2543
|
);
|
|
2514
2544
|
}
|
|
2515
|
-
await Promise.all(d),
|
|
2516
|
-
const
|
|
2545
|
+
await Promise.all(d), g.forEach((m) => m.terminate());
|
|
2546
|
+
const u = new Float64Array(f), w = new Float32Array(h), b = new Array(i);
|
|
2517
2547
|
for (let m = 0; m < i; m++)
|
|
2518
|
-
|
|
2519
|
-
await this._deleteDataPoints(t), await this._addDataPoints(
|
|
2548
|
+
b[m] = [u[m], w[m]];
|
|
2549
|
+
await this._deleteDataPoints(t), await this._addDataPoints(b);
|
|
2520
2550
|
}
|
|
2521
2551
|
/**
|
|
2522
2552
|
* Multi-threaded version of {@link _fillGaps}.
|
|
@@ -2525,84 +2555,103 @@ class Es {
|
|
|
2525
2555
|
* 3. Cumulative fill counts before each segment give each worker's output startTarget, ensuring no overlap.
|
|
2526
2556
|
* 4. Each worker copies its segment to the output buffer and inserts its gap fills inline.
|
|
2527
2557
|
*/
|
|
2528
|
-
|
|
2529
|
-
|
|
2530
|
-
|
|
2531
|
-
|
|
2558
|
+
/**
|
|
2559
|
+
* @param range Optional `[startTs, endTs]` window in epoch
|
|
2560
|
+
* milliseconds. Both bounds inclusive; snapped to the nearest
|
|
2561
|
+
* enclosed point via binary search. Datetime-addressed (not
|
|
2562
|
+
* index-addressed) so the same call survives data growth and is
|
|
2563
|
+
* portable across datasets for QC script replay.
|
|
2564
|
+
*/
|
|
2565
|
+
async _fillGaps(t, r, s, n, o) {
|
|
2566
|
+
const a = this.dataX.length;
|
|
2567
|
+
if (a === 0) return;
|
|
2568
|
+
const i = t[0] * ne[t[1]] * 1e3, l = r[0] * ne[r[1]] * 1e3, f = this.dataX, h = o?.[0] != null && Number.isFinite(o[0]) ? X(f, o[0]) : 0, y = o?.[1] != null && Number.isFinite(o[1]) ? Q(f, o[1]) : a - 1, p = [], g = [];
|
|
2532
2569
|
let d = 0;
|
|
2533
|
-
for (let k =
|
|
2534
|
-
if (
|
|
2535
|
-
let P = 0,
|
|
2536
|
-
for (;
|
|
2537
|
-
P++,
|
|
2538
|
-
P > 0 && (
|
|
2570
|
+
for (let k = h + 1; k <= y; k++)
|
|
2571
|
+
if (f[k] - f[k - 1] > i) {
|
|
2572
|
+
let P = 0, Y = f[k - 1] + l;
|
|
2573
|
+
for (; Y < f[k]; )
|
|
2574
|
+
P++, Y += l;
|
|
2575
|
+
P > 0 && (p.push([k - 1, k]), g.push(P), d += P);
|
|
2539
2576
|
}
|
|
2540
2577
|
if (d === 0) return;
|
|
2541
|
-
const
|
|
2542
|
-
b,
|
|
2543
|
-
Math.max(this.dataX.buffer.maxByteLength, b)
|
|
2544
|
-
), S = U(
|
|
2578
|
+
const u = a + d, w = u * Float64Array.BYTES_PER_ELEMENT, b = u * Float32Array.BYTES_PER_ELEMENT, m = M(
|
|
2545
2579
|
w,
|
|
2546
|
-
Math.max(this.
|
|
2580
|
+
Math.max(this.dataX.buffer.maxByteLength, w)
|
|
2581
|
+
), S = M(
|
|
2582
|
+
b,
|
|
2583
|
+
Math.max(this.dataY.buffer.maxByteLength, b)
|
|
2547
2584
|
);
|
|
2548
|
-
if (!
|
|
2549
|
-
datasetSize:
|
|
2585
|
+
if (!D(E.FILL_GAPS, {
|
|
2586
|
+
datasetSize: a,
|
|
2550
2587
|
selectionSize: d
|
|
2551
2588
|
}).useWorker) {
|
|
2552
|
-
const k = new Float64Array(m),
|
|
2553
|
-
|
|
2589
|
+
const k = new Float64Array(m), j = new Float32Array(S);
|
|
2590
|
+
Dr(
|
|
2554
2591
|
this.dataX,
|
|
2555
2592
|
this.dataY,
|
|
2556
|
-
|
|
2593
|
+
p,
|
|
2557
2594
|
k,
|
|
2558
|
-
|
|
2595
|
+
j,
|
|
2559
2596
|
0,
|
|
2560
|
-
|
|
2597
|
+
a - 1,
|
|
2561
2598
|
0,
|
|
2562
2599
|
l,
|
|
2563
2600
|
s,
|
|
2564
2601
|
n
|
|
2565
|
-
), this.dataset.source.x = k, this.dataset.source.y =
|
|
2602
|
+
), this.dataset.source.x = k, this.dataset.source.y = j, this._resizeTo(u);
|
|
2566
2603
|
return;
|
|
2567
2604
|
}
|
|
2568
2605
|
this._pendingExecutionMode = "worker";
|
|
2569
|
-
const T = navigator.hardwareConcurrency || 1, L = Math.ceil(
|
|
2570
|
-
let
|
|
2606
|
+
const T = navigator.hardwareConcurrency || 1, L = Math.ceil(a / T), R = [];
|
|
2607
|
+
let U = 0;
|
|
2571
2608
|
for (let k = 0; k < T; k++) {
|
|
2572
|
-
const
|
|
2573
|
-
let
|
|
2574
|
-
for (;
|
|
2575
|
-
|
|
2576
|
-
|
|
2609
|
+
const j = k * L, P = Math.min((k + 1) * L - 1, a - 1), Y = [];
|
|
2610
|
+
let re = 0;
|
|
2611
|
+
for (; U < p.length && p[U][0] <= P; )
|
|
2612
|
+
Y.push(p[U]), re += g[U], U++;
|
|
2613
|
+
R.push({ start: j, end: P, gapsSegment: Y, fillsInSegment: re });
|
|
2577
2614
|
}
|
|
2578
|
-
const
|
|
2615
|
+
const pe = new Array(T).fill(0);
|
|
2579
2616
|
for (let k = 1; k < T; k++)
|
|
2580
|
-
|
|
2581
|
-
const Pe = [],
|
|
2617
|
+
pe[k] = pe[k - 1] + R[k - 1].fillsInSegment;
|
|
2618
|
+
const Pe = [], Ne = [];
|
|
2582
2619
|
for (let k = 0; k < T; k++) {
|
|
2583
|
-
const { start:
|
|
2584
|
-
|
|
2585
|
-
new Promise((
|
|
2586
|
-
const
|
|
2587
|
-
Pe.push(
|
|
2620
|
+
const { start: j, end: P, gapsSegment: Y } = R[k], re = j + pe[k];
|
|
2621
|
+
Ne.push(
|
|
2622
|
+
new Promise((Nt) => {
|
|
2623
|
+
const ye = new Sr();
|
|
2624
|
+
Pe.push(ye), ye.postMessage({
|
|
2588
2625
|
bufferX: this.dataX.buffer,
|
|
2589
2626
|
bufferY: this.dataY.buffer,
|
|
2590
2627
|
outputBufferX: m,
|
|
2591
2628
|
outputBufferY: S,
|
|
2592
|
-
start:
|
|
2629
|
+
start: j,
|
|
2593
2630
|
end: P,
|
|
2594
|
-
gapsSegment:
|
|
2595
|
-
startTarget:
|
|
2631
|
+
gapsSegment: Y,
|
|
2632
|
+
startTarget: re,
|
|
2596
2633
|
fillDelta: l,
|
|
2597
2634
|
interpolate: s,
|
|
2598
2635
|
fillValue: n
|
|
2599
|
-
}),
|
|
2600
|
-
|
|
2636
|
+
}), ye.onmessage = (Bt) => {
|
|
2637
|
+
Nt(Bt.data);
|
|
2601
2638
|
};
|
|
2602
2639
|
})
|
|
2603
2640
|
);
|
|
2604
2641
|
}
|
|
2605
|
-
await Promise.all(
|
|
2642
|
+
await Promise.all(Ne), Pe.forEach((k) => k.terminate()), this.dataset.source.x = new Float64Array(m), this.dataset.source.y = new Float32Array(S), this._resizeTo(u);
|
|
2643
|
+
}
|
|
2644
|
+
/**
|
|
2645
|
+
* Dispatch wrapper around `_deleteDataPoints` — reads target
|
|
2646
|
+
* indices from `history[length - 2].selected`. Internal callers
|
|
2647
|
+
* (`_shift`, `_assignDatetimesBulk`'s delete + add chain) keep
|
|
2648
|
+
* using `_deleteDataPoints` directly with locally-computed
|
|
2649
|
+
* indices; only the external dispatch path goes through here.
|
|
2650
|
+
*/
|
|
2651
|
+
async _deleteDataPointsFromSelection() {
|
|
2652
|
+
const t = this.history[this.history.length - 2]?.selected;
|
|
2653
|
+
if (!(!t || t.length === 0))
|
|
2654
|
+
return this._deleteDataPoints(t);
|
|
2606
2655
|
}
|
|
2607
2656
|
/**
|
|
2608
2657
|
Deletes data points from a large array using worker threads.
|
|
@@ -2610,70 +2659,88 @@ class Es {
|
|
|
2610
2659
|
2. For each segment, binary search locates the indexes to delete (deleteSegment), ensuring efficient lookups.
|
|
2611
2660
|
3. The cumulative deletions before each segment help compute the starting index (startTarget) for each worker's output, ensuring no overlap.
|
|
2612
2661
|
4. Each worker processes its segment linearly, skipping deletions and copying kept elements to their computed positions.
|
|
2613
|
-
* @param deleteIndices
|
|
2662
|
+
* @param deleteIndices
|
|
2614
2663
|
*/
|
|
2615
2664
|
async _deleteDataPoints(t) {
|
|
2616
2665
|
const r = this.dataX.length, s = r - t.length;
|
|
2617
|
-
if (!
|
|
2666
|
+
if (!D(E.DELETE_POINTS, {
|
|
2618
2667
|
datasetSize: r,
|
|
2619
2668
|
selectionSize: t.length
|
|
2620
2669
|
}).useWorker) {
|
|
2621
|
-
const
|
|
2670
|
+
const g = M(
|
|
2622
2671
|
this.dataX.buffer.byteLength,
|
|
2623
2672
|
this.dataX.buffer.maxByteLength
|
|
2624
|
-
), d =
|
|
2673
|
+
), d = M(
|
|
2625
2674
|
this.dataY.buffer.byteLength,
|
|
2626
2675
|
this.dataY.buffer.maxByteLength
|
|
2627
|
-
),
|
|
2676
|
+
), u = new Float64Array(g), w = new Float32Array(d);
|
|
2628
2677
|
Cr(
|
|
2629
2678
|
this.dataX,
|
|
2630
2679
|
this.dataY,
|
|
2631
2680
|
t,
|
|
2632
|
-
|
|
2633
|
-
|
|
2681
|
+
u,
|
|
2682
|
+
w,
|
|
2634
2683
|
0,
|
|
2635
2684
|
r - 1,
|
|
2636
2685
|
0
|
|
2637
|
-
), this.dataset.source.x =
|
|
2686
|
+
), this.dataset.source.x = u, this.dataset.source.y = w, this._resizeTo(s);
|
|
2638
2687
|
return;
|
|
2639
2688
|
}
|
|
2640
2689
|
this._pendingExecutionMode = "worker";
|
|
2641
|
-
const
|
|
2642
|
-
for (let
|
|
2643
|
-
const d =
|
|
2644
|
-
l.push({ start: d, end:
|
|
2645
|
-
}
|
|
2646
|
-
const f = new Array(
|
|
2647
|
-
for (let
|
|
2648
|
-
f[
|
|
2649
|
-
const
|
|
2690
|
+
const o = navigator.hardwareConcurrency || 1, a = Math.ceil(this.dataX.length / o), i = [], l = [];
|
|
2691
|
+
for (let g = 0; g < o; g++) {
|
|
2692
|
+
const d = g * a, u = Math.min((g + 1) * a - 1, this.dataX.length - 1), w = X(t, d), b = Q(t, u), m = t.slice(w, b + 1);
|
|
2693
|
+
l.push({ start: d, end: u, deleteSegment: m });
|
|
2694
|
+
}
|
|
2695
|
+
const f = new Array(o).fill(0);
|
|
2696
|
+
for (let g = 1; g < o; g++)
|
|
2697
|
+
f[g] = f[g - 1] + l[g - 1].deleteSegment.length;
|
|
2698
|
+
const h = [], y = M(
|
|
2650
2699
|
this.dataX.buffer.byteLength,
|
|
2651
2700
|
this.dataX.buffer.maxByteLength
|
|
2652
|
-
),
|
|
2701
|
+
), p = M(
|
|
2653
2702
|
this.dataY.buffer.byteLength,
|
|
2654
2703
|
this.dataY.buffer.maxByteLength
|
|
2655
2704
|
);
|
|
2656
|
-
for (let
|
|
2657
|
-
const { start: d, end:
|
|
2658
|
-
|
|
2705
|
+
for (let g = 0; g < o; g++) {
|
|
2706
|
+
const { start: d, end: u, deleteSegment: w } = l[g], b = d - f[g];
|
|
2707
|
+
h.push(
|
|
2659
2708
|
new Promise((m) => {
|
|
2660
|
-
const S = new
|
|
2709
|
+
const S = new br();
|
|
2661
2710
|
i.push(S), S.postMessage({
|
|
2662
2711
|
bufferX: this.dataX.buffer,
|
|
2663
2712
|
bufferY: this.dataY.buffer,
|
|
2664
|
-
outputBufferX:
|
|
2665
|
-
outputBufferY:
|
|
2713
|
+
outputBufferX: y,
|
|
2714
|
+
outputBufferY: p,
|
|
2666
2715
|
start: d,
|
|
2667
|
-
end:
|
|
2668
|
-
deleteSegment:
|
|
2669
|
-
startTarget:
|
|
2670
|
-
}), S.onmessage = (
|
|
2671
|
-
m(
|
|
2716
|
+
end: u,
|
|
2717
|
+
deleteSegment: w,
|
|
2718
|
+
startTarget: b
|
|
2719
|
+
}), S.onmessage = (v) => {
|
|
2720
|
+
m(v.data);
|
|
2672
2721
|
};
|
|
2673
2722
|
})
|
|
2674
2723
|
);
|
|
2675
2724
|
}
|
|
2676
|
-
await Promise.all(
|
|
2725
|
+
await Promise.all(h), i.forEach((g) => g.terminate()), this.dataset.source.x = new Float64Array(y), this.dataset.source.y = new Float32Array(p), this._resizeTo(s);
|
|
2726
|
+
}
|
|
2727
|
+
/**
|
|
2728
|
+
* Dispatch wrapper around `_driftCorrection` — reads target
|
|
2729
|
+
* indices from `history[length - 2].selected`, partitions them
|
|
2730
|
+
* into consecutive groups, and applies the same `value` drift to
|
|
2731
|
+
* each group as one logged operation. The internal
|
|
2732
|
+
* `_driftCorrection` retains its per-range `[start, end, value]`
|
|
2733
|
+
* signature so future callers that need distinct per-range values
|
|
2734
|
+
* can still use it directly.
|
|
2735
|
+
*/
|
|
2736
|
+
async _driftCorrectionFromSelection(t) {
|
|
2737
|
+
const r = this.history[this.history.length - 2]?.selected;
|
|
2738
|
+
if (!r || r.length === 0) return;
|
|
2739
|
+
const s = this._getConsecutiveGroups(r), n = [];
|
|
2740
|
+
for (const o of s)
|
|
2741
|
+
o.length !== 0 && n.push([o[0], o[o.length - 1], t]);
|
|
2742
|
+
if (n.length !== 0)
|
|
2743
|
+
return this._driftCorrection(n);
|
|
2677
2744
|
}
|
|
2678
2745
|
/**
|
|
2679
2746
|
*
|
|
@@ -2692,52 +2759,52 @@ class Es {
|
|
|
2692
2759
|
if (!t || t.length === 0) return;
|
|
2693
2760
|
const r = this.dataset.source.x, s = navigator.hardwareConcurrency || 1;
|
|
2694
2761
|
let n = 0;
|
|
2695
|
-
for (const [
|
|
2696
|
-
|
|
2697
|
-
if (!
|
|
2762
|
+
for (const [y, p] of t)
|
|
2763
|
+
p > y && (n += p - y);
|
|
2764
|
+
if (!D(E.DRIFT_CORRECTION, {
|
|
2698
2765
|
datasetSize: r.length,
|
|
2699
2766
|
selectionSize: n
|
|
2700
2767
|
}).useWorker) {
|
|
2701
|
-
|
|
2768
|
+
Nr(r, this.dataY, t);
|
|
2702
2769
|
return;
|
|
2703
2770
|
}
|
|
2704
2771
|
this._pendingExecutionMode = "worker";
|
|
2705
|
-
const
|
|
2706
|
-
for (const [p, g
|
|
2707
|
-
if (
|
|
2708
|
-
const d = r[
|
|
2709
|
-
if (
|
|
2710
|
-
const
|
|
2711
|
-
for (let m =
|
|
2712
|
-
|
|
2772
|
+
const a = [];
|
|
2773
|
+
for (const [y, p, g] of t) {
|
|
2774
|
+
if (p <= y) continue;
|
|
2775
|
+
const d = r[y], u = r[p] - d;
|
|
2776
|
+
if (u === 0) continue;
|
|
2777
|
+
const w = p - y, b = Math.max(1, Math.ceil(w / s));
|
|
2778
|
+
for (let m = y; m < p; m += b)
|
|
2779
|
+
a.push({
|
|
2713
2780
|
chunkStart: m,
|
|
2714
|
-
chunkEnd: Math.min(m +
|
|
2781
|
+
chunkEnd: Math.min(m + b, p),
|
|
2715
2782
|
startDatetime: d,
|
|
2716
|
-
value:
|
|
2717
|
-
extent:
|
|
2783
|
+
value: g,
|
|
2784
|
+
extent: u
|
|
2718
2785
|
});
|
|
2719
2786
|
}
|
|
2720
|
-
if (
|
|
2721
|
-
const i = Math.min(s,
|
|
2787
|
+
if (a.length === 0) return;
|
|
2788
|
+
const i = Math.min(s, a.length), l = Array.from(
|
|
2722
2789
|
{ length: i },
|
|
2723
2790
|
() => []
|
|
2724
2791
|
);
|
|
2725
|
-
|
|
2726
|
-
const f = [],
|
|
2727
|
-
for (const
|
|
2728
|
-
|
|
2729
|
-
new Promise((
|
|
2730
|
-
const
|
|
2731
|
-
f.push(
|
|
2792
|
+
a.forEach((y, p) => l[p % i].push(y));
|
|
2793
|
+
const f = [], h = [];
|
|
2794
|
+
for (const y of l)
|
|
2795
|
+
y.length !== 0 && h.push(
|
|
2796
|
+
new Promise((p) => {
|
|
2797
|
+
const g = new vr();
|
|
2798
|
+
f.push(g), g.postMessage({
|
|
2732
2799
|
bufferX: this.dataX.buffer,
|
|
2733
2800
|
bufferY: this.dataY.buffer,
|
|
2734
|
-
jobs:
|
|
2735
|
-
}),
|
|
2736
|
-
|
|
2801
|
+
jobs: y
|
|
2802
|
+
}), g.onmessage = (d) => {
|
|
2803
|
+
p(d.data);
|
|
2737
2804
|
};
|
|
2738
2805
|
})
|
|
2739
2806
|
);
|
|
2740
|
-
await Promise.all(
|
|
2807
|
+
await Promise.all(h), f.forEach((y) => y.terminate());
|
|
2741
2808
|
}
|
|
2742
2809
|
/** Traverses the index array and returns groups of consecutive values.
|
|
2743
2810
|
* i.e.: `[0, 1, 3, 4, 6] => [[0, 1], [3, 4], [6]]`
|
|
@@ -2747,8 +2814,8 @@ class Es {
|
|
|
2747
2814
|
_getConsecutiveGroups(t) {
|
|
2748
2815
|
const r = [[]];
|
|
2749
2816
|
return t.reduce((s, n) => {
|
|
2750
|
-
const
|
|
2751
|
-
return !
|
|
2817
|
+
const o = s[s.length - 1];
|
|
2818
|
+
return !o.length || n == o[o.length - 1] + 1 ? o.push(n) : s.push([n]), s;
|
|
2752
2819
|
}, r), r;
|
|
2753
2820
|
}
|
|
2754
2821
|
/**
|
|
@@ -2761,59 +2828,59 @@ class Es {
|
|
|
2761
2828
|
async _addDataPoints(t) {
|
|
2762
2829
|
if (t.length === 0) return;
|
|
2763
2830
|
const r = this.dataX.length, s = r + t.length;
|
|
2764
|
-
t.sort((d,
|
|
2765
|
-
const n = s * Float64Array.BYTES_PER_ELEMENT,
|
|
2831
|
+
t.sort((d, u) => d[0] - u[0]);
|
|
2832
|
+
const n = s * Float64Array.BYTES_PER_ELEMENT, o = s * Float32Array.BYTES_PER_ELEMENT, a = M(
|
|
2766
2833
|
n,
|
|
2767
2834
|
Math.max(this.dataX.buffer.maxByteLength, n)
|
|
2768
|
-
), i =
|
|
2769
|
-
|
|
2770
|
-
Math.max(this.dataY.buffer.maxByteLength,
|
|
2835
|
+
), i = M(
|
|
2836
|
+
o,
|
|
2837
|
+
Math.max(this.dataY.buffer.maxByteLength, o)
|
|
2771
2838
|
);
|
|
2772
|
-
if (!
|
|
2839
|
+
if (!D(E.ADD_POINTS, {
|
|
2773
2840
|
datasetSize: r,
|
|
2774
2841
|
selectionSize: t.length
|
|
2775
2842
|
}).useWorker) {
|
|
2776
|
-
const d = new Float64Array(
|
|
2777
|
-
|
|
2843
|
+
const d = new Float64Array(a), u = new Float32Array(i);
|
|
2844
|
+
Fr(
|
|
2778
2845
|
this.dataX,
|
|
2779
2846
|
this.dataY,
|
|
2780
2847
|
t,
|
|
2781
2848
|
d,
|
|
2782
|
-
|
|
2849
|
+
u,
|
|
2783
2850
|
0,
|
|
2784
2851
|
r,
|
|
2785
2852
|
0
|
|
2786
|
-
), this.dataset.source.x = d, this.dataset.source.y =
|
|
2853
|
+
), this.dataset.source.x = d, this.dataset.source.y = u, this._resizeTo(s);
|
|
2787
2854
|
return;
|
|
2788
2855
|
}
|
|
2789
2856
|
this._pendingExecutionMode = "worker";
|
|
2790
2857
|
const f = t.map(
|
|
2791
|
-
(d) =>
|
|
2792
|
-
),
|
|
2858
|
+
(d) => Q(this.dataX, d[0]) + 1
|
|
2859
|
+
), h = Math.max(
|
|
2793
2860
|
1,
|
|
2794
2861
|
Math.min(navigator.hardwareConcurrency || 1, Math.max(r, 1))
|
|
2795
|
-
),
|
|
2796
|
-
for (let d = 0; d <
|
|
2797
|
-
const
|
|
2798
|
-
|
|
2862
|
+
), y = Math.ceil(Math.max(r, 1) / h), p = [], g = [];
|
|
2863
|
+
for (let d = 0; d < h; d++) {
|
|
2864
|
+
const u = d * y, w = Math.min((d + 1) * y, r), b = X(f, u), m = d === h - 1 ? t.length : X(f, w), S = t.slice(b, m), v = u + b;
|
|
2865
|
+
u >= w && S.length === 0 || g.push(
|
|
2799
2866
|
new Promise((T) => {
|
|
2800
2867
|
const L = new kr();
|
|
2801
|
-
|
|
2868
|
+
p.push(L), L.postMessage({
|
|
2802
2869
|
bufferX: this.dataX.buffer,
|
|
2803
2870
|
bufferY: this.dataY.buffer,
|
|
2804
|
-
outputBufferX:
|
|
2871
|
+
outputBufferX: a,
|
|
2805
2872
|
outputBufferY: i,
|
|
2806
|
-
origStart:
|
|
2807
|
-
origEnd:
|
|
2873
|
+
origStart: u,
|
|
2874
|
+
origEnd: w,
|
|
2808
2875
|
insertions: S,
|
|
2809
|
-
outStart:
|
|
2810
|
-
}), L.onmessage = (
|
|
2811
|
-
T(
|
|
2876
|
+
outStart: v
|
|
2877
|
+
}), L.onmessage = (R) => {
|
|
2878
|
+
T(R.data);
|
|
2812
2879
|
};
|
|
2813
2880
|
})
|
|
2814
2881
|
);
|
|
2815
2882
|
}
|
|
2816
|
-
await Promise.all(
|
|
2883
|
+
await Promise.all(g), p.forEach((d) => d.terminate()), this.dataset.source.x = new Float64Array(a), this.dataset.source.y = new Float32Array(i), this._resizeTo(s);
|
|
2817
2884
|
}
|
|
2818
2885
|
// =======================
|
|
2819
2886
|
// FILTER OPERATIONS
|
|
@@ -2835,43 +2902,43 @@ class Es {
|
|
|
2835
2902
|
const r = Object.keys(t);
|
|
2836
2903
|
if (r.length === 0) return [];
|
|
2837
2904
|
const s = {
|
|
2838
|
-
[
|
|
2839
|
-
[
|
|
2840
|
-
[
|
|
2841
|
-
[
|
|
2842
|
-
[
|
|
2843
|
-
}, n = r.map((
|
|
2905
|
+
[K.LT]: 0,
|
|
2906
|
+
[K.LTE]: 1,
|
|
2907
|
+
[K.GT]: 2,
|
|
2908
|
+
[K.GTE]: 3,
|
|
2909
|
+
[K.E]: 4
|
|
2910
|
+
}, n = r.map((u) => s[u] ?? 4), o = r.map((u) => t[u]), a = this.dataset.source.y, i = a.length;
|
|
2844
2911
|
if (i === 0) return [];
|
|
2845
|
-
if (!
|
|
2912
|
+
if (!D(A.VALUE_THRESHOLD, {
|
|
2846
2913
|
datasetSize: i
|
|
2847
2914
|
}).useWorker)
|
|
2848
|
-
return Pt(
|
|
2915
|
+
return Pt(a, 0, i, n, o);
|
|
2849
2916
|
this._pendingExecutionMode = "worker";
|
|
2850
|
-
const f = Math.min(navigator.hardwareConcurrency || 1, i),
|
|
2851
|
-
for (let
|
|
2852
|
-
const
|
|
2853
|
-
if (
|
|
2854
|
-
|
|
2917
|
+
const f = Math.min(navigator.hardwareConcurrency || 1, i), h = Math.ceil(i / f), y = [], p = [];
|
|
2918
|
+
for (let u = 0; u < f; u++) {
|
|
2919
|
+
const w = u * h, b = Math.min((u + 1) * h, i);
|
|
2920
|
+
if (w >= b) break;
|
|
2921
|
+
p.push(
|
|
2855
2922
|
new Promise((m) => {
|
|
2856
|
-
const S = new
|
|
2857
|
-
|
|
2923
|
+
const S = new Ie();
|
|
2924
|
+
y.push(S), S.postMessage({
|
|
2858
2925
|
bufferY: this.dataY.buffer,
|
|
2859
|
-
start:
|
|
2860
|
-
end:
|
|
2926
|
+
start: w,
|
|
2927
|
+
end: b,
|
|
2861
2928
|
ops: n,
|
|
2862
|
-
values:
|
|
2863
|
-
}), S.onmessage = (
|
|
2864
|
-
m(
|
|
2929
|
+
values: o
|
|
2930
|
+
}), S.onmessage = (v) => {
|
|
2931
|
+
m(v.data);
|
|
2865
2932
|
};
|
|
2866
2933
|
})
|
|
2867
2934
|
);
|
|
2868
2935
|
}
|
|
2869
|
-
const
|
|
2870
|
-
|
|
2936
|
+
const g = await Promise.all(p);
|
|
2937
|
+
y.forEach((u) => u.terminate());
|
|
2871
2938
|
const d = [];
|
|
2872
|
-
for (let
|
|
2873
|
-
const
|
|
2874
|
-
for (let
|
|
2939
|
+
for (let u = 0; u < g.length; u++) {
|
|
2940
|
+
const w = g[u];
|
|
2941
|
+
for (let b = 0; b < w.length; b++) d.push(w[b]);
|
|
2875
2942
|
}
|
|
2876
2943
|
return d;
|
|
2877
2944
|
}
|
|
@@ -2890,39 +2957,39 @@ class Es {
|
|
|
2890
2957
|
async _rateOfChange(t, r) {
|
|
2891
2958
|
const s = this.dataset.source.y;
|
|
2892
2959
|
if (s.length < 2) return [];
|
|
2893
|
-
const n = 1,
|
|
2894
|
-
if (!
|
|
2960
|
+
const n = 1, o = s.length, a = o - n;
|
|
2961
|
+
if (!D(A.RATE_OF_CHANGE, {
|
|
2895
2962
|
datasetSize: s.length
|
|
2896
2963
|
}).useWorker)
|
|
2897
|
-
return
|
|
2964
|
+
return Or(s, n, o, t, r);
|
|
2898
2965
|
this._pendingExecutionMode = "worker";
|
|
2899
|
-
const l = Math.min(navigator.hardwareConcurrency || 1,
|
|
2966
|
+
const l = Math.min(navigator.hardwareConcurrency || 1, a), f = Math.ceil(a / l), h = [], y = [];
|
|
2900
2967
|
for (let d = 0; d < l; d++) {
|
|
2901
|
-
const
|
|
2902
|
-
if (
|
|
2903
|
-
|
|
2904
|
-
new Promise((
|
|
2905
|
-
const m = new
|
|
2906
|
-
|
|
2968
|
+
const u = n + d * f, w = Math.min(n + (d + 1) * f, o);
|
|
2969
|
+
if (u >= w) break;
|
|
2970
|
+
y.push(
|
|
2971
|
+
new Promise((b) => {
|
|
2972
|
+
const m = new $r();
|
|
2973
|
+
h.push(m), m.postMessage({
|
|
2907
2974
|
bufferY: this.dataY.buffer,
|
|
2908
|
-
start:
|
|
2909
|
-
end:
|
|
2975
|
+
start: u,
|
|
2976
|
+
end: w,
|
|
2910
2977
|
comparator: t,
|
|
2911
2978
|
value: r
|
|
2912
2979
|
}), m.onmessage = (S) => {
|
|
2913
|
-
|
|
2980
|
+
b(S.data);
|
|
2914
2981
|
};
|
|
2915
2982
|
})
|
|
2916
2983
|
);
|
|
2917
2984
|
}
|
|
2918
|
-
const
|
|
2919
|
-
|
|
2920
|
-
const
|
|
2921
|
-
for (let d = 0; d <
|
|
2922
|
-
const
|
|
2923
|
-
for (let
|
|
2985
|
+
const p = await Promise.all(y);
|
|
2986
|
+
h.forEach((d) => d.terminate());
|
|
2987
|
+
const g = [];
|
|
2988
|
+
for (let d = 0; d < p.length; d++) {
|
|
2989
|
+
const u = p[d];
|
|
2990
|
+
for (let w = 0; w < u.length; w++) g.push(u[w]);
|
|
2924
2991
|
}
|
|
2925
|
-
return
|
|
2992
|
+
return g;
|
|
2926
2993
|
}
|
|
2927
2994
|
/**
|
|
2928
2995
|
* Select all points whose datetime falls inside `[from, to]` (inclusive).
|
|
@@ -2933,18 +3000,40 @@ class Es {
|
|
|
2933
3000
|
async _datetimeRange(t, r) {
|
|
2934
3001
|
const s = this.dataset.source.x, n = s.length;
|
|
2935
3002
|
if (n === 0) return [];
|
|
2936
|
-
const
|
|
2937
|
-
if (
|
|
2938
|
-
const i = new Array(
|
|
2939
|
-
for (let l =
|
|
3003
|
+
const o = t == null ? 0 : X(s, t), a = r == null ? n - 1 : Q(s, r);
|
|
3004
|
+
if (o > a) return [];
|
|
3005
|
+
const i = new Array(a - o + 1);
|
|
3006
|
+
for (let l = o; l <= a; l++) i[l - o] = l;
|
|
2940
3007
|
return i;
|
|
2941
3008
|
}
|
|
2942
3009
|
/**
|
|
2943
|
-
*
|
|
2944
|
-
*
|
|
3010
|
+
* SELECTION filter handler — also acts as the cleanup site for the
|
|
3011
|
+
* SELECTION-vs-preceding-filter interaction. `dispatchFilter` always
|
|
3012
|
+
* pushes (never replaces) a SELECTION when the previous entry is a
|
|
3013
|
+
* non-SELECTION filter; this method then decides what to keep based
|
|
3014
|
+
* on what the SELECTION's indices look like relative to the filter:
|
|
3015
|
+
*
|
|
3016
|
+
* | incoming SELECTION | preceding non-SEL filter | result |
|
|
3017
|
+
* | -------------------------- | -------------------------- | ------------------------------------- |
|
|
3018
|
+
* | empty | had non-empty `selected` | pop both — user cleared the filter |
|
|
3019
|
+
* | empty | had empty `selected` | pop SELECTION — no-op echo on a |
|
|
3020
|
+
* | | | zero-result filter, keep filter |
|
|
3021
|
+
* | empty | none / non-filter prev | pop SELECTION (clear) |
|
|
3022
|
+
* | non-empty matches prev | (any filter) | pop SELECTION — Plotly relayout echo |
|
|
3023
|
+
* | | | of the filter's `selected` |
|
|
3024
|
+
* | non-empty differs from prev| (any filter) | splice prev — user override takes |
|
|
3025
|
+
* | | | ownership; SELECTION stands alone |
|
|
3026
|
+
* | non-empty (other cases) | n/a | keep as-is (already pushed) |
|
|
3027
|
+
*
|
|
3028
|
+
* The "Plotly echo" case exists because consumers commonly chain
|
|
3029
|
+
* `dispatchFilter(SOMETHING)` with `dispatchSelection(result)` for
|
|
3030
|
+
* visual highlighting; Plotly's debounced relayout listener then
|
|
3031
|
+
* fires a SELECTION carrying the same indices. Without this dedup
|
|
3032
|
+
* the script would grow a phantom SELECTION after every real filter.
|
|
2945
3033
|
*/
|
|
2946
3034
|
async _selection(t) {
|
|
2947
|
-
|
|
3035
|
+
const r = this.history[this.history.length - 2], s = !!r && r.method !== A.SELECTION && !!A[r.method], n = s && Array.isArray(r.selected) ? r.selected : void 0;
|
|
3036
|
+
return !t || !t.length ? (this.history.pop(), n && n.length > 0 && this.history.pop(), t) : (n && qr(n, t) ? this.history.pop() : s && this.history.splice(this.history.length - 2, 1), t);
|
|
2948
3037
|
}
|
|
2949
3038
|
/**
|
|
2950
3039
|
*
|
|
@@ -2961,39 +3050,39 @@ class Es {
|
|
|
2961
3050
|
async _change(t, r) {
|
|
2962
3051
|
const s = this.dataset.source.y;
|
|
2963
3052
|
if (s.length < 2) return [];
|
|
2964
|
-
const n = 1,
|
|
2965
|
-
if (!
|
|
3053
|
+
const n = 1, o = s.length, a = o - n;
|
|
3054
|
+
if (!D(A.CHANGE, {
|
|
2966
3055
|
datasetSize: s.length
|
|
2967
3056
|
}).useWorker)
|
|
2968
|
-
return
|
|
3057
|
+
return Ir(s, n, o, t, r);
|
|
2969
3058
|
this._pendingExecutionMode = "worker";
|
|
2970
|
-
const l = Math.min(navigator.hardwareConcurrency || 1,
|
|
3059
|
+
const l = Math.min(navigator.hardwareConcurrency || 1, a), f = Math.ceil(a / l), h = [], y = [];
|
|
2971
3060
|
for (let d = 0; d < l; d++) {
|
|
2972
|
-
const
|
|
2973
|
-
if (
|
|
2974
|
-
|
|
2975
|
-
new Promise((
|
|
2976
|
-
const m = new
|
|
2977
|
-
|
|
3061
|
+
const u = n + d * f, w = Math.min(n + (d + 1) * f, o);
|
|
3062
|
+
if (u >= w) break;
|
|
3063
|
+
y.push(
|
|
3064
|
+
new Promise((b) => {
|
|
3065
|
+
const m = new Lr();
|
|
3066
|
+
h.push(m), m.postMessage({
|
|
2978
3067
|
bufferY: this.dataY.buffer,
|
|
2979
|
-
start:
|
|
2980
|
-
end:
|
|
3068
|
+
start: u,
|
|
3069
|
+
end: w,
|
|
2981
3070
|
comparator: t,
|
|
2982
3071
|
value: r
|
|
2983
3072
|
}), m.onmessage = (S) => {
|
|
2984
|
-
|
|
3073
|
+
b(S.data);
|
|
2985
3074
|
};
|
|
2986
3075
|
})
|
|
2987
3076
|
);
|
|
2988
3077
|
}
|
|
2989
|
-
const
|
|
2990
|
-
|
|
2991
|
-
const
|
|
2992
|
-
for (let d = 0; d <
|
|
2993
|
-
const
|
|
2994
|
-
for (let
|
|
3078
|
+
const p = await Promise.all(y);
|
|
3079
|
+
h.forEach((d) => d.terminate());
|
|
3080
|
+
const g = [];
|
|
3081
|
+
for (let d = 0; d < p.length; d++) {
|
|
3082
|
+
const u = p[d];
|
|
3083
|
+
for (let w = 0; w < u.length; w++) g.push(u[w]);
|
|
2995
3084
|
}
|
|
2996
|
-
return
|
|
3085
|
+
return g;
|
|
2997
3086
|
}
|
|
2998
3087
|
/**
|
|
2999
3088
|
* Find gaps in the data using worker threads.
|
|
@@ -3002,47 +3091,56 @@ class Es {
|
|
|
3002
3091
|
* 3. Main thread collects all pairs and dedups via Set — identical return shape to the original implementation.
|
|
3003
3092
|
* @param value The time value
|
|
3004
3093
|
* @param unit The time unit (TimeUnit)
|
|
3005
|
-
* @param range If specified,
|
|
3094
|
+
* @param range If specified, gap detection is restricted to this
|
|
3095
|
+
* `[startTs, endTs]` window in epoch milliseconds. Both bounds
|
|
3096
|
+
* are inclusive and snapped to the nearest enclosed point via
|
|
3097
|
+
* binary search. Datetime-addressed (not index-addressed) so the
|
|
3098
|
+
* same call survives data growth and is portable across datasets
|
|
3099
|
+
* for QC script replay.
|
|
3006
3100
|
*/
|
|
3007
3101
|
async _findGaps(t, r, s) {
|
|
3008
3102
|
const n = this.dataset.source.x;
|
|
3009
|
-
let
|
|
3010
|
-
if (s
|
|
3011
|
-
|
|
3012
|
-
|
|
3013
|
-
|
|
3103
|
+
let o = 0, a = n.length;
|
|
3104
|
+
if (s != null) {
|
|
3105
|
+
const [w, b] = s;
|
|
3106
|
+
w != null && Number.isFinite(w) && (o = X(n, w)), b != null && Number.isFinite(b) && (a = Q(n, b) + 1);
|
|
3107
|
+
}
|
|
3108
|
+
if (a <= o) return [];
|
|
3109
|
+
const i = t * ne[r] * 1e3;
|
|
3110
|
+
if (!D(A.FIND_GAPS, {
|
|
3111
|
+
datasetSize: a - o
|
|
3014
3112
|
}).useWorker) {
|
|
3015
|
-
const
|
|
3016
|
-
for (let m = 0; m <
|
|
3017
|
-
return [...
|
|
3113
|
+
const w = Mr(n, o, a - 1, i), b = /* @__PURE__ */ new Set();
|
|
3114
|
+
for (let m = 0; m < w.length; m++) b.add(w[m]);
|
|
3115
|
+
return [...b];
|
|
3018
3116
|
}
|
|
3019
3117
|
this._pendingExecutionMode = "worker";
|
|
3020
|
-
const f =
|
|
3021
|
-
for (let
|
|
3022
|
-
const
|
|
3023
|
-
if (
|
|
3024
|
-
|
|
3118
|
+
const f = a - o, h = Math.min(navigator.hardwareConcurrency || 1, f), y = Math.ceil(f / h), p = [], g = [];
|
|
3119
|
+
for (let w = 0; w < h; w++) {
|
|
3120
|
+
const b = o + w * y, m = Math.min(o + (w + 1) * y, a);
|
|
3121
|
+
if (b >= m) break;
|
|
3122
|
+
g.push(
|
|
3025
3123
|
new Promise((S) => {
|
|
3026
|
-
const
|
|
3027
|
-
|
|
3124
|
+
const v = new Ar();
|
|
3125
|
+
p.push(v), v.postMessage({
|
|
3028
3126
|
bufferX: this.dataX.buffer,
|
|
3029
|
-
start:
|
|
3127
|
+
start: b,
|
|
3030
3128
|
endInclusive: m,
|
|
3031
3129
|
threshold: i
|
|
3032
|
-
}),
|
|
3130
|
+
}), v.onmessage = (T) => {
|
|
3033
3131
|
S(T.data);
|
|
3034
3132
|
};
|
|
3035
3133
|
})
|
|
3036
3134
|
);
|
|
3037
3135
|
}
|
|
3038
|
-
const d = await Promise.all(
|
|
3039
|
-
|
|
3040
|
-
const
|
|
3041
|
-
for (let
|
|
3042
|
-
const
|
|
3043
|
-
for (let m = 0; m <
|
|
3136
|
+
const d = await Promise.all(g);
|
|
3137
|
+
p.forEach((w) => w.terminate());
|
|
3138
|
+
const u = /* @__PURE__ */ new Set();
|
|
3139
|
+
for (let w = 0; w < d.length; w++) {
|
|
3140
|
+
const b = d[w];
|
|
3141
|
+
for (let m = 0; m < b.length; m++) u.add(b[m]);
|
|
3044
3142
|
}
|
|
3045
|
-
return [...
|
|
3143
|
+
return [...u];
|
|
3046
3144
|
}
|
|
3047
3145
|
/**
|
|
3048
3146
|
* Find points where the values are the same at least `times` in a row, using worker threads.
|
|
@@ -3052,127 +3150,226 @@ class Es {
|
|
|
3052
3150
|
*
|
|
3053
3151
|
* Matches the Python reference implementation in `edit_service.py::persistence` — every member of a qualifying run is selected (including the run's first index).
|
|
3054
3152
|
* @param times The minimum run length to qualify
|
|
3055
|
-
* @param range If specified,
|
|
3153
|
+
* @param range If specified, persistence detection is restricted
|
|
3154
|
+
* to this `[startTs, endTs]` window in epoch milliseconds. Both
|
|
3155
|
+
* bounds are inclusive and snapped to the nearest enclosed point
|
|
3156
|
+
* via binary search on `dataX`. Datetime-addressed (not index-
|
|
3157
|
+
* addressed) so the same call survives data growth and is
|
|
3158
|
+
* portable across datasets for QC script replay.
|
|
3056
3159
|
*/
|
|
3057
3160
|
async _persistence(t, r) {
|
|
3058
|
-
const s = this.dataset.source.y;
|
|
3059
|
-
let
|
|
3060
|
-
if (r
|
|
3061
|
-
|
|
3062
|
-
|
|
3063
|
-
|
|
3161
|
+
const s = this.dataset.source.x, n = this.dataset.source.y;
|
|
3162
|
+
let o = 0, a = n.length;
|
|
3163
|
+
if (r != null) {
|
|
3164
|
+
const [m, S] = r;
|
|
3165
|
+
m != null && Number.isFinite(m) && (o = X(s, m)), S != null && Number.isFinite(S) && (a = Q(s, S) + 1);
|
|
3166
|
+
}
|
|
3167
|
+
if (a <= o) return [];
|
|
3168
|
+
const i = a - o;
|
|
3169
|
+
if (!D(A.PERSISTENCE, {
|
|
3170
|
+
datasetSize: i
|
|
3064
3171
|
}).useWorker) {
|
|
3065
|
-
const
|
|
3066
|
-
for (let
|
|
3067
|
-
const
|
|
3068
|
-
if (
|
|
3069
|
-
for (let
|
|
3172
|
+
const m = Ur(n, o, a), S = [];
|
|
3173
|
+
for (let v = 0; v < m.length; v += 3) {
|
|
3174
|
+
const T = m[v], L = m[v + 1];
|
|
3175
|
+
if (L >= t)
|
|
3176
|
+
for (let R = 0; R < L; R++) S.push(T + R);
|
|
3070
3177
|
}
|
|
3071
|
-
return
|
|
3178
|
+
return S;
|
|
3072
3179
|
}
|
|
3073
3180
|
this._pendingExecutionMode = "worker";
|
|
3074
|
-
const
|
|
3075
|
-
for (let
|
|
3076
|
-
const
|
|
3077
|
-
if (
|
|
3181
|
+
const f = Math.min(navigator.hardwareConcurrency || 1, i), h = Math.ceil(i / f), y = [], p = [];
|
|
3182
|
+
for (let m = 0; m < f; m++) {
|
|
3183
|
+
const S = o + m * h, v = Math.min(o + (m + 1) * h, a);
|
|
3184
|
+
if (S >= v) break;
|
|
3078
3185
|
p.push(
|
|
3079
|
-
new Promise((
|
|
3080
|
-
const
|
|
3081
|
-
|
|
3186
|
+
new Promise((T) => {
|
|
3187
|
+
const L = new Tr();
|
|
3188
|
+
y.push(L), L.postMessage({
|
|
3082
3189
|
bufferY: this.dataY.buffer,
|
|
3083
|
-
start:
|
|
3084
|
-
end:
|
|
3085
|
-
}),
|
|
3086
|
-
|
|
3190
|
+
start: S,
|
|
3191
|
+
end: v
|
|
3192
|
+
}), L.onmessage = (R) => {
|
|
3193
|
+
T(R.data);
|
|
3087
3194
|
};
|
|
3088
3195
|
})
|
|
3089
3196
|
);
|
|
3090
3197
|
}
|
|
3091
3198
|
const g = await Promise.all(p);
|
|
3092
|
-
|
|
3093
|
-
const
|
|
3094
|
-
for (let
|
|
3095
|
-
const
|
|
3096
|
-
for (let
|
|
3097
|
-
const
|
|
3098
|
-
|
|
3199
|
+
y.forEach((m) => m.terminate());
|
|
3200
|
+
const d = [], u = [], w = [];
|
|
3201
|
+
for (let m = 0; m < g.length; m++) {
|
|
3202
|
+
const S = g[m];
|
|
3203
|
+
for (let v = 0; v < S.length; v += 3) {
|
|
3204
|
+
const T = S[v], L = S[v + 1], R = S[v + 2], U = d.length - 1;
|
|
3205
|
+
U >= 0 && w[U] === R && d[U] + u[U] === T ? u[U] += L : (d.push(T), u.push(L), w.push(R));
|
|
3099
3206
|
}
|
|
3100
3207
|
}
|
|
3101
3208
|
const b = [];
|
|
3102
|
-
for (let
|
|
3103
|
-
const
|
|
3104
|
-
if (
|
|
3105
|
-
const
|
|
3106
|
-
for (let
|
|
3209
|
+
for (let m = 0; m < d.length; m++) {
|
|
3210
|
+
const S = u[m];
|
|
3211
|
+
if (S >= t) {
|
|
3212
|
+
const v = d[m];
|
|
3213
|
+
for (let T = 0; T < S; T++) b.push(v + T);
|
|
3107
3214
|
}
|
|
3108
3215
|
}
|
|
3109
3216
|
return b;
|
|
3110
3217
|
}
|
|
3111
3218
|
}
|
|
3219
|
+
const le = "1", Qr = /* @__PURE__ */ new Set([
|
|
3220
|
+
...Object.values(E),
|
|
3221
|
+
...Object.values(A)
|
|
3222
|
+
]);
|
|
3223
|
+
function Ts(e, t) {
|
|
3224
|
+
const r = e.history.map((s) => {
|
|
3225
|
+
const n = {
|
|
3226
|
+
method: s.method,
|
|
3227
|
+
args: s.args ? [...s.args] : []
|
|
3228
|
+
};
|
|
3229
|
+
return s.status === "failed" && (n.status = "failed"), n;
|
|
3230
|
+
});
|
|
3231
|
+
return {
|
|
3232
|
+
version: le,
|
|
3233
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
3234
|
+
window: {
|
|
3235
|
+
startDate: t.startDate,
|
|
3236
|
+
endDate: t.endDate
|
|
3237
|
+
},
|
|
3238
|
+
operations: r
|
|
3239
|
+
};
|
|
3240
|
+
}
|
|
3241
|
+
function Ls(e) {
|
|
3242
|
+
if (!e || typeof e != "object")
|
|
3243
|
+
throw new Error("QC script must be a JSON object.");
|
|
3244
|
+
const t = e;
|
|
3245
|
+
if (t.version !== le)
|
|
3246
|
+
throw new Error(
|
|
3247
|
+
`Unsupported QC script version: ${String(t.version)}. This loader understands version "${le}".`
|
|
3248
|
+
);
|
|
3249
|
+
if (typeof t.createdAt != "string")
|
|
3250
|
+
throw new Error("QC script is missing `createdAt` (ISO-8601 string).");
|
|
3251
|
+
const r = t.window;
|
|
3252
|
+
if (!r || typeof r != "object")
|
|
3253
|
+
throw new Error("QC script is missing `window`.");
|
|
3254
|
+
if (typeof r.startDate != "string" || typeof r.endDate != "string")
|
|
3255
|
+
throw new Error("`window.startDate` and `window.endDate` must be ISO-8601 strings.");
|
|
3256
|
+
if (!Array.isArray(t.operations))
|
|
3257
|
+
throw new Error("QC script `operations` must be an array.");
|
|
3258
|
+
const s = t.operations.map((n, o) => {
|
|
3259
|
+
if (!n || typeof n != "object")
|
|
3260
|
+
throw new Error(`Operation ${o} must be an object.`);
|
|
3261
|
+
const a = n;
|
|
3262
|
+
if (typeof a.method != "string")
|
|
3263
|
+
throw new Error(`Operation ${o} missing string \`method\`.`);
|
|
3264
|
+
if (!Qr.has(a.method))
|
|
3265
|
+
throw new Error(`Operation ${o} has unknown method: "${a.method}".`);
|
|
3266
|
+
if (!Array.isArray(a.args))
|
|
3267
|
+
throw new Error(`Operation ${o} \`args\` must be an array.`);
|
|
3268
|
+
const i = {
|
|
3269
|
+
method: a.method,
|
|
3270
|
+
args: [...a.args]
|
|
3271
|
+
};
|
|
3272
|
+
return a.status === "failed" && (i.status = "failed"), i;
|
|
3273
|
+
});
|
|
3274
|
+
return {
|
|
3275
|
+
version: le,
|
|
3276
|
+
createdAt: t.createdAt,
|
|
3277
|
+
window: {
|
|
3278
|
+
startDate: r.startDate,
|
|
3279
|
+
endDate: r.endDate
|
|
3280
|
+
},
|
|
3281
|
+
operations: s
|
|
3282
|
+
};
|
|
3283
|
+
}
|
|
3284
|
+
async function $s(e, t) {
|
|
3285
|
+
e.history.length = 0, e.redoStack.length = 0, await e.reload();
|
|
3286
|
+
const r = { applied: 0, failed: [] };
|
|
3287
|
+
for (let s = 0; s < t.operations.length; s++) {
|
|
3288
|
+
const n = t.operations[s];
|
|
3289
|
+
try {
|
|
3290
|
+
await e.dispatch(n.method, ...n.args), e.history[e.history.length - 1]?.status === "failed" ? r.failed.push({
|
|
3291
|
+
index: s,
|
|
3292
|
+
method: n.method,
|
|
3293
|
+
error: "Operation handler reported failure (see console)."
|
|
3294
|
+
}) : r.applied++;
|
|
3295
|
+
} catch (o) {
|
|
3296
|
+
r.failed.push({
|
|
3297
|
+
index: s,
|
|
3298
|
+
method: n.method,
|
|
3299
|
+
error: o instanceof Error ? o.message : String(o)
|
|
3300
|
+
});
|
|
3301
|
+
}
|
|
3302
|
+
}
|
|
3303
|
+
return r;
|
|
3304
|
+
}
|
|
3112
3305
|
export {
|
|
3113
3306
|
C as ACCOUNT_BASE,
|
|
3114
3307
|
Ue as AUTH_BASE,
|
|
3115
|
-
|
|
3116
|
-
|
|
3117
|
-
|
|
3118
|
-
|
|
3119
|
-
|
|
3120
|
-
|
|
3308
|
+
ls as ApiKey,
|
|
3309
|
+
F as BASE_URL,
|
|
3310
|
+
hs as Collaborator,
|
|
3311
|
+
St as DEFAULT_SNACK_DURATION,
|
|
3312
|
+
fs as DataSource,
|
|
3313
|
+
es as Datastream,
|
|
3121
3314
|
E as EnumEditOperations,
|
|
3122
|
-
|
|
3123
|
-
|
|
3124
|
-
|
|
3125
|
-
|
|
3315
|
+
A as EnumFilterOperations,
|
|
3316
|
+
K as FilterOperation,
|
|
3317
|
+
Yt as HydroShareArchive,
|
|
3318
|
+
te as INCREASE_AMOUNT,
|
|
3126
3319
|
Gt as Location,
|
|
3127
|
-
|
|
3128
|
-
|
|
3129
|
-
|
|
3130
|
-
|
|
3131
|
-
|
|
3132
|
-
|
|
3133
|
-
|
|
3134
|
-
|
|
3135
|
-
|
|
3136
|
-
|
|
3137
|
-
|
|
3138
|
-
|
|
3139
|
-
|
|
3140
|
-
|
|
3141
|
-
|
|
3142
|
-
|
|
3143
|
-
|
|
3144
|
-
|
|
3145
|
-
Et as
|
|
3320
|
+
Wt as LogicalOperation,
|
|
3321
|
+
cs as OAuthProvider,
|
|
3322
|
+
As as ObservationRecord,
|
|
3323
|
+
ss as ObservedProperty,
|
|
3324
|
+
jt as Operator,
|
|
3325
|
+
as as Organization,
|
|
3326
|
+
ce as PROVIDER_BASE,
|
|
3327
|
+
ys as Payload,
|
|
3328
|
+
Ht as PermissionAction,
|
|
3329
|
+
zt as PermissionResource,
|
|
3330
|
+
ar as Position,
|
|
3331
|
+
Kr as PostHydroShareArchive,
|
|
3332
|
+
ns as ProcessingLevel,
|
|
3333
|
+
le as QC_SCRIPT_VERSION,
|
|
3334
|
+
os as ResultQualifier,
|
|
3335
|
+
be as SESSION_BASE,
|
|
3336
|
+
rs as Sensor,
|
|
3337
|
+
ir as Snack,
|
|
3338
|
+
Et as SnackColor,
|
|
3339
|
+
vt as SnackIcon,
|
|
3146
3340
|
kt as SnackTitle,
|
|
3147
|
-
|
|
3148
|
-
|
|
3341
|
+
cr as Snackbar,
|
|
3342
|
+
Qe as TAG_BASE,
|
|
3149
3343
|
_ as THINGS_BASE,
|
|
3150
|
-
|
|
3151
|
-
|
|
3152
|
-
|
|
3153
|
-
|
|
3154
|
-
|
|
3155
|
-
|
|
3344
|
+
Zr as Thing,
|
|
3345
|
+
x as TimeUnit,
|
|
3346
|
+
ts as Unit,
|
|
3347
|
+
is as User,
|
|
3348
|
+
us as Workspace,
|
|
3349
|
+
ps as api,
|
|
3156
3350
|
c as apiMethods,
|
|
3157
|
-
|
|
3158
|
-
|
|
3159
|
-
|
|
3160
|
-
|
|
3161
|
-
|
|
3162
|
-
|
|
3163
|
-
|
|
3164
|
-
|
|
3165
|
-
|
|
3166
|
-
|
|
3167
|
-
|
|
3168
|
-
|
|
3169
|
-
|
|
3170
|
-
|
|
3171
|
-
|
|
3172
|
-
|
|
3173
|
-
|
|
3174
|
-
|
|
3175
|
-
|
|
3176
|
-
|
|
3177
|
-
|
|
3351
|
+
$s as applyScript,
|
|
3352
|
+
ks as clearCalibration,
|
|
3353
|
+
_t as createPatchObject,
|
|
3354
|
+
_s as ensureCalibration,
|
|
3355
|
+
Xt as extractErrorMessage,
|
|
3356
|
+
X as findFirstGreaterOrEqual,
|
|
3357
|
+
Q as findLastLessOrEqual,
|
|
3358
|
+
gs as formatDate,
|
|
3359
|
+
ms as formatDuration,
|
|
3360
|
+
ft as getCSRFToken,
|
|
3361
|
+
Ss as getCalibration,
|
|
3362
|
+
Es as getLastBenchmarkDetail,
|
|
3363
|
+
ds as getObservationsEndpoint,
|
|
3364
|
+
vs as getOperationTable,
|
|
3365
|
+
Ee as measureEllapsedTime,
|
|
3366
|
+
bs as onCalibrationChange,
|
|
3367
|
+
Ls as parseScript,
|
|
3368
|
+
dt as requestInterceptor,
|
|
3369
|
+
pt as responseInterceptor,
|
|
3370
|
+
Yr as runBenchmarks,
|
|
3371
|
+
Ts as serializeHistory,
|
|
3372
|
+
D as shouldUseWorker,
|
|
3373
|
+
ws as subtractHours,
|
|
3374
|
+
ne as timeUnitMultipliers
|
|
3178
3375
|
};
|