@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 CHANGED
@@ -1,5 +1,5 @@
1
- var F = /* @__PURE__ */ ((e) => (e.SECOND = "s", e.MINUTE = "m", e.HOUR = "h", e.DAY = "D", e.WEEK = "W", e.MONTH = "M", e.YEAR = "Y", e))(F || {}), 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 || {}), v = /* @__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))(v || {}), J = /* @__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))(J || {}), Bt = /* @__PURE__ */ ((e) => (e.ADD = "ADD", e.SUB = "SUB", e.MULT = "MULT", e.DIV = "DIV", e.ASSIGN = "ASSIGN", e))(Bt || {}), jt = /* @__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))(jt || {});
2
- class Wt {
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 Vr extends Wt {
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 qr {
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 Jr {
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 Kr {
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 Qr {
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 Zr {
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 es {
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 ts {
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 rs {
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 ss {
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 ns {
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 Yt = /* @__PURE__ */ ((e) => (e.Global = "*", e.View = "view", e.Create = "create", e.Edit = "edit", e.Delete = "delete", e))(Yt || {}), Ht = /* @__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))(Ht || {});
177
- class os {
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 as {
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 is {
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 ht() {
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 ft(e) {
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"] = ht() || "", {
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 zt(e) {
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 dt(e) {
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: zt(r)
272
+ message: Xt(r)
273
273
  };
274
274
  throw console.error("API response not OK:", s.message), s;
275
275
  }
276
- var ve = function(e, t) {
277
- return ve = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(r, s) {
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
- }, ve(e, t);
281
+ }, _e(e, t);
282
282
  };
283
- function ue(e, t) {
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
- ve(e, t);
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 _e(e) {
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 Ae(e, t) {
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, a = [], o;
305
+ var s = r.call(e), n, o = [], a;
306
306
  try {
307
- for (; (t === void 0 || t-- > 0) && !(n = s.next()).done; ) a.push(n.value);
307
+ for (; (t === void 0 || t-- > 0) && !(n = s.next()).done; ) o.push(n.value);
308
308
  } catch (i) {
309
- o = { error: i };
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 (o) throw o.error;
314
+ if (a) throw a.error;
315
315
  }
316
316
  }
317
- return a;
317
+ return o;
318
318
  }
319
- function Te(e, t, r) {
320
- if (r || arguments.length === 2) for (var s = 0, n = t.length, a; s < n; s++)
321
- (a || !(s in t)) && (a || (a = Array.prototype.slice.call(t, 0, s)), a[s] = t[s]);
322
- return e.concat(a || Array.prototype.slice.call(t));
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 N(e) {
324
+ function B(e) {
325
325
  return typeof e == "function";
326
326
  }
327
- function pt(e) {
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 pe = pt(function(e) {
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 Le(e, t) {
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 he = (function() {
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, a;
353
+ var t, r, s, n, o;
354
354
  if (!this.closed) {
355
355
  this.closed = !0;
356
- var o = this._parentage;
357
- if (o)
358
- if (this._parentage = null, Array.isArray(o))
356
+ var a = this._parentage;
357
+ if (a)
358
+ if (this._parentage = null, Array.isArray(a))
359
359
  try {
360
- for (var i = _e(o), l = i.next(); !l.done; l = i.next()) {
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 (h) {
365
- t = { error: h };
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
- o.remove(this);
375
- var u = this.initialTeardown;
376
- if (N(u))
374
+ a.remove(this);
375
+ var h = this.initialTeardown;
376
+ if (B(h))
377
377
  try {
378
- u();
379
- } catch (h) {
380
- a = h instanceof pe ? h.errors : [h];
378
+ h();
379
+ } catch (u) {
380
+ o = u instanceof ge ? u.errors : [u];
381
381
  }
382
- var p = this._finalizers;
383
- if (p) {
382
+ var y = this._finalizers;
383
+ if (y) {
384
384
  this._finalizers = null;
385
385
  try {
386
- for (var g = _e(p), y = g.next(); !y.done; y = g.next()) {
387
- var d = y.value;
386
+ for (var p = Ae(y), g = p.next(); !g.done; g = p.next()) {
387
+ var d = g.value;
388
388
  try {
389
- Ne(d);
390
- } catch (h) {
391
- a = a ?? [], h instanceof pe ? a = Te(Te([], Ae(a)), Ae(h.errors)) : a.push(h);
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 (h) {
395
- s = { error: h };
394
+ } catch (u) {
395
+ s = { error: u };
396
396
  } finally {
397
397
  try {
398
- y && !y.done && (n = g.return) && n.call(g);
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 (a)
405
- throw new pe(a);
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
- Ne(t);
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) && Le(r, t);
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 && Le(r, t), t instanceof e && t._removeParent(this);
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
- })(), yt = he.EMPTY;
437
- function gt(e) {
438
- return e instanceof he || e && "closed" in e && N(e.remove) && N(e.add) && N(e.unsubscribe);
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 Ne(e) {
441
- N(e) ? e() : e.unsubscribe();
440
+ function Be(e) {
441
+ B(e) ? e() : e.unsubscribe();
442
442
  }
443
- var Xt = {
443
+ var Vt = {
444
444
  Promise: void 0
445
- }, Vt = {
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, Te([e, t], Ae(r)));
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 qt(e) {
457
- Vt.setTimeout(function() {
456
+ function Jt(e) {
457
+ qt.setTimeout(function() {
458
458
  throw e;
459
459
  });
460
460
  }
461
- function Be() {
461
+ function je() {
462
462
  }
463
- function ae(e) {
463
+ function ie(e) {
464
464
  e();
465
465
  }
466
- var mt = (function(e) {
467
- ue(t, e);
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, gt(r) && r.add(s)) : s.destination = Qt, s;
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 $e(r, s, n);
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
- })(he), Jt = (function() {
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
- te(s);
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
- te(s);
515
+ se(s);
516
516
  }
517
517
  else
518
- te(t);
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
- te(r);
525
+ se(r);
526
526
  }
527
527
  }, e;
528
- })(), $e = (function(e) {
529
- ue(t, e);
528
+ })(), Re = (function(e) {
529
+ fe(t, e);
530
530
  function t(r, s, n) {
531
- var a = e.call(this) || this, o;
532
- return N(r) || !r ? o = {
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
- } : o = r, a.destination = new Jt(o), a;
536
+ } : a = r, o.destination = new Qt(a), o;
537
537
  }
538
538
  return t;
539
- })(mt);
540
- function te(e) {
541
- qt(e);
539
+ })(wt);
540
+ function se(e) {
541
+ Jt(e);
542
542
  }
543
543
  function Kt(e) {
544
544
  throw e;
545
545
  }
546
- var Qt = {
546
+ var Zt = {
547
547
  closed: !0,
548
- next: Be,
548
+ next: je,
549
549
  error: Kt,
550
- complete: Be
551
- }, Zt = (function() {
550
+ complete: je
551
+ }, er = (function() {
552
552
  return typeof Symbol == "function" && Symbol.observable || "@@observable";
553
553
  })();
554
- function er(e) {
554
+ function tr(e) {
555
555
  return e;
556
556
  }
557
- function tr(e) {
558
- return e.length === 0 ? er : e.length === 1 ? e[0] : function(r) {
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 je = (function() {
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, a = sr(t) ? t : new $e(t, r, s);
573
- return ae(function() {
574
- var o = n, i = o.operator, l = o.source;
575
- a.add(i ? i.call(a, l) : l ? n._subscribe(a) : n._trySubscribe(a));
576
- }), a;
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 = We(r), new r(function(n, a) {
586
- var o = new $e({
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
- a(l), o.unsubscribe();
591
+ o(l), a.unsubscribe();
592
592
  }
593
593
  },
594
- error: a,
594
+ error: o,
595
595
  complete: n
596
596
  });
597
- s.subscribe(o);
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[Zt] = function() {
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 tr(t)(this);
607
+ return rr(t)(this);
608
608
  }, e.prototype.toPromise = function(t) {
609
609
  var r = this;
610
- return t = We(t), new t(function(s, n) {
611
- var a;
612
- r.subscribe(function(o) {
613
- return a = o;
614
- }, function(o) {
615
- return n(o);
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(a);
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 We(e) {
624
+ function Ye(e) {
625
625
  var t;
626
- return (t = e ?? Xt.Promise) !== null && t !== void 0 ? t : Promise;
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 instanceof mt || rr(e) && gt(e);
629
+ return e && B(e.next) && B(e.error) && B(e.complete);
633
630
  }
634
- var nr = pt(function(e) {
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
- }), wt = (function(e) {
639
- ue(t, e);
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 nr();
649
+ throw new or();
650
650
  }, t.prototype.next = function(r) {
651
651
  var s = this;
652
- ae(function() {
653
- var n, a;
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 o = _e(s.currentObservers), i = o.next(); !i.done; i = o.next()) {
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 && (a = o.return) && a.call(o);
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
- ae(function() {
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
- ae(function() {
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, a = n.hasError, o = n.isStopped, i = n.observers;
705
- return a || o ? yt : (this.currentObservers = null, i.push(r), new he(function() {
706
- s.currentObservers = null, Le(i, r);
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, a = s.thrownError, o = s.isStopped;
710
- n ? r.error(a) : o && r.complete();
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 je();
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
- })(je), Ge = (function(e) {
718
- ue(t, e);
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 : yt;
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
- })(wt);
737
- const bt = 3e3;
738
- var St = /* @__PURE__ */ ((e) => (e.Warning = "warning", e.Success = "success", e.Error = "error", e.Info = "info", e))(St || {}), Et = /* @__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))(Et || {}), kt = /* @__PURE__ */ ((e) => (e.Warning = "Warning", e.Success = "Success", e.Error = "Error", e.Info = "Info", e))(kt || {}), or = /* @__PURE__ */ ((e) => (e.Center = "center", e.Left = "left", e.Right = "right", e.Bottom = "bottom", e.Top = "top", e))(or || {});
739
- class ar {
740
- constructor(t = "", r = "info", s = "none", n = "Info", a = bt, o = "center", i = !1) {
741
- this.message = t, this.color = r, this.icon = s, this.title = n, this.timeout = a, this.position = o, this.visible = i;
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 ir {
745
- static subject = new wt();
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 ar(
751
+ new ir(
752
752
  t,
753
- St[r],
754
753
  Et[r],
754
+ vt[r],
755
755
  kt[r],
756
- bt,
756
+ St,
757
757
  "bottom",
758
758
  !0
759
759
  )
@@ -788,24 +788,24 @@ class ir {
788
788
  );
789
789
  }
790
790
  }
791
- function vt(e, t) {
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 = vt(e[s], t[s]);
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 cr(e) {
802
+ function lr(e) {
803
803
  return e && e.__esModule && Object.prototype.hasOwnProperty.call(e, "default") ? e.default : e;
804
804
  }
805
- var ye, Ye;
806
- function lr() {
807
- if (Ye) return ye;
808
- Ye = 1;
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 ye = t, ye;
845
+ return me = t, me;
846
846
  }
847
- var ge, He;
848
- function ur() {
849
- if (He) return ge;
850
- He = 1;
851
- const e = lr();
852
- return ge = (r) => {
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 a = () => {
857
+ const o = () => {
858
858
  n--, s.size > 0 && s.dequeue()();
859
- }, o = async (f, u, ...p) => {
859
+ }, a = async (f, h, ...y) => {
860
860
  n++;
861
- const g = (async () => f(...p))();
862
- u(g);
861
+ const p = (async () => f(...y))();
862
+ h(p);
863
863
  try {
864
- await g;
864
+ await p;
865
865
  } catch {
866
866
  }
867
- a();
868
- }, i = (f, u, ...p) => {
869
- s.enqueue(o.bind(null, f, u, ...p)), (async () => (await Promise.resolve(), n < r && s.size > 0 && s.dequeue()()))();
870
- }, l = (f, ...u) => new Promise((p) => {
871
- i(f, p, ...u);
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
- }, ge;
886
+ }, we;
887
887
  }
888
- var hr = ur();
889
- const fr = /* @__PURE__ */ cr(hr), Y = fr(10), dr = 1e3;
890
- async function X(e, t) {
891
- const r = ft(t);
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 dt(s);
894
+ return await pt(s);
895
895
  } catch (s) {
896
- throw s instanceof TypeError && ir.error("Network error. Please check your connection."), s;
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 Y(() => X(e, t));
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 ? vt(r, t) : t, Object.keys(s.body).length !== 0)
905
- return await Y(() => X(e, s));
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 Y(() => X(e, r));
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 Y(() => X(e, r));
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 Y(() => X(e, r));
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 ?? dr, s = e.includes("?") ? "&" : "?", n = `${e}${s}page_size=${r}&page=1`, a = ft({ method: "GET" }), o = await Y(() => fetch(n, a)), i = Number(o.headers.get("x-total-pages")) || 1, f = [...await dt(o)];
918
- for (let u = 2; u <= i; u++) {
919
- const p = `${e}${s}page_size=${r}&page=${u}`, g = await Y(() => X(p, { method: "GET" }));
920
- f.push(...g);
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
- }, ze = {
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
- }, Xe = {
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
- }, Ve = {
958
+ }, qe = {
959
959
  HydroServer: {
960
960
  type: "HydroServer"
961
961
  }
962
962
  };
963
- class cs {
963
+ class fs {
964
964
  name = "";
965
965
  settings = {
966
966
  type: "SDL",
967
- extractor: JSON.parse(JSON.stringify(ze.local)),
968
- transformer: JSON.parse(JSON.stringify(Xe.CSV)),
969
- loader: JSON.parse(JSON.stringify(Ve.HydroServer)),
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(ze[t])
991
+ JSON.stringify(Xe[t])
992
992
  );
993
993
  }
994
994
  switchTransformer(t) {
995
995
  this.settings.transformer = JSON.parse(
996
- JSON.stringify(Xe[t])
996
+ JSON.stringify(Ve[t])
997
997
  );
998
998
  }
999
999
  switchLoader(t) {
1000
- this.settings.loader = JSON.parse(JSON.stringify(Ve[t]));
1000
+ this.settings.loader = JSON.parse(JSON.stringify(qe[t]));
1001
1001
  }
1002
1002
  }
1003
- function qe(e) {
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 D = "https://lro.hydroserver.org/api", Ue = `${D}/auth`, C = `${Ue}/browser/account`, me = `${Ue}/browser/session`, ie = `${Ue}/browser/provider`, $ = `${D}/data/workspaces`, we = `${D}/data/roles`, R = `${D}/data/datastreams`, j = `${D}/data/sensors`, _ = `${D}/data/things`, Je = `${_}/tags`, V = `${D}/data/orchestration-systems`, x = `${D}/data/data-sources`, H = `${D}/data/observed-properties`, q = `${D}/data/processing-levels`, K = `${D}/data/result-qualifiers`, z = `${D}/data/units`, ls = (e, t, r, s, n) => {
1014
- let a = `${R}/${e}/observations?format=column`;
1015
- return a += `&order_by=phenomenonTime&page_size=${t}`, a += `&phenomenon_time_min=${encodeURIComponent(r)}`, s && (a += `&phenomenon_time_max=${encodeURIComponent(s)}`), n && (a += `&page=${n}`), a;
1016
- }, pr = (e, t, r) => {
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 = ht(), a = document.createElement("form");
1022
- if (a.method = "POST", a.action = `${ie}/redirect`, n) {
1023
- const o = document.createElement("input");
1024
- o.type = "hidden", o.name = "csrfmiddlewaretoken", o.value = n, a.appendChild(o);
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 o in s) {
1026
+ for (const a in s) {
1027
1027
  const i = document.createElement("input");
1028
- i.type = "hidden", i.name = o, i.value = s[o] || "", a.appendChild(i);
1028
+ i.type = "hidden", i.name = a, i.value = s[a] || "", o.appendChild(i);
1029
1029
  }
1030
- document.body.appendChild(a), a.submit();
1031
- }, us = {
1032
- fetchSession: async () => c.fetch(`${me}`),
1033
- login: async (e, t) => c.post(`${me}`, { email: e, password: t }),
1034
- logout: async () => c.delete(`${me}`),
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(`${we}?is_user_role=true`),
1064
- getAPIKeyRoles: async (e) => c.paginatedFetch(`${we}?is_apikey_role=true`),
1065
- getRole: async (e) => c.fetch(`${we}/${e}`),
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(`${ie}/connections`),
1111
- providerRedirect: pr,
1112
- providerSignup: async (e) => c.post(`${ie}/signup`, e),
1113
- deleteProvider: async (e, t) => c.delete(`${ie}/connections`, {
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(`${Je}`),
1153
+ fetchUsersSiteTags: async () => c.fetch(`${Qe}`),
1154
1154
  deleteSiteTag: async (e, t) => c.delete(`${_}/${e}/tags`, t),
1155
- fetchWorkspaceTags: async (e) => c.fetch(`${Je}/keys?workspace_id=${e}`),
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(R, e),
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(`${R}${r}`);
1172
+ return c.paginatedFetch(`${I}${r}`);
1173
1173
  },
1174
- fetchDatastreamsForThing: async (e) => c.paginatedFetch(`${R}?thing_id=${e}`),
1174
+ fetchDatastreamsForThing: async (e) => c.paginatedFetch(`${I}?thing_id=${e}`),
1175
1175
  fetchExpandedDatastreamsForThing: async (e) => c.paginatedFetch(
1176
- `${R}?thing_id=${e}&expand_related=true`
1176
+ `${I}?thing_id=${e}&expand_related=true`
1177
1177
  ),
1178
- fetchDatastreamsForDataSource: async (e) => c.paginatedFetch(`${R}?data_source_id=${e}`),
1179
- fetchDatastream: async (e) => c.fetch(`${R}/${e}`),
1180
- fetchDatastreamExpanded: async (e) => c.fetch(`${R}/${e}?expand_related=true`),
1181
- fetchUsersDatastreams: async () => c.paginatedFetch(`${R}?exclude_unowned=true`),
1182
- updateDatastream: async (e, t = null) => c.patch(`${R}/${e.id}`, e, t),
1183
- deleteDatastream: async (e) => c.delete(`${R}/${e}`),
1184
- downloadDatastreamCSV: async (e) => c.fetch(`${R}/${e}/csv`),
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(q, e),
1192
- fetchProcessingLevels: async () => c.paginatedFetch(`${q}`),
1193
- fetchProcessingLevel: async (e) => c.fetch(`${q}/${e}`),
1194
- fetchWorkspaceProcessingLevels: async (e) => c.paginatedFetch(`${q}?workspace_id=${e}`),
1195
- updateProcessingLevel: async (e, t = null) => c.patch(`${q}/${e.id}`, e, t),
1196
- deleteProcessingLevel: async (e) => c.delete(`${q}/${e}`),
1197
- createSensor: async (e) => c.post(j, e),
1198
- fetchSensors: async () => c.paginatedFetch(`${j}`),
1199
- fetchSensor: async (e) => c.fetch(`${j}/${e}`),
1200
- fetchWorkspaceSensors: async (e) => c.paginatedFetch(`${j}?workspace_id=${e}`),
1201
- updateSensor: async (e, t = null) => c.patch(`${j}/${e.id}`, e, t),
1202
- deleteSensor: async (e) => c.delete(`${j}/${e}`),
1203
- createResultQualifier: async (e) => c.post(K, e),
1204
- fetchResultQualifiers: async () => c.paginatedFetch(`${K}`),
1205
- fetchWorkspaceResultQualifiers: async (e) => c.paginatedFetch(`${K}?workspace_id=${e}`),
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
- `${K}/${e.id}`,
1207
+ `${Z}/${e.id}`,
1208
1208
  e,
1209
1209
  t
1210
1210
  ),
1211
- deleteResultQualifier: async (e) => c.delete(`${K}/${e}`),
1212
- createOrchestrationSystem: async (e) => c.post(V, e),
1213
- fetchOrchestrationSystems: async () => c.paginatedFetch(V),
1214
- fetchWorkspaceOrchestrationSystems: async (e) => c.paginatedFetch(`${V}?workspace_id=${e}`),
1215
- fetchOrchestrationSystem: async (e) => c.fetch(`${V}/${e}`),
1216
- updateOrchestrationSystem: async (e, t) => c.patch(`${V}/${e}`, t),
1217
- deleteOrchestrationSystem: async (e) => c.delete(`${V}/${e}`),
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
- `${x}?expand_related=true`,
1220
- qe(e)
1219
+ `${N}?expand_related=true`,
1220
+ Je(e)
1221
1221
  ),
1222
- fetchDataSources: async () => c.paginatedFetch(`${x}?expand_related=true`),
1222
+ fetchDataSources: async () => c.paginatedFetch(`${N}?expand_related=true`),
1223
1223
  fetchWorkspaceDataSources: async (e) => c.paginatedFetch(
1224
- `${x}?workspace_id=${e}&expand_related=true`
1224
+ `${N}?workspace_id=${e}&expand_related=true`
1225
1225
  ),
1226
- fetchDataSource: async (e) => c.fetch(`${x}/${e}?expand_related=true`),
1226
+ fetchDataSource: async (e) => c.fetch(`${N}/${e}?expand_related=true`),
1227
1227
  updateDataSource: async (e) => c.patch(
1228
- `${x}/${e.id}?expand_related=true`,
1229
- qe(e)
1228
+ `${N}/${e.id}?expand_related=true`,
1229
+ Je(e)
1230
1230
  ),
1231
1231
  updateDataSourcePartial: async (e) => c.patch(
1232
- `${x}/${e.id}?expand_related=true`,
1232
+ `${N}/${e.id}?expand_related=true`,
1233
1233
  e
1234
1234
  ),
1235
- deleteDataSource: async (e) => c.delete(`${x}/${e}`),
1235
+ deleteDataSource: async (e) => c.delete(`${N}/${e}`),
1236
1236
  linkDatastreamToDataSource: async (e, t) => c.post(
1237
- `${x}/${e}/datastreams/${t}`
1237
+ `${N}/${e}/datastreams/${t}`
1238
1238
  ),
1239
1239
  unlinkDatastreamFromDataSource: async (e, t) => c.delete(
1240
- `${x}/${e}/datastreams/${t}`
1240
+ `${N}/${e}/datastreams/${t}`
1241
1241
  ),
1242
1242
  fetchObservations: async (e) => c.fetch(e),
1243
- deleteObservationsForDatastream: async (e) => c.post(`${R}/${e}/observations/bulk-delete`, {
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(`${j}/encoding-types`),
1252
- fetchMethodTypes: async () => c.paginatedFetch(`${j}/method-types`),
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(`${R}/statuses`),
1256
- fetchDatastreamAggregations: async () => c.paginatedFetch(`${R}/aggregation-statistics`),
1257
- fetchSampledMediums: async () => c.paginatedFetch(`${R}/sampled-mediums`)
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 hs {
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 _t = 1, ce = _t * 60, Oe = ce * 60, De = Oe * 24, yr = De * 7, gr = Oe * 30, mr = De * 365, re = {
1268
- [F.SECOND]: _t,
1269
- [F.MINUTE]: ce,
1270
- [F.HOUR]: Oe,
1271
- [F.DAY]: De,
1272
- [F.WEEK]: yr,
1273
- [F.MONTH]: gr,
1274
- [F.YEAR]: mr
1275
- }, fs = (e) => e.toLocaleString(void 0, {
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
- }), ds = (e) => {
1283
+ }), ms = (e) => {
1284
1284
  let t, r;
1285
- e >= ce * 1e3 ? (t = e / (ce * 1e3), r = "m") : e >= 1e3 ? (t = e / 1e3, r = "s") : (t = e, r = "ms");
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
- }, be = async (e, t) => {
1288
+ }, Ee = async (e, t) => {
1289
1289
  t && console.info(t);
1290
- const r = performance.now(), s = await e(), n = performance.now();
1291
- console.info(` Done in ${(n - r).toFixed(2)} ms`);
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 ps(e, t) {
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 se = (e, t) => {
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
- }, Se = (e, t) => {
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
- }, At = `(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")}})();
1314
- `, Ke = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", At], { type: "text/javascript;charset=utf-8" });
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 = Qe && (self.URL || self.webkitURL).createObjectURL(Qe), !t) throw "";
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 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")}})();
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";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")}})();
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";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")}})();
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 kr(e) {
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";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")}})();
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 vr(e) {
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 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))}})();
1440
- `, st = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Mt], { type: "text/javascript;charset=utf-8" });
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(Mt),
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 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))}})();
1461
- `, nt = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Ut], { type: "text/javascript;charset=utf-8" });
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(Ut),
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 Ot = `(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))}})();
1482
- `, ot = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Ot], { type: "text/javascript;charset=utf-8" });
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(Ot),
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 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))}})();
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 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))}})();
1524
- `, it = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Ct], { type: "text/javascript;charset=utf-8" });
1525
- function Re(e) {
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(Ct),
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 Ft = `(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")}})();
1545
- `, ct = typeof self < "u" && self.Blob && new Blob(["(self.URL || self.webkitURL).revokeObjectURL(self.location.href);", Ft], { type: "text/javascript;charset=utf-8" });
1546
- function $r(e) {
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(Ft),
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 a = [], o = s.length;
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 u = 0; u < o; u++) {
1571
- const p = s[u], g = n[u];
1572
- if (p === 0) {
1573
- if (l < g) {
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 (p === 1) {
1578
- if (l <= g) {
1575
+ } else if (y === 1) {
1576
+ if (l <= p) {
1579
1577
  f = !0;
1580
1578
  break;
1581
1579
  }
1582
- } else if (p === 2) {
1583
- if (l > g) {
1580
+ } else if (y === 2) {
1581
+ if (l > p) {
1584
1582
  f = !0;
1585
1583
  break;
1586
1584
  }
1587
- } else if (p === 3) {
1588
- if (l >= g) {
1585
+ } else if (y === 3) {
1586
+ if (l >= p) {
1589
1587
  f = !0;
1590
1588
  break;
1591
1589
  }
1592
- } else if (l == g) {
1590
+ } else if (l == p) {
1593
1591
  f = !0;
1594
1592
  break;
1595
1593
  }
1596
1594
  }
1597
- f && a.push(i);
1595
+ f && o.push(i);
1598
1596
  }
1599
- return a;
1597
+ return o;
1600
1598
  }
1601
- function Rr(e, t, r, s, n) {
1602
- const a = [];
1599
+ function Ir(e, t, r, s, n) {
1600
+ const o = [];
1603
1601
  if (s === "Less than")
1604
- for (let o = t; o < r; o++)
1605
- e[o] - e[o - 1] < n && a.push(o);
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 o = t; o < r; o++)
1608
- e[o] - e[o - 1] <= n && a.push(o);
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 o = t; o < r; o++)
1611
- e[o] - e[o - 1] > n && a.push(o);
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 o = t; o < r; o++)
1614
- e[o] - e[o - 1] >= n && a.push(o);
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 o = t; o < r; o++)
1617
- e[o] - e[o - 1] == n && a.push(o);
1618
- return a;
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 Ir(e, t, r, s, n) {
1621
- const a = [];
1618
+ function Or(e, t, r, s, n) {
1619
+ const o = [];
1622
1620
  if (s === "Less than")
1623
- for (let o = t; o < r; o++) {
1624
- const i = e[o - 1];
1625
- (e[o] - i) / Math.abs(i) < n && a.push(o);
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 o = t; o < r; o++) {
1629
- const i = e[o - 1];
1630
- (e[o] - i) / Math.abs(i) <= n && a.push(o);
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 o = t; o < r; o++) {
1634
- const i = e[o - 1];
1635
- (e[o] - i) / Math.abs(i) > n && a.push(o);
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 o = t; o < r; o++) {
1639
- const i = e[o - 1];
1640
- (e[o] - i) / Math.abs(i) >= n && a.push(o);
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 o = t; o < r; o++) {
1644
- const i = e[o - 1];
1645
- (e[o] - i) / Math.abs(i) == n && a.push(o);
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 a;
1645
+ return o;
1648
1646
  }
1649
1647
  function Mr(e, t, r, s) {
1650
1648
  const n = [];
1651
- let a = e[t];
1652
- for (let o = t + 1; o <= r; o++) {
1653
- const i = e[o];
1654
- i - a > s && n.push(o - 1, o), a = 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, a = e[t];
1662
- for (let o = t + 1; o < r; o++) {
1663
- const i = e[o];
1664
- i !== a && (s.push(n, o - n, a), n = o, a = i);
1665
- }
1666
- return s.push(n, r - n, a), s;
1667
- }
1668
- function Or(e, t, r, s, n, a, o, i, l, f, u) {
1669
- let p = 0, g = i;
1670
- for (let y = a; y <= o; y++)
1671
- if (s[g] = e[y], n[g] = t[y], g++, p < r.length && y === r[p][0]) {
1672
- const d = r[p][0], h = r[p][1], b = e[d], w = e[h], m = t[d], S = t[h], A = w - b, T = S - m;
1673
- let L = b + l;
1674
- for (; L < w; )
1675
- s[g] = L, n[g] = f ? m + (L - b) * T / A : u, g++, L += l;
1676
- p++;
1677
- }
1678
- return g - i;
1679
- }
1680
- function Dr(e, t, r, s, n, a, o, i) {
1681
- let l = a, f = 0, u = i;
1682
- const p = r.length;
1683
- for (; l < o && f < p; ) {
1684
- const g = r[f][0];
1685
- e[l] <= g ? (s[u] = e[l], n[u] = t[l], l++) : (s[u] = g, n[u] = r[f][1], f++), u++;
1686
- }
1687
- for (; l < o; )
1688
- s[u] = e[l], n[u] = t[l], l++, u++;
1689
- for (; f < p; )
1690
- s[u] = r[f][0], n[u] = r[f][1], f++, u++;
1691
- return u - i;
1692
- }
1693
- function Cr(e, t, r, s, n, a, o, i) {
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 u = a; u <= o; u++)
1696
- l < r.length && u === r[l] ? l++ : (s[f] = e[u], n[f] = t[u], f++);
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 Fr(e, t, r, s) {
1700
- const n = r.length, a = new Array(n);
1697
+ function xr(e, t, r, s) {
1698
+ const n = r.length, o = new Array(n);
1701
1699
  if (s.isMonth)
1702
- for (let o = 0; o < n; o++) {
1703
- const i = r[o], l = new Date(e[i]);
1704
- l.setMonth(l.getMonth() + s.amount), a[o] = [l.getTime(), t[i]];
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 o = 0; o < n; o++) {
1708
- const i = r[o], l = new Date(e[i]);
1709
- l.setFullYear(l.getFullYear() + s.amount), a[o] = [l.getTime(), t[i]];
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 o = 0; o < n; o++) {
1713
- const i = r[o];
1714
- a[o] = [e[i] + s.deltaMs, t[i]];
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 a;
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: a, upperIdx: o } = r[s], i = e[a], l = t[a], f = e[o], u = t[o], p = f - i, g = u - l;
1721
- if (p === 0) {
1722
- for (let y = 0; y < n.length; y++) t[n[y]] = l;
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 y = 0; y < n.length; y++) {
1726
- const d = n[y];
1727
- t[d] = l + (e[d] - i) * g / p;
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 xr(e, t, r) {
1729
+ function Nr(e, t, r) {
1732
1730
  for (let s = 0; s < r.length; s++) {
1733
- const n = r[s][0], a = r[s][1], o = r[s][2];
1734
- if (a <= n) continue;
1735
- const i = e[n], l = e[a] - i;
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 < a; f++)
1738
- t[f] = t[f] + o * ((e[f] - i) / l);
1735
+ for (let f = n; f < o; f++)
1736
+ t[f] = t[f] + a * ((e[f] - i) / l);
1739
1737
  }
1740
1738
  }
1741
- function lt(e, t, r, s) {
1739
+ function ut(e, t, r, s) {
1742
1740
  const n = t.length;
1743
1741
  if (r === "ADD")
1744
- for (let a = 0; a < n; a++) e[t[a]] = e[t[a]] + s;
1742
+ for (let o = 0; o < n; o++) e[t[o]] = e[t[o]] + s;
1745
1743
  else if (r === "SUB")
1746
- for (let a = 0; a < n; a++) e[t[a]] = e[t[a]] - s;
1744
+ for (let o = 0; o < n; o++) e[t[o]] = e[t[o]] - s;
1747
1745
  else if (r === "MULT")
1748
- for (let a = 0; a < n; a++) e[t[a]] = e[t[a]] * s;
1746
+ for (let o = 0; o < n; o++) e[t[o]] = e[t[o]] * s;
1749
1747
  else if (r === "DIV")
1750
- for (let a = 0; a < n; a++) e[t[a]] = e[t[a]] / s;
1748
+ for (let o = 0; o < n; o++) e[t[o]] = e[t[o]] / s;
1751
1749
  else if (r === "ASSIGN")
1752
- for (let a = 0; a < n; a++) e[t[a]] = s;
1750
+ for (let o = 0; o < n; o++) e[t[o]] = s;
1753
1751
  }
1754
- const Nr = 1, Ce = `qc-utils:calibration:v${Nr}`, Br = 720 * 60 * 60 * 1e3, ne = 5e4, oe = 2e5, le = {
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 M = Gr() ?? le, Fe = null, Q = null;
1766
- const Ie = /* @__PURE__ */ new Set(), Me = {
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
- [v.VALUE_THRESHOLD]: {
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
- [v.CHANGE]: {
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
- [v.RATE_OF_CHANGE]: {
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
- [v.FIND_GAPS]: {
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
- [v.PERSISTENCE]: {
1786
+ [A.PERSISTENCE]: {
1789
1787
  mode: "calibrated",
1790
1788
  weight: 1.3,
1791
1789
  rationale: "O(n) + chunk-boundary stitch"
1792
1790
  },
1793
- [v.DATETIME_RANGE]: {
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
- [v.SELECTION]: {
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 O(e, t) {
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 = jr(e, t);
1878
+ const s = Wr(e, t);
1881
1879
  if (s <= 0)
1882
1880
  return {
1883
1881
  useWorker: !1,
1884
1882
  predictedInlineMs: 0,
1885
- predictedWorkerMs: M.spawnOverheadMs,
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 ?? M.hwConcurrency,
1892
- M.hwConcurrency
1889
+ t.parallelism ?? O.hwConcurrency,
1890
+ O.hwConcurrency
1893
1891
  )
1894
- ), a = r.weight * s / M.inlineThroughput, o = M.spawnOverheadMs + r.weight * s / (M.workerThroughput * n), i = a > o;
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: a,
1898
- predictedWorkerMs: o,
1899
- reason: i ? `worker faster (${o.toFixed(1)} vs ${a.toFixed(1)} ms)` : `inline faster (${a.toFixed(1)} vs ${o.toFixed(1)} ms)`
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 jr(e, t) {
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 ys(e) {
1920
- return Ie.add(e), () => Ie.delete(e);
1917
+ function bs(e) {
1918
+ return Oe.add(e), () => Oe.delete(e);
1921
1919
  }
1922
- function gs() {
1923
- return M;
1920
+ function Ss() {
1921
+ return O;
1924
1922
  }
1925
- function ms() {
1926
- return Fe;
1923
+ function Es() {
1924
+ return xe;
1927
1925
  }
1928
- function ws() {
1926
+ function vs() {
1929
1927
  return Object.keys(Me).map((e) => ({ op: e, ...Me[e] }));
1930
1928
  }
1931
- function bs() {
1932
- M = le, Fe = null;
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 Ss(e = {}) {
1939
- if (typeof window > "u" || !(e.force || M.measuredAt === 0 || Date.now() - M.measuredAt > Br)) return M;
1940
- if (Q) await Q;
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
- Q = Wr().finally(() => {
1943
- Q = null;
1940
+ ee = Yr().finally(() => {
1941
+ ee = null;
1944
1942
  });
1945
- const r = await Q;
1946
- M = r, Yr(r), Fe = r;
1947
- for (const s of Ie) s(M);
1943
+ const r = await ee;
1944
+ O = r, Hr(r), xe = r;
1945
+ for (const s of Oe) s(O);
1948
1946
  }
1949
- return M;
1947
+ return O;
1950
1948
  }
1951
- async function Wr() {
1949
+ async function Yr() {
1952
1950
  if (!(typeof SharedArrayBuffer < "u"))
1953
1951
  return {
1954
- ...le,
1952
+ ...he,
1955
1953
  measuredAt: Date.now(),
1956
1954
  userAgent: navigator.userAgent,
1957
- hwConcurrency: navigator.hardwareConcurrency || le.hwConcurrency,
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(ne);
1962
- for (let h = 0; h < ne; h++) r[h] = Math.sin(h);
1963
- const s = await Ee(3, () => {
1964
- const h = performance.now();
1965
- return Pt(r, 0, ne, [2], [0.5]), performance.now() - h;
1966
- }), n = ke(s), a = ne / Math.max(n, 1e-3), o = new SharedArrayBuffer(256 * Float32Array.BYTES_PER_ELEMENT), i = await Ee(3, async () => {
1967
- const h = performance.now();
1968
- return await new Promise((b) => {
1969
- const w = new Re();
1970
- w.onmessage = () => {
1971
- w.terminate(), b();
1972
- }, w.postMessage({
1973
- bufferY: o,
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() - h;
1977
+ }), performance.now() - u;
1980
1978
  }), l = ke(i), f = new SharedArrayBuffer(
1981
- oe * Float32Array.BYTES_PER_ELEMENT
1982
- ), u = new Float32Array(f);
1983
- for (let h = 0; h < oe; h++) u[h] = Math.sin(h);
1984
- const p = await Ee(3, async () => {
1985
- const h = performance.now();
1986
- return await new Promise((b) => {
1987
- const w = new Re();
1988
- w.onmessage = () => {
1989
- w.terminate(), b();
1990
- }, w.postMessage({
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: oe,
1991
+ end: ae,
1994
1992
  ops: [2],
1995
1993
  values: [0.5]
1996
1994
  });
1997
- }), performance.now() - h;
1998
- }), g = Math.max(ke(p) - l, 0.1), y = oe / g;
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: a,
2002
- workerThroughput: y,
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: p
2008
+ workerScanMs: y
2011
2009
  }
2012
2010
  };
2013
2011
  }
2014
- async function Ee(e, t) {
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 Yr(e) {
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 Z = 20 * 1e3, Hr = 1024, zr = ["date", "value", "qualifier"], Xr = typeof SharedArrayBuffer < "u";
2052
- function U(e, t) {
2053
- return Xr ? t !== void 0 ? new SharedArrayBuffer(e, { maxByteLength: t }) : new SharedArrayBuffer(e) : t !== void 0 ? new ArrayBuffer(e, { maxByteLength: t }) : new ArrayBuffer(e);
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 ut(e, t) {
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
- class Es {
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: zr,
2075
+ dimensions: Xr,
2063
2076
  source: {
2064
2077
  x: new Float64Array(
2065
- U(
2066
- Z * Float64Array.BYTES_PER_ELEMENT,
2067
- Z * Float64Array.BYTES_PER_ELEMENT
2078
+ M(
2079
+ te * Float64Array.BYTES_PER_ELEMENT,
2080
+ te * Float64Array.BYTES_PER_ELEMENT
2068
2081
  )
2069
2082
  ),
2070
2083
  y: new Float32Array(
2071
- U(
2072
- Z * Float32Array.BYTES_PER_ELEMENT,
2073
- Z * Float32Array.BYTES_PER_ELEMENT
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 be(() => {
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 += Z * Float64Array.BYTES_PER_ELEMENT;
2157
+ s += te * Float64Array.BYTES_PER_ELEMENT;
2145
2158
  if (s * Float64Array.BYTES_PER_ELEMENT > this.dataX.buffer.maxByteLength) {
2146
- const n = U(
2159
+ const n = M(
2147
2160
  this.dataX.buffer.byteLength,
2148
2161
  s * Float64Array.BYTES_PER_ELEMENT
2149
- ), a = U(
2162
+ ), o = M(
2150
2163
  this.dataY.buffer.byteLength,
2151
2164
  s * Float32Array.BYTES_PER_ELEMENT
2152
- ), o = new Float64Array(n), i = new Float32Array(a);
2153
- o.set(this.dataX), i.set(this.dataY), this.dataset.source.x = o, this.dataset.source.y = i;
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 && (ut(this.dataX.buffer, t * Float64Array.BYTES_PER_ELEMENT), ut(this.dataY.buffer, t * Float32Array.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
- /** Dispatch an operation and log its signature in hisotry */
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._deleteDataPoints,
2223
- [E.DRIFT_CORRECTION]: this._driftCorrection,
2224
- [E.INTERPOLATE]: this._interpolate,
2225
- [E.SHIFT_DATETIMES]: this._shift,
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 a = [];
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
- this.history.push(o);
2249
- const i = this.history.length - 1;
2250
- this._pendingExecutionMode = "inline";
2251
- const l = await be(async () => await s[t].apply(this, r));
2252
- a = l.response;
2253
- const f = this.history[i];
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 a;
2274
+ return n;
2262
2275
  }
2263
2276
  async dispatch(t, ...r) {
2264
- const s = async (n, a) => v[n] ? await this.dispatchFilter(n, ...a) : await this.dispatchAction(n, ...a);
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 a = 0; a < t.length; a++) {
2268
- const o = t[a][0], i = t[a].slice(1, t[a].length);
2269
- n = await s(o, i);
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
- [v.FIND_GAPS]: this._findGaps,
2279
- [v.VALUE_THRESHOLD]: this._valueThreshold,
2280
- [v.DATETIME_RANGE]: this._datetimeRange,
2281
- [v.PERSISTENCE]: this._persistence,
2282
- [v.CHANGE]: this._change,
2283
- [v.RATE_OF_CHANGE]: this._rateOfChange,
2284
- [v.SELECTION]: this._selection
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 a = [];
2299
+ let n = [], o = null;
2295
2300
  try {
2296
- this._isReplaying || (this.redoStack.length = 0);
2297
- const o = {
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
- }, i = this.history[this.history.length - 1];
2303
- let l;
2304
- v[i?.method] ? (l = this.history.length - 1, this.history[l] = o) : (this.history.push(o), l = this.history.length - 1), this._pendingExecutionMode = "inline";
2305
- const f = await be(async () => await s[t].apply(this, r));
2306
- a = f.response;
2307
- const u = this.history[l];
2308
- u && (u.duration = f.duration, u.executionMode = this._pendingExecutionMode, u.selected = f.response, u.isLoading = !1);
2309
- } catch (o) {
2310
- console.log(
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 a;
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 (!O(E.CHANGE_VALUES, {
2341
+ if (!D(E.CHANGE_VALUES, {
2334
2342
  datasetSize: this.dataset.source.y.length,
2335
2343
  selectionSize: n
2336
- }).useWorker || n < Hr)
2337
- return lt(this.dataY, s, t, r), [];
2344
+ }).useWorker || n < zr)
2345
+ return ut(this.dataY, s, t, r), [];
2338
2346
  this._pendingExecutionMode = "worker";
2339
- const o = Math.min(navigator.hardwareConcurrency || 1, n), i = Math.ceil(n / o), l = [], f = [];
2340
- for (let u = 0; u < o; u++) {
2341
- const p = u * i, g = Math.min((u + 1) * i, n);
2342
- if (p >= g) break;
2343
- const y = s.slice(p, g);
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 h = new $r();
2347
- l.push(h), h.postMessage({
2354
+ const u = new Rr();
2355
+ l.push(u), u.postMessage({
2348
2356
  bufferY: this.dataY.buffer,
2349
- indexes: y,
2357
+ indexes: g,
2350
2358
  operator: t,
2351
2359
  value: r
2352
- }), h.onmessage = (b) => {
2353
- d(b.data);
2360
+ }), u.onmessage = (w) => {
2361
+ d(w.data);
2354
2362
  };
2355
2363
  })
2356
2364
  );
2357
2365
  }
2358
- return await Promise.all(f), l.forEach((u) => u.terminate()), [];
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
- lt(this.dataY, t, r, s);
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 a = 0; a < s; a++) n[r[a]] = t[a];
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), a = new Array(s);
2401
- for (let o = 0; o < s; o++)
2402
- n[o] = [t[o], this.dataY[r[o]]], a[o] = r[o];
2403
- return a.sort((o, i) => o - i), await this._deleteDataPoints(a), await this._addDataPoints(n), [];
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((u) => ({
2415
- indexes: u,
2416
- lowerIdx: Math.max(0, u[0] - 1),
2417
- upperIdx: Math.min(s - 1, u[u.length - 1] + 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 (!O(E.INTERPOLATE, {
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 o = Math.min(
2447
+ const a = Math.min(
2428
2448
  navigator.hardwareConcurrency || 1,
2429
2449
  n.length
2430
- ), i = Math.ceil(n.length / o), l = [], f = [];
2431
- for (let u = 0; u < o; u++) {
2432
- const p = n.slice(
2433
- u * i,
2434
- (u + 1) * i
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 (p.length === 0) break;
2456
+ if (y.length === 0) break;
2437
2457
  f.push(
2438
- new Promise((g) => {
2439
- const y = new Sr();
2440
- l.push(y), y.postMessage({
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: p
2444
- }), y.onmessage = (d) => {
2445
- g(d.data);
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((u) => u.terminate());
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 === F.MONTH, a = s === F.YEAR, o = !n && !a ? r * re[s] * 1e3 : 0, i = t.length;
2476
- if (!O(E.SHIFT_DATETIMES, {
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 = Fr(
2510
+ const m = xr(
2481
2511
  this.dataX,
2482
2512
  this.dataY,
2483
2513
  t,
2484
- { amount: r, isMonth: n, isYear: a, deltaMs: o }
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 = U(i * Float64Array.BYTES_PER_ELEMENT), u = U(i * Float32Array.BYTES_PER_ELEMENT), p = Math.min(navigator.hardwareConcurrency || 1, i), g = Math.ceil(i / p), y = [], d = [];
2491
- for (let m = 0; m < p; m++) {
2492
- const S = m * g, A = Math.min((m + 1) * g, i);
2493
- if (S >= A) break;
2494
- const T = t.slice(S, A);
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 I = new vr();
2498
- y.push(I), I.postMessage({
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: u,
2532
+ outputBufferY: h,
2503
2533
  indexes: T,
2504
2534
  outStart: S,
2505
2535
  amount: r,
2506
2536
  isMonth: n,
2507
- isYear: a,
2508
- deltaMs: o
2509
- }), I.onmessage = (W) => {
2510
- L(W.data);
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), y.forEach((m) => m.terminate());
2516
- const h = new Float64Array(f), b = new Float32Array(u), w = new Array(i);
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
- w[m] = [h[m], b[m]];
2519
- await this._deleteDataPoints(t), await this._addDataPoints(w);
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
- async _fillGaps(t, r, s, n, a) {
2529
- const o = this.dataX.length;
2530
- if (o === 0) return;
2531
- const i = t[0] * re[t[1]] * 1e3, l = r[0] * re[r[1]] * 1e3, f = a?.[0] ?? 0, u = a?.[1] ?? o - 1, p = this.dataX, g = [], y = [];
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 = f + 1; k <= u; k++)
2534
- if (p[k] - p[k - 1] > i) {
2535
- let P = 0, G = p[k - 1] + l;
2536
- for (; G < p[k]; )
2537
- P++, G += l;
2538
- P > 0 && (g.push([k - 1, k]), y.push(P), d += P);
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 h = o + d, b = h * Float64Array.BYTES_PER_ELEMENT, w = h * Float32Array.BYTES_PER_ELEMENT, m = U(
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.dataY.buffer.maxByteLength, w)
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 (!O(E.FILL_GAPS, {
2549
- datasetSize: o,
2585
+ if (!D(E.FILL_GAPS, {
2586
+ datasetSize: a,
2550
2587
  selectionSize: d
2551
2588
  }).useWorker) {
2552
- const k = new Float64Array(m), B = new Float32Array(S);
2553
- Or(
2589
+ const k = new Float64Array(m), j = new Float32Array(S);
2590
+ Dr(
2554
2591
  this.dataX,
2555
2592
  this.dataY,
2556
- g,
2593
+ p,
2557
2594
  k,
2558
- B,
2595
+ j,
2559
2596
  0,
2560
- o - 1,
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 = B, this._resizeTo(h);
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(o / T), I = [];
2570
- let W = 0;
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 B = k * L, P = Math.min((k + 1) * L - 1, o - 1), G = [];
2573
- let ee = 0;
2574
- for (; W < g.length && g[W][0] <= P; )
2575
- G.push(g[W]), ee += y[W], W++;
2576
- I.push({ start: B, end: P, gapsSegment: G, fillsInSegment: ee });
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 fe = new Array(T).fill(0);
2615
+ const pe = new Array(T).fill(0);
2579
2616
  for (let k = 1; k < T; k++)
2580
- fe[k] = fe[k - 1] + I[k - 1].fillsInSegment;
2581
- const Pe = [], xe = [];
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: B, end: P, gapsSegment: G } = I[k], ee = B + fe[k];
2584
- xe.push(
2585
- new Promise((xt) => {
2586
- const de = new br();
2587
- Pe.push(de), de.postMessage({
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: B,
2629
+ start: j,
2593
2630
  end: P,
2594
- gapsSegment: G,
2595
- startTarget: ee,
2631
+ gapsSegment: Y,
2632
+ startTarget: re,
2596
2633
  fillDelta: l,
2597
2634
  interpolate: s,
2598
2635
  fillValue: n
2599
- }), de.onmessage = (Nt) => {
2600
- xt(Nt.data);
2636
+ }), ye.onmessage = (Bt) => {
2637
+ Nt(Bt.data);
2601
2638
  };
2602
2639
  })
2603
2640
  );
2604
2641
  }
2605
- await Promise.all(xe), Pe.forEach((k) => k.terminate()), this.dataset.source.x = new Float64Array(m), this.dataset.source.y = new Float32Array(S), this._resizeTo(h);
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 (!O(E.DELETE_POINTS, {
2666
+ if (!D(E.DELETE_POINTS, {
2618
2667
  datasetSize: r,
2619
2668
  selectionSize: t.length
2620
2669
  }).useWorker) {
2621
- const y = U(
2670
+ const g = M(
2622
2671
  this.dataX.buffer.byteLength,
2623
2672
  this.dataX.buffer.maxByteLength
2624
- ), d = U(
2673
+ ), d = M(
2625
2674
  this.dataY.buffer.byteLength,
2626
2675
  this.dataY.buffer.maxByteLength
2627
- ), h = new Float64Array(y), b = new Float32Array(d);
2676
+ ), u = new Float64Array(g), w = new Float32Array(d);
2628
2677
  Cr(
2629
2678
  this.dataX,
2630
2679
  this.dataY,
2631
2680
  t,
2632
- h,
2633
- b,
2681
+ u,
2682
+ w,
2634
2683
  0,
2635
2684
  r - 1,
2636
2685
  0
2637
- ), this.dataset.source.x = h, this.dataset.source.y = b, this._resizeTo(s);
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 a = navigator.hardwareConcurrency || 1, o = Math.ceil(this.dataX.length / a), i = [], l = [];
2642
- for (let y = 0; y < a; y++) {
2643
- const d = y * o, h = Math.min((y + 1) * o - 1, this.dataX.length - 1), b = se(t, d), w = Se(t, h), m = t.slice(b, w + 1);
2644
- l.push({ start: d, end: h, deleteSegment: m });
2645
- }
2646
- const f = new Array(a).fill(0);
2647
- for (let y = 1; y < a; y++)
2648
- f[y] = f[y - 1] + l[y - 1].deleteSegment.length;
2649
- const u = [], p = U(
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
- ), g = U(
2701
+ ), p = M(
2653
2702
  this.dataY.buffer.byteLength,
2654
2703
  this.dataY.buffer.maxByteLength
2655
2704
  );
2656
- for (let y = 0; y < a; y++) {
2657
- const { start: d, end: h, deleteSegment: b } = l[y], w = d - f[y];
2658
- u.push(
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 wr();
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: p,
2665
- outputBufferY: g,
2713
+ outputBufferX: y,
2714
+ outputBufferY: p,
2666
2715
  start: d,
2667
- end: h,
2668
- deleteSegment: b,
2669
- startTarget: w
2670
- }), S.onmessage = (A) => {
2671
- m(A.data);
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(u), i.forEach((y) => y.terminate()), this.dataset.source.x = new Float64Array(p), this.dataset.source.y = new Float32Array(g), this._resizeTo(s);
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 [p, g] of t)
2696
- g > p && (n += g - p);
2697
- if (!O(E.DRIFT_CORRECTION, {
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
- xr(r, this.dataY, t);
2768
+ Nr(r, this.dataY, t);
2702
2769
  return;
2703
2770
  }
2704
2771
  this._pendingExecutionMode = "worker";
2705
- const o = [];
2706
- for (const [p, g, y] of t) {
2707
- if (g <= p) continue;
2708
- const d = r[p], h = r[g] - d;
2709
- if (h === 0) continue;
2710
- const b = g - p, w = Math.max(1, Math.ceil(b / s));
2711
- for (let m = p; m < g; m += w)
2712
- o.push({
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 + w, g),
2781
+ chunkEnd: Math.min(m + b, p),
2715
2782
  startDatetime: d,
2716
- value: y,
2717
- extent: h
2783
+ value: g,
2784
+ extent: u
2718
2785
  });
2719
2786
  }
2720
- if (o.length === 0) return;
2721
- const i = Math.min(s, o.length), l = Array.from(
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
- o.forEach((p, g) => l[g % i].push(p));
2726
- const f = [], u = [];
2727
- for (const p of l)
2728
- p.length !== 0 && u.push(
2729
- new Promise((g) => {
2730
- const y = new Er();
2731
- f.push(y), y.postMessage({
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: p
2735
- }), y.onmessage = (d) => {
2736
- g(d.data);
2801
+ jobs: y
2802
+ }), g.onmessage = (d) => {
2803
+ p(d.data);
2737
2804
  };
2738
2805
  })
2739
2806
  );
2740
- await Promise.all(u), f.forEach((p) => p.terminate());
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 a = s[s.length - 1];
2751
- return !a.length || n == a[a.length - 1] + 1 ? a.push(n) : s.push([n]), s;
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, h) => d[0] - h[0]);
2765
- const n = s * Float64Array.BYTES_PER_ELEMENT, a = s * Float32Array.BYTES_PER_ELEMENT, o = U(
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 = U(
2769
- a,
2770
- Math.max(this.dataY.buffer.maxByteLength, a)
2835
+ ), i = M(
2836
+ o,
2837
+ Math.max(this.dataY.buffer.maxByteLength, o)
2771
2838
  );
2772
- if (!O(E.ADD_POINTS, {
2839
+ if (!D(E.ADD_POINTS, {
2773
2840
  datasetSize: r,
2774
2841
  selectionSize: t.length
2775
2842
  }).useWorker) {
2776
- const d = new Float64Array(o), h = new Float32Array(i);
2777
- Dr(
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
- h,
2849
+ u,
2783
2850
  0,
2784
2851
  r,
2785
2852
  0
2786
- ), this.dataset.source.x = d, this.dataset.source.y = h, this._resizeTo(s);
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) => Se(this.dataX, d[0]) + 1
2792
- ), u = Math.max(
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
- ), p = Math.ceil(Math.max(r, 1) / u), g = [], y = [];
2796
- for (let d = 0; d < u; d++) {
2797
- const h = d * p, b = Math.min((d + 1) * p, r), w = se(f, h), m = d === u - 1 ? t.length : se(f, b), S = t.slice(w, m), A = h + w;
2798
- h >= b && S.length === 0 || y.push(
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
- g.push(L), L.postMessage({
2868
+ p.push(L), L.postMessage({
2802
2869
  bufferX: this.dataX.buffer,
2803
2870
  bufferY: this.dataY.buffer,
2804
- outputBufferX: o,
2871
+ outputBufferX: a,
2805
2872
  outputBufferY: i,
2806
- origStart: h,
2807
- origEnd: b,
2873
+ origStart: u,
2874
+ origEnd: w,
2808
2875
  insertions: S,
2809
- outStart: A
2810
- }), L.onmessage = (I) => {
2811
- T(I.data);
2876
+ outStart: v
2877
+ }), L.onmessage = (R) => {
2878
+ T(R.data);
2812
2879
  };
2813
2880
  })
2814
2881
  );
2815
2882
  }
2816
- await Promise.all(y), g.forEach((d) => d.terminate()), this.dataset.source.x = new Float64Array(o), this.dataset.source.y = new Float32Array(i), this._resizeTo(s);
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
- [J.LT]: 0,
2839
- [J.LTE]: 1,
2840
- [J.GT]: 2,
2841
- [J.GTE]: 3,
2842
- [J.E]: 4
2843
- }, n = r.map((h) => s[h] ?? 4), a = r.map((h) => t[h]), o = this.dataset.source.y, i = o.length;
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 (!O(v.VALUE_THRESHOLD, {
2912
+ if (!D(A.VALUE_THRESHOLD, {
2846
2913
  datasetSize: i
2847
2914
  }).useWorker)
2848
- return Pt(o, 0, i, n, a);
2915
+ return Pt(a, 0, i, n, o);
2849
2916
  this._pendingExecutionMode = "worker";
2850
- const f = Math.min(navigator.hardwareConcurrency || 1, i), u = Math.ceil(i / f), p = [], g = [];
2851
- for (let h = 0; h < f; h++) {
2852
- const b = h * u, w = Math.min((h + 1) * u, i);
2853
- if (b >= w) break;
2854
- g.push(
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 Re();
2857
- p.push(S), S.postMessage({
2923
+ const S = new Ie();
2924
+ y.push(S), S.postMessage({
2858
2925
  bufferY: this.dataY.buffer,
2859
- start: b,
2860
- end: w,
2926
+ start: w,
2927
+ end: b,
2861
2928
  ops: n,
2862
- values: a
2863
- }), S.onmessage = (A) => {
2864
- m(A.data);
2929
+ values: o
2930
+ }), S.onmessage = (v) => {
2931
+ m(v.data);
2865
2932
  };
2866
2933
  })
2867
2934
  );
2868
2935
  }
2869
- const y = await Promise.all(g);
2870
- p.forEach((h) => h.terminate());
2936
+ const g = await Promise.all(p);
2937
+ y.forEach((u) => u.terminate());
2871
2938
  const d = [];
2872
- for (let h = 0; h < y.length; h++) {
2873
- const b = y[h];
2874
- for (let w = 0; w < b.length; w++) d.push(b[w]);
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, a = s.length, o = a - n;
2894
- if (!O(v.RATE_OF_CHANGE, {
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 Ir(s, n, a, t, r);
2964
+ return Or(s, n, o, t, r);
2898
2965
  this._pendingExecutionMode = "worker";
2899
- const l = Math.min(navigator.hardwareConcurrency || 1, o), f = Math.ceil(o / l), u = [], p = [];
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 h = n + d * f, b = Math.min(n + (d + 1) * f, a);
2902
- if (h >= b) break;
2903
- p.push(
2904
- new Promise((w) => {
2905
- const m = new Lr();
2906
- u.push(m), m.postMessage({
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: h,
2909
- end: b,
2975
+ start: u,
2976
+ end: w,
2910
2977
  comparator: t,
2911
2978
  value: r
2912
2979
  }), m.onmessage = (S) => {
2913
- w(S.data);
2980
+ b(S.data);
2914
2981
  };
2915
2982
  })
2916
2983
  );
2917
2984
  }
2918
- const g = await Promise.all(p);
2919
- u.forEach((d) => d.terminate());
2920
- const y = [];
2921
- for (let d = 0; d < g.length; d++) {
2922
- const h = g[d];
2923
- for (let b = 0; b < h.length; b++) y.push(h[b]);
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 y;
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 a = t == null ? 0 : se(s, t), o = r == null ? n - 1 : Se(s, r);
2937
- if (a > o) return [];
2938
- const i = new Array(o - a + 1);
2939
- for (let l = a; l <= o; l++) i[l - a] = 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
- * @param index
2944
- * @returns
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
- return (!t || !t.length) && this.history.pop(), t;
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, a = s.length, o = a - n;
2965
- if (!O(v.CHANGE, {
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 Rr(s, n, a, t, r);
3057
+ return Ir(s, n, o, t, r);
2969
3058
  this._pendingExecutionMode = "worker";
2970
- const l = Math.min(navigator.hardwareConcurrency || 1, o), f = Math.ceil(o / l), u = [], p = [];
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 h = n + d * f, b = Math.min(n + (d + 1) * f, a);
2973
- if (h >= b) break;
2974
- p.push(
2975
- new Promise((w) => {
2976
- const m = new Tr();
2977
- u.push(m), m.postMessage({
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: h,
2980
- end: b,
3068
+ start: u,
3069
+ end: w,
2981
3070
  comparator: t,
2982
3071
  value: r
2983
3072
  }), m.onmessage = (S) => {
2984
- w(S.data);
3073
+ b(S.data);
2985
3074
  };
2986
3075
  })
2987
3076
  );
2988
3077
  }
2989
- const g = await Promise.all(p);
2990
- u.forEach((d) => d.terminate());
2991
- const y = [];
2992
- for (let d = 0; d < g.length; d++) {
2993
- const h = g[d];
2994
- for (let b = 0; b < h.length; b++) y.push(h[b]);
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 y;
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, the gaps will be found only within the range
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 a = 0, o = n.length;
3010
- if (s?.[0] && s?.[1] && (a = s[0], o = s[1]), o <= a) return [];
3011
- const i = t * re[r] * 1e3;
3012
- if (!O(v.FIND_GAPS, {
3013
- datasetSize: o - a
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 b = Mr(n, a, o - 1, i), w = /* @__PURE__ */ new Set();
3016
- for (let m = 0; m < b.length; m++) w.add(b[m]);
3017
- return [...w];
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 = o - a, u = Math.min(navigator.hardwareConcurrency || 1, f), p = Math.ceil(f / u), g = [], y = [];
3021
- for (let b = 0; b < u; b++) {
3022
- const w = a + b * p, m = Math.min(a + (b + 1) * p, o);
3023
- if (w >= m) break;
3024
- y.push(
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 A = new _r();
3027
- g.push(A), A.postMessage({
3124
+ const v = new Ar();
3125
+ p.push(v), v.postMessage({
3028
3126
  bufferX: this.dataX.buffer,
3029
- start: w,
3127
+ start: b,
3030
3128
  endInclusive: m,
3031
3129
  threshold: i
3032
- }), A.onmessage = (T) => {
3130
+ }), v.onmessage = (T) => {
3033
3131
  S(T.data);
3034
3132
  };
3035
3133
  })
3036
3134
  );
3037
3135
  }
3038
- const d = await Promise.all(y);
3039
- g.forEach((b) => b.terminate());
3040
- const h = /* @__PURE__ */ new Set();
3041
- for (let b = 0; b < d.length; b++) {
3042
- const w = d[b];
3043
- for (let m = 0; m < w.length; m++) h.add(w[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 [...h];
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, the points will be found only within the range
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 n = 0, a = s.length;
3060
- if (r?.[0] && r?.[1] && (n = r[0], a = r[1]), a <= n) return [];
3061
- const o = a - n;
3062
- if (!O(v.PERSISTENCE, {
3063
- datasetSize: o
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 w = Ur(s, n, a), m = [];
3066
- for (let S = 0; S < w.length; S += 3) {
3067
- const A = w[S], T = w[S + 1];
3068
- if (T >= t)
3069
- for (let L = 0; L < T; L++) m.push(A + L);
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 m;
3178
+ return S;
3072
3179
  }
3073
3180
  this._pendingExecutionMode = "worker";
3074
- const l = Math.min(navigator.hardwareConcurrency || 1, o), f = Math.ceil(o / l), u = [], p = [];
3075
- for (let w = 0; w < l; w++) {
3076
- const m = n + w * f, S = Math.min(n + (w + 1) * f, a);
3077
- if (m >= S) break;
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((A) => {
3080
- const T = new Ar();
3081
- u.push(T), T.postMessage({
3186
+ new Promise((T) => {
3187
+ const L = new Tr();
3188
+ y.push(L), L.postMessage({
3082
3189
  bufferY: this.dataY.buffer,
3083
- start: m,
3084
- end: S
3085
- }), T.onmessage = (L) => {
3086
- A(L.data);
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
- u.forEach((w) => w.terminate());
3093
- const y = [], d = [], h = [];
3094
- for (let w = 0; w < g.length; w++) {
3095
- const m = g[w];
3096
- for (let S = 0; S < m.length; S += 3) {
3097
- const A = m[S], T = m[S + 1], L = m[S + 2], I = y.length - 1;
3098
- I >= 0 && h[I] === L && y[I] + d[I] === A ? d[I] += T : (y.push(A), d.push(T), h.push(L));
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 w = 0; w < y.length; w++) {
3103
- const m = d[w];
3104
- if (m >= t) {
3105
- const S = y[w];
3106
- for (let A = 0; A < m; A++) b.push(S + A);
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
- os as ApiKey,
3116
- D as BASE_URL,
3117
- is as Collaborator,
3118
- bt as DEFAULT_SNACK_DURATION,
3119
- cs as DataSource,
3120
- Jr as Datastream,
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
- v as EnumFilterOperations,
3123
- J as FilterOperation,
3124
- Wt as HydroShareArchive,
3125
- Z as INCREASE_AMOUNT,
3315
+ A as EnumFilterOperations,
3316
+ K as FilterOperation,
3317
+ Yt as HydroShareArchive,
3318
+ te as INCREASE_AMOUNT,
3126
3319
  Gt as Location,
3127
- jt as LogicalOperation,
3128
- ns as OAuthProvider,
3129
- Es as ObservationRecord,
3130
- Zr as ObservedProperty,
3131
- Bt as Operator,
3132
- rs as Organization,
3133
- ie as PROVIDER_BASE,
3134
- hs as Payload,
3135
- Yt as PermissionAction,
3136
- Ht as PermissionResource,
3137
- or as Position,
3138
- Vr as PostHydroShareArchive,
3139
- es as ProcessingLevel,
3140
- ts as ResultQualifier,
3141
- me as SESSION_BASE,
3142
- Qr as Sensor,
3143
- ar as Snack,
3144
- St as SnackColor,
3145
- Et as SnackIcon,
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
- ir as Snackbar,
3148
- Je as TAG_BASE,
3341
+ cr as Snackbar,
3342
+ Qe as TAG_BASE,
3149
3343
  _ as THINGS_BASE,
3150
- qr as Thing,
3151
- F as TimeUnit,
3152
- Kr as Unit,
3153
- ss as User,
3154
- as as Workspace,
3155
- us as api,
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
- bs as clearCalibration,
3158
- vt as createPatchObject,
3159
- Ss as ensureCalibration,
3160
- zt as extractErrorMessage,
3161
- se as findFirstGreaterOrEqual,
3162
- Se as findLastLessOrEqual,
3163
- fs as formatDate,
3164
- ds as formatDuration,
3165
- ht as getCSRFToken,
3166
- gs as getCalibration,
3167
- ms as getLastBenchmarkDetail,
3168
- ls as getObservationsEndpoint,
3169
- ws as getOperationTable,
3170
- be as measureEllapsedTime,
3171
- ys as onCalibrationChange,
3172
- ft as requestInterceptor,
3173
- dt as responseInterceptor,
3174
- Wr as runBenchmarks,
3175
- O as shouldUseWorker,
3176
- ps as subtractHours,
3177
- re as timeUnitMultipliers
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
  };