@aiao/utils 0.0.5 → 0.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,34 +1,59 @@
1
- import { Observable as ae, BehaviorSubject as W, distinctUntilChanged as V, skip as le } from "rxjs";
2
- import ue from "ms";
3
- import { distance as fe } from "fastest-levenshtein";
4
- class he {
5
- #e = /* @__PURE__ */ new Map();
1
+ import { Observable as ae, shareReplay as le, BehaviorSubject as G, distinctUntilChanged as V, skip as ue } from "rxjs";
2
+ import fe from "ms";
3
+ import { distance as he } from "fastest-levenshtein";
4
+ class pe {
5
+ cache = /* @__PURE__ */ new Map();
6
+ /**
7
+ * 发送消息到指定频道
8
+ * @param event 频道名称
9
+ * @param data 消息数据
10
+ * @throws 如果频道不存在则抛出错误
11
+ */
6
12
  emit(t, r) {
7
- const n = this.#e.get(t);
8
- if (n?.channel)
9
- n.channel.postMessage(r);
10
- else
11
- throw new Error("broadcast-channel not found");
13
+ const n = this.cache.get(t);
14
+ if (!n)
15
+ throw new Error(`BroadcastChannel "${t}" not found`);
16
+ n.channel.postMessage(r);
12
17
  }
18
+ /**
19
+ * 订阅指定频道的消息
20
+ * @param event 频道名称
21
+ * @returns Observable 消息流
22
+ */
13
23
  on(t) {
14
- if (!this.#e.has(t)) {
15
- const r = new ae((n) => {
16
- const o = this.#e.get(t);
17
- o.observerCount++, o.observer = n;
18
- const c = (i) => n.next(i.data), s = new BroadcastChannel(t);
19
- return s.addEventListener("message", c), o.channel = s, () => {
20
- o.observerCount--, o.observerCount <= 0 && (s.removeEventListener("message", c), this.#e.delete(t));
21
- };
22
- });
23
- return this.#e.set(t, { observable: r, observerCount: 0 }), r;
24
- }
25
- return this.#e.get(t).observable;
24
+ const r = this.cache.get(t);
25
+ if (r)
26
+ return r.refCount++, r.observable;
27
+ const n = new BroadcastChannel(t), o = new ae((s) => {
28
+ const i = (a) => {
29
+ try {
30
+ s.next(a.data);
31
+ } catch (l) {
32
+ s.error(l);
33
+ }
34
+ };
35
+ return n.addEventListener("message", i), () => {
36
+ n.removeEventListener("message", i), this.decrementRef(t);
37
+ };
38
+ }).pipe(le(1)), c = {
39
+ observable: o,
40
+ channel: n,
41
+ refCount: 1
42
+ };
43
+ return this.cache.set(t, c), o;
44
+ }
45
+ /**
46
+ * 减少引用计数,当计数为 0 时关闭频道
47
+ */
48
+ decrementRef(t) {
49
+ const r = this.cache.get(t);
50
+ r && (r.refCount--, r.refCount <= 0 && (r.channel.close(), this.cache.delete(t)));
26
51
  }
27
52
  }
28
- const L = new he(), et = (e) => ({
29
- message$: L.on(e),
30
- emit: (n) => L.emit(e, n)
31
- }), pe = [
53
+ const I = new pe(), rt = (e) => ({
54
+ message$: I.on(e),
55
+ emit: (n) => I.emit(e, n)
56
+ }), de = [
32
57
  "mousemove",
33
58
  "keydown",
34
59
  "wheel",
@@ -42,10 +67,10 @@ const L = new he(), et = (e) => ({
42
67
  "visibilitychange",
43
68
  "focus"
44
69
  ];
45
- class tt {
70
+ class nt {
46
71
  #e = 1e3 * 2;
47
72
  #t;
48
- #r = new W(!1);
73
+ #r = new G(!1);
49
74
  idle$ = this.#r.asObservable().pipe(V());
50
75
  constructor(t) {
51
76
  this.#e = t?.timeout || this.#e;
@@ -59,7 +84,7 @@ class tt {
59
84
  }, this.#e);
60
85
  };
61
86
  #o() {
62
- pe.forEach(
87
+ de.forEach(
63
88
  (t) => document.addEventListener(t, this.#n, {
64
89
  capture: !0,
65
90
  passive: !0
@@ -67,12 +92,12 @@ class tt {
67
92
  );
68
93
  }
69
94
  }
70
- class rt {
95
+ class ot {
71
96
  constructor(t) {
72
97
  this.name = t, window.addEventListener("beforeunload", () => this.#n && this.#n(!0));
73
98
  }
74
- #e = new W(!1);
75
- #t = this.#e.asObservable().pipe(V(), le(1));
99
+ #e = new G(!1);
100
+ #t = this.#e.asObservable().pipe(V(), ue(1));
76
101
  #r;
77
102
  #n;
78
103
  get isLeader() {
@@ -84,7 +109,14 @@ class rt {
84
109
  })))), this.#t;
85
110
  }
86
111
  }
87
- function nt(e, t) {
112
+ const me = () => "storage" in navigator && "getDirectory" in navigator.storage, st = async () => {
113
+ try {
114
+ return me() ? !!await navigator.storage.getDirectory() : !1;
115
+ } catch (e) {
116
+ return console.error("OPFS not available:", e), !1;
117
+ }
118
+ };
119
+ function ct(e, t) {
88
120
  if (e.length === 0) return;
89
121
  let r = 0;
90
122
  function n() {
@@ -96,13 +128,13 @@ function nt(e, t) {
96
128
  }
97
129
  n();
98
130
  }
99
- const ot = (e, t) => {
131
+ const it = (e, t) => {
100
132
  const r = Math.floor(t), n = [];
101
133
  for (let o = 0; o < e.length; o += r)
102
134
  n.push(e.slice(o, o + r));
103
135
  return n;
104
- }, st = (e, t) => e.filter((r) => !t.includes(r)), ct = (e) => Array.prototype.concat([], ...e), de = (e) => e.flatMap((t) => Array.isArray(t) ? de(t) : t), it = (...e) => e.reduce((t, r) => t.filter((n) => r.includes(n))), S = Array.isArray, me = (e) => e instanceof ArrayBuffer;
105
- function at(e) {
136
+ }, at = (e, t) => e.filter((r) => !t.includes(r)), lt = (e) => Array.prototype.concat([], ...e), ye = (e) => e.flatMap((t) => Array.isArray(t) ? ye(t) : t), ut = (...e) => e.reduce((t, r) => t.filter((n) => r.includes(n))), b = Array.isArray, ge = (e) => e instanceof ArrayBuffer;
137
+ function ft(e) {
106
138
  return e === !0 || e === !1 || e != null && typeof e.valueOf() == "boolean";
107
139
  }
108
140
  function Z(e) {
@@ -114,86 +146,84 @@ const d = (e) => !!(e && e.constructor && e.call && e.apply), p = (e) => {
114
146
  } catch {
115
147
  return !1;
116
148
  }
117
- }, ye = (e) => e && e.constructor === Symbol, lt = (e) => {
149
+ }, we = (e) => e && e.constructor === Symbol, ht = (e) => {
118
150
  if (e === !0 || e === !1 || e === null || e === void 0) return !0;
119
151
  if (p(e)) return e === 0;
120
152
  if (Z(e)) return isNaN(e.getTime());
121
- if (d(e) || ye(e)) return !1;
153
+ if (d(e) || we(e)) return !1;
122
154
  const t = e.length;
123
155
  if (p(t)) return t === 0;
124
156
  const r = e.size;
125
157
  return p(r) ? r === 0 : Object.keys(e).length === 0;
126
- }, ut = (e) => p(e) && e % 1 !== 0, ge = (e) => Number.isInteger(e);
127
- function ft(e) {
128
- return S(e) && e.every(ge);
158
+ }, pt = (e) => p(e) && e % 1 !== 0, Ae = (e) => Number.isInteger(e);
159
+ function dt(e) {
160
+ return b(e) && e.every(Ae);
129
161
  }
130
- const Q = (e) => e == null;
131
- function ht(e) {
132
- return S(e) && e.every(p);
162
+ const H = (e) => e == null;
163
+ function mt(e) {
164
+ return b(e) && e.every(p);
133
165
  }
134
- const x = (e) => !!e && e.constructor === Object, pt = (e) => typeof e == "object" && e !== null;
135
- function we(e) {
166
+ const _ = (e) => !!e && e.constructor === Object, yt = (e) => typeof e == "object" && e !== null;
167
+ function Ee(e) {
136
168
  if (Object.prototype.toString.call(e) !== "[object Object]")
137
169
  return !1;
138
170
  const t = Object.getPrototypeOf(e);
139
171
  return t === null || t === Object.prototype;
140
172
  }
141
- function dt(e) {
173
+ function gt(e) {
142
174
  return e == null || typeof e != "object" && typeof e != "function";
143
175
  }
144
- const mt = (e) => !(!e || !e.then || !d(e.then));
145
- function yt(e) {
176
+ const wt = (e) => !(!e || !e.then || !d(e.then));
177
+ function At(e) {
146
178
  return e instanceof RegExp;
147
179
  }
148
- function T(e) {
180
+ function O(e) {
149
181
  return typeof e == "string";
150
182
  }
151
- const gt = (e) => S(e) ? e.every(T) : !1, M = (e) => e instanceof Uint8Array, wt = (e) => Array.isArray(e) ? e : Q(e) ? [] : [e], At = (e, t = [], r = []) => {
183
+ const Et = (e) => b(e) ? e.every(O) : !1, $ = (e) => e instanceof Uint8Array, St = (e) => Array.isArray(e) ? e : H(e) ? [] : [e], bt = (e, t = [], r = []) => {
152
184
  const n = [...e];
153
185
  return n.sort((o, c) => {
154
186
  for (let s = 0; s < t.length; s++) {
155
- const i = t[s], a = r[s] || "asc", u = o[i], l = c[i];
156
- if (u == null && l == null) continue;
157
- if (u == null) return a === "desc" ? 1 : -1;
158
- if (l == null) return a === "desc" ? -1 : 1;
187
+ const i = t[s], a = r[s] || "asc", l = o[i], u = c[i];
188
+ if (l == null && u == null) continue;
189
+ if (l == null) return a === "desc" ? 1 : -1;
190
+ if (u == null) return a === "desc" ? -1 : 1;
159
191
  let f = 0;
160
- if (u < l ? f = -1 : u > l && (f = 1), a === "desc" && (f = -f), f !== 0)
192
+ if (l < u ? f = -1 : l > u && (f = 1), a === "desc" && (f = -f), f !== 0)
161
193
  return f;
162
194
  }
163
195
  return 0;
164
196
  }), n;
165
- }, Et = (e) => (t, r) => {
197
+ }, Ot = (e) => (t, r) => {
166
198
  const n = t[e], o = r[e];
167
199
  return n == null && o == null ? 0 : n == null ? 1 : o == null ? -1 : n > o ? 1 : n < o ? -1 : 0;
168
- }, bt = (e, t) => e.filter(/* @__PURE__ */ ((r) => (n) => r.has(t(n)) ? !1 : r.add(t(n)))(/* @__PURE__ */ new Set()));
169
- class St {
200
+ }, Tt = (e, t) => e.filter(/* @__PURE__ */ ((r) => (n) => r.has(t(n)) ? !1 : r.add(t(n)))(/* @__PURE__ */ new Set()));
201
+ class Ct {
170
202
  maxConcurrent;
171
203
  running = 0;
172
204
  queue = [];
205
+ queue_map = /* @__PURE__ */ new Map();
173
206
  constructor(t = 3) {
174
207
  this.maxConcurrent = t || 1;
175
208
  }
176
209
  /**
177
210
  * 添加任务到执行器
178
211
  * @param task - 返回 Promise 的异步任务函数
212
+ * @param id - 任务唯一标识符(可选),用于去重相同任务
179
213
  * @returns 返回任务执行结果的 Promise
180
214
  */
181
- addTask(t) {
182
- return new Promise((r, n) => {
215
+ addTask(t, r) {
216
+ if (r && this.queue_map.has(r))
217
+ return this.queue_map.get(r);
218
+ const n = new Promise((o, c) => {
183
219
  this.queue.push({
184
220
  task: t,
185
- resolve: r,
186
- reject: n
187
- }), this._runNext();
221
+ resolve: o,
222
+ reject: c,
223
+ id: r
224
+ }), this._run_next();
188
225
  });
189
- }
190
- /**
191
- * 批量添加多个任务
192
- * @param tasks - 任务数组
193
- * @returns 返回所有任务结果的 Promise 数组
194
- */
195
- addTasks(t) {
196
- return Promise.all(t.map((r) => this.addTask(r)));
226
+ return r !== void 0 && this.queue_map.set(r, n), n;
197
227
  }
198
228
  /**
199
229
  * 获取当前状态
@@ -212,7 +242,7 @@ class St {
212
242
  */
213
243
  setMaxConcurrent(t) {
214
244
  for (t = t || 1, this.maxConcurrent = t; this.running < this.maxConcurrent && this.queue.length > 0; )
215
- this._runNext();
245
+ this._run_next();
216
246
  }
217
247
  /**
218
248
  * 清空队列(不影响正在执行的任务)
@@ -220,7 +250,7 @@ class St {
220
250
  clearQueue() {
221
251
  this.queue.forEach(({ reject: t }) => {
222
252
  t(new Error("Task cancelled: queue cleared"));
223
- }), this.queue = [];
253
+ }), this.queue = [], this.queue_map.clear();
224
254
  }
225
255
  /**
226
256
  * 等待所有任务完成
@@ -249,31 +279,31 @@ class St {
249
279
  /**
250
280
  * 执行队列中的下一个任务
251
281
  */
252
- _runNext() {
282
+ _run_next() {
253
283
  if (this.running >= this.maxConcurrent || this.queue.length === 0) return;
254
284
  const t = this.queue.shift();
255
285
  if (!t) return;
256
- const { task: r, resolve: n, reject: o } = t;
257
- this.running++, Promise.resolve().then(() => r()).then((c) => {
258
- n(c);
259
- }).catch((c) => {
260
- o(c);
286
+ const { task: r, resolve: n, reject: o, id: c } = t;
287
+ this.running++, Promise.resolve().then(() => r()).then((s) => {
288
+ n(s);
289
+ }).catch((s) => {
290
+ o(s);
261
291
  }).finally(() => {
262
- this.running--, this._runNext();
292
+ this.running--, c !== void 0 && this.queue_map.delete(c), this._run_next();
263
293
  });
264
294
  }
265
295
  }
266
- const Tt = (e) => setTimeout(() => e(), 0), j = /* @__PURE__ */ Promise.resolve(), Ot = (e) => e ? j.then(e) : j, Ct = (e) => new Promise((t) => setTimeout(t, e)), Ae = new TextDecoder(), Pt = (e) => Ae.decode(e);
267
- function Ee(e, t) {
296
+ const Pt = (e) => setTimeout(() => e(), 0), L = /* @__PURE__ */ Promise.resolve(), $t = (e) => e ? L.then(e) : L, Mt = (e) => new Promise((t) => setTimeout(t, e)), Se = new TextDecoder(), _t = (e) => Se.decode(e);
297
+ function be(e, t) {
268
298
  for (const r in e)
269
- Object.prototype.hasOwnProperty.call(e, r) && (t(r, e[r], e), H(e[r], t));
299
+ Object.prototype.hasOwnProperty.call(e, r) && (t(r, e[r], e), Q(e[r], t));
270
300
  }
271
- const H = (e, t) => {
272
- Array.isArray(e) ? e.forEach((r) => H(r, t)) : x(e) && Ee(e, t);
301
+ const Q = (e, t) => {
302
+ Array.isArray(e) ? e.forEach((r) => Q(r, t)) : _(e) && be(e, t);
273
303
  }, C = (e) => new Uint8Array(
274
304
  atob(e).split("").map((t) => t.charCodeAt(0))
275
305
  );
276
- async function Mt(e, t, r) {
306
+ async function Rt(e, t, r) {
277
307
  const n = await crypto.subtle.importKey(
278
308
  "raw",
279
309
  C(t),
@@ -293,19 +323,19 @@ async function Mt(e, t, r) {
293
323
  );
294
324
  return new TextDecoder().decode(c);
295
325
  }
296
- const b = (e) => {
297
- if (T(e))
326
+ const S = (e) => {
327
+ if (O(e))
298
328
  return btoa(e);
299
- if (M(e) || Array.isArray(e))
329
+ if ($(e) || Array.isArray(e))
300
330
  return btoa(String.fromCharCode(...e));
301
- if (me(e)) {
331
+ if (ge(e)) {
302
332
  const t = new Uint8Array(e);
303
333
  return btoa(String.fromCharCode(...t));
304
334
  }
305
335
  throw new TypeError(`Unsupported type for base64 encoding: ${typeof e}`);
306
- }, { subtle: be } = globalThis.crypto;
307
- async function Se() {
308
- return await be.generateKey(
336
+ }, { subtle: Oe } = globalThis.crypto;
337
+ async function Te() {
338
+ return await Oe.generateKey(
309
339
  {
310
340
  name: "AES-GCM",
311
341
  length: 256
@@ -314,12 +344,12 @@ async function Se() {
314
344
  ["encrypt", "decrypt"]
315
345
  );
316
346
  }
317
- async function Te(e) {
347
+ async function Ce(e) {
318
348
  const t = await crypto.subtle.exportKey("raw", e);
319
- return b(t);
349
+ return S(t);
320
350
  }
321
- async function $t(e) {
322
- const t = new TextEncoder(), r = await Se(), n = crypto.getRandomValues(new Uint8Array(16)), o = await crypto.subtle.encrypt(
351
+ async function xt(e) {
352
+ const t = new TextEncoder(), r = await Te(), n = crypto.getRandomValues(new Uint8Array(16)), o = await crypto.subtle.encrypt(
323
353
  {
324
354
  name: "AES-GCM",
325
355
  iv: n
@@ -328,25 +358,25 @@ async function $t(e) {
328
358
  t.encode(e)
329
359
  );
330
360
  return {
331
- key: await Te(r),
332
- iv: b(n),
333
- cipherText: b(o)
361
+ key: await Ce(r),
362
+ iv: S(n),
363
+ cipherText: S(o)
334
364
  };
335
365
  }
336
- const Oe = (e) => atob(e.replace(/[-]/g, "+").replace(/[_]/g, "/")), xt = (e) => {
366
+ const Pe = (e) => atob(e.replace(/[-]/g, "+").replace(/[_]/g, "/")), Bt = (e) => {
337
367
  const t = e.split(".");
338
368
  if (t.length !== 3) throw new Error("JWT is not valid: not a JWT structure");
339
369
  const r = t[1];
340
- return JSON.parse(Oe(r));
370
+ return JSON.parse(Pe(r));
341
371
  };
342
- function N(e) {
372
+ function R(e) {
343
373
  const t = new ArrayBuffer(e.length), r = new Uint8Array(t);
344
374
  for (let n = 0, o = e.length; n < o; n++)
345
375
  r[n] = e.charCodeAt(n);
346
376
  return t;
347
377
  }
348
- function Ce(e) {
349
- const t = e.replace(/-----.*-----/g, "").trim(), r = atob(t), n = N(r);
378
+ function $e(e) {
379
+ const t = e.replace(/-----.*-----/g, "").trim(), r = atob(t), n = R(r);
350
380
  return crypto.subtle.importKey(
351
381
  "pkcs8",
352
382
  n,
@@ -358,8 +388,8 @@ function Ce(e) {
358
388
  ["decrypt"]
359
389
  );
360
390
  }
361
- async function Nt(e, t) {
362
- const r = await Ce(t), n = await crypto.subtle.decrypt(
391
+ async function It(e, t) {
392
+ const r = await $e(t), n = await crypto.subtle.decrypt(
363
393
  {
364
394
  name: "RSA-OAEP"
365
395
  },
@@ -368,8 +398,8 @@ async function Nt(e, t) {
368
398
  );
369
399
  return new TextDecoder().decode(n);
370
400
  }
371
- function Pe(e) {
372
- const t = e.replace(/-----.*-----/g, "").trim(), r = atob(t), n = N(r);
401
+ function Me(e) {
402
+ const t = e.replace(/-----.*-----/g, "").trim(), r = atob(t), n = R(r);
373
403
  return crypto.subtle.importKey(
374
404
  "spki",
375
405
  n,
@@ -381,22 +411,22 @@ function Pe(e) {
381
411
  ["encrypt"]
382
412
  );
383
413
  }
384
- async function Rt(e, t) {
385
- const r = await Pe(t), n = await crypto.subtle.encrypt(
414
+ async function Lt(e, t) {
415
+ const r = await Me(t), n = await crypto.subtle.encrypt(
386
416
  {
387
417
  name: "RSA-OAEP"
388
418
  },
389
419
  r,
390
- N(e)
420
+ R(e)
391
421
  );
392
- return b(n);
422
+ return S(n);
393
423
  }
394
- const I = "PUBLIC KEY", _ = "RAS PRIVATE KEY";
424
+ const j = "PUBLIC KEY", N = "RAS PRIVATE KEY";
395
425
  async function D(e, t = "pkcs8") {
396
426
  const r = await crypto.subtle.exportKey(t, e);
397
- return b(r);
427
+ return S(r);
398
428
  }
399
- async function Bt(e = 1024) {
429
+ async function jt(e = 1024) {
400
430
  const { publicKey: t, privateKey: r } = await crypto.subtle.generateKey(
401
431
  {
402
432
  name: "RSA-OAEP",
@@ -410,15 +440,15 @@ async function Bt(e = 1024) {
410
440
  ["encrypt", "decrypt"]
411
441
  ), n = await D(t, "spki"), o = await D(r, "pkcs8");
412
442
  return {
413
- publicKey: `-----BEGIN ${I}-----
443
+ publicKey: `-----BEGIN ${j}-----
414
444
  ${n}
415
- -----END ${I}-----`,
416
- privateKey: `-----BEGIN ${_}-----
445
+ -----END ${j}-----`,
446
+ privateKey: `-----BEGIN ${N}-----
417
447
  ${o}
418
- -----END ${_}-----`
448
+ -----END ${N}-----`
419
449
  };
420
450
  }
421
- const Lt = (e) => p(e) || Z(e) ? !0 : Q(e) ? !1 : new Date(e).getTime() > 0, Me = (e) => {
451
+ const Nt = (e) => p(e) || Z(e) ? !0 : H(e) ? !1 : new Date(e).getTime() > 0, _e = (e) => {
422
452
  const t = e > 0 ? "+" : "-", r = Math.abs(e), n = `${Math.floor(r / 60)}`.padStart(2, "0"), o = `${r % 60}`.padStart(2, "0");
423
453
  return {
424
454
  flag: t,
@@ -426,25 +456,25 @@ const Lt = (e) => p(e) || Z(e) ? !0 : Q(e) ? !1 : new Date(e).getTime() > 0, Me
426
456
  hour: n,
427
457
  minute: o
428
458
  };
429
- }, $e = (e, t, r) => {
430
- const { flag: n, hour: o, minute: c } = Me(r);
459
+ }, Re = (e, t, r) => {
460
+ const { flag: n, hour: o, minute: c } = _e(r);
431
461
  return `${e}T${t}${n}${o}:${c}`;
432
- }, jt = (e, t, r) => new Date($e(e, t, r)), J = (e, t) => {
462
+ }, Dt = (e, t, r) => new Date(Re(e, t, r)), J = (e, t) => {
433
463
  const r = t.getTime() - e.getTime(), n = Math.floor(r / 864e5), o = Math.floor(n / 30), c = Math.floor(o / 12), s = Math.floor(r / 36e5) % 24, i = Math.floor(r / 6e4) % 60, a = Math.floor(r / 1e3) % 60;
434
464
  return { year: c, month: o, day: n, hour: s, minute: i, second: a };
435
- }, Y = (e, t, r) => r ? `${t} ${r[e] || e}` : `${t} ${e}`, X = ["year", "month", "day", "hour", "minute", "second"], It = (e, t, r) => {
465
+ }, Y = (e, t, r) => r ? `${t} ${r[e] || e}` : `${t} ${e}`, X = ["year", "month", "day", "hour", "minute", "second"], Ut = (e, t, r) => {
436
466
  const n = J(e, t), o = X.find((s) => n[s] > 0) || "second", c = n[o];
437
467
  return d(r) ? r({ key: o, value: c }) : Y(o, c, r);
438
- }, _t = (e, t, r) => {
468
+ }, kt = (e, t, r) => {
439
469
  const n = J(e, t);
440
470
  return d(r) ? r(n) : X.filter((o) => o).map((o) => Y(o, n[o], r)).join(" ");
441
- }, Dt = (e) => T(e) && /\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d(?:\.\d+)?(?:Z|\+[0-2]\d(?:\\:[0-5]\d)?)?/g.test(e);
442
- function kt(e) {
443
- return p(e) ? !0 : T(e) ? !!/^(?<value>-?(?:\d+)?\.?\d+) *(?<type>milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(
471
+ }, Kt = (e) => O(e) && /\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d(?:\.\d+)?(?:Z|\+[0-2]\d(?:\\:[0-5]\d)?)?/g.test(e);
472
+ function qt(e) {
473
+ return p(e) ? !0 : O(e) ? !!/^(?<value>-?(?:\d+)?\.?\d+) *(?<type>milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(
444
474
  e
445
475
  )?.groups : !1;
446
476
  }
447
- const Ut = (e) => ue(e), Kt = () => Math.floor(Date.now() / 1e3), zt = (e, t = 50) => {
477
+ const Ft = (e) => fe(e), zt = () => Math.floor(Date.now() / 1e3), Wt = (e, t = 50) => {
448
478
  let r;
449
479
  return function(...n) {
450
480
  const o = () => {
@@ -452,9 +482,9 @@ const Ut = (e) => ue(e), Kt = () => Math.floor(Date.now() / 1e3), zt = (e, t = 5
452
482
  };
453
483
  r !== void 0 && clearTimeout(r), r = setTimeout(o, t);
454
484
  };
455
- }, Ft = () => {
485
+ }, vt = () => {
456
486
  };
457
- function qt(e) {
487
+ function Gt(e) {
458
488
  let t = !1, r;
459
489
  return function() {
460
490
  if (t)
@@ -463,7 +493,7 @@ function qt(e) {
463
493
  return t = !0, r = n, n;
464
494
  };
465
495
  }
466
- const Gt = (e, t) => {
496
+ const Vt = (e, t) => {
467
497
  let r = 0;
468
498
  return function(...n) {
469
499
  const o = (/* @__PURE__ */ new Date()).getTime();
@@ -473,201 +503,198 @@ const Gt = (e, t) => {
473
503
  function w(e, t, r) {
474
504
  const n = r[0];
475
505
  if (t != null && e >= t)
476
- throw new Error(e + " >= " + t);
477
- if (e.slice(-1) === n || t && t.slice(-1) === n)
506
+ throw new Error(`${e} >= ${t}`);
507
+ if (e.endsWith(n) || t && t.endsWith(n))
478
508
  throw new Error("trailing zero");
479
509
  if (t) {
480
510
  let s = 0;
481
- for (; (e[s] || n) === t[s]; )
511
+ for (; (e[s] ?? n) === t[s]; )
482
512
  s++;
483
513
  if (s > 0)
484
514
  return t.slice(0, s) + w(e.slice(s), t.slice(s), r);
485
515
  }
486
516
  const o = e ? r.indexOf(e[0]) : 0, c = t != null ? r.indexOf(t[0]) : r.length;
487
517
  if (c - o > 1) {
488
- const s = Math.round(0.5 * (o + c));
518
+ const s = Math.round((o + c) / 2);
489
519
  return r[s];
490
- } else
491
- return t && t.length > 1 ? t.slice(0, 1) : r[o] + w(e.slice(1), null, r);
520
+ }
521
+ return t && t.length > 1 ? t[0] : r[o] + w(e.slice(1), null, r);
492
522
  }
493
523
  function te(e) {
494
- if (e.length !== re(e[0]))
495
- throw new Error("invalid integer part of order key: " + e);
496
- }
497
- function re(e) {
524
+ const t = e.charCodeAt(0), r = 97, n = 90;
498
525
  if (e >= "a" && e <= "z")
499
- return e.charCodeAt(0) - 97 + 2;
526
+ return t - r + 2;
500
527
  if (e >= "A" && e <= "Z")
501
- return 90 - e.charCodeAt(0) + 2;
502
- throw new Error("invalid order key head: " + e);
528
+ return n - t + 2;
529
+ throw new Error(`invalid order key head: ${e}`);
503
530
  }
504
531
  function E(e) {
505
- const t = re(e[0]);
532
+ const t = te(e[0]);
506
533
  if (t > e.length)
507
- throw new Error("invalid order key: " + e);
534
+ throw new Error(`invalid order key: ${e}`);
508
535
  return e.slice(0, t);
509
536
  }
510
- function k(e, t) {
537
+ function re(e) {
538
+ if (e.length !== te(e[0]))
539
+ throw new Error(`invalid integer part of order key: ${e}`);
540
+ }
541
+ function U(e, t) {
511
542
  if (e === "A" + t[0].repeat(26))
512
- throw new Error("invalid order key: " + e);
543
+ throw new Error(`invalid order key: ${e}`);
513
544
  const r = E(e);
514
- if (e.slice(r.length).slice(-1) === t[0])
515
- throw new Error("invalid order key: " + e);
545
+ if (e.slice(r.length).endsWith(t[0]))
546
+ throw new Error(`invalid order key: ${e}`);
516
547
  }
517
- function U(e, t) {
518
- te(e);
519
- const [r, ...n] = e.split("");
548
+ function k(e, t) {
549
+ re(e);
550
+ const r = e[0], n = e.slice(1).split("");
520
551
  let o = !0;
521
552
  for (let c = n.length - 1; o && c >= 0; c--) {
522
553
  const s = t.indexOf(n[c]) + 1;
523
554
  s === t.length ? n[c] = t[0] : (n[c] = t[s], o = !1);
524
555
  }
525
556
  if (o) {
526
- if (r === "Z")
527
- return "a" + t[0];
528
- if (r === "z")
529
- return null;
557
+ if (r === "Z") return "a" + t[0];
558
+ if (r === "z") return null;
530
559
  const c = String.fromCharCode(r.charCodeAt(0) + 1);
531
560
  return c > "a" ? n.push(t[0]) : n.pop(), c + n.join("");
532
- } else
533
- return r + n.join("");
561
+ }
562
+ return r + n.join("");
534
563
  }
535
564
  function xe(e, t) {
536
- te(e);
537
- const [r, ...n] = e.split("");
565
+ re(e);
566
+ const r = e[0], n = e.slice(1).split("");
538
567
  let o = !0;
539
568
  for (let c = n.length - 1; o && c >= 0; c--) {
540
569
  const s = t.indexOf(n[c]) - 1;
541
- s === -1 ? n[c] = t.slice(-1) : (n[c] = t[s], o = !1);
570
+ s === -1 ? n[c] = t[t.length - 1] : (n[c] = t[s], o = !1);
542
571
  }
543
572
  if (o) {
544
- if (r === "a")
545
- return "Z" + t.slice(-1);
546
- if (r === "A")
547
- return null;
573
+ if (r === "a") return "Z" + t[t.length - 1];
574
+ if (r === "A") return null;
548
575
  const c = String.fromCharCode(r.charCodeAt(0) - 1);
549
- return c < "Z" ? n.push(t.slice(-1)) : n.pop(), c + n.join("");
550
- } else
551
- return r + n.join("");
576
+ return c < "Z" ? n.push(t[t.length - 1]) : n.pop(), c + n.join("");
577
+ }
578
+ return r + n.join("");
552
579
  }
553
580
  function g(e, t, r = ee) {
554
- if (e != null && k(e, r), t != null && k(t, r), e != null && t != null && e >= t)
555
- throw new Error(e + " >= " + t);
581
+ if (e != null && U(e, r), t != null && U(t, r), e != null && t != null && e >= t)
582
+ throw new Error(`${e} >= ${t}`);
583
+ if (e == null && t == null)
584
+ return "a" + r[0];
556
585
  if (e == null) {
557
- if (t == null)
558
- return "a" + r[0];
559
- const a = E(t), u = t.slice(a.length);
586
+ const a = E(t), l = t.slice(a.length);
560
587
  if (a === "A" + r[0].repeat(26))
561
- return a + w("", u, r);
588
+ return a + w("", l, r);
562
589
  if (a < t)
563
590
  return a;
564
- const l = xe(a, r);
565
- if (l == null)
591
+ const u = xe(a, r);
592
+ if (u == null)
566
593
  throw new Error("cannot decrement any more");
567
- return l;
594
+ return u;
568
595
  }
569
596
  if (t == null) {
570
- const a = E(e), u = e.slice(a.length), l = U(a, r);
571
- return l ?? a + w(u, null, r);
597
+ const a = E(e), l = e.slice(a.length);
598
+ return k(a, r) ?? a + w(l, null, r);
572
599
  }
573
600
  const n = E(e), o = e.slice(n.length), c = E(t), s = t.slice(c.length);
574
601
  if (n === c)
575
602
  return n + w(o, s, r);
576
- const i = U(n, r);
603
+ const i = k(n, r);
577
604
  if (i == null)
578
605
  throw new Error("cannot increment any more");
579
606
  return i < t ? i : n + w(o, null, r);
580
607
  }
581
608
  function K(e, t, r, n = ee) {
582
- if (r === 0)
583
- return [];
584
- if (r === 1)
585
- return [g(e, t, n)];
609
+ if (r === 0) return [];
610
+ if (r === 1) return [g(e, t, n)];
586
611
  if (t == null) {
587
- let s = g(e, t, n);
588
- const i = [s];
589
- for (let a = 0; a < r - 1; a++)
590
- s = g(s, t, n), i.push(s);
591
- return i;
612
+ const s = [];
613
+ let i = g(e, t, n);
614
+ s.push(i);
615
+ for (let a = 1; a < r; a++)
616
+ i = g(i, t, n), s.push(i);
617
+ return s;
592
618
  }
593
619
  if (e == null) {
594
- let s = g(e, t, n);
595
- const i = [s];
596
- for (let a = 0; a < r - 1; a++)
597
- s = g(e, s, n), i.push(s);
598
- return i.reverse(), i;
620
+ const s = [];
621
+ let i = g(e, t, n);
622
+ s.push(i);
623
+ for (let a = 1; a < r; a++)
624
+ i = g(e, i, n), s.push(i);
625
+ return s.reverse();
599
626
  }
600
627
  const o = Math.floor(r / 2), c = g(e, t, n);
601
628
  return [...K(e, c, o, n), c, ...K(c, t, r - o - 1, n)];
602
629
  }
603
- const Ne = (e) => {
630
+ const Be = (e) => {
604
631
  if (e == null || e === "") return !1;
605
632
  const t = parseFloat(e);
606
633
  return !(isNaN(t) || !isFinite(t));
607
- }, Re = (e, t) => Math.ceil(e / t) * t, vt = (e, t = 80, r = 1) => Re(e * r, t), Wt = (e, t = 12) => parseFloat(e.toPrecision(t)), Vt = (e) => {
634
+ }, Ie = (e, t) => Math.ceil(e / t) * t, Zt = (e, t = 80, r = 1) => Ie(e * r, t), Ht = (e, t = 12) => parseFloat(e.toPrecision(t)), Qt = (e) => {
608
635
  const t = Number(e);
609
636
  return t < 0 ? Math.ceil(t) : Math.floor(t);
610
- }, Zt = (e) => {
611
- if (Ne(e)) {
637
+ }, Jt = (e) => {
638
+ if (Be(e)) {
612
639
  const t = Number(e);
613
640
  return isNaN(t) || !isFinite(t) ? e : t;
614
641
  }
615
642
  return e;
616
- }, Be = (e) => {
643
+ }, Le = (e) => {
617
644
  for (const r of Object.getOwnPropertyNames(e)) {
618
645
  const n = e[r];
619
- !x(n) && !d(n) || n === null || Be(n);
646
+ !_(n) && !d(n) || n === null || Le(n);
620
647
  }
621
648
  return Object.isFrozen(e) ? e : Object.freeze(e);
622
- }, Le = (e) => e.replace(/\[/g, ".").replace(/\]/g, "").split(".");
649
+ }, je = (e) => e.replace(/\[/g, ".").replace(/\]/g, "").split(".");
623
650
  function ne(e, t, r, n) {
624
651
  const o = d(n) ? n : void 0;
625
- return Le(t).reduce((s, i, a, u) => {
626
- if (a === u.length - 1)
652
+ return je(t).reduce((s, i, a, l) => {
653
+ if (a === l.length - 1)
627
654
  return s[i] = r, s;
628
655
  if (i in s)
629
656
  return s[i];
630
657
  if (!i) return s;
631
658
  if (o) {
632
- const l = o(s[i], i, s);
633
- if (l) return s[i] = l;
659
+ const u = o(s[i], i, s);
660
+ if (u) return s[i] = u;
634
661
  }
635
- return s[i] = /^[0-9]{1,}$/.test(u[a + 1]) ? [] : {};
662
+ return s[i] = /^[0-9]{1,}$/.test(l[a + 1]) ? [] : {};
636
663
  }, e), e;
637
664
  }
638
- function je(e, t, r) {
665
+ function Ne(e, t, r) {
639
666
  return ne(e, t, r);
640
667
  }
641
- function Ie(e, t, r, n) {
668
+ function De(e, t, r, n) {
642
669
  const o = d(n) ? n : void 0;
643
670
  return ne(e, t, r, o);
644
671
  }
645
- const Qt = (e) => {
672
+ const Yt = (e) => {
646
673
  const t = {};
647
674
  return Object.keys(e).forEach((r) => {
648
- r.match(/[^\]]*\[\d+\]/) ? je(t, r, e[r]) : Ie(t, r, e[r], Object);
675
+ r.match(/[^\]]*\[\d+\]/) ? Ne(t, r, e[r]) : De(t, r, e[r], Object);
649
676
  }), t;
650
- }, _e = (e, t, r) => {
677
+ }, Ue = (e, t, r) => {
651
678
  const n = (c) => String.prototype.split.call(t, c).filter(Boolean).reduce((s, i) => s != null ? s[i] : s, e), o = n(/[,[\]]+?/) || n(/[,[\].]+?/);
652
679
  return o === void 0 || o === e ? r : o;
653
- }, De = (e, t) => {
680
+ }, ke = (e, t) => {
654
681
  const r = t.split(".");
655
- return !!e && (r.length > 1 ? De(e[t.split(".")[0]], r.slice(1).join(".")) : Object.hasOwnProperty.call(e, t));
682
+ return !!e && (r.length > 1 ? ke(e[t.split(".")[0]], r.slice(1).join(".")) : Object.hasOwnProperty.call(e, t));
656
683
  };
657
- function ke(e, t) {
684
+ function Ke(e, t) {
658
685
  return e.length !== t.length ? !1 : e.every((r, n) => r === t[n]);
659
686
  }
660
- const z = (e, t) => {
687
+ const q = (e, t) => {
661
688
  if (e === t || Object.is(e, t)) return !0;
662
689
  if (e && t && typeof e == "object" && typeof t == "object") {
663
690
  if (e.constructor !== t.constructor) return !1;
664
691
  let r, n;
665
692
  if (Array.isArray(e)) {
666
693
  if (r = e.length, r != t.length) return !1;
667
- for (n = r; n-- !== 0; ) if (!z(e[n], t[n])) return !1;
694
+ for (n = r; n-- !== 0; ) if (!q(e[n], t[n])) return !1;
668
695
  return !0;
669
696
  }
670
- if (M(e) && M(t)) return ke(e, t);
697
+ if ($(e) && $(t)) return Ke(e, t);
671
698
  if (e.constructor === RegExp) return e.source === t.source && e.flags === t.flags;
672
699
  if (e.valueOf !== Object.prototype.valueOf) return e.valueOf() === t.valueOf();
673
700
  if (e.toString !== Object.prototype.toString) return e.toString() === t.toString();
@@ -676,90 +703,90 @@ const z = (e, t) => {
676
703
  for (n = r; n-- !== 0; ) if (!Object.prototype.hasOwnProperty.call(t, o[n])) return !1;
677
704
  for (n = r; n-- !== 0; ) {
678
705
  const c = o[n];
679
- if (!z(e[c], t[c])) return !1;
706
+ if (!q(e[c], t[c])) return !1;
680
707
  }
681
708
  return !0;
682
709
  }
683
710
  return e !== e && t !== t;
684
- }, Ht = (e, t) => +e == +t, Jt = (e, t) => e ? !t || t.length === 0 ? e : t.reduce(
711
+ }, Xt = (e, t) => +e == +t, er = (e, t) => e ? !t || t.length === 0 ? e : t.reduce(
685
712
  (r, n) => (delete r[n], r),
686
713
  { ...e }
687
714
  ) : {};
688
- function Yt(e, t) {
715
+ function tr(e, t) {
689
716
  return Object.keys(e).filter((r) => !t(e[r], r)).reduce((r, n) => (r[n] = e[n], r), {});
690
717
  }
691
- function Xt(e, t) {
718
+ function rr(e, t) {
692
719
  return e ? t.reduce(
693
720
  (r, n) => (Object.prototype.hasOwnProperty.call(e, n) && (r[n] = e[n]), r),
694
721
  {}
695
722
  ) : {};
696
723
  }
697
- function er(e, t) {
724
+ function nr(e, t) {
698
725
  return Object.keys(e).filter((r) => t(e[r], r)).reduce((r, n) => (r[n] = e[n], r), {});
699
726
  }
700
- const $ = (e, t = "", r = {}) => (S(e) ? e.forEach((n, o) => $(n, `${t}[${o}]`, r)) : we(e) ? Object.keys(e).forEach(
701
- (n) => $(e[n], `${t ? t + "." : ""}${n}`, r)
727
+ const M = (e, t = "", r = {}) => (b(e) ? e.forEach((n, o) => M(n, `${t}[${o}]`, r)) : Ee(e) ? Object.keys(e).forEach(
728
+ (n) => M(e[n], `${t ? t + "." : ""}${n}`, r)
702
729
  ) : r[`${t}`] = e, r);
703
- function tr(e) {
704
- return $(e);
730
+ function or(e) {
731
+ return M(e);
705
732
  }
706
- const rr = (e) => {
733
+ const sr = (e) => {
707
734
  const t = {};
708
735
  for (const r in e)
709
736
  Object.prototype.hasOwnProperty.call(e, r) && (t[r] = e[r]);
710
737
  return t;
711
738
  };
712
- function nr(e, t) {
739
+ function cr(e, t) {
713
740
  if (!e || !e.length)
714
741
  return {};
715
- const r = d(t) ? t : S(t) ? (n, o) => t[o] : () => t;
742
+ const r = d(t) ? t : b(t) ? (n, o) => t[o] : () => t;
716
743
  return e.reduce(
717
744
  (n, o, c) => (n[o] = r(o, c), n),
718
745
  {}
719
746
  );
720
747
  }
721
- const or = typeof window == "object", sr = (e) => e[Math.floor(Math.random() * e.length)], cr = (e = Number.MIN_SAFE_INTEGER, t = Number.MAX_SAFE_INTEGER) => Math.random() * (t - e) + e;
722
- function ir(e = Number.MIN_SAFE_INTEGER, t = Number.MAX_SAFE_INTEGER) {
748
+ const ir = typeof window == "object", ar = (e) => e[Math.floor(Math.random() * e.length)], lr = (e = Number.MIN_SAFE_INTEGER, t = Number.MAX_SAFE_INTEGER) => Math.random() * (t - e) + e;
749
+ function ur(e = Number.MIN_SAFE_INTEGER, t = Number.MAX_SAFE_INTEGER) {
723
750
  return Math.floor(Math.random() * (t - e + 1) + e);
724
751
  }
725
- const Ue = "0", oe = "123456789", se = Ue + oe, ce = "abcdefghijklmnopqrstuvwxyz", Ke = ce.toUpperCase(), ze = ce + Ke, Fe = "_-", qe = se + ze + Fe, F = (e = 16, t = qe) => {
752
+ const qe = "0", oe = "123456789", se = qe + oe, ce = "abcdefghijklmnopqrstuvwxyz", Fe = ce.toUpperCase(), ze = ce + Fe, We = "_-", ve = se + ze + We, F = (e = 16, t = ve) => {
726
753
  let r = "";
727
754
  const n = crypto.getRandomValues(new Uint8Array(e |= 0)), o = t.length - 1;
728
755
  for (; e--; ) r += t[n[e] & o];
729
756
  return r;
730
- }, Ge = (e = 16) => F(1, oe) + F(e - 1, se), ar = (e = 16) => parseInt(Ge(e), 10), ie = (e) => {
757
+ }, Ge = (e = 16) => F(1, oe) + F(e - 1, se), fr = (e = 16) => parseInt(Ge(e), 10), ie = (e) => {
731
758
  if (!e) return "";
732
759
  const t = e.toLowerCase();
733
- return ve(t);
734
- }, ve = (e) => e ? e.substring(0, 1).toUpperCase() + e.substring(1, e.length) : "", We = /[A-Z]?[a-z]+|[0-9]+|[A-Z]+(?![a-z])/g, R = (e) => Array.from(e.match(We) ?? []);
735
- function lr(e) {
736
- const t = R(e);
760
+ return Ve(t);
761
+ }, Ve = (e) => e ? e.substring(0, 1).toUpperCase() + e.substring(1, e.length) : "", Ze = /[A-Z]?[a-z]+|[0-9]+|[A-Z]+(?![a-z])/g, x = (e) => Array.from(e.match(Ze) ?? []);
762
+ function hr(e) {
763
+ const t = x(e);
737
764
  if (t.length === 0)
738
765
  return "";
739
766
  const [r, ...n] = t;
740
767
  return `${r.toLowerCase()}${n.map((o) => ie(o)).join("")}`;
741
768
  }
742
- const ur = async (e, t = "deflate") => {
769
+ const pr = async (e, t = "deflate") => {
743
770
  try {
744
771
  const n = new TextEncoder().encode(e), o = new CompressionStream(t), s = o.writable.getWriter();
745
772
  await s.write(n), await s.close();
746
- const a = o.readable.getReader(), u = [];
747
- let l = 0;
773
+ const a = o.readable.getReader(), l = [];
774
+ let u = 0;
748
775
  for (; ; ) {
749
776
  const { done: m, value: P } = await a.read();
750
777
  if (m) break;
751
- u.push(P), l += P.length;
778
+ l.push(P), u += P.length;
752
779
  }
753
- const f = new Uint8Array(l);
780
+ const f = new Uint8Array(u);
754
781
  let A = 0;
755
- for (const m of u)
782
+ for (const m of l)
756
783
  f.set(m, A), A += m.length;
757
784
  let y = btoa(String.fromCharCode(...f));
758
785
  return y = y.replace(/\+/g, "-").replace(/\//g, "_").replace(/=+$/, ""), y;
759
786
  } catch (r) {
760
787
  throw console.error("压缩过程中出错:", r), r;
761
788
  }
762
- }, fr = async (e, t = "deflate") => {
789
+ }, dr = async (e, t = "deflate") => {
763
790
  try {
764
791
  let r = e.replace(/-/g, "+").replace(/_/g, "/");
765
792
  const n = (4 - r.length % 4) % 4;
@@ -769,10 +796,10 @@ const ur = async (e, t = "deflate") => {
769
796
  c[h] = o.charCodeAt(h);
770
797
  const s = new DecompressionStream(t), a = s.writable.getWriter();
771
798
  await a.write(c), await a.close();
772
- const l = s.readable.getReader(), f = [];
799
+ const u = s.readable.getReader(), f = [];
773
800
  let A = 0;
774
801
  for (; ; ) {
775
- const { done: h, value: B } = await l.read();
802
+ const { done: h, value: B } = await u.read();
776
803
  if (h) break;
777
804
  f.push(B), A += B.length;
778
805
  }
@@ -784,7 +811,7 @@ const ur = async (e, t = "deflate") => {
784
811
  } catch (r) {
785
812
  throw console.error("解压过程中出错:", r), r;
786
813
  }
787
- }, Ve = (e) => R(e).map((r) => r.toLowerCase()).join("-"), Ze = {
814
+ }, He = (e) => x(e).map((r) => r.toLowerCase()).join("-"), Qe = {
788
815
  "〇": 0,
789
816
  一: 1,
790
817
  二: 2,
@@ -823,10 +850,10 @@ const ur = async (e, t = "deflate") => {
823
850
  8: 8,
824
851
  9: 9
825
852
  };
826
- function hr(e) {
853
+ function mr(e) {
827
854
  let t = 0, r = 0, n = 0, o = !1;
828
855
  for (const c of e.split("").reverse()) {
829
- if (r = Ze[c], r === void 0)
856
+ if (r = Qe[c], r === void 0)
830
857
  throw new Error(`无法解析的数字: ${c}`);
831
858
  switch (r) {
832
859
  case 10: {
@@ -849,7 +876,7 @@ function hr(e) {
849
876
  }
850
877
  return o && (t += r), t;
851
878
  }
852
- const pr = (e) => {
879
+ const yr = (e) => {
853
880
  const t = {};
854
881
  return new URLSearchParams(e).forEach((n, o) => {
855
882
  if (Object.prototype.hasOwnProperty.call(t, o)) {
@@ -858,7 +885,7 @@ const pr = (e) => {
858
885
  } else
859
886
  t[o] = n;
860
887
  }), t;
861
- }, dr = (e) => {
888
+ }, gr = (e) => {
862
889
  const t = new URLSearchParams();
863
890
  for (const r in e)
864
891
  if (Object.prototype.hasOwnProperty.call(e, r)) {
@@ -866,43 +893,43 @@ const pr = (e) => {
866
893
  Array.isArray(n) ? n.forEach((o) => t.append(r, `${o}`)) : t.set(r, `${n}`);
867
894
  }
868
895
  return t.sort(), t.toString();
869
- }, Qe = ["角", "分", "厘"], q = ["零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"], O = [
896
+ }, Je = ["角", "分", "厘"], z = ["零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"], T = [
870
897
  ["元", "万", "亿", "兆", "京", "垓"],
871
898
  ["", "拾", "佰", "仟"]
872
- ], G = Math.pow(10, 22), mr = (e) => {
899
+ ], W = Math.pow(10, 22), wr = (e) => {
873
900
  const t = e < 0 ? "欠" : "";
874
901
  let r = Math.abs(e);
875
- if (r > G)
876
- throw new Error(`max value is ${G}`);
902
+ if (r > W)
903
+ throw new Error(`max value is ${W}`);
877
904
  let n = "";
878
905
  if (e > Math.floor(e)) {
879
906
  const o = +("0." + `${r}`.split(".")[1]);
880
- n = Qe.reduce(
881
- (c, s, i) => c + (q[Math.floor(o * 10 * Math.pow(10, i)) % 10] + s).replace(/零./, ""),
907
+ n = Je.reduce(
908
+ (c, s, i) => c + (z[Math.floor(o * 10 * Math.pow(10, i)) % 10] + s).replace(/零./, ""),
882
909
  ""
883
910
  );
884
911
  }
885
912
  n = n || "整", r = Math.floor(r);
886
- for (let o = 0; o < O[0].length && r > 0; o++) {
913
+ for (let o = 0; o < T[0].length && r > 0; o++) {
887
914
  let c = "";
888
- for (let s = 0; s < O[1].length && r > 0; s++)
889
- c = q[r % 10] + O[1][s] + c, r = Math.floor(r / 10);
890
- n = c.replace(/(零.)*零$/g, "").replace(/^$/, "零") + O[0][o] + n;
915
+ for (let s = 0; s < T[1].length && r > 0; s++)
916
+ c = z[r % 10] + T[1][s] + c, r = Math.floor(r / 10);
917
+ n = c.replace(/(零.)*零$/g, "").replace(/^$/, "零") + T[0][o] + n;
891
918
  }
892
919
  return `${t}${n.replace(/(零.)*零元/, "元").replace(/(零.)+/g, "零").replace(/^整$/, "零元整")}`;
893
920
  };
894
- function yr(e, t) {
921
+ function Ar(e, t) {
895
922
  const r = e || "", n = t || "", o = Math.max(r.length, n.length);
896
- return o === 0 ? 1 : (o - fe(r, n)) / o;
923
+ return o === 0 ? 1 : (o - he(r, n)) / o;
897
924
  }
898
- const gr = (e) => R(e).map((r) => r.toLowerCase()).join("_"), wr = (e) => Ve(e).split("-").filter((t) => !!t).map((t) => ie(t.toLowerCase())).join(" "), Ar = (e) => e.trim().replace(/\s+/g, " "), Er = (e, t) => e.replace(/\${([^}]+)}/g, (r, n) => _e(t, n.trim(), "")), He = (e) => e ? e.substring(0, 1).toLowerCase() + e.substring(1, e.length) : "", br = (e) => {
925
+ const Er = (e) => x(e).map((r) => r.toLowerCase()).join("_"), Sr = (e) => He(e).split("-").filter((t) => !!t).map((t) => ie(t.toLowerCase())).join(" "), br = (e) => e.trim().replace(/\s+/g, " "), Or = (e, t) => e.replace(/\${([^}]+)}/g, (r, n) => Ue(t, n.trim(), "")), Ye = (e) => e ? e.substring(0, 1).toLowerCase() + e.substring(1, e.length) : "", Tr = (e) => {
899
926
  if (!e) return "";
900
927
  const t = e.toLowerCase();
901
- return He(t);
902
- }, v = /^([^/:]+):\/*/, Sr = (...e) => {
928
+ return Ye(t);
929
+ }, v = /^([^/:]+):\/*/, Cr = (...e) => {
903
930
  if (e = e.filter((s) => s !== ""), e.length === 0)
904
931
  return "";
905
- if (e.findIndex((s) => !(T(s) || p(s))) >= 0)
932
+ if (e.findIndex((s) => !(O(s) || p(s))) >= 0)
906
933
  throw new Error("paths must be a string or number");
907
934
  let r = "";
908
935
  const n = `${e[0]}`;
@@ -921,7 +948,7 @@ const gr = (e) => R(e).map((r) => r.toLowerCase()).join("_"), wr = (e) => Ve(e).
921
948
  }
922
949
  return c.replace(/\/(\?|&|#[^!])/g, "$1");
923
950
  };
924
- class Tr {
951
+ class Pr {
925
952
  #e = /* @__PURE__ */ new Map();
926
953
  /**
927
954
  * 添加事件监听器
@@ -975,9 +1002,9 @@ class Tr {
975
1002
  }
976
1003
  }
977
1004
  }
978
- const Or = "", Cr = "", Pr = (e, ...t) => {
1005
+ const $r = "", Mr = "", _r = (e, ...t) => {
979
1006
  const r = [];
980
- x(e) ? Object.keys(e).sort().forEach((o) => {
1007
+ _(e) ? Object.keys(e).sort().forEach((o) => {
981
1008
  const c = e[o];
982
1009
  r.push([o, c]);
983
1010
  }) : r.push([e]), t.length && t.forEach((o) => {
@@ -985,126 +1012,128 @@ const Or = "
985
1012
  }), (console?.table ?? console.log)(r);
986
1013
  };
987
1014
  export {
988
- St as AsyncTaskExecutor,
1015
+ Ct as AsyncQueueExecutor,
989
1016
  ee as BASE_62_DIGITS,
990
- Tr as EventDispatcher,
991
- Or as IMAGE_MIN_BASE64_BLACK,
992
- Cr as IMAGE_MIN_BASE64_TRANSPARENT,
993
- or as IS_BROWSER,
994
- tt as IdleTimer,
995
- rt as LeaderElection,
996
- Mt as aesDecrypt,
997
- $t as aesEncrypt,
1017
+ Pr as EventDispatcher,
1018
+ $r as IMAGE_MIN_BASE64_BLACK,
1019
+ Mr as IMAGE_MIN_BASE64_TRANSPARENT,
1020
+ ir as IS_BROWSER,
1021
+ nt as IdleTimer,
1022
+ ot as LeaderElection,
1023
+ Rt as aesDecrypt,
1024
+ xt as aesEncrypt,
998
1025
  C as base64Decode,
999
- b as base64Encode,
1000
- lr as camelCase,
1001
- Lt as canBeDate,
1002
- Ne as canBeNumber,
1026
+ S as base64Encode,
1027
+ hr as camelCase,
1028
+ Nt as canBeDate,
1029
+ Be as canBeNumber,
1003
1030
  ie as capitalize,
1004
- ve as capitalizeFirst,
1005
- ot as chunk,
1006
- ur as compressToBase64Url,
1007
- et as createBroadcastTopic,
1008
- jt as dateStringToDate,
1009
- $e as dateStringWithTimezone,
1010
- zt as debounce,
1011
- xt as decodeJWTPayload,
1012
- fr as decompressFromBase64Url,
1013
- Be as deepFreeze,
1014
- st as difference,
1015
- Ft as emptyFunction,
1016
- ct as flatten,
1017
- de as flattenDeep,
1018
- Qt as flattenPathObjectToPlainObject,
1019
- _t as formatCountdown,
1020
- It as formatPassTime,
1031
+ Ve as capitalizeFirst,
1032
+ st as checkOPFSAvailable,
1033
+ it as chunk,
1034
+ pr as compressToBase64Url,
1035
+ rt as createBroadcastTopic,
1036
+ Dt as dateStringToDate,
1037
+ Re as dateStringWithTimezone,
1038
+ Wt as debounce,
1039
+ Bt as decodeJWTPayload,
1040
+ dr as decompressFromBase64Url,
1041
+ Le as deepFreeze,
1042
+ at as difference,
1043
+ vt as emptyFunction,
1044
+ lt as flatten,
1045
+ ye as flattenDeep,
1046
+ Yt as flattenPathObjectToPlainObject,
1047
+ kt as formatCountdown,
1048
+ Ut as formatPassTime,
1021
1049
  g as generateKeyBetween,
1022
1050
  K as generateKeysBetween,
1023
- _e as get,
1024
- De as has,
1025
- it as intersection,
1026
- S as isArray,
1027
- me as isArrayBuffer,
1028
- at as isBoolean,
1051
+ Ue as get,
1052
+ ke as has,
1053
+ ut as intersection,
1054
+ b as isArray,
1055
+ ge as isArrayBuffer,
1056
+ ft as isBoolean,
1029
1057
  Z as isDate,
1030
- lt as isEmpty,
1031
- z as isEqual,
1032
- Ht as isEqualDate,
1033
- ke as isEqualUint8Array,
1034
- ut as isFloat,
1058
+ ht as isEmpty,
1059
+ q as isEqual,
1060
+ Xt as isEqualDate,
1061
+ Ke as isEqualUint8Array,
1062
+ pt as isFloat,
1035
1063
  d as isFunction,
1036
- Dt as isISODateString,
1037
- ge as isInt,
1038
- ft as isIntArray,
1039
- kt as isMSTime,
1040
- Q as isNil,
1064
+ Kt as isISODateString,
1065
+ Ae as isInt,
1066
+ dt as isIntArray,
1067
+ qt as isMSTime,
1068
+ H as isNil,
1041
1069
  p as isNumber,
1042
- ht as isNumberArray,
1043
- x as isObject,
1044
- pt as isObjectLike,
1045
- we as isPlainObject,
1046
- dt as isPrimitive,
1047
- mt as isPromise,
1048
- yt as isRegExp,
1049
- T as isString,
1050
- gt as isStringArray,
1051
- ye as isSymbol,
1052
- M as isUint8Array,
1053
- Ve as kebabCase,
1054
- Pr as logError,
1055
- Ut as msTimeToMilliseconds,
1056
- wt as needArray,
1057
- Tt as nextMacroTask,
1058
- Ot as nextMicroTask,
1059
- Ft as noop,
1060
- Re as numberStep,
1061
- vt as numberStepScreenSize,
1062
- Wt as numberStrip,
1063
- Jt as omit,
1064
- Yt as omitBy,
1065
- qt as once,
1066
- At as orderBy,
1067
- hr as parseChineseNumber,
1070
+ mt as isNumberArray,
1071
+ me as isOPFSSupported,
1072
+ _ as isObject,
1073
+ yt as isObjectLike,
1074
+ Ee as isPlainObject,
1075
+ gt as isPrimitive,
1076
+ wt as isPromise,
1077
+ At as isRegExp,
1078
+ O as isString,
1079
+ Et as isStringArray,
1080
+ we as isSymbol,
1081
+ $ as isUint8Array,
1082
+ He as kebabCase,
1083
+ _r as logError,
1084
+ Ft as msTimeToMilliseconds,
1085
+ St as needArray,
1086
+ Pt as nextMacroTask,
1087
+ $t as nextMicroTask,
1088
+ vt as noop,
1089
+ Ie as numberStep,
1090
+ Zt as numberStepScreenSize,
1091
+ Ht as numberStrip,
1092
+ er as omit,
1093
+ tr as omitBy,
1094
+ Gt as once,
1095
+ bt as orderBy,
1096
+ mr as parseChineseNumber,
1068
1097
  J as parseTime,
1069
- nt as performChunk,
1070
- Xt as pick,
1071
- er as pickBy,
1072
- tr as plainObjectToFlattenPathObject,
1073
- L as pool,
1074
- pr as queryParse,
1075
- dr as queryStringify,
1076
- sr as randomArrayItem,
1077
- cr as randomFloat,
1078
- ir as randomInt,
1098
+ ct as performChunk,
1099
+ rr as pick,
1100
+ nr as pickBy,
1101
+ or as plainObjectToFlattenPathObject,
1102
+ I as pool,
1103
+ yr as queryParse,
1104
+ gr as queryStringify,
1105
+ ar as randomArrayItem,
1106
+ lr as randomFloat,
1107
+ ur as randomInt,
1079
1108
  F as randomString,
1080
- ar as randomUintByLength,
1109
+ fr as randomUintByLength,
1081
1110
  Ge as randomUintString,
1082
- mr as rmbUppercase,
1083
- Nt as rsaDecrypt,
1084
- Rt as rsaEncrypt,
1085
- Bt as rsaGenerateKey,
1086
- je as set,
1111
+ wr as rmbUppercase,
1112
+ It as rsaDecrypt,
1113
+ Lt as rsaEncrypt,
1114
+ jt as rsaGenerateKey,
1115
+ Ne as set,
1087
1116
  ne as setBase,
1088
- Ie as setWith,
1089
- yr as similarity,
1090
- Ct as sleep,
1091
- gr as snakeCase,
1092
- Et as sortBy,
1093
- wr as startCase,
1094
- Ar as stringSingleline,
1095
- Er as stringTemplate,
1117
+ De as setWith,
1118
+ Ar as similarity,
1119
+ Mt as sleep,
1120
+ Er as snakeCase,
1121
+ Ot as sortBy,
1122
+ Sr as startCase,
1123
+ br as stringSingleline,
1124
+ Or as stringTemplate,
1096
1125
  Y as stringTime,
1097
- N as stringToArrayBuffer,
1098
- Gt as throttle,
1099
- Vt as toInt,
1100
- rr as toPlainObject,
1101
- H as traverseObjectKeys,
1102
- Zt as tryToNumber,
1103
- Pt as uint8ArrayToString,
1104
- br as uncapitalize,
1105
- He as uncapitalizeFirst,
1106
- bt as unionBy,
1107
- Kt as unixTimestamp,
1108
- Sr as urlJoin,
1109
- nr as zipObject
1126
+ R as stringToArrayBuffer,
1127
+ Vt as throttle,
1128
+ Qt as toInt,
1129
+ sr as toPlainObject,
1130
+ Q as traverseObjectKeys,
1131
+ Jt as tryToNumber,
1132
+ _t as uint8ArrayToString,
1133
+ Tr as uncapitalize,
1134
+ Ye as uncapitalizeFirst,
1135
+ Tt as unionBy,
1136
+ zt as unixTimestamp,
1137
+ Cr as urlJoin,
1138
+ cr as zipObject
1110
1139
  };