zeed 0.8.2 → 0.8.5

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.
@@ -1,4384 +1,8 @@
1
- 'use strict';
2
-
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
-
22
- // src/index.browser.ts
23
- var index_browser_exports = {};
24
- __export(index_browser_exports, {
25
- Channel: () => Channel,
26
- CryptoEncoder: () => CryptoEncoder,
27
- Currency: () => Currency,
28
- DAY_MS: () => DAY_MS,
29
- Day: () => Day,
30
- Emitter: () => Emitter,
31
- JsonEncoder: () => JsonEncoder,
32
- LocalChannel: () => LocalChannel,
33
- LocalStorage: () => LocalStorage,
34
- LogLevel: () => LogLevel,
35
- LogLevelAlias: () => LogLevelAlias,
36
- Logger: () => Logger,
37
- LoggerBrowserClassicHandler: () => LoggerBrowserClassicHandler,
38
- LoggerBrowserHandler: () => LoggerBrowserHandler,
39
- LoggerBrowserSetupDebugFactory: () => LoggerBrowserSetupDebugFactory,
40
- LoggerConsoleHandler: () => LoggerConsoleHandler,
41
- LoggerContext: () => LoggerContext,
42
- LoggerMemoryHandler: () => LoggerMemoryHandler,
43
- MemStorage: () => MemStorage,
44
- NoopEncoder: () => NoopEncoder,
45
- PoolTaskIdConflictResolution: () => PoolTaskIdConflictResolution,
46
- PoolTaskState: () => PoolTaskState,
47
- PubSub: () => PubSub,
48
- SerialQueue: () => SerialQueue,
49
- Uint8ArrayToHexDump: () => Uint8ArrayToHexDump,
50
- Uint8ArrayToJson: () => Uint8ArrayToJson,
51
- Uint8ArrayToString: () => Uint8ArrayToString,
52
- XRX: () => XRX,
53
- _decodeUtf8Polyfill: () => _decodeUtf8Polyfill,
54
- _encodeUtf8Polyfill: () => _encodeUtf8Polyfill,
55
- activateConsoleDebug: () => activateConsoleDebug,
56
- arrayAvg: () => arrayAvg,
57
- arrayBatches: () => arrayBatches,
58
- arrayEmptyInPlace: () => arrayEmptyInPlace,
59
- arrayFilterInPlace: () => arrayFilterInPlace,
60
- arrayFlatten: () => arrayFlatten,
61
- arrayIntersection: () => arrayIntersection,
62
- arrayIsEqual: () => arrayIsEqual,
63
- arrayMax: () => arrayMax,
64
- arrayMin: () => arrayMin,
65
- arrayMinus: () => arrayMinus,
66
- arrayRandomElement: () => arrayRandomElement,
67
- arrayRemoveElement: () => arrayRemoveElement,
68
- arraySetElement: () => arraySetElement,
69
- arrayShuffle: () => arrayShuffle,
70
- arrayShuffleForce: () => arrayShuffleForce,
71
- arrayShuffleInPlace: () => arrayShuffleInPlace,
72
- arraySorted: () => arraySorted,
73
- arraySortedNumbers: () => arraySortedNumbers,
74
- arraySum: () => arraySum,
75
- arraySymmetricDifference: () => arraySymmetricDifference,
76
- arrayToggleInPlace: () => arrayToggleInPlace,
77
- arrayUnion: () => arrayUnion,
78
- arrayUnique: () => arrayUnique,
79
- avg: () => avg,
80
- between: () => between,
81
- cloneJsonObject: () => cloneJsonObject,
82
- cloneObject: () => cloneObject,
83
- cmp: () => cmp,
84
- composeOrderby: () => composeOrderby,
85
- createArray: () => createArray,
86
- createLocalChannelPair: () => createLocalChannelPair,
87
- createPromise: () => createPromise,
88
- createPromiseProxy: () => createPromiseProxy,
89
- csv: () => csv,
90
- currency: () => currency,
91
- dateStringToDays: () => dateStringToDays,
92
- day: () => day,
93
- dayDay: () => dayDay,
94
- dayDiff: () => dayDiff,
95
- dayFromAny: () => dayFromAny,
96
- dayFromDate: () => dayFromDate,
97
- dayFromDateGMT: () => dayFromDateGMT,
98
- dayFromParts: () => dayFromParts,
99
- dayFromString: () => dayFromString,
100
- dayFromTimestamp: () => dayFromTimestamp,
101
- dayFromToday: () => dayFromToday,
102
- dayMonth: () => dayMonth,
103
- dayMonthStart: () => dayMonthStart,
104
- dayOffset: () => dayOffset,
105
- dayToDate: () => dayToDate,
106
- dayToDateGMT: () => dayToDateGMT,
107
- dayToParts: () => dayToParts,
108
- dayToString: () => dayToString,
109
- dayToTimestamp: () => dayToTimestamp,
110
- dayYear: () => dayYear,
111
- dayYearStart: () => dayYearStart,
112
- debounce: () => debounce,
113
- decimal: () => decimal,
114
- decimalCentsPart: () => decimalCentsPart,
115
- decimalFromCents: () => decimalFromCents,
116
- decimalToCents: () => decimalToCents,
117
- decodeBase16: () => decodeBase16,
118
- decodeBase32: () => decodeBase32,
119
- decodeBase58: () => decodeBase58,
120
- decodeBase62: () => decodeBase62,
121
- decodeBase64: () => decodeBase64,
122
- decrypt: () => decrypt,
123
- deepEqual: () => deepEqual,
124
- deepMerge: () => deepMerge,
125
- deriveKeyPbkdf2: () => deriveKeyPbkdf2,
126
- detect: () => detect,
127
- digest: () => digest,
128
- empty: () => empty,
129
- encodeBase16: () => encodeBase16,
130
- encodeBase32: () => encodeBase32,
131
- encodeBase58: () => encodeBase58,
132
- encodeBase62: () => encodeBase62,
133
- encodeBase64: () => encodeBase64,
134
- encodeQuery: () => encodeQuery,
135
- encrypt: () => encrypt,
136
- endSortWeight: () => endSortWeight,
137
- ensureKey: () => ensureKey,
138
- ensureKeyAsync: () => ensureKeyAsync,
139
- equalBinary: () => equalBinary,
140
- escapeHTML: () => escapeHTML,
141
- escapeRegExp: () => escapeRegExp,
142
- fetchBasic: () => fetchBasic,
143
- fetchJson: () => fetchJson,
144
- fetchOptionsBasicAuth: () => fetchOptionsBasicAuth,
145
- fetchOptionsFormURLEncoded: () => fetchOptionsFormURLEncoded,
146
- fetchOptionsJson: () => fetchOptionsJson,
147
- fetchText: () => fetchText,
148
- fixBrokenUth8String: () => fixBrokenUth8String,
149
- forEachDay: () => forEachDay,
150
- forTimes: () => forTimes,
151
- formatMessages: () => formatMessages,
152
- formatMilliseconds: () => formatMilliseconds,
153
- fromBase64: () => fromBase64,
154
- fromCamelCase: () => fromCamelCase,
155
- getGlobal: () => getGlobal,
156
- getGlobalContext: () => getGlobalContext,
157
- getGlobalEmitter: () => getGlobalEmitter,
158
- getNamespaceFilterString: () => getNamespaceFilterString,
159
- getNavigator: () => getNavigator,
160
- getSecureRandom: () => getSecureRandom,
161
- getSecureRandomIfPossible: () => getSecureRandomIfPossible,
162
- getTimestamp: () => getTimestamp,
163
- getWindow: () => getWindow,
164
- gravatarURLByEmail: () => gravatarURLByEmail,
165
- immediate: () => immediate,
166
- isArray: () => isArray,
167
- isBoolean: () => isBoolean,
168
- isBrowser: () => isBrowser,
169
- isEven: () => isEven,
170
- isHalf: () => isHalf,
171
- isInteger: () => isInteger,
172
- isLocalHost: () => isLocalHost,
173
- isNullOrUndefined: () => isNullOrUndefined,
174
- isNumber: () => isNumber,
175
- isObject: () => isObject,
176
- isPrime: () => isPrime,
177
- isPrimeRX: () => isPrimeRX,
178
- isPrimitive: () => isPrimitive,
179
- isPromise: () => isPromise,
180
- isRecord: () => isRecord,
181
- isSafeInteger: () => isSafeInteger,
182
- isString: () => isString,
183
- isTimeout: () => isTimeout,
184
- isUint8Array: () => isUint8Array,
185
- joinToUint8Array: () => joinToUint8Array,
186
- jsonStringify: () => jsonStringify,
187
- jsonToUint8Array: () => jsonToUint8Array,
188
- last: () => last,
189
- lazyListener: () => lazyListener,
190
- linkifyPlainText: () => linkifyPlainText,
191
- memoize: () => memoize,
192
- messages: () => messages,
193
- moveSortWeight: () => moveSortWeight,
194
- parseBasicAuth: () => parseBasicAuth,
195
- parseDate: () => parseDate,
196
- parseLogLevel: () => parseLogLevel,
197
- parseOrderby: () => parseOrderby,
198
- parseQuery: () => parseQuery,
199
- platform: () => platform,
200
- promisify: () => promisify,
201
- qid: () => qid,
202
- randomBoolean: () => randomBoolean,
203
- randomFloat: () => randomFloat,
204
- randomInt: () => randomInt,
205
- randomUint8Array: () => randomUint8Array,
206
- regExpEscape: () => regExpEscape,
207
- regExpString: () => regExpString,
208
- renderMessages: () => renderMessages,
209
- roundDown: () => roundDown,
210
- roundHalfAwayFromZero: () => roundHalfAwayFromZero,
211
- roundHalfDown: () => roundHalfDown,
212
- roundHalfEven: () => roundHalfEven,
213
- roundHalfOdd: () => roundHalfOdd,
214
- roundHalfTowardsZero: () => roundHalfTowardsZero,
215
- roundHalfUp: () => roundHalfUp,
216
- roundUp: () => roundUp,
217
- selectColor: () => selectColor,
218
- size: () => size,
219
- sleep: () => sleep,
220
- sortedItems: () => sortedItems,
221
- sortedOrderby: () => sortedOrderby,
222
- startSortWeight: () => startSortWeight,
223
- stringToBoolean: () => stringToBoolean,
224
- stringToFloat: () => stringToFloat,
225
- stringToInteger: () => stringToInteger,
226
- stringToUInt8Array: () => stringToUInt8Array,
227
- suid: () => suid,
228
- suidBytes: () => suidBytes,
229
- suidBytesDate: () => suidBytesDate,
230
- suidDate: () => suidDate,
231
- sum: () => sum,
232
- supportsColors: () => supportsColors,
233
- throttle: () => throttle,
234
- timeout: () => timeout,
235
- timeoutReached: () => timeoutReached,
236
- timoutError: () => timoutError,
237
- toBase64: () => toBase64,
238
- toBase64Url: () => toBase64Url,
239
- toBool: () => toBool,
240
- toCamelCase: () => toCamelCase,
241
- toCapitalize: () => toCapitalize,
242
- toCapitalizeWords: () => toCapitalizeWords,
243
- toFloat: () => toFloat,
244
- toHex: () => toHex,
245
- toHumanReadableUrl: () => toHumanReadableUrl,
246
- toInt: () => toInt,
247
- toString: () => toString,
248
- toUint8Array: () => toUint8Array,
249
- toValidFilename: () => toValidFilename,
250
- today: () => today,
251
- tryTimeout: () => tryTimeout,
252
- uname: () => uname,
253
- unescapeHTML: () => unescapeHTML,
254
- urlBase64ToUint8Array: () => urlBase64ToUint8Array,
255
- useAsyncMutex: () => useAsyncMutex,
256
- useBase: () => useBase,
257
- useDefer: () => useDefer,
258
- useDispose: () => useDispose,
259
- useDisposer: () => useDisposer,
260
- useEventListener: () => useEventListener,
261
- useExitHandler: () => useExitHandler,
262
- useInterval: () => useInterval,
263
- useLevelFilter: () => useLevelFilter,
264
- useMessageHub: () => useMessageHub,
265
- useMutex: () => useMutex,
266
- useNamespaceFilter: () => useNamespaceFilter,
267
- usePool: () => usePool,
268
- usePubSub: () => usePubSub,
269
- useRPC: () => useRPC,
270
- useTimeout: () => useTimeout,
271
- uuid: () => uuid,
272
- uuid32Decode: () => uuid32Decode,
273
- uuid32Encode: () => uuid32Encode,
274
- uuid32bit: () => uuid32bit,
275
- uuidB32: () => uuidB32,
276
- uuidBytes: () => uuidBytes,
277
- uuidDecode: () => uuidDecode,
278
- uuidEncode: () => uuidEncode,
279
- uuidv4: () => uuidv4,
280
- valueToBoolean: () => valueToBoolean,
281
- valueToFloat: () => valueToFloat,
282
- valueToInteger: () => valueToInteger,
283
- valueToString: () => valueToString,
284
- waitOn: () => waitOn
285
- });
286
- module.exports = __toCommonJS(index_browser_exports);
287
-
288
- // src/common/data/is.ts
289
- function isObject(obj) {
290
- return obj != null && typeof obj === "object";
291
- }
292
- __name(isObject, "isObject");
293
- function isPrimitive(obj) {
294
- return Object(obj) !== obj;
295
- }
296
- __name(isPrimitive, "isPrimitive");
297
- function isArray(obj) {
298
- return Array.isArray(obj);
299
- }
300
- __name(isArray, "isArray");
301
- function isRecord(obj) {
302
- return isObject(obj) && !isArray(obj);
303
- }
304
- __name(isRecord, "isRecord");
305
- function isString(obj) {
306
- return typeof obj === "string";
307
- }
308
- __name(isString, "isString");
309
- function isNumber(obj) {
310
- return typeof obj === "number";
311
- }
312
- __name(isNumber, "isNumber");
313
- function isInteger(obj) {
314
- return typeof obj === "number" && Number.isInteger(obj);
315
- }
316
- __name(isInteger, "isInteger");
317
- function isSafeInteger(obj) {
318
- return typeof obj === "number" && Number.isSafeInteger(obj);
319
- }
320
- __name(isSafeInteger, "isSafeInteger");
321
- function isBoolean(obj) {
322
- return typeof obj === "boolean";
323
- }
324
- __name(isBoolean, "isBoolean");
325
- function isNullOrUndefined(obj) {
326
- return obj == null;
327
- }
328
- __name(isNullOrUndefined, "isNullOrUndefined");
329
- function isUint8Array(obj) {
330
- return isObject(obj) && obj.constructor.name === "Uint8Array";
331
- }
332
- __name(isUint8Array, "isUint8Array");
333
-
334
- // src/common/data/deep.ts
335
- function deepEqual(a, b, hash = /* @__PURE__ */ new WeakSet()) {
336
- if (a === b) {
337
- return true;
338
- }
339
- if (hash.has(b)) {
340
- return true;
341
- }
342
- if (!isPrimitive(b)) {
343
- hash.add(b);
344
- }
345
- if (!(a instanceof Object) || !(b instanceof Object)) {
346
- return false;
347
- }
348
- if (a.constructor !== b.constructor) {
349
- return false;
350
- }
351
- if (a.length !== b.length) {
352
- return false;
353
- }
354
- for (let p in a) {
355
- if (!a.hasOwnProperty(p)) {
356
- continue;
357
- }
358
- if (!b.hasOwnProperty(p)) {
359
- return false;
360
- }
361
- let aa = a[p];
362
- let bb = b[p];
363
- if (!deepEqual(aa, bb, hash)) {
364
- return false;
365
- }
366
- }
367
- for (let p in b) {
368
- if (b.hasOwnProperty(p) && !a.hasOwnProperty(p)) {
369
- return false;
370
- }
371
- }
372
- return true;
373
- }
374
- __name(deepEqual, "deepEqual");
375
- function deepMerge(target, ...sources) {
376
- for (let source of sources) {
377
- if (!isObject(target)) {
378
- target = {};
379
- }
380
- if (source == null)
381
- continue;
382
- Object.keys(source).forEach((key) => {
383
- const targetValue = target[key];
384
- const sourceValue = source[key];
385
- if (Array.isArray(targetValue) && Array.isArray(sourceValue)) {
386
- target[key] = targetValue.concat(sourceValue);
387
- } else if (isObject(targetValue) && isObject(sourceValue)) {
388
- target[key] = deepMerge(Object.assign({}, targetValue), sourceValue);
389
- } else {
390
- target[key] = sourceValue;
391
- }
392
- });
393
- }
394
- return target;
395
- }
396
- __name(deepMerge, "deepMerge");
397
-
398
- // src/common/log-filter.ts
399
- function getNamespaceFilterString(defaultNamespaceFilter2) {
400
- if (defaultNamespaceFilter2 === true || defaultNamespaceFilter2 === "true" || defaultNamespaceFilter2 === "1" || typeof defaultNamespaceFilter2 === "number" && defaultNamespaceFilter2 !== 0) {
401
- defaultNamespaceFilter2 = "*";
402
- } else if (defaultNamespaceFilter2 === false || defaultNamespaceFilter2 === "false" || defaultNamespaceFilter2 === 0 || defaultNamespaceFilter2 === "0" || defaultNamespaceFilter2 == null || defaultNamespaceFilter2 === "null" || defaultNamespaceFilter2 === "undefined") {
403
- defaultNamespaceFilter2 = "";
404
- } else {
405
- defaultNamespaceFilter2 = String(defaultNamespaceFilter2);
406
- }
407
- return defaultNamespaceFilter2;
408
- }
409
- __name(getNamespaceFilterString, "getNamespaceFilterString");
410
- var defaultNamespaceFilter = getNamespaceFilterString(
411
- typeof process !== "undefined" ? process.env.ZEED ?? process.env.DEBUG : typeof localStorage !== "undefined" ? localStorage.zeed ?? localStorage.debug : "*"
412
- );
413
- function useNamespaceFilter(filter = defaultNamespaceFilter) {
414
- let fn;
415
- let reject = [];
416
- let accept = [];
417
- if (!filter) {
418
- fn = /* @__PURE__ */ __name(function(name) {
419
- return false;
420
- }, "fn");
421
- } else if (filter === "*") {
422
- fn = /* @__PURE__ */ __name(function(name) {
423
- return true;
424
- }, "fn");
425
- } else {
426
- let i;
427
- const split = filter.split(/[\s,]+/);
428
- const len = split.length;
429
- for (i = 0; i < len; i++) {
430
- if (!split[i]) {
431
- continue;
432
- }
433
- let template = split[i].replace(/\*/g, ".*?");
434
- if (template[0] === "-") {
435
- reject.push(new RegExp("^" + template.substr(1) + "$"));
436
- } else {
437
- accept.push(new RegExp("^" + template + "$"));
438
- }
439
- }
440
- fn = /* @__PURE__ */ __name(function(name) {
441
- if (reject.length === 0 && accept.length === 0) {
442
- return true;
443
- }
444
- let i2, len2;
445
- for (i2 = 0, len2 = reject.length; i2 < len2; i2++) {
446
- if (reject[i2].test(name)) {
447
- return false;
448
- }
449
- }
450
- for (i2 = 0, len2 = accept.length; i2 < len2; i2++) {
451
- if (accept[i2].test(name)) {
452
- return true;
453
- }
454
- }
455
- return false;
456
- }, "fn");
457
- }
458
- fn.accept = accept;
459
- fn.reject = reject;
460
- fn.filter = filter;
461
- return fn;
462
- }
463
- __name(useNamespaceFilter, "useNamespaceFilter");
464
- var defaultLevelFilter = typeof process !== "undefined" ? process.env.ZEED_LEVEL ?? process.env.LEVEL ?? process.env.DEBUG_LEVEL : typeof localStorage !== "undefined" ? localStorage.zeed_level ?? localStorage.level ?? localStorage.debug_level : void 0;
465
- function parseLogLevel(filter) {
466
- if (filter === false)
467
- return Infinity /* off */;
468
- if (typeof filter === "number")
469
- return filter;
470
- if (typeof filter === "string") {
471
- const l = LogLevelAlias[filter.toLocaleLowerCase().trim()];
472
- if (l != null)
473
- return l;
474
- }
475
- return -1 /* all */;
476
- }
477
- __name(parseLogLevel, "parseLogLevel");
478
- function useLevelFilter(filter = defaultLevelFilter) {
479
- const filterLevel = parseLogLevel(filter);
480
- return (level) => level >= filterLevel;
481
- }
482
- __name(useLevelFilter, "useLevelFilter");
483
-
484
- // src/common/log-base.ts
485
- var LogLevel = /* @__PURE__ */ ((LogLevel2) => {
486
- LogLevel2[LogLevel2["all"] = -1] = "all";
487
- LogLevel2[LogLevel2["debug"] = 0] = "debug";
488
- LogLevel2[LogLevel2["info"] = 1] = "info";
489
- LogLevel2[LogLevel2["warn"] = 2] = "warn";
490
- LogLevel2[LogLevel2["error"] = 3] = "error";
491
- LogLevel2[LogLevel2["fatal"] = 4] = "fatal";
492
- LogLevel2[LogLevel2["off"] = Infinity] = "off";
493
- return LogLevel2;
494
- })(LogLevel || {});
495
- var LogLevelAlias = {
496
- "*": -1 /* all */,
497
- a: -1 /* all */,
498
- all: -1 /* all */,
499
- d: 0 /* debug */,
500
- dbg: 0 /* debug */,
501
- debug: 0 /* debug */,
502
- i: 1 /* info */,
503
- inf: 1 /* info */,
504
- info: 1 /* info */,
505
- w: 2 /* warn */,
506
- warn: 2 /* warn */,
507
- warning: 2 /* warn */,
508
- e: 3 /* error */,
509
- err: 3 /* error */,
510
- error: 3 /* error */,
511
- fatal: 4 /* fatal */,
512
- off: Infinity /* off */,
513
- "-": Infinity /* off */
514
- };
515
- function LoggerContext(prefix = "") {
516
- let logHandlers = [LoggerConsoleHandler()];
517
- let logAssertLevel = 2 /* warn */;
518
- let logCheckNamespace = /* @__PURE__ */ __name((name) => true, "logCheckNamespace");
519
- let logLock = false;
520
- let logFactory = LoggerBaseFactory;
521
- function LoggerBaseFactory(name = "", level) {
522
- function log11(...messages2) {
523
- emit({
524
- name,
525
- messages: messages2,
526
- level: 0 /* debug */
527
- });
528
- }
529
- __name(log11, "log");
530
- log11.label = name;
531
- log11.active = true;
532
- log11.level = parseLogLevel(level ?? -1 /* all */);
533
- log11.extend = function(prefix2) {
534
- return logFactory(name ? `${name}:${prefix2}` : prefix2);
535
- };
536
- const emit = /* @__PURE__ */ __name((msg) => {
537
- if (log11.active === true) {
538
- if (msg.level >= Logger2.level && msg.level >= log11.level) {
539
- if (logCheckNamespace(name)) {
540
- for (let handler of logHandlers) {
541
- if (handler)
542
- handler(msg);
543
- }
544
- }
545
- }
546
- }
547
- }, "emit");
548
- log11.debug = function(...messages2) {
549
- emit({
550
- name,
551
- messages: messages2,
552
- level: 0 /* debug */
553
- });
554
- };
555
- log11.info = function(...messages2) {
556
- emit({
557
- name,
558
- messages: messages2,
559
- level: 1 /* info */
560
- });
561
- };
562
- log11.warn = function(...messages2) {
563
- emit({
564
- name,
565
- messages: messages2,
566
- level: 2 /* warn */
567
- });
568
- };
569
- log11.error = function(...messages2) {
570
- emit({
571
- name,
572
- messages: messages2,
573
- level: 3 /* error */
574
- });
575
- };
576
- log11.assert = function(cond, ...messages2) {
577
- if (!cond) {
578
- if (typeof console !== void 0) {
579
- if (console.assert) {
580
- console.assert(cond, ...messages2);
581
- } else {
582
- console.error(`Assert did fail with: ${cond}`, ...messages2);
583
- }
584
- }
585
- emit({
586
- name,
587
- messages: messages2 || [`Assert did fail with: ${cond}`],
588
- level: logAssertLevel
589
- });
590
- }
591
- };
592
- log11.assertEqual = function(value, expected, ...args) {
593
- let equal = deepEqual(value, expected);
594
- if (!equal) {
595
- log11.assert(
596
- equal,
597
- `Assert did fail. Expected ${expected} got ${value}`,
598
- expected,
599
- value,
600
- ...args
601
- );
602
- }
603
- };
604
- log11.assertNotEqual = function(value, expected, ...args) {
605
- let equal = deepEqual(value, expected);
606
- if (equal) {
607
- log11.assert(
608
- equal,
609
- `Assert did fail. Expected ${expected} not to be equal with ${value}`,
610
- expected,
611
- value,
612
- ...args
613
- );
614
- }
615
- };
616
- return log11;
617
- }
618
- __name(LoggerBaseFactory, "LoggerBaseFactory");
619
- function Logger2(name = "", level) {
620
- return logFactory(name, level);
621
- }
622
- __name(Logger2, "Logger");
623
- Logger2.registerHandler = function(handler) {
624
- logHandlers.push(handler);
625
- };
626
- Logger2.setFilter = function(namespaces3) {
627
- logCheckNamespace = useNamespaceFilter(namespaces3);
628
- };
629
- Logger2.setLock = (lock = true) => logLock = lock;
630
- Logger2.setHandlers = function(handlers = []) {
631
- if (logFactory !== LoggerBaseFactory) {
632
- logFactory = LoggerBaseFactory;
633
- }
634
- if (logLock)
635
- return;
636
- logHandlers = [...handlers].filter((h) => typeof h === "function");
637
- };
638
- Logger2.level = -1 /* all */;
639
- Logger2.setLogLevel = function(level = -1 /* all */) {
640
- if (logLock)
641
- return;
642
- Logger2.level = level;
643
- };
644
- Logger2.setFactory = function(factory) {
645
- if (logLock)
646
- return;
647
- logFactory = factory;
648
- };
649
- return Logger2;
650
- }
651
- __name(LoggerContext, "LoggerContext");
652
-
653
- // src/common/log-console.ts
654
- function LoggerConsoleHandler(opt = {}) {
655
- const {
656
- level = void 0,
657
- filter = void 0,
658
- colors: colors2 = true,
659
- levelHelper = false,
660
- nameBrackets = true,
661
- padding = 16
662
- } = opt;
663
- const matchesNamespace = useNamespaceFilter(filter);
664
- const matchesLevel = useLevelFilter(level);
665
- return (msg) => {
666
- if (!matchesLevel(msg.level))
667
- return;
668
- if (!matchesNamespace(msg.name))
669
- return;
670
- let name = msg.name ? `[${msg.name}]` : "";
671
- switch (msg.level) {
672
- case 1 /* info */:
673
- console.info(`I|* ${name}`, ...msg.messages);
674
- break;
675
- case 2 /* warn */:
676
- console.warn(`W|** ${name}`, ...msg.messages);
677
- break;
678
- case 3 /* error */:
679
- console.error(`E|*** ${name}`, ...msg.messages);
680
- break;
681
- default:
682
- console.debug(`D| ${name}`, ...msg.messages);
683
- break;
684
- }
685
- };
686
- }
687
- __name(LoggerConsoleHandler, "LoggerConsoleHandler");
688
-
689
- // src/common/global.ts
690
- function _global() {
691
- if (typeof self !== "undefined")
692
- return self;
693
- if (typeof window !== "undefined")
694
- return window;
695
- if (typeof global !== "undefined")
696
- return global;
697
- if (typeof globalThis !== "undefined")
698
- return globalThis;
699
- throw new Error("unable to locate global object");
700
- }
701
- __name(_global, "_global");
702
- function getGlobalContext() {
703
- let gcontext = _global();
704
- if (gcontext._zeedGlobal == null) {
705
- gcontext._zeedGlobal = {};
706
- }
707
- return gcontext._zeedGlobal;
708
- }
709
- __name(getGlobalContext, "getGlobalContext");
710
-
711
- // src/common/log.ts
712
- var globalLogger;
713
- function getLoggerContext() {
714
- let logger = LoggerContext();
715
- logger.setHandlers([LoggerConsoleHandler()]);
716
- return logger;
717
- }
718
- __name(getLoggerContext, "getLoggerContext");
719
- try {
720
- let _global2 = getGlobalContext();
721
- if (_global2 != null) {
722
- if ((_global2 == null ? void 0 : _global2.logger) == null) {
723
- globalLogger = getLoggerContext();
724
- _global2.logger = globalLogger;
725
- } else {
726
- globalLogger = _global2.logger;
727
- }
728
- } else {
729
- globalLogger = getLoggerContext();
730
- }
731
- } catch (e) {
732
- globalLogger = getLoggerContext();
733
- }
734
- var Logger = globalLogger;
735
-
736
- // src/common/data/bin.ts
737
- var log = Logger("bin");
738
- function _encodeUtf8Polyfill(str) {
739
- const encodedString = unescape(encodeURIComponent(str));
740
- const len = encodedString.length;
741
- const buf = new Uint8Array(len);
742
- for (let i = 0; i < len; i++) {
743
- buf[i] = encodedString.codePointAt(i) || 0;
744
- }
745
- return buf;
746
- }
747
- __name(_encodeUtf8Polyfill, "_encodeUtf8Polyfill");
748
- function _decodeUtf8Polyfill(buf) {
749
- let remainingLen = buf.length;
750
- let encodedString = "";
751
- let bufPos = 0;
752
- while (remainingLen > 0) {
753
- const nextLen = remainingLen < 1e4 ? remainingLen : 1e4;
754
- const bytes = buf.subarray(bufPos, bufPos + nextLen);
755
- bufPos += nextLen;
756
- encodedString += String.fromCodePoint.apply(null, bytes);
757
- remainingLen -= nextLen;
758
- }
759
- return decodeURIComponent(escape(encodedString));
760
- }
761
- __name(_decodeUtf8Polyfill, "_decodeUtf8Polyfill");
762
- var _textEncoder;
763
- function stringToUInt8Array(text) {
764
- if (_textEncoder == null) {
765
- _textEncoder = _encodeUtf8Polyfill;
766
- if (typeof TextEncoder !== "undefined") {
767
- const encoder = new TextEncoder();
768
- _textEncoder = /* @__PURE__ */ __name((data) => encoder.encode(data), "_textEncoder");
769
- }
770
- }
771
- return _textEncoder(text.normalize("NFC"));
772
- }
773
- __name(stringToUInt8Array, "stringToUInt8Array");
774
- var _textDecoder;
775
- function Uint8ArrayToString(bin) {
776
- if (_textDecoder == null) {
777
- _textDecoder = _decodeUtf8Polyfill;
778
- if (typeof TextDecoder !== "undefined") {
779
- const decoder = new TextDecoder("utf-8", { ignoreBOM: true });
780
- _textDecoder = /* @__PURE__ */ __name((data) => decoder.decode(data), "_textDecoder");
781
- }
782
- }
783
- return _textDecoder(bin).normalize("NFC");
784
- }
785
- __name(Uint8ArrayToString, "Uint8ArrayToString");
786
- function toUint8Array(data) {
787
- if (data instanceof ArrayBuffer)
788
- return new Uint8Array(data);
789
- if (typeof data === "string")
790
- return stringToUInt8Array(data);
791
- if (data.length)
792
- return new Uint8Array(data);
793
- return data;
794
- }
795
- __name(toUint8Array, "toUint8Array");
796
- function joinToUint8Array(...args) {
797
- let length = 0;
798
- const bins = args.flat(1).map((d) => {
799
- const b = toUint8Array(d);
800
- length += b.length;
801
- return b;
802
- });
803
- let bin = new Uint8Array(length);
804
- let cursor = 0;
805
- for (let b of bins) {
806
- bin.set(b, cursor);
807
- cursor += b.length;
808
- }
809
- return bin;
810
- }
811
- __name(joinToUint8Array, "joinToUint8Array");
812
- function toHex(bin) {
813
- if (typeof Buffer !== "undefined") {
814
- return Buffer.from(toUint8Array(bin)).toString("hex");
815
- }
816
- const h = "0123456789abcdef";
817
- let s = "";
818
- for (const v of [...toUint8Array(bin)]) {
819
- s += h[v >> 4] + h[v & 15];
820
- }
821
- return s;
822
- }
823
- __name(toHex, "toHex");
824
- function toBase64(bin) {
825
- const bytes = toUint8Array(bin);
826
- if (typeof Buffer !== "undefined") {
827
- return Buffer.from(bytes).toString("base64");
828
- }
829
- let s = "";
830
- for (let i = 0; i < bytes.byteLength; i++) {
831
- s += String.fromCharCode(bytes[i]);
832
- }
833
- return btoa(s);
834
- }
835
- __name(toBase64, "toBase64");
836
- function toBase64Url(bin) {
837
- const bytes = toUint8Array(bin);
838
- if (typeof Buffer !== "undefined") {
839
- return Buffer.from(bytes).toString("base64url");
840
- }
841
- let s = "";
842
- for (let i = 0; i < bytes.byteLength; i++) {
843
- s += String.fromCharCode(bytes[i]);
844
- }
845
- return btoa(s).replace(/\+/g, "-").replace(/\//g, "_");
846
- }
847
- __name(toBase64Url, "toBase64Url");
848
- function fromBase64(s) {
849
- if (typeof Buffer !== "undefined") {
850
- const buf = Buffer.from(s, "base64");
851
- return new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength);
852
- }
853
- const a = atob(s);
854
- const bytes = new Uint8Array(a.length);
855
- for (let i = 0; i < a.length; i++) {
856
- bytes[i] = a.charCodeAt(i);
857
- }
858
- return bytes;
859
- }
860
- __name(fromBase64, "fromBase64");
861
- function equalBinary(a, b) {
862
- if (a.byteLength !== b.byteLength)
863
- return false;
864
- const aa = toUint8Array(a);
865
- const bb = toUint8Array(b);
866
- for (let i = 0; i < aa.length; i++) {
867
- if (aa[i] !== bb[i]) {
868
- return false;
869
- }
870
- }
871
- return true;
872
- }
873
- __name(equalBinary, "equalBinary");
874
- function jsonToUint8Array(json) {
875
- try {
876
- return stringToUInt8Array(JSON.stringify(json));
877
- } catch (err) {
878
- log.warn("jsonToUint8Array", json);
879
- throw err;
880
- }
881
- }
882
- __name(jsonToUint8Array, "jsonToUint8Array");
883
- function Uint8ArrayToJson(data) {
884
- try {
885
- return JSON.parse(Uint8ArrayToString(data));
886
- } catch (err) {
887
- log.warn("Uint8ArrayToJson", data);
888
- throw err;
889
- }
890
- }
891
- __name(Uint8ArrayToJson, "Uint8ArrayToJson");
892
- function Uint8ArrayToHexDump(buffer, blockSize) {
893
- if (typeof buffer === "string") ; else if (buffer instanceof ArrayBuffer && buffer.byteLength !== void 0) {
894
- buffer = String.fromCharCode.apply(
895
- String,
896
- [].slice.call(new Uint8Array(buffer))
897
- );
898
- } else if (Array.isArray(buffer)) {
899
- buffer = String.fromCharCode.apply(String, buffer);
900
- } else if (buffer.constructor === Uint8Array) {
901
- buffer = String.fromCharCode.apply(String, [].slice.call(buffer));
902
- } else {
903
- return false;
904
- }
905
- blockSize = blockSize || 16;
906
- var lines = [];
907
- var hex = "0123456789ABCDEF";
908
- for (var b = 0; b < buffer.length; b += blockSize) {
909
- var block = buffer.slice(b, Math.min(b + blockSize, buffer.length));
910
- var addr = ("0000" + b.toString(16)).slice(-4);
911
- var codes = block.split("").map((ch) => {
912
- var code = ch.charCodeAt(0);
913
- return " " + hex[(240 & code) >> 4] + hex[15 & code];
914
- }).join("");
915
- codes += " ".repeat(blockSize - block.length);
916
- var chars = block.replace(/[\x00-\x1F\x20]/g, ".");
917
- chars += " ".repeat(blockSize - block.length);
918
- lines.push(addr + " " + codes + " " + chars);
919
- }
920
- return lines.join("\n");
921
- }
922
- __name(Uint8ArrayToHexDump, "Uint8ArrayToHexDump");
923
-
924
- // src/common/crypto.ts
925
- function randomUint8Array(length = 16) {
926
- let randomBytes = new Uint8Array(length);
927
- if (typeof crypto !== "undefined" && crypto.getRandomValues) {
928
- crypto.getRandomValues(randomBytes);
929
- } else {
930
- for (let i = 0; i < length; i++) {
931
- randomBytes[i] = Math.floor(Math.random() * 256);
932
- }
933
- }
934
- return randomBytes;
935
- }
936
- __name(randomUint8Array, "randomUint8Array");
937
- var DEFAULT_HASH_ALG = "SHA-256";
938
- var DEFAULT_CRYPTO_ALG = "AES-GCM";
939
- var DEFAULT_DERIVE_ALG = "PBKDF2";
940
- async function digest(message, algorithm = DEFAULT_HASH_ALG) {
941
- return toUint8Array(
942
- await crypto.subtle.digest(algorithm, toUint8Array(message))
943
- );
944
- }
945
- __name(digest, "digest");
946
- async function deriveKeyPbkdf2(secret, opt = {}) {
947
- const secretBuffer = toUint8Array(secret);
948
- const keyMaterial = await crypto.subtle.importKey(
949
- "raw",
950
- secretBuffer,
951
- DEFAULT_DERIVE_ALG,
952
- false,
953
- ["deriveKey"]
954
- );
955
- return await crypto.subtle.deriveKey(
956
- {
957
- name: DEFAULT_DERIVE_ALG,
958
- salt: opt.salt ? toUint8Array(opt.salt) : new Uint8Array(0),
959
- iterations: opt.iterations ?? 1e5,
960
- hash: DEFAULT_HASH_ALG
961
- },
962
- keyMaterial,
963
- {
964
- name: DEFAULT_CRYPTO_ALG,
965
- length: 256
966
- },
967
- true,
968
- ["encrypt", "decrypt"]
969
- );
970
- }
971
- __name(deriveKeyPbkdf2, "deriveKeyPbkdf2");
972
- var MAGIC_ID = new Uint8Array([1, 1]);
973
- async function encrypt(data, key) {
974
- const iv = randomUint8Array(12);
975
- const cipher = await crypto.subtle.encrypt(
976
- { name: DEFAULT_CRYPTO_ALG, iv },
977
- key,
978
- data
979
- );
980
- const binCypher = new Uint8Array(cipher);
981
- const bufferLength = MAGIC_ID.length + iv.length + binCypher.length;
982
- const buffer = new Uint8Array(bufferLength);
983
- let pos = 0;
984
- buffer.set(MAGIC_ID, pos);
985
- pos += MAGIC_ID.length;
986
- buffer.set(iv, pos);
987
- pos += iv.length;
988
- buffer.set(binCypher, pos);
989
- return buffer;
990
- }
991
- __name(encrypt, "encrypt");
992
- async function decrypt(data, key) {
993
- let magic = data.subarray(0, 2);
994
- if (!equalBinary(magic, MAGIC_ID)) {
995
- return Promise.reject(`Unknown magic ${magic}`);
996
- }
997
- let iv = data.subarray(2, 2 + 12);
998
- let cipher = data.subarray(2 + 12, data.length);
999
- const plain = await crypto.subtle.decrypt(
1000
- { name: DEFAULT_CRYPTO_ALG, iv },
1001
- key,
1002
- cipher
1003
- );
1004
- return new Uint8Array(plain);
1005
- }
1006
- __name(decrypt, "decrypt");
1007
-
1008
- // src/common/csv.ts
1009
- var separator = ",";
1010
- function filterFloat(value) {
1011
- if (/^([-+])?([0-9]+(\.[0-9]+)?|Infinity)$/.test(value)) {
1012
- return Number(value);
1013
- }
1014
- return NaN;
1015
- }
1016
- __name(filterFloat, "filterFloat");
1017
- function escape2(field) {
1018
- if (field == void 0) {
1019
- return "";
1020
- }
1021
- if (!isNaN(filterFloat(field)) && isFinite(field)) {
1022
- return parseFloat(field);
1023
- }
1024
- return '"' + String(field).replace(/"/g, '""') + '"';
1025
- }
1026
- __name(escape2, "escape");
1027
- function csv(data, headerRow) {
1028
- let body = "";
1029
- if (headerRow) {
1030
- body = headerRow.join(separator) + "\r\n";
1031
- }
1032
- for (let i = 0; i < data.length; i++) {
1033
- body += data[i].map(escape2).join(separator) + "\r\n";
1034
- }
1035
- return body;
1036
- }
1037
- __name(csv, "csv");
1038
-
1039
- // src/common/data/math.ts
1040
- function getSecureRandom() {
1041
- return crypto.getRandomValues(new Uint32Array(1))[0] / 4294967295;
1042
- }
1043
- __name(getSecureRandom, "getSecureRandom");
1044
- function getSecureRandomIfPossible() {
1045
- return typeof crypto !== "undefined" ? getSecureRandom() : Math.random();
1046
- }
1047
- __name(getSecureRandomIfPossible, "getSecureRandomIfPossible");
1048
- function randomBoolean(bias = 0.25) {
1049
- return getSecureRandomIfPossible() < bias;
1050
- }
1051
- __name(randomBoolean, "randomBoolean");
1052
- function randomInt(max = 100, min = 0) {
1053
- return min + Math.floor(getSecureRandomIfPossible() * (max - min));
1054
- }
1055
- __name(randomInt, "randomInt");
1056
- function randomFloat(max = 100, min = 0) {
1057
- return min + getSecureRandomIfPossible() * (max - min);
1058
- }
1059
- __name(randomFloat, "randomFloat");
1060
- function between(min, value, max) {
1061
- return Math.max(min, Math.min(max, value));
1062
- }
1063
- __name(between, "between");
1064
- function sum(array) {
1065
- return array.reduce((acc, value) => acc + value, 0);
1066
- }
1067
- __name(sum, "sum");
1068
- function avg(array) {
1069
- return sum(array) / array.length;
1070
- }
1071
- __name(avg, "avg");
1072
- function isPrimeRX(value) {
1073
- return !/^1?$|^(11+?)\1+$/.test("1".repeat(value));
1074
- }
1075
- __name(isPrimeRX, "isPrimeRX");
1076
- function isPrime(value) {
1077
- for (var i = 2; i < value; i++)
1078
- if (value % i === 0)
1079
- return false;
1080
- return value > 1;
1081
- }
1082
- __name(isPrime, "isPrime");
1083
-
1084
- // src/common/data/orderby.ts
1085
- function parseOrderby(value = "") {
1086
- let [field = "", orderby = "asc"] = value.split(" ");
1087
- orderby = orderby.toLowerCase();
1088
- return {
1089
- field,
1090
- orderby,
1091
- asc: orderby !== "desc",
1092
- desc: orderby === "desc"
1093
- };
1094
- }
1095
- __name(parseOrderby, "parseOrderby");
1096
- function composeOrderby(field, asc = true) {
1097
- return `${field} ${asc ? "asc" : "desc"}`;
1098
- }
1099
- __name(composeOrderby, "composeOrderby");
1100
- function cmp(a, b, asc = true) {
1101
- const aa = a || 0;
1102
- const bb = b || 0;
1103
- return aa > bb ? asc ? 1 : -1 : aa < bb ? asc ? -1 : 1 : 0;
1104
- }
1105
- __name(cmp, "cmp");
1106
- function sortedOrderby(values, ...orderby) {
1107
- if (orderby.length > 0) {
1108
- let orderByList = orderby.map(parseOrderby);
1109
- let sortValues = Array.from(values);
1110
- sortValues.sort((a, b) => {
1111
- for (let { field, asc } of orderByList) {
1112
- const result = cmp(a[field], b[field], asc);
1113
- if (result !== 0)
1114
- return result;
1115
- }
1116
- return 0;
1117
- });
1118
- return sortValues;
1119
- }
1120
- return values;
1121
- }
1122
- __name(sortedOrderby, "sortedOrderby");
1123
-
1124
- // src/common/data/array.ts
1125
- function arrayUnique(x) {
1126
- return x.filter((n, index) => x.indexOf(n) === index);
1127
- }
1128
- __name(arrayUnique, "arrayUnique");
1129
- function arrayMinus(x, y) {
1130
- return arrayUnique(x.filter((n) => !y.includes(n)));
1131
- }
1132
- __name(arrayMinus, "arrayMinus");
1133
- function arrayUnion(...a) {
1134
- return arrayUnique(a.reduce((acc = [], value) => acc.concat(value), []));
1135
- }
1136
- __name(arrayUnion, "arrayUnion");
1137
- function arrayFlatten(...list) {
1138
- return list.flat(Infinity);
1139
- }
1140
- __name(arrayFlatten, "arrayFlatten");
1141
- function arrayIntersection(x, y) {
1142
- return arrayUnique(x).filter((n) => y.includes(n));
1143
- }
1144
- __name(arrayIntersection, "arrayIntersection");
1145
- function arraySymmetricDifference(x, y) {
1146
- return arrayMinus(arrayUnion(x, y), arrayIntersection(x, y));
1147
- }
1148
- __name(arraySymmetricDifference, "arraySymmetricDifference");
1149
- function arrayRemoveElement(arr, el) {
1150
- if (arr && Array.isArray(arr)) {
1151
- let index;
1152
- while ((index = arr.indexOf(el)) !== -1) {
1153
- arr.splice(index, 1);
1154
- }
1155
- return arr;
1156
- }
1157
- return [];
1158
- }
1159
- __name(arrayRemoveElement, "arrayRemoveElement");
1160
- function arraySetElement(arr, el) {
1161
- if (!arr.includes(el))
1162
- arr.push(el);
1163
- return arr;
1164
- }
1165
- __name(arraySetElement, "arraySetElement");
1166
- function arrayFilterInPlace(array, fn) {
1167
- array.splice(0, array.length, ...array.filter(fn));
1168
- return array;
1169
- }
1170
- __name(arrayFilterInPlace, "arrayFilterInPlace");
1171
- function arrayToggleInPlace(array, el) {
1172
- const index = array.findIndex((e) => e === el);
1173
- if (index >= 0)
1174
- array.splice(index, 1);
1175
- else
1176
- array.push(el);
1177
- return array;
1178
- }
1179
- __name(arrayToggleInPlace, "arrayToggleInPlace");
1180
- function arrayEmptyInPlace(array) {
1181
- array.splice(0, array.length);
1182
- return array;
1183
- }
1184
- __name(arrayEmptyInPlace, "arrayEmptyInPlace");
1185
- function arraySorted(arr, cond = cmp) {
1186
- return Array.from(arr).sort(cond);
1187
- }
1188
- __name(arraySorted, "arraySorted");
1189
- function arraySortedNumbers(arr) {
1190
- return arraySorted(arr, (l, r) => l - r);
1191
- }
1192
- __name(arraySortedNumbers, "arraySortedNumbers");
1193
- function arrayIsEqual(array1, array2) {
1194
- return array1.length === array2.length && array1.every((value, index) => value === array2[index]);
1195
- }
1196
- __name(arrayIsEqual, "arrayIsEqual");
1197
- function arrayShuffleInPlace(array) {
1198
- array.sort(() => getSecureRandomIfPossible() > 0.5 ? 1 : -1);
1199
- return array;
1200
- }
1201
- __name(arrayShuffleInPlace, "arrayShuffleInPlace");
1202
- function arrayShuffle(array) {
1203
- return arrayShuffleInPlace(Array.from(array));
1204
- }
1205
- __name(arrayShuffle, "arrayShuffle");
1206
- function arrayShuffleForce(array) {
1207
- while (array.length > 1) {
1208
- const copy = Array.from(array);
1209
- arrayShuffleInPlace(copy);
1210
- if (!arrayIsEqual(array, copy))
1211
- return copy;
1212
- }
1213
- return array;
1214
- }
1215
- __name(arrayShuffleForce, "arrayShuffleForce");
1216
- function arrayRandomElement(array) {
1217
- return array[Math.floor(getSecureRandomIfPossible() * array.length)];
1218
- }
1219
- __name(arrayRandomElement, "arrayRandomElement");
1220
- function arrayMax(...array) {
1221
- return arrayFlatten(array).reduce(
1222
- (acc, value) => acc != null ? value > acc ? value : acc : value,
1223
- void 0
1224
- );
1225
- }
1226
- __name(arrayMax, "arrayMax");
1227
- function arrayMin(...array) {
1228
- return arrayFlatten(array).reduce(
1229
- (acc, value) => acc != null ? value < acc ? value : acc : value,
1230
- void 0
1231
- );
1232
- }
1233
- __name(arrayMin, "arrayMin");
1234
- function arraySum(...array) {
1235
- return arrayFlatten(array).reduce((acc, value) => acc + value, 0);
1236
- }
1237
- __name(arraySum, "arraySum");
1238
- function arrayAvg(...array) {
1239
- let flatArray = arrayFlatten(array);
1240
- return flatArray.reduce((acc, value) => acc + value, 0) / flatArray.length;
1241
- }
1242
- __name(arrayAvg, "arrayAvg");
1243
- function arrayBatches(array, chunckLength) {
1244
- let chunks = [];
1245
- let i = 0;
1246
- const n = array.length;
1247
- while (i < n) {
1248
- chunks.push(array.slice(i, i += chunckLength));
1249
- }
1250
- return chunks;
1251
- }
1252
- __name(arrayBatches, "arrayBatches");
1253
- function createArray(size2 = 0, item) {
1254
- if (size2 <= 0)
1255
- return [];
1256
- let arr = new Array(size2);
1257
- for (let i = 0; i < size2; i++) {
1258
- arr[i] = item instanceof Function ? item(i) : item;
1259
- }
1260
- return arr;
1261
- }
1262
- __name(createArray, "createArray");
1263
-
1264
- // src/common/data/basex.ts
1265
- var log2 = Logger("zeed:basex");
1266
- var alphabets = {
1267
- "2": "01",
1268
- "8": "01234567",
1269
- "11": "0123456789a",
1270
- "16": "0123456789abcdef",
1271
- "32": "0123456789ABCDEFGHJKMNPQRSTVWXYZ",
1272
- "32-rfc": "ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",
1273
- "32-hex": "0123456789ABCDEFGHIJKLMNOPQRSTUV",
1274
- "32-zbase": "ybndrfg8ejkmcpqxot1uwisza345h769",
1275
- "36": "0123456789abcdefghijklmnopqrstuvwxyz",
1276
- "58": "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",
1277
- "62": "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",
1278
- "64": "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",
1279
- "64-url": "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",
1280
- "66": "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.!~",
1281
- "85": "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz!#$%&()*+-;<=>?@^_`{|}~"
1282
- };
1283
- function useBase(alphaOrBase) {
1284
- let ALPHABET;
1285
- if (typeof alphaOrBase === "string") {
1286
- ALPHABET = alphaOrBase;
1287
- } else {
1288
- ALPHABET = alphabets[String(alphaOrBase)];
1289
- if (ALPHABET == null)
1290
- throw new Error(`Unknown base ${alphaOrBase}`);
1291
- }
1292
- if (ALPHABET.length >= 255)
1293
- throw new TypeError("Alphabet too long");
1294
- const BASE_MAP = new Uint8Array(256);
1295
- for (let j = 0; j < BASE_MAP.length; j++) {
1296
- BASE_MAP[j] = 255;
1297
- }
1298
- for (let i = 0; i < ALPHABET.length; i++) {
1299
- const x = ALPHABET.charAt(i);
1300
- const xc = x.charCodeAt(0);
1301
- if (BASE_MAP[xc] !== 255)
1302
- throw new TypeError(x + " is ambiguous");
1303
- BASE_MAP[xc] = i;
1304
- }
1305
- const BASE = ALPHABET.length;
1306
- const LEADER = ALPHABET.charAt(0);
1307
- const FACTOR = Math.log(BASE) / Math.log(256);
1308
- const iFACTOR = Math.log(256) / Math.log(BASE);
1309
- function encode(source, padToLength = -1) {
1310
- let data = toUint8Array(source);
1311
- if (data.byteLength === 0)
1312
- return "";
1313
- let length = 0;
1314
- let pbegin = 0;
1315
- const pend = data.byteLength;
1316
- while (pbegin !== pend && data[pbegin] === 0)
1317
- pbegin++;
1318
- const size2 = (pend - pbegin) * iFACTOR + 1 >>> 0;
1319
- const dataEncoded = new Uint8Array(size2);
1320
- while (pbegin !== pend) {
1321
- let carry = data[pbegin];
1322
- let i = 0;
1323
- for (let it1 = size2 - 1; (carry !== 0 || i < length) && it1 !== -1; it1--, i++) {
1324
- carry += 256 * dataEncoded[it1] >>> 0;
1325
- dataEncoded[it1] = carry % BASE >>> 0;
1326
- carry = carry / BASE >>> 0;
1327
- }
1328
- if (carry !== 0) {
1329
- log2.warn("Non-zero carry", data, padToLength, i, size2);
1330
- throw new Error("Non-zero carry");
1331
- }
1332
- length = i;
1333
- pbegin++;
1334
- }
1335
- let it2 = size2 - length;
1336
- while (it2 !== size2 && dataEncoded[it2] === 0) {
1337
- it2++;
1338
- }
1339
- let str = "";
1340
- for (; it2 < size2; ++it2)
1341
- str += ALPHABET.charAt(dataEncoded[it2]);
1342
- if (padToLength > 0) {
1343
- return str.padStart(padToLength, LEADER);
1344
- }
1345
- return str;
1346
- }
1347
- __name(encode, "encode");
1348
- function decode(source, padToLength = -1) {
1349
- if (typeof source !== "string")
1350
- throw new TypeError("Expected String");
1351
- if (source.length === 0)
1352
- return new Uint8Array();
1353
- source = source.replace(/\s+/gi, "");
1354
- let psz = 0;
1355
- let length = 0;
1356
- while (source[psz] === LEADER) {
1357
- psz++;
1358
- }
1359
- const size2 = (source.length - psz) * FACTOR + 1 >>> 0;
1360
- const dataDecoded = new Uint8Array(size2);
1361
- while (source[psz]) {
1362
- let carry = BASE_MAP[source.charCodeAt(psz)];
1363
- if (carry === 255)
1364
- throw new Error(`Unsupported character "${source[psz]}"`);
1365
- let i = 0;
1366
- for (let it3 = size2 - 1; (carry !== 0 || i < length) && it3 !== -1; it3--, i++) {
1367
- carry += BASE * dataDecoded[it3] >>> 0;
1368
- dataDecoded[it3] = carry % 256 >>> 0;
1369
- carry = carry / 256 >>> 0;
1370
- }
1371
- if (carry !== 0)
1372
- throw new Error("Non-zero carry");
1373
- length = i;
1374
- psz++;
1375
- }
1376
- let it4 = size2 - length;
1377
- while (it4 !== size2 && dataDecoded[it4] === 0) {
1378
- it4++;
1379
- }
1380
- if (padToLength > 0) {
1381
- return new Uint8Array([
1382
- ...new Uint8Array(padToLength - dataDecoded.length + it4),
1383
- ...dataDecoded.slice(it4)
1384
- ]);
1385
- }
1386
- return dataDecoded.slice(it4);
1387
- }
1388
- __name(decode, "decode");
1389
- return {
1390
- encode,
1391
- decode
1392
- };
1393
- }
1394
- __name(useBase, "useBase");
1395
- var { encode: encodeBase16, decode: decodeBase16 } = useBase(16);
1396
- var { encode: encodeBase32, decode: decodeBase32 } = useBase(32);
1397
- var { encode: encodeBase58, decode: decodeBase58 } = useBase(58);
1398
- var { encode: encodeBase62, decode: decodeBase62 } = useBase(62);
1399
- var { encode: encodeBase64, decode: decodeBase64 } = useBase(62);
1400
-
1401
- // src/common/data/camelcase.ts
1402
- var toCamelCase = /* @__PURE__ */ __name((s) => {
1403
- if (s.length > 0) {
1404
- if (/^[A-Z0-9_\-\ ]*$/g.test(s)) {
1405
- s = s.toLowerCase();
1406
- }
1407
- s = s.replace(/^[-_\ ]+/gi, "").replace(/[-_\ ]+$/gi, "").replace(/[-_\ ]+([a-z0-9])/gi, ($0, $1) => $1.toUpperCase());
1408
- s = s[0].toLowerCase() + s.substring(1);
1409
- }
1410
- return s;
1411
- }, "toCamelCase");
1412
- function toCapitalize(s) {
1413
- return s.charAt(0).toUpperCase() + s.toLowerCase().slice(1);
1414
- }
1415
- __name(toCapitalize, "toCapitalize");
1416
- function toCapitalizeWords(s) {
1417
- return s.replace(/\w\S*/g, toCapitalize);
1418
- }
1419
- __name(toCapitalizeWords, "toCapitalizeWords");
1420
- function fromCamelCase(str, separator2 = "-") {
1421
- separator2 = typeof separator2 === "undefined" ? "_" : separator2;
1422
- return str.replace(/([a-z\d])([A-Z])/g, "$1" + separator2 + "$2").replace(/([A-Z]+)([A-Z][a-z\d]+)/g, "$1" + separator2 + "$2").toLowerCase();
1423
- }
1424
- __name(fromCamelCase, "fromCamelCase");
1425
-
1426
- // src/common/data/json.ts
1427
- function serializer(replacer, cycleReplacer) {
1428
- var stack = [], keys = [];
1429
- if (cycleReplacer == null)
1430
- cycleReplacer = /* @__PURE__ */ __name(function(key, value) {
1431
- if (stack[0] === value)
1432
- return "[Circular ~]";
1433
- return "[Circular ~." + keys.slice(0, stack.indexOf(value)).join(".") + "]";
1434
- }, "cycleReplacer");
1435
- return function(key, value) {
1436
- if (stack.length > 0) {
1437
- var thisPos = stack.indexOf(this);
1438
- ~thisPos ? stack.splice(thisPos + 1) : stack.push(this);
1439
- ~thisPos ? keys.splice(thisPos, Infinity, key) : keys.push(key);
1440
- if (~stack.indexOf(value))
1441
- value = cycleReplacer == null ? void 0 : cycleReplacer.call(this, key, value);
1442
- } else
1443
- stack.push(value);
1444
- return replacer == null ? value : replacer.call(this, key, value);
1445
- };
1446
- }
1447
- __name(serializer, "serializer");
1448
- function jsonStringify(obj, replacer, spaces, cycleReplacer) {
1449
- return JSON.stringify(obj, serializer(replacer, cycleReplacer), spaces);
1450
- }
1451
- __name(jsonStringify, "jsonStringify");
1452
-
1453
- // src/common/data/convert.ts
1454
- var TRUE_VALUES_LIST = ["1", "true", "yes", "y", "on"];
1455
- function stringToBoolean(value, defaultValue = false) {
1456
- if (value == null || typeof value !== "string")
1457
- return defaultValue;
1458
- return TRUE_VALUES_LIST.includes(String(value).trim().toLowerCase());
1459
- }
1460
- __name(stringToBoolean, "stringToBoolean");
1461
- function stringToInteger(value, defaultValue = 0) {
1462
- if (value == null || typeof value !== "string")
1463
- return defaultValue;
1464
- return parseInt(value.trim(), 10) ?? defaultValue;
1465
- }
1466
- __name(stringToInteger, "stringToInteger");
1467
- function stringToFloat(value, defaultValue = 0) {
1468
- if (value == null || typeof value !== "string")
1469
- return defaultValue;
1470
- return parseFloat(value.trim()) ?? defaultValue;
1471
- }
1472
- __name(stringToFloat, "stringToFloat");
1473
- function valueToBoolean(value, defaultValue = false) {
1474
- if (value == null)
1475
- return defaultValue;
1476
- if (typeof value === "boolean")
1477
- return value;
1478
- if (typeof value === "number")
1479
- return value !== 0;
1480
- return TRUE_VALUES_LIST.includes(String(value).trim().toLowerCase());
1481
- }
1482
- __name(valueToBoolean, "valueToBoolean");
1483
- function valueToInteger(value, defaultValue = 0) {
1484
- if (value == null)
1485
- return defaultValue;
1486
- if (typeof value === "boolean")
1487
- return value ? 1 : 0;
1488
- if (typeof value === "number")
1489
- return Math.floor(value);
1490
- return parseInt(String(value).trim(), 10) ?? defaultValue;
1491
- }
1492
- __name(valueToInteger, "valueToInteger");
1493
- function valueToFloat(value, defaultValue = 0) {
1494
- if (value == null)
1495
- return defaultValue;
1496
- if (typeof value === "boolean")
1497
- return value ? 1 : 0;
1498
- if (typeof value === "number")
1499
- return Math.floor(value);
1500
- return parseFloat(String(value).trim()) ?? defaultValue;
1501
- }
1502
- __name(valueToFloat, "valueToFloat");
1503
- function valueToString(value, defaultValue = "") {
1504
- if (value == null)
1505
- return defaultValue;
1506
- return String(value) ?? defaultValue;
1507
- }
1508
- __name(valueToString, "valueToString");
1509
- var toFloat = valueToFloat;
1510
- var toInt = valueToInteger;
1511
- var toString = valueToString;
1512
- var toBool = valueToBoolean;
1513
- function formatMessages(messages2, opt = {}) {
1514
- const { trace = true, pretty = true } = opt;
1515
- return messages2.map((obj) => {
1516
- if (obj && typeof obj === "object") {
1517
- if (pretty && (obj instanceof Uint8Array || obj instanceof ArrayBuffer)) {
1518
- return "\n" + Uint8ArrayToHexDump(obj) + "\n";
1519
- }
1520
- if (obj instanceof Error) {
1521
- if (!trace) {
1522
- return `${obj.name || "Error"}: ${obj.message}`;
1523
- }
1524
- return `${obj.name || "Error"}: ${obj.message}
1525
- ${obj.stack}`;
1526
- }
1527
- return pretty ? jsonStringify(obj, null, 2) : jsonStringify(obj);
1528
- }
1529
- return String(obj);
1530
- });
1531
- }
1532
- __name(formatMessages, "formatMessages");
1533
- function renderMessages(messages2, opt = {}) {
1534
- return formatMessages(messages2, opt).join(" ");
1535
- }
1536
- __name(renderMessages, "renderMessages");
1537
- function fixBrokenUth8String(brokenString) {
1538
- try {
1539
- return decodeURIComponent(escape(brokenString));
1540
- } catch (e) {
1541
- }
1542
- return brokenString;
1543
- }
1544
- __name(fixBrokenUth8String, "fixBrokenUth8String");
1545
-
1546
- // src/common/data/currency.ts
1547
- var defaults = {
1548
- symbol: "$",
1549
- separator: ",",
1550
- decimal: ".",
1551
- errorOnInvalid: false,
1552
- precision: 2,
1553
- pattern: "!#",
1554
- negativePattern: "-!#",
1555
- format,
1556
- fromCents: false
1557
- };
1558
- var round = /* @__PURE__ */ __name((v) => Math.round(v), "round");
1559
- var pow = /* @__PURE__ */ __name((p) => Math.pow(10, p), "pow");
1560
- var rounding = /* @__PURE__ */ __name((value, increment) => round(value / increment) * increment, "rounding");
1561
- var groupRegex = /(\d)(?=(\d{3})+\b)/g;
1562
- var vedicRegex = /(\d)(?=(\d\d)+\d\b)/g;
1563
- function currency(value, opts = {}) {
1564
- return new Currency(value, opts);
1565
- }
1566
- __name(currency, "currency");
1567
- var _Currency = class {
1568
- constructor(value, opts = {}) {
1569
- let settings = Object.assign({}, defaults, opts);
1570
- let precision = pow(settings.precision ?? 2);
1571
- let v = parse(value, settings);
1572
- this.intValue = v;
1573
- this.value = v / precision;
1574
- settings.increment = settings.increment || 1 / precision;
1575
- if (settings.useVedic) {
1576
- settings.groups = vedicRegex;
1577
- } else {
1578
- settings.groups = groupRegex;
1579
- }
1580
- this._settings = settings;
1581
- this._precision = precision;
1582
- }
1583
- add(number) {
1584
- let { intValue, _settings, _precision } = this;
1585
- return currency(
1586
- (intValue += parse(number, _settings)) / (_settings.fromCents ? 1 : _precision),
1587
- _settings
1588
- );
1589
- }
1590
- subtract(number) {
1591
- let { intValue, _settings, _precision } = this;
1592
- return currency(
1593
- (intValue -= parse(number, _settings)) / (_settings.fromCents ? 1 : _precision),
1594
- _settings
1595
- );
1596
- }
1597
- multiply(number) {
1598
- let { intValue, _settings, _precision } = this;
1599
- return currency(
1600
- (intValue *= number) / (_settings.fromCents ? 1 : pow(_precision)),
1601
- _settings
1602
- );
1603
- }
1604
- divide(number) {
1605
- let { intValue, _settings } = this;
1606
- return currency(intValue /= parse(number, _settings, false), _settings);
1607
- }
1608
- distribute(count) {
1609
- let { intValue, _precision, _settings } = this, distribution = [], split = Math[intValue >= 0 ? "floor" : "ceil"](intValue / count), pennies = Math.abs(intValue - split * count), precision = _settings.fromCents ? 1 : _precision;
1610
- for (; count !== 0; count--) {
1611
- let item = currency(split / precision, _settings);
1612
- pennies-- > 0 && (item = item[intValue >= 0 ? "add" : "subtract"](1 / precision));
1613
- distribution.push(item);
1614
- }
1615
- return distribution;
1616
- }
1617
- dollars() {
1618
- return ~~this.value;
1619
- }
1620
- cents() {
1621
- let { intValue, _precision } = this;
1622
- return ~~(intValue % _precision);
1623
- }
1624
- format(options) {
1625
- let { _settings } = this;
1626
- if (typeof options === "function") {
1627
- return options(this, _settings);
1628
- }
1629
- return _settings.format(this, Object.assign({}, _settings, options));
1630
- }
1631
- toString() {
1632
- let { intValue, _precision, _settings } = this;
1633
- return rounding(intValue / _precision, _settings.increment).toFixed(
1634
- _settings.precision
1635
- );
1636
- }
1637
- toJSON() {
1638
- return this.value;
1639
- }
1640
- static sum(...array) {
1641
- return arrayFlatten(array).reduce(
1642
- (acc, value) => currency(acc).add(value),
1643
- this.zero
1644
- );
1645
- }
1646
- static avg(...array) {
1647
- let arr = arrayFlatten(array);
1648
- return arr.reduce((acc, value) => currency(acc).add(value), this.zero).divide(arr.length);
1649
- }
1650
- };
1651
- var Currency = _Currency;
1652
- __name(Currency, "Currency");
1653
- Currency.zero = new _Currency(0);
1654
- Currency.one = new _Currency(1);
1655
- Currency.hundred = new _Currency(100);
1656
- function parse(value, opts, useRounding = true) {
1657
- let v = 0, { decimal: decimal2, errorOnInvalid, precision: decimals, fromCents } = opts, precision = pow(decimals), isNumber2 = typeof value === "number";
1658
- if (value instanceof Currency && fromCents) {
1659
- return value.intValue;
1660
- }
1661
- if (isNumber2 || value instanceof Currency) {
1662
- v = value instanceof Currency ? value.value : value;
1663
- } else if (typeof value === "string") {
1664
- let regex = new RegExp("[^-\\d" + decimal2 + "]", "g"), decimalString = new RegExp("\\" + decimal2, "g");
1665
- v = value.replace(/\((.*)\)/, "-$1").replace(regex, "").replace(decimalString, ".");
1666
- v = v || 0;
1667
- } else {
1668
- if (errorOnInvalid) {
1669
- throw Error("Invalid Input");
1670
- }
1671
- v = 0;
1672
- }
1673
- if (!fromCents) {
1674
- v *= precision;
1675
- v = v.toFixed(4);
1676
- }
1677
- return useRounding ? round(v) : v;
1678
- }
1679
- __name(parse, "parse");
1680
- function format(currency2, settings) {
1681
- let { pattern: pattern2, negativePattern, symbol, separator: separator2, decimal: decimal2, groups } = settings, split = ("" + currency2).replace(/^-/, "").split("."), dollars = split[0], cents = split[1];
1682
- return (currency2.value >= 0 ? pattern2 : negativePattern).replace("!", symbol).replace(
1683
- "#",
1684
- dollars.replace(groups, "$1" + separator2) + (cents ? decimal2 + cents : "")
1685
- );
1686
- }
1687
- __name(format, "format");
1688
-
1689
- // src/common/data/day.ts
1690
- var DAY_MS = 864e5;
1691
- function dayYear(day2) {
1692
- return Math.floor(day2 / 1e4);
1693
- }
1694
- __name(dayYear, "dayYear");
1695
- function dayMonth(day2) {
1696
- return Math.floor(day2 / 100 % 100);
1697
- }
1698
- __name(dayMonth, "dayMonth");
1699
- function dayDay(day2) {
1700
- return Math.floor(day2 % 100);
1701
- }
1702
- __name(dayDay, "dayDay");
1703
- function dayToParts(day2) {
1704
- return [dayYear(day2), dayMonth(day2), dayDay(day2)];
1705
- }
1706
- __name(dayToParts, "dayToParts");
1707
- function dayToDate(day2, gmt = false) {
1708
- return gmt ? new Date(`${dayToString(day2)}T00:00:00.000Z`) : new Date(
1709
- day2 / 1e4,
1710
- day2 / 100 % 100 - 1,
1711
- day2 % 100
1712
- );
1713
- }
1714
- __name(dayToDate, "dayToDate");
1715
- function dayFromToday() {
1716
- return dayFromDate(new Date());
1717
- }
1718
- __name(dayFromToday, "dayFromToday");
1719
- function dayFromAny(value, gmt = false) {
1720
- if (typeof value === "number") {
1721
- if (value < 100)
1722
- return;
1723
- return value;
1724
- } else if (typeof value === "string") {
1725
- return dayFromString(value);
1726
- } else if (Array.isArray(value) && value.length === 3) {
1727
- const [year, month, day2] = value;
1728
- return dayFromParts(year, month, day2);
1729
- } else if (value instanceof Date) {
1730
- return dayFromDate(value, gmt);
1731
- }
1732
- }
1733
- __name(dayFromAny, "dayFromAny");
1734
- function dayToDateGMT(day2) {
1735
- return dayToDate(day2, true);
1736
- }
1737
- __name(dayToDateGMT, "dayToDateGMT");
1738
- function dayFromDate(date, gmt = false) {
1739
- return gmt ? dayFromString(date.toISOString()) : date.getFullYear() * 1e4 + (date.getMonth() + 1) * 100 + date.getDate();
1740
- }
1741
- __name(dayFromDate, "dayFromDate");
1742
- function dayFromDateGMT(date) {
1743
- return dayFromDate(date, true);
1744
- }
1745
- __name(dayFromDateGMT, "dayFromDateGMT");
1746
- function dayToTimestamp(day2, gmt = true) {
1747
- return dayToDate(day2, gmt).getTime();
1748
- }
1749
- __name(dayToTimestamp, "dayToTimestamp");
1750
- function dayFromTimestamp(ms, gmt = true) {
1751
- return dayFromDate(new Date(ms), gmt);
1752
- }
1753
- __name(dayFromTimestamp, "dayFromTimestamp");
1754
- function dayToString(day2, sep = "-") {
1755
- let baseString = String(day2);
1756
- return baseString.slice(0, 4) + sep + baseString.slice(4, 6) + sep + baseString.slice(6, 8);
1757
- }
1758
- __name(dayToString, "dayToString");
1759
- function dayFromParts(year, month = 1, day2 = 1) {
1760
- if (month < 1 || month > 12 || day2 < 1 || day2 > 31)
1761
- return;
1762
- return year * 1e4 + month * 100 + day2;
1763
- }
1764
- __name(dayFromParts, "dayFromParts");
1765
- function dayFromString(value) {
1766
- const string = String(value).replace(/[^0-9]/g, "").slice(0, 8);
1767
- if (string.length === 8)
1768
- return +string;
1769
- }
1770
- __name(dayFromString, "dayFromString");
1771
- function dayMonthStart(day2, offset = 0) {
1772
- let year = dayYear(day2);
1773
- let month = dayMonth(day2);
1774
- if (offset !== 0) {
1775
- month += offset;
1776
- year += Math.floor((month - 1) / 12);
1777
- month = Math.floor((month - 1) % 12) + 1;
1778
- if (month === 0)
1779
- month = 12;
1780
- }
1781
- return dayFromParts(year, month, 1);
1782
- }
1783
- __name(dayMonthStart, "dayMonthStart");
1784
- function dayYearStart(day2, offset = 0) {
1785
- let year = dayYear(day2);
1786
- return dayFromParts(year + offset, 1, 1);
1787
- }
1788
- __name(dayYearStart, "dayYearStart");
1789
- function dayOffset(day2, offset) {
1790
- return dayFromTimestamp(dayToTimestamp(day2) + offset * DAY_MS);
1791
- }
1792
- __name(dayOffset, "dayOffset");
1793
- function dayDiff(left, right) {
1794
- return Math.round((dayToTimestamp(right) - dayToTimestamp(left)) / DAY_MS);
1795
- }
1796
- __name(dayDiff, "dayDiff");
1797
-
1798
- // src/common/exec/promise.ts
1799
- var { warn } = Logger("zeed:promise");
1800
- function createPromise() {
1801
- let resolve, reject;
1802
- let promise = new Promise((_resolve, _reject) => {
1803
- resolve = _resolve;
1804
- reject = _reject;
1805
- });
1806
- return [promise, resolve, reject];
1807
- }
1808
- __name(createPromise, "createPromise");
1809
- async function sleep(milliSeconds) {
1810
- return new Promise((resolve) => setTimeout(resolve, milliSeconds));
1811
- }
1812
- __name(sleep, "sleep");
1813
- async function immediate() {
1814
- return new Promise((resolve) => setTimeout(resolve, 0));
1815
- }
1816
- __name(immediate, "immediate");
1817
- var timeoutReached = Symbol("timeout");
1818
- async function timeout(promise, milliSeconds, timeoutValue = timeoutReached) {
1819
- return new Promise(async (resolve, reject) => {
1820
- let done = false;
1821
- const timeout2 = setTimeout(() => {
1822
- done = true;
1823
- resolve(timeoutValue);
1824
- }, milliSeconds);
1825
- try {
1826
- let result = await promise;
1827
- clearTimeout(timeout2);
1828
- if (!done)
1829
- resolve(result);
1830
- } catch (err) {
1831
- clearTimeout(timeout2);
1832
- if (!done)
1833
- reject(err);
1834
- }
1835
- });
1836
- }
1837
- __name(timeout, "timeout");
1838
- var timoutError = new Error("Timeout reached");
1839
- function isTimeout(value) {
1840
- return value === timeoutReached || value === timoutError;
1841
- }
1842
- __name(isTimeout, "isTimeout");
1843
- async function tryTimeout(promise, milliSeconds) {
1844
- if (milliSeconds <= 0) {
1845
- return await promise;
1846
- }
1847
- return new Promise(async (resolve, reject) => {
1848
- let done = false;
1849
- const timeout2 = setTimeout(() => {
1850
- done = true;
1851
- reject(timoutError);
1852
- }, milliSeconds);
1853
- try {
1854
- let result = await promise;
1855
- clearTimeout(timeout2);
1856
- if (!done)
1857
- resolve(result);
1858
- } catch (err) {
1859
- clearTimeout(timeout2);
1860
- if (!done)
1861
- reject(err);
1862
- }
1863
- });
1864
- }
1865
- __name(tryTimeout, "tryTimeout");
1866
- function waitOn(obj, event, timeoutMS = 1e3) {
1867
- return new Promise((resolve, reject) => {
1868
- let fn = /* @__PURE__ */ __name((value) => {
1869
- if (timer) {
1870
- clearTimeout(timer);
1871
- done();
1872
- resolve(value);
1873
- }
1874
- }, "fn");
1875
- let done = /* @__PURE__ */ __name(() => {
1876
- timer = null;
1877
- if (obj.off) {
1878
- obj.off(event, fn);
1879
- } else if (obj.removeEventListener) {
1880
- obj.removeEventListener(event, fn);
1881
- } else {
1882
- warn("No remove listener method found for", obj, event);
1883
- }
1884
- }, "done");
1885
- let timer = setTimeout(() => {
1886
- done();
1887
- reject(new Error(`Did not response in time`));
1888
- }, timeoutMS);
1889
- if (obj.on) {
1890
- obj.on(event, fn);
1891
- } else if (obj.addEventListener) {
1892
- obj.addEventListener(event, fn);
1893
- } else {
1894
- warn("No listener method found for", obj);
1895
- }
1896
- });
1897
- }
1898
- __name(waitOn, "waitOn");
1899
- function isPromise(value) {
1900
- return Boolean(
1901
- value && (value instanceof Promise || typeof value.then === "function")
1902
- );
1903
- }
1904
- __name(isPromise, "isPromise");
1905
- function promisify(value) {
1906
- return Promise.resolve(value);
1907
- }
1908
- __name(promisify, "promisify");
1909
-
1910
- // src/common/data/day-legacy.ts
1911
- var Day = class {
1912
- get value() {
1913
- return this.days;
1914
- }
1915
- constructor(days) {
1916
- var _a;
1917
- if (typeof days === "number") {
1918
- this.days = days;
1919
- return;
1920
- }
1921
- if (days != null) {
1922
- days = (_a = Day.from(days)) == null ? void 0 : _a.days;
1923
- }
1924
- if (days == null) {
1925
- const date = new Date();
1926
- this.days = date.getFullYear() * 1e4 + (date.getMonth() + 1) * 100 + date.getDate();
1927
- } else {
1928
- this.days = days;
1929
- }
1930
- }
1931
- static fromNumber(n) {
1932
- return new Day(n);
1933
- }
1934
- static fromString(dateString) {
1935
- return Day.from(+dateString.replace(/[^0-9]/g, "").slice(0, 8));
1936
- }
1937
- static fromDate(date, gmt = false) {
1938
- return gmt ? Day.fromString(date.toISOString().substr(0, 10)) : Day.from(
1939
- date.getFullYear() * 1e4 + (date.getMonth() + 1) * 100 + date.getDate()
1940
- );
1941
- }
1942
- static fromDateGMT(date) {
1943
- return Day.fromDate(date, true);
1944
- }
1945
- static from(value, gmt = false) {
1946
- if (typeof value === "number") {
1947
- if (value < 100)
1948
- return;
1949
- return new Day(value);
1950
- } else if (typeof value === "string") {
1951
- return Day.fromString(value);
1952
- } else if (Array.isArray(value) && value.length === 3) {
1953
- const [year, month = 1, day2 = 1] = value;
1954
- if (month < 1 || month > 12 || day2 < 1 || day2 > 31)
1955
- return;
1956
- return new Day(year * 1e4 + month * 100 + day2);
1957
- } else if (value instanceof Date) {
1958
- return Day.fromDate(value, gmt);
1959
- } else if (value instanceof Day) {
1960
- return value;
1961
- }
1962
- }
1963
- toNumber() {
1964
- return this.days;
1965
- }
1966
- toJson() {
1967
- return this.days;
1968
- }
1969
- toString(sep = "-") {
1970
- let baseString = String(this.days);
1971
- return baseString.slice(0, 4) + sep + baseString.slice(4, 6) + sep + baseString.slice(6, 8);
1972
- }
1973
- toDate(gmt = false) {
1974
- return gmt ? new Date(`${this.toString()}T00:00:00.000Z`) : new Date(
1975
- this.days / 1e4,
1976
- this.days / 100 % 100 - 1,
1977
- this.days % 100
1978
- );
1979
- }
1980
- toDateGMT() {
1981
- return this.toDate(true);
1982
- }
1983
- get year() {
1984
- return Math.floor(this.days / 1e4);
1985
- }
1986
- get month() {
1987
- return Math.floor(this.days / 100 % 100);
1988
- }
1989
- get day() {
1990
- return Math.floor(this.days % 100);
1991
- }
1992
- dayOffset(offset) {
1993
- return Day.fromDateGMT(
1994
- new Date(this.toDateGMT().getTime() + offset * DAY_MS)
1995
- );
1996
- }
1997
- monthStart() {
1998
- return Day.from([this.year, this.month, 1]);
1999
- }
2000
- yearStart() {
2001
- return Day.from([this.year, 1, 1]);
2002
- }
2003
- monthOffset(offset) {
2004
- let m = this.month + offset;
2005
- let mm = Math.floor((m - 1) % 12) + 1;
2006
- if (mm === 0)
2007
- mm = 12;
2008
- let yy = Math.floor((m - 1) / 12);
2009
- return Day.from([this.year + yy, mm, this.day]);
2010
- }
2011
- daysUntil(otherDay) {
2012
- var _a;
2013
- return Math.round(
2014
- (((_a = new Day(otherDay)) == null ? void 0 : _a.toDateGMT().getTime()) - this.toDateGMT().getTime()) / DAY_MS
2015
- );
2016
- }
2017
- yesterday() {
2018
- return this.dayOffset(-1);
2019
- }
2020
- tomorrow() {
2021
- return this.dayOffset(1);
2022
- }
2023
- };
2024
- __name(Day, "Day");
2025
- async function forEachDay(from, to, handler) {
2026
- let start = Day.from(from);
2027
- let end = Day.from(to);
2028
- while (start && end && (start == null ? void 0 : start.days) <= (end == null ? void 0 : end.days)) {
2029
- let result = handler(start);
2030
- if (isPromise(result)) {
2031
- await result;
2032
- }
2033
- start = start.dayOffset(1);
2034
- }
2035
- }
2036
- __name(forEachDay, "forEachDay");
2037
- function today() {
2038
- return new Day();
2039
- }
2040
- __name(today, "today");
2041
- function day(days) {
2042
- return new Day(days);
2043
- }
2044
- __name(day, "day");
2045
- function dateStringToDays(dateString) {
2046
- return Day.fromDate(new Date(dateString)).days;
2047
- }
2048
- __name(dateStringToDays, "dateStringToDays");
2049
-
2050
- // src/common/data/decimal.ts
2051
- function decimal(value, decimalPlaces = 2) {
2052
- return +(+value).toFixed(decimalPlaces);
2053
- }
2054
- __name(decimal, "decimal");
2055
- function decimalFromCents(value, decimalPlaces = 2) {
2056
- return +(+value / Math.pow(10, decimalPlaces)).toFixed(decimalPlaces);
2057
- }
2058
- __name(decimalFromCents, "decimalFromCents");
2059
- function decimalToCents(value, decimalPlaces = 2) {
2060
- return Math.round(+value * Math.pow(10, decimalPlaces));
2061
- }
2062
- __name(decimalToCents, "decimalToCents");
2063
- function decimalCentsPart(value, decimalPlaces = 2) {
2064
- return decimalPlaces * (decimal(value, decimalPlaces) % 1);
2065
- }
2066
- __name(decimalCentsPart, "decimalCentsPart");
2067
-
2068
- // src/common/data/html.ts
2069
- var escapeHTML = /* @__PURE__ */ __name((s) => s.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/'/g, "&apos;").replace(/"/g, "&quot;"), "escapeHTML");
2070
- var unescapeHTML = /* @__PURE__ */ __name((s) => s.replace(/&lt;/gi, "<").replace(/&gt;/gi, ">").replace(/&quot;/gi, '"').replace(/&apos;/gi, "'").replace(/&amp;/gi, "&"), "unescapeHTML");
2071
-
2072
- // src/common/data/path.ts
2073
- var MAX_FILENAME_LENGTH = 100;
2074
- var reControlChars = /[\u0000-\u001F\u0080-\u009F]/g;
2075
- var reRelativePath = /^\.+/;
2076
- var reTrailingPeriods = /\.+$/;
2077
- function filenameReservedRegex() {
2078
- return /[<>:"/\\|?*\u0000-\u001F]/g;
2079
- }
2080
- __name(filenameReservedRegex, "filenameReservedRegex");
2081
- function windowsReservedNameRegex() {
2082
- return /^(con|prn|aux|nul|com\d|lpt\d)$/i;
2083
- }
2084
- __name(windowsReservedNameRegex, "windowsReservedNameRegex");
2085
- function toValidFilename(string) {
2086
- if (typeof string !== "string") {
2087
- throw new TypeError("Expected a string");
2088
- }
2089
- const replacement = "_";
2090
- if (filenameReservedRegex().test(replacement) && reControlChars.test(replacement)) {
2091
- throw new Error(
2092
- "Replacement string cannot contain reserved filename characters"
2093
- );
2094
- }
2095
- string = string.replace(filenameReservedRegex(), replacement).replace(reControlChars, replacement).replace(reRelativePath, replacement).replace(reTrailingPeriods, "");
2096
- string = windowsReservedNameRegex().test(string) ? string + replacement : string;
2097
- return string.slice(0, MAX_FILENAME_LENGTH);
2098
- }
2099
- __name(toValidFilename, "toValidFilename");
2100
-
2101
- // src/common/data/regexp.ts
2102
- var rxEscape = /[\\\-\[\]\/{}()*+?.^$|]/g;
2103
- function escapeRegExp(value) {
2104
- if (!value)
2105
- return "";
2106
- if (value instanceof RegExp) {
2107
- return value.source;
2108
- }
2109
- return value.replace(rxEscape, "\\$&");
2110
- }
2111
- __name(escapeRegExp, "escapeRegExp");
2112
-
2113
- // src/common/data/rounding.ts
2114
- var isHalf = /* @__PURE__ */ __name((value) => Math.abs(value) % 1 === 0.5, "isHalf");
2115
- var isEven = /* @__PURE__ */ __name((value) => value % 2 === 0, "isEven");
2116
- var roundUp = /* @__PURE__ */ __name((value) => Math.ceil(value), "roundUp");
2117
- var roundDown = /* @__PURE__ */ __name((value) => Math.floor(value), "roundDown");
2118
- var roundHalfUp = /* @__PURE__ */ __name((value) => Math.round(value), "roundHalfUp");
2119
- var roundHalfOdd = /* @__PURE__ */ __name((value) => {
2120
- const rounded = Math.round(value);
2121
- if (!isHalf(value)) {
2122
- return rounded;
2123
- }
2124
- return isEven(rounded) ? rounded - 1 : rounded;
2125
- }, "roundHalfOdd");
2126
- var roundHalfAwayFromZero = /* @__PURE__ */ __name((value) => {
2127
- return isHalf(value) ? Math.sign(value) * Math.ceil(Math.abs(value)) : Math.round(value);
2128
- }, "roundHalfAwayFromZero");
2129
- var roundHalfDown = /* @__PURE__ */ __name((value) => isHalf(value) ? Math.floor(value) : Math.round(value), "roundHalfDown");
2130
- var roundHalfEven = /* @__PURE__ */ __name((value) => {
2131
- const rounded = Math.round(value);
2132
- if (!isHalf(value)) {
2133
- return rounded;
2134
- }
2135
- return isEven(rounded) ? rounded : rounded - 1;
2136
- }, "roundHalfEven");
2137
- var roundHalfTowardsZero = /* @__PURE__ */ __name((value) => isHalf(value) ? Math.sign(value) * Math.floor(Math.abs(value)) : Math.round(value), "roundHalfTowardsZero");
2138
-
2139
- // src/common/data/sortable.ts
2140
- function startSortWeight(items) {
2141
- return items.reduce((acc, item) => Math.min(acc, item.sort_weight || 0), 0) - 1 - getSecureRandomIfPossible();
2142
- }
2143
- __name(startSortWeight, "startSortWeight");
2144
- function endSortWeight(items) {
2145
- return items.reduce((acc, item) => Math.max(acc, item.sort_weight || 0), 0) + 1 + getSecureRandomIfPossible();
2146
- }
2147
- __name(endSortWeight, "endSortWeight");
2148
- function moveSortWeight(newIndex, oldIndex, items) {
2149
- let count = items.length;
2150
- const moveLower = newIndex < oldIndex;
2151
- if (count <= 0 || newIndex >= count - 1) {
2152
- return endSortWeight(items);
2153
- }
2154
- if (newIndex <= 0) {
2155
- return startSortWeight(items);
2156
- }
2157
- items = sortedItems([...items]);
2158
- const step = moveLower ? -1 : 0;
2159
- const lower = items[newIndex + step].sort_weight || 0;
2160
- const upper = items[newIndex + step + 1].sort_weight || 0;
2161
- const distance = upper - lower;
2162
- if (distance === 0) {
2163
- if (moveLower) {
2164
- return startSortWeight(items);
2165
- }
2166
- return endSortWeight(items);
2167
- }
2168
- const middle = lower + distance / 2;
2169
- const fuzzy = distance * 0.01 * (getSecureRandomIfPossible() - 0.5);
2170
- return middle + fuzzy;
2171
- }
2172
- __name(moveSortWeight, "moveSortWeight");
2173
- function sortedItems(items) {
2174
- items.sort((a, b) => (a.sort_weight || 0) - (b.sort_weight || 0));
2175
- return items;
2176
- }
2177
- __name(sortedItems, "sortedItems");
2178
-
2179
- // src/common/data/url.ts
2180
- var findURL = /((?:(?:(?:https?|ftp):)?\/\/)(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z0-9\u00a1-\uffff][a-z0-9\u00a1-\uffff_-]{0,62})?[a-z0-9\u00a1-\uffff]\.)+(?:[a-z\u00a1-\uffff]{2,}\.?))(?::\d{2,5})?(?:[/?#]\S*)?)/gim;
2181
- function linkifyPlainText(text) {
2182
- return text.split(findURL).map((part, i) => {
2183
- const escapedPart = escapeHTML(part);
2184
- return i % 2 ? `<a target="_blank" href="${escapedPart}">${toHumanReadableUrl(
2185
- escapedPart
2186
- )}</a>` : escapedPart;
2187
- }).join("");
2188
- }
2189
- __name(linkifyPlainText, "linkifyPlainText");
2190
- function toHumanReadableUrl(url) {
2191
- return url.replace(/^https?:\/\/(www\.)?/, "").replace(/\/$/, "");
2192
- }
2193
- __name(toHumanReadableUrl, "toHumanReadableUrl");
2194
- function encodeQuery(data) {
2195
- let pairs = [];
2196
- for (let [key, value] of Object.entries(data)) {
2197
- if (value != null) {
2198
- if (!Array.isArray(value)) {
2199
- value = [value];
2200
- }
2201
- for (let v of value) {
2202
- if (v != null) {
2203
- pairs.push(
2204
- encodeURIComponent(key) + "=" + encodeURIComponent(String(v))
2205
- );
2206
- }
2207
- }
2208
- }
2209
- }
2210
- return pairs.join("&");
2211
- }
2212
- __name(encodeQuery, "encodeQuery");
2213
- function parseQuery(queryString) {
2214
- let query = {};
2215
- let pairs = (queryString[0] === "?" ? queryString.substr(1) : queryString).split("&");
2216
- for (let i = 0; i < pairs.length; i++) {
2217
- let pair = pairs[i].split("=");
2218
- let key = decodeURIComponent(pair[0]);
2219
- let value = decodeURIComponent(pair[1] || "");
2220
- if (query[key] != null) {
2221
- if (!Array.isArray(query[key])) {
2222
- query[key] = [query[key]];
2223
- }
2224
- query[key].push(value);
2225
- } else {
2226
- query[key] = value;
2227
- }
2228
- }
2229
- return query;
2230
- }
2231
- __name(parseQuery, "parseQuery");
2232
-
2233
- // src/common/data/utils.ts
2234
- function ensureKey(obj, key, createFn) {
2235
- let value = obj[key];
2236
- if (value === void 0) {
2237
- value = createFn(key, obj);
2238
- obj[key] = value;
2239
- }
2240
- return value;
2241
- }
2242
- __name(ensureKey, "ensureKey");
2243
- async function ensureKeyAsync(obj, key, createFn) {
2244
- let value = obj[key];
2245
- if (value === void 0) {
2246
- value = await createFn(key, obj);
2247
- obj[key] = value;
2248
- }
2249
- return value;
2250
- }
2251
- __name(ensureKeyAsync, "ensureKeyAsync");
2252
- function size(obj) {
2253
- if (obj != null) {
2254
- if (obj.size != null) {
2255
- return obj.size;
2256
- }
2257
- if (obj.length != null) {
2258
- return obj.length;
2259
- }
2260
- return Object.keys(obj).length;
2261
- }
2262
- return 0;
2263
- }
2264
- __name(size, "size");
2265
- function last(array) {
2266
- return array != null && array.length > 0 ? array[array.length - 1] : void 0;
2267
- }
2268
- __name(last, "last");
2269
- function empty(value) {
2270
- try {
2271
- if (value != null) {
2272
- if (Array.isArray(value)) {
2273
- return value.length <= 0;
2274
- } else if (typeof value === "string") {
2275
- return value.length <= 0;
2276
- } else if ((value == null ? void 0 : value.size) != null) {
2277
- return value.size <= 0;
2278
- } else {
2279
- return Object.keys(value).length <= 0;
2280
- }
2281
- }
2282
- } catch (err) {
2283
- console.warn("Failed to check if empty for", value, err);
2284
- }
2285
- return true;
2286
- }
2287
- __name(empty, "empty");
2288
- function cloneObject(obj) {
2289
- if (Object(obj) !== obj)
2290
- return obj;
2291
- return JSON.parse(JSON.stringify(obj));
2292
- }
2293
- __name(cloneObject, "cloneObject");
2294
- function cloneJsonObject(obj) {
2295
- if (Object(obj) !== obj)
2296
- return obj;
2297
- return JSON.parse(JSON.stringify(obj));
2298
- }
2299
- __name(cloneJsonObject, "cloneJsonObject");
2300
- function memoize(fn) {
2301
- let cache = /* @__PURE__ */ new Map();
2302
- return (n) => {
2303
- if (cache.has(n)) {
2304
- return cache.get(n);
2305
- }
2306
- let result = fn(n);
2307
- cache.set(n, result);
2308
- return result;
2309
- };
2310
- }
2311
- __name(memoize, "memoize");
2312
- function forTimes(count, fn) {
2313
- let result = [];
2314
- for (let i = 0; i < count; i++) {
2315
- result.push(fn(i, count));
2316
- }
2317
- return result;
2318
- }
2319
- __name(forTimes, "forTimes");
2320
-
2321
- // src/common/data/xrx.ts
2322
- var RX_WHITESPACE = /\\\s|\s+|#[^\n]*\n?/gm;
2323
- var RX_REAL_GROUPS = /\(\?P?<(\w[\w\d_]+)>|\((?!\?(:|\!|=|<=|<\!))/gm;
2324
- var RX_LOOK_BEHIND = /^((?:\(\?[\w$]+\))?)\(\?<([=!])([\s\S]*?)\)/gm;
2325
- var log3 = Logger("xrx");
2326
- function regExpString(rx) {
2327
- return typeof rx === "string" ? rx : rx.source || "";
2328
- }
2329
- __name(regExpString, "regExpString");
2330
- function regExpEscape(str) {
2331
- return str.replace(/[-\[\]{}()*+?.,\\^$|#\s]/g, "\\$&");
2332
- }
2333
- __name(regExpEscape, "regExpEscape");
2334
- var XRX = class {
2335
- constructor(pattern2, flags) {
2336
- this.namedGroups = {};
2337
- this.names = [];
2338
- let _flags = flags ?? "";
2339
- let _rx;
2340
- if (pattern2 instanceof RegExp) {
2341
- if (flags == null) {
2342
- _flags = pattern2.flags;
2343
- }
2344
- _rx = pattern2.source;
2345
- } else {
2346
- _rx = pattern2;
2347
- }
2348
- const extended = _flags && _flags.indexOf("x") !== -1;
2349
- if (extended) {
2350
- _flags = _flags.replace("x", "");
2351
- _rx = _rx.replace(RX_WHITESPACE, (r) => {
2352
- return r[0] === "\\" ? r : "";
2353
- });
2354
- }
2355
- if (!(pattern2 instanceof RegExp)) {
2356
- let index = 0;
2357
- _rx = _rx.replace(RX_REAL_GROUPS, (str, name) => {
2358
- index += 1;
2359
- if (name) {
2360
- if (name !== "index" && name !== "length" && !this.namedGroups[name]) {
2361
- this.namedGroups[name] = index;
2362
- } else {
2363
- log3.error(`Unallowed or duplicate group name: ${name}`);
2364
- }
2365
- return "(";
2366
- }
2367
- return str;
2368
- });
2369
- this.names = Object.keys(this.namedGroups);
2370
- }
2371
- _rx = regExpString(_rx);
2372
- RX_LOOK_BEHIND.lastIndex = 0;
2373
- let parts = RX_LOOK_BEHIND.exec(_rx);
2374
- if (parts) {
2375
- this.lookBehind = {
2376
- rx: new RegExp(`${parts[3]}$(?!\\s)`),
2377
- expect: parts ? parts[2] === "=" : !parts
2378
- };
2379
- _rx = _rx.substr(parts[0].length);
2380
- }
2381
- this.rx = new RegExp(_rx, _flags);
2382
- }
2383
- get lastIndex() {
2384
- return this.rx.lastIndex;
2385
- }
2386
- set lastIndex(index) {
2387
- this.rx.lastIndex = index;
2388
- }
2389
- _handleMatch(m) {
2390
- if (this.lookBehind) {
2391
- let leftContext = m.input.slice(0, m.index);
2392
- if (this.lookBehind.expect !== this.lookBehind.rx.test(leftContext)) {
2393
- return null;
2394
- }
2395
- }
2396
- for (let name of this.names) {
2397
- m[name] = m[this.namedGroups[name]];
2398
- }
2399
- return m;
2400
- }
2401
- exec(str) {
2402
- let m;
2403
- while (m = this.rx.exec(str)) {
2404
- if (this.rx.lastIndex === m.index) {
2405
- this.rx.lastIndex++;
2406
- }
2407
- m = this._handleMatch(m);
2408
- if (m != null) {
2409
- return m;
2410
- }
2411
- }
2412
- }
2413
- execAll(str) {
2414
- let matches = [];
2415
- let m;
2416
- this.rx.lastIndex = 0;
2417
- while (m = this.exec(str)) {
2418
- matches.push(m);
2419
- }
2420
- this.rx.lastIndex = 0;
2421
- return matches;
2422
- }
2423
- replace(str, replacement) {
2424
- let fn = typeof replacement === "function" ? replacement : () => replacement;
2425
- return str.replace(this.rx, (m) => {
2426
- return fn(m);
2427
- });
2428
- }
2429
- };
2430
- __name(XRX, "XRX");
2431
-
2432
- // src/common/dispose-defer.ts
2433
- var log4 = Logger("dispose");
2434
- async function callDisposer(disposable) {
2435
- if (typeof disposable === "function") {
2436
- await promisify(disposable());
2437
- } else if (isPromise(disposable)) {
2438
- await disposable;
2439
- } else if (typeof disposable.dispose === "function") {
2440
- await promisify(disposable.dispose());
2441
- } else if (isPromise(disposable.dispose)) {
2442
- await disposable.dispose;
2443
- } else if (typeof disposable.cleanup === "function") {
2444
- await promisify(disposable.cleanup());
2445
- } else if (isPromise(disposable.cleanup)) {
2446
- await disposable.cleanup;
2447
- }
2448
- }
2449
- __name(callDisposer, "callDisposer");
2450
- function useDispose(config) {
2451
- const { name } = typeof config === "string" ? { name: config } : config ?? {};
2452
- let tracked = [];
2453
- const untrack = /* @__PURE__ */ __name(async (disposable) => {
2454
- if (disposable != null && tracked.includes(disposable)) {
2455
- arrayFilterInPlace(tracked, (el) => el !== disposable);
2456
- await callDisposer(disposable);
2457
- }
2458
- }, "untrack");
2459
- const dispose = /* @__PURE__ */ __name(async () => {
2460
- if (name)
2461
- log4.debug(`dispose ${name}: ${tracked.length} entries`);
2462
- while (tracked.length > 0) {
2463
- await untrack(tracked[0]);
2464
- }
2465
- }, "dispose");
2466
- const track = /* @__PURE__ */ __name((obj) => {
2467
- if (obj == null)
2468
- return;
2469
- tracked.unshift(obj);
2470
- return () => untrack(obj);
2471
- }, "track");
2472
- return Object.assign(dispose, {
2473
- track,
2474
- add: track,
2475
- untrack,
2476
- dispose,
2477
- exec: dispose,
2478
- getSize() {
2479
- return tracked.length;
2480
- }
2481
- });
2482
- }
2483
- __name(useDispose, "useDispose");
2484
- var useDisposer = useDispose;
2485
- function useDefer(config = {}) {
2486
- const { mode = "fifo" } = config;
2487
- let steps = [];
2488
- const exec = /* @__PURE__ */ __name(async (expectSync = false) => {
2489
- while (steps.length > 0) {
2490
- let step = steps[0];
2491
- arrayFilterInPlace(steps, (el) => el !== step);
2492
- if (typeof step === "function") {
2493
- let result = step();
2494
- if (isPromise(result)) {
2495
- if (expectSync)
2496
- throw new Error(
2497
- `Expected sync only function, but found async: ${step}`
2498
- );
2499
- await result;
2500
- }
2501
- } else if (isPromise(step)) {
2502
- if (expectSync)
2503
- throw new Error(
2504
- `Expected sync only function, but found async: ${step}`
2505
- );
2506
- await step;
2507
- } else {
2508
- throw new Error(`Unhandled disposable: ${step}`);
2509
- }
2510
- }
2511
- }, "exec");
2512
- const add = /* @__PURE__ */ __name((obj) => {
2513
- if (mode === "lifo") {
2514
- steps.unshift(obj);
2515
- } else {
2516
- steps.push(obj);
2517
- }
2518
- }, "add");
2519
- return Object.assign(exec, {
2520
- add,
2521
- exec,
2522
- getSize() {
2523
- return steps.length;
2524
- }
2525
- });
2526
- }
2527
- __name(useDefer, "useDefer");
2528
- function useTimeout(fn, timeout2 = 0) {
2529
- let timeoutHandle = setTimeout(fn, timeout2);
2530
- return () => {
2531
- if (timeoutHandle) {
2532
- clearTimeout(timeoutHandle);
2533
- timeoutHandle = void 0;
2534
- }
2535
- };
2536
- }
2537
- __name(useTimeout, "useTimeout");
2538
- function useInterval(fn, interval) {
2539
- let intervalHandle = setInterval(fn, interval);
2540
- return () => {
2541
- if (intervalHandle) {
2542
- clearInterval(intervalHandle);
2543
- intervalHandle = void 0;
2544
- }
2545
- };
2546
- }
2547
- __name(useInterval, "useInterval");
2548
- function useEventListener(emitter, eventName, fn, ...args) {
2549
- if (emitter == null)
2550
- return () => {
2551
- };
2552
- if (emitter.on) {
2553
- emitter.on(eventName, fn, ...args);
2554
- } else if (emitter.addEventListener) {
2555
- emitter.addEventListener(eventName, fn, ...args);
2556
- }
2557
- return () => {
2558
- if (emitter.off) {
2559
- emitter.off(eventName, fn, ...args);
2560
- } else if (emitter.removeEventListener) {
2561
- emitter.removeEventListener(eventName, fn, ...args);
2562
- }
2563
- };
2564
- }
2565
- __name(useEventListener, "useEventListener");
2566
-
2567
- // src/common/exec/mutex.ts
2568
- function useMutex() {
2569
- let token = true;
2570
- return (fn, elseFn) => {
2571
- let executed = false;
2572
- if (token) {
2573
- token = false;
2574
- try {
2575
- fn();
2576
- executed = true;
2577
- } finally {
2578
- token = true;
2579
- }
2580
- } else if (elseFn !== void 0) {
2581
- elseFn();
2582
- }
2583
- return executed;
2584
- };
2585
- }
2586
- __name(useMutex, "useMutex");
2587
- function useAsyncMutex() {
2588
- let token = true;
2589
- return async (fn, elseFn) => {
2590
- let executed = false;
2591
- if (token) {
2592
- token = false;
2593
- try {
2594
- let result = fn();
2595
- if (isPromise(result))
2596
- await result;
2597
- executed = true;
2598
- } finally {
2599
- token = true;
2600
- }
2601
- } else if (elseFn !== void 0) {
2602
- let result = elseFn();
2603
- if (isPromise(result))
2604
- await result;
2605
- }
2606
- return executed;
2607
- };
2608
- }
2609
- __name(useAsyncMutex, "useAsyncMutex");
2610
-
2611
- // src/common/msg/emitter.ts
2612
- var log5 = Logger("zeed:emitter");
2613
- var Emitter = class {
2614
- constructor() {
2615
- this.subscribers = {};
2616
- this.subscribersOnAny = [];
2617
- this.dispose = useDispose();
2618
- this.call = new Proxy({}, {
2619
- get: (target, name) => (...args) => this.emit(name, ...args)
2620
- });
2621
- }
2622
- async emit(event, ...args) {
2623
- let ok = false;
2624
- this.dispose.add(() => {
2625
- this.subscribers = {};
2626
- this.subscribersOnAny = [];
2627
- });
2628
- try {
2629
- let subscribers = this.subscribers[event] || [];
2630
- this.subscribersOnAny.forEach((fn) => fn(event, ...args));
2631
- if (subscribers.length > 0) {
2632
- let all = subscribers.map((fn) => {
2633
- try {
2634
- return promisify(fn(...args));
2635
- } catch (err) {
2636
- log5.warn("emit warning:", err);
2637
- }
2638
- });
2639
- ok = true;
2640
- await Promise.all(all);
2641
- }
2642
- } catch (err) {
2643
- log5.error("emit exception", err);
2644
- }
2645
- return ok;
2646
- }
2647
- onAny(fn) {
2648
- this.subscribersOnAny.push(fn);
2649
- }
2650
- on(event, listener) {
2651
- let subscribers = this.subscribers[event] || [];
2652
- subscribers.push(listener);
2653
- this.subscribers[event] = subscribers;
2654
- return () => {
2655
- this.off(event, listener);
2656
- };
2657
- }
2658
- onCall(handlers) {
2659
- for (const [name, handler] of Object.entries(handlers)) {
2660
- this.on(name, handler);
2661
- }
2662
- }
2663
- once(event, listener) {
2664
- const onceListener = /* @__PURE__ */ __name(async (...args) => {
2665
- this.off(event, onceListener);
2666
- return await promisify(listener(...args));
2667
- }, "onceListener");
2668
- this.on(event, onceListener);
2669
- return () => {
2670
- this.off(event, listener);
2671
- };
2672
- }
2673
- off(event, listener) {
2674
- this.subscribers[event] = (this.subscribers[event] || []).filter(
2675
- (f) => listener && f !== listener
2676
- );
2677
- return this;
2678
- }
2679
- removeAllListeners() {
2680
- this.subscribers = {};
2681
- return this;
2682
- }
2683
- };
2684
- __name(Emitter, "Emitter");
2685
- function getGlobalEmitter() {
2686
- let emitter = getGlobalContext().emitter;
2687
- if (!emitter) {
2688
- emitter = new Emitter();
2689
- getGlobalContext().emitter = emitter;
2690
- }
2691
- return emitter;
2692
- }
2693
- __name(getGlobalEmitter, "getGlobalEmitter");
2694
- var messages = new Emitter();
2695
- function lazyListener(emitter, listenerKey) {
2696
- const name = Math.round(getSecureRandomIfPossible() * 100);
2697
- var events = [];
2698
- var lazyResolve;
2699
- const incoming = /* @__PURE__ */ __name((key, obj) => {
2700
- let ev = { key, obj };
2701
- events.push(ev);
2702
- lazyResolve && lazyResolve();
2703
- }, "incoming");
2704
- if (listenerKey) {
2705
- if (emitter.on) {
2706
- emitter.on(listenerKey, (obj) => {
2707
- incoming(listenerKey, obj);
2708
- });
2709
- } else if (emitter.addEventListener) {
2710
- emitter.addEventListener(listenerKey, (obj) => {
2711
- incoming(listenerKey, obj);
2712
- });
2713
- } else {
2714
- log5.error(name, "Cannot listen to key");
2715
- }
2716
- } else {
2717
- if (emitter.onAny) {
2718
- emitter.onAny((key, obj) => {
2719
- incoming(key, obj);
2720
- });
2721
- } else {
2722
- log5.error(name, "cannot listen to all for", emitter);
2723
- }
2724
- }
2725
- let on = /* @__PURE__ */ __name((key, skipUnmatched = true) => {
2726
- return new Promise((resolve, reject) => {
2727
- if (!key) {
2728
- key = listenerKey;
2729
- if (!key) {
2730
- if (events.length) {
2731
- key = events[0].key;
2732
- }
2733
- }
2734
- }
2735
- lazyResolve = /* @__PURE__ */ __name(() => {
2736
- while (events.length > 0) {
2737
- let ev = events.shift();
2738
- if (ev.key === key) {
2739
- lazyResolve = void 0;
2740
- resolve(ev.obj);
2741
- } else {
2742
- if (skipUnmatched) {
2743
- log5.warn(name, `Unhandled event ${key} with value: ${ev.obj}`);
2744
- continue;
2745
- }
2746
- reject(`Expected ${key}, but found ${ev.key} with value=${ev.obj}`);
2747
- log5.error(name, `Unhandled event ${key} with value: ${ev.obj}`);
2748
- }
2749
- break;
2750
- }
2751
- }, "lazyResolve");
2752
- lazyResolve();
2753
- });
2754
- }, "on");
2755
- return on;
2756
- }
2757
- __name(lazyListener, "lazyListener");
2758
-
2759
- // src/common/time.ts
2760
- var getTimestamp = /* @__PURE__ */ __name(() => Date.now(), "getTimestamp");
2761
- function formatMilliseconds(ms) {
2762
- return ms > 999 ? (ms / 1e3).toFixed(1) + "s" : ms.toFixed(2) + "ms";
2763
- }
2764
- __name(formatMilliseconds, "formatMilliseconds");
2765
- function parseDate(...dateCandidates) {
2766
- for (let dateCandidate of dateCandidates) {
2767
- if (dateCandidate instanceof Date) {
2768
- return dateCandidate;
2769
- }
2770
- if (typeof dateCandidate === "string") {
2771
- let date = null;
2772
- if (dateCandidate.includes(":")) {
2773
- try {
2774
- date = new Date(dateCandidate);
2775
- } catch (err) {
2776
- }
2777
- }
2778
- if (!(date instanceof Date)) {
2779
- let m = /(\d\d\d\d)-(\d\d)-(\d\d)/.exec(dateCandidate);
2780
- if (m) {
2781
- date = new Date(+m[1], +m[2] - 1, +m[3], 12, 0);
2782
- }
2783
- }
2784
- if (date instanceof Date) {
2785
- return date;
2786
- }
2787
- }
2788
- }
2789
- }
2790
- __name(parseDate, "parseDate");
2791
-
2792
- // src/common/uuid.ts
2793
- var { encode: encode62, decode: decode62 } = useBase(62);
2794
- var { encode: encode32, decode: decode32 } = useBase(32);
2795
- function uuidBytes() {
2796
- return randomUint8Array(16);
2797
- }
2798
- __name(uuidBytes, "uuidBytes");
2799
- var uuid32bit = /* @__PURE__ */ __name(() => new Uint32Array(randomUint8Array(4))[0], "uuid32bit");
2800
- function uuid() {
2801
- return encode62(uuidBytes(), 22);
2802
- }
2803
- __name(uuid, "uuid");
2804
- function uuidEncode(bytes) {
2805
- return encode62(bytes, 22);
2806
- }
2807
- __name(uuidEncode, "uuidEncode");
2808
- function uuidDecode(uuid2) {
2809
- return decode62(uuid2, 16);
2810
- }
2811
- __name(uuidDecode, "uuidDecode");
2812
- function uuidB32() {
2813
- return encode32(uuidBytes(), 26);
2814
- }
2815
- __name(uuidB32, "uuidB32");
2816
- function uuid32Encode(bytes) {
2817
- return encode32(bytes, 26);
2818
- }
2819
- __name(uuid32Encode, "uuid32Encode");
2820
- function uuid32Decode(uuid2) {
2821
- return decode32(uuid2, 16);
2822
- }
2823
- __name(uuid32Decode, "uuid32Decode");
2824
- var _unameCounters = {};
2825
- function uname(name = "id") {
2826
- if (_unameCounters[name] == null) {
2827
- _unameCounters[name] = 0;
2828
- }
2829
- return `${name}-${_unameCounters[name]++}`;
2830
- }
2831
- __name(uname, "uname");
2832
- var _qid = 0;
2833
- function qid() {
2834
- return `id-${_qid++}`;
2835
- }
2836
- __name(qid, "qid");
2837
- var pattern = "10000000-1000-4000-8000-100000000000";
2838
- var uuidv4 = typeof crypto !== "undefined" && crypto.randomUUID != null ? crypto.randomUUID : () => pattern.replace(
2839
- /[018]/g,
2840
- (c) => (c ^ randomUint8Array(1)[0] & 15 >> c / 4).toString(16)
2841
- );
2842
- var ReferenceDateInMS = 16e11;
2843
- function longToByteArray(long) {
2844
- var byteArray = new Uint8Array([0, 0, 0, 0, 0, 0]);
2845
- const bytes = byteArray.length - 1;
2846
- for (var index = 0; index < byteArray.length; index++) {
2847
- var byte = long & 255;
2848
- byteArray[bytes - index] = byte;
2849
- long = (long - byte) / 256;
2850
- }
2851
- return byteArray;
2852
- }
2853
- __name(longToByteArray, "longToByteArray");
2854
- function suidBytes() {
2855
- const ms = getTimestamp() - ReferenceDateInMS;
2856
- return new Uint8Array([...longToByteArray(ms), ...randomUint8Array(10)]);
2857
- }
2858
- __name(suidBytes, "suidBytes");
2859
- function suid() {
2860
- return encode62(suidBytes(), 22);
2861
- }
2862
- __name(suid, "suid");
2863
- function suidDate(id) {
2864
- return suidBytesDate(decode62(id, 16));
2865
- }
2866
- __name(suidDate, "suidDate");
2867
- function suidBytesDate(id) {
2868
- return new Date(
2869
- ReferenceDateInMS + id.slice(0, 6).reduce((acc, byte) => {
2870
- return acc * 256 + byte;
2871
- }, 0)
2872
- );
2873
- }
2874
- __name(suidBytesDate, "suidBytesDate");
2875
-
2876
- // src/common/exec/pool.ts
2877
- var PoolTaskState = /* @__PURE__ */ ((PoolTaskState2) => {
2878
- PoolTaskState2[PoolTaskState2["waiting"] = 0] = "waiting";
2879
- PoolTaskState2[PoolTaskState2["running"] = 1] = "running";
2880
- PoolTaskState2[PoolTaskState2["finished"] = 2] = "finished";
2881
- return PoolTaskState2;
2882
- })(PoolTaskState || {});
2883
- var PoolTaskIdConflictResolution = /* @__PURE__ */ ((PoolTaskIdConflictResolution2) => {
2884
- PoolTaskIdConflictResolution2[PoolTaskIdConflictResolution2["replace"] = 0] = "replace";
2885
- PoolTaskIdConflictResolution2[PoolTaskIdConflictResolution2["memoize"] = 1] = "memoize";
2886
- PoolTaskIdConflictResolution2[PoolTaskIdConflictResolution2["error"] = 2] = "error";
2887
- return PoolTaskIdConflictResolution2;
2888
- })(PoolTaskIdConflictResolution || {});
2889
- function usePool(config = {}) {
2890
- const { maxParallel = 3 } = config;
2891
- const events = new Emitter();
2892
- let countMax = 0;
2893
- let countResolved = 0;
2894
- let currentParallel = 0;
2895
- let priority = 0;
2896
- let tasks = {};
2897
- async function waitFinishAll() {
2898
- if (countMax > 0) {
2899
- const [promise, resolve] = createPromise();
2900
- events.once("didFinish", resolve);
2901
- return promise;
2902
- }
2903
- }
2904
- __name(waitFinishAll, "waitFinishAll");
2905
- function didFinish() {
2906
- events.emit("didFinish");
2907
- countMax = 0;
2908
- countResolved = 0;
2909
- }
2910
- __name(didFinish, "didFinish");
2911
- function didUpdate() {
2912
- let presentMax = 0;
2913
- let presentResolved = 0;
2914
- for (const { max, resolved, state } of Object.values(tasks)) {
2915
- presentMax += max;
2916
- presentResolved += state === 2 /* finished */ ? max : Math.min(max, resolved);
2917
- }
2918
- events.emit(
2919
- "didUpdate",
2920
- countMax,
2921
- countResolved,
2922
- presentMax,
2923
- presentResolved
2924
- );
2925
- }
2926
- __name(didUpdate, "didUpdate");
2927
- function performNext() {
2928
- didUpdate();
2929
- if (countMax > 0 && countMax === countResolved)
2930
- didFinish();
2931
- if (currentParallel >= maxParallel)
2932
- return;
2933
- let waitingTasks = Object.values(tasks).filter(
2934
- (t) => t.state === 0 /* waiting */
2935
- );
2936
- if (waitingTasks.length > 0) {
2937
- let taskInfo;
2938
- for (let t of waitingTasks) {
2939
- if (taskInfo == null || t.priority < taskInfo.priority) {
2940
- taskInfo = t;
2941
- }
2942
- }
2943
- if (taskInfo != null) {
2944
- const id = taskInfo.id;
2945
- const done = taskInfo.done;
2946
- taskInfo.state = 1 /* running */;
2947
- ++currentParallel;
2948
- events.emit("didStart", id);
2949
- const taskFinished = /* @__PURE__ */ __name((result) => {
2950
- if (taskInfo) {
2951
- taskInfo.result = result;
2952
- taskInfo.state = 2 /* finished */;
2953
- taskInfo.resolved = taskInfo.max;
2954
- }
2955
- --currentParallel;
2956
- ++countResolved;
2957
- performNext();
2958
- }, "taskFinished");
2959
- taskInfo.task(taskInfo).then((r) => {
2960
- done(r);
2961
- events.emit("didResolve", id, r);
2962
- taskFinished(r);
2963
- }).catch((err) => {
2964
- done();
2965
- events.emit("didReject", id, err);
2966
- taskFinished();
2967
- });
2968
- }
2969
- }
2970
- }
2971
- __name(performNext, "performNext");
2972
- function cancel(id) {
2973
- let taskInfo = tasks[id];
2974
- if (taskInfo && taskInfo.state === 0 /* waiting */) {
2975
- tasks[id].state = 2 /* finished */;
2976
- ++countResolved;
2977
- events.emit("didCancel", id);
2978
- didUpdate();
2979
- }
2980
- }
2981
- __name(cancel, "cancel");
2982
- function cancelAll() {
2983
- Object.keys(tasks).forEach(cancel);
2984
- }
2985
- __name(cancelAll, "cancelAll");
2986
- function enqueue(task, config2 = {}) {
2987
- let done;
2988
- let promise = new Promise((resolve) => done = resolve);
2989
- let id = config2.id ?? uuid();
2990
- if (tasks[id] != null) {
2991
- const resolution = config2.idConflictResolution ?? 1 /* memoize */;
2992
- if (resolution === 0 /* replace */) {
2993
- cancel(id);
2994
- } else if (resolution === 1 /* memoize */) {
2995
- let runningTask = tasks[id];
2996
- return {
2997
- id,
2998
- promise: (async () => {
2999
- if (runningTask.state === 2 /* finished */) {
3000
- return tasks[id].result;
3001
- }
3002
- })(),
3003
- dispose: () => cancel(id),
3004
- cancel: () => cancel(id)
3005
- };
3006
- } else {
3007
- throw new Error(`Pool task with id=${id} already exists!`);
3008
- }
3009
- }
3010
- tasks[id] = {
3011
- id,
3012
- task,
3013
- priority: ++priority,
3014
- state: 0 /* waiting */,
3015
- max: config2.max ?? 1,
3016
- resolved: config2.resolved ?? 0,
3017
- done,
3018
- payload: config2.payload,
3019
- setMax(max) {
3020
- tasks[id].max = max;
3021
- didUpdate();
3022
- },
3023
- setResolved(max) {
3024
- tasks[id].resolved = max;
3025
- didUpdate();
3026
- },
3027
- incResolved(inc = 1) {
3028
- tasks[id].resolved += inc;
3029
- didUpdate();
3030
- }
3031
- };
3032
- ++countMax;
3033
- performNext();
3034
- return {
3035
- id,
3036
- promise,
3037
- dispose: () => cancel(id),
3038
- cancel: () => cancel(id)
3039
- };
3040
- }
3041
- __name(enqueue, "enqueue");
3042
- return {
3043
- events,
3044
- cancel,
3045
- cancelAll,
3046
- enqueue,
3047
- dispose: cancelAll,
3048
- waitFinishAll
3049
- };
3050
- }
3051
- __name(usePool, "usePool");
3052
-
3053
- // src/common/exec/queue.ts
3054
- var SerialQueue = class extends Emitter {
3055
- constructor(opt = {}) {
3056
- super();
3057
- this.queue = [];
3058
- this.waitToFinish = [];
3059
- this.countMax = 0;
3060
- this.countResolved = 0;
3061
- this.paused = false;
3062
- const { name = uname("queue"), logLevel } = opt;
3063
- this.name = name;
3064
- this.log = Logger(`zeed:queue:${name}`, logLevel ?? Infinity /* off */);
3065
- }
3066
- async performNext() {
3067
- this.log(`performNext, queue.length =`, this.queue.length);
3068
- if (this.currentTask != null) {
3069
- this.log(`performNext => skip while another task is running`);
3070
- return;
3071
- }
3072
- if (this.paused) {
3073
- this.log(`performNext => skip while is paused`);
3074
- return;
3075
- }
3076
- while (this.currentTask == null && !this.paused) {
3077
- let info = this.queue.shift();
3078
- this.log(`performNext => ${info == null ? void 0 : info.name}`);
3079
- if (info == null) {
3080
- break;
3081
- }
3082
- if (this.countResolved === 0) {
3083
- this.emit("didStart", this.countMax);
3084
- }
3085
- const { name, task, resolve } = info;
3086
- this.currentTask = task();
3087
- let result = void 0;
3088
- try {
3089
- this.log.info(`start task ${name}`);
3090
- result = await this.currentTask;
3091
- this.log(`finished task ${name} with result =`, result);
3092
- } catch (err) {
3093
- this.log.warn("Error performing task", err);
3094
- }
3095
- resolve(result);
3096
- this.currentTask = void 0;
3097
- this.countResolved += 1;
3098
- this.emit("didUpdate", this.countMax, this.countResolved);
3099
- }
3100
- if (this.queue.length === 0) {
3101
- this.emit("didFinish");
3102
- this.countMax = 0;
3103
- this.countResolved = 0;
3104
- }
3105
- while (this.waitToFinish.length > 0) {
3106
- this.waitToFinish.shift()();
3107
- }
3108
- }
3109
- async enqueue(task, opt = {}) {
3110
- const { immediate: immediate2 = false, name = uname(this.name) } = opt;
3111
- if (immediate2) {
3112
- this.log.info(`immediate execution ${name}`);
3113
- return await task();
3114
- }
3115
- this.log(`enqueue ${name}`);
3116
- return new Promise((resolve) => {
3117
- this.queue.push({
3118
- name,
3119
- task,
3120
- resolve
3121
- });
3122
- this.countMax += 1;
3123
- this.emit("didUpdate", this.countMax, this.countResolved);
3124
- this.performNext();
3125
- });
3126
- }
3127
- async enqueueReentrant(task, opt = {}) {
3128
- return this.enqueue(task, {
3129
- immediate: this.currentTask != null,
3130
- name: opt.name
3131
- });
3132
- }
3133
- async cancelAll(unblock = true) {
3134
- this.log(`cancelAll`);
3135
- this.emit("didCancel");
3136
- let resolver = this.queue.map((task) => task.resolve);
3137
- this.queue = [];
3138
- resolver.forEach((r) => r(void 0));
3139
- await this.wait();
3140
- }
3141
- async pause() {
3142
- this.log(`pause`);
3143
- this.paused = true;
3144
- await this.wait();
3145
- }
3146
- resume() {
3147
- this.log(`resume`);
3148
- this.paused = false;
3149
- this.performNext();
3150
- }
3151
- async wait() {
3152
- this.log(`wait`);
3153
- if (this.currentTask == null && (this.queue.length === 0 || this.paused)) {
3154
- return;
3155
- }
3156
- return new Promise((resolve) => {
3157
- this.waitToFinish.push(resolve);
3158
- });
3159
- }
3160
- get isPaused() {
3161
- return this.paused;
3162
- }
3163
- get hasTasks() {
3164
- return this.queue.length !== 0;
3165
- }
3166
- };
3167
- __name(SerialQueue, "SerialQueue");
3168
- var log6 = () => {
3169
- };
3170
- function throttle(callback, opt = {}) {
3171
- const { delay = 100, trailing = true, leading = true } = opt;
3172
- let timeoutID = 0;
3173
- let checkpoint = 0;
3174
- let visited = 0;
3175
- let trailingExec;
3176
- let debugCheckpoint = Date.now();
3177
- function clearExistingTimeout() {
3178
- if (timeoutID) {
3179
- clearTimeout(timeoutID);
3180
- timeoutID = void 0;
3181
- }
3182
- }
3183
- __name(clearExistingTimeout, "clearExistingTimeout");
3184
- function wrapper(...args) {
3185
- const now = Date.now();
3186
- let self2 = this;
3187
- let elapsed = now - checkpoint;
3188
- function debugElapsed() {
3189
- const dnow = Date.now();
3190
- return `total ${(dnow - debugCheckpoint).toFixed(1)}ms - elapsed ${(dnow - checkpoint).toFixed(1)}ms - visited ${visited}x`;
3191
- }
3192
- __name(debugElapsed, "debugElapsed");
3193
- function exec() {
3194
- visited = 0;
3195
- checkpoint = Date.now();
3196
- callback.apply(self2, args);
3197
- }
3198
- __name(exec, "exec");
3199
- trailingExec = exec;
3200
- if (elapsed > delay || !timeoutID) {
3201
- if (leading) {
3202
- if (elapsed > delay) {
3203
- exec();
3204
- } else {
3205
- ++visited;
3206
- }
3207
- }
3208
- const timeout2 = elapsed > delay ? delay : delay - elapsed;
3209
- log6(`\u23F1 start timeout with ${timeout2.toFixed(1)}ms`, debugElapsed());
3210
- clearExistingTimeout();
3211
- checkpoint = now;
3212
- timeoutID = setTimeout(() => {
3213
- timeoutID = 0;
3214
- if (trailing && (!leading || visited > 0)) {
3215
- trailingExec == null ? void 0 : trailingExec();
3216
- }
3217
- }, timeout2);
3218
- } else {
3219
- ++visited;
3220
- }
3221
- }
3222
- __name(wrapper, "wrapper");
3223
- wrapper.cancel = clearExistingTimeout;
3224
- wrapper.dispose = clearExistingTimeout;
3225
- return wrapper;
3226
- }
3227
- __name(throttle, "throttle");
3228
- function debounce(callback, opt = {}) {
3229
- const { delay = 100 } = opt;
3230
- let timeoutID = 0;
3231
- function clearExistingTimeout() {
3232
- if (timeoutID) {
3233
- clearTimeout(timeoutID);
3234
- timeoutID = 0;
3235
- }
3236
- }
3237
- __name(clearExistingTimeout, "clearExistingTimeout");
3238
- function wrapper(...arguments_) {
3239
- let self2 = this;
3240
- clearExistingTimeout();
3241
- timeoutID = setTimeout(() => {
3242
- timeoutID = 0;
3243
- callback.apply(self2, arguments_);
3244
- }, delay);
3245
- }
3246
- __name(wrapper, "wrapper");
3247
- wrapper.cancel = clearExistingTimeout;
3248
- wrapper.dispose = clearExistingTimeout;
3249
- return wrapper;
3250
- }
3251
- __name(debounce, "debounce");
3252
-
3253
- // src/common/localhost.ts
3254
- function isLocalHost(hostname = ((_a) => (_a = globalThis == null ? void 0 : globalThis.location) == null ? void 0 : _a.hostname)() ?? "") {
3255
- return ["::ffff:127.0.0.1", "localhost", "127.0.0.1", "", "::1", "::"].includes(
3256
- hostname
3257
- ) || hostname.startsWith("192.168.") || hostname.startsWith("10.0.") || hostname.endsWith(".local");
3258
- }
3259
- __name(isLocalHost, "isLocalHost");
3260
-
3261
- // src/common/log-memory.ts
3262
- function LoggerMemoryHandler(opt) {
3263
- let { level = void 0, filter = void 0, messages: messages2 = [] } = opt;
3264
- const matchesNamespace = useNamespaceFilter(filter);
3265
- const matchesLevel = useLevelFilter(level);
3266
- return (msg) => {
3267
- if (!matchesLevel(msg.level))
3268
- return;
3269
- if (!matchesNamespace(msg.name))
3270
- return;
3271
- messages2.push(msg);
3272
- };
3273
- }
3274
- __name(LoggerMemoryHandler, "LoggerMemoryHandler");
3275
-
3276
- // src/common/msg/channel.ts
3277
- var Channel = class extends Emitter {
3278
- constructor() {
3279
- super(...arguments);
3280
- this.id = uuid();
3281
- }
3282
- close() {
3283
- this.dispose();
3284
- }
3285
- };
3286
- __name(Channel, "Channel");
3287
- var LocalChannel = class extends Channel {
3288
- constructor() {
3289
- super(...arguments);
3290
- this.isConnected = true;
3291
- }
3292
- postMessage(data) {
3293
- var _a;
3294
- (_a = this.other) == null ? void 0 : _a.emit("message", {
3295
- data,
3296
- origin: "local",
3297
- lastEventId: uuid()
3298
- });
3299
- }
3300
- };
3301
- __name(LocalChannel, "LocalChannel");
3302
- function createLocalChannelPair() {
3303
- let w1 = new LocalChannel();
3304
- let w2 = new LocalChannel();
3305
- w1.other = w2;
3306
- w2.other = w1;
3307
- return [w1, w2];
3308
- }
3309
- __name(createLocalChannelPair, "createLocalChannelPair");
3310
-
3311
- // src/common/msg/encoder.ts
3312
- var NoopEncoder = class {
3313
- async encode(data) {
3314
- return data;
3315
- }
3316
- async decode(data) {
3317
- return data;
3318
- }
3319
- };
3320
- __name(NoopEncoder, "NoopEncoder");
3321
- var JsonEncoder = class {
3322
- async encode(data) {
3323
- return jsonToUint8Array(data);
3324
- }
3325
- async decode(data) {
3326
- return Uint8ArrayToJson(data);
3327
- }
3328
- };
3329
- __name(JsonEncoder, "JsonEncoder");
3330
- var CryptoEncoder = class {
3331
- constructor(key) {
3332
- this.key = key;
3333
- }
3334
- async encode(data) {
3335
- const plain = jsonToUint8Array(data);
3336
- return await encrypt(plain, this.key);
3337
- }
3338
- async decode(data) {
3339
- const plain = await decrypt(data, this.key);
3340
- return Uint8ArrayToJson(plain);
3341
- }
3342
- };
3343
- __name(CryptoEncoder, "CryptoEncoder");
3344
-
3345
- // src/common/msg/messages.ts
3346
- var createPromiseProxy = /* @__PURE__ */ __name((fn, opt, predefinedMethods = {}) => new Proxy(predefinedMethods, {
3347
- get: (target, name) => {
3348
- if (name in target)
3349
- return target[name];
3350
- return (...args) => fn(name, args, opt);
3351
- }
3352
- }), "createPromiseProxy");
3353
- function useMessageHub(opt = {}) {
3354
- let {
3355
- name = uname("hub"),
3356
- encoder = new JsonEncoder(),
3357
- retryAfter = 1e3,
3358
- ignoreUnhandled = true,
3359
- logLevel = false
3360
- } = opt;
3361
- const log11 = Logger(name, logLevel);
3362
- let handlers = {};
3363
- let channel;
3364
- let queue = [];
3365
- let queueRetryTimer;
3366
- let waitingForResponse = {};
3367
- const dispose = /* @__PURE__ */ __name(() => {
3368
- clearTimeout(queueRetryTimer);
3369
- }, "dispose");
3370
- const postNext = /* @__PURE__ */ __name(async () => {
3371
- clearTimeout(queueRetryTimer);
3372
- if (channel) {
3373
- if (channel.isConnected) {
3374
- while (queue.length) {
3375
- let message = queue[0];
3376
- try {
3377
- channel.postMessage(await encoder.encode(message));
3378
- queue.shift();
3379
- } catch (err) {
3380
- log11.warn("postMessage", err);
3381
- break;
3382
- }
3383
- }
3384
- }
3385
- if (queue.length > 0 && retryAfter > 0) {
3386
- queueRetryTimer = setTimeout(postNext, retryAfter);
3387
- }
3388
- }
3389
- }, "postNext");
3390
- const postMessage = /* @__PURE__ */ __name(async (message) => {
3391
- log11("enqueue postMessage", message);
3392
- queue.push(message);
3393
- await postNext();
3394
- }, "postMessage");
3395
- const connect = /* @__PURE__ */ __name(async (newChannel) => {
3396
- channel = newChannel;
3397
- channel.on("connect", postNext);
3398
- channel.on("message", async (msg) => {
3399
- log11("onmessage", typeof msg);
3400
- const { name: name2, args, id, result, error: error2 } = await encoder.decode(msg.data);
3401
- if (name2) {
3402
- log11(`name ${name2} id ${id}`);
3403
- try {
3404
- if (handlers[name2] == null) {
3405
- throw new Error(`handler for ${name2} was not found`);
3406
- }
3407
- let result2 = handlers[name2](...args);
3408
- if (isPromise(result2))
3409
- result2 = await result2;
3410
- log11(`result ${result2}`);
3411
- if (id) {
3412
- postMessage({ id, result: result2 });
3413
- }
3414
- } catch (error3) {
3415
- let err = error3 instanceof Error ? error3 : new Error(valueToString(error3));
3416
- log11.warn("execution error", err.name);
3417
- postMessage({
3418
- id,
3419
- error: {
3420
- message: err.message,
3421
- stack: err.stack,
3422
- name: err.name
3423
- }
3424
- });
3425
- }
3426
- } else if (id) {
3427
- log11(`response for id=${id}: result=${result}, error=${error2}`);
3428
- if (waitingForResponse[id] == null) {
3429
- if (result === void 0) {
3430
- log11(`skip response for ${id}`);
3431
- } else {
3432
- log11.warn(`no response hook for ${id}`);
3433
- }
3434
- } else {
3435
- const [resolve, reject] = waitingForResponse[id];
3436
- if (resolve && reject) {
3437
- delete waitingForResponse[id];
3438
- if (error2) {
3439
- let err = new Error(error2.message);
3440
- err.stack = error2.stack;
3441
- err.name = error2.name;
3442
- log11.warn("reject", err.name);
3443
- reject(err);
3444
- } else {
3445
- log11("resolve", result);
3446
- resolve(result);
3447
- }
3448
- }
3449
- }
3450
- } else if (!ignoreUnhandled) {
3451
- log11.warn("Unhandled message", msg);
3452
- }
3453
- });
3454
- postNext();
3455
- }, "connect");
3456
- const fetchMessage = /* @__PURE__ */ __name(async (name2, args, opt2 = {}) => {
3457
- const { timeout: timeout2 = 5e3 } = opt2;
3458
- const id = uuid();
3459
- postMessage({
3460
- name: name2,
3461
- args,
3462
- id
3463
- });
3464
- return tryTimeout(
3465
- new Promise(
3466
- (resolve, reject) => waitingForResponse[id] = [resolve, reject]
3467
- ),
3468
- timeout2
3469
- );
3470
- }, "fetchMessage");
3471
- if (opt.channel) {
3472
- connect(opt.channel);
3473
- }
3474
- return {
3475
- dispose,
3476
- connect,
3477
- listen(newHandlers) {
3478
- Object.assign(handlers, newHandlers);
3479
- },
3480
- send() {
3481
- return createPromiseProxy(fetchMessage, {}, {
3482
- options(perCallopt) {
3483
- return createPromiseProxy(fetchMessage, { ...perCallopt });
3484
- }
3485
- });
3486
- }
3487
- };
3488
- }
3489
- __name(useMessageHub, "useMessageHub");
3490
-
3491
- // src/common/msg/pubsub.ts
3492
- var PubSub = class extends Emitter {
3493
- constructor(opt) {
3494
- super();
3495
- this.publish = this.emit;
3496
- this.subscribe = this.on;
3497
- let { name, encoder = new JsonEncoder(), channel, debug = false } = opt;
3498
- this.channel = channel;
3499
- this.encoder = encoder;
3500
- this.debug = debug;
3501
- this.name = name ?? this.channel.id ?? uname("pubsub");
3502
- this.log = Logger(`${this.shortId}`);
3503
- if (this.debug) {
3504
- this.channel.on("connect", () => {
3505
- this.log("channel connected");
3506
- });
3507
- this.channel.on("disconnect", () => {
3508
- this.log("channel disconnected");
3509
- });
3510
- }
3511
- this.channel.on("message", async ({ data }) => {
3512
- let info = await this.encoder.decode(data);
3513
- if (this.debug)
3514
- this.log(`channel message, event=${info == null ? void 0 : info.event}, info=`, info);
3515
- else
3516
- this.log(`channel message, event=${info == null ? void 0 : info.event}`);
3517
- if (info) {
3518
- const { event, args } = info;
3519
- await this.emitSuper(event, ...args);
3520
- }
3521
- });
3522
- }
3523
- get shortId() {
3524
- return this.name.substr(0, 6);
3525
- }
3526
- async emitSuper(event, ...args) {
3527
- return await super.emit(event, ...args);
3528
- }
3529
- async emit(event, ...args) {
3530
- try {
3531
- if (this.debug)
3532
- this.log(`emit(${String(event)})`, event);
3533
- else
3534
- this.log(`emit(${String(event)})`, args.length);
3535
- if (!this.channel.isConnected) {
3536
- this.log.warn("channel not connected");
3537
- return false;
3538
- }
3539
- const data = await this.encoder.encode({ event, args });
3540
- this.channel.postMessage(data);
3541
- return true;
3542
- } catch (err) {
3543
- this.log.warn(`emit(${String(event)})`, err);
3544
- }
3545
- return false;
3546
- }
3547
- };
3548
- __name(PubSub, "PubSub");
3549
- function usePubSub(opt) {
3550
- return new PubSub(opt);
3551
- }
3552
- __name(usePubSub, "usePubSub");
3553
-
3554
- // src/common/msg/rpc.ts
3555
- var rpcCounter = 1;
3556
- var defaultSerialize = /* @__PURE__ */ __name((i) => i, "defaultSerialize");
3557
- var defaultDeserialize = defaultSerialize;
3558
- function useRPC(functions, options) {
3559
- const {
3560
- post,
3561
- on,
3562
- eventNames = [],
3563
- serialize = defaultSerialize,
3564
- deserialize = defaultDeserialize
3565
- } = options;
3566
- const rpcPromiseMap = /* @__PURE__ */ new Map();
3567
- on(async (data) => {
3568
- const msg = deserialize(data);
3569
- const [mode, args, id, method] = msg;
3570
- if (mode === 1 /* request */ || mode === 2 /* event */) {
3571
- let result, error2;
3572
- if (method != null) {
3573
- try {
3574
- result = await functions[method](...args);
3575
- } catch (e) {
3576
- error2 = String(e);
3577
- }
3578
- } else {
3579
- error2 = "Method implementation missing";
3580
- }
3581
- if (mode === 1 /* request */ && id) {
3582
- if (error2) {
3583
- post(serialize([4 /* reject */, error2, id]));
3584
- } else {
3585
- post(serialize([3 /* resolve */, result, id]));
3586
- }
3587
- }
3588
- } else if (id) {
3589
- const promise = rpcPromiseMap.get(id);
3590
- if (promise != null) {
3591
- if (mode === 4 /* reject */)
3592
- promise.reject(args);
3593
- else
3594
- promise.resolve(args);
3595
- }
3596
- rpcPromiseMap.delete(id);
3597
- }
3598
- });
3599
- return new Proxy(
3600
- {},
3601
- {
3602
- get(_, method) {
3603
- const sendEvent = /* @__PURE__ */ __name((...args) => {
3604
- post(serialize([2 /* event */, args, null, method]));
3605
- }, "sendEvent");
3606
- if (options.onlyEvents || eventNames.includes(method)) {
3607
- sendEvent.asEvent = sendEvent;
3608
- return sendEvent;
3609
- }
3610
- const sendCall = /* @__PURE__ */ __name((...args) => {
3611
- return new Promise((resolve, reject) => {
3612
- const id = rpcCounter++;
3613
- rpcPromiseMap.set(id, { resolve, reject });
3614
- post(serialize([1 /* request */, args, id, method]));
3615
- });
3616
- }, "sendCall");
3617
- sendCall.asEvent = sendEvent;
3618
- return sendCall;
3619
- }
3620
- }
3621
- );
3622
- }
3623
- __name(useRPC, "useRPC");
3624
-
3625
- // src/common/network.ts
3626
- var log7 = Logger("network");
3627
- var defaultOptions = {
3628
- cache: "no-cache",
3629
- redirect: "follow",
3630
- headers: {}
3631
- };
3632
- function parseBasicAuth(url) {
3633
- let m = /:\/\/([^@]*)@/gi.exec(url);
3634
- if (m && m[1]) {
3635
- let [username, password] = m[1].split(":", 2);
3636
- return {
3637
- url: url.replace(m[1] + "@", ""),
3638
- username,
3639
- password
3640
- };
3641
- }
3642
- }
3643
- __name(parseBasicAuth, "parseBasicAuth");
3644
- async function fetchBasic(url, fetchOptions = {}, fetchFn = fetch) {
3645
- try {
3646
- if (isArray(fetchOptions)) {
3647
- fetchOptions = deepMerge({}, ...arrayFlatten(fetchOptions));
3648
- }
3649
- let auth = parseBasicAuth(String(url));
3650
- if (auth) {
3651
- url = auth.url;
3652
- fetchOptions = deepMerge(
3653
- {},
3654
- fetchOptions,
3655
- fetchOptionsBasicAuth(auth.username, auth.password)
3656
- );
3657
- }
3658
- if (fetchOptions.headers != null && !(fetchOptions.headers instanceof Headers)) {
3659
- fetchOptions.headers = new Headers(fetchOptions.headers);
3660
- }
3661
- log7("fetch", url, fetchOptions);
3662
- const response = await fetchFn(String(url), fetchOptions);
3663
- if (response.status < 400) {
3664
- return response;
3665
- }
3666
- try {
3667
- log7.warn(
3668
- `Fetch of ${url} with ${fetchOptions} returned status=${response.status}`
3669
- );
3670
- log7.warn(`Response: ${await response.text()}`);
3671
- } catch (err) {
3672
- log7.error("Exception:", err);
3673
- }
3674
- } catch (err) {
3675
- log7.error("fetchBasic", err);
3676
- }
3677
- }
3678
- __name(fetchBasic, "fetchBasic");
3679
- async function fetchJson(url, fetchOptions = {}, fetchFn = fetch) {
3680
- try {
3681
- let res = await fetchBasic(
3682
- url,
3683
- [
3684
- {
3685
- method: "GET",
3686
- headers: {
3687
- Accept: "application/json"
3688
- }
3689
- },
3690
- fetchOptions
3691
- ],
3692
- fetchFn
3693
- );
3694
- if (res) {
3695
- return await res.json();
3696
- }
3697
- } catch (err) {
3698
- log7.error("fetchJSON error:", err);
3699
- }
3700
- }
3701
- __name(fetchJson, "fetchJson");
3702
- async function fetchText(url, fetchOptions = {}, fetchFn = fetch) {
3703
- try {
3704
- let res = await fetchBasic(
3705
- url,
3706
- [defaultOptions, { method: "GET" }, fetchOptions],
3707
- fetchFn
3708
- );
3709
- if (res) {
3710
- return await res.text();
3711
- }
3712
- } catch (err) {
3713
- log7.error("fetchHTML error:", err);
3714
- }
3715
- }
3716
- __name(fetchText, "fetchText");
3717
- function fetchOptionsFormURLEncoded(data, method = "POST") {
3718
- return {
3719
- method,
3720
- ...defaultOptions,
3721
- headers: {
3722
- "Content-Type": "application/x-www-form-urlencoded; charset=utf-8"
3723
- },
3724
- body: encodeQuery(data)
3725
- };
3726
- }
3727
- __name(fetchOptionsFormURLEncoded, "fetchOptionsFormURLEncoded");
3728
- function fetchOptionsJson(data, method = "POST") {
3729
- return {
3730
- method,
3731
- ...defaultOptions,
3732
- headers: {
3733
- "Content-Type": "application/json; charset=utf-8"
3734
- },
3735
- body: JSON.stringify(data)
3736
- };
3737
- }
3738
- __name(fetchOptionsJson, "fetchOptionsJson");
3739
- function fetchOptionsBasicAuth(username, password) {
3740
- return {
3741
- headers: {
3742
- Authorization: "Basic " + toBase64(username + ":" + password)
3743
- }
3744
- };
3745
- }
3746
- __name(fetchOptionsBasicAuth, "fetchOptionsBasicAuth");
3747
-
3748
- // src/common/platform.ts
3749
- function getWindow() {
3750
- if (typeof window !== "undefined")
3751
- return window;
3752
- }
3753
- __name(getWindow, "getWindow");
3754
- function getNavigator() {
3755
- if (typeof navigator !== "undefined")
3756
- return navigator;
3757
- }
3758
- __name(getNavigator, "getNavigator");
3759
- function getGlobal() {
3760
- return getWindow() ?? typeof WorkerGlobalScope !== "undefined" ? self : typeof global !== "undefined" ? global : Function("return this;")();
3761
- }
3762
- __name(getGlobal, "getGlobal");
3763
- var _navigator = getNavigator();
3764
- var _window = getWindow();
3765
- function detect(info = {
3766
- ios: false,
3767
- macos: false,
3768
- windows: false,
3769
- beaker: false,
3770
- electron: false,
3771
- wkwebview: false,
3772
- pwa: false,
3773
- pwaInstalled: false,
3774
- browser: false,
3775
- node: false,
3776
- worker: false,
3777
- test: false,
3778
- jest: false,
3779
- macosNative: false,
3780
- iosNative: false,
3781
- appleNative: false,
3782
- touch: false
3783
- }) {
3784
- var _a, _b, _c, _d, _e, _f, _g, _h, _i;
3785
- info.ios = ((_a = _navigator == null ? void 0 : _navigator.platform) == null ? void 0 : _a.match(/(iPhone|iPod|iPad)/i)) != null;
3786
- info.macos = !!((_b = _navigator == null ? void 0 : _navigator.platform) == null ? void 0 : _b.startsWith("Mac"));
3787
- info.windows = !!((_c = _navigator == null ? void 0 : _navigator.platform) == null ? void 0 : _c.startsWith("Win"));
3788
- info.beaker = (_window == null ? void 0 : _window["beaker"]) != null;
3789
- info.electron = (((_e = (_d = _navigator == null ? void 0 : _navigator.userAgent) == null ? void 0 : _d.toLowerCase()) == null ? void 0 : _e.indexOf(" electron/")) || -1) > -1 && !info.beaker;
3790
- info.wkwebview = ((_f = _window == null ? void 0 : _window.webkit) == null ? void 0 : _f["messageHandlers"]) != null;
3791
- info.pwa = (_navigator == null ? void 0 : _navigator.serviceWorker) != null;
3792
- info.pwaInstalled = (_navigator == null ? void 0 : _navigator.standalone) || ((_h = (_g = _window == null ? void 0 : _window.matchMedia) == null ? void 0 : _g.call(_window, "(display-mode: standalone)")) == null ? void 0 : _h.matches);
3793
- info.node = typeof process !== "undefined" && ((_i = process == null ? void 0 : process.release) == null ? void 0 : _i.name) === "node";
3794
- info.browser = !info.electron && !info.wkwebview && !info.node;
3795
- info.worker = typeof WorkerGlobalScope !== "undefined" && self instanceof WorkerGlobalScope;
3796
- info.jest = typeof jest !== "undefined" || typeof vitest !== "undefined";
3797
- info.test = info.jest;
3798
- info.macosNative = info.wkwebview && info.macos;
3799
- info.iosNative = info.wkwebview && info.ios;
3800
- info.appleNative = info.wkwebview;
3801
- info.touch = _window && "ontouchstart" in _window || ((_navigator == null ? void 0 : _navigator.maxTouchPoints) || 0) > 1 || (_navigator == null ? void 0 : _navigator.msPointerEnabled) && (_window == null ? void 0 : _window.MSGesture) || (_window == null ? void 0 : _window.DocumentTouch) && document instanceof DocumentTouch;
3802
- return info;
3803
- }
3804
- __name(detect, "detect");
3805
- var isBrowser = /* @__PURE__ */ __name(() => typeof window !== "undefined" && globalThis === window, "isBrowser");
3806
- var platform = detect();
3807
- function useExitHandler(handler) {
3808
- if (isBrowser()) {
3809
- window.addEventListener("beforeunload", handler);
3810
- } else if (typeof process !== "undefined") {
3811
- process.on("exit", () => handler);
3812
- }
3813
- }
3814
- __name(useExitHandler, "useExitHandler");
3815
-
3816
- // src/common/storage/memstorage.ts
3817
- Logger("zeed:memstorage");
3818
- var MemStorage = class {
3819
- constructor(opt = {}) {
3820
- this.store = {};
3821
- }
3822
- setItem(key, value) {
3823
- this.store[key] = cloneObject(value);
3824
- }
3825
- getItem(key) {
3826
- if (this.store.hasOwnProperty(key)) {
3827
- return cloneObject(this.store[key]);
3828
- }
3829
- }
3830
- removeItem(key) {
3831
- delete this.store[key];
3832
- }
3833
- clear() {
3834
- this.store = {};
3835
- }
3836
- allKeys() {
3837
- return Object.keys(this.store);
3838
- }
3839
- };
3840
- __name(MemStorage, "MemStorage");
3841
-
3842
- // src/browser/base64.ts
3843
- var { error } = Logger("zeed:base64");
3844
- function urlBase64ToUint8Array(base64String) {
3845
- try {
3846
- let padding = "=".repeat((4 - base64String.length % 4) % 4);
3847
- let base64 = (base64String + padding).replace(/-/g, "+").replace(/_/g, "/");
3848
- let rawData = window.atob(base64);
3849
- let outputArray = new Uint8Array(rawData.length);
3850
- for (let i = 0; i < rawData.length; ++i) {
3851
- outputArray[i] = rawData.charCodeAt(i);
3852
- }
3853
- return outputArray;
3854
- } catch (err) {
3855
- error(err, base64String);
3856
- }
3857
- }
3858
- __name(urlBase64ToUint8Array, "urlBase64ToUint8Array");
3859
-
3860
- // src/browser/gravatar.ts
3861
- var log9 = Logger("zeed:gravatar");
3862
- function gravatar(email, options) {
3863
- function md5cycle(e, t) {
3864
- var n = e[0], r = e[1], i = e[2], s = e[3];
3865
- n = ff(n, r, i, s, t[0], 7, -680876936);
3866
- s = ff(s, n, r, i, t[1], 12, -389564586);
3867
- i = ff(i, s, n, r, t[2], 17, 606105819);
3868
- r = ff(r, i, s, n, t[3], 22, -1044525330);
3869
- n = ff(n, r, i, s, t[4], 7, -176418897);
3870
- s = ff(s, n, r, i, t[5], 12, 1200080426);
3871
- i = ff(i, s, n, r, t[6], 17, -1473231341);
3872
- r = ff(r, i, s, n, t[7], 22, -45705983);
3873
- n = ff(n, r, i, s, t[8], 7, 1770035416);
3874
- s = ff(s, n, r, i, t[9], 12, -1958414417);
3875
- i = ff(i, s, n, r, t[10], 17, -42063);
3876
- r = ff(r, i, s, n, t[11], 22, -1990404162);
3877
- n = ff(n, r, i, s, t[12], 7, 1804603682);
3878
- s = ff(s, n, r, i, t[13], 12, -40341101);
3879
- i = ff(i, s, n, r, t[14], 17, -1502002290);
3880
- r = ff(r, i, s, n, t[15], 22, 1236535329);
3881
- n = gg(n, r, i, s, t[1], 5, -165796510);
3882
- s = gg(s, n, r, i, t[6], 9, -1069501632);
3883
- i = gg(i, s, n, r, t[11], 14, 643717713);
3884
- r = gg(r, i, s, n, t[0], 20, -373897302);
3885
- n = gg(n, r, i, s, t[5], 5, -701558691);
3886
- s = gg(s, n, r, i, t[10], 9, 38016083);
3887
- i = gg(i, s, n, r, t[15], 14, -660478335);
3888
- r = gg(r, i, s, n, t[4], 20, -405537848);
3889
- n = gg(n, r, i, s, t[9], 5, 568446438);
3890
- s = gg(s, n, r, i, t[14], 9, -1019803690);
3891
- i = gg(i, s, n, r, t[3], 14, -187363961);
3892
- r = gg(r, i, s, n, t[8], 20, 1163531501);
3893
- n = gg(n, r, i, s, t[13], 5, -1444681467);
3894
- s = gg(s, n, r, i, t[2], 9, -51403784);
3895
- i = gg(i, s, n, r, t[7], 14, 1735328473);
3896
- r = gg(r, i, s, n, t[12], 20, -1926607734);
3897
- n = hh(n, r, i, s, t[5], 4, -378558);
3898
- s = hh(s, n, r, i, t[8], 11, -2022574463);
3899
- i = hh(i, s, n, r, t[11], 16, 1839030562);
3900
- r = hh(r, i, s, n, t[14], 23, -35309556);
3901
- n = hh(n, r, i, s, t[1], 4, -1530992060);
3902
- s = hh(s, n, r, i, t[4], 11, 1272893353);
3903
- i = hh(i, s, n, r, t[7], 16, -155497632);
3904
- r = hh(r, i, s, n, t[10], 23, -1094730640);
3905
- n = hh(n, r, i, s, t[13], 4, 681279174);
3906
- s = hh(s, n, r, i, t[0], 11, -358537222);
3907
- i = hh(i, s, n, r, t[3], 16, -722521979);
3908
- r = hh(r, i, s, n, t[6], 23, 76029189);
3909
- n = hh(n, r, i, s, t[9], 4, -640364487);
3910
- s = hh(s, n, r, i, t[12], 11, -421815835);
3911
- i = hh(i, s, n, r, t[15], 16, 530742520);
3912
- r = hh(r, i, s, n, t[2], 23, -995338651);
3913
- n = ii(n, r, i, s, t[0], 6, -198630844);
3914
- s = ii(s, n, r, i, t[7], 10, 1126891415);
3915
- i = ii(i, s, n, r, t[14], 15, -1416354905);
3916
- r = ii(r, i, s, n, t[5], 21, -57434055);
3917
- n = ii(n, r, i, s, t[12], 6, 1700485571);
3918
- s = ii(s, n, r, i, t[3], 10, -1894986606);
3919
- i = ii(i, s, n, r, t[10], 15, -1051523);
3920
- r = ii(r, i, s, n, t[1], 21, -2054922799);
3921
- n = ii(n, r, i, s, t[8], 6, 1873313359);
3922
- s = ii(s, n, r, i, t[15], 10, -30611744);
3923
- i = ii(i, s, n, r, t[6], 15, -1560198380);
3924
- r = ii(r, i, s, n, t[13], 21, 1309151649);
3925
- n = ii(n, r, i, s, t[4], 6, -145523070);
3926
- s = ii(s, n, r, i, t[11], 10, -1120210379);
3927
- i = ii(i, s, n, r, t[2], 15, 718787259);
3928
- r = ii(r, i, s, n, t[9], 21, -343485551);
3929
- e[0] = add32(n, e[0]);
3930
- e[1] = add32(r, e[1]);
3931
- e[2] = add32(i, e[2]);
3932
- e[3] = add32(s, e[3]);
3933
- }
3934
- __name(md5cycle, "md5cycle");
3935
- function cmn(e, t, n, r, i, s) {
3936
- t = add32(add32(t, e), add32(r, s));
3937
- return add32(t << i | t >>> 32 - i, n);
3938
- }
3939
- __name(cmn, "cmn");
3940
- function ff(e, t, n, r, i, s, o) {
3941
- return cmn(t & n | ~t & r, e, t, i, s, o);
3942
- }
3943
- __name(ff, "ff");
3944
- function gg(e, t, n, r, i, s, o) {
3945
- return cmn(t & r | n & ~r, e, t, i, s, o);
3946
- }
3947
- __name(gg, "gg");
3948
- function hh(e, t, n, r, i, s, o) {
3949
- return cmn(t ^ n ^ r, e, t, i, s, o);
3950
- }
3951
- __name(hh, "hh");
3952
- function ii(e, t, n, r, i, s, o) {
3953
- return cmn(n ^ (t | ~r), e, t, i, s, o);
3954
- }
3955
- __name(ii, "ii");
3956
- function md51(e) {
3957
- var t = e.length, n = [1732584193, -271733879, -1732584194, 271733878], r;
3958
- for (r = 64; r <= e.length; r += 64) {
3959
- md5cycle(n, md5blk(e.substring(r - 64, r)));
3960
- }
3961
- e = e.substring(r - 64);
3962
- var i = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];
3963
- for (r = 0; r < e.length; r++)
3964
- i[r >> 2] |= e.charCodeAt(r) << (r % 4 << 3);
3965
- i[r >> 2] |= 128 << (r % 4 << 3);
3966
- if (r > 55) {
3967
- md5cycle(n, i);
3968
- for (r = 0; r < 16; r++)
3969
- i[r] = 0;
3970
- }
3971
- i[14] = t * 8;
3972
- md5cycle(n, i);
3973
- return n;
3974
- }
3975
- __name(md51, "md51");
3976
- function md5blk(e) {
3977
- var t = [], n;
3978
- for (n = 0; n < 64; n += 4) {
3979
- t[n >> 2] = e.charCodeAt(n) + (e.charCodeAt(n + 1) << 8) + (e.charCodeAt(n + 2) << 16) + (e.charCodeAt(n + 3) << 24);
3980
- }
3981
- return t;
3982
- }
3983
- __name(md5blk, "md5blk");
3984
- function rhex(e) {
3985
- var t = "", n = 0;
3986
- for (; n < 4; n++)
3987
- t += hex_chr[e >> n * 8 + 4 & 15] + hex_chr[e >> n * 8 & 15];
3988
- return t;
3989
- }
3990
- __name(rhex, "rhex");
3991
- function hex(e) {
3992
- for (var t = 0; t < e.length; t++)
3993
- e[t] = rhex(e[t]);
3994
- return e.join("");
3995
- }
3996
- __name(hex, "hex");
3997
- function md5(e) {
3998
- return hex(md51(e));
3999
- }
4000
- __name(md5, "md5");
4001
- function add32(e, t) {
4002
- return e + t & 4294967295;
4003
- }
4004
- __name(add32, "add32");
4005
- var hex_chr = "0123456789abcdef".split("");
4006
- var options = options || {}, base, params = [];
4007
- options = {
4008
- size: options.size || "50",
4009
- rating: options.rating || "g",
4010
- secure: options.secure || location.protocol === "https:",
4011
- backup: options.backup || ""
4012
- };
4013
- email = email.trim().toLowerCase();
4014
- base = options.secure ? "https://secure.gravatar.com/avatar/" : "http://www.gravatar.com/avatar/";
4015
- if (options.rating) {
4016
- params.push("r=" + options.rating);
4017
- }
4018
- if (options.backup) {
4019
- params.push("d=" + encodeURIComponent(options.backup));
4020
- }
4021
- if (options.size) {
4022
- params.push("s=" + options.size);
4023
- }
4024
- return base + md5(email) + "?" + params.join("&");
4025
- }
4026
- __name(gravatar, "gravatar");
4027
- function gravatarURLByEmail(email, defaultURL = "") {
4028
- try {
4029
- return gravatar(email, {
4030
- size: 256,
4031
- backup: "monsterid",
4032
- secure: true
4033
- });
4034
- } catch (error2) {
4035
- log9("Gravatar issue: Did not find an image for " + email);
4036
- return defaultURL;
4037
- }
4038
- }
4039
- __name(gravatarURLByEmail, "gravatarURLByEmail");
4040
-
4041
- // src/browser/localstorage.ts
4042
- var log10 = Logger("zeed:localstorage");
4043
- var LocalStorage = class {
4044
- constructor(opt) {
4045
- this.pretty = false;
4046
- log10.assert(opt.name, "name required");
4047
- this.name = opt.name;
4048
- this.prefix = `${opt.name}$`;
4049
- this.objectToString = opt.objectToString ?? ((data) => {
4050
- return this.pretty ? JSON.stringify(data, null, 2) : JSON.stringify(data);
4051
- });
4052
- this.objectFromString = opt.objectFromString ?? ((data) => {
4053
- try {
4054
- return JSON.parse(data);
4055
- } catch (err) {
4056
- log10.warn(`LocalStorage parse error '${err}' in`, data);
4057
- }
4058
- });
4059
- }
4060
- setItem(key, value) {
4061
- const data = this.objectToString(value);
4062
- localStorage.setItem(`${this.prefix}${key}`, data);
4063
- }
4064
- getItem(key) {
4065
- let value = localStorage.getItem(`${this.prefix}${key}`);
4066
- if (value != null) {
4067
- return this.objectFromString(value);
4068
- }
4069
- }
4070
- removeItem(key) {
4071
- localStorage.removeItem(`${this.prefix}${key}`);
4072
- }
4073
- clear() {
4074
- Object.keys(localStorage).filter((key) => key.startsWith(this.prefix)).forEach((key) => {
4075
- localStorage.removeItem(key);
4076
- });
4077
- }
4078
- allKeys() {
4079
- const prefixLength = this.prefix.length;
4080
- return Object.keys(localStorage).filter((key) => key.startsWith(this.prefix)).map((key) => key.substr(prefixLength));
4081
- }
4082
- };
4083
- __name(LocalStorage, "LocalStorage");
4084
-
4085
- // src/browser/log-colors.ts
4086
- var colors = [
4087
- "#0000CC",
4088
- "#0000FF",
4089
- "#0033CC",
4090
- "#0033FF",
4091
- "#0066CC",
4092
- "#0066FF",
4093
- "#0099CC",
4094
- "#0099FF",
4095
- "#00CC00",
4096
- "#00CC33",
4097
- "#00CC66",
4098
- "#00CC99",
4099
- "#00CCCC",
4100
- "#00CCFF",
4101
- "#3300CC",
4102
- "#3300FF",
4103
- "#3333CC",
4104
- "#3333FF",
4105
- "#3366CC",
4106
- "#3366FF",
4107
- "#3399CC",
4108
- "#3399FF",
4109
- "#33CC00",
4110
- "#33CC33",
4111
- "#33CC66",
4112
- "#33CC99",
4113
- "#33CCCC",
4114
- "#33CCFF",
4115
- "#6600CC",
4116
- "#6600FF",
4117
- "#6633CC",
4118
- "#6633FF",
4119
- "#66CC00",
4120
- "#66CC33",
4121
- "#9900CC",
4122
- "#9900FF",
4123
- "#9933CC",
4124
- "#9933FF",
4125
- "#99CC00",
4126
- "#99CC33",
4127
- "#CC0000",
4128
- "#CC0033",
4129
- "#CC0066",
4130
- "#CC0099",
4131
- "#CC00CC",
4132
- "#CC00FF",
4133
- "#CC3300",
4134
- "#CC3333",
4135
- "#CC3366",
4136
- "#CC3399",
4137
- "#CC33CC",
4138
- "#CC33FF",
4139
- "#CC6600",
4140
- "#CC6633",
4141
- "#CC9900",
4142
- "#CC9933",
4143
- "#CCCC00",
4144
- "#CCCC33",
4145
- "#FF0000",
4146
- "#FF0033",
4147
- "#FF0066",
4148
- "#FF0099",
4149
- "#FF00CC",
4150
- "#FF00FF",
4151
- "#FF3300",
4152
- "#FF3333",
4153
- "#FF3366",
4154
- "#FF3399",
4155
- "#FF33CC",
4156
- "#FF33FF",
4157
- "#FF6600",
4158
- "#FF6633",
4159
- "#FF9900",
4160
- "#FF9933",
4161
- "#FFCC00",
4162
- "#FFCC33"
4163
- ];
4164
- function supportsColors() {
4165
- if (typeof window !== "undefined" && window.process && (window.process.type === "renderer" || window.process.__nwjs)) {
4166
- return true;
4167
- }
4168
- if (typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)) {
4169
- return false;
4170
- }
4171
- return typeof document !== "undefined" && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance || typeof window !== "undefined" && window.console && (window.console.firebug || window.console.exception && window.console.table) || typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31 || typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/);
4172
- }
4173
- __name(supportsColors, "supportsColors");
4174
- function selectColor(namespace) {
4175
- let hash = 0;
4176
- for (let i = 0; i < namespace.length; i++) {
4177
- hash = (hash << 5) - hash + namespace.charCodeAt(i);
4178
- hash |= 0;
4179
- }
4180
- return colors[Math.abs(hash) % colors.length];
4181
- }
4182
- __name(selectColor, "selectColor");
4183
-
4184
- // src/browser/log-browser.ts
4185
- var styleFont = `font-family: "JetBrains Mono", Menlo; font-size: 11px;`;
4186
- var styleDefault = `${styleFont}`;
4187
- var styleBold = `font-weight: 600; ${styleFont}`;
4188
- var useColors = supportsColors();
4189
- var namespaces = {};
4190
- var time = getTimestamp();
4191
- function LoggerBrowserHandler(opt = {}) {
4192
- const {
4193
- filter = void 0,
4194
- level = void 0,
4195
- colors: colors2 = true,
4196
- levelHelper = false,
4197
- nameBrackets = true,
4198
- padding = 16
4199
- } = opt;
4200
- const matchesNamespace = useNamespaceFilter(filter);
4201
- const matchesLevel = useLevelFilter(level);
4202
- return (msg) => {
4203
- var _a;
4204
- if (!matchesLevel(msg.level))
4205
- return;
4206
- if (!matchesNamespace(msg.name))
4207
- return;
4208
- const timeNow = getTimestamp();
4209
- let name = msg.name || "";
4210
- let ninfo = namespaces[name || ""];
4211
- if (ninfo == null) {
4212
- ninfo = {
4213
- color: selectColor(name)
4214
- };
4215
- namespaces[name] = ninfo;
4216
- }
4217
- const diff = formatMilliseconds(timeNow - time);
4218
- let args;
4219
- if (padding > 0) {
4220
- name = name.padEnd(16, " ");
4221
- }
4222
- if (colors2 && useColors) {
4223
- args = [`%c${name}%c %s %c+${diff}`];
4224
- args.push(`color:${ninfo.color}; ${styleBold}`);
4225
- args.push(styleDefault);
4226
- args.push(((_a = msg.messages) == null ? void 0 : _a[0]) ?? "");
4227
- args.push(`color:${ninfo.color};`);
4228
- args.push(...msg.messages.slice(1));
4229
- } else {
4230
- args = [name, ...msg.messages, `+${diff}`];
4231
- }
4232
- switch (msg.level) {
4233
- case 1 /* info */:
4234
- if (opt.levelHelper)
4235
- args[0] = `I|* ` + args[0];
4236
- console.info(...args);
4237
- break;
4238
- case 2 /* warn */:
4239
- if (opt.levelHelper)
4240
- args[0] = `W|** ` + args[0];
4241
- console.warn(...args);
4242
- break;
4243
- case 3 /* error */:
4244
- if (opt.levelHelper)
4245
- args[0] = `E|*** ` + args[0];
4246
- console.error(...args);
4247
- break;
4248
- default:
4249
- if (opt.levelHelper)
4250
- args[0] = `D| ` + args[0];
4251
- console.debug(...args);
4252
- break;
4253
- }
4254
- };
4255
- }
4256
- __name(LoggerBrowserHandler, "LoggerBrowserHandler");
4257
- function LoggerBrowserSetupDebugFactory(opt = {}) {
4258
- const filter = opt.filter ?? localStorage.zeed ?? localStorage.debug;
4259
- return /* @__PURE__ */ __name(function LoggerBrowserDebugFactory(name = "") {
4260
- let log11;
4261
- const matches = useNamespaceFilter(filter);
4262
- if (matches(name)) {
4263
- let fixedArgs = [];
4264
- if (useColors) {
4265
- const color = selectColor(name);
4266
- fixedArgs.push(`%c${name.padEnd(16, " ")}%c %s`);
4267
- fixedArgs.push(`color:${color}; ${styleBold}`);
4268
- fixedArgs.push(styleDefault);
4269
- } else {
4270
- fixedArgs.push(`[${name}] %s`);
4271
- }
4272
- log11 = console.debug.bind(console, ...fixedArgs);
4273
- log11.debug = console.debug.bind(console, ...fixedArgs);
4274
- log11.info = console.info.bind(console, ...fixedArgs);
4275
- log11.warn = console.warn.bind(console, ...fixedArgs);
4276
- log11.error = console.error.bind(console, ...fixedArgs);
4277
- log11.assert = console.assert.bind(console);
4278
- log11.assertEqual = function(value, expected, ...args) {
4279
- let equal = deepEqual(value, expected);
4280
- if (!equal) {
4281
- log11.assert(
4282
- equal,
4283
- `Assert did fail. Expected ${expected} got ${value}`,
4284
- expected,
4285
- value,
4286
- ...args
4287
- );
4288
- }
4289
- };
4290
- log11.assertNotEqual = function(value, expected, ...args) {
4291
- let equal = deepEqual(value, expected);
4292
- if (equal) {
4293
- log11.assert(
4294
- equal,
4295
- `Assert did fail. Expected ${expected} not to be equal with ${value}`,
4296
- expected,
4297
- value,
4298
- ...args
4299
- );
4300
- }
4301
- };
4302
- } else {
4303
- const noop = /* @__PURE__ */ __name(() => {
4304
- }, "noop");
4305
- log11 = noop;
4306
- log11.debug = noop;
4307
- log11.info = noop;
4308
- log11.warn = noop;
4309
- log11.error = noop;
4310
- log11.assert = noop;
4311
- log11.assertEqual = noop;
4312
- log11.assertNotEqual = noop;
4313
- }
4314
- log11.extend = (subName) => {
4315
- return LoggerBrowserDebugFactory(name ? `${name}:${subName}` : subName);
4316
- };
4317
- log11.label = name;
4318
- return log11;
4319
- }, "LoggerBrowserDebugFactory");
4320
- }
4321
- __name(LoggerBrowserSetupDebugFactory, "LoggerBrowserSetupDebugFactory");
4322
- function activateConsoleDebug(opt = {}) {
4323
- console.info("activateConsoleDebug is activated by default in browsers");
4324
- }
4325
- __name(activateConsoleDebug, "activateConsoleDebug");
4326
-
4327
- // src/browser/log-browser-classic.ts
4328
- var namespaces2 = {};
4329
- var time2 = getTimestamp();
4330
- var useColors2 = supportsColors();
4331
- function LoggerBrowserClassicHandler(level, opt = {}) {
4332
- const { filter = void 0 } = opt;
4333
- const matchesNamespace = useNamespaceFilter(filter);
4334
- const matchesLevel = useLevelFilter(level);
4335
- return (msg) => {
4336
- if (!matchesLevel(msg.level))
4337
- return;
4338
- if (!matchesNamespace(msg.name))
4339
- return;
4340
- const timeNow = getTimestamp();
4341
- let name = msg.name || "";
4342
- let ninfo = namespaces2[name || ""];
4343
- if (ninfo == null) {
4344
- ninfo = {
4345
- color: selectColor(name)
4346
- };
4347
- namespaces2[name] = ninfo;
4348
- }
4349
- const diff = formatMilliseconds(timeNow - time2);
4350
- let args;
4351
- if (opt.colors && useColors2) {
4352
- args = opt.nameBrackets ? [`%c[${name}]`] : [`%c${name}`];
4353
- args.push(`color:${ninfo.color}`);
4354
- args.push(...msg.messages);
4355
- } else {
4356
- args = [name, ...msg.messages];
4357
- }
4358
- args.push(`+${diff}`);
4359
- switch (msg.level) {
4360
- case 1 /* info */:
4361
- if (opt.levelHelper)
4362
- args[0] = `I|* ` + args[0];
4363
- console.info(...args);
4364
- break;
4365
- case 2 /* warn */:
4366
- if (opt.levelHelper)
4367
- args[0] = `W|** ` + args[0];
4368
- console.warn(...args);
4369
- break;
4370
- case 3 /* error */:
4371
- if (opt.levelHelper)
4372
- args[0] = `E|*** ` + args[0];
4373
- console.error(...args);
4374
- break;
4375
- default:
4376
- if (opt.levelHelper)
4377
- args[0] = `D| ` + args[0];
4378
- console.debug(...args);
4379
- break;
4380
- }
4381
- };
4382
- }
4383
- __name(LoggerBrowserClassicHandler, "LoggerBrowserClassicHandler");
1
+ "use strict";var ge=Object.defineProperty;var Tr=Object.getOwnPropertyDescriptor;var Lr=Object.getOwnPropertyNames;var vr=Object.prototype.hasOwnProperty;var o=(e,t)=>ge(e,"name",{value:t,configurable:!0});var Cr=(e,t)=>{for(var r in t)ge(e,r,{get:t[r],enumerable:!0})},Ar=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of Lr(t))!vr.call(e,i)&&i!==r&&ge(e,i,{get:()=>t[i],enumerable:!(n=Tr(t,i))||n.enumerable});return e};var Fr=e=>Ar(ge({},"__esModule",{value:!0}),e);var Wi={};Cr(Wi,{Channel:()=>ce,CryptoEncoder:()=>$e,Currency:()=>k,DAY_MS:()=>Me,Day:()=>F,Emitter:()=>I,JsonEncoder:()=>G,LocalChannel:()=>ne,LocalStorage:()=>Ne,LogLevel:()=>W,LogLevelAlias:()=>ze,Logger:()=>A,LoggerBrowserClassicHandler:()=>Ji,LoggerBrowserHandler:()=>bt,LoggerBrowserSetupDebugFactory:()=>wt,LoggerConsoleHandler:()=>se,LoggerContext:()=>qe,LoggerMemoryHandler:()=>Ci,MemStorage:()=>He,NoopEncoder:()=>Oe,PoolTaskIdConflictResolution:()=>ar,PoolTaskState:()=>sr,PubSub:()=>fe,SerialQueue:()=>ke,Uint8ArrayToHexDump:()=>We,Uint8ArrayToJson:()=>we,Uint8ArrayToString:()=>At,XRX:()=>Ue,_decodeUtf8Polyfill:()=>Ct,_encodeUtf8Polyfill:()=>vt,activateConsoleDebug:()=>Vi,arrayAvg:()=>mn,arrayBatches:()=>yn,arrayEmptyInPlace:()=>an,arrayFilterInPlace:()=>Ce,arrayFlatten:()=>O,arrayIntersection:()=>Rt,arrayIsEqual:()=>Ot,arrayMax:()=>pn,arrayMin:()=>dn,arrayMinus:()=>It,arrayRandomElement:()=>fn,arrayRemoveElement:()=>nn,arraySetElement:()=>on,arrayShuffle:()=>ln,arrayShuffleForce:()=>cn,arrayShuffleInPlace:()=>Qe,arraySorted:()=>kt,arraySortedNumbers:()=>un,arraySum:()=>gn,arraySymmetricDifference:()=>rn,arrayToggleInPlace:()=>sn,arrayUnion:()=>Ut,arrayUnique:()=>ve,avg:()=>Yr,between:()=>Kr,cloneJsonObject:()=>No,cloneObject:()=>Ie,cmp:()=>Le,composeOrderby:()=>en,createArray:()=>hn,createLocalChannelPair:()=>Ai,createPromise:()=>nt,createPromiseProxy:()=>mt,csv:()=>_r,currency:()=>j,dateStringToDays:()=>fo,day:()=>co,dayDay:()=>Vt,dayDiff:()=>ro,dayFromAny:()=>Kn,dayFromDate:()=>ue,dayFromDateGMT:()=>Qn,dayFromParts:()=>Se,dayFromString:()=>rt,dayFromTimestamp:()=>Gt,dayFromToday:()=>Zn,dayMonth:()=>et,dayMonthStart:()=>Xn,dayOffset:()=>to,dayToDate:()=>tt,dayToDateGMT:()=>Yn,dayToParts:()=>Wn,dayToString:()=>_t,dayToTimestamp:()=>De,dayYear:()=>Pe,dayYearStart:()=>eo,debounce:()=>Li,decimal:()=>Wt,decimalCentsPart:()=>mo,decimalFromCents:()=>po,decimalToCents:()=>go,decodeBase16:()=>Tn,decodeBase32:()=>vn,decodeBase58:()=>An,decodeBase62:()=>En,decodeBase64:()=>Mn,decrypt:()=>Ye,deepEqual:()=>N,deepMerge:()=>ie,deriveKeyPbkdf2:()=>qr,detect:()=>pr,digest:()=>zr,empty:()=>Ho,encodeBase16:()=>wn,encodeBase32:()=>Ln,encodeBase58:()=>Cn,encodeBase62:()=>Fn,encodeBase64:()=>Dn,encodeQuery:()=>ft,encrypt:()=>Ke,endSortWeight:()=>ct,ensureKey:()=>ko,ensureKeyAsync:()=>Oo,equalBinary:()=>Je,escapeHTML:()=>at,escapeRegExp:()=>Lo,fetchBasic:()=>ht,fetchJson:()=>Si,fetchOptionsBasicAuth:()=>cr,fetchOptionsFormURLEncoded:()=>Ui,fetchOptionsJson:()=>Ri,fetchText:()=>Ii,fixBrokenUth8String:()=>zn,forEachDay:()=>uo,forTimes:()=>zo,formatMessages:()=>zt,formatMilliseconds:()=>le,fromBase64:()=>jr,fromCamelCase:()=>In,getGlobal:()=>ki,getGlobalContext:()=>Y,getGlobalEmitter:()=>ri,getNamespaceFilterString:()=>Tt,getNavigator:()=>fr,getSecureRandom:()=>Mt,getSecureRandomIfPossible:()=>U,getTimestamp:()=>H,getWindow:()=>xt,gravatarURLByEmail:()=>zi,immediate:()=>oo,isArray:()=>me,isBoolean:()=>Ur,isBrowser:()=>Be,isEven:()=>ut,isHalf:()=>X,isInteger:()=>Sr,isLocalHost:()=>vi,isNullOrUndefined:()=>Rr,isNumber:()=>Pr,isObject:()=>J,isPrime:()=>Xr,isPrimeRX:()=>Qr,isPrimitive:()=>je,isPromise:()=>S,isRecord:()=>Dr,isSafeInteger:()=>Ir,isString:()=>Mr,isTimeout:()=>so,isUint8Array:()=>kr,joinToUint8Array:()=>Br,jsonStringify:()=>Ae,jsonToUint8Array:()=>be,last:()=>Bo,lazyListener:()=>oi,linkifyPlainText:()=>Uo,memoize:()=>jo,messages:()=>ni,moveSortWeight:()=>So,parseBasicAuth:()=>lr,parseDate:()=>ii,parseLogLevel:()=>ye,parseOrderby:()=>St,parseQuery:()=>Ro,platform:()=>Oi,promisify:()=>z,qid:()=>gi,randomBoolean:()=>Jr,randomFloat:()=>Zr,randomInt:()=>Wr,randomUint8Array:()=>Z,regExpEscape:()=>_o,regExpString:()=>er,renderMessages:()=>jn,roundDown:()=>Co,roundHalfAwayFromZero:()=>Eo,roundHalfDown:()=>Do,roundHalfEven:()=>Mo,roundHalfOdd:()=>Fo,roundHalfTowardsZero:()=>Po,roundHalfUp:()=>Ao,roundUp:()=>vo,selectColor:()=>oe,size:()=>$o,sleep:()=>no,sortedItems:()=>Yt,sortedOrderby:()=>tn,startSortWeight:()=>lt,stringToBoolean:()=>Rn,stringToFloat:()=>On,stringToInteger:()=>kn,stringToUInt8Array:()=>Ge,suid:()=>xi,suidBytes:()=>or,suidBytesDate:()=>ir,suidDate:()=>bi,sum:()=>Pt,supportsColors:()=>pe,throttle:()=>Ti,timeout:()=>io,timeoutReached:()=>ot,timoutError:()=>it,toBase64:()=>_e,toBase64Url:()=>Nr,toBool:()=>Nn,toCamelCase:()=>Pn,toCapitalize:()=>$t,toCapitalizeWords:()=>Sn,toFloat:()=>$n,toHex:()=>Hr,toHumanReadableUrl:()=>Qt,toInt:()=>Bn,toString:()=>Hn,toUint8Array:()=>P,toValidFilename:()=>wo,today:()=>lo,tryTimeout:()=>st,uname:()=>V,unescapeHTML:()=>yo,urlBase64ToUint8Array:()=>Hi,useAsyncMutex:()=>ti,useBase:()=>B,useDefer:()=>Ko,useDispose:()=>Re,useDisposer:()=>Zo,useEventListener:()=>Xo,useExitHandler:()=>$i,useInterval:()=>Qo,useLevelFilter:()=>$,useMessageHub:()=>Fi,useMutex:()=>ei,useNamespaceFilter:()=>R,usePool:()=>wi,usePubSub:()=>Ei,useRPC:()=>Pi,useTimeout:()=>Yo,uuid:()=>q,uuid32Decode:()=>pi,uuid32Encode:()=>fi,uuid32bit:()=>ai,uuidB32:()=>ci,uuidBytes:()=>gt,uuidDecode:()=>li,uuidEncode:()=>ui,uuidv4:()=>yi,valueToBoolean:()=>Ht,valueToFloat:()=>jt,valueToInteger:()=>Nt,valueToString:()=>Fe,waitOn:()=>ao});module.exports=Fr(Wi);function Er(){if(typeof self<"u")return self;if(typeof window<"u")return window;if(typeof global<"u")return global;if(typeof globalThis<"u")return globalThis;throw new Error("unable to locate global object")}o(Er,"_global");function Y(){let e=Er();return e._zeedGlobal==null&&(e._zeedGlobal={}),e._zeedGlobal}o(Y,"getGlobalContext");function J(e){return e!=null&&typeof e=="object"}o(J,"isObject");function je(e){return Object(e)!==e}o(je,"isPrimitive");function me(e){return Array.isArray(e)}o(me,"isArray");function Dr(e){return J(e)&&!me(e)}o(Dr,"isRecord");function Mr(e){return typeof e=="string"}o(Mr,"isString");function Pr(e){return typeof e=="number"}o(Pr,"isNumber");function Sr(e){return typeof e=="number"&&Number.isInteger(e)}o(Sr,"isInteger");function Ir(e){return typeof e=="number"&&Number.isSafeInteger(e)}o(Ir,"isSafeInteger");function Ur(e){return typeof e=="boolean"}o(Ur,"isBoolean");function Rr(e){return e==null}o(Rr,"isNullOrUndefined");function kr(e){return J(e)&&e.constructor.name==="Uint8Array"}o(kr,"isUint8Array");function N(e,t,r=new WeakSet){if(e===t||r.has(t))return!0;if(je(t)||r.add(t),!(e instanceof Object)||!(t instanceof Object)||e.constructor!==t.constructor||e.length!==t.length)return!1;for(let n in e){if(!e.hasOwnProperty(n))continue;if(!t.hasOwnProperty(n))return!1;let i=e[n],s=t[n];if(!N(i,s,r))return!1}for(let n in t)if(t.hasOwnProperty(n)&&!e.hasOwnProperty(n))return!1;return!0}o(N,"deepEqual");function ie(e,...t){for(let r of t)J(e)||(e={}),r!=null&&Object.keys(r).forEach(n=>{let i=e[n],s=r[n];Array.isArray(i)&&Array.isArray(s)?e[n]=i.concat(s):J(i)&&J(s)?e[n]=ie(Object.assign({},i),s):e[n]=s});return e}o(ie,"deepMerge");function Tt(e){return e===!0||e==="true"||e==="1"||typeof e=="number"&&e!==0?e="*":e===!1||e==="false"||e===0||e==="0"||e==null||e==="null"||e==="undefined"?e="":e=String(e),e}o(Tt,"getNamespaceFilterString");var Or=Tt(typeof process<"u"?process.env.ZEED??process.env.DEBUG:typeof localStorage<"u"?localStorage.zeed??localStorage.debug:"*");function R(e=Or){let t,r=[],n=[];if(!e)t=o(function(i){return!1},"fn");else if(e==="*")t=o(function(i){return!0},"fn");else{let i,s=e.split(/[\s,]+/),u=s.length;for(i=0;i<u;i++){if(!s[i])continue;let a=s[i].replace(/\*/g,".*?");a[0]==="-"?r.push(new RegExp("^"+a.substr(1)+"$")):n.push(new RegExp("^"+a+"$"))}t=o(function(a){if(r.length===0&&n.length===0)return!0;let p,g;for(p=0,g=r.length;p<g;p++)if(r[p].test(a))return!1;for(p=0,g=n.length;p<g;p++)if(n[p].test(a))return!0;return!1},"fn")}return t.accept=n,t.reject=r,t.filter=e,t}o(R,"useNamespaceFilter");var $r=typeof process<"u"?process.env.ZEED_LEVEL??process.env.LEVEL??process.env.DEBUG_LEVEL:typeof localStorage<"u"?localStorage.zeed_level??localStorage.level??localStorage.debug_level:void 0;function ye(e){if(e===!1)return 1/0;if(typeof e=="number")return e;if(typeof e=="string"){let t=ze[e.toLocaleLowerCase().trim()];if(t!=null)return t}return-1}o(ye,"parseLogLevel");function $(e=$r){let t=ye(e);return r=>r>=t}o($,"useLevelFilter");function se(e={}){let{level:t=void 0,filter:r=void 0,colors:n=!0,levelHelper:i=!1,nameBrackets:s=!0,padding:u=16}=e,a=R(r),p=$(t);return g=>{if(!p(g.level)||!a(g.name))return;let y=g.name?`[${g.name}]`:"";switch(g.level){case 1:console.info(`I|* ${y}`,...g.messages);break;case 2:console.warn(`W|** ${y}`,...g.messages);break;case 3:console.error(`E|*** ${y}`,...g.messages);break;default:console.debug(`D| ${y}`,...g.messages);break}}}o(se,"LoggerConsoleHandler");var W=(a=>(a[a.all=-1]="all",a[a.debug=0]="debug",a[a.info=1]="info",a[a.warn=2]="warn",a[a.error=3]="error",a[a.fatal=4]="fatal",a[a.off=1/0]="off",a))(W||{}),ze={"*":-1,a:-1,all:-1,d:0,dbg:0,debug:0,i:1,inf:1,info:1,w:2,warn:2,warning:2,e:3,err:3,error:3,fatal:4,off:1/0,"-":1/0};function qe(e=""){let t=[se()],r=2,n=o(p=>!0,"logCheckNamespace"),i=!1,s=u;function u(p="",g){function y(...x){w({name:p,messages:x,level:0})}o(y,"log"),y.label=p,y.active=!0,y.level=ye(g??-1),y.extend=function(x){return s(p?`${p}:${x}`:x)};let w=o(x=>{if(y.active===!0&&x.level>=a.level&&x.level>=y.level&&n(p))for(let L of t)L&&L(x)},"emit");return y.debug=function(...x){w({name:p,messages:x,level:0})},y.info=function(...x){w({name:p,messages:x,level:1})},y.warn=function(...x){w({name:p,messages:x,level:2})},y.error=function(...x){w({name:p,messages:x,level:3})},y.assert=function(x,...L){x||(typeof console!==void 0&&(console.assert?console.assert(x,...L):console.error(`Assert did fail with: ${x}`,...L)),w({name:p,messages:L||[`Assert did fail with: ${x}`],level:r}))},y.assertEqual=function(x,L,...v){let b=N(x,L);b||y.assert(b,`Assert did fail. Expected ${L} got ${x}`,L,x,...v)},y.assertNotEqual=function(x,L,...v){let b=N(x,L);b&&y.assert(b,`Assert did fail. Expected ${L} not to be equal with ${x}`,L,x,...v)},y}o(u,"LoggerBaseFactory");function a(p="",g){return s(p,g)}return o(a,"Logger"),a.registerHandler=function(p){t.push(p)},a.setFilter=function(p){n=R(p)},a.setLock=(p=!0)=>i=p,a.setHandlers=function(p=[]){s!==u&&(s=u),!i&&(t=[...p].filter(g=>typeof g=="function"))},a.level=-1,a.setLogLevel=function(p=-1){i||(a.level=p)},a.setFactory=function(p){i||(s=p)},a}o(qe,"LoggerContext");var Q;function Ve(){let e=qe();return e.setHandlers([se()]),e}o(Ve,"getLoggerContext");try{let e=Y();e!=null?(e==null?void 0:e.logger)==null?(Q=Ve(),e.logger=Q):Q=e.logger:Q=Ve()}catch{Q=Ve()}var A=Q;var Lt=A("bin");function vt(e){let t=unescape(encodeURIComponent(e)),r=t.length,n=new Uint8Array(r);for(let i=0;i<r;i++)n[i]=t.codePointAt(i)||0;return n}o(vt,"_encodeUtf8Polyfill");function Ct(e){let t=e.length,r="",n=0;for(;t>0;){let i=t<1e4?t:1e4,s=e.subarray(n,n+i);n+=i,r+=String.fromCodePoint.apply(null,s),t-=i}return decodeURIComponent(escape(r))}o(Ct,"_decodeUtf8Polyfill");var he;function Ge(e){if(he==null&&(he=vt,typeof TextEncoder<"u")){let t=new TextEncoder;he=o(r=>t.encode(r),"_textEncoder")}return he(e.normalize("NFC"))}o(Ge,"stringToUInt8Array");var xe;function At(e){if(xe==null&&(xe=Ct,typeof TextDecoder<"u")){let t=new TextDecoder("utf-8",{ignoreBOM:!0});xe=o(r=>t.decode(r),"_textDecoder")}return xe(e).normalize("NFC")}o(At,"Uint8ArrayToString");function P(e){return e instanceof ArrayBuffer?new Uint8Array(e):typeof e=="string"?Ge(e):e.length?new Uint8Array(e):e}o(P,"toUint8Array");function Br(...e){let t=0,r=e.flat(1).map(s=>{let u=P(s);return t+=u.length,u}),n=new Uint8Array(t),i=0;for(let s of r)n.set(s,i),i+=s.length;return n}o(Br,"joinToUint8Array");function Hr(e){if(typeof Buffer<"u")return Buffer.from(P(e)).toString("hex");let t="0123456789abcdef",r="";for(let n of[...P(e)])r+=t[n>>4]+t[n&15];return r}o(Hr,"toHex");function _e(e){let t=P(e);if(typeof Buffer<"u")return Buffer.from(t).toString("base64");let r="";for(let n=0;n<t.byteLength;n++)r+=String.fromCharCode(t[n]);return btoa(r)}o(_e,"toBase64");function Nr(e){let t=P(e);if(typeof Buffer<"u")return Buffer.from(t).toString("base64url");let r="";for(let n=0;n<t.byteLength;n++)r+=String.fromCharCode(t[n]);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_")}o(Nr,"toBase64Url");function jr(e){if(typeof Buffer<"u"){let n=Buffer.from(e,"base64");return new Uint8Array(n.buffer,n.byteOffset,n.byteLength)}let t=atob(e),r=new Uint8Array(t.length);for(let n=0;n<t.length;n++)r[n]=t.charCodeAt(n);return r}o(jr,"fromBase64");function Je(e,t){if(e.byteLength!==t.byteLength)return!1;let r=P(e),n=P(t);for(let i=0;i<r.length;i++)if(r[i]!==n[i])return!1;return!0}o(Je,"equalBinary");function be(e){try{return Ge(JSON.stringify(e))}catch(t){throw Lt.warn("jsonToUint8Array",e),t}}o(be,"jsonToUint8Array");function we(e){try{return JSON.parse(At(e))}catch(t){throw Lt.warn("Uint8ArrayToJson",e),t}}o(we,"Uint8ArrayToJson");function We(e,t){if(typeof e!="string")if(e instanceof ArrayBuffer&&e.byteLength!==void 0)e=String.fromCharCode.apply(String,[].slice.call(new Uint8Array(e)));else if(Array.isArray(e))e=String.fromCharCode.apply(String,e);else if(e.constructor===Uint8Array)e=String.fromCharCode.apply(String,[].slice.call(e));else return!1;t=t||16;for(var r=[],n="0123456789ABCDEF",i=0;i<e.length;i+=t){var s=e.slice(i,Math.min(i+t,e.length)),u=("0000"+i.toString(16)).slice(-4),a=s.split("").map(g=>{var y=g.charCodeAt(0);return" "+n[(240&y)>>4]+n[15&y]}).join("");a+=" ".repeat(t-s.length);var p=s.replace(/[\x00-\x1F\x20]/g,".");p+=" ".repeat(t-s.length),r.push(u+" "+a+" "+p)}return r.join(`
2
+ `)}o(We,"Uint8ArrayToHexDump");function Z(e=16){let t=new Uint8Array(e);if(typeof crypto<"u"&&crypto.getRandomValues)crypto.getRandomValues(t);else for(let r=0;r<e;r++)t[r]=Math.floor(Math.random()*256);return t}o(Z,"randomUint8Array");var Et="SHA-256",Ze="AES-GCM",Ft="PBKDF2";async function zr(e,t=Et){return P(await crypto.subtle.digest(t,P(e)))}o(zr,"digest");async function qr(e,t={}){let r=P(e),n=await crypto.subtle.importKey("raw",r,Ft,!1,["deriveKey"]);return await crypto.subtle.deriveKey({name:Ft,salt:t.salt?P(t.salt):new Uint8Array(0),iterations:t.iterations??1e5,hash:Et},n,{name:Ze,length:256},!0,["encrypt","decrypt"])}o(qr,"deriveKeyPbkdf2");var Te=new Uint8Array([1,1]);async function Ke(e,t){let r=Z(12),n=await crypto.subtle.encrypt({name:Ze,iv:r},t,e),i=new Uint8Array(n),s=Te.length+r.length+i.length,u=new Uint8Array(s),a=0;return u.set(Te,a),a+=Te.length,u.set(r,a),a+=r.length,u.set(i,a),u}o(Ke,"encrypt");async function Ye(e,t){let r=e.subarray(0,2);if(!Je(r,Te))return Promise.reject(`Unknown magic ${r}`);let n=e.subarray(2,2+12),i=e.subarray(2+12,e.length),s=await crypto.subtle.decrypt({name:Ze,iv:n},t,i);return new Uint8Array(s)}o(Ye,"decrypt");var Dt=",";function Vr(e){return/^([-+])?([0-9]+(\.[0-9]+)?|Infinity)$/.test(e)?Number(e):NaN}o(Vr,"filterFloat");function Gr(e){return e==null?"":!isNaN(Vr(e))&&isFinite(e)?parseFloat(e):'"'+String(e).replace(/"/g,'""')+'"'}o(Gr,"escape");function _r(e,t){let r="";t&&(r=t.join(Dt)+`\r
3
+ `);for(let n=0;n<e.length;n++)r+=e[n].map(Gr).join(Dt)+`\r
4
+ `;return r}o(_r,"csv");function Mt(){return crypto.getRandomValues(new Uint32Array(1))[0]/4294967295}o(Mt,"getSecureRandom");function U(){return typeof crypto<"u"?Mt():Math.random()}o(U,"getSecureRandomIfPossible");function Jr(e=.25){return U()<e}o(Jr,"randomBoolean");function Wr(e=100,t=0){return t+Math.floor(U()*(e-t))}o(Wr,"randomInt");function Zr(e=100,t=0){return t+U()*(e-t)}o(Zr,"randomFloat");function Kr(e,t,r){return Math.max(e,Math.min(r,t))}o(Kr,"between");function Pt(e){return e.reduce((t,r)=>t+r,0)}o(Pt,"sum");function Yr(e){return Pt(e)/e.length}o(Yr,"avg");function Qr(e){return!/^1?$|^(11+?)\1+$/.test("1".repeat(e))}o(Qr,"isPrimeRX");function Xr(e){for(var t=2;t<e;t++)if(e%t===0)return!1;return e>1}o(Xr,"isPrime");function St(e=""){let[t="",r="asc"]=e.split(" ");return r=r.toLowerCase(),{field:t,orderby:r,asc:r!=="desc",desc:r==="desc"}}o(St,"parseOrderby");function en(e,t=!0){return`${e} ${t?"asc":"desc"}`}o(en,"composeOrderby");function Le(e,t,r=!0){let n=e||0,i=t||0;return n>i?r?1:-1:n<i?r?-1:1:0}o(Le,"cmp");function tn(e,...t){if(t.length>0){let r=t.map(St),n=Array.from(e);return n.sort((i,s)=>{for(let{field:u,asc:a}of r){let p=Le(i[u],s[u],a);if(p!==0)return p}return 0}),n}return e}o(tn,"sortedOrderby");function ve(e){return e.filter((t,r)=>e.indexOf(t)===r)}o(ve,"arrayUnique");function It(e,t){return ve(e.filter(r=>!t.includes(r)))}o(It,"arrayMinus");function Ut(...e){return ve(e.reduce((t=[],r)=>t.concat(r),[]))}o(Ut,"arrayUnion");function O(...e){return e.flat(1/0)}o(O,"arrayFlatten");function Rt(e,t){return ve(e).filter(r=>t.includes(r))}o(Rt,"arrayIntersection");function rn(e,t){return It(Ut(e,t),Rt(e,t))}o(rn,"arraySymmetricDifference");function nn(e,t){if(e&&Array.isArray(e)){let r;for(;(r=e.indexOf(t))!==-1;)e.splice(r,1);return e}return[]}o(nn,"arrayRemoveElement");function on(e,t){return e.includes(t)||e.push(t),e}o(on,"arraySetElement");function Ce(e,t){return e.splice(0,e.length,...e.filter(t)),e}o(Ce,"arrayFilterInPlace");function sn(e,t){let r=e.findIndex(n=>n===t);return r>=0?e.splice(r,1):e.push(t),e}o(sn,"arrayToggleInPlace");function an(e){return e.splice(0,e.length),e}o(an,"arrayEmptyInPlace");function kt(e,t=Le){return Array.from(e).sort(t)}o(kt,"arraySorted");function un(e){return kt(e,(t,r)=>t-r)}o(un,"arraySortedNumbers");function Ot(e,t){return e.length===t.length&&e.every((r,n)=>r===t[n])}o(Ot,"arrayIsEqual");function Qe(e){return e.sort(()=>U()>.5?1:-1),e}o(Qe,"arrayShuffleInPlace");function ln(e){return Qe(Array.from(e))}o(ln,"arrayShuffle");function cn(e){for(;e.length>1;){let t=Array.from(e);if(Qe(t),!Ot(e,t))return t}return e}o(cn,"arrayShuffleForce");function fn(e){return e[Math.floor(U()*e.length)]}o(fn,"arrayRandomElement");function pn(...e){return O(e).reduce((t,r)=>t!=null?r>t?r:t:r,void 0)}o(pn,"arrayMax");function dn(...e){return O(e).reduce((t,r)=>t!=null?r<t?r:t:r,void 0)}o(dn,"arrayMin");function gn(...e){return O(e).reduce((t,r)=>t+r,0)}o(gn,"arraySum");function mn(...e){let t=O(e);return t.reduce((r,n)=>r+n,0)/t.length}o(mn,"arrayAvg");function yn(e,t){let r=[],n=0,i=e.length;for(;n<i;)r.push(e.slice(n,n+=t));return r}o(yn,"arrayBatches");function hn(e=0,t){if(e<=0)return[];let r=new Array(e);for(let n=0;n<e;n++)r[n]=t instanceof Function?t(n):t;return r}o(hn,"createArray");var xn=A("zeed:basex"),bn={2:"01",8:"01234567",11:"0123456789a",16:"0123456789abcdef",32:"0123456789ABCDEFGHJKMNPQRSTVWXYZ","32-rfc":"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567","32-hex":"0123456789ABCDEFGHIJKLMNOPQRSTUV","32-zbase":"ybndrfg8ejkmcpqxot1uwisza345h769",36:"0123456789abcdefghijklmnopqrstuvwxyz",58:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",62:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",64:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/","64-url":"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",66:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.!~",85:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz!#$%&()*+-;<=>?@^_`{|}~"};function B(e){let t;if(typeof e=="string")t=e;else if(t=bn[String(e)],t==null)throw new Error(`Unknown base ${e}`);if(t.length>=255)throw new TypeError("Alphabet too long");let r=new Uint8Array(256);for(let g=0;g<r.length;g++)r[g]=255;for(let g=0;g<t.length;g++){let y=t.charAt(g),w=y.charCodeAt(0);if(r[w]!==255)throw new TypeError(y+" is ambiguous");r[w]=g}let n=t.length,i=t.charAt(0),s=Math.log(n)/Math.log(256),u=Math.log(256)/Math.log(n);function a(g,y=-1){let w=P(g);if(w.byteLength===0)return"";let x=0,L=0,v=w.byteLength;for(;L!==v&&w[L]===0;)L++;let b=(v-L)*u+1>>>0,T=new Uint8Array(b);for(;L!==v;){let c=w[L],l=0;for(let f=b-1;(c!==0||l<x)&&f!==-1;f--,l++)c+=256*T[f]>>>0,T[f]=c%n>>>0,c=c/n>>>0;if(c!==0)throw xn.warn("Non-zero carry",w,y,l,b),new Error("Non-zero carry");x=l,L++}let C=b-x;for(;C!==b&&T[C]===0;)C++;let h="";for(;C<b;++C)h+=t.charAt(T[C]);return y>0?h.padStart(y,i):h}o(a,"encode");function p(g,y=-1){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;g=g.replace(/\s+/gi,"");let w=0,x=0;for(;g[w]===i;)w++;let L=(g.length-w)*s+1>>>0,v=new Uint8Array(L);for(;g[w];){let T=r[g.charCodeAt(w)];if(T===255)throw new Error(`Unsupported character "${g[w]}"`);let C=0;for(let h=L-1;(T!==0||C<x)&&h!==-1;h--,C++)T+=n*v[h]>>>0,v[h]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");x=C,w++}let b=L-x;for(;b!==L&&v[b]===0;)b++;return y>0?new Uint8Array([...new Uint8Array(y-v.length+b),...v.slice(b)]):v.slice(b)}return o(p,"decode"),{encode:a,decode:p}}o(B,"useBase");var{encode:wn,decode:Tn}=B(16),{encode:Ln,decode:vn}=B(32),{encode:Cn,decode:An}=B(58),{encode:Fn,decode:En}=B(62),{encode:Dn,decode:Mn}=B(62);var Pn=o(e=>(e.length>0&&(/^[A-Z0-9_\-\ ]*$/g.test(e)&&(e=e.toLowerCase()),e=e.replace(/^[-_\ ]+/gi,"").replace(/[-_\ ]+$/gi,"").replace(/[-_\ ]+([a-z0-9])/gi,(t,r)=>r.toUpperCase()),e=e[0].toLowerCase()+e.substring(1)),e),"toCamelCase");function $t(e){return e.charAt(0).toUpperCase()+e.toLowerCase().slice(1)}o($t,"toCapitalize");function Sn(e){return e.replace(/\w\S*/g,$t)}o(Sn,"toCapitalizeWords");function In(e,t="-"){return t=typeof t>"u"?"_":t,e.replace(/([a-z\d])([A-Z])/g,"$1"+t+"$2").replace(/([A-Z]+)([A-Z][a-z\d]+)/g,"$1"+t+"$2").toLowerCase()}o(In,"fromCamelCase");function Un(e,t){var r=[],n=[];return t==null&&(t=o(function(i,s){return r[0]===s?"[Circular ~]":"[Circular ~."+n.slice(0,r.indexOf(s)).join(".")+"]"},"cycleReplacer")),function(i,s){if(r.length>0){var u=r.indexOf(this);~u?r.splice(u+1):r.push(this),~u?n.splice(u,1/0,i):n.push(i),~r.indexOf(s)&&(s=t==null?void 0:t.call(this,i,s))}else r.push(s);return e==null?s:e.call(this,i,s)}}o(Un,"serializer");function Ae(e,t,r,n){return JSON.stringify(e,Un(t,n),r)}o(Ae,"jsonStringify");var Bt=["1","true","yes","y","on"];function Rn(e,t=!1){return e==null||typeof e!="string"?t:Bt.includes(String(e).trim().toLowerCase())}o(Rn,"stringToBoolean");function kn(e,t=0){return e==null||typeof e!="string"?t:parseInt(e.trim(),10)??t}o(kn,"stringToInteger");function On(e,t=0){return e==null||typeof e!="string"?t:parseFloat(e.trim())??t}o(On,"stringToFloat");function Ht(e,t=!1){return e==null?t:typeof e=="boolean"?e:typeof e=="number"?e!==0:Bt.includes(String(e).trim().toLowerCase())}o(Ht,"valueToBoolean");function Nt(e,t=0){return e==null?t:typeof e=="boolean"?e?1:0:typeof e=="number"?Math.floor(e):parseInt(String(e).trim(),10)??t}o(Nt,"valueToInteger");function jt(e,t=0){return e==null?t:typeof e=="boolean"?e?1:0:typeof e=="number"?Math.floor(e):parseFloat(String(e).trim())??t}o(jt,"valueToFloat");function Fe(e,t=""){return e==null?t:String(e)??t}o(Fe,"valueToString");var $n=jt,Bn=Nt,Hn=Fe,Nn=Ht;function zt(e,t={}){let{trace:r=!0,pretty:n=!0}=t;return e.map(i=>i&&typeof i=="object"?n&&(i instanceof Uint8Array||i instanceof ArrayBuffer)?`
5
+ `+We(i)+`
6
+ `:i instanceof Error?r?`${i.name||"Error"}: ${i.message}
7
+ ${i.stack}`:`${i.name||"Error"}: ${i.message}`:n?Ae(i,null,2):Ae(i):String(i))}o(zt,"formatMessages");function jn(e,t={}){return zt(e,t).join(" ")}o(jn,"renderMessages");function zn(e){try{return decodeURIComponent(escape(e))}catch{}return e}o(zn,"fixBrokenUth8String");var qn={symbol:"$",separator:",",decimal:".",errorOnInvalid:!1,precision:2,pattern:"!#",negativePattern:"-!#",format:Jn,fromCents:!1},qt=o(e=>Math.round(e),"round"),Xe=o(e=>Math.pow(10,e),"pow"),Vn=o((e,t)=>qt(e/t)*t,"rounding"),Gn=/(\d)(?=(\d{3})+\b)/g,_n=/(\d)(?=(\d\d)+\d\b)/g;function j(e,t={}){return new k(e,t)}o(j,"currency");var ae=class{constructor(t,r={}){let n=Object.assign({},qn,r),i=Xe(n.precision??2),s=Ee(t,n);this.intValue=s,this.value=s/i,n.increment=n.increment||1/i,n.useVedic?n.groups=_n:n.groups=Gn,this._settings=n,this._precision=i}add(t){let{intValue:r,_settings:n,_precision:i}=this;return j((r+=Ee(t,n))/(n.fromCents?1:i),n)}subtract(t){let{intValue:r,_settings:n,_precision:i}=this;return j((r-=Ee(t,n))/(n.fromCents?1:i),n)}multiply(t){let{intValue:r,_settings:n,_precision:i}=this;return j((r*=t)/(n.fromCents?1:Xe(i)),n)}divide(t){let{intValue:r,_settings:n}=this;return j(r/=Ee(t,n,!1),n)}distribute(t){let{intValue:r,_precision:n,_settings:i}=this,s=[],u=Math[r>=0?"floor":"ceil"](r/t),a=Math.abs(r-u*t),p=i.fromCents?1:n;for(;t!==0;t--){let g=j(u/p,i);a-- >0&&(g=g[r>=0?"add":"subtract"](1/p)),s.push(g)}return s}dollars(){return~~this.value}cents(){let{intValue:t,_precision:r}=this;return~~(t%r)}format(t){let{_settings:r}=this;return typeof t=="function"?t(this,r):r.format(this,Object.assign({},r,t))}toString(){let{intValue:t,_precision:r,_settings:n}=this;return Vn(t/r,n.increment).toFixed(n.precision)}toJSON(){return this.value}static sum(...t){return O(t).reduce((r,n)=>j(r).add(n),this.zero)}static avg(...t){let r=O(t);return r.reduce((n,i)=>j(n).add(i),this.zero).divide(r.length)}},k=ae;o(k,"Currency"),k.zero=new ae(0),k.one=new ae(1),k.hundred=new ae(100);function Ee(e,t,r=!0){let n=0,{decimal:i,errorOnInvalid:s,precision:u,fromCents:a}=t,p=Xe(u),g=typeof e=="number";if(e instanceof k&&a)return e.intValue;if(g||e instanceof k)n=e instanceof k?e.value:e;else if(typeof e=="string"){let y=new RegExp("[^-\\d"+i+"]","g"),w=new RegExp("\\"+i,"g");n=e.replace(/\((.*)\)/,"-$1").replace(y,"").replace(w,"."),n=n||0}else{if(s)throw Error("Invalid Input");n=0}return a||(n*=p,n=n.toFixed(4)),r?qt(n):n}o(Ee,"parse");function Jn(e,t){let{pattern:r,negativePattern:n,symbol:i,separator:s,decimal:u,groups:a}=t,p=(""+e).replace(/^-/,"").split("."),g=p[0],y=p[1];return(e.value>=0?r:n).replace("!",i).replace("#",g.replace(a,"$1"+s)+(y?u+y:""))}o(Jn,"format");var Me=864e5;function Pe(e){return Math.floor(e/1e4)}o(Pe,"dayYear");function et(e){return Math.floor(e/100%100)}o(et,"dayMonth");function Vt(e){return Math.floor(e%100)}o(Vt,"dayDay");function Wn(e){return[Pe(e),et(e),Vt(e)]}o(Wn,"dayToParts");function tt(e,t=!1){return t?new Date(`${_t(e)}T00:00:00.000Z`):new Date(e/1e4,e/100%100-1,e%100)}o(tt,"dayToDate");function Zn(){return ue(new Date)}o(Zn,"dayFromToday");function Kn(e,t=!1){if(typeof e=="number")return e<100?void 0:e;if(typeof e=="string")return rt(e);if(Array.isArray(e)&&e.length===3){let[r,n,i]=e;return Se(r,n,i)}else if(e instanceof Date)return ue(e,t)}o(Kn,"dayFromAny");function Yn(e){return tt(e,!0)}o(Yn,"dayToDateGMT");function ue(e,t=!1){return t?rt(e.toISOString()):e.getFullYear()*1e4+(e.getMonth()+1)*100+e.getDate()}o(ue,"dayFromDate");function Qn(e){return ue(e,!0)}o(Qn,"dayFromDateGMT");function De(e,t=!0){return tt(e,t).getTime()}o(De,"dayToTimestamp");function Gt(e,t=!0){return ue(new Date(e),t)}o(Gt,"dayFromTimestamp");function _t(e,t="-"){let r=String(e);return r.slice(0,4)+t+r.slice(4,6)+t+r.slice(6,8)}o(_t,"dayToString");function Se(e,t=1,r=1){if(!(t<1||t>12||r<1||r>31))return e*1e4+t*100+r}o(Se,"dayFromParts");function rt(e){let t=String(e).replace(/[^0-9]/g,"").slice(0,8);if(t.length===8)return+t}o(rt,"dayFromString");function Xn(e,t=0){let r=Pe(e),n=et(e);return t!==0&&(n+=t,r+=Math.floor((n-1)/12),n=Math.floor((n-1)%12)+1,n===0&&(n=12)),Se(r,n,1)}o(Xn,"dayMonthStart");function eo(e,t=0){let r=Pe(e);return Se(r+t,1,1)}o(eo,"dayYearStart");function to(e,t){return Gt(De(e)+t*864e5)}o(to,"dayOffset");function ro(e,t){return Math.round((De(t)-De(e))/864e5)}o(ro,"dayDiff");var{warn:Jt}=A("zeed:promise");function nt(){let e,t;return[new Promise((n,i)=>{e=n,t=i}),e,t]}o(nt,"createPromise");async function no(e){return new Promise(t=>setTimeout(t,e))}o(no,"sleep");async function oo(){return new Promise(e=>setTimeout(e,0))}o(oo,"immediate");var ot=Symbol("timeout");async function io(e,t,r=ot){return new Promise(async(n,i)=>{let s=!1,u=setTimeout(()=>{s=!0,n(r)},t);try{let a=await e;clearTimeout(u),s||n(a)}catch(a){clearTimeout(u),s||i(a)}})}o(io,"timeout");var it=new Error("Timeout reached");function so(e){return e===ot||e===it}o(so,"isTimeout");async function st(e,t){return t<=0?await e:new Promise(async(r,n)=>{let i=!1,s=setTimeout(()=>{i=!0,n(it)},t);try{let u=await e;clearTimeout(s),i||r(u)}catch(u){clearTimeout(s),i||n(u)}})}o(st,"tryTimeout");function ao(e,t,r=1e3){return new Promise((n,i)=>{let s=o(p=>{a&&(clearTimeout(a),u(),n(p))},"fn"),u=o(()=>{a=null,e.off?e.off(t,s):e.removeEventListener?e.removeEventListener(t,s):Jt("No remove listener method found for",e,t)},"done"),a=setTimeout(()=>{u(),i(new Error("Did not response in time"))},r);e.on?e.on(t,s):e.addEventListener?e.addEventListener(t,s):Jt("No listener method found for",e)})}o(ao,"waitOn");function S(e){return Boolean(e&&(e instanceof Promise||typeof e.then=="function"))}o(S,"isPromise");function z(e){return Promise.resolve(e)}o(z,"promisify");var F=class{get value(){return this.days}constructor(t){var r;if(typeof t=="number"){this.days=t;return}if(t!=null&&(t=(r=F.from(t))==null?void 0:r.days),t==null){let n=new Date;this.days=n.getFullYear()*1e4+(n.getMonth()+1)*100+n.getDate()}else this.days=t}static fromNumber(t){return new F(t)}static fromString(t){return F.from(+t.replace(/[^0-9]/g,"").slice(0,8))}static fromDate(t,r=!1){return r?F.fromString(t.toISOString().substr(0,10)):F.from(t.getFullYear()*1e4+(t.getMonth()+1)*100+t.getDate())}static fromDateGMT(t){return F.fromDate(t,!0)}static from(t,r=!1){if(typeof t=="number")return t<100?void 0:new F(t);if(typeof t=="string")return F.fromString(t);if(Array.isArray(t)&&t.length===3){let[n,i=1,s=1]=t;return i<1||i>12||s<1||s>31?void 0:new F(n*1e4+i*100+s)}else{if(t instanceof Date)return F.fromDate(t,r);if(t instanceof F)return t}}toNumber(){return this.days}toJson(){return this.days}toString(t="-"){let r=String(this.days);return r.slice(0,4)+t+r.slice(4,6)+t+r.slice(6,8)}toDate(t=!1){return t?new Date(`${this.toString()}T00:00:00.000Z`):new Date(this.days/1e4,this.days/100%100-1,this.days%100)}toDateGMT(){return this.toDate(!0)}get year(){return Math.floor(this.days/1e4)}get month(){return Math.floor(this.days/100%100)}get day(){return Math.floor(this.days%100)}dayOffset(t){return F.fromDateGMT(new Date(this.toDateGMT().getTime()+t*864e5))}monthStart(){return F.from([this.year,this.month,1])}yearStart(){return F.from([this.year,1,1])}monthOffset(t){let r=this.month+t,n=Math.floor((r-1)%12)+1;n===0&&(n=12);let i=Math.floor((r-1)/12);return F.from([this.year+i,n,this.day])}daysUntil(t){var r;return Math.round((((r=new F(t))==null?void 0:r.toDateGMT().getTime())-this.toDateGMT().getTime())/864e5)}yesterday(){return this.dayOffset(-1)}tomorrow(){return this.dayOffset(1)}};o(F,"Day");async function uo(e,t,r){let n=F.from(e),i=F.from(t);for(;n&&i&&(n==null?void 0:n.days)<=(i==null?void 0:i.days);){let s=r(n);S(s)&&await s,n=n.dayOffset(1)}}o(uo,"forEachDay");function lo(){return new F}o(lo,"today");function co(e){return new F(e)}o(co,"day");function fo(e){return F.fromDate(new Date(e)).days}o(fo,"dateStringToDays");function Wt(e,t=2){return+(+e).toFixed(t)}o(Wt,"decimal");function po(e,t=2){return+(+e/Math.pow(10,t)).toFixed(t)}o(po,"decimalFromCents");function go(e,t=2){return Math.round(+e*Math.pow(10,t))}o(go,"decimalToCents");function mo(e,t=2){return t*(Wt(e,t)%1)}o(mo,"decimalCentsPart");var at=o(e=>e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/'/g,"&apos;").replace(/"/g,"&quot;"),"escapeHTML"),yo=o(e=>e.replace(/&lt;/gi,"<").replace(/&gt;/gi,">").replace(/&quot;/gi,'"').replace(/&apos;/gi,"'").replace(/&amp;/gi,"&"),"unescapeHTML");var Zt=/[\u0000-\u001F\u0080-\u009F]/g,ho=/^\.+/,xo=/\.+$/;function Kt(){return/[<>:"/\\|?*\u0000-\u001F]/g}o(Kt,"filenameReservedRegex");function bo(){return/^(con|prn|aux|nul|com\d|lpt\d)$/i}o(bo,"windowsReservedNameRegex");function wo(e){if(typeof e!="string")throw new TypeError("Expected a string");let t="_";if(Kt().test(t)&&Zt.test(t))throw new Error("Replacement string cannot contain reserved filename characters");return e=e.replace(Kt(),t).replace(Zt,t).replace(ho,t).replace(xo,""),e=bo().test(e)?e+t:e,e.slice(0,100)}o(wo,"toValidFilename");var To=/[\\\-\[\]\/{}()*+?.^$|]/g;function Lo(e){return e?e instanceof RegExp?e.source:e.replace(To,"\\$&"):""}o(Lo,"escapeRegExp");var X=o(e=>Math.abs(e)%1===.5,"isHalf"),ut=o(e=>e%2===0,"isEven"),vo=o(e=>Math.ceil(e),"roundUp"),Co=o(e=>Math.floor(e),"roundDown"),Ao=o(e=>Math.round(e),"roundHalfUp"),Fo=o(e=>{let t=Math.round(e);return X(e)&&ut(t)?t-1:t},"roundHalfOdd"),Eo=o(e=>X(e)?Math.sign(e)*Math.ceil(Math.abs(e)):Math.round(e),"roundHalfAwayFromZero"),Do=o(e=>X(e)?Math.floor(e):Math.round(e),"roundHalfDown"),Mo=o(e=>{let t=Math.round(e);return X(e)?ut(t)?t:t-1:t},"roundHalfEven"),Po=o(e=>X(e)?Math.sign(e)*Math.floor(Math.abs(e)):Math.round(e),"roundHalfTowardsZero");function lt(e){return e.reduce((t,r)=>Math.min(t,r.sort_weight||0),0)-1-U()}o(lt,"startSortWeight");function ct(e){return e.reduce((t,r)=>Math.max(t,r.sort_weight||0),0)+1+U()}o(ct,"endSortWeight");function So(e,t,r){let n=r.length,i=e<t;if(n<=0||e>=n-1)return ct(r);if(e<=0)return lt(r);r=Yt([...r]);let s=i?-1:0,u=r[e+s].sort_weight||0,p=(r[e+s+1].sort_weight||0)-u;if(p===0)return i?lt(r):ct(r);let g=u+p/2,y=p*.01*(U()-.5);return g+y}o(So,"moveSortWeight");function Yt(e){return e.sort((t,r)=>(t.sort_weight||0)-(r.sort_weight||0)),e}o(Yt,"sortedItems");var Io=/((?:(?:(?:https?|ftp):)?\/\/)(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z0-9\u00a1-\uffff][a-z0-9\u00a1-\uffff_-]{0,62})?[a-z0-9\u00a1-\uffff]\.)+(?:[a-z\u00a1-\uffff]{2,}\.?))(?::\d{2,5})?(?:[/?#]\S*)?)/gim;function Uo(e){return e.split(Io).map((t,r)=>{let n=at(t);return r%2?`<a target="_blank" href="${n}">${Qt(n)}</a>`:n}).join("")}o(Uo,"linkifyPlainText");function Qt(e){return e.replace(/^https?:\/\/(www\.)?/,"").replace(/\/$/,"")}o(Qt,"toHumanReadableUrl");function ft(e){let t=[];for(let[r,n]of Object.entries(e))if(n!=null){Array.isArray(n)||(n=[n]);for(let i of n)i!=null&&t.push(encodeURIComponent(r)+"="+encodeURIComponent(String(i)))}return t.join("&")}o(ft,"encodeQuery");function Ro(e){let t={},r=(e[0]==="?"?e.substr(1):e).split("&");for(let n=0;n<r.length;n++){let i=r[n].split("="),s=decodeURIComponent(i[0]),u=decodeURIComponent(i[1]||"");t[s]!=null?(Array.isArray(t[s])||(t[s]=[t[s]]),t[s].push(u)):t[s]=u}return t}o(Ro,"parseQuery");function ko(e,t,r){let n=e[t];return n===void 0&&(n=r(t,e),e[t]=n),n}o(ko,"ensureKey");async function Oo(e,t,r){let n=e[t];return n===void 0&&(n=await r(t,e),e[t]=n),n}o(Oo,"ensureKeyAsync");function $o(e){return e!=null?e.size!=null?e.size:e.length!=null?e.length:Object.keys(e).length:0}o($o,"size");function Bo(e){return e!=null&&e.length>0?e[e.length-1]:void 0}o(Bo,"last");function Ho(e){try{if(e!=null)return Array.isArray(e)||typeof e=="string"?e.length<=0:(e==null?void 0:e.size)!=null?e.size<=0:Object.keys(e).length<=0}catch(t){console.warn("Failed to check if empty for",e,t)}return!0}o(Ho,"empty");function Ie(e){return Object(e)!==e?e:JSON.parse(JSON.stringify(e))}o(Ie,"cloneObject");function No(e){return Object(e)!==e?e:JSON.parse(JSON.stringify(e))}o(No,"cloneJsonObject");function jo(e){let t=new Map;return r=>{if(t.has(r))return t.get(r);let n=e(r);return t.set(r,n),n}}o(jo,"memoize");function zo(e,t){let r=[];for(let n=0;n<e;n++)r.push(t(n,e));return r}o(zo,"forTimes");var qo=/\\\s|\s+|#[^\n]*\n?/gm,Vo=/\(\?P?<(\w[\w\d_]+)>|\((?!\?(:|\!|=|<=|<\!))/gm,Xt=/^((?:\(\?[\w$]+\))?)\(\?<([=!])([\s\S]*?)\)/gm,Go=A("xrx");function er(e){return typeof e=="string"?e:e.source||""}o(er,"regExpString");function _o(e){return e.replace(/[-\[\]{}()*+?.,\\^$|#\s]/g,"\\$&")}o(_o,"regExpEscape");var Ue=class{constructor(t,r){this.namedGroups={};this.names=[];let n=r??"",i;if(t instanceof RegExp?(r==null&&(n=t.flags),i=t.source):i=t,n&&n.indexOf("x")!==-1&&(n=n.replace("x",""),i=i.replace(qo,a=>a[0]==="\\"?a:"")),!(t instanceof RegExp)){let a=0;i=i.replace(Vo,(p,g)=>(a+=1,g?(g!=="index"&&g!=="length"&&!this.namedGroups[g]?this.namedGroups[g]=a:Go.error(`Unallowed or duplicate group name: ${g}`),"("):p)),this.names=Object.keys(this.namedGroups)}i=er(i),Xt.lastIndex=0;let u=Xt.exec(i);u&&(this.lookBehind={rx:new RegExp(`${u[3]}$(?!\\s)`),expect:u?u[2]==="=":!u},i=i.substr(u[0].length)),this.rx=new RegExp(i,n)}get lastIndex(){return this.rx.lastIndex}set lastIndex(t){this.rx.lastIndex=t}_handleMatch(t){if(this.lookBehind){let r=t.input.slice(0,t.index);if(this.lookBehind.expect!==this.lookBehind.rx.test(r))return null}for(let r of this.names)t[r]=t[this.namedGroups[r]];return t}exec(t){let r;for(;r=this.rx.exec(t);)if(this.rx.lastIndex===r.index&&this.rx.lastIndex++,r=this._handleMatch(r),r!=null)return r}execAll(t){let r=[],n;for(this.rx.lastIndex=0;n=this.exec(t);)r.push(n);return this.rx.lastIndex=0,r}replace(t,r){let n=typeof r=="function"?r:()=>r;return t.replace(this.rx,i=>n(i))}};o(Ue,"XRX");var Jo=A("dispose");async function Wo(e){typeof e=="function"?await z(e()):S(e)?await e:typeof e.dispose=="function"?await z(e.dispose()):S(e.dispose)?await e.dispose:typeof e.cleanup=="function"?await z(e.cleanup()):S(e.cleanup)&&await e.cleanup}o(Wo,"callDisposer");function Re(e){let{name:t}=typeof e=="string"?{name:e}:e??{},r=[],n=o(async u=>{u!=null&&r.includes(u)&&(Ce(r,a=>a!==u),await Wo(u))},"untrack"),i=o(async()=>{for(t&&Jo.debug(`dispose ${t}: ${r.length} entries`);r.length>0;)await n(r[0])},"dispose"),s=o(u=>{if(u!=null)return r.unshift(u),()=>n(u)},"track");return Object.assign(i,{track:s,add:s,untrack:n,dispose:i,exec:i,getSize(){return r.length}})}o(Re,"useDispose");var Zo=Re;function Ko(e={}){let{mode:t="fifo"}=e,r=[],n=o(async(s=!1)=>{for(;r.length>0;){let u=r[0];if(Ce(r,a=>a!==u),typeof u=="function"){let a=u();if(S(a)){if(s)throw new Error(`Expected sync only function, but found async: ${u}`);await a}}else if(S(u)){if(s)throw new Error(`Expected sync only function, but found async: ${u}`);await u}else throw new Error(`Unhandled disposable: ${u}`)}},"exec");return Object.assign(n,{add:o(s=>{t==="lifo"?r.unshift(s):r.push(s)},"add"),exec:n,getSize(){return r.length}})}o(Ko,"useDefer");function Yo(e,t=0){let r=setTimeout(e,t);return()=>{r&&(clearTimeout(r),r=void 0)}}o(Yo,"useTimeout");function Qo(e,t){let r=setInterval(e,t);return()=>{r&&(clearInterval(r),r=void 0)}}o(Qo,"useInterval");function Xo(e,t,r,...n){return e==null?()=>{}:(e.on?e.on(t,r,...n):e.addEventListener&&e.addEventListener(t,r,...n),()=>{e.off?e.off(t,r,...n):e.removeEventListener&&e.removeEventListener(t,r,...n)})}o(Xo,"useEventListener");function ei(){let e=!0;return(t,r)=>{let n=!1;if(e){e=!1;try{t(),n=!0}finally{e=!0}}else r!==void 0&&r();return n}}o(ei,"useMutex");function ti(){let e=!0;return async(t,r)=>{let n=!1;if(e){e=!1;try{let i=t();S(i)&&await i,n=!0}finally{e=!0}}else if(r!==void 0){let i=r();S(i)&&await i}return n}}o(ti,"useAsyncMutex");var ee=A("zeed:emitter"),I=class{constructor(){this.subscribers={};this.subscribersOnAny=[];this.dispose=Re();this.call=new Proxy({},{get:(t,r)=>(...n)=>this.emit(r,...n)})}async emit(t,...r){let n=!1;this.dispose.add(()=>{this.subscribers={},this.subscribersOnAny=[]});try{let i=this.subscribers[t]||[];if(this.subscribersOnAny.forEach(s=>s(t,...r)),i.length>0){let s=i.map(u=>{try{return z(u(...r))}catch(a){ee.warn("emit warning:",a)}});n=!0,await Promise.all(s)}}catch(i){ee.error("emit exception",i)}return n}onAny(t){this.subscribersOnAny.push(t)}on(t,r){let n=this.subscribers[t]||[];return n.push(r),this.subscribers[t]=n,()=>{this.off(t,r)}}onCall(t){for(let[r,n]of Object.entries(t))this.on(r,n)}once(t,r){let n=o(async(...i)=>(this.off(t,n),await z(r(...i))),"onceListener");return this.on(t,n),()=>{this.off(t,r)}}off(t,r){return this.subscribers[t]=(this.subscribers[t]||[]).filter(n=>r&&n!==r),this}removeAllListeners(){return this.subscribers={},this}};o(I,"Emitter");function ri(){let e=Y().emitter;return e||(e=new I,Y().emitter=e),e}o(ri,"getGlobalEmitter");var ni=new I;function oi(e,t){let r=Math.round(U()*100);var n=[],i;let s=o((a,p)=>{let g={key:a,obj:p};n.push(g),i&&i()},"incoming");return t?e.on?e.on(t,a=>{s(t,a)}):e.addEventListener?e.addEventListener(t,a=>{s(t,a)}):ee.error(r,"Cannot listen to key"):e.onAny?e.onAny((a,p)=>{s(a,p)}):ee.error(r,"cannot listen to all for",e),o((a,p=!0)=>new Promise((g,y)=>{a||(a=t,a||n.length&&(a=n[0].key)),i=o(()=>{for(;n.length>0;){let w=n.shift();if(w.key===a)i=void 0,g(w.obj);else{if(p){ee.warn(r,`Unhandled event ${a} with value: ${w.obj}`);continue}y(`Expected ${a}, but found ${w.key} with value=${w.obj}`),ee.error(r,`Unhandled event ${a} with value: ${w.obj}`)}break}},"lazyResolve"),i()}),"on")}o(oi,"lazyListener");var H=o(()=>Date.now(),"getTimestamp");function le(e){return e>999?(e/1e3).toFixed(1)+"s":e.toFixed(2)+"ms"}o(le,"formatMilliseconds");function ii(...e){for(let t of e){if(t instanceof Date)return t;if(typeof t=="string"){let r=null;if(t.includes(":"))try{r=new Date(t)}catch{}if(!(r instanceof Date)){let n=/(\d\d\d\d)-(\d\d)-(\d\d)/.exec(t);n&&(r=new Date(+n[1],+n[2]-1,+n[3],12,0))}if(r instanceof Date)return r}}}o(ii,"parseDate");var{encode:dt,decode:tr}=B(62),{encode:rr,decode:si}=B(32);function gt(){return Z(16)}o(gt,"uuidBytes");var ai=o(()=>new Uint32Array(Z(4))[0],"uuid32bit");function q(){return dt(gt(),22)}o(q,"uuid");function ui(e){return dt(e,22)}o(ui,"uuidEncode");function li(e){return tr(e,16)}o(li,"uuidDecode");function ci(){return rr(gt(),26)}o(ci,"uuidB32");function fi(e){return rr(e,26)}o(fi,"uuid32Encode");function pi(e){return si(e,16)}o(pi,"uuid32Decode");var pt={};function V(e="id"){return pt[e]==null&&(pt[e]=0),`${e}-${pt[e]++}`}o(V,"uname");var di=0;function gi(){return`id-${di++}`}o(gi,"qid");var mi="10000000-1000-4000-8000-100000000000",yi=typeof crypto<"u"&&crypto.randomUUID!=null?crypto.randomUUID:()=>mi.replace(/[018]/g,e=>(e^Z(1)[0]&15>>e/4).toString(16)),nr=16e11;function hi(e){var t=new Uint8Array([0,0,0,0,0,0]);let r=t.length-1;for(var n=0;n<t.length;n++){var i=e&255;t[r-n]=i,e=(e-i)/256}return t}o(hi,"longToByteArray");function or(){let e=H()-nr;return new Uint8Array([...hi(e),...Z(10)])}o(or,"suidBytes");function xi(){return dt(or(),22)}o(xi,"suid");function bi(e){return ir(tr(e,16))}o(bi,"suidDate");function ir(e){return new Date(nr+e.slice(0,6).reduce((t,r)=>t*256+r,0))}o(ir,"suidBytesDate");var sr=(n=>(n[n.waiting=0]="waiting",n[n.running=1]="running",n[n.finished=2]="finished",n))(sr||{}),ar=(n=>(n[n.replace=0]="replace",n[n.memoize=1]="memoize",n[n.error=2]="error",n))(ar||{});function wi(e={}){let{maxParallel:t=3}=e,r=new I,n=0,i=0,s=0,u=0,a={};async function p(){if(n>0){let[b,T]=nt();return r.once("didFinish",T),b}}o(p,"waitFinishAll");function g(){r.emit("didFinish"),n=0,i=0}o(g,"didFinish");function y(){let b=0,T=0;for(let{max:C,resolved:h,state:c}of Object.values(a))b+=C,T+=c===2?C:Math.min(C,h);r.emit("didUpdate",n,i,b,T)}o(y,"didUpdate");function w(){if(y(),n>0&&n===i&&g(),s>=t)return;let b=Object.values(a).filter(T=>T.state===0);if(b.length>0){let T;for(let C of b)(T==null||C.priority<T.priority)&&(T=C);if(T!=null){let C=T.id,h=T.done;T.state=1,++s,r.emit("didStart",C);let c=o(l=>{T&&(T.result=l,T.state=2,T.resolved=T.max),--s,++i,w()},"taskFinished");T.task(T).then(l=>{h(l),r.emit("didResolve",C,l),c(l)}).catch(l=>{h(),r.emit("didReject",C,l),c()})}}}o(w,"performNext");function x(b){let T=a[b];T&&T.state===0&&(a[b].state=2,++i,r.emit("didCancel",b),y())}o(x,"cancel");function L(){Object.keys(a).forEach(x)}o(L,"cancelAll");function v(b,T={}){let C,h=new Promise(l=>C=l),c=T.id??q();if(a[c]!=null){let l=T.idConflictResolution??1;if(l===0)x(c);else if(l===1){let f=a[c];return{id:c,promise:(async()=>{if(f.state===2)return a[c].result})(),dispose:()=>x(c),cancel:()=>x(c)}}else throw new Error(`Pool task with id=${c} already exists!`)}return a[c]={id:c,task:b,priority:++u,state:0,max:T.max??1,resolved:T.resolved??0,done:C,payload:T.payload,setMax(l){a[c].max=l,y()},setResolved(l){a[c].resolved=l,y()},incResolved(l=1){a[c].resolved+=l,y()}},++n,w(),{id:c,promise:h,dispose:()=>x(c),cancel:()=>x(c)}}return o(v,"enqueue"),{events:r,cancel:x,cancelAll:L,enqueue:v,dispose:L,waitFinishAll:p}}o(wi,"usePool");var ke=class extends I{constructor(r={}){super();this.queue=[];this.waitToFinish=[];this.countMax=0;this.countResolved=0;this.paused=!1;let{name:n=V("queue"),logLevel:i}=r;this.name=n,this.log=A(`zeed:queue:${n}`,i??1/0)}async performNext(){if(this.log("performNext, queue.length =",this.queue.length),this.currentTask!=null){this.log("performNext => skip while another task is running");return}if(this.paused){this.log("performNext => skip while is paused");return}for(;this.currentTask==null&&!this.paused;){let r=this.queue.shift();if(this.log(`performNext => ${r==null?void 0:r.name}`),r==null)break;this.countResolved===0&&this.emit("didStart",this.countMax);let{name:n,task:i,resolve:s}=r;this.currentTask=i();let u;try{this.log.info(`start task ${n}`),u=await this.currentTask,this.log(`finished task ${n} with result =`,u)}catch(a){this.log.warn("Error performing task",a)}s(u),this.currentTask=void 0,this.countResolved+=1,this.emit("didUpdate",this.countMax,this.countResolved)}for(this.queue.length===0&&(this.emit("didFinish"),this.countMax=0,this.countResolved=0);this.waitToFinish.length>0;)this.waitToFinish.shift()()}async enqueue(r,n={}){let{immediate:i=!1,name:s=V(this.name)}=n;return i?(this.log.info(`immediate execution ${s}`),await r()):(this.log(`enqueue ${s}`),new Promise(u=>{this.queue.push({name:s,task:r,resolve:u}),this.countMax+=1,this.emit("didUpdate",this.countMax,this.countResolved),this.performNext()}))}async enqueueReentrant(r,n={}){return this.enqueue(r,{immediate:this.currentTask!=null,name:n.name})}async cancelAll(r=!0){this.log("cancelAll"),this.emit("didCancel");let n=this.queue.map(i=>i.resolve);this.queue=[],n.forEach(i=>i(void 0)),await this.wait()}async pause(){this.log("pause"),this.paused=!0,await this.wait()}resume(){this.log("resume"),this.paused=!1,this.performNext()}async wait(){if(this.log("wait"),!(this.currentTask==null&&(this.queue.length===0||this.paused)))return new Promise(r=>{this.waitToFinish.push(r)})}get isPaused(){return this.paused}get hasTasks(){return this.queue.length!==0}};o(ke,"SerialQueue");var re=!1,te=re?A("zeed:throttle"):()=>{};function Ti(e,t={}){let{delay:r=100,trailing:n=!0,leading:i=!0}=t,s=0,u=0,a=0,p,g=Date.now();function y(){s&&(clearTimeout(s),s=void 0)}o(y,"clearExistingTimeout");function w(...x){let L=Date.now(),v=this,b=L-u;function T(){let h=Date.now();return`total ${(h-g).toFixed(1)}ms - elapsed ${(h-u).toFixed(1)}ms - visited ${a}x`}o(T,"debugElapsed");function C(){a=0,u=Date.now(),e.apply(v,x)}if(o(C,"exec"),p=C,b>r||!s){re&&te("elapsed",T()),i&&(b>r?(re&&te("\u{1F680} leading",T()),C()):++a);let h=b>r?r:r-b;te(`\u23F1 start timeout with ${h.toFixed(1)}ms`,T()),y(),u=L,s=setTimeout(()=>{re&&te("\u23F1 reached timeout",T()),s=0,n&&(!i||a>0)&&(re&&te("\u{1F680} trailing",T()),p==null||p())},h)}else++a,re&&te("visited",T())}return o(w,"wrapper"),w.cancel=y,w.dispose=y,w}o(Ti,"throttle");function Li(e,t={}){let{delay:r=100}=t,n=0;function i(){n&&(clearTimeout(n),n=0)}o(i,"clearExistingTimeout");function s(...u){let a=this;i(),n=setTimeout(()=>{n=0,e.apply(a,u)},r)}return o(s,"wrapper"),s.cancel=i,s.dispose=i,s}o(Li,"debounce");function vi(e=(t=>(t=globalThis==null?void 0:globalThis.location)==null?void 0:t.hostname)()??""){return["::ffff:127.0.0.1","localhost","127.0.0.1","","::1","::"].includes(e)||e.startsWith("192.168.")||e.startsWith("10.0.")||e.endsWith(".local")}o(vi,"isLocalHost");function Ci(e){let{level:t=void 0,filter:r=void 0,messages:n=[]}=e,i=R(r),s=$(t);return u=>{!s(u.level)||!i(u.name)||n.push(u)}}o(Ci,"LoggerMemoryHandler");var ce=class extends I{constructor(){super(...arguments);this.id=q()}close(){this.dispose()}};o(ce,"Channel");var ne=class extends ce{constructor(){super(...arguments);this.isConnected=!0}postMessage(r){var n;(n=this.other)==null||n.emit("message",{data:r,origin:"local",lastEventId:q()})}};o(ne,"LocalChannel");function Ai(){let e=new ne,t=new ne;return e.other=t,t.other=e,[e,t]}o(Ai,"createLocalChannelPair");var Oe=class{async encode(t){return t}async decode(t){return t}};o(Oe,"NoopEncoder");var G=class{async encode(t){return be(t)}async decode(t){return we(t)}};o(G,"JsonEncoder");var $e=class{constructor(t){this.key=t}async encode(t){let r=be(t);return await Ke(r,this.key)}async decode(t){let r=await Ye(t,this.key);return we(r)}};o($e,"CryptoEncoder");var mt=o((e,t,r={})=>new Proxy(r,{get:(n,i)=>i in n?n[i]:(...s)=>e(i,s,t)}),"createPromiseProxy");function Fi(e={}){let{name:t=V("hub"),encoder:r=new G,retryAfter:n=1e3,ignoreUnhandled:i=!0,logLevel:s=!1}=e,u=A(t,s),a={},p,g=[],y,w={},x=o(()=>{clearTimeout(y)},"dispose"),L=o(async()=>{if(clearTimeout(y),p){if(p.isConnected)for(;g.length;){let C=g[0];try{p.postMessage(await r.encode(C)),g.shift()}catch(h){u.warn("postMessage",h);break}}g.length>0&&n>0&&(y=setTimeout(L,n))}},"postNext"),v=o(async C=>{u("enqueue postMessage",C),g.push(C),await L()},"postMessage"),b=o(async C=>{p=C,p.on("connect",L),p.on("message",async h=>{u("onmessage",typeof h);let{name:c,args:l,id:f,result:d,error:m}=await r.decode(h.data);if(c){u(`name ${c} id ${f}`);try{if(a[c]==null)throw new Error(`handler for ${c} was not found`);let D=a[c](...l);S(D)&&(D=await D),u(`result ${D}`),f&&v({id:f,result:D})}catch(D){let _=D instanceof Error?D:new Error(Fe(D));u.warn("execution error",_.name),v({id:f,error:{message:_.message,stack:_.stack,name:_.name}})}}else if(f)if(u(`response for id=${f}: result=${d}, error=${m}`),w[f]==null)d===void 0?u(`skip response for ${f}`):u.warn(`no response hook for ${f}`);else{let[D,_]=w[f];if(D&&_)if(delete w[f],m){let de=new Error(m.message);de.stack=m.stack,de.name=m.name,u.warn("reject",de.name),_(de)}else u("resolve",d),D(d)}else i||u.warn("Unhandled message",h)}),L()},"connect"),T=o(async(C,h,c={})=>{let{timeout:l=5e3}=c,f=q();return v({name:C,args:h,id:f}),st(new Promise((d,m)=>w[f]=[d,m]),l)},"fetchMessage");return e.channel&&b(e.channel),{dispose:x,connect:b,listen(C){Object.assign(a,C)},send(){return mt(T,{},{options(C){return mt(T,{...C})}})}}}o(Fi,"useMessageHub");var fe=class extends I{constructor(r){super();this.publish=this.emit;this.subscribe=this.on;let{name:n,encoder:i=new G,channel:s,debug:u=!1}=r;this.channel=s,this.encoder=i,this.debug=u,this.name=n??this.channel.id??V("pubsub"),this.log=A(`${this.shortId}`),this.debug&&(this.channel.on("connect",()=>{this.log("channel connected")}),this.channel.on("disconnect",()=>{this.log("channel disconnected")})),this.channel.on("message",async({data:a})=>{let p=await this.encoder.decode(a);if(this.debug?this.log(`channel message, event=${p==null?void 0:p.event}, info=`,p):this.log(`channel message, event=${p==null?void 0:p.event}`),p){let{event:g,args:y}=p;await this.emitSuper(g,...y)}})}get shortId(){return this.name.substr(0,6)}async emitSuper(r,...n){return await super.emit(r,...n)}async emit(r,...n){try{if(this.debug?this.log(`emit(${String(r)})`,r):this.log(`emit(${String(r)})`,n.length),!this.channel.isConnected)return this.log.warn("channel not connected"),!1;let i=await this.encoder.encode({event:r,args:n});return this.channel.postMessage(i),!0}catch(i){this.log.warn(`emit(${String(r)})`,i)}return!1}};o(fe,"PubSub");function Ei(e){return new fe(e)}o(Ei,"usePubSub");var Di=1;var ur=o(e=>e,"defaultSerialize"),Mi=ur;function Pi(e,t){let{post:r,on:n,eventNames:i=[],serialize:s=ur,deserialize:u=Mi}=t,a=new Map;return n(async p=>{let g=u(p),[y,w,x,L]=g;if(y===1||y===2){let v,b;if(L!=null)try{v=await e[L](...w)}catch(T){b=String(T)}else b="Method implementation missing";y===1&&x&&r(s(b?[4,b,x]:[3,v,x]))}else if(x){let v=a.get(x);v!=null&&(y===4?v.reject(w):v.resolve(w)),a.delete(x)}}),new Proxy({},{get(p,g){let y=o((...x)=>{r(s([2,x,null,g]))},"sendEvent");if(t.onlyEvents||i.includes(g))return y.asEvent=y,y;let w=o((...x)=>new Promise((L,v)=>{let b=Di++;a.set(b,{resolve:L,reject:v}),r(s([1,x,b,g]))}),"sendCall");return w.asEvent=y,w}})}o(Pi,"useRPC");var K=A("network"),yt={cache:"no-cache",redirect:"follow",headers:{}};function lr(e){let t=/:\/\/([^@]*)@/gi.exec(e);if(t&&t[1]){let[r,n]=t[1].split(":",2);return{url:e.replace(t[1]+"@",""),username:r,password:n}}}o(lr,"parseBasicAuth");async function ht(e,t={},r=fetch){try{me(t)&&(t=ie({},...O(t)));let n=lr(String(e));n&&(e=n.url,t=ie({},t,cr(n.username,n.password))),t.headers!=null&&!(t.headers instanceof Headers)&&(t.headers=new Headers(t.headers)),K("fetch",e,t);let i=await r(String(e),t);if(i.status<400)return i;try{K.warn(`Fetch of ${e} with ${t} returned status=${i.status}`),K.warn(`Response: ${await i.text()}`)}catch(s){K.error("Exception:",s)}}catch(n){K.error("fetchBasic",n)}}o(ht,"fetchBasic");async function Si(e,t={},r=fetch){try{let n=await ht(e,[{method:"GET",headers:{Accept:"application/json"}},t],r);if(n)return await n.json()}catch(n){K.error("fetchJSON error:",n)}}o(Si,"fetchJson");async function Ii(e,t={},r=fetch){try{let n=await ht(e,[yt,{method:"GET"},t],r);if(n)return await n.text()}catch(n){K.error("fetchHTML error:",n)}}o(Ii,"fetchText");function Ui(e,t="POST"){return{method:t,...yt,headers:{"Content-Type":"application/x-www-form-urlencoded; charset=utf-8"},body:ft(e)}}o(Ui,"fetchOptionsFormURLEncoded");function Ri(e,t="POST"){return{method:t,...yt,headers:{"Content-Type":"application/json; charset=utf-8"},body:JSON.stringify(e)}}o(Ri,"fetchOptionsJson");function cr(e,t){return{headers:{Authorization:"Basic "+_e(e+":"+t)}}}o(cr,"fetchOptionsBasicAuth");function xt(){if(typeof window<"u")return window}o(xt,"getWindow");function fr(){if(typeof navigator<"u")return navigator}o(fr,"getNavigator");function ki(){return xt()??typeof WorkerGlobalScope<"u"?self:typeof global<"u"?global:Function("return this;")()}o(ki,"getGlobal");var E=fr(),M=xt();function pr(e={ios:!1,macos:!1,windows:!1,beaker:!1,electron:!1,wkwebview:!1,pwa:!1,pwaInstalled:!1,browser:!1,node:!1,worker:!1,test:!1,jest:!1,macosNative:!1,iosNative:!1,appleNative:!1,touch:!1}){var t,r,n,i,s,u,a,p,g;return e.ios=((t=E==null?void 0:E.platform)==null?void 0:t.match(/(iPhone|iPod|iPad)/i))!=null,e.macos=!!((r=E==null?void 0:E.platform)!=null&&r.startsWith("Mac")),e.windows=!!((n=E==null?void 0:E.platform)!=null&&n.startsWith("Win")),e.beaker=(M==null?void 0:M.beaker)!=null,e.electron=(((s=(i=E==null?void 0:E.userAgent)==null?void 0:i.toLowerCase())==null?void 0:s.indexOf(" electron/"))||-1)>-1&&!e.beaker,e.wkwebview=((u=M==null?void 0:M.webkit)==null?void 0:u.messageHandlers)!=null,e.pwa=(E==null?void 0:E.serviceWorker)!=null,e.pwaInstalled=(E==null?void 0:E.standalone)||((p=(a=M==null?void 0:M.matchMedia)==null?void 0:a.call(M,"(display-mode: standalone)"))==null?void 0:p.matches),e.node=typeof process<"u"&&((g=process==null?void 0:process.release)==null?void 0:g.name)==="node",e.browser=!e.electron&&!e.wkwebview&&!e.node,e.worker=typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope,e.jest=typeof jest<"u"||typeof vitest<"u",e.test=e.jest,e.macosNative=e.wkwebview&&e.macos,e.iosNative=e.wkwebview&&e.ios,e.appleNative=e.wkwebview,e.touch=M&&"ontouchstart"in M||((E==null?void 0:E.maxTouchPoints)||0)>1||(E==null?void 0:E.msPointerEnabled)&&(M==null?void 0:M.MSGesture)||(M==null?void 0:M.DocumentTouch)&&document instanceof DocumentTouch,e}o(pr,"detect");var Be=o(()=>typeof window<"u"&&globalThis===window,"isBrowser"),Oi=pr();function $i(e){Be()?window.addEventListener("beforeunload",e):typeof process<"u"&&process.on("exit",()=>e)}o($i,"useExitHandler");var Yu=A("zeed:memstorage"),He=class{constructor(t={}){this.store={}}setItem(t,r){this.store[t]=Ie(r)}getItem(t){if(this.store.hasOwnProperty(t))return Ie(this.store[t])}removeItem(t){delete this.store[t]}clear(){this.store={}}allKeys(){return Object.keys(this.store)}};o(He,"MemStorage");var{error:Bi}=A("zeed:base64");function Hi(e){try{let t="=".repeat((4-e.length%4)%4),r=(e+t).replace(/-/g,"+").replace(/_/g,"/"),n=window.atob(r),i=new Uint8Array(n.length);for(let s=0;s<n.length;++s)i[s]=n.charCodeAt(s);return i}catch(t){Bi(t,e)}}o(Hi,"urlBase64ToUint8Array");var Ni=A("zeed:gravatar");function ji(e,b){function r(h,c){var l=h[0],f=h[1],d=h[2],m=h[3];l=i(l,f,d,m,c[0],7,-680876936),m=i(m,l,f,d,c[1],12,-389564586),d=i(d,m,l,f,c[2],17,606105819),f=i(f,d,m,l,c[3],22,-1044525330),l=i(l,f,d,m,c[4],7,-176418897),m=i(m,l,f,d,c[5],12,1200080426),d=i(d,m,l,f,c[6],17,-1473231341),f=i(f,d,m,l,c[7],22,-45705983),l=i(l,f,d,m,c[8],7,1770035416),m=i(m,l,f,d,c[9],12,-1958414417),d=i(d,m,l,f,c[10],17,-42063),f=i(f,d,m,l,c[11],22,-1990404162),l=i(l,f,d,m,c[12],7,1804603682),m=i(m,l,f,d,c[13],12,-40341101),d=i(d,m,l,f,c[14],17,-1502002290),f=i(f,d,m,l,c[15],22,1236535329),l=s(l,f,d,m,c[1],5,-165796510),m=s(m,l,f,d,c[6],9,-1069501632),d=s(d,m,l,f,c[11],14,643717713),f=s(f,d,m,l,c[0],20,-373897302),l=s(l,f,d,m,c[5],5,-701558691),m=s(m,l,f,d,c[10],9,38016083),d=s(d,m,l,f,c[15],14,-660478335),f=s(f,d,m,l,c[4],20,-405537848),l=s(l,f,d,m,c[9],5,568446438),m=s(m,l,f,d,c[14],9,-1019803690),d=s(d,m,l,f,c[3],14,-187363961),f=s(f,d,m,l,c[8],20,1163531501),l=s(l,f,d,m,c[13],5,-1444681467),m=s(m,l,f,d,c[2],9,-51403784),d=s(d,m,l,f,c[7],14,1735328473),f=s(f,d,m,l,c[12],20,-1926607734),l=u(l,f,d,m,c[5],4,-378558),m=u(m,l,f,d,c[8],11,-2022574463),d=u(d,m,l,f,c[11],16,1839030562),f=u(f,d,m,l,c[14],23,-35309556),l=u(l,f,d,m,c[1],4,-1530992060),m=u(m,l,f,d,c[4],11,1272893353),d=u(d,m,l,f,c[7],16,-155497632),f=u(f,d,m,l,c[10],23,-1094730640),l=u(l,f,d,m,c[13],4,681279174),m=u(m,l,f,d,c[0],11,-358537222),d=u(d,m,l,f,c[3],16,-722521979),f=u(f,d,m,l,c[6],23,76029189),l=u(l,f,d,m,c[9],4,-640364487),m=u(m,l,f,d,c[12],11,-421815835),d=u(d,m,l,f,c[15],16,530742520),f=u(f,d,m,l,c[2],23,-995338651),l=a(l,f,d,m,c[0],6,-198630844),m=a(m,l,f,d,c[7],10,1126891415),d=a(d,m,l,f,c[14],15,-1416354905),f=a(f,d,m,l,c[5],21,-57434055),l=a(l,f,d,m,c[12],6,1700485571),m=a(m,l,f,d,c[3],10,-1894986606),d=a(d,m,l,f,c[10],15,-1051523),f=a(f,d,m,l,c[1],21,-2054922799),l=a(l,f,d,m,c[8],6,1873313359),m=a(m,l,f,d,c[15],10,-30611744),d=a(d,m,l,f,c[6],15,-1560198380),f=a(f,d,m,l,c[13],21,1309151649),l=a(l,f,d,m,c[4],6,-145523070),m=a(m,l,f,d,c[11],10,-1120210379),d=a(d,m,l,f,c[2],15,718787259),f=a(f,d,m,l,c[9],21,-343485551),h[0]=L(l,h[0]),h[1]=L(f,h[1]),h[2]=L(d,h[2]),h[3]=L(m,h[3])}o(r,"md5cycle");function n(h,c,l,f,d,m){return c=L(L(c,h),L(f,m)),L(c<<d|c>>>32-d,l)}o(n,"cmn");function i(h,c,l,f,d,m,D){return n(c&l|~c&f,h,c,d,m,D)}o(i,"ff");function s(h,c,l,f,d,m,D){return n(c&f|l&~f,h,c,d,m,D)}o(s,"gg");function u(h,c,l,f,d,m,D){return n(c^l^f,h,c,d,m,D)}o(u,"hh");function a(h,c,l,f,d,m,D){return n(l^(c|~f),h,c,d,m,D)}o(a,"ii");function p(h){var c=h.length,l=[1732584193,-271733879,-1732584194,271733878],f;for(f=64;f<=h.length;f+=64)r(l,g(h.substring(f-64,f)));h=h.substring(f-64);var d=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];for(f=0;f<h.length;f++)d[f>>2]|=h.charCodeAt(f)<<(f%4<<3);if(d[f>>2]|=128<<(f%4<<3),f>55)for(r(l,d),f=0;f<16;f++)d[f]=0;return d[14]=c*8,r(l,d),l}o(p,"md51");function g(h){var c=[],l;for(l=0;l<64;l+=4)c[l>>2]=h.charCodeAt(l)+(h.charCodeAt(l+1)<<8)+(h.charCodeAt(l+2)<<16)+(h.charCodeAt(l+3)<<24);return c}o(g,"md5blk");function y(h){for(var c="",l=0;l<4;l++)c+=v[h>>l*8+4&15]+v[h>>l*8&15];return c}o(y,"rhex");function w(h){for(var c=0;c<h.length;c++)h[c]=y(h[c]);return h.join("")}o(w,"hex");function x(h){return w(p(h))}o(x,"md5");function L(h,c){return h+c&4294967295}o(L,"add32");var v="0123456789abcdef".split(""),b=b||{},T,C=[];return b={size:b.size||"50",rating:b.rating||"g",secure:b.secure||location.protocol==="https:",backup:b.backup||""},e=e.trim().toLowerCase(),T=b.secure?"https://secure.gravatar.com/avatar/":"http://www.gravatar.com/avatar/",b.rating&&C.push("r="+b.rating),b.backup&&C.push("d="+encodeURIComponent(b.backup)),b.size&&C.push("s="+b.size),T+x(e)+"?"+C.join("&")}o(ji,"gravatar");function zi(e,t=""){try{return ji(e,{size:256,backup:"monsterid",secure:!0})}catch{return Ni("Gravatar issue: Did not find an image for "+e),t}}o(zi,"gravatarURLByEmail");var dr=A("zeed:localstorage"),Ne=class{constructor(t){this.pretty=!1;dr.assert(t.name,"name required"),this.name=t.name,this.prefix=`${t.name}$`,this.objectToString=t.objectToString??(r=>this.pretty?JSON.stringify(r,null,2):JSON.stringify(r)),this.objectFromString=t.objectFromString??(r=>{try{return JSON.parse(r)}catch(n){dr.warn(`LocalStorage parse error '${n}' in`,r)}})}setItem(t,r){let n=this.objectToString(r);localStorage.setItem(`${this.prefix}${t}`,n)}getItem(t){let r=localStorage.getItem(`${this.prefix}${t}`);if(r!=null)return this.objectFromString(r)}removeItem(t){localStorage.removeItem(`${this.prefix}${t}`)}clear(){Object.keys(localStorage).filter(t=>t.startsWith(this.prefix)).forEach(t=>{localStorage.removeItem(t)})}allKeys(){let t=this.prefix.length;return Object.keys(localStorage).filter(r=>r.startsWith(this.prefix)).map(r=>r.substr(t))}};o(Ne,"LocalStorage");var gr=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function pe(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}o(pe,"supportsColors");function oe(e){let t=0;for(let r=0;r<e.length;r++)t=(t<<5)-t+e.charCodeAt(r),t|=0;return gr[Math.abs(t)%gr.length]}o(oe,"selectColor");var yr='font-family: "JetBrains Mono", Menlo; font-size: 11px;',hr=`${yr}`,xr=`font-weight: 600; ${yr}`,br=pe(),mr={},qi=H();function bt(e={}){let{filter:t=void 0,level:r=void 0,colors:n=!0,levelHelper:i=!1,nameBrackets:s=!0,padding:u=16}=e,a=R(t),p=$(r);return g=>{var b;if(!p(g.level)||!a(g.name))return;let y=H(),w=g.name||"",x=mr[w||""];x==null&&(x={color:oe(w)},mr[w]=x);let L=le(y-qi),v;switch(u>0&&(w=w.padEnd(16," ")),n&&br?(v=[`%c${w}%c %s %c+${L}`],v.push(`color:${x.color}; ${xr}`),v.push(hr),v.push(((b=g.messages)==null?void 0:b[0])??""),v.push(`color:${x.color};`),v.push(...g.messages.slice(1))):v=[w,...g.messages,`+${L}`],g.level){case 1:e.levelHelper&&(v[0]="I|* "+v[0]),console.info(...v);break;case 2:e.levelHelper&&(v[0]="W|** "+v[0]),console.warn(...v);break;case 3:e.levelHelper&&(v[0]="E|*** "+v[0]),console.error(...v);break;default:e.levelHelper&&(v[0]="D| "+v[0]),console.debug(...v);break}}}o(bt,"LoggerBrowserHandler");function wt(e={}){let t=e.filter??localStorage.zeed??localStorage.debug;return o(function r(n=""){let i;if(R(t)(n)){let u=[];if(br){let a=oe(n);u.push(`%c${n.padEnd(16," ")}%c %s`),u.push(`color:${a}; ${xr}`),u.push(hr)}else u.push(`[${n}] %s`);i=console.debug.bind(console,...u),i.debug=console.debug.bind(console,...u),i.info=console.info.bind(console,...u),i.warn=console.warn.bind(console,...u),i.error=console.error.bind(console,...u),i.assert=console.assert.bind(console),i.assertEqual=function(a,p,...g){let y=N(a,p);y||i.assert(y,`Assert did fail. Expected ${p} got ${a}`,p,a,...g)},i.assertNotEqual=function(a,p,...g){let y=N(a,p);y&&i.assert(y,`Assert did fail. Expected ${p} not to be equal with ${a}`,p,a,...g)}}else{let u=o(()=>{},"noop");i=u,i.debug=u,i.info=u,i.warn=u,i.error=u,i.assert=u,i.assertEqual=u,i.assertNotEqual=u}return i.extend=u=>r(n?`${n}:${u}`:u),i.label=n,i},"LoggerBrowserDebugFactory")}o(wt,"LoggerBrowserSetupDebugFactory");function Vi(e={}){console.info("activateConsoleDebug is activated by default in browsers")}o(Vi,"activateConsoleDebug");var wr={},Gi=H(),_i=pe();function Ji(e,t={}){let{filter:r=void 0}=t,n=R(r),i=$(e);return s=>{if(!i(s.level)||!n(s.name))return;let u=H(),a=s.name||"",p=wr[a||""];p==null&&(p={color:oe(a)},wr[a]=p);let g=le(u-Gi),y;switch(t.colors&&_i?(y=t.nameBrackets?[`%c[${a}]`]:[`%c${a}`],y.push(`color:${p.color}`),y.push(...s.messages)):y=[a,...s.messages],y.push(`+${g}`),s.level){case 1:t.levelHelper&&(y[0]="I|* "+y[0]),console.info(...y);break;case 2:t.levelHelper&&(y[0]="W|** "+y[0]),console.warn(...y);break;case 3:t.levelHelper&&(y[0]="E|*** "+y[0]),console.error(...y);break;default:t.levelHelper&&(y[0]="D| "+y[0]),console.debug(...y);break}}}o(Ji,"LoggerBrowserClassicHandler");Be()&&(A.setHandlers([bt()]),A.setFactory(wt({})));0&&(module.exports={Channel,CryptoEncoder,Currency,DAY_MS,Day,Emitter,JsonEncoder,LocalChannel,LocalStorage,LogLevel,LogLevelAlias,Logger,LoggerBrowserClassicHandler,LoggerBrowserHandler,LoggerBrowserSetupDebugFactory,LoggerConsoleHandler,LoggerContext,LoggerMemoryHandler,MemStorage,NoopEncoder,PoolTaskIdConflictResolution,PoolTaskState,PubSub,SerialQueue,Uint8ArrayToHexDump,Uint8ArrayToJson,Uint8ArrayToString,XRX,_decodeUtf8Polyfill,_encodeUtf8Polyfill,activateConsoleDebug,arrayAvg,arrayBatches,arrayEmptyInPlace,arrayFilterInPlace,arrayFlatten,arrayIntersection,arrayIsEqual,arrayMax,arrayMin,arrayMinus,arrayRandomElement,arrayRemoveElement,arraySetElement,arrayShuffle,arrayShuffleForce,arrayShuffleInPlace,arraySorted,arraySortedNumbers,arraySum,arraySymmetricDifference,arrayToggleInPlace,arrayUnion,arrayUnique,avg,between,cloneJsonObject,cloneObject,cmp,composeOrderby,createArray,createLocalChannelPair,createPromise,createPromiseProxy,csv,currency,dateStringToDays,day,dayDay,dayDiff,dayFromAny,dayFromDate,dayFromDateGMT,dayFromParts,dayFromString,dayFromTimestamp,dayFromToday,dayMonth,dayMonthStart,dayOffset,dayToDate,dayToDateGMT,dayToParts,dayToString,dayToTimestamp,dayYear,dayYearStart,debounce,decimal,decimalCentsPart,decimalFromCents,decimalToCents,decodeBase16,decodeBase32,decodeBase58,decodeBase62,decodeBase64,decrypt,deepEqual,deepMerge,deriveKeyPbkdf2,detect,digest,empty,encodeBase16,encodeBase32,encodeBase58,encodeBase62,encodeBase64,encodeQuery,encrypt,endSortWeight,ensureKey,ensureKeyAsync,equalBinary,escapeHTML,escapeRegExp,fetchBasic,fetchJson,fetchOptionsBasicAuth,fetchOptionsFormURLEncoded,fetchOptionsJson,fetchText,fixBrokenUth8String,forEachDay,forTimes,formatMessages,formatMilliseconds,fromBase64,fromCamelCase,getGlobal,getGlobalContext,getGlobalEmitter,getNamespaceFilterString,getNavigator,getSecureRandom,getSecureRandomIfPossible,getTimestamp,getWindow,gravatarURLByEmail,immediate,isArray,isBoolean,isBrowser,isEven,isHalf,isInteger,isLocalHost,isNullOrUndefined,isNumber,isObject,isPrime,isPrimeRX,isPrimitive,isPromise,isRecord,isSafeInteger,isString,isTimeout,isUint8Array,joinToUint8Array,jsonStringify,jsonToUint8Array,last,lazyListener,linkifyPlainText,memoize,messages,moveSortWeight,parseBasicAuth,parseDate,parseLogLevel,parseOrderby,parseQuery,platform,promisify,qid,randomBoolean,randomFloat,randomInt,randomUint8Array,regExpEscape,regExpString,renderMessages,roundDown,roundHalfAwayFromZero,roundHalfDown,roundHalfEven,roundHalfOdd,roundHalfTowardsZero,roundHalfUp,roundUp,selectColor,size,sleep,sortedItems,sortedOrderby,startSortWeight,stringToBoolean,stringToFloat,stringToInteger,stringToUInt8Array,suid,suidBytes,suidBytesDate,suidDate,sum,supportsColors,throttle,timeout,timeoutReached,timoutError,toBase64,toBase64Url,toBool,toCamelCase,toCapitalize,toCapitalizeWords,toFloat,toHex,toHumanReadableUrl,toInt,toString,toUint8Array,toValidFilename,today,tryTimeout,uname,unescapeHTML,urlBase64ToUint8Array,useAsyncMutex,useBase,useDefer,useDispose,useDisposer,useEventListener,useExitHandler,useInterval,useLevelFilter,useMessageHub,useMutex,useNamespaceFilter,usePool,usePubSub,useRPC,useTimeout,uuid,uuid32Decode,uuid32Encode,uuid32bit,uuidB32,uuidBytes,uuidDecode,uuidEncode,uuidv4,valueToBoolean,valueToFloat,valueToInteger,valueToString,waitOn});
4384
8
  //# sourceMappingURL=index.browser.cjs.map