@jasonshimmy/custom-elements-runtime 0.2.0 → 0.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,13 +1,13 @@
1
- function mt(e, t) {
2
- return oe(e ? t : [], "when-block");
1
+ function yt(e, t) {
2
+ return te(e ? t : [], "when-block");
3
3
  }
4
- function bt(e, t) {
5
- return e.map((r, n) => {
6
- const o = typeof r == "object" ? r?.key ?? r?.id ?? `idx-${n}` : String(r);
7
- return oe(t(r, n), `each-${o}`);
4
+ function mt(e, t) {
5
+ return e.map((r, o) => {
6
+ const n = typeof r == "object" ? r?.key ?? r?.id ?? `idx-${o}` : String(r);
7
+ return te(t(r, o), `each-${n}`);
8
8
  });
9
9
  }
10
- function Be() {
10
+ function Re() {
11
11
  const e = [];
12
12
  return {
13
13
  when(t, r) {
@@ -17,18 +17,18 @@ function Be() {
17
17
  return e.push([!0, t]), this;
18
18
  },
19
19
  done() {
20
- return Re(...e);
20
+ return Be(...e);
21
21
  }
22
22
  };
23
23
  }
24
- function Re(...e) {
24
+ function Be(...e) {
25
25
  for (let t = 0; t < e.length; t++) {
26
- const [r, n] = e[t];
27
- if (r) return [oe(n, `whenChain-branch-${t}`)];
26
+ const [r, o] = e[t];
27
+ if (r) return [te(o, `whenChain-branch-${t}`)];
28
28
  }
29
- return [oe([], "whenChain-empty")];
29
+ return [te([], "whenChain-empty")];
30
30
  }
31
- function oe(e, t) {
31
+ function te(e, t) {
32
32
  const r = e ? Array.isArray(e) ? e.filter(Boolean) : [e].filter(Boolean) : [];
33
33
  return {
34
34
  tag: "#anchor",
@@ -36,7 +36,7 @@ function oe(e, t) {
36
36
  children: r
37
37
  };
38
38
  }
39
- class V extends EventTarget {
39
+ class K extends EventTarget {
40
40
  handlers = {};
41
41
  static instance;
42
42
  eventCounters = /* @__PURE__ */ new Map();
@@ -44,7 +44,7 @@ class V extends EventTarget {
44
44
  * Returns the singleton instance of GlobalEventBus
45
45
  */
46
46
  static getInstance() {
47
- return V.instance || (V.instance = new V()), V.instance;
47
+ return K.instance || (K.instance = new K()), K.instance;
48
48
  }
49
49
  // Enhanced emit method with better typing and event storm protection
50
50
  /**
@@ -53,10 +53,10 @@ class V extends EventTarget {
53
53
  * @param data - Optional event payload
54
54
  */
55
55
  emit(t, r) {
56
- const n = Date.now(), o = this.eventCounters.get(t);
57
- if (!o || n - o.window > 1e3)
58
- this.eventCounters.set(t, { count: 1, window: n });
59
- else if (o.count++, o.count > 50 && (console.error(`Event storm detected for "${t}": ${o.count} events in 1 second. Throttling...`), o.count > 100)) {
56
+ const o = Date.now(), n = this.eventCounters.get(t);
57
+ if (!n || o - n.window > 1e3)
58
+ this.eventCounters.set(t, { count: 1, window: o });
59
+ else if (n.count++, n.count > 50 && (console.error(`Event storm detected for "${t}": ${n.count} events in 1 second. Throttling...`), n.count > 100)) {
60
60
  console.warn(`Blocking further "${t}" events to prevent infinite loop`);
61
61
  return;
62
62
  }
@@ -89,8 +89,8 @@ class V extends EventTarget {
89
89
  * @param handler - Handler function to remove
90
90
  */
91
91
  off(t, r) {
92
- const n = this.handlers[t];
93
- n && n.delete(r);
92
+ const o = this.handlers[t];
93
+ o && o.delete(r);
94
94
  }
95
95
  /**
96
96
  * Remove all handlers for a specific event.
@@ -105,8 +105,8 @@ class V extends EventTarget {
105
105
  * @param handler - CustomEvent handler
106
106
  * @param options - AddEventListener options
107
107
  */
108
- listen(t, r, n) {
109
- return this.addEventListener(t, r, n), () => this.removeEventListener(t, r);
108
+ listen(t, r, o) {
109
+ return this.addEventListener(t, r, o), () => this.removeEventListener(t, r);
110
110
  }
111
111
  /**
112
112
  * Register a one-time event handler. Returns a promise that resolves with the event data.
@@ -114,9 +114,9 @@ class V extends EventTarget {
114
114
  * @param handler - Handler function
115
115
  */
116
116
  once(t, r) {
117
- return new Promise((n) => {
118
- const o = this.on(t, (s) => {
119
- o(), r(s), n(s);
117
+ return new Promise((o) => {
118
+ const n = this.on(t, (s) => {
119
+ n(), r(s), o(s);
120
120
  });
121
121
  });
122
122
  }
@@ -146,9 +146,9 @@ class V extends EventTarget {
146
146
  */
147
147
  getEventStats() {
148
148
  const t = {};
149
- for (const [r, n] of this.eventCounters.entries())
149
+ for (const [r, o] of this.eventCounters.entries())
150
150
  t[r] = {
151
- count: n.count,
151
+ count: o.count,
152
152
  handlersCount: this.getHandlerCount(r)
153
153
  };
154
154
  return t;
@@ -160,29 +160,29 @@ class V extends EventTarget {
160
160
  this.eventCounters.clear();
161
161
  }
162
162
  }
163
- const X = V.getInstance(), vt = (e, t) => X.emit(e, t), wt = (e, t) => X.on(e, t), xt = (e, t) => X.off(e, t), kt = (e, t) => X.once(e, t), $t = (e, t, r) => X.listen(e, t, r);
163
+ const Z = K.getInstance(), bt = (e, t) => Z.emit(e, t), vt = (e, t) => Z.on(e, t), xt = (e, t) => Z.off(e, t), wt = (e, t) => Z.once(e, t), kt = (e, t, r) => Z.listen(e, t, r);
164
164
  function xe(e) {
165
165
  let t = { ...e };
166
166
  const r = [];
167
- function n(a) {
167
+ function o(a) {
168
168
  r.push(a), a(t);
169
169
  }
170
- function o() {
170
+ function n() {
171
171
  return t;
172
172
  }
173
173
  function s(a) {
174
- const c = typeof a == "function" ? a(t) : a;
175
- t = { ...t, ...c }, i();
174
+ const l = typeof a == "function" ? a(t) : a;
175
+ t = { ...t, ...l }, i();
176
176
  }
177
177
  function i() {
178
178
  r.forEach((a) => a(t));
179
179
  }
180
- return { subscribe: n, getState: o, setState: s };
180
+ return { subscribe: o, getState: n, setState: s };
181
181
  }
182
- function ve(e) {
182
+ function me(e) {
183
183
  return e.replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase();
184
184
  }
185
- function ge(e) {
185
+ function pe(e) {
186
186
  return typeof e == "string" ? e.replace(
187
187
  /[&<>"']/g,
188
188
  (t) => ({
@@ -194,116 +194,116 @@ function ge(e) {
194
194
  })[t]
195
195
  ) : e;
196
196
  }
197
- function Oe(e, t, r) {
197
+ function Pe(e, t, r) {
198
198
  if (r)
199
- for (const [n, o] of Object.entries(r)) {
199
+ for (const [o, n] of Object.entries(r)) {
200
200
  let s, i = {};
201
- if (Array.isArray(o) ? (s = o[0], i = o[1] || {}) : s = o, t.set(n, {
201
+ if (Array.isArray(n) ? (s = n[0], i = n[1] || {}) : s = n, t.set(o, {
202
202
  callback: s,
203
203
  options: i,
204
- oldValue: ye(e, n)
204
+ oldValue: he(e, o)
205
205
  }), i.immediate)
206
206
  try {
207
- const a = ye(e, n);
207
+ const a = he(e, o);
208
208
  s(a, void 0, e);
209
209
  } catch (a) {
210
- console.error(`Error in immediate watcher for "${n}":`, a);
210
+ console.error(`Error in immediate watcher for "${o}":`, a);
211
211
  }
212
212
  }
213
213
  }
214
- function ye(e, t) {
215
- return t.split(".").reduce((r, n) => r?.[n], e);
214
+ function he(e, t) {
215
+ return t.split(".").reduce((r, o) => r?.[o], e);
216
216
  }
217
- function Me(e, t, r, n) {
218
- const o = (i, a) => {
217
+ function Oe(e, t, r, o) {
218
+ const n = (i, a) => {
219
219
  if (i === a) return !0;
220
220
  if (typeof i != typeof a || typeof i != "object" || i === null || a === null) return !1;
221
221
  if (Array.isArray(i) && Array.isArray(a))
222
- return i.length !== a.length ? !1 : i.every((l, y) => o(l, a[y]));
223
- const c = Object.keys(i), u = Object.keys(a);
224
- return c.length !== u.length ? !1 : c.every((l) => o(i[l], a[l]));
222
+ return i.length !== a.length ? !1 : i.every((p, y) => n(p, a[y]));
223
+ const l = Object.keys(i), f = Object.keys(a);
224
+ return l.length !== f.length ? !1 : l.every((p) => n(i[p], a[p]));
225
225
  }, s = t.get(r);
226
- if (s && !o(n, s.oldValue))
226
+ if (s && !n(o, s.oldValue))
227
227
  try {
228
- s.callback(n, s.oldValue, e), s.oldValue = n;
228
+ s.callback(o, s.oldValue, e), s.oldValue = o;
229
229
  } catch (i) {
230
230
  console.error(`Error in watcher for "${r}":`, i);
231
231
  }
232
232
  for (const [i, a] of t.entries())
233
233
  if (a.options.deep && r.startsWith(i + "."))
234
234
  try {
235
- const c = ye(e, i);
236
- o(c, a.oldValue) || (a.callback(c, a.oldValue, e), a.oldValue = c);
237
- } catch (c) {
238
- console.error(`Error in deep watcher for "${i}":`, c);
235
+ const l = he(e, i);
236
+ n(l, a.oldValue) || (a.callback(l, a.oldValue, e), a.oldValue = l);
237
+ } catch (l) {
238
+ console.error(`Error in deep watcher for "${i}":`, l);
239
239
  }
240
240
  }
241
- function Ne(e, t, r) {
241
+ function Me(e, t, r) {
242
242
  if (!t.props) return;
243
- function n(o, s) {
244
- return s === Boolean ? o === "true" : s === Number ? Number(o) : o;
243
+ function o(n, s) {
244
+ return s === Boolean ? n === "true" : s === Number ? Number(n) : n;
245
245
  }
246
- Object.entries(t.props).forEach(([o, s]) => {
247
- if (s.type === Function && typeof e[o] == "function")
248
- r[o] = e[o];
246
+ Object.entries(t.props).forEach(([n, s]) => {
247
+ if (s.type === Function && typeof e[n] == "function")
248
+ r[n] = e[n];
249
249
  else {
250
- const i = e.getAttribute(ve(o));
251
- i !== null ? r[o] = ge(n(i, s.type)) : "default" in s && s.default !== void 0 && (r[o] = ge(s.default));
250
+ const i = e.getAttribute(me(n));
251
+ i !== null ? r[n] = pe(o(i, s.type)) : "default" in s && s.default !== void 0 && (r[n] = pe(s.default));
252
252
  }
253
253
  });
254
254
  }
255
- function We(e, t, r, n) {
256
- e.onConnected && !r && (e.onConnected(t), n(!0));
255
+ function Ne(e, t, r, o) {
256
+ e.onConnected && !r && (e.onConnected(t), o(!0));
257
257
  }
258
- function De(e, t, r, n, o, s, i, a) {
259
- e.onDisconnected && e.onDisconnected(t), r.forEach((c) => c()), n(), o(), s(!1), i(null), a(!1);
258
+ function We(e, t, r, o, n, s, i, a) {
259
+ e.onDisconnected && e.onDisconnected(t), r.forEach((l) => l()), o(), n(), s(!1), i(null), a(!1);
260
260
  }
261
- function qe(e, t, r, n, o) {
262
- e.onAttributeChanged && e.onAttributeChanged(t, r, n, o);
261
+ function De(e, t, r, o, n) {
262
+ e.onAttributeChanged && e.onAttributeChanged(t, r, o, n);
263
263
  }
264
- function H(e, t) {
264
+ function q(e, t) {
265
265
  if (t && e instanceof HTMLElement) {
266
266
  for (const r in t)
267
267
  t[r] === e && delete t[r];
268
268
  for (const r of Array.from(e.childNodes))
269
- H(r, t);
269
+ q(r, t);
270
270
  }
271
271
  }
272
- function K(e, t) {
273
- return typeof t == "string" ? t.split(".").reduce((r, n) => r?.[n], e) : t;
272
+ function I(e, t) {
273
+ return typeof t == "string" ? t.split(".").reduce((r, o) => r?.[o], e) : t;
274
274
  }
275
- function ke(e, t, r) {
276
- const n = t.split("."), o = n.pop();
277
- if (!o) return;
278
- const s = n.reduce((i, a) => (a in i || (i[a] = {}), i[a]), e);
279
- s[o] = r;
275
+ function we(e, t, r) {
276
+ const o = t.split("."), n = o.pop();
277
+ if (!n) return;
278
+ const s = o.reduce((i, a) => (a in i || (i[a] = {}), i[a]), e);
279
+ s[n] = r;
280
280
  }
281
- function Ie(e, t, r, n, o, s, i) {
281
+ function qe(e, t, r, o, n, s, i) {
282
282
  if (!s) return;
283
- const a = t.includes("lazy"), c = t.includes("trim"), u = t.includes("number"), l = () => {
284
- const p = s._state || s;
285
- return K(p, e);
286
- }, y = l();
287
- let d = "text";
288
- const b = n?.type;
289
- if (i instanceof HTMLInputElement ? d = b || i.type || "text" : i instanceof HTMLSelectElement ? d = "select" : i instanceof HTMLTextAreaElement && (d = "textarea"), d === "checkbox")
283
+ const a = t.includes("lazy"), l = t.includes("trim"), f = t.includes("number"), p = () => {
284
+ const h = s._state || s;
285
+ return I(h, e);
286
+ }, y = p();
287
+ let c = "text";
288
+ const w = o?.type;
289
+ if (i instanceof HTMLInputElement ? c = w || i.type || "text" : i instanceof HTMLSelectElement ? c = "select" : i instanceof HTMLTextAreaElement && (c = "textarea"), c === "checkbox")
290
290
  if (Array.isArray(y)) {
291
- const p = i?.getAttribute("value") || n?.value || "", f = y.includes(p);
292
- i && i.checked !== f && (r.checked = f);
291
+ const h = i?.getAttribute("value") || o?.value || "", u = y.includes(h);
292
+ i && i.checked !== u && (r.checked = u);
293
293
  } else {
294
- const p = i?.getAttribute("true-value") || !0, f = y === p;
295
- i && i.checked !== f && (r.checked = f);
294
+ const h = i?.getAttribute("true-value") || !0, u = y === h;
295
+ i && i.checked !== u && (r.checked = u);
296
296
  }
297
- else if (d === "radio") {
298
- const p = n?.value || "", f = y === p;
299
- i && i.checked !== f && (r.checked = f);
300
- } else if (d === "select")
297
+ else if (c === "radio") {
298
+ const h = o?.value || "", u = y === h;
299
+ i && i.checked !== u && (r.checked = u);
300
+ } else if (c === "select")
301
301
  if (i && i.hasAttribute("multiple")) {
302
- const p = i, f = Array.isArray(y) ? y : [];
302
+ const h = i, u = Array.isArray(y) ? y : [];
303
303
  setTimeout(() => {
304
- Array.from(p.options).forEach((g) => {
305
- const m = f.includes(g.value);
306
- g.selected !== m && (g.selected = m);
304
+ Array.from(h.options).forEach((g) => {
305
+ const b = u.includes(g.value);
306
+ g.selected !== b && (g.selected = b);
307
307
  });
308
308
  }, 0);
309
309
  } else
@@ -311,139 +311,130 @@ function Ie(e, t, r, n, o, s, i) {
311
311
  i instanceof HTMLSelectElement && i.value !== String(y) && (i.value = String(y));
312
312
  }, 0);
313
313
  else {
314
- const p = String(y ?? "");
315
- (!i || i.value !== p) && (r.value = y);
316
- }
317
- const k = a || d === "checkbox" || d === "radio" || d === "select" ? "change" : "input", x = (p) => {
318
- if (p.isComposing || o._isComposing || p.isTrusted === !1) return;
319
- const f = p.target;
320
- if (f._modelUpdating) return;
321
- const g = l();
322
- let m = f.value;
323
- if (d === "checkbox")
314
+ const h = String(y ?? "");
315
+ (!i || i.value !== h) && (r.value = y);
316
+ }
317
+ const x = a || c === "checkbox" || c === "radio" || c === "select" ? "change" : "input", k = (h) => {
318
+ if (h.isComposing || n._isComposing || h.isTrusted === !1) return;
319
+ const u = h.target;
320
+ if (u._modelUpdating) return;
321
+ const g = p();
322
+ let b = u.value;
323
+ if (c === "checkbox")
324
324
  if (Array.isArray(g)) {
325
- const $ = f.getAttribute("value") || "", _ = [...g];
326
- if (f.checked)
325
+ const $ = u.getAttribute("value") || "", _ = [...g];
326
+ if (u.checked)
327
327
  _.includes($) || _.push($);
328
328
  else {
329
329
  const C = _.indexOf($);
330
330
  C > -1 && _.splice(C, 1);
331
331
  }
332
- m = _;
332
+ b = _;
333
333
  } else {
334
- const $ = f.getAttribute("true-value") || !0, _ = f.getAttribute("false-value") || !1;
335
- m = f.checked ? $ : _;
334
+ const $ = u.getAttribute("true-value") || !0, _ = u.getAttribute("false-value") || !1;
335
+ b = u.checked ? $ : _;
336
336
  }
337
- else if (d === "radio")
338
- m = f.getAttribute("value") || f.value;
339
- else if (d === "select" && f.multiple) {
340
- const $ = f;
341
- m = Array.from($.selectedOptions).map(
337
+ else if (c === "radio")
338
+ b = u.getAttribute("value") || u.value;
339
+ else if (c === "select" && u.multiple) {
340
+ const $ = u;
341
+ b = Array.from($.selectedOptions).map(
342
342
  (_) => _.value
343
343
  );
344
- } else if (c && (m = m.trim()), u) {
345
- const $ = Number(m);
346
- isNaN($) || (m = $);
344
+ } else if (l && (b = b.trim()), f) {
345
+ const $ = Number(b);
346
+ isNaN($) || (b = $);
347
347
  }
348
- const h = s._state || s, w = K(h, e);
349
- if (Array.isArray(m) && Array.isArray(w) ? JSON.stringify([...m].sort()) !== JSON.stringify([...w].sort()) : m !== w) {
350
- const $ = p.target;
351
- $._modelUpdating = !0, ke(h, e, m), setTimeout(() => {
348
+ const d = s._state || s, v = I(d, e);
349
+ if (Array.isArray(b) && Array.isArray(v) ? JSON.stringify([...b].sort()) !== JSON.stringify([...v].sort()) : b !== v) {
350
+ const $ = h.target;
351
+ $._modelUpdating = !0, we(d, e, b), setTimeout(() => {
352
352
  $._modelUpdating = !1;
353
353
  }, 0), s._requestRender && s._requestRender();
354
354
  }
355
355
  };
356
- if (o[k] = x, d === "text" || d === "textarea") {
357
- const p = () => {
358
- o._isComposing = !0;
359
- }, f = (g) => {
360
- o._isComposing = !1;
361
- const m = g.target;
356
+ if (n[x] = k, c === "text" || c === "textarea") {
357
+ const h = () => {
358
+ n._isComposing = !0;
359
+ }, u = (g) => {
360
+ n._isComposing = !1;
361
+ const b = g.target;
362
362
  setTimeout(() => {
363
- if (m) {
364
- let h = m.value;
365
- if (c && (h = h.trim()), u) {
366
- const _ = Number(h);
367
- isNaN(_) || (h = _);
363
+ if (b) {
364
+ let d = b.value;
365
+ if (l && (d = d.trim()), f) {
366
+ const _ = Number(d);
367
+ isNaN(_) || (d = _);
368
368
  }
369
- const w = s._state || s, v = K(w, e);
370
- (Array.isArray(h) && Array.isArray(v) ? JSON.stringify([...h].sort()) !== JSON.stringify([...v].sort()) : h !== v) && (m && (m._modelUpdating = !0, setTimeout(() => {
371
- m._modelUpdating = !1;
372
- }, 0)), ke(w, e, h), s._requestRender && s._requestRender());
369
+ const v = s._state || s, m = I(v, e);
370
+ (Array.isArray(d) && Array.isArray(m) ? JSON.stringify([...d].sort()) !== JSON.stringify([...m].sort()) : d !== m) && (b && (b._modelUpdating = !0, setTimeout(() => {
371
+ b._modelUpdating = !1;
372
+ }, 0)), we(v, e, d), s._requestRender && s._requestRender());
373
373
  }
374
374
  }, 0);
375
375
  };
376
- o.compositionstart = p, o.compositionend = f;
376
+ n.compositionstart = h, n.compositionend = u;
377
377
  }
378
378
  }
379
- function Te(e) {
379
+ function Ae(e) {
380
380
  return e.slice(2).charAt(0).toLowerCase() + e.slice(3);
381
381
  }
382
- function ee(e) {
383
- if (!e) return [void 0, void 0];
384
- if (typeof e == "function") return [e, void 0];
385
- if (typeof e == "object") {
386
- if (typeof e.handler == "function") return [e.handler, e.options];
387
- if (typeof e.fn == "function") return [e.fn, e.options];
388
- }
389
- return [void 0, void 0];
390
- }
391
- function He(e, t, r, n) {
392
- if (n) {
382
+ function Ie(e, t, r, o) {
383
+ if (o) {
393
384
  if (typeof e == "object" && e !== null)
394
- for (const [o, s] of Object.entries(e))
395
- t[o] = s;
385
+ for (const [n, s] of Object.entries(e))
386
+ t[n] = s;
396
387
  else if (typeof e == "string")
397
388
  try {
398
- const o = JSON.parse(e);
399
- if (typeof o == "object" && o !== null) {
400
- for (const [s, i] of Object.entries(o))
389
+ const n = JSON.parse(e);
390
+ if (typeof n == "object" && n !== null) {
391
+ for (const [s, i] of Object.entries(n))
401
392
  t[s] = i;
402
393
  return;
403
394
  }
404
395
  } catch {
405
- const o = K(n, e);
406
- r[e] = o;
396
+ const n = I(o, e);
397
+ r[e] = n;
407
398
  }
408
399
  }
409
400
  }
410
- function Ke(e, t, r) {
401
+ function He(e, t, r) {
411
402
  if (!r) return;
412
- const n = K(r, e), o = t.style || "", s = n ? "" : "none";
413
- if (o) {
414
- const i = o.split(";").filter(Boolean), a = i.findIndex(
415
- (c) => c.trim().startsWith("display:")
403
+ const o = I(r, e), n = t.style || "", s = o ? "" : "none";
404
+ if (n) {
405
+ const i = n.split(";").filter(Boolean), a = i.findIndex(
406
+ (l) => l.trim().startsWith("display:")
416
407
  );
417
408
  a >= 0 ? i[a] = `display: ${s}` : i.push(`display: ${s}`), t.style = i.join("; ");
418
409
  } else
419
410
  t.style = `display: ${s}`;
420
411
  }
421
- function Ue(e, t, r) {
412
+ function Fe(e, t, r) {
422
413
  if (!r) return;
423
- const n = K(r, e);
424
- let o = [];
425
- typeof n == "string" ? o = [n] : Array.isArray(n) ? o = n.filter(Boolean) : typeof n == "object" && (o = Object.entries(n).filter(([, a]) => !!a).flatMap(([a]) => a.split(/\s+/).filter(Boolean)));
426
- const s = t.class || "", i = s ? `${s} ${o.join(" ")}`.trim() : o.join(" ");
414
+ const o = I(r, e);
415
+ let n = [];
416
+ typeof o == "string" ? n = [o] : Array.isArray(o) ? n = o.filter(Boolean) : typeof o == "object" && (n = Object.entries(o).filter(([, a]) => !!a).flatMap(([a]) => a.split(/\s+/).filter(Boolean)));
417
+ const s = t.class || "", i = s ? `${s} ${n.join(" ")}`.trim() : n.join(" ");
427
418
  i && (t.class = i);
428
419
  }
429
- function Fe(e, t, r) {
430
- let n;
420
+ function Ke(e, t, r) {
421
+ let o;
431
422
  if (typeof e == "string") {
432
423
  if (!r) return;
433
- n = K(r, e);
424
+ o = I(r, e);
434
425
  } else
435
- n = e;
436
- let o = "";
437
- if (typeof n == "string")
438
- o = n;
439
- else if (n && typeof n == "object") {
426
+ o = e;
427
+ let n = "";
428
+ if (typeof o == "string")
429
+ n = o;
430
+ else if (o && typeof o == "object") {
440
431
  const i = [];
441
- for (const [a, c] of Object.entries(n))
442
- if (c != null && c !== "") {
443
- const u = a.replace(
432
+ for (const [a, l] of Object.entries(o))
433
+ if (l != null && l !== "") {
434
+ const f = a.replace(
444
435
  /[A-Z]/g,
445
- (d) => `-${d.toLowerCase()}`
446
- ), l = [
436
+ (c) => `-${c.toLowerCase()}`
437
+ ), p = [
447
438
  "width",
448
439
  "height",
449
440
  "top",
@@ -469,24 +460,24 @@ function Fe(e, t, r) {
469
460
  "min-height",
470
461
  "max-height"
471
462
  ];
472
- let y = String(c);
473
- typeof c == "number" && l.includes(u) && (y = `${c}px`), i.push(`${u}: ${y}`);
463
+ let y = String(l);
464
+ typeof l == "number" && p.includes(f) && (y = `${l}px`), i.push(`${f}: ${y}`);
474
465
  }
475
- o = i.join("; ") + (i.length > 0 ? ";" : "");
466
+ n = i.join("; ") + (i.length > 0 ? ";" : "");
476
467
  }
477
468
  const s = t.style || "";
478
- t.style = s + (s && !s.endsWith(";") ? "; " : "") + o;
469
+ t.style = s + (s && !s.endsWith(";") ? "; " : "") + n;
479
470
  }
480
- function je(e, t, r, n) {
481
- const o = {}, s = { ...n || {} }, i = {};
482
- for (const [a, c] of Object.entries(e)) {
483
- const { value: u, modifiers: l } = c;
471
+ function Te(e, t, r, o) {
472
+ const n = {}, s = { ...o || {} }, i = {};
473
+ for (const [a, l] of Object.entries(e)) {
474
+ const { value: f, modifiers: p } = l;
484
475
  switch (a) {
485
476
  case "model":
486
- Ie(
487
- typeof u == "string" ? u : String(u),
488
- l,
489
- o,
477
+ qe(
478
+ typeof f == "string" ? f : String(f),
479
+ p,
480
+ n,
490
481
  s,
491
482
  i,
492
483
  t,
@@ -494,47 +485,47 @@ function je(e, t, r, n) {
494
485
  );
495
486
  break;
496
487
  case "bind":
497
- He(u, o, s, t);
488
+ Ie(f, n, s, t);
498
489
  break;
499
490
  case "show":
500
- Ke(u, s, t);
491
+ He(f, s, t);
501
492
  break;
502
493
  case "class":
503
- Ue(u, s, t);
494
+ Fe(f, s, t);
504
495
  break;
505
496
  case "style":
506
- Fe(u, s, t);
497
+ Ke(f, s, t);
507
498
  break;
508
499
  }
509
500
  }
510
- return { props: o, attrs: s, listeners: i };
501
+ return { props: n, attrs: s, listeners: i };
511
502
  }
512
- function me(e, t) {
503
+ function ge(e, t) {
513
504
  if (Array.isArray(e)) {
514
505
  const s = /* @__PURE__ */ new Set();
515
506
  return e.map((i) => {
516
507
  if (!i || typeof i != "object") return i;
517
508
  let a = i.props?.key ?? i.key;
518
509
  if (!a) {
519
- const y = i.tag || "node", d = i.props?.attrs?.id ?? i.props?.attrs?.name ?? i.props?.attrs?.["data-key"] ?? "";
520
- a = d ? `${t}:${y}:${d}` : `${t}:${y}`;
510
+ const y = i.tag || "node", c = i.props?.attrs?.id ?? i.props?.attrs?.name ?? i.props?.attrs?.["data-key"] ?? "";
511
+ a = c ? `${t}:${y}:${c}` : `${t}:${y}`;
521
512
  }
522
- let c = a, u = 1;
523
- for (; s.has(c); )
524
- c = `${a}#${u++}`;
525
- s.add(c);
526
- let l = i.children;
527
- return Array.isArray(l) && (l = me(l, c)), { ...i, key: c, children: l };
513
+ let l = a, f = 1;
514
+ for (; s.has(l); )
515
+ l = `${a}#${f++}`;
516
+ s.add(l);
517
+ let p = i.children;
518
+ return Array.isArray(p) && (p = ge(p, l)), { ...i, key: l, children: p };
528
519
  });
529
520
  }
530
521
  const r = e;
531
- let n = r.props?.key ?? r.key ?? t, o = r.children;
532
- return Array.isArray(o) && (o = me(o, n)), { ...r, key: n, children: o };
522
+ let o = r.props?.key ?? r.key ?? t, n = r.children;
523
+ return Array.isArray(n) && (n = ge(n, o)), { ...r, key: o, children: n };
533
524
  }
534
- function Ve(e, t, r, n) {
535
- const o = r.directives ?? {}, s = je(
536
- o,
525
+ function Ue(e, t, r, o) {
526
+ const n = r.directives ?? {}, s = Te(
537
527
  n,
528
+ o,
538
529
  e,
539
530
  r.attrs
540
531
  ), i = {
@@ -545,32 +536,30 @@ function Ve(e, t, r, n) {
545
536
  ...t.attrs,
546
537
  ...r.attrs,
547
538
  ...s.attrs
548
- }, c = t.props ?? {}, u = i;
549
- for (const d in { ...c, ...u }) {
550
- const b = c[d], k = u[d];
551
- if (b !== k)
552
- if (d === "value" && (e instanceof HTMLInputElement || e instanceof HTMLTextAreaElement || e instanceof HTMLSelectElement))
553
- e.value !== k && (e.value = k ?? "");
554
- else if (d === "checked" && e instanceof HTMLInputElement)
555
- e.checked = !!k;
556
- else if (d.startsWith("on")) {
557
- const x = Te(d), [p, f] = ee(k), [g, m] = ee(b);
558
- g && e.removeEventListener(x, g, m), p && e.addEventListener(x, p, f);
559
- } else k == null || k === !1 ? e.removeAttribute(d) : e.setAttribute(d, String(k));
560
- }
561
- for (const [d, b] of Object.entries(
539
+ }, l = t.props ?? {}, f = i;
540
+ for (const c in { ...l, ...f }) {
541
+ const w = l[c], x = f[c];
542
+ if (w !== x)
543
+ if (c === "value" && (e instanceof HTMLInputElement || e instanceof HTMLTextAreaElement || e instanceof HTMLSelectElement))
544
+ e.value !== x && (e.value = x ?? "");
545
+ else if (c === "checked" && e instanceof HTMLInputElement)
546
+ e.checked = !!x;
547
+ else if (c.startsWith("on") && typeof x == "function") {
548
+ const k = Ae(c);
549
+ typeof w == "function" && e.removeEventListener(k, w), e.addEventListener(k, x);
550
+ } else x == null || x === !1 ? e.removeAttribute(c) : e.setAttribute(c, String(x));
551
+ }
552
+ for (const [c, w] of Object.entries(
562
553
  s.listeners || {}
563
- )) {
564
- const [k, x] = ee(b);
565
- k && e.addEventListener(d, k, x);
566
- }
567
- const l = t.attrs ?? {}, y = a;
568
- for (const d in { ...l, ...y }) {
569
- const b = l[d], k = y[d];
570
- b !== k && (k == null || k === !1 ? e.removeAttribute(d) : e.setAttribute(d, String(k)));
554
+ ))
555
+ e.addEventListener(c, w);
556
+ const p = t.attrs ?? {}, y = a;
557
+ for (const c in { ...p, ...y }) {
558
+ const w = p[c], x = y[c];
559
+ w !== x && (x == null || x === !1 ? e.removeAttribute(c) : e.setAttribute(c, String(x)));
571
560
  }
572
561
  }
573
- function O(e, t, r) {
562
+ function P(e, t, r) {
574
563
  if (typeof e == "string")
575
564
  return document.createTextNode(e);
576
565
  if (e.tag === "#text") {
@@ -580,170 +569,169 @@ function O(e, t, r) {
580
569
  return e.key != null && (y.key = e.key), y;
581
570
  }
582
571
  if (e.tag === "#anchor") {
583
- const y = e, d = Array.isArray(y.children) ? y.children : [], b = document.createTextNode(""), k = document.createTextNode("");
584
- y.key != null && (b.key = `${y.key}:start`, k.key = `${y.key}:end`), y._startNode = b, y._endNode = k;
585
- const x = document.createDocumentFragment();
586
- x.appendChild(b);
587
- for (const p of d) {
588
- const f = O(p, t);
589
- x.appendChild(f);
572
+ const y = e, c = Array.isArray(y.children) ? y.children : [], w = document.createTextNode(""), x = document.createTextNode("");
573
+ y.key != null && (w.key = `${y.key}:start`, x.key = `${y.key}:end`), y._startNode = w, y._endNode = x;
574
+ const k = document.createDocumentFragment();
575
+ k.appendChild(w);
576
+ for (const h of c) {
577
+ const u = P(h, t);
578
+ k.appendChild(u);
590
579
  }
591
- return x.appendChild(k), x;
580
+ return k.appendChild(x), k;
592
581
  }
593
- const n = document.createElement(e.tag);
594
- e.key != null && (n.key = e.key);
595
- const { props: o = {}, attrs: s = {}, directives: i = {} } = e.props ?? {}, a = je(i, t, n, s), c = {
596
- ...o,
582
+ const o = document.createElement(e.tag);
583
+ e.key != null && (o.key = e.key);
584
+ const { props: n = {}, attrs: s = {}, directives: i = {} } = e.props ?? {}, a = Te(i, t, o, s), l = {
585
+ ...n,
597
586
  ...a.props
598
- }, u = {
587
+ }, f = {
599
588
  ...s,
600
589
  ...a.attrs
601
590
  };
602
- for (const y in u) {
603
- const d = u[y];
591
+ for (const y in f) {
592
+ const c = f[y];
604
593
  if (typeof y != "string" || /\[object Object\]/.test(y)) {
605
- typeof window < "u" && window.console && console.warn("Skipping invalid attribute key:", y, d);
594
+ typeof window < "u" && window.console && console.warn("Skipping invalid attribute key:", y, c);
606
595
  continue;
607
596
  }
608
- typeof d == "boolean" ? d && n.setAttribute(y, "") : d != null && n.setAttribute(y, d);
597
+ typeof c == "boolean" ? c && o.setAttribute(y, "") : c != null && o.setAttribute(y, c);
609
598
  }
610
- for (const y in c) {
611
- const d = c[y];
599
+ for (const y in l) {
600
+ const c = l[y];
612
601
  if (typeof y != "string" || /\[object Object\]/.test(y)) {
613
- typeof window < "u" && window.console && console.warn("Skipping invalid prop key:", y, d);
602
+ typeof window < "u" && window.console && console.warn("Skipping invalid prop key:", y, c);
614
603
  continue;
615
604
  }
616
- if (y === "value" && (n instanceof HTMLInputElement || n instanceof HTMLTextAreaElement || n instanceof HTMLSelectElement))
617
- n.value = d ?? "";
618
- else if (y === "checked" && n instanceof HTMLInputElement)
619
- n.checked = !!d;
620
- else if (y.startsWith("on")) {
621
- const [b, k] = ee(d);
622
- b && n.addEventListener(Te(y), b, k);
623
- } else {
624
- if (y.startsWith("on") && d === void 0)
605
+ if (y === "value" && (o instanceof HTMLInputElement || o instanceof HTMLTextAreaElement || o instanceof HTMLSelectElement))
606
+ o.value = c ?? "";
607
+ else if (y === "checked" && o instanceof HTMLInputElement)
608
+ o.checked = !!c;
609
+ else if (y.startsWith("on") && typeof c == "function")
610
+ o.addEventListener(Ae(y), c);
611
+ else {
612
+ if (y.startsWith("on") && c === void 0)
625
613
  continue;
626
- d == null || d === !1 ? n.removeAttribute(y) : n.setAttribute(y, String(d));
614
+ c == null || c === !1 ? o.removeAttribute(y) : o.setAttribute(y, String(c));
627
615
  }
628
616
  }
629
- for (const [y, d] of Object.entries(
617
+ for (const [y, c] of Object.entries(
630
618
  a.listeners || {}
631
619
  ))
632
- n.addEventListener(y, d);
633
- const l = e.props?.ref ?? (e.props?.props && e.props.props.ref);
634
- if (typeof e != "string" && l && r && (r[l] = n), Array.isArray(e.children))
620
+ o.addEventListener(y, c);
621
+ const p = e.props?.ref ?? (e.props?.props && e.props.props.ref);
622
+ if (typeof e != "string" && p && r && (r[p] = o), Array.isArray(e.children))
635
623
  for (const y of e.children)
636
- n.appendChild(O(y, t, r));
637
- else typeof e.children == "string" && (n.textContent = e.children);
638
- return n;
624
+ o.appendChild(P(y, t, r));
625
+ else typeof e.children == "string" && (o.textContent = e.children);
626
+ return o;
639
627
  }
640
- function Je(e, t, r, n, o) {
628
+ function Ve(e, t, r, o, n) {
641
629
  if (typeof r == "string") {
642
630
  e.textContent !== r && (e.textContent = r);
643
631
  return;
644
632
  }
645
633
  if (!Array.isArray(r)) return;
646
634
  const s = Array.from(e.childNodes), i = Array.isArray(t) ? t : [], a = /* @__PURE__ */ new Map();
647
- for (const b of i)
648
- b && b.key != null && a.set(b.key, b);
649
- const c = /* @__PURE__ */ new Map();
650
- for (const b of s) {
651
- const k = b.key;
652
- k != null && c.set(k, b);
653
- }
654
- const u = /* @__PURE__ */ new Set();
655
- let l = e.firstChild;
656
- function y(b, k) {
657
- let x = b;
658
- for (; x && (u.add(x), x !== k); )
659
- x = x.nextSibling;
660
- }
661
- function d(b, k, x, p) {
662
- const f = [];
663
- let g = b.nextSibling;
664
- for (; g && g !== k; )
665
- f.push(g), g = g.nextSibling;
666
- const m = Array.isArray(x) ? x : [];
667
- if (p.some((w) => w && w.key != null) || m.some((w) => w && w.key != null)) {
668
- const w = /* @__PURE__ */ new Map(), v = /* @__PURE__ */ new Map();
669
- for (const C of m)
670
- C && C.key != null && w.set(C.key, C);
671
- for (const C of f) {
635
+ for (const w of i)
636
+ w && w.key != null && a.set(w.key, w);
637
+ const l = /* @__PURE__ */ new Map();
638
+ for (const w of s) {
639
+ const x = w.key;
640
+ x != null && l.set(x, w);
641
+ }
642
+ const f = /* @__PURE__ */ new Set();
643
+ let p = e.firstChild;
644
+ function y(w, x) {
645
+ let k = w;
646
+ for (; k && (f.add(k), k !== x); )
647
+ k = k.nextSibling;
648
+ }
649
+ function c(w, x, k, h) {
650
+ const u = [];
651
+ let g = w.nextSibling;
652
+ for (; g && g !== x; )
653
+ u.push(g), g = g.nextSibling;
654
+ const b = Array.isArray(k) ? k : [];
655
+ if (h.some((v) => v && v.key != null) || b.some((v) => v && v.key != null)) {
656
+ const v = /* @__PURE__ */ new Map(), m = /* @__PURE__ */ new Map();
657
+ for (const C of b)
658
+ C && C.key != null && v.set(C.key, C);
659
+ for (const C of u) {
672
660
  const E = C.key;
673
- E != null && v.set(E, C);
661
+ E != null && m.set(E, C);
674
662
  }
675
663
  const $ = /* @__PURE__ */ new Set();
676
- let _ = b.nextSibling;
677
- for (const C of p) {
664
+ let _ = w.nextSibling;
665
+ for (const C of h) {
678
666
  let E;
679
- if (C.key != null && v.has(C.key)) {
680
- const j = w.get(C.key);
681
- E = te(
682
- v.get(C.key),
667
+ if (C.key != null && m.has(C.key)) {
668
+ const j = v.get(C.key);
669
+ E = X(
670
+ m.get(C.key),
683
671
  j,
684
672
  C,
685
- n
673
+ o
686
674
  ), $.add(E), E !== _ && e.contains(E) && e.insertBefore(E, _);
687
675
  } else
688
- E = O(C, n), e.insertBefore(E, _), $.add(E);
676
+ E = P(C, o), e.insertBefore(E, _), $.add(E);
689
677
  _ = E.nextSibling;
690
678
  }
691
- for (const C of f)
679
+ for (const C of u)
692
680
  !$.has(C) && e.contains(C) && e.removeChild(C);
693
681
  } else {
694
- const w = Math.min(
695
- m.length,
696
- p.length
682
+ const v = Math.min(
683
+ b.length,
684
+ h.length
697
685
  );
698
- for (let v = 0; v < w; v++) {
699
- const $ = m[v], _ = p[v], C = te(f[v], $, _, n);
700
- C !== f[v] && (e.insertBefore(C, f[v]), e.removeChild(f[v]));
686
+ for (let m = 0; m < v; m++) {
687
+ const $ = b[m], _ = h[m], C = X(u[m], $, _, o);
688
+ C !== u[m] && (e.insertBefore(C, u[m]), e.removeChild(u[m]));
701
689
  }
702
- for (let v = w; v < p.length; v++)
703
- e.insertBefore(O(p[v], n), k);
704
- for (let v = w; v < f.length; v++)
705
- e.removeChild(f[v]);
690
+ for (let m = v; m < h.length; m++)
691
+ e.insertBefore(P(h[m], o), x);
692
+ for (let m = v; m < u.length; m++)
693
+ e.removeChild(u[m]);
706
694
  }
707
695
  }
708
- for (const b of r) {
709
- let k;
710
- if (b.tag === "#anchor") {
711
- const x = b.key, p = `${x}:start`, f = `${x}:end`;
712
- let g = c.get(p), m = c.get(f);
713
- const h = Array.isArray(b.children) ? b.children : [];
714
- if (g || (g = document.createTextNode(""), g.key = p), m || (m = document.createTextNode(""), m.key = f), b._startNode = g, b._endNode = m, !e.contains(g) || !e.contains(m)) {
715
- e.insertBefore(g, l);
716
- for (const w of h)
717
- e.insertBefore(O(w, n), l);
718
- e.insertBefore(m, l);
696
+ for (const w of r) {
697
+ let x;
698
+ if (w.tag === "#anchor") {
699
+ const k = w.key, h = `${k}:start`, u = `${k}:end`;
700
+ let g = l.get(h), b = l.get(u);
701
+ const d = Array.isArray(w.children) ? w.children : [];
702
+ if (g || (g = document.createTextNode(""), g.key = h), b || (b = document.createTextNode(""), b.key = u), w._startNode = g, w._endNode = b, !e.contains(g) || !e.contains(b)) {
703
+ e.insertBefore(g, p);
704
+ for (const v of d)
705
+ e.insertBefore(P(v, o), p);
706
+ e.insertBefore(b, p);
719
707
  } else
720
- d(
708
+ c(
721
709
  g,
722
- m,
723
- a.get(x)?.children,
724
- h
710
+ b,
711
+ a.get(k)?.children,
712
+ d
725
713
  );
726
- y(g, m), l = m.nextSibling;
714
+ y(g, b), p = b.nextSibling;
727
715
  continue;
728
716
  }
729
- if (b.key != null && c.has(b.key)) {
730
- const x = a.get(b.key);
731
- k = te(
732
- c.get(b.key),
733
- x,
734
- b,
735
- n,
736
- o
737
- ), u.add(k), k !== l && e.contains(k) && (l && !e.contains(l) && (l = null), e.insertBefore(k, l));
717
+ if (w.key != null && l.has(w.key)) {
718
+ const k = a.get(w.key);
719
+ x = X(
720
+ l.get(w.key),
721
+ k,
722
+ w,
723
+ o,
724
+ n
725
+ ), f.add(x), x !== p && e.contains(x) && (p && !e.contains(p) && (p = null), e.insertBefore(x, p));
738
726
  } else
739
- k = O(b, n, o), l && !e.contains(l) && (l = null), e.insertBefore(k, l), u.add(k);
740
- l = k.nextSibling;
727
+ x = P(w, o, n), p && !e.contains(p) && (p = null), e.insertBefore(x, p), f.add(x);
728
+ p = x.nextSibling;
741
729
  }
742
- for (const b of s)
743
- !u.has(b) && e.contains(b) && (H(b, o), e.removeChild(b));
730
+ for (const w of s)
731
+ !f.has(w) && e.contains(w) && (q(w, n), e.removeChild(w));
744
732
  }
745
- function te(e, t, r, n, o) {
746
- if (t && typeof t != "string" && t.props?.ref && o && H(e, o), t === r) return e;
733
+ function X(e, t, r, o, n) {
734
+ if (t && typeof t != "string" && t.props?.ref && n && q(e, n), t === r) return e;
747
735
  if (typeof r == "string") {
748
736
  if (e.nodeType === Node.TEXT_NODE)
749
737
  return e.textContent !== r && (e.textContent = r), e;
@@ -753,78 +741,78 @@ function te(e, t, r, n, o) {
753
741
  }
754
742
  }
755
743
  if (r && typeof r != "string" && r.tag === "#anchor") {
756
- const i = r, a = Array.isArray(i.children) ? i.children : [], c = i._startNode ?? document.createTextNode(""), u = i._endNode ?? document.createTextNode("");
757
- i.key != null && (c.key = `${i.key}:start`, u.key = `${i.key}:end`), i._startNode = c, i._endNode = u;
758
- const l = document.createDocumentFragment();
759
- l.appendChild(c);
744
+ const i = r, a = Array.isArray(i.children) ? i.children : [], l = i._startNode ?? document.createTextNode(""), f = i._endNode ?? document.createTextNode("");
745
+ i.key != null && (l.key = `${i.key}:start`, f.key = `${i.key}:end`), i._startNode = l, i._endNode = f;
746
+ const p = document.createDocumentFragment();
747
+ p.appendChild(l);
760
748
  for (const y of a) {
761
- const d = O(y, n);
762
- l.appendChild(d);
749
+ const c = P(y, o);
750
+ p.appendChild(c);
763
751
  }
764
- return l.appendChild(u), e.parentNode?.replaceChild(l, e), c;
752
+ return p.appendChild(f), e.parentNode?.replaceChild(p, e), l;
765
753
  }
766
754
  if (!r) {
767
- H(e, o);
755
+ q(e, n);
768
756
  const i = document.createComment("removed");
769
757
  return e.parentNode?.replaceChild(i, e), i;
770
758
  }
771
759
  if (!t || typeof t == "string") {
772
- H(e, o);
773
- const i = O(r, n, o);
774
- return typeof r != "string" && r.props?.ref && o && (o[r.props.ref] = i), e.parentNode?.replaceChild(i, e), i;
760
+ q(e, n);
761
+ const i = P(r, o, n);
762
+ return typeof r != "string" && r.props?.ref && n && (n[r.props.ref] = i), e.parentNode?.replaceChild(i, e), i;
775
763
  }
776
764
  if (r.tag === "#anchor") {
777
- const i = Array.isArray(r.children) ? r.children : [], a = r._startNode ?? document.createTextNode(""), c = r._endNode ?? document.createTextNode("");
778
- r.key != null && (a.key = `${r.key}:start`, c.key = `${r.key}:end`), r._startNode = a, r._endNode = c;
779
- const u = document.createDocumentFragment();
780
- u.appendChild(a);
781
- for (const l of i)
782
- u.appendChild(O(l, n));
783
- return u.appendChild(c), e.parentNode?.replaceChild(u, e), a;
765
+ const i = Array.isArray(r.children) ? r.children : [], a = r._startNode ?? document.createTextNode(""), l = r._endNode ?? document.createTextNode("");
766
+ r.key != null && (a.key = `${r.key}:start`, l.key = `${r.key}:end`), r._startNode = a, r._endNode = l;
767
+ const f = document.createDocumentFragment();
768
+ f.appendChild(a);
769
+ for (const p of i)
770
+ f.appendChild(P(p, o));
771
+ return f.appendChild(l), e.parentNode?.replaceChild(f, e), a;
784
772
  }
785
773
  if (typeof t != "string" && typeof r != "string" && t.tag === r.tag && t.key === r.key) {
786
774
  const i = e;
787
- return Ve(i, t.props || {}, r.props || {}, n), Je(i, t.children, r.children, n, o), typeof r != "string" && r.props?.ref && o && (o[r.props.ref] = i), i;
775
+ return Ue(i, t.props || {}, r.props || {}, o), Ve(i, t.children, r.children, o, n), typeof r != "string" && r.props?.ref && n && (n[r.props.ref] = i), i;
788
776
  }
789
- H(e, o);
790
- const s = O(r, n, o);
791
- return typeof r != "string" && r.props?.ref && o && (o[r.props.ref] = s), e.parentNode?.replaceChild(s, e), s;
777
+ q(e, n);
778
+ const s = P(r, o, n);
779
+ return typeof r != "string" && r.props?.ref && n && (n[r.props.ref] = s), e.parentNode?.replaceChild(s, e), s;
792
780
  }
793
- function Ze(e, t, r, n) {
794
- let o;
795
- Array.isArray(t) ? t.length === 1 ? (o = t[0], o && typeof o == "object" && o.key == null && (o = { ...o, key: "__root__" })) : o = { tag: "div", key: "__root__", children: t } : (o = t, o && typeof o == "object" && o.key == null && (o = { ...o, key: "__root__" })), o && typeof o == "object" && o.tag === "#anchor" && (o = {
781
+ function Je(e, t, r, o) {
782
+ let n;
783
+ Array.isArray(t) ? t.length === 1 ? (n = t[0], n && typeof n == "object" && n.key == null && (n = { ...n, key: "__root__" })) : n = { tag: "div", key: "__root__", children: t } : (n = t, n && typeof n == "object" && n.key == null && (n = { ...n, key: "__root__" })), n && typeof n == "object" && n.tag === "#anchor" && (n = {
796
784
  tag: "div",
797
785
  key: "__anchor_root__",
798
786
  props: { attrs: { "data-anchor-block-root": "", key: "__anchor_root__" } },
799
- children: [o]
800
- }), o = me(o, String(o.key ?? "root"));
787
+ children: [n]
788
+ }), n = ge(n, String(n.key ?? "root"));
801
789
  const s = e._prevVNode ?? null, i = e._prevDom ?? e.firstChild ?? null;
802
790
  let a;
803
- s && i ? typeof s != "string" && typeof o != "string" && s.tag === o.tag && s.key === o.key ? a = te(i, s, o, r, n) : (a = O(o, r, n), e.replaceChild(a, i)) : (a = O(o, r, n), e.firstChild ? e.replaceChild(a, e.firstChild) : e.appendChild(a));
804
- const c = [];
805
- for (let u = 0; u < e.childNodes.length; u++) {
806
- const l = e.childNodes[u];
807
- l !== a && l.nodeName !== "STYLE" && (H(l, n), c.push(l));
791
+ s && i ? typeof s != "string" && typeof n != "string" && s.tag === n.tag && s.key === n.key ? a = X(i, s, n, r, o) : (a = P(n, r, o), e.replaceChild(a, i)) : (a = P(n, r, o), e.firstChild ? e.replaceChild(a, e.firstChild) : e.appendChild(a));
792
+ const l = [];
793
+ for (let f = 0; f < e.childNodes.length; f++) {
794
+ const p = e.childNodes[f];
795
+ p !== a && p.nodeName !== "STYLE" && (q(p, o), l.push(p));
808
796
  }
809
- c.forEach((u) => e.removeChild(u)), e._prevVNode = o, e._prevDom = a;
797
+ l.forEach((f) => e.removeChild(f)), e._prevVNode = n, e._prevDom = a;
810
798
  }
811
- function Le(e, ...t) {
799
+ function je(e, ...t) {
812
800
  let r = "";
813
- for (let n = 0; n < e.length; n++)
814
- r += e[n], n < t.length && (r += t[n]);
801
+ for (let o = 0; o < e.length; o++)
802
+ r += e[o], o < t.length && (r += t[o]);
815
803
  return r;
816
804
  }
817
- function ze(e) {
805
+ function Le(e) {
818
806
  return e.replace(/\/\*[\s\S]*?\*\//g, "").replace(/\s+/g, " ").replace(/\s*([{}:;,>+~])\s*/g, "$1").replace(/;}/g, "}").trim();
819
807
  }
820
808
  let Y = null;
821
- function $e() {
822
- return Y || (Y = new CSSStyleSheet(), Y.replaceSync(ze(Xe))), Y;
809
+ function ke() {
810
+ return Y || (Y = new CSSStyleSheet(), Y.replaceSync(Le(Ye))), Y;
823
811
  }
824
- function Qe(e) {
812
+ function Ze(e) {
825
813
  return e.replace(/url\s*\(\s*['"]?javascript:[^)]*\)/gi, "").replace(/<script[\s\S]*?>[\s\S]*?<\/script>/gi, "").replace(/expression\s*\([^)]*\)/gi, "");
826
814
  }
827
- const Xe = Le`
815
+ const Ye = je`
828
816
  :host, *, ::before, ::after {
829
817
  all: isolate;
830
818
  box-sizing: border-box;
@@ -882,7 +870,7 @@ const Xe = Le`
882
870
  sup { top: -.5em }
883
871
  [disabled], [aria-disabled=true] { cursor: not-allowed }
884
872
  [hidden] { display: none }
885
- `, Ye = {
873
+ `, Qe = {
886
874
  gray: {
887
875
  50: "var(--color-gray-50, #f9fafb)",
888
876
  100: "var(--color-gray-100, #f3f4f6)",
@@ -1017,7 +1005,7 @@ const Xe = Le`
1017
1005
  },
1018
1006
  white: { DEFAULT: "var(--color-white, #ffffff)" },
1019
1007
  black: { DEFAULT: "var(--color-black, #000000)" }
1020
- }, le = {
1008
+ }, se = {
1021
1009
  /* Display */
1022
1010
  block: "display:block;",
1023
1011
  inline: "display:inline;",
@@ -1198,7 +1186,7 @@ const Xe = Le`
1198
1186
  "z-30": "z-index:30;",
1199
1187
  "z-40": "z-index:40;",
1200
1188
  "z-50": "z-index:50;"
1201
- }, Ge = "0.25rem", Se = {
1189
+ }, Xe = "0.25rem", $e = {
1202
1190
  m: ["margin"],
1203
1191
  mx: ["margin-inline"],
1204
1192
  my: ["margin-block"],
@@ -1230,34 +1218,34 @@ const Xe = Le`
1230
1218
  "gap-x": ["column-gap"],
1231
1219
  "gap-y": ["row-gap"]
1232
1220
  };
1233
- function R(e, t) {
1234
- let r = 0, n = 0;
1235
- for (let o = 0; o < e.length; o++) {
1236
- const s = e[o];
1221
+ function B(e, t) {
1222
+ let r = 0, o = 0;
1223
+ for (let n = 0; n < e.length; n++) {
1224
+ const s = e[n];
1237
1225
  if (s === "[") r++;
1238
1226
  else if (s === "]" && r > 0) r--;
1239
- else if (s === "(") n++;
1240
- else if (s === ")" && n > 0) n--;
1241
- else if (r === 0 && n === 0 && (s === ">" || s === "+" || s === "~" || s === " "))
1242
- return e.slice(0, o) + t + e.slice(o);
1227
+ else if (s === "(") o++;
1228
+ else if (s === ")" && o > 0) o--;
1229
+ else if (r === 0 && o === 0 && (s === ">" || s === "+" || s === "~" || s === " "))
1230
+ return e.slice(0, n) + t + e.slice(n);
1243
1231
  }
1244
1232
  return e + t;
1245
1233
  }
1246
- const et = {
1234
+ const Ge = {
1247
1235
  before: (e, t) => `${e}::before{${t}}`,
1248
1236
  after: (e, t) => `${e}::after{${t}}`,
1249
- hover: (e, t) => `${R(e, ":hover")}{${t}}`,
1250
- focus: (e, t) => `${R(e, ":focus")}{${t}}`,
1251
- active: (e, t) => `${R(e, ":active")}{${t}}`,
1252
- disabled: (e, t) => `${R(e, ":disabled")}{${t}}`,
1253
- visited: (e, t) => `${R(e, ":visited")}{${t}}`,
1254
- checked: (e, t) => `${R(e, ":checked")}{${t}}`,
1255
- first: (e, t) => `${R(e, ":first-child")}{${t}}`,
1256
- last: (e, t) => `${R(e, ":last-child")}{${t}}`,
1257
- odd: (e, t) => `${R(e, ":nth-child(odd)")}{${t}}`,
1258
- even: (e, t) => `${R(e, ":nth-child(even)")}{${t}}`,
1259
- "focus-within": (e, t) => `${R(e, ":focus-within")}{${t}}`,
1260
- "focus-visible": (e, t) => `${R(e, ":focus-visible")}{${t}}`,
1237
+ hover: (e, t) => `${B(e, ":hover")}{${t}}`,
1238
+ focus: (e, t) => `${B(e, ":focus")}{${t}}`,
1239
+ active: (e, t) => `${B(e, ":active")}{${t}}`,
1240
+ disabled: (e, t) => `${B(e, ":disabled")}{${t}}`,
1241
+ visited: (e, t) => `${B(e, ":visited")}{${t}}`,
1242
+ checked: (e, t) => `${B(e, ":checked")}{${t}}`,
1243
+ first: (e, t) => `${B(e, ":first-child")}{${t}}`,
1244
+ last: (e, t) => `${B(e, ":last-child")}{${t}}`,
1245
+ odd: (e, t) => `${B(e, ":nth-child(odd)")}{${t}}`,
1246
+ even: (e, t) => `${B(e, ":nth-child(even)")}{${t}}`,
1247
+ "focus-within": (e, t) => `${B(e, ":focus-within")}{${t}}`,
1248
+ "focus-visible": (e, t) => `${B(e, ":focus-visible")}{${t}}`,
1261
1249
  "group-hover": (e, t) => `.group:hover ${e}{${t}}`,
1262
1250
  "group-focus": (e, t) => `.group:focus ${e}{${t}}`,
1263
1251
  "group-active": (e, t) => `.group:active ${e}{${t}}`,
@@ -1266,7 +1254,7 @@ const et = {
1266
1254
  "peer-focus": (e, t) => `.peer:focus ~ ${e}{${t}}`,
1267
1255
  "peer-checked": (e, t) => `.peer:checked ~ ${e}{${t}}`,
1268
1256
  "peer-disabled": (e, t) => `.peer:disabled ~ ${e}{${t}}`
1269
- }, ce = {
1257
+ }, ae = {
1270
1258
  // Responsive
1271
1259
  sm: "(min-width:640px)",
1272
1260
  md: "(min-width:768px)",
@@ -1275,23 +1263,23 @@ const et = {
1275
1263
  "2xl": "(min-width:1536px)",
1276
1264
  // Dark mode (now plain string)
1277
1265
  dark: "(prefers-color-scheme: dark)"
1278
- }, fe = ["sm", "md", "lg", "xl", "2xl"];
1279
- function ue(e) {
1280
- const t = e.startsWith("-"), n = (t ? e.slice(1) : e).split("-");
1281
- if (n.length < 2) return null;
1282
- const o = n.slice(0, -1).join("-"), s = n[n.length - 1], i = parseFloat(s);
1283
- if (Number.isNaN(i) || !Se[o]) return null;
1266
+ }, ce = ["sm", "md", "lg", "xl", "2xl"];
1267
+ function le(e) {
1268
+ const t = e.startsWith("-"), o = (t ? e.slice(1) : e).split("-");
1269
+ if (o.length < 2) return null;
1270
+ const n = o.slice(0, -1).join("-"), s = o[o.length - 1], i = parseFloat(s);
1271
+ if (Number.isNaN(i) || !$e[n]) return null;
1284
1272
  const a = t ? "-" : "";
1285
- return Se[o].map((c) => `${c}:calc(${a}${Ge} * ${i});`).join("");
1273
+ return $e[n].map((l) => `${l}:calc(${a}${Xe} * ${i});`).join("");
1286
1274
  }
1287
- function _e(e) {
1288
- const t = e.replace("#", ""), r = parseInt(t, 16), n = r >> 16 & 255, o = r >> 8 & 255, s = r & 255;
1289
- return `${n} ${o} ${s}`;
1275
+ function Se(e) {
1276
+ const t = e.replace("#", ""), r = parseInt(t, 16), o = r >> 16 & 255, n = r >> 8 & 255, s = r & 255;
1277
+ return `${o} ${n} ${s}`;
1290
1278
  }
1291
- function tt(e) {
1279
+ function et(e) {
1292
1280
  const t = /^(bg|text|border|decoration|shadow|outline|caret|accent|fill|stroke)-([a-z]+)-?(\d{2,3}|DEFAULT)?$/.exec(e);
1293
1281
  if (!t) return null;
1294
- const [, r, n, o = "DEFAULT"] = t, s = Ye[n]?.[o];
1282
+ const [, r, o, n = "DEFAULT"] = t, s = Qe[o]?.[n];
1295
1283
  return s ? `${{
1296
1284
  bg: "background-color",
1297
1285
  decoration: "text-decoration-color",
@@ -1306,55 +1294,55 @@ function tt(e) {
1306
1294
  stroke: "stroke-color"
1307
1295
  }[r]}:${s};` : null;
1308
1296
  }
1309
- function rt(e) {
1297
+ function tt(e) {
1310
1298
  const [t, r] = e.split("/");
1311
1299
  if (!r) return { base: t };
1312
- const n = parseInt(r, 10);
1313
- return isNaN(n) || n < 0 || n > 100 ? { base: t } : { base: t, opacity: n / 100 };
1300
+ const o = parseInt(r, 10);
1301
+ return isNaN(o) || o < 0 || o > 100 ? { base: t } : { base: t, opacity: o / 100 };
1314
1302
  }
1315
- function de(e) {
1316
- const { base: t, opacity: r } = rt(e), n = tt(t);
1317
- if (n) {
1303
+ function fe(e) {
1304
+ const { base: t, opacity: r } = tt(e), o = et(t);
1305
+ if (o) {
1318
1306
  if (r !== void 0) {
1319
- const s = /#([0-9a-f]{6})/i.exec(n);
1307
+ const s = /#([0-9a-f]{6})/i.exec(o);
1320
1308
  if (s) {
1321
- const i = _e(s[0]);
1322
- return n.replace(/#([0-9a-f]{6})/i, `rgb(${i} / ${r})`);
1309
+ const i = Se(s[0]);
1310
+ return o.replace(/#([0-9a-f]{6})/i, `rgb(${i} / ${r})`);
1323
1311
  }
1324
1312
  }
1325
- return n;
1313
+ return o;
1326
1314
  }
1327
- const o = re(t);
1328
- if (o && r !== void 0) {
1329
- const s = /#([0-9a-f]{6})/i.exec(o);
1315
+ const n = G(t);
1316
+ if (n && r !== void 0) {
1317
+ const s = /#([0-9a-f]{6})/i.exec(n);
1330
1318
  if (s) {
1331
- const i = _e(s[0]);
1332
- return o.replace(/#([0-9a-f]{6})/i, `rgb(${i} / ${r})`);
1319
+ const i = Se(s[0]);
1320
+ return n.replace(/#([0-9a-f]{6})/i, `rgb(${i} / ${r})`);
1333
1321
  }
1334
1322
  }
1335
- return o;
1323
+ return n;
1336
1324
  }
1337
- function pe(e) {
1325
+ function ue(e) {
1338
1326
  const t = /^opacity-(\d{1,3})$/.exec(e);
1339
1327
  if (!t) return null;
1340
1328
  const r = parseInt(t[1], 10);
1341
1329
  return r < 0 || r > 100 ? null : `opacity:${r / 100};`;
1342
1330
  }
1343
- function re(e) {
1331
+ function G(e) {
1344
1332
  if (e.startsWith("[") && e.endsWith("]") && !e.includes("-[")) {
1345
- const o = e.slice(1, -1).trim().match(/^([a-zA-Z][a-zA-Z0-9-]*)\s*:(.*)$/);
1346
- if (o) {
1347
- const s = o[1].trim();
1348
- let i = o[2].trim();
1333
+ const n = e.slice(1, -1).trim().match(/^([a-zA-Z][a-zA-Z0-9-]*)\s*:(.*)$/);
1334
+ if (n) {
1335
+ const s = n[1].trim();
1336
+ let i = n[2].trim();
1349
1337
  return i = i.replace(/url\('\s*([^']*?)\s*'\)/g, 'url("$1")'), i = i.replace(/^'([^']*)'$/g, '"$1"'), `${s}:${i};`;
1350
1338
  }
1351
1339
  return null;
1352
1340
  }
1353
1341
  const t = e.indexOf("-["), r = e.endsWith("]");
1354
1342
  if (t > 0 && r) {
1355
- const n = e.slice(0, t);
1356
- let o = e.slice(t + 2, -1);
1357
- o = o.replace(/_/g, " ");
1343
+ const o = e.slice(0, t);
1344
+ let n = e.slice(t + 2, -1);
1345
+ n = n.replace(/_/g, " ");
1358
1346
  const s = {
1359
1347
  bg: "background-color",
1360
1348
  text: "color",
@@ -1395,14 +1383,14 @@ function re(e) {
1395
1383
  leading: "line-height",
1396
1384
  z: "z-index"
1397
1385
  };
1398
- if (n === "rotate")
1399
- return `transform:rotate(${o});`;
1400
- const i = s[n] ?? n.replace(/_/g, "-");
1401
- if (i && o) return `${i}:${o};`;
1386
+ if (o === "rotate")
1387
+ return `transform:rotate(${n});`;
1388
+ const i = s[o] ?? o.replace(/_/g, "-");
1389
+ if (i && n) return `${i}:${n};`;
1402
1390
  }
1403
1391
  return null;
1404
1392
  }
1405
- function nt(e) {
1393
+ function rt(e) {
1406
1394
  if (e.startsWith("[") && e.endsWith("]")) {
1407
1395
  const r = e.slice(1, -1);
1408
1396
  return r.includes("&") ? r : e;
@@ -1414,44 +1402,44 @@ function nt(e) {
1414
1402
  }
1415
1403
  return null;
1416
1404
  }
1417
- function ot(e) {
1405
+ function nt(e) {
1418
1406
  return e.replace(/([!"#$%&'()*+,./:;<=>?@[\\\]^`{|}~])/g, "\\$1");
1419
1407
  }
1420
- function it(e) {
1408
+ function ot(e) {
1421
1409
  const t = /class\s*=\s*(['"])(.*?)\1/g, r = [];
1422
- let n;
1423
- for (; n = t.exec(e); ) {
1424
- const o = n[2].split(/\s+/).filter(Boolean);
1425
- o.length && r.push(...o);
1410
+ let o;
1411
+ for (; o = t.exec(e); ) {
1412
+ const n = o[2].split(/\s+/).filter(Boolean);
1413
+ n.length && r.push(...n);
1426
1414
  }
1427
1415
  return r.filter(Boolean);
1428
1416
  }
1429
- const Ce = /* @__PURE__ */ new Map(), st = 16;
1430
- function at(e) {
1431
- const t = Date.now(), r = Ce.get(e);
1432
- if (r && t - r.timestamp < st) return r.css;
1433
- const n = it(e), o = new Set(n), s = [], i = [], a = [], c = [], u = {};
1434
- function l(p, f = !1) {
1435
- const g = (f ? "dark|" : "") + p;
1436
- if (g in u) return u[g];
1437
- const m = k(p, f);
1438
- return u[g] = m, m;
1439
- }
1440
- function y(p) {
1441
- const f = p.some((m) => fe.includes(m)), g = p.includes("dark");
1442
- return p.length === 0 ? 1 : !f && !g ? 2 : f && !g ? 3 : 4;
1443
- }
1444
- function d(p) {
1445
- const f = [];
1446
- let g = "", m = 0, h = 0;
1447
- for (let w = 0; w < p.length; w++) {
1448
- const v = p[w];
1449
- v === "[" ? m++ : v === "]" && m > 0 ? m-- : v === "(" ? h++ : v === ")" && h > 0 && h--, v === ":" && m === 0 && h === 0 ? (f.push(g), g = "") : g += v;
1417
+ const _e = /* @__PURE__ */ new Map(), it = 16;
1418
+ function st(e) {
1419
+ const t = Date.now(), r = _e.get(e);
1420
+ if (r && t - r.timestamp < it) return r.css;
1421
+ const o = ot(e), n = new Set(o), s = [], i = [], a = [], l = [], f = {};
1422
+ function p(h, u = !1) {
1423
+ const g = (u ? "dark|" : "") + h;
1424
+ if (g in f) return f[g];
1425
+ const b = x(h, u);
1426
+ return f[g] = b, b;
1427
+ }
1428
+ function y(h) {
1429
+ const u = h.some((b) => ce.includes(b)), g = h.includes("dark");
1430
+ return h.length === 0 ? 1 : !u && !g ? 2 : u && !g ? 3 : 4;
1431
+ }
1432
+ function c(h) {
1433
+ const u = [];
1434
+ let g = "", b = 0, d = 0;
1435
+ for (let v = 0; v < h.length; v++) {
1436
+ const m = h[v];
1437
+ m === "[" ? b++ : m === "]" && b > 0 ? b-- : m === "(" ? d++ : m === ")" && d > 0 && d--, m === ":" && b === 0 && d === 0 ? (u.push(g), g = "") : g += m;
1450
1438
  }
1451
- return g && f.push(g), f;
1439
+ return g && u.push(g), u;
1452
1440
  }
1453
- function b(p) {
1454
- switch (p) {
1441
+ function w(h) {
1442
+ switch (h) {
1455
1443
  case "hover":
1456
1444
  return ":hover";
1457
1445
  case "focus":
@@ -1480,182 +1468,206 @@ function at(e) {
1480
1468
  return null;
1481
1469
  }
1482
1470
  }
1483
- function k(p, f = !1) {
1484
- const g = d(p);
1485
- (p.includes("mask-image") || p.includes("sm: hover") || p.includes("sm:hover") || p.includes("mask.svg")) && console.error("DEBUG generateRule:", p, g);
1486
- let m = !1, h = g.find((S) => (S.startsWith("!") && (m = !0, S = S.slice(1)), le[S] || ue(S) || pe(S) || de(S) || re(S)));
1487
- if (!h) return null;
1488
- const w = h.replace(/^!/, ""), v = le[w] ?? ue(w) ?? pe(w) ?? de(w) ?? re(w);
1489
- if (!v) return null;
1490
- const $ = g.indexOf(h);
1471
+ function x(h, u = !1) {
1472
+ const g = c(h);
1473
+ (h.includes("mask-image") || h.includes("sm: hover") || h.includes("sm:hover") || h.includes("mask.svg")) && console.error("DEBUG generateRule:", h, g);
1474
+ let b = !1, d = g.find((S) => (S.startsWith("!") && (b = !0, S = S.slice(1)), se[S] || le(S) || ue(S) || fe(S) || G(S)));
1475
+ if (!d) return null;
1476
+ const v = d.replace(/^!/, ""), m = se[v] ?? le(v) ?? ue(v) ?? fe(v) ?? G(v);
1477
+ if (!m) return null;
1478
+ const $ = g.indexOf(d);
1491
1479
  let _ = $ >= 0 ? g.slice(0, $) : [];
1492
- f && (_ = _.filter((S) => S !== "dark"));
1493
- const C = `.${ot(p)}`, E = "__SUBJECT__", j = m ? v.replace(/;$/, " !important;") : v;
1494
- let T = E;
1495
- const A = [];
1480
+ u && (_ = _.filter((S) => S !== "dark"));
1481
+ const C = `.${nt(h)}`, E = "__SUBJECT__", j = b ? m.replace(/;$/, " !important;") : m;
1482
+ let A = E;
1483
+ const re = [];
1496
1484
  for (const S of _)
1497
- S.startsWith("group-") ? (T = `.group:${S.slice(6)} ${T}`, A.push(S)) : S.startsWith("peer-") && (T = T.replace(E, `.peer:${S.slice(5)}~${E}`), A.push(S));
1498
- _ = _.filter((S) => !A.includes(S));
1499
- const q = [], ie = [];
1485
+ S.startsWith("group-") ? (A = `.group:${S.slice(6)} ${A}`, re.push(S)) : S.startsWith("peer-") && (A = A.replace(E, `.peer:${S.slice(5)}~${E}`), re.push(S));
1486
+ _ = _.filter((S) => !re.includes(S));
1487
+ const ne = [], be = [];
1500
1488
  let W = null;
1501
1489
  for (const S of _) {
1502
- if (S === "dark" || fe.includes(S)) continue;
1503
- const N = nt(S);
1504
- if (N) {
1505
- W = N;
1490
+ if (S === "dark" || ce.includes(S)) continue;
1491
+ const M = rt(S);
1492
+ if (M) {
1493
+ W = M;
1506
1494
  continue;
1507
1495
  }
1508
- const z = b(S);
1509
- if (z) {
1510
- W ? ie.push(z) : q.push(z);
1496
+ const L = w(S);
1497
+ if (L) {
1498
+ W ? be.push(L) : ne.push(L);
1511
1499
  continue;
1512
1500
  }
1513
- const B = et[S];
1514
- typeof B == "function" && (T = B(T, j).split("{")[0]);
1501
+ const R = Ge[S];
1502
+ typeof R == "function" && (A = R(A, j).split("{")[0]);
1515
1503
  }
1516
- function Pe(S, N) {
1517
- if (!N) return S;
1518
- let z = 0, B = 0;
1504
+ function ze(S, M) {
1505
+ if (!M) return S;
1506
+ let L = 0, R = 0;
1519
1507
  if (S.length && (S[0] === ">" || S[0] === "+" || S[0] === "~" || S[0] === " ")) {
1520
- let L = 1;
1521
- for (; L < S.length && S[L] === " "; ) L++;
1522
- for (; L < S.length; L++) {
1523
- const P = S[L];
1524
- if (P === "[" ? z++ : P === "]" && z > 0 ? z-- : P === "(" ? B++ : P === ")" && B > 0 && B--, z === 0 && B === 0 && (S[L] === ">" || S[L] === "+" || S[L] === "~" || S[L] === " "))
1525
- return S.slice(0, L) + N + S.slice(L);
1508
+ let T = 1;
1509
+ for (; T < S.length && S[T] === " "; ) T++;
1510
+ for (; T < S.length; T++) {
1511
+ const z = S[T];
1512
+ if (z === "[" ? L++ : z === "]" && L > 0 ? L-- : z === "(" ? R++ : z === ")" && R > 0 && R--, L === 0 && R === 0 && (S[T] === ">" || S[T] === "+" || S[T] === "~" || S[T] === " "))
1513
+ return S.slice(0, T) + M + S.slice(T);
1526
1514
  }
1527
- return S + N;
1515
+ return S + M;
1528
1516
  }
1529
- for (let L = 0; L < S.length; L++) {
1530
- const P = S[L];
1531
- if (P === "[" ? z++ : P === "]" && z > 0 ? z-- : P === "(" ? B++ : P === ")" && B > 0 && B--, z === 0 && B === 0 && (P === ">" || P === "+" || P === "~" || P === " "))
1532
- return S.slice(0, L) + N + S.slice(L);
1517
+ for (let T = 0; T < S.length; T++) {
1518
+ const z = S[T];
1519
+ if (z === "[" ? L++ : z === "]" && L > 0 ? L-- : z === "(" ? R++ : z === ")" && R > 0 && R--, L === 0 && R === 0 && (z === ">" || z === "+" || z === "~" || z === " "))
1520
+ return S.slice(0, T) + M + S.slice(T);
1533
1521
  }
1534
- return S + N;
1522
+ return S + M;
1535
1523
  }
1536
- const se = q.join(""), J = ie.join("");
1524
+ const oe = ne.join(""), U = be.join("");
1537
1525
  if (W)
1538
1526
  if (W.includes("&")) {
1539
- const S = W.indexOf("&"), N = W.slice(0, S), z = W.slice(S + 1), B = E + se, L = T;
1540
- if (q.length === 0)
1541
- T = L.replace(E, N + B + J + z);
1527
+ const S = W.indexOf("&"), M = W.slice(0, S), L = W.slice(S + 1), R = E + oe, T = A;
1528
+ if (ne.length === 0)
1529
+ A = T.replace(E, M + R + U + L);
1542
1530
  else {
1543
- const P = Pe(z, J);
1544
- T = L.replace(E, N + B + P);
1531
+ const z = ze(L, U);
1532
+ A = T.replace(E, M + R + z);
1545
1533
  }
1546
1534
  } else
1547
- T = T.replace(E, `${W}${E + se}`), J && (T = T.replace(E, `${E}${J}`));
1535
+ A = A.replace(E, `${W}${E + oe}`), U && (A = A.replace(E, `${E}${U}`));
1548
1536
  else
1549
- T = E + se + J;
1550
- T = T.replace(new RegExp(E, "g"), C);
1551
- let M = `${T}{${j}}`;
1552
- const ae = _.filter((S) => fe.includes(S)), U = ae.length ? ae[ae.length - 1] : null, we = _.includes("dark");
1553
- return f && U ? M = `@media (prefers-color-scheme: dark) and ${ce[U]}{${M}}` : f ? M = `@media (prefers-color-scheme: dark){${M}}` : we && U ? M = `@media (prefers-color-scheme: dark) and ${ce[U]}{${M}}` : we ? M = `@media (prefers-color-scheme: dark){${M}}` : U && (M = `@media ${ce[U]}{${M}}`), M;
1554
- }
1555
- for (const p of o) {
1556
- const f = d(p), g = f.find(
1557
- (v) => le[v] || ue(v) || pe(v) || de(v) || re(v)
1537
+ A = E + oe + U;
1538
+ A = A.replace(new RegExp(E, "g"), C);
1539
+ let O = `${A}{${j}}`;
1540
+ const ie = _.filter((S) => ce.includes(S)), H = ie.length ? ie[ie.length - 1] : null, ve = _.includes("dark");
1541
+ return u && H ? O = `@media (prefers-color-scheme: dark) and ${ae[H]}{${O}}` : u ? O = `@media (prefers-color-scheme: dark){${O}}` : ve && H ? O = `@media (prefers-color-scheme: dark) and ${ae[H]}{${O}}` : ve ? O = `@media (prefers-color-scheme: dark){${O}}` : H && (O = `@media ${ae[H]}{${O}}`), O;
1542
+ }
1543
+ for (const h of n) {
1544
+ const u = c(h), g = u.find(
1545
+ (m) => se[m] || le(m) || ue(m) || fe(m) || G(m)
1558
1546
  );
1559
1547
  if (!g) continue;
1560
- const m = f.indexOf(g), h = m >= 0 ? f.slice(0, m) : [], w = y(h);
1561
- if (w === 4) {
1562
- const v = l(p, !0);
1563
- v && c.push(v);
1548
+ const b = u.indexOf(g), d = b >= 0 ? u.slice(0, b) : [], v = y(d);
1549
+ if (v === 4) {
1550
+ const m = p(h, !0);
1551
+ m && l.push(m);
1564
1552
  } else {
1565
- const v = l(p);
1566
- v && (w === 1 ? s.push(v) : w === 2 ? i.push(v) : w === 3 && a.push(v));
1553
+ const m = p(h);
1554
+ m && (v === 1 ? s.push(m) : v === 2 ? i.push(m) : v === 3 && a.push(m));
1567
1555
  }
1568
1556
  }
1569
- const x = [...s, ...i, ...a, ...c].join("");
1570
- return Ce.set(e, { css: x, timestamp: t }), x;
1557
+ const k = [...s, ...i, ...a, ...l].join("");
1558
+ return _e.set(e, { css: k, timestamp: t }), k;
1571
1559
  }
1572
- const Q = [];
1573
- function lt(e, t, r, n, o, s, i, a) {
1560
+ const J = [];
1561
+ function at(e, t, r, o, n, s, i, a) {
1574
1562
  if (e) {
1575
- Q.push(r);
1563
+ J.push(r);
1576
1564
  try {
1577
1565
  if (t.loadingTemplate && r.isLoading) {
1578
- F(e, t.loadingTemplate(r), r, n, o);
1566
+ F(e, t.loadingTemplate(r), r, o, n);
1579
1567
  return;
1580
1568
  }
1581
1569
  if (t.errorTemplate && r.hasError) {
1582
- r.error instanceof Error && F(e, t.errorTemplate(r.error, r), r, n, o);
1570
+ r.error instanceof Error && F(e, t.errorTemplate(r.error, r), r, o, n);
1583
1571
  return;
1584
1572
  }
1585
- const c = t.render(r);
1586
- if (c instanceof Promise) {
1587
- s(!0), c.then((u) => {
1588
- s(!1), i(null), F(e, u, r, n, o), a(e.innerHTML);
1589
- }).catch((u) => {
1590
- s(!1), i(u), t.errorTemplate && F(e, t.errorTemplate(u, r), r, n, o);
1591
- }), t.loadingTemplate && F(e, t.loadingTemplate(r), r, n, o);
1573
+ const l = t.render(r);
1574
+ if (l instanceof Promise) {
1575
+ s(!0), l.then((f) => {
1576
+ s(!1), i(null), F(e, f, r, o, n), a(e.innerHTML);
1577
+ }).catch((f) => {
1578
+ s(!1), i(f), t.errorTemplate && F(e, t.errorTemplate(f, r), r, o, n);
1579
+ }), t.loadingTemplate && F(e, t.loadingTemplate(r), r, o, n);
1592
1580
  return;
1593
1581
  }
1594
- F(e, c, r, n, o), a(e.innerHTML);
1582
+ F(e, l, r, o, n), a(e.innerHTML);
1595
1583
  } finally {
1596
- Q.pop();
1584
+ J.pop();
1597
1585
  }
1598
1586
  }
1599
1587
  }
1600
- function F(e, t, r, n, o) {
1601
- e && (Ze(
1588
+ function F(e, t, r, o, n) {
1589
+ e && (Je(
1602
1590
  e,
1603
1591
  Array.isArray(t) ? t : [t],
1604
1592
  r,
1605
- n
1606
- ), o(e.innerHTML));
1593
+ o
1594
+ ), n(e.innerHTML));
1607
1595
  }
1608
- function ct(e, t, r, n, o, s, i) {
1596
+ function ct(e, t, r, o, n, s, i) {
1609
1597
  if (s !== null && clearTimeout(s), Date.now() - t < 16) {
1610
- if (o(r + 1), r > 10) {
1598
+ if (n(r + 1), r > 10) {
1611
1599
  console.warn("Potential infinite render loop detected. Skipping render."), i(null);
1612
1600
  return;
1613
1601
  }
1614
1602
  } else
1615
- o(0);
1616
- const c = setTimeout(() => {
1617
- n(Date.now()), e(), i(null);
1603
+ n(0);
1604
+ const l = setTimeout(() => {
1605
+ o(Date.now()), e(), i(null);
1618
1606
  }, 0);
1619
- i(c);
1607
+ i(l);
1620
1608
  }
1621
- function ft(e, t, r, n, o, s) {
1609
+ function lt(e, t, r, o, n, s) {
1622
1610
  if (!e) return;
1623
- const i = at(n);
1611
+ const i = st(o);
1624
1612
  if (!t.style && (!i || i.trim() === "")) {
1625
- s(null), e.adoptedStyleSheets = [$e()];
1613
+ s(null), e.adoptedStyleSheets = [ke()];
1626
1614
  return;
1627
1615
  }
1628
1616
  let a = "";
1629
1617
  t.style && (typeof t.style == "string" ? a = t.style : typeof t.style == "function" && (a = t.style(r)));
1630
- let c = Qe(`${a}
1618
+ let l = Ze(`${a}
1631
1619
  ${i}
1632
1620
  `);
1633
- c = ze(c);
1634
- let u = o;
1635
- u || (u = new CSSStyleSheet()), (u.cssRules.length === 0 || u.toString() !== c) && u.replaceSync(c), e.adoptedStyleSheets = [$e(), u], s(u);
1636
- }
1637
- const be = /* @__PURE__ */ new Map();
1638
- function Ee(e, t, r) {
1639
- let n = ve(e);
1640
- n.includes("-") || (n = `cer-${n}`);
1641
- let o;
1642
- if (typeof t == "function" ? o = { ...r, render: t } : o = t, typeof o.onError != "function" && (o.onError = (s, i) => {
1643
- console.error(`[${n}] Error:`, s, i);
1644
- }), be.set(n, o), typeof window < "u")
1645
- if (!customElements.get(n))
1646
- customElements.define(n, ut(n, o));
1621
+ l = Le(l);
1622
+ let f = n;
1623
+ f || (f = new CSSStyleSheet()), (f.cssRules.length === 0 || f.toString() !== l) && f.replaceSync(l), e.adoptedStyleSheets = [ke(), f], s(f);
1624
+ }
1625
+ const ye = /* @__PURE__ */ new Map();
1626
+ function Ce(e, t, r) {
1627
+ let o = me(e);
1628
+ o.includes("-") || (o = `cer-${o}`);
1629
+ let n;
1630
+ typeof t == "function" ? n = { ...r, render: t } : n = t, typeof n.onError != "function" && (n.onError = (s, i) => {
1631
+ console.error(`[${o}] Error:`, s, i);
1632
+ });
1633
+ try {
1634
+ const s = /* @__PURE__ */ new Set([
1635
+ "refs",
1636
+ "requestRender",
1637
+ "error",
1638
+ "hasError",
1639
+ "isLoading",
1640
+ "emit"
1641
+ ]), i = [];
1642
+ if (n.state && typeof n.state == "object" && Object.keys(n.state).forEach((a) => {
1643
+ s.has(a) && i.push(a);
1644
+ }), n.props && typeof n.props == "object" && Object.keys(n.props).forEach((a) => {
1645
+ s.has(a) && i.push(a);
1646
+ }), n.computed && typeof n.computed == "object" && Object.keys(n.computed).forEach((a) => {
1647
+ s.has(a) && i.push(a);
1648
+ }), i.length > 0) {
1649
+ const a = Array.from(new Set(i));
1650
+ console.warn(
1651
+ `[${o}] Reserved runtime context keys used in component config: ${a.join(", ")}. These names are provided by the runtime (for example: refs, error, emit). Rename your state/prop/computed keys (e.g. 'error' -> 'errorMessage') to avoid collisions and TypeScript type conflicts.`
1652
+ );
1653
+ }
1654
+ } catch {
1655
+ }
1656
+ if (ye.set(o, n), typeof window < "u")
1657
+ if (!customElements.get(o))
1658
+ customElements.define(o, ft(o, n));
1647
1659
  else
1648
1660
  try {
1649
- document.querySelectorAll(n).forEach((s) => {
1661
+ document.querySelectorAll(o).forEach((s) => {
1650
1662
  try {
1651
- typeof s._cfg < "u" && (s._cfg = o), typeof s._render == "function" && s._render(o);
1663
+ typeof s._cfg < "u" && (s._cfg = n), typeof s._render == "function" && s._render(n);
1652
1664
  } catch {
1653
1665
  }
1654
1666
  });
1655
1667
  } catch {
1656
1668
  }
1657
1669
  }
1658
- function ut(e, t) {
1670
+ function ft(e, t) {
1659
1671
  if (!t.render)
1660
1672
  throw new Error(
1661
1673
  "Component must have a render function"
@@ -1699,7 +1711,7 @@ function ut(e, t) {
1699
1711
  _templateLoading = !1;
1700
1712
  _templateError = null;
1701
1713
  constructor() {
1702
- super(), this.attachShadow({ mode: "open" }), this._cfg = be.get(e) || t;
1714
+ super(), this.attachShadow({ mode: "open" }), this._cfg = ye.get(e) || t;
1703
1715
  const r = this._initContext(t);
1704
1716
  Object.defineProperty(r, "refs", {
1705
1717
  value: this._refs,
@@ -1712,8 +1724,8 @@ function ut(e, t) {
1712
1724
  enumerable: !1,
1713
1725
  configurable: !1
1714
1726
  }), this.context = r, this._applyProps(t), Object.defineProperty(this.context, "emit", {
1715
- value: (o, s, i) => {
1716
- const a = new CustomEvent(o, {
1727
+ value: (n, s, i) => {
1728
+ const a = new CustomEvent(n, {
1717
1729
  detail: s,
1718
1730
  bubbles: !0,
1719
1731
  composed: !0,
@@ -1725,15 +1737,15 @@ function ut(e, t) {
1725
1737
  enumerable: !1,
1726
1738
  configurable: !1
1727
1739
  });
1728
- const n = be.get(e) || t;
1729
- Object.keys(n).forEach((o) => {
1730
- const s = n[o];
1731
- typeof s == "function" && (this.context[o] = (...i) => s(...i, this.context));
1732
- }), this._applyComputed(n), this._initializing = !1, this._initWatchers(n), this._render(n);
1740
+ const o = ye.get(e) || t;
1741
+ Object.keys(o).forEach((n) => {
1742
+ const s = o[n];
1743
+ typeof s == "function" && (this.context[n] = (...i) => s(...i, this.context));
1744
+ }), this._applyComputed(o), this._initializing = !1, this._initWatchers(o), this._render(o);
1733
1745
  }
1734
1746
  connectedCallback() {
1735
1747
  this._runLogicWithinErrorBoundary(t, () => {
1736
- We(
1748
+ Ne(
1737
1749
  t,
1738
1750
  this.context,
1739
1751
  this._mounted,
@@ -1745,7 +1757,7 @@ function ut(e, t) {
1745
1757
  }
1746
1758
  disconnectedCallback() {
1747
1759
  this._runLogicWithinErrorBoundary(t, () => {
1748
- De(
1760
+ We(
1749
1761
  t,
1750
1762
  this.context,
1751
1763
  this._listeners,
@@ -1767,27 +1779,27 @@ function ut(e, t) {
1767
1779
  );
1768
1780
  });
1769
1781
  }
1770
- attributeChangedCallback(r, n, o) {
1782
+ attributeChangedCallback(r, o, n) {
1771
1783
  this._runLogicWithinErrorBoundary(t, () => {
1772
- this._applyProps(t), qe(
1784
+ this._applyProps(t), De(
1773
1785
  t,
1774
1786
  r,
1775
- n,
1776
1787
  o,
1788
+ n,
1777
1789
  this.context
1778
1790
  );
1779
1791
  });
1780
1792
  }
1781
1793
  static get observedAttributes() {
1782
- return t.props ? Object.keys(t.props).map(ve) : [];
1794
+ return t.props ? Object.keys(t.props).map(me) : [];
1783
1795
  }
1784
1796
  _applyComputed(r) {
1785
1797
  this._runLogicWithinErrorBoundary(t, () => {
1786
- r.computed && Object.entries(r.computed).forEach(([n, o]) => {
1787
- Object.defineProperty(this.context, n, {
1798
+ r.computed && Object.entries(r.computed).forEach(([o, n]) => {
1799
+ Object.defineProperty(this.context, o, {
1788
1800
  get: () => {
1789
- const s = o(this.context);
1790
- return ge(s);
1801
+ const s = n(this.context);
1802
+ return pe(s);
1791
1803
  },
1792
1804
  enumerable: !0
1793
1805
  });
@@ -1797,21 +1809,21 @@ function ut(e, t) {
1797
1809
  // --- Render ---
1798
1810
  _render(r) {
1799
1811
  this._runLogicWithinErrorBoundary(r, () => {
1800
- lt(
1812
+ at(
1801
1813
  this.shadowRoot,
1802
1814
  r,
1803
1815
  this.context,
1804
1816
  this._refs,
1805
- (n) => {
1806
- this._lastHtmlStringForJitCSS = n, typeof this.onHtmlStringUpdate == "function" && this.onHtmlStringUpdate(n);
1817
+ (o) => {
1818
+ this._lastHtmlStringForJitCSS = o, typeof this.onHtmlStringUpdate == "function" && this.onHtmlStringUpdate(o);
1807
1819
  },
1808
- (n) => {
1809
- this._templateLoading = n, typeof this.onLoadingStateChange == "function" && this.onLoadingStateChange(n);
1820
+ (o) => {
1821
+ this._templateLoading = o, typeof this.onLoadingStateChange == "function" && this.onLoadingStateChange(o);
1810
1822
  },
1811
- (n) => {
1812
- this._templateError = n, typeof this.onErrorStateChange == "function" && this.onErrorStateChange(n);
1823
+ (o) => {
1824
+ this._templateError = o, typeof this.onErrorStateChange == "function" && this.onErrorStateChange(o);
1813
1825
  },
1814
- (n) => this._applyStyle(r, n)
1826
+ (o) => this._applyStyle(r, o)
1815
1827
  );
1816
1828
  });
1817
1829
  }
@@ -1838,28 +1850,28 @@ function ut(e, t) {
1838
1850
  });
1839
1851
  }
1840
1852
  // --- Style ---
1841
- _applyStyle(r, n) {
1853
+ _applyStyle(r, o) {
1842
1854
  this._runLogicWithinErrorBoundary(r, () => {
1843
- ft(
1855
+ lt(
1844
1856
  this.shadowRoot,
1845
1857
  r,
1846
1858
  this.context,
1847
- n,
1859
+ o,
1848
1860
  this._styleSheet,
1849
- (o) => {
1850
- this._styleSheet = o;
1861
+ (n) => {
1862
+ this._styleSheet = n;
1851
1863
  }
1852
1864
  );
1853
1865
  });
1854
1866
  }
1855
1867
  // --- Error Boundary function ---
1856
- _runLogicWithinErrorBoundary(r, n) {
1868
+ _runLogicWithinErrorBoundary(r, o) {
1857
1869
  this._hasError && (this._hasError = !1);
1858
1870
  try {
1859
- n();
1860
- } catch (o) {
1861
- this._hasError = !0, r.onError && r.onError(o, this.context), r.errorFallback && this.shadowRoot && (this.shadowRoot.innerHTML = r.errorFallback(
1862
- o,
1871
+ o();
1872
+ } catch (n) {
1873
+ this._hasError = !0, r.onError && r.onError(n, this.context), r.errorFallback && this.shadowRoot && (this.shadowRoot.innerHTML = r.errorFallback(
1874
+ n,
1863
1875
  this.context
1864
1876
  ));
1865
1877
  }
@@ -1867,11 +1879,11 @@ function ut(e, t) {
1867
1879
  // --- State, props, computed ---
1868
1880
  _initContext(r) {
1869
1881
  try {
1870
- let n = function(s, i = "") {
1882
+ let o = function(s, i = "") {
1871
1883
  return Array.isArray(s) ? new Proxy(s, {
1872
- get(a, c, u) {
1873
- const l = Reflect.get(a, c, u);
1874
- return typeof l == "function" && typeof c == "string" && [
1884
+ get(a, l, f) {
1885
+ const p = Reflect.get(a, l, f);
1886
+ return typeof p == "function" && typeof l == "string" && [
1875
1887
  "push",
1876
1888
  "pop",
1877
1889
  "shift",
@@ -1879,213 +1891,168 @@ function ut(e, t) {
1879
1891
  "splice",
1880
1892
  "sort",
1881
1893
  "reverse"
1882
- ].includes(c) ? function(...d) {
1883
- const b = l.apply(a, d);
1884
- if (!o._initializing) {
1885
- const k = i || "root";
1886
- o._triggerWatchers(k, a), o._render(r);
1894
+ ].includes(l) ? function(...c) {
1895
+ const w = p.apply(a, c);
1896
+ if (!n._initializing) {
1897
+ const x = i || "root";
1898
+ n._triggerWatchers(x, a), n._render(r);
1887
1899
  }
1888
- return b;
1889
- } : l;
1900
+ return w;
1901
+ } : p;
1890
1902
  },
1891
- set(a, c, u) {
1892
- if (a[c] = u, !o._initializing) {
1893
- const l = i ? `${i}.${String(c)}` : String(c);
1894
- o._triggerWatchers(l, u), o._render(r);
1903
+ set(a, l, f) {
1904
+ if (a[l] = f, !n._initializing) {
1905
+ const p = i ? `${i}.${String(l)}` : String(l);
1906
+ n._triggerWatchers(p, f), n._render(r);
1895
1907
  }
1896
1908
  return !0;
1897
1909
  },
1898
- deleteProperty(a, c) {
1899
- if (delete a[c], !o._initializing) {
1900
- const u = i ? `${i}.${String(c)}` : String(c);
1901
- o._triggerWatchers(u, void 0), o._render(r);
1910
+ deleteProperty(a, l) {
1911
+ if (delete a[l], !n._initializing) {
1912
+ const f = i ? `${i}.${String(l)}` : String(l);
1913
+ n._triggerWatchers(f, void 0), n._render(r);
1902
1914
  }
1903
1915
  return !0;
1904
1916
  }
1905
1917
  }) : s && typeof s == "object" ? (Object.keys(s).forEach((a) => {
1906
- const c = i ? `${i}.${a}` : a;
1907
- s[a] = n(s[a], c);
1918
+ const l = i ? `${i}.${a}` : a;
1919
+ s[a] = o(s[a], l);
1908
1920
  }), new Proxy(s, {
1909
- set(a, c, u) {
1910
- const l = i ? `${i}.${String(c)}` : String(c);
1911
- return a[c] = n(u, l), o._initializing || (o._triggerWatchers(
1912
- l,
1913
- a[c]
1914
- ), o._render(r)), !0;
1921
+ set(a, l, f) {
1922
+ const p = i ? `${i}.${String(l)}` : String(l);
1923
+ return a[l] = o(f, p), n._initializing || (n._triggerWatchers(
1924
+ p,
1925
+ a[l]
1926
+ ), n._render(r)), !0;
1915
1927
  },
1916
- get(a, c, u) {
1917
- return Reflect.get(a, c, u);
1928
+ get(a, l, f) {
1929
+ return Reflect.get(a, l, f);
1918
1930
  }
1919
1931
  })) : s;
1920
1932
  };
1921
- const o = this;
1922
- return n({ ...r.state });
1933
+ const n = this;
1934
+ return o({ ...r.state });
1923
1935
  } catch {
1924
1936
  return {};
1925
1937
  }
1926
1938
  }
1927
1939
  _initWatchers(r) {
1928
1940
  this._runLogicWithinErrorBoundary(r, () => {
1929
- Oe(
1941
+ Pe(
1930
1942
  this.context,
1931
1943
  this._watchers,
1932
1944
  r.watch || {}
1933
1945
  );
1934
1946
  });
1935
1947
  }
1936
- _triggerWatchers(r, n) {
1937
- Me(this.context, this._watchers, r, n);
1948
+ _triggerWatchers(r, o) {
1949
+ Oe(this.context, this._watchers, r, o);
1938
1950
  }
1939
1951
  _applyProps(r) {
1940
1952
  this._runLogicWithinErrorBoundary(r, () => {
1941
1953
  try {
1942
- Ne(this, r, this.context);
1943
- } catch (n) {
1944
- this._hasError = !0, r.onError && r.onError(n, this.context), r.errorFallback && this.shadowRoot && (this.shadowRoot.innerHTML = r.errorFallback(n, this.context));
1954
+ Me(this, r, this.context);
1955
+ } catch (o) {
1956
+ this._hasError = !0, r.onError && r.onError(o, this.context), r.errorFallback && this.shadowRoot && (this.shadowRoot.innerHTML = r.errorFallback(o, this.context));
1945
1957
  }
1946
1958
  });
1947
1959
  }
1948
1960
  };
1949
1961
  }
1950
- function Z(e, t = {}, r, n) {
1951
- const o = n ?? t.key;
1952
- return { tag: e, key: o, props: t, children: r };
1962
+ function V(e, t = {}, r, o) {
1963
+ const n = o ?? t.key;
1964
+ return { tag: e, key: n, props: t, children: r };
1953
1965
  }
1954
- function ne(e) {
1966
+ function ee(e) {
1955
1967
  return !!e && typeof e == "object" && (e.type === "AnchorBlock" || e.tag === "#anchor");
1956
1968
  }
1957
- function G(e) {
1958
- return typeof e == "object" && e !== null && "tag" in e && !ne(e);
1969
+ function Q(e) {
1970
+ return typeof e == "object" && e !== null && "tag" in e && !ee(e);
1959
1971
  }
1960
- function dt(e, t) {
1972
+ function ut(e, t) {
1961
1973
  return e.key != null ? e : { ...e, key: t };
1962
1974
  }
1963
- function pt(e, t = [], r = {}) {
1964
- const n = {}, o = {}, s = {};
1965
- function i(u, l, y) {
1966
- const d = typeof u == "function" ? u : typeof y[u] == "function" ? y[u] : void 0;
1967
- if (typeof d != "function") return;
1968
- const b = l.includes("prevent"), k = l.includes("stop"), x = l.includes("stopImmediate") || l.includes("stopImmediatePropagation"), p = l.includes("self"), f = l.includes("left"), g = l.includes("middle"), m = l.includes("right"), h = l.includes("ctrl") || l.includes("control"), w = l.includes("alt") || l.includes("option"), v = l.includes("shift"), $ = l.includes("meta") || l.includes("cmd") || l.includes("command"), _ = {
1969
- enter: "Enter",
1970
- tab: "Tab",
1971
- space: " ",
1972
- spacebar: " ",
1973
- esc: "Escape",
1974
- escape: "Escape",
1975
- del: "Delete",
1976
- delete: "Delete",
1977
- backspace: "Backspace",
1978
- up: "ArrowUp",
1979
- down: "ArrowDown",
1980
- left: "ArrowLeft",
1981
- right: "ArrowRight",
1982
- home: "Home",
1983
- end: "End",
1984
- pageup: "PageUp",
1985
- pagedown: "PageDown",
1986
- insert: "Insert",
1987
- pause: "Pause"
1988
- };
1989
- let C = l.filter((A) => _[A]);
1990
- (f || g || m) && (C = C.filter((A) => A !== "left" && A !== "middle" && A !== "right"));
1991
- const E = function(A) {
1992
- if (!((f || g || m) && A instanceof MouseEvent && (f && A.button !== 0 || g && A.button !== 1 || m && A.button !== 2)) && !(h && !A.ctrlKey) && !(w && !A.altKey) && !(v && !A.shiftKey) && !($ && !A.metaKey)) {
1993
- if (C.length > 0) {
1994
- const q = A.key;
1995
- if (!q || !C.some((W) => _[W] === q)) return;
1996
- }
1997
- if (!(p && A.target !== A.currentTarget)) {
1998
- b && A.preventDefault(), k && A.stopPropagation(), x && A.stopImmediatePropagation();
1999
- try {
2000
- return typeof u == "function" ? u.call(void 0, A) : d.call(y, A);
2001
- } catch (q) {
2002
- throw q;
2003
- }
2004
- }
2005
- }
2006
- }, j = {};
2007
- return l.includes("once") && (j.once = !0), l.includes("capture") && (j.capture = !0), l.includes("passive") && (j.passive = !0), Object.keys(j).length > 0 ? { handler: E, options: j } : E;
2008
- }
2009
- const a = /([:@#]?)([a-zA-Z0-9-:\.]+)=("([^"\\]*(\\.[^"\\]*)*)"|'([^'\\]*(\\.[^'\\]*)*)')/g;
2010
- let c;
2011
- for (; c = a.exec(e); ) {
2012
- const u = c[1], l = c[2], y = (c[4] || c[6]) ?? "", d = y.match(/^{{(\d+)}}$/);
2013
- let b = d ? t[Number(d[1])] ?? null : y;
2014
- d || (b === "true" ? b = !0 : b === "false" ? b = !1 : b === "null" ? b = null : isNaN(Number(b)) || (b = Number(b)));
2015
- const k = ["model", "bind", "show", "class", "style"];
2016
- if (u === ":") {
2017
- const [x, ...p] = l.split(".");
2018
- if (k.includes(x)) {
2019
- const f = [...p];
1975
+ function dt(e, t = [], r = {}) {
1976
+ const o = {}, n = {}, s = {}, i = /([:@#]?)([a-zA-Z0-9-:\.]+)=("([^"\\]*(\\.[^"\\]*)*)"|'([^'\\]*(\\.[^'\\]*)*)')/g;
1977
+ let a;
1978
+ for (; a = i.exec(e); ) {
1979
+ const l = a[1], f = a[2], p = (a[4] || a[6]) ?? "", y = p.match(/^{{(\d+)}}$/);
1980
+ let c = y ? t[Number(y[1])] ?? null : p;
1981
+ y || (c === "true" ? c = !0 : c === "false" ? c = !1 : c === "null" ? c = null : isNaN(Number(c)) || (c = Number(c)));
1982
+ const w = ["model", "bind", "show", "class", "style"];
1983
+ if (l === ":") {
1984
+ const [x, ...k] = f.split(".");
1985
+ if (w.includes(x)) {
1986
+ const h = [...k];
2020
1987
  s[x] = {
2021
- value: b,
2022
- modifiers: f
1988
+ value: c,
1989
+ modifiers: h
2023
1990
  };
2024
1991
  } else
2025
- o[l] = b;
2026
- } else if (u === "@") {
2027
- const x = l.split("."), p = x[0], f = x.slice(1), g = "on" + p.charAt(0).toUpperCase() + p.slice(1), m = i(b, f, r);
2028
- m !== void 0 && (n[g] = m);
2029
- } else l === "ref" ? n.ref = b : o[l] = b;
1992
+ n[f] = c;
1993
+ } else if (l === "@") {
1994
+ const x = "on" + f.charAt(0).toUpperCase() + f.slice(1);
1995
+ o[x] = typeof c == "function" ? c : typeof r[c] == "function" ? r[c] : void 0;
1996
+ } else f === "ref" ? o.ref = c : n[f] = c;
2030
1997
  }
2031
- return { props: n, attrs: o, directives: s };
1998
+ return { props: o, attrs: n, directives: s };
2032
1999
  }
2033
- function ht(e, t, r) {
2034
- const n = Q.length > 0 ? Q[Q.length - 1] : void 0, o = r ?? n;
2035
- function s(h, w) {
2036
- return Z("#text", {}, h, w);
2000
+ function pt(e, t, r) {
2001
+ const o = J.length > 0 ? J[J.length - 1] : void 0, n = r ?? o;
2002
+ function s(d, v) {
2003
+ return V("#text", {}, d, v);
2037
2004
  }
2038
2005
  let i = "";
2039
- for (let h = 0; h < e.length; h++)
2040
- i += e[h], h < t.length && (i += `{{${h}}}`);
2041
- const a = /<\/?([a-zA-Z0-9-]+)((?:\s+[^\s=>/]+(?:\s*=\s*(?:"(?:\\.|[^"])*"|'(?:\\.|[^'])*'|[^\s>]+))?)*)\s*\/?>|{{(\d+)}}|([^<]+)/g, c = [];
2042
- let u, l = [], y = null, d = {}, b, k = 0, x = [];
2043
- function p(h) {
2044
- !h || typeof h != "object" || ne(h) || (h.props || h.attrs ? (h.props && (d.props || (d.props = {}), Object.assign(d.props, h.props)), h.attrs && (d.attrs || (d.attrs = {}), Object.keys(h.attrs).forEach((w) => {
2045
- if (w === "style" && d.attrs.style) {
2046
- const v = d.attrs.style.replace(
2006
+ for (let d = 0; d < e.length; d++)
2007
+ i += e[d], d < t.length && (i += `{{${d}}}`);
2008
+ const a = /<\/?([a-zA-Z0-9-]+)((?:\s+[^\s=>/]+(?:\s*=\s*(?:"(?:\\.|[^"])*"|'(?:\\.|[^'])*'|[^\s>]+))?)*)\s*\/?>|{{(\d+)}}|([^<]+)/g, l = [];
2009
+ let f, p = [], y = null, c = {}, w, x = 0, k = [];
2010
+ function h(d) {
2011
+ !d || typeof d != "object" || ee(d) || (d.props || d.attrs ? (d.props && (c.props || (c.props = {}), Object.assign(c.props, d.props)), d.attrs && (c.attrs || (c.attrs = {}), Object.keys(d.attrs).forEach((v) => {
2012
+ if (v === "style" && c.attrs.style) {
2013
+ const m = c.attrs.style.replace(
2047
2014
  /;?\s*$/,
2048
2015
  ""
2049
- ), $ = h.attrs.style.replace(/^;?\s*/, "");
2050
- d.attrs.style = v + "; " + $;
2051
- } else if (w === "class" && d.attrs.class) {
2052
- const v = d.attrs.class.trim().split(/\s+/).filter(Boolean), $ = h.attrs.class.trim().split(/\s+/).filter(Boolean), _ = [
2053
- .../* @__PURE__ */ new Set([...v, ...$])
2016
+ ), $ = d.attrs.style.replace(/^;?\s*/, "");
2017
+ c.attrs.style = m + "; " + $;
2018
+ } else if (v === "class" && c.attrs.class) {
2019
+ const m = c.attrs.class.trim().split(/\s+/).filter(Boolean), $ = d.attrs.class.trim().split(/\s+/).filter(Boolean), _ = [
2020
+ .../* @__PURE__ */ new Set([...m, ...$])
2054
2021
  ];
2055
- d.attrs.class = _.join(" ");
2022
+ c.attrs.class = _.join(" ");
2056
2023
  } else
2057
- d.attrs[w] = h.attrs[w];
2058
- }))) : (d.props || (d.props = {}), Object.assign(d.props, h)));
2059
- }
2060
- function f(h, w) {
2061
- const v = y ? l : x;
2062
- if (ne(h)) {
2063
- const $ = h.key ?? w;
2064
- let _ = h.children;
2065
- v.push({
2066
- ...h,
2024
+ c.attrs[v] = d.attrs[v];
2025
+ }))) : (c.props || (c.props = {}), Object.assign(c.props, d)));
2026
+ }
2027
+ function u(d, v) {
2028
+ const m = y ? p : k;
2029
+ if (ee(d)) {
2030
+ const $ = d.key ?? v;
2031
+ let _ = d.children;
2032
+ m.push({
2033
+ ...d,
2067
2034
  key: $,
2068
2035
  children: _
2069
2036
  });
2070
2037
  return;
2071
2038
  }
2072
- if (G(h)) {
2073
- v.push(dt(h, void 0));
2039
+ if (Q(d)) {
2040
+ m.push(ut(d, void 0));
2074
2041
  return;
2075
2042
  }
2076
- if (Array.isArray(h)) {
2077
- if (h.length === 0) return;
2078
- for (let $ = 0; $ < h.length; $++) {
2079
- const _ = h[$];
2080
- ne(_) || G(_) || Array.isArray(_) ? f(_, `${w}-${$}`) : _ !== null && typeof _ == "object" ? p(_) : v.push(s(String(_), `${w}-${$}`));
2043
+ if (Array.isArray(d)) {
2044
+ if (d.length === 0) return;
2045
+ for (let $ = 0; $ < d.length; $++) {
2046
+ const _ = d[$];
2047
+ ee(_) || Q(_) || Array.isArray(_) ? u(_, `${v}-${$}`) : _ !== null && typeof _ == "object" ? h(_) : m.push(s(String(_), `${v}-${$}`));
2081
2048
  }
2082
2049
  return;
2083
2050
  }
2084
- if (h !== null && typeof h == "object") {
2085
- p(h);
2051
+ if (d !== null && typeof d == "object") {
2052
+ h(d);
2086
2053
  return;
2087
2054
  }
2088
- v.push(s(String(h), w));
2055
+ m.push(s(String(d), v));
2089
2056
  }
2090
2057
  const g = /* @__PURE__ */ new Set([
2091
2058
  "area",
@@ -2103,232 +2070,232 @@ function ht(e, t, r) {
2103
2070
  "track",
2104
2071
  "wbr"
2105
2072
  ]);
2106
- for (; u = a.exec(i); )
2107
- if (u[1]) {
2108
- const h = u[1], w = u[0][1] === "/", v = u[0][u[0].length - 2] === "/" || g.has(h), {
2073
+ for (; f = a.exec(i); )
2074
+ if (f[1]) {
2075
+ const d = f[1], v = f[0][1] === "/", m = f[0][f[0].length - 2] === "/" || g.has(d), {
2109
2076
  props: $,
2110
2077
  attrs: _,
2111
2078
  directives: C
2112
- } = pt(u[2] || "", t, o), E = { props: {}, attrs: {} };
2079
+ } = dt(f[2] || "", t, n), E = { props: {}, attrs: {} };
2113
2080
  for (const j in $) E.props[j] = $[j];
2114
2081
  for (const j in _) E.attrs[j] = _[j];
2115
- if (Object.keys(C).length > 0 && (E.directives = { ...C }), w) {
2116
- const j = Z(
2082
+ if (Object.keys(C).length > 0 && (E.directives = { ...C }), v) {
2083
+ const j = V(
2117
2084
  y,
2118
- d,
2119
- l.length === 1 && G(l[0]) && l[0].tag === "#text" ? typeof l[0].children == "string" ? l[0].children : "" : l.length ? l : void 0,
2120
- b
2121
- ), T = c.pop();
2122
- T ? (y = T.tag, d = T.props, b = T.key, l = T.children, l.push(j)) : (x.push(j), y = null, d = {}, b = void 0, l = []);
2123
- } else v ? y ? l.push(Z(h, E, void 0, void 0)) : x.push(Z(h, E, void 0, void 0)) : (y && c.push({
2085
+ c,
2086
+ p.length === 1 && Q(p[0]) && p[0].tag === "#text" ? typeof p[0].children == "string" ? p[0].children : "" : p.length ? p : void 0,
2087
+ w
2088
+ ), A = l.pop();
2089
+ A ? (y = A.tag, c = A.props, w = A.key, p = A.children, p.push(j)) : (k.push(j), y = null, c = {}, w = void 0, p = []);
2090
+ } else m ? y ? p.push(V(d, E, void 0, void 0)) : k.push(V(d, E, void 0, void 0)) : (y && l.push({
2124
2091
  tag: y,
2125
- props: d,
2126
- children: l,
2127
- key: b
2128
- }), y = h, d = E, l = []);
2129
- } else if (typeof u[3] < "u") {
2130
- const h = Number(u[3]), w = t[h], v = `interp-${h}`;
2131
- f(w, v);
2132
- } else if (u[4]) {
2133
- const h = u[4], w = y ? l : x, v = h.split(/({{\d+}})/);
2134
- for (const $ of v) {
2092
+ props: c,
2093
+ children: p,
2094
+ key: w
2095
+ }), y = d, c = E, p = []);
2096
+ } else if (typeof f[3] < "u") {
2097
+ const d = Number(f[3]), v = t[d], m = `interp-${d}`;
2098
+ u(v, m);
2099
+ } else if (f[4]) {
2100
+ const d = f[4], v = y ? p : k, m = d.split(/({{\d+}})/);
2101
+ for (const $ of m) {
2135
2102
  if (!$) continue;
2136
2103
  const _ = $.match(/^{{(\d+)}}$/);
2137
2104
  if (_) {
2138
2105
  const C = Number(_[1]), E = t[C], j = `interp-${C}`;
2139
- f(E, j);
2106
+ u(E, j);
2140
2107
  } else {
2141
- const C = `text-${k++}`;
2142
- w.push(s($, C));
2108
+ const C = `text-${x++}`;
2109
+ v.push(s($, C));
2143
2110
  }
2144
2111
  }
2145
2112
  }
2146
- const m = x.filter((h) => G(h) && h.tag === "#text" ? typeof h.children == "string" && h.children.trim() !== "" : !0);
2147
- return m.length === 1 ? m[0] : m.length > 1 ? m : Z("div", {}, "", "fallback-root");
2113
+ const b = k.filter((d) => Q(d) && d.tag === "#text" ? typeof d.children == "string" && d.children.trim() !== "" : !0);
2114
+ return b.length === 1 ? b[0] : b.length > 1 ? b : V("div", {}, "", "fallback-root");
2148
2115
  }
2149
- function I(e, ...t) {
2150
- const r = t[t.length - 1], n = typeof r == "object" && r && !Array.isArray(r) ? r : void 0;
2151
- return ht(e, t, n);
2116
+ function D(e, ...t) {
2117
+ const r = t[t.length - 1], o = typeof r == "object" && r && !Array.isArray(r) ? r : void 0;
2118
+ return pt(e, t, o);
2152
2119
  }
2153
- const Ae = (e) => e ? typeof URLSearchParams > "u" ? {} : Object.fromEntries(new URLSearchParams(e)) : {}, D = (e, t) => {
2120
+ const Ee = (e) => e ? typeof URLSearchParams > "u" ? {} : Object.fromEntries(new URLSearchParams(e)) : {}, N = (e, t) => {
2154
2121
  for (const r of e) {
2155
- const n = [], o = r.path.replace(/:[^/]+/g, (a) => (n.push(a.slice(1)), "([^/]+)")), s = new RegExp(`^${o}$`), i = t.match(s);
2122
+ const o = [], n = r.path.replace(/:[^/]+/g, (a) => (o.push(a.slice(1)), "([^/]+)")), s = new RegExp(`^${n}$`), i = t.match(s);
2156
2123
  if (i) {
2157
2124
  const a = {};
2158
- return n.forEach((c, u) => {
2159
- a[c] = i[u + 1];
2125
+ return o.forEach((l, f) => {
2126
+ a[l] = i[f + 1];
2160
2127
  }), { route: r, params: a };
2161
2128
  }
2162
2129
  }
2163
2130
  return { route: null, params: {} };
2164
- }, he = {};
2165
- async function gt(e) {
2131
+ }, de = {};
2132
+ async function ht(e) {
2166
2133
  if (e.component) return e.component;
2167
2134
  if (e.load) {
2168
- if (he[e.path]) return he[e.path];
2135
+ if (de[e.path]) return de[e.path];
2169
2136
  try {
2170
2137
  const t = await e.load();
2171
- return he[e.path] = t.default, t.default;
2138
+ return de[e.path] = t.default, t.default;
2172
2139
  } catch {
2173
2140
  throw new Error(`Failed to load component for route: ${e.path}`);
2174
2141
  }
2175
2142
  }
2176
2143
  throw new Error(`No component or loader defined for route: ${e.path}`);
2177
2144
  }
2178
- function yt(e) {
2179
- const { routes: t, base: r = "", initialUrl: n } = e;
2180
- let o, s, i, a, c, u, l;
2181
- const y = async (x, p) => {
2182
- const f = t.find((g) => D([g], x.path).route !== null);
2183
- if (f?.beforeEnter)
2145
+ function gt(e) {
2146
+ const { routes: t, base: r = "", initialUrl: o } = e;
2147
+ let n, s, i, a, l, f, p;
2148
+ const y = async (k, h) => {
2149
+ const u = t.find((g) => N([g], k.path).route !== null);
2150
+ if (u?.beforeEnter)
2184
2151
  try {
2185
- const g = await f.beforeEnter(x, p);
2186
- return typeof g == "string" ? (await k(g, !0), !1) : g !== !1;
2152
+ const g = await u.beforeEnter(k, h);
2153
+ return typeof g == "string" ? (await x(g, !0), !1) : g !== !1;
2187
2154
  } catch (g) {
2188
2155
  return console.error("beforeEnter error", g), !1;
2189
2156
  }
2190
2157
  return !0;
2191
- }, d = async (x, p) => {
2192
- const f = t.find((g) => D([g], x.path).route !== null);
2193
- if (f?.onEnter)
2158
+ }, c = async (k, h) => {
2159
+ const u = t.find((g) => N([g], k.path).route !== null);
2160
+ if (u?.onEnter)
2194
2161
  try {
2195
- const g = await f.onEnter(x, p);
2196
- return typeof g == "string" ? (await k(g, !0), !1) : g !== !1;
2162
+ const g = await u.onEnter(k, h);
2163
+ return typeof g == "string" ? (await x(g, !0), !1) : g !== !1;
2197
2164
  } catch (g) {
2198
2165
  return console.error("onEnter error", g), !1;
2199
2166
  }
2200
2167
  return !0;
2201
- }, b = (x, p) => {
2202
- const f = t.find((g) => D([g], x.path).route !== null);
2203
- if (f?.afterEnter)
2168
+ }, w = (k, h) => {
2169
+ const u = t.find((g) => N([g], k.path).route !== null);
2170
+ if (u?.afterEnter)
2204
2171
  try {
2205
- f.afterEnter(x, p);
2172
+ u.afterEnter(k, h);
2206
2173
  } catch (g) {
2207
2174
  console.error("afterEnter error", g);
2208
2175
  }
2209
- }, k = async (x, p = !1) => {
2176
+ }, x = async (k, h = !1) => {
2210
2177
  try {
2211
- const f = {
2212
- path: x.replace(r, "") || "/",
2178
+ const u = {
2179
+ path: k.replace(r, "") || "/",
2213
2180
  query: {}
2214
- }, g = D(t, f.path);
2215
- if (!g) throw new Error(`No route found for ${f.path}`);
2216
- const m = i.getState(), h = {
2217
- path: f.path,
2181
+ }, g = N(t, u.path);
2182
+ if (!g) throw new Error(`No route found for ${u.path}`);
2183
+ const b = i.getState(), d = {
2184
+ path: u.path,
2218
2185
  params: g.params,
2219
- query: f.query
2186
+ query: u.query
2220
2187
  };
2221
- if (!await y(h, m) || !await d(h, m)) return;
2222
- typeof window < "u" && typeof document < "u" && (p ? window.history.replaceState({}, "", r + x) : window.history.pushState({}, "", r + x)), i.setState(h), b(h, m);
2223
- } catch (f) {
2224
- console.error("Navigation error:", f);
2188
+ if (!await y(d, b) || !await c(d, b)) return;
2189
+ typeof window < "u" && typeof document < "u" && (h ? window.history.replaceState({}, "", r + k) : window.history.pushState({}, "", r + k)), i.setState(d), w(d, b);
2190
+ } catch (u) {
2191
+ console.error("Navigation error:", u);
2225
2192
  }
2226
2193
  };
2227
2194
  if (typeof window < "u" && typeof document < "u") {
2228
- o = () => {
2229
- const p = new URL(window.location.href), f = p.pathname.replace(r, "") || "/", g = Ae(p.search);
2230
- return { path: f, query: g };
2231
- }, s = o();
2232
- const x = D(t, s.path);
2195
+ n = () => {
2196
+ const h = new URL(window.location.href), u = h.pathname.replace(r, "") || "/", g = Ee(h.search);
2197
+ return { path: u, query: g };
2198
+ }, s = n();
2199
+ const k = N(t, s.path);
2233
2200
  i = xe({
2234
2201
  path: s.path,
2235
- params: x.params,
2202
+ params: k.params,
2236
2203
  query: s.query
2237
- }), a = async (p = !1) => {
2238
- const f = o();
2239
- await k(f.path, p);
2240
- }, window.addEventListener("popstate", () => a(!0)), c = (p) => k(p, !1), u = (p) => k(p, !0), l = () => window.history.back();
2204
+ }), a = async (h = !1) => {
2205
+ const u = n();
2206
+ await x(u.path, h);
2207
+ }, window.addEventListener("popstate", () => a(!0)), l = (h) => x(h, !1), f = (h) => x(h, !0), p = () => window.history.back();
2241
2208
  } else {
2242
- o = () => {
2243
- const f = new URL(n || "/", "http://localhost"), g = f.pathname.replace(r, "") || "/", m = Ae(f.search);
2244
- return { path: g, query: m };
2245
- }, s = o();
2246
- const x = D(t, s.path);
2209
+ n = () => {
2210
+ const u = new URL(o || "/", "http://localhost"), g = u.pathname.replace(r, "") || "/", b = Ee(u.search);
2211
+ return { path: g, query: b };
2212
+ }, s = n();
2213
+ const k = N(t, s.path);
2247
2214
  i = xe({
2248
2215
  path: s.path,
2249
- params: x.params,
2216
+ params: k.params,
2250
2217
  query: s.query
2251
2218
  }), a = async () => {
2252
- const f = o();
2253
- await p(f.path);
2219
+ const u = n();
2220
+ await h(u.path);
2254
2221
  };
2255
- const p = async (f) => {
2222
+ const h = async (u) => {
2256
2223
  try {
2257
2224
  const g = {
2258
- path: f.replace(r, "") || "/",
2225
+ path: u.replace(r, "") || "/",
2259
2226
  query: {}
2260
- }, m = D(t, g.path);
2261
- if (!m) throw new Error(`No route found for ${g.path}`);
2262
- const h = i.getState(), w = {
2227
+ }, b = N(t, g.path);
2228
+ if (!b) throw new Error(`No route found for ${g.path}`);
2229
+ const d = i.getState(), v = {
2263
2230
  path: g.path,
2264
- params: m.params,
2231
+ params: b.params,
2265
2232
  query: g.query
2266
- }, v = t.find(($) => D([$], w.path).route !== null);
2267
- if (v?.beforeEnter)
2233
+ }, m = t.find(($) => N([$], v.path).route !== null);
2234
+ if (m?.beforeEnter)
2268
2235
  try {
2269
- const $ = await v.beforeEnter(w, h);
2236
+ const $ = await m.beforeEnter(v, d);
2270
2237
  if (typeof $ == "string") {
2271
- await p($);
2238
+ await h($);
2272
2239
  return;
2273
2240
  }
2274
2241
  if ($ === !1) return;
2275
2242
  } catch {
2276
2243
  return;
2277
2244
  }
2278
- if (v?.onEnter)
2245
+ if (m?.onEnter)
2279
2246
  try {
2280
- const $ = await v.onEnter(w, h);
2247
+ const $ = await m.onEnter(v, d);
2281
2248
  if (typeof $ == "string") {
2282
- await p($);
2249
+ await h($);
2283
2250
  return;
2284
2251
  }
2285
2252
  if ($ === !1) return;
2286
2253
  } catch {
2287
2254
  return;
2288
2255
  }
2289
- if (i.setState(w), v?.afterEnter)
2256
+ if (i.setState(v), m?.afterEnter)
2290
2257
  try {
2291
- v.afterEnter(w, h);
2258
+ m.afterEnter(v, d);
2292
2259
  } catch {
2293
2260
  }
2294
2261
  } catch {
2295
2262
  }
2296
2263
  };
2297
- c = async (f) => p(f), u = async (f) => p(f), l = () => {
2264
+ l = async (u) => h(u), f = async (u) => h(u), p = () => {
2298
2265
  };
2299
2266
  }
2300
2267
  return {
2301
2268
  store: i,
2302
- push: c,
2303
- replace: u,
2304
- back: l,
2269
+ push: l,
2270
+ replace: f,
2271
+ back: p,
2305
2272
  subscribe: i.subscribe,
2306
- matchRoute: (x) => D(t, x),
2273
+ matchRoute: (k) => N(t, k),
2307
2274
  getCurrent: () => i.getState(),
2308
- resolveRouteComponent: gt
2275
+ resolveRouteComponent: ht
2309
2276
  };
2310
2277
  }
2311
- function St(e, t) {
2312
- return D(e, t);
2278
+ function $t(e, t) {
2279
+ return N(e, t);
2313
2280
  }
2314
- function _t(e) {
2315
- const t = yt(e);
2316
- return Ee("router-view", {
2281
+ function St(e) {
2282
+ const t = gt(e);
2283
+ return Ce("router-view", {
2317
2284
  async render() {
2318
- if (!t) return I`<div>Router not initialized.</div>`;
2319
- const r = t.getCurrent(), { path: n } = r, o = t.matchRoute(n);
2320
- if (!o.route) return I`<div>Not found</div>`;
2285
+ if (!t) return D`<div>Router not initialized.</div>`;
2286
+ const r = t.getCurrent(), { path: o } = r, n = t.matchRoute(o);
2287
+ if (!n.route) return D`<div>Not found</div>`;
2321
2288
  try {
2322
- const s = await t.resolveRouteComponent(o.route);
2289
+ const s = await t.resolveRouteComponent(n.route);
2323
2290
  if (typeof s == "string")
2324
2291
  return { tag: s, props: {}, children: [] };
2325
2292
  if (typeof s == "function") {
2326
2293
  const i = s(), a = i instanceof Promise ? await i : i;
2327
2294
  return typeof a == "string" ? { tag: a, props: {}, children: [] } : a;
2328
2295
  }
2329
- return I`<div>Invalid route component</div>`;
2296
+ return D`<div>Invalid route component</div>`;
2330
2297
  } catch {
2331
- return I`<div>Invalid route component</div>`;
2298
+ return D`<div>Invalid route component</div>`;
2332
2299
  }
2333
2300
  },
2334
2301
  onConnected(r) {
@@ -2336,7 +2303,7 @@ function _t(e) {
2336
2303
  typeof r.requestRender == "function" && r.requestRender();
2337
2304
  });
2338
2305
  }
2339
- }), Ee("router-link", {
2306
+ }), Ce("router-link", {
2340
2307
  state: {},
2341
2308
  props: {
2342
2309
  to: { type: String, default: "" },
@@ -2349,7 +2316,7 @@ function _t(e) {
2349
2316
  disabled: { type: Boolean, default: !1 },
2350
2317
  external: { type: Boolean, default: !1 },
2351
2318
  class: { type: String, default: "" },
2352
- style: { type: String, default: Le`
2319
+ style: { type: String, default: je`
2353
2320
  [aria-disabled="true"] {
2354
2321
  pointer-events: none;
2355
2322
  opacity: 0.5;
@@ -2358,66 +2325,66 @@ function _t(e) {
2358
2325
  },
2359
2326
  style: (r) => r.style,
2360
2327
  render: (r) => {
2361
- const n = t.getCurrent(), o = r.to, s = r.exact, i = r.exactActiveClass, a = r.activeClass, c = r.ariaCurrentValue, u = r.tag, l = r.disabled, y = r.external, d = n.path === o, b = s ? d : n && typeof n.path == "string" ? n.path.startsWith(o) : !1, k = d ? `aria-current="${c}"` : "", x = (r.class || "").split(/\s+/).filter(Boolean), p = {};
2362
- for (const w of x) p[w] = !0;
2363
- const f = {
2364
- ...p,
2328
+ const o = t.getCurrent(), n = r.to, s = r.exact, i = r.exactActiveClass, a = r.activeClass, l = r.ariaCurrentValue, f = r.tag, p = r.disabled, y = r.external, c = o.path === n, w = s ? c : o && typeof o.path == "string" ? o.path.startsWith(n) : !1, x = c ? `aria-current="${l}"` : "", k = (r.class || "").split(/\s+/).filter(Boolean), h = {};
2329
+ for (const v of k) h[v] = !0;
2330
+ const u = {
2331
+ ...h,
2365
2332
  // Also include the configurable names (may duplicate the above)
2366
- [a]: b,
2367
- [i]: d
2368
- }, g = u === "button", m = l ? g ? 'disabled aria-disabled="true" tabindex="-1"' : 'aria-disabled="true" tabindex="-1"' : "", h = y && (u === "a" || !u) ? 'target="_blank" rel="noopener noreferrer"' : "";
2369
- return I`
2370
- ${Be().when(g, I`
2333
+ [a]: w,
2334
+ [i]: c
2335
+ }, g = f === "button", b = p ? g ? 'disabled aria-disabled="true" tabindex="-1"' : 'aria-disabled="true" tabindex="-1"' : "", d = y && (f === "a" || !f) ? 'target="_blank" rel="noopener noreferrer"' : "";
2336
+ return D`
2337
+ ${Re().when(g, D`
2371
2338
  <button
2372
2339
  part="button"
2373
- :class="${f}"
2374
- ${k}
2375
- ${m}
2376
- ${h}
2340
+ :class="${u}"
2341
+ ${x}
2342
+ ${b}
2343
+ ${d}
2377
2344
  @click="navigate"
2378
2345
  ><slot></slot></button>
2379
- `).otherwise(I`
2346
+ `).otherwise(D`
2380
2347
  <a
2381
2348
  part="link"
2382
- href="${o}"
2383
- :class="${f}"
2384
- ${k}
2385
- ${m}
2386
- ${h}
2349
+ href="${n}"
2350
+ :class="${u}"
2351
+ ${x}
2352
+ ${b}
2353
+ ${d}
2387
2354
  @click="navigate"
2388
2355
  ><slot></slot></a>
2389
2356
  `).done()}
2390
2357
  `;
2391
2358
  },
2392
- navigate: (r, n) => {
2393
- if (n.disabled) {
2359
+ navigate: (r, o) => {
2360
+ if (o.disabled) {
2394
2361
  r.preventDefault();
2395
2362
  return;
2396
2363
  }
2397
- n.external && (n.tag === "a" || !n.tag) || (r.preventDefault(), n.replace ? t.replace(n.to) : t.push(n.to));
2364
+ o.external && (o.tag === "a" || !o.tag) || (r.preventDefault(), o.replace ? t.replace(o.to) : t.push(o.to));
2398
2365
  }
2399
2366
  }), t;
2400
2367
  }
2401
2368
  export {
2402
- V as GlobalEventBus,
2403
- Ee as component,
2369
+ K as GlobalEventBus,
2370
+ Ce as component,
2404
2371
  xe as createStore,
2405
- Le as css,
2406
- bt as each,
2407
- vt as emit,
2408
- X as eventBus,
2409
- I as html,
2410
- _t as initRouter,
2411
- $t as listen,
2412
- Be as match,
2413
- D as matchRoute,
2414
- St as matchRouteSSR,
2372
+ je as css,
2373
+ mt as each,
2374
+ bt as emit,
2375
+ Z as eventBus,
2376
+ D as html,
2377
+ St as initRouter,
2378
+ kt as listen,
2379
+ Re as match,
2380
+ N as matchRoute,
2381
+ $t as matchRouteSSR,
2415
2382
  xt as off,
2416
- wt as on,
2417
- kt as once,
2418
- Ae as parseQuery,
2419
- gt as resolveRouteComponent,
2420
- yt as useRouter,
2421
- mt as when
2383
+ vt as on,
2384
+ wt as once,
2385
+ Ee as parseQuery,
2386
+ ht as resolveRouteComponent,
2387
+ gt as useRouter,
2388
+ yt as when
2422
2389
  };
2423
2390
  //# sourceMappingURL=custom-elements-runtime.es.js.map