cogsbox-state 0.5.278 → 0.5.279

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.
@@ -10,9 +10,9 @@ import { getGlobalStore as r, formRefStore as It } from "./store.js";
10
10
  import { useCogsConfig as $t } from "./CogsStateClient.jsx";
11
11
  import { applyPatch as Ot } from "fast-json-patch";
12
12
  function pt(t, i) {
13
- const v = r.getState().getInitialOptions, g = r.getState().setInitialStateOptions, y = v(t) || {};
13
+ const v = r.getState().getInitialOptions, g = r.getState().setInitialStateOptions, h = v(t) || {};
14
14
  g(t, {
15
- ...y,
15
+ ...h,
16
16
  ...i
17
17
  });
18
18
  }
@@ -21,7 +21,7 @@ function wt({
21
21
  options: i,
22
22
  initialOptionsPart: v
23
23
  }) {
24
- const g = Q(t) || {}, y = v[t] || {}, k = r.getState().setInitialStateOptions, p = { ...y, ...g };
24
+ const g = Q(t) || {}, h = v[t] || {}, k = r.getState().setInitialStateOptions, p = { ...h, ...g };
25
25
  let I = !1;
26
26
  if (i)
27
27
  for (const s in i)
@@ -34,29 +34,29 @@ function ee(t, { formElements: i, validation: v }) {
34
34
  }
35
35
  const ne = (t, i) => {
36
36
  let v = t;
37
- const [g, y] = bt(v);
38
- (Object.keys(y).length > 0 || i && Object.keys(i).length > 0) && Object.keys(y).forEach((I) => {
39
- y[I] = y[I] || {}, y[I].formElements = {
37
+ const [g, h] = bt(v);
38
+ (Object.keys(h).length > 0 || i && Object.keys(i).length > 0) && Object.keys(h).forEach((I) => {
39
+ h[I] = h[I] || {}, h[I].formElements = {
40
40
  ...i?.formElements,
41
41
  // Global defaults first
42
42
  ...i?.validation,
43
- ...y[I].formElements || {}
43
+ ...h[I].formElements || {}
44
44
  // State-specific overrides
45
- }, Q(I) || r.getState().setInitialStateOptions(I, y[I]);
45
+ }, Q(I) || r.getState().setInitialStateOptions(I, h[I]);
46
46
  }), r.getState().setInitialStates(g), r.getState().setCreatedState(g);
47
47
  const k = (I, s) => {
48
- const [h] = nt(s?.componentId ?? mt());
48
+ const [y] = nt(s?.componentId ?? mt());
49
49
  wt({
50
50
  stateKey: I,
51
51
  options: s,
52
- initialOptionsPart: y
52
+ initialOptionsPart: h
53
53
  });
54
54
  const a = r.getState().cogsStateStore[I] || g[I], S = s?.modifyState ? s.modifyState(a) : a, [D, R] = Wt(
55
55
  S,
56
56
  {
57
57
  stateKey: I,
58
58
  syncUpdate: s?.syncUpdate,
59
- componentId: h,
59
+ componentId: y,
60
60
  localStorage: s?.localStorage,
61
61
  middleware: s?.middleware,
62
62
  enabledSync: s?.enabledSync,
@@ -70,7 +70,7 @@ const ne = (t, i) => {
70
70
  return R;
71
71
  };
72
72
  function p(I, s) {
73
- wt({ stateKey: I, options: s, initialOptionsPart: y }), s.localStorage && Dt(I, s), lt(I);
73
+ wt({ stateKey: I, options: s, initialOptionsPart: h }), s.localStorage && Dt(I, s), lt(I);
74
74
  }
75
75
  return { useCogsState: k, setCogsOptions: p };
76
76
  }, {
@@ -82,9 +82,9 @@ const ne = (t, i) => {
82
82
  setStateLog: Ft,
83
83
  updateInitialStateGlobal: yt,
84
84
  addValidationError: Ut,
85
- removeValidationError: z,
85
+ removeValidationError: q,
86
86
  setServerSyncActions: jt
87
- } = r.getState(), Et = (t, i, v, g, y) => {
87
+ } = r.getState(), Et = (t, i, v, g, h) => {
88
88
  v?.log && console.log(
89
89
  "saving to localstorage",
90
90
  i,
@@ -102,11 +102,11 @@ const ne = (t, i) => {
102
102
  const s = {
103
103
  state: t,
104
104
  lastUpdated: Date.now(),
105
- lastSyncedWithServer: y ?? I
106
- }, h = Mt.serialize(s);
105
+ lastSyncedWithServer: h ?? I
106
+ }, y = Mt.serialize(s);
107
107
  window.localStorage.setItem(
108
108
  p,
109
- JSON.stringify(h.json)
109
+ JSON.stringify(y.json)
110
110
  );
111
111
  }
112
112
  }, ct = (t) => {
@@ -118,22 +118,22 @@ const ne = (t, i) => {
118
118
  return console.error("Error loading from localStorage:", i), null;
119
119
  }
120
120
  }, Dt = (t, i) => {
121
- const v = r.getState().cogsStateStore[t], { sessionId: g } = $t(), y = J(i?.localStorage?.key) ? i.localStorage.key(v) : i?.localStorage?.key;
122
- if (y && g) {
121
+ const v = r.getState().cogsStateStore[t], { sessionId: g } = $t(), h = J(i?.localStorage?.key) ? i.localStorage.key(v) : i?.localStorage?.key;
122
+ if (h && g) {
123
123
  const k = ct(
124
- `${g}-${t}-${y}`
124
+ `${g}-${t}-${h}`
125
125
  );
126
126
  if (k && k.lastUpdated > (k.lastSyncedWithServer || 0))
127
127
  return Z(t, k.state), lt(t), !0;
128
128
  }
129
129
  return !1;
130
- }, xt = (t, i, v, g, y, k) => {
130
+ }, xt = (t, i, v, g, h, k) => {
131
131
  const p = {
132
132
  initialState: i,
133
133
  updaterState: st(
134
134
  t,
135
135
  g,
136
- y,
136
+ h,
137
137
  k
138
138
  ),
139
139
  state: v
@@ -151,10 +151,10 @@ const ne = (t, i) => {
151
151
  }, re = (t, i) => {
152
152
  const v = r.getState().stateComponents.get(t);
153
153
  if (v) {
154
- const g = `${t}////${i}`, y = v.components.get(g);
155
- if ((y ? Array.isArray(y.reactiveType) ? y.reactiveType : [y.reactiveType || "component"] : null)?.includes("none"))
154
+ const g = `${t}////${i}`, h = v.components.get(g);
155
+ if ((h ? Array.isArray(h.reactiveType) ? h.reactiveType : [h.reactiveType || "component"] : null)?.includes("none"))
156
156
  return;
157
- y && y.forceUpdate();
157
+ h && h.forceUpdate();
158
158
  }
159
159
  }, Gt = (t, i, v, g) => {
160
160
  switch (t) {
@@ -183,12 +183,12 @@ function Wt(t, {
183
183
  stateKey: i,
184
184
  serverSync: v,
185
185
  localStorage: g,
186
- formElements: y,
186
+ formElements: h,
187
187
  reactiveDeps: k,
188
188
  reactiveType: p,
189
189
  componentId: I,
190
190
  initialState: s,
191
- syncUpdate: h,
191
+ syncUpdate: y,
192
192
  dependencies: a,
193
193
  serverState: S
194
194
  } = {}) {
@@ -198,18 +198,18 @@ function Wt(t, {
198
198
  null
199
199
  );
200
200
  O.current = Q(f) ?? null, gt(() => {
201
- if (h && h.stateKey === f && h.path?.[0]) {
201
+ if (y && y.stateKey === f && y.path?.[0]) {
202
202
  Z(f, (n) => ({
203
203
  ...n,
204
- [h.path[0]]: h.newValue
204
+ [y.path[0]]: y.newValue
205
205
  }));
206
- const e = `${h.stateKey}:${h.path.join(".")}`;
206
+ const e = `${y.stateKey}:${y.path.join(".")}`;
207
207
  r.getState().setSyncInfo(e, {
208
- timeStamp: h.timeStamp,
209
- userId: h.userId
208
+ timeStamp: y.timeStamp,
209
+ userId: y.userId
210
210
  });
211
211
  }
212
- }, [h]), gt(() => {
212
+ }, [y]), gt(() => {
213
213
  if (s) {
214
214
  pt(f, {
215
215
  initialState: s
@@ -239,7 +239,7 @@ function Wt(t, {
239
239
  ]), ft(() => {
240
240
  G && pt(f, {
241
241
  serverSync: v,
242
- formElements: y,
242
+ formElements: h,
243
243
  initialState: s,
244
244
  localStorage: g,
245
245
  middleware: O.current?.middleware
@@ -305,11 +305,11 @@ function Wt(t, {
305
305
  C.removeShadowArrayElement(f, A, _);
306
306
  break;
307
307
  }
308
- })(), console.log("shadowState", r.getState().shadowStateStore), o.updateType === "update" && (c || O.current?.validation?.key) && n && z(
308
+ })(), console.log("shadowState", r.getState().shadowStateStore), o.updateType === "update" && (c || O.current?.validation?.key) && n && q(
309
309
  (c || O.current?.validation?.key) + "." + n.join(".")
310
310
  );
311
311
  const T = n.slice(0, n.length - 1);
312
- o.updateType === "cut" && O.current?.validation?.key && z(
312
+ o.updateType === "cut" && O.current?.validation?.key && q(
313
313
  O.current?.validation?.key + "." + T.join(".")
314
314
  ), o.updateType === "insert" && O.current?.validation?.key && Rt(
315
315
  O.current?.validation?.key + "." + T.join(".")
@@ -317,7 +317,7 @@ function Wt(t, {
317
317
  let _ = $?.split(".").length;
318
318
  if ($ == T.join(".") && _ == T.length - 1) {
319
319
  let E = $ + "." + T;
320
- z($), Ut(E, A);
320
+ q($), Ut(E, A);
321
321
  }
322
322
  });
323
323
  const P = r.getState().stateComponents.get(f);
@@ -381,7 +381,7 @@ function Wt(t, {
381
381
  m,
382
382
  d,
383
383
  n
384
- ), q = {
384
+ ), z = {
385
385
  timeStamp: x,
386
386
  stateKey: f,
387
387
  path: n,
@@ -391,7 +391,7 @@ function Wt(t, {
391
391
  newValue: W
392
392
  };
393
393
  if (Ft(f, (C) => {
394
- const A = [...C ?? [], q].reduce((_, E) => {
394
+ const A = [...C ?? [], z].reduce((_, E) => {
395
395
  const M = `${E.stateKey}:${JSON.stringify(E.path)}`, b = _.get(M);
396
396
  return b ? (b.timeStamp = Math.max(b.timeStamp, E.timeStamp), b.newValue = E.newValue, b.oldValue = b.oldValue ?? E.oldValue, b.updateType = E.updateType) : _.set(M, { ...E }), _;
397
397
  }, /* @__PURE__ */ new Map());
@@ -403,7 +403,7 @@ function Wt(t, {
403
403
  F
404
404
  ), O.current?.middleware && O.current.middleware({
405
405
  updateLog: l,
406
- update: q
406
+ update: z
407
407
  }), O.current?.serverSync) {
408
408
  const C = r.getState().serverState[f], $ = O.current?.serverSync;
409
409
  jt(f, {
@@ -434,22 +434,22 @@ function Wt(t, {
434
434
  return [kt(f), u];
435
435
  }
436
436
  function st(t, i, v, g) {
437
- const y = /* @__PURE__ */ new Map();
437
+ const h = /* @__PURE__ */ new Map();
438
438
  let k = 0;
439
- const p = (h) => {
440
- const a = h.join(".");
441
- for (const [S] of y)
442
- (S === a || S.startsWith(a + ".")) && y.delete(S);
439
+ const p = (y) => {
440
+ const a = y.join(".");
441
+ for (const [S] of h)
442
+ (S === a || S.startsWith(a + ".")) && h.delete(S);
443
443
  k++;
444
444
  }, I = {
445
- removeValidation: (h) => {
446
- h?.validationKey && z(h.validationKey);
445
+ removeValidation: (y) => {
446
+ y?.validationKey && q(y.validationKey);
447
447
  },
448
- revertToInitialState: (h) => {
448
+ revertToInitialState: (y) => {
449
449
  const a = r.getState().getInitialOptions(t)?.validation;
450
- a?.key && z(a?.key), h?.validationKey && z(h.validationKey);
450
+ a?.key && q(a?.key), y?.validationKey && q(y.validationKey);
451
451
  const S = r.getState().initialStateGlobal[t];
452
- r.getState().clearSelectedIndexesForState(t), y.clear(), k++;
452
+ r.getState().clearSelectedIndexesForState(t), h.clear(), k++;
453
453
  const D = s(S, []), R = Q(t), F = J(R?.localStorage?.key) ? R?.localStorage?.key(S) : R?.localStorage?.key, G = `${g}-${t}-${F}`;
454
454
  G && localStorage.removeItem(G), ot(t, D), Z(t, S);
455
455
  const f = r.getState().stateComponents.get(t);
@@ -457,8 +457,8 @@ function st(t, i, v, g) {
457
457
  l.forceUpdate();
458
458
  }), S;
459
459
  },
460
- updateInitialState: (h) => {
461
- y.clear(), k++;
460
+ updateInitialState: (y) => {
461
+ h.clear(), k++;
462
462
  const a = st(
463
463
  t,
464
464
  i,
@@ -466,7 +466,7 @@ function st(t, i, v, g) {
466
466
  g
467
467
  ), S = r.getState().initialStateGlobal[t], D = Q(t), R = J(D?.localStorage?.key) ? D?.localStorage?.key(S) : D?.localStorage?.key, F = `${g}-${t}-${R}`;
468
468
  return localStorage.getItem(F) && localStorage.removeItem(F), Vt(() => {
469
- yt(t, h), ot(t, a), Z(t, h);
469
+ yt(t, y), r.getState().initializeShadowState(t, y), ot(t, a), Z(t, y);
470
470
  const G = r.getState().stateComponents.get(t);
471
471
  G && G.components.forEach((f) => {
472
472
  f.forceUpdate();
@@ -479,13 +479,13 @@ function st(t, i, v, g) {
479
479
  _serverState: r.getState().serverState[t],
480
480
  _isLoading: r.getState().isLoadingGlobal[t],
481
481
  _isServerSynced: () => {
482
- const h = r.getState().serverState[t];
483
- return !!(h && L(h, kt(t)));
482
+ const y = r.getState().serverState[t];
483
+ return !!(y && L(y, kt(t)));
484
484
  }
485
485
  };
486
- function s(h, a = [], S) {
486
+ function s(y, a = [], S) {
487
487
  const D = a.map(String).join(".");
488
- y.get(D);
488
+ h.get(D);
489
489
  const R = function() {
490
490
  return r().getNestedState(t, a);
491
491
  };
@@ -499,7 +499,7 @@ function st(t, i, v, g) {
499
499
  ), console.trace("Apply trap stack trace"), r().getNestedState(t, a);
500
500
  },
501
501
  get(f, l) {
502
- S?.validIndices && !Array.isArray(h) && (S = { ...S, validIndices: void 0 });
502
+ S?.validIndices && !Array.isArray(y) && (S = { ...S, validIndices: void 0 });
503
503
  const rt = /* @__PURE__ */ new Set([
504
504
  "insert",
505
505
  "cut",
@@ -591,8 +591,8 @@ function st(t, i, v, g) {
591
591
  throw new Error("Validation key not found");
592
592
  return r.getState().getValidationErrors(u.key + "." + a.join("."));
593
593
  };
594
- if (Array.isArray(h)) {
595
- const u = () => S?.validIndices ? h.map((n, o) => ({
594
+ if (Array.isArray(y)) {
595
+ const u = () => S?.validIndices ? y.map((n, o) => ({
596
596
  item: n,
597
597
  originalIndex: S.validIndices[o]
598
598
  })) : r.getState().getNestedState(t, a).map((n, o) => ({
@@ -604,7 +604,7 @@ function st(t, i, v, g) {
604
604
  const e = r.getState().getSelectedIndex(t, a.join("."));
605
605
  if (e !== void 0)
606
606
  return s(
607
- h[e],
607
+ y[e],
608
608
  [...a, e.toString()],
609
609
  S
610
610
  );
@@ -666,7 +666,7 @@ function st(t, i, v, g) {
666
666
  });
667
667
  })), P.current = !1, M(), () => A.removeEventListener("scroll", M);
668
668
  }, [V, n, o, c]);
669
- const q = vt(
669
+ const z = vt(
670
670
  (A = "smooth") => {
671
671
  m.current && m.current.scrollTo({
672
672
  top: m.current.scrollHeight,
@@ -702,7 +702,7 @@ function st(t, i, v, g) {
702
702
  return {
703
703
  virtualState: W,
704
704
  virtualizerProps: $,
705
- scrollToBottom: q,
705
+ scrollToBottom: z,
706
706
  scrollToIndex: C
707
707
  };
708
708
  };
@@ -746,8 +746,8 @@ function st(t, i, v, g) {
746
746
  forceUpdate: () => P({}),
747
747
  paths: /* @__PURE__ */ new Set([N.join(".")])
748
748
  }), r.getState().stateComponents.set(t, W), () => {
749
- const q = r.getState().stateComponents.get(t);
750
- q && q.components.delete(V);
749
+ const z = r.getState().stateComponents.get(t);
750
+ z && z.components.delete(V);
751
751
  };
752
752
  }, [t, x]);
753
753
  },
@@ -760,7 +760,7 @@ function st(t, i, v, g) {
760
760
  ), null);
761
761
  };
762
762
  if (l === "stateMapNoRender")
763
- return (e) => h.map((o, c) => {
763
+ return (e) => y.map((o, c) => {
764
764
  let m;
765
765
  S?.validIndices && S.validIndices[c] !== void 0 ? m = S.validIndices[c] : m = c;
766
766
  const d = [...a, m.toString()], N = s(o, d, S);
@@ -768,8 +768,8 @@ function st(t, i, v, g) {
768
768
  o,
769
769
  N,
770
770
  c,
771
- h,
772
- s(h, a, S)
771
+ y,
772
+ s(y, a, S)
773
773
  );
774
774
  });
775
775
  if (l === "$stateMap")
@@ -784,8 +784,8 @@ function st(t, i, v, g) {
784
784
  });
785
785
  if (l === "stateFlattenOn")
786
786
  return (e) => {
787
- const n = h;
788
- y.clear(), k++;
787
+ const n = y;
788
+ h.clear(), k++;
789
789
  const o = n.flatMap(
790
790
  (c) => c[e] ?? []
791
791
  );
@@ -797,7 +797,7 @@ function st(t, i, v, g) {
797
797
  };
798
798
  if (l === "index")
799
799
  return (e) => {
800
- const n = h[e];
800
+ const n = y[e];
801
801
  return s(n, [...a, e.toString()]);
802
802
  };
803
803
  if (l === "last")
@@ -844,12 +844,12 @@ function st(t, i, v, g) {
844
844
  };
845
845
  if (l === "cutByValue")
846
846
  return (e) => {
847
- for (let n = 0; n < h.length; n++)
848
- h[n] === e && at(i, a, t, n);
847
+ for (let n = 0; n < y.length; n++)
848
+ y[n] === e && at(i, a, t, n);
849
849
  };
850
850
  if (l === "toggleByValue")
851
851
  return (e) => {
852
- const n = h.findIndex((o) => o === e);
852
+ const n = y.findIndex((o) => o === e);
853
853
  n > -1 ? at(i, a, t, n) : ut(i, e, a, t);
854
854
  };
855
855
  if (l === "stateFind")
@@ -884,7 +884,7 @@ function st(t, i, v, g) {
884
884
  }
885
885
  if (l === "get")
886
886
  return () => {
887
- if (S?.validIndices && Array.isArray(h)) {
887
+ if (S?.validIndices && Array.isArray(y)) {
888
888
  const u = r.getState().getNestedState(t, a);
889
889
  return S.validIndices.map((e) => u[e]);
890
890
  }
@@ -968,10 +968,10 @@ function st(t, i, v, g) {
968
968
  T = !0;
969
969
  break;
970
970
  }
971
- const q = x.substring(
971
+ const z = x.substring(
972
972
  V + 1
973
973
  );
974
- if (!isNaN(Number(q))) {
974
+ if (!isNaN(Number(z))) {
975
975
  const C = W.lastIndexOf(".");
976
976
  if (C !== -1) {
977
977
  const $ = W.substring(
@@ -1005,12 +1005,12 @@ function st(t, i, v, g) {
1005
1005
  throw new Error("Zod schema not found");
1006
1006
  if (!u?.key)
1007
1007
  throw new Error("Validation key not found");
1008
- z(u.key);
1008
+ q(u.key);
1009
1009
  const n = r.getState().cogsStateStore[t];
1010
1010
  try {
1011
1011
  const o = r.getState().getValidationErrors(u.key);
1012
1012
  o && o.length > 0 && o.forEach(([m]) => {
1013
- m && m.startsWith(u.key) && z(m);
1013
+ m && m.startsWith(u.key) && q(m);
1014
1014
  });
1015
1015
  const c = u.zodSchema.safeParse(n);
1016
1016
  return c.success ? !0 : (c.error.errors.forEach((d) => {
@@ -1087,7 +1087,7 @@ function st(t, i, v, g) {
1087
1087
  return s(K, O, S);
1088
1088
  }
1089
1089
  }, G = new Proxy(R, F);
1090
- return y.set(D, {
1090
+ return h.set(D, {
1091
1091
  proxy: G,
1092
1092
  stateVersion: k
1093
1093
  }), G;
@@ -1108,7 +1108,7 @@ function Lt({
1108
1108
  v,
1109
1109
  t._path
1110
1110
  ).stateMapNoRender(
1111
- (y, k, p, I, s) => t._mapFn(y, k, p, I, s)
1111
+ (h, k, p, I, s) => t._mapFn(h, k, p, I, s)
1112
1112
  ) : null;
1113
1113
  }
1114
1114
  function Bt({
@@ -1118,16 +1118,16 @@ function Bt({
1118
1118
  return gt(() => {
1119
1119
  const g = i.current;
1120
1120
  if (!g || !g.parentElement) return;
1121
- const y = g.parentElement, p = Array.from(y.childNodes).indexOf(g);
1122
- let I = y.getAttribute("data-parent-id");
1123
- I || (I = `parent-${crypto.randomUUID()}`, y.setAttribute("data-parent-id", I));
1124
- const h = {
1121
+ const h = g.parentElement, p = Array.from(h.childNodes).indexOf(g);
1122
+ let I = h.getAttribute("data-parent-id");
1123
+ I || (I = `parent-${crypto.randomUUID()}`, h.setAttribute("data-parent-id", I));
1124
+ const y = {
1125
1125
  instanceId: `instance-${crypto.randomUUID()}`,
1126
1126
  parentId: I,
1127
1127
  position: p,
1128
1128
  effect: t._effect
1129
1129
  };
1130
- r.getState().addSignalElement(v, h);
1130
+ r.getState().addSignalElement(v, y);
1131
1131
  const a = r.getState().getNestedState(t._stateKey, t._path);
1132
1132
  let S;
1133
1133
  if (t._effect)
@@ -1 +1 @@
1
- {"version":3,"file":"CogsState.jsx","sources":["../src/CogsState.tsx"],"sourcesContent":["\"use client\";\r\n\r\nimport {\r\n createElement,\r\n startTransition,\r\n useCallback,\r\n useEffect,\r\n useLayoutEffect,\r\n useMemo,\r\n useRef,\r\n useState,\r\n useSyncExternalStore,\r\n type CSSProperties,\r\n type ReactNode,\r\n type RefObject,\r\n} from \"react\";\r\n\r\nimport {\r\n debounce,\r\n getDifferences,\r\n getNestedValue,\r\n isFunction,\r\n type GenericObject,\r\n} from \"./utility.js\";\r\nimport {\r\n cutFunc,\r\n FormControlComponent,\r\n pushFunc,\r\n updateFn,\r\n ValidationWrapper,\r\n} from \"./Functions.js\";\r\nimport { isDeepEqual, transformStateFunc } from \"./utility.js\";\r\nimport superjson from \"superjson\";\r\nimport { v4 as uuidv4 } from \"uuid\";\r\nimport { z } from \"zod\";\r\n\r\nimport { formRefStore, getGlobalStore, type ComponentsType } from \"./store.js\";\r\nimport { useCogsConfig } from \"./CogsStateClient.js\";\r\nimport { applyPatch } from \"fast-json-patch\";\r\n\r\ntype Prettify<T> = { [K in keyof T]: T[K] } & {};\r\n\r\nexport type VirtualViewOptions = {\r\n itemHeight: number;\r\n overscan?: number;\r\n stickToBottom?: boolean;\r\n};\r\n\r\n// The result now returns a real StateObject\r\nexport type VirtualStateObjectResult<T extends any[]> = {\r\n /**\r\n * A new, fully-functional StateObject that represents the virtualized slice.\r\n * You can use `.get()`, `.stateMap()`, `.insert()`, `.cut()` etc. on this object.\r\n */\r\n virtualState: StateObject<T>;\r\n /**\r\n * Props to be spread onto your DOM elements to enable virtualization.\r\n */\r\n virtualizerProps: {\r\n outer: { ref: RefObject<HTMLDivElement>; style: CSSProperties };\r\n inner: { style: CSSProperties };\r\n list: { style: CSSProperties };\r\n };\r\n scrollToBottom: (behavior?: ScrollBehavior) => void;\r\n scrollToIndex: (index: number, behavior?: ScrollBehavior) => void;\r\n};\r\n\r\nexport type ServerSyncStatus = {\r\n isFresh: boolean;\r\n isFreshTime: number;\r\n isStale: boolean;\r\n isStaleTime: number;\r\n isSyncing: boolean;\r\n isSyncingTime: number;\r\n};\r\n\r\nexport type SyncInfo = {\r\n timeStamp: number;\r\n userId: number;\r\n};\r\n\r\nexport type FormElementParams<T> = {\r\n get: () => T;\r\n\r\n set: UpdateType<T>;\r\n syncStatus: (SyncInfo & { date: Date }) | null;\r\n path: string[];\r\n validationErrors: () => string[];\r\n addValidationError: (message?: string) => void;\r\n\r\n inputProps: {\r\n ref?: React.RefObject<any>;\r\n value?: T extends boolean ? never : T;\r\n onChange?: (\r\n event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>\r\n ) => void;\r\n onBlur?: () => void;\r\n };\r\n};\r\n\r\nexport type StateKeys = string;\r\n\r\ntype findWithFuncType<U> = (\r\n thisKey: keyof U,\r\n thisValue: U[keyof U]\r\n) => EndType<U> & StateObject<U>;\r\nexport type PushArgs<U, T> = (\r\n update:\r\n | Prettify<U>\r\n | ((prevState: NonNullable<Prettify<U>>[]) => NonNullable<Prettify<U>>),\r\n opts?: UpdateOpts<U>\r\n) => StateObject<T>;\r\n\r\ntype CutFunctionType<T> = (\r\n index?: number,\r\n options?: { waitForSync?: boolean }\r\n) => StateObject<T>;\r\n\r\nexport type InferArrayElement<T> = T extends (infer U)[] ? U : never;\r\ntype ArraySpecificPrototypeKeys =\r\n | \"concat\"\r\n | \"copyWithin\"\r\n | \"fill\"\r\n | \"find\"\r\n | \"findIndex\"\r\n | \"flat\"\r\n | \"flatMap\"\r\n | \"includes\"\r\n | \"indexOf\"\r\n | \"join\"\r\n | \"keys\"\r\n | \"lastIndexOf\"\r\n | \"map\"\r\n | \"pop\"\r\n | \"push\"\r\n | \"reduce\"\r\n | \"reduceRight\"\r\n | \"reverse\"\r\n | \"shift\"\r\n | \"slice\"\r\n | \"some\"\r\n | \"sort\"\r\n | \"splice\"\r\n | \"unshift\"\r\n | \"values\"\r\n | \"entries\"\r\n | \"every\"\r\n | \"filter\"\r\n | \"forEach\"\r\n | \"with\";\r\n\r\nexport type ArrayEndType<TShape extends unknown> = {\r\n findWith: findWithFuncType<InferArrayElement<TShape>>;\r\n index: (index: number) => StateObject<InferArrayElement<TShape>> & {\r\n insert: PushArgs<InferArrayElement<TShape>, TShape>;\r\n cut: CutFunctionType<TShape>;\r\n _index: number;\r\n } & EndType<InferArrayElement<TShape>>;\r\n insert: PushArgs<InferArrayElement<TShape>, TShape>;\r\n cut: CutFunctionType<TShape>;\r\n cutByValue: (value: string | number | boolean) => void;\r\n toggleByValue: (value: string | number | boolean) => void;\r\n stateSort: (\r\n compareFn: (\r\n a: InferArrayElement<TShape>,\r\n b: InferArrayElement<TShape>\r\n ) => number\r\n ) => ArrayEndType<TShape>;\r\n useVirtualView: (\r\n options: VirtualViewOptions\r\n ) => VirtualStateObjectResult<InferArrayElement<TShape>[]>;\r\n\r\n stateMapNoRender: (\r\n callbackfn: (\r\n value: InferArrayElement<TShape>,\r\n setter: StateObject<InferArrayElement<TShape>>,\r\n index: number,\r\n array: TShape,\r\n arraySetter: StateObject<TShape>\r\n ) => void\r\n ) => any;\r\n stateMap: (\r\n callbackfn: (\r\n value: InferArrayElement<TShape>,\r\n setter: StateObject<InferArrayElement<TShape>>,\r\n index: number,\r\n array: TShape,\r\n arraySetter: StateObject<TShape>\r\n ) => void\r\n ) => any;\r\n $stateMap: (\r\n callbackfn: (\r\n value: InferArrayElement<TShape>,\r\n setter: StateObject<InferArrayElement<TShape>>,\r\n index: number,\r\n array: TShape,\r\n arraySetter: StateObject<TShape>\r\n ) => void\r\n ) => any;\r\n stateFlattenOn: <K extends keyof InferArrayElement<TShape>>(\r\n field: K\r\n ) => StateObject<InferArrayElement<InferArrayElement<TShape>[K]>[]>;\r\n uniqueInsert: (\r\n payload: UpdateArg<InferArrayElement<TShape>>,\r\n fields?: (keyof InferArrayElement<TShape>)[],\r\n onMatch?: (existingItem: any) => any\r\n ) => void;\r\n stateFind: (\r\n callbackfn: (value: InferArrayElement<TShape>, index: number) => boolean\r\n ) => StateObject<InferArrayElement<TShape>> | undefined;\r\n stateFilter: (\r\n callbackfn: (value: InferArrayElement<TShape>, index: number) => void\r\n ) => ArrayEndType<TShape>;\r\n getSelected: () => StateObject<InferArrayElement<TShape>> | undefined;\r\n clearSelected: () => void;\r\n getSelectedIndex: () => number;\r\n last: () => StateObject<InferArrayElement<TShape>> | undefined;\r\n} & EndType<TShape>;\r\n\r\nexport type FormOptsType = {\r\n key?: string;\r\n validation?: {\r\n hideMessage?: boolean;\r\n message?: string;\r\n stretch?: boolean;\r\n props?: GenericObject;\r\n disable?: boolean;\r\n };\r\n formElements?: boolean;\r\n debounceTime?: number;\r\n stateServerDifferences?: string[][];\r\n};\r\n\r\nexport type FormControl<T> = (obj: FormElementParams<T>) => JSX.Element;\r\n\r\nexport type UpdateArg<S> = S | ((prevState: S) => S);\r\n\r\nexport type UpdateType<T> = (\r\n payload: UpdateArg<T>,\r\n opts?: UpdateOpts<T>\r\n) => void;\r\n\r\nexport type UpdateOpts<T> = {\r\n afterUpdate?: (state: T) => void;\r\n debounce?: number;\r\n};\r\nexport type ObjectEndType<T> = EndType<T> & {\r\n [K in keyof T]-?: ObjectEndType<T[K]>;\r\n} & {\r\n stateObject: (callbackfn: (value: T, setter: StateObject<T>) => void) => any;\r\n delete: () => void;\r\n};\r\ntype EffectFunction<T, R> = (state: T) => R;\r\nexport type EndType<T, IsArrayElement = false> = {\r\n applyJsonPatch: (patches: any[]) => void;\r\n update: UpdateType<T>;\r\n _path: string[];\r\n _stateKey: string;\r\n formElement: (control: FormControl<T>, opts?: FormOptsType) => JSX.Element;\r\n get: () => T;\r\n $get: () => T;\r\n $derive: <R>(fn: EffectFunction<T, R>) => R;\r\n _status: \"fresh\" | \"stale\" | \"synced\";\r\n getStatus: () => \"fresh\" | \"stale\";\r\n\r\n showValidationErrors: () => string[];\r\n setValidation: (ctx: string) => void;\r\n removeValidation: (ctx: string) => void;\r\n ignoreFields: (fields: string[]) => StateObject<T>;\r\n _selected: boolean;\r\n setSelected: (value: boolean) => void;\r\n toggleSelected: () => void;\r\n getFormRef: () => React.RefObject<any> | undefined;\r\n removeStorage: () => void;\r\n sync: () => void;\r\n validationWrapper: ({\r\n children,\r\n hideMessage,\r\n }: {\r\n children: React.ReactNode;\r\n hideMessage?: boolean;\r\n }) => JSX.Element;\r\n lastSynced?: SyncInfo;\r\n} & (IsArrayElement extends true ? { cut: () => void } : {});\r\n\r\nexport type StateObject<T> = (T extends any[]\r\n ? ArrayEndType<T>\r\n : T extends Record<string, unknown> | object\r\n ? { [K in keyof T]-?: StateObject<T[K]> } & ObjectEndType<T>\r\n : T extends string | number | boolean | null\r\n ? T\r\n : never) &\r\n EndType<T, true> & {\r\n getAllFormRefs: () => Map<string, React.RefObject<any>>;\r\n _componentId: string | null;\r\n getComponents: () => ComponentsType;\r\n validateZodSchema: () => void;\r\n _initialState: T;\r\n updateInitialState: (newState: T | null) => {\r\n fetchId: (field: keyof T) => string | number;\r\n };\r\n _isLoading: boolean;\r\n _serverState: T;\r\n revertToInitialState: (obj?: { validationKey?: string }) => T;\r\n getDifferences: () => string[];\r\n middleware: (\r\n middles: ({\r\n updateLog,\r\n update,\r\n }: {\r\n updateLog: UpdateTypeDetail[] | undefined;\r\n update: UpdateTypeDetail;\r\n }) => void\r\n ) => void;\r\n _isServerSynced: () => boolean;\r\n getLocalStorage: (key: string) => LocalStorageData<T> | null;\r\n };\r\n\r\nexport type CogsUpdate<T extends unknown> = UpdateType<T>;\r\n\r\nexport type EffectiveSetState<TStateObject> = (\r\n newStateOrFunction: UpdateArg<TStateObject>,\r\n path: string[],\r\n updateObj: { updateType: \"update\" | \"insert\" | \"cut\" },\r\n validationKey?: string,\r\n opts?: UpdateOpts<TStateObject>\r\n) => void;\r\n\r\nexport type UpdateTypeDetail = {\r\n timeStamp: number;\r\n stateKey: string;\r\n updateType: \"update\" | \"insert\" | \"cut\";\r\n path: string[];\r\n status: \"new\" | \"sent\" | \"synced\";\r\n oldValue: any;\r\n newValue: any;\r\n userId?: number;\r\n};\r\n\r\nexport type ActionsType<T> = {\r\n type: \"onChange\";\r\n action: ({ state, actionType }: { state: T; actionType: string }) => void;\r\n debounce?: number;\r\n}[];\r\n\r\ntype ArrayToObject<T extends string[]> = Record<T[number], string>;\r\ntype CookieType<T> = {\r\n timeStamp: number;\r\n value: T;\r\n cookieName: string;\r\n OnUnMountCookie?: Boolean;\r\n};\r\nexport type CogsCookiesType<T extends string[] = string[]> = CookieType<\r\n ArrayToObject<T>\r\n>;\r\nexport type ReactivityType = \"none\" | \"component\" | \"deps\" | \"all\";\r\n\r\ntype ValidationOptionsType = {\r\n key?: string;\r\n zodSchema?: z.ZodTypeAny;\r\n onBlur?: boolean;\r\n};\r\n\r\nexport type OptionsType<T extends unknown = unknown> = {\r\n log?: boolean;\r\n componentId?: string;\r\n serverSync?: ServerSyncType<T>;\r\n validation?: ValidationOptionsType;\r\n enableServerState?: boolean;\r\n serverState?: {\r\n id?: string | number;\r\n data?: T;\r\n status?: \"pending\" | \"error\" | \"success\";\r\n };\r\n sync?: {\r\n action: (state: T) => Promise<{\r\n success: boolean;\r\n data?: any;\r\n error?: any;\r\n errors?: Array<{\r\n path: (string | number)[];\r\n message: string;\r\n }>;\r\n }>;\r\n onSuccess?: (data: any) => void;\r\n onError?: (error: any) => void;\r\n };\r\n middleware?: ({\r\n updateLog,\r\n update,\r\n }: {\r\n updateLog: UpdateTypeDetail[] | undefined;\r\n update: UpdateTypeDetail;\r\n }) => void;\r\n\r\n modifyState?: (state: T) => T;\r\n localStorage?: {\r\n key: string | ((state: T) => string);\r\n onChange?: (state: T) => void;\r\n };\r\n formElements?: FormsElementsType;\r\n enabledSync?: (state: T) => boolean;\r\n reactiveDeps?: (state: T) => any[] | true;\r\n reactiveType?: ReactivityType[] | ReactivityType;\r\n syncUpdate?: Partial<UpdateTypeDetail>;\r\n\r\n initialState?: T;\r\n dependencies?: any[];\r\n};\r\nexport type ServerSyncType<T> = {\r\n testKey?: string;\r\n syncKey: (({ state }: { state: T }) => string) | string;\r\n syncFunction: ({ state }: { state: T }) => void;\r\n debounce?: number;\r\n\r\n snapshot?: {\r\n name: (({ state }: { state: T }) => string) | string;\r\n stateKeys: StateKeys[];\r\n currentUrl: string;\r\n currentParams?: URLSearchParams;\r\n };\r\n};\r\nexport type SyncActionsType<T> = {\r\n syncKey: string;\r\n\r\n rollBackState?: T;\r\n actionTimeStamp: number;\r\n retryCount?: number;\r\n status:\r\n | \"success\"\r\n | \"waiting\"\r\n | \"rolledBack\"\r\n | \"error\"\r\n | \"cancelled\"\r\n | \"failed\";\r\n snapshot?: {\r\n name: string;\r\n stateKeys: StateKeys[];\r\n currentUrl: string;\r\n currentParams?: URLSearchParams;\r\n };\r\n};\r\n\r\nexport type ValidationWrapperOptions<T extends unknown = unknown> = {\r\n children: React.ReactNode;\r\n active: boolean;\r\n stretch?: boolean;\r\n path: string[];\r\n message?: string;\r\n data?: T;\r\n key?: string;\r\n};\r\nexport type SyncRenderOptions<T extends unknown = unknown> = {\r\n children: React.ReactNode;\r\n time: number;\r\n data?: T;\r\n key?: string;\r\n};\r\n\r\ntype FormsElementsType<T extends unknown = unknown> = {\r\n validation?: (options: ValidationWrapperOptions<T>) => React.ReactNode;\r\n syncRender?: (options: SyncRenderOptions<T>) => React.ReactNode;\r\n};\r\n\r\nexport type InitialStateInnerType<T extends unknown = unknown> = {\r\n initialState: T;\r\n} & OptionsType<T>;\r\n\r\nexport type InitialStateType<T> = {\r\n [key: string]: InitialStateInnerType<T>;\r\n};\r\n\r\nexport type AllStateTypes<T extends unknown> = Record<string, T>;\r\n\r\nexport type CogsInitialState<T> = {\r\n initialState: T;\r\n formElements?: FormsElementsType<T>;\r\n};\r\n\r\nexport type TransformedStateType<T> = {\r\n [P in keyof T]: T[P] extends CogsInitialState<infer U> ? U : T[P];\r\n};\r\n\r\nfunction setAndMergeOptions(stateKey: string, newOptions: OptionsType<any>) {\r\n const getInitialOptions = getGlobalStore.getState().getInitialOptions;\r\n const setInitialStateOptions =\r\n getGlobalStore.getState().setInitialStateOptions;\r\n\r\n const initialOptions = getInitialOptions(stateKey as string) || {};\r\n\r\n setInitialStateOptions(stateKey as string, {\r\n ...initialOptions,\r\n ...newOptions,\r\n });\r\n}\r\n\r\n// Fix for the setOptions function\r\nfunction setOptions<StateKey, Opt>({\r\n stateKey,\r\n options,\r\n initialOptionsPart,\r\n}: {\r\n stateKey: StateKey;\r\n options?: OptionsType<any>;\r\n initialOptionsPart: Record<string, any>;\r\n}) {\r\n const initialOptions = getInitialOptions(stateKey as string) || {};\r\n const initialOptionsPartState = initialOptionsPart[stateKey as string] || {};\r\n const setInitialStateOptions =\r\n getGlobalStore.getState().setInitialStateOptions;\r\n const mergedOptions = { ...initialOptionsPartState, ...initialOptions };\r\n\r\n let needToAdd = false;\r\n if (options) {\r\n for (const key in options) {\r\n if (!mergedOptions.hasOwnProperty(key)) {\r\n needToAdd = true;\r\n mergedOptions[key] = options[key as keyof typeof options];\r\n } else {\r\n if (\r\n key == \"localStorage\" &&\r\n options[key] &&\r\n mergedOptions[key].key !== options[key]?.key\r\n ) {\r\n needToAdd = true;\r\n mergedOptions[key] = options[key];\r\n }\r\n if (\r\n key == \"initialState\" &&\r\n options[key] &&\r\n mergedOptions[key] !== options[key] && // Different references\r\n !isDeepEqual(mergedOptions[key], options[key]) // And different values\r\n ) {\r\n needToAdd = true;\r\n mergedOptions[key] = options[key];\r\n }\r\n }\r\n }\r\n }\r\n\r\n if (needToAdd) {\r\n setInitialStateOptions(stateKey as string, mergedOptions);\r\n }\r\n}\r\nexport function addStateOptions<T extends unknown>(\r\n initialState: T,\r\n { formElements, validation }: OptionsType<T>\r\n) {\r\n return { initialState: initialState, formElements, validation } as T;\r\n}\r\n\r\nexport const createCogsState = <State extends Record<string, unknown>>(\r\n initialState: State,\r\n opt?: { formElements?: FormsElementsType; validation?: ValidationOptionsType }\r\n) => {\r\n let newInitialState = initialState;\r\n\r\n // Extract state parts and options using transformStateFunc\r\n const [statePart, initialOptionsPart] =\r\n transformStateFunc<State>(newInitialState);\r\n\r\n // Apply global formElements as defaults to each state key's options\r\n if (\r\n Object.keys(initialOptionsPart).length > 0 ||\r\n (opt && Object.keys(opt).length > 0)\r\n ) {\r\n Object.keys(initialOptionsPart).forEach((key) => {\r\n // Get the existing options for this state key\r\n initialOptionsPart[key] = initialOptionsPart[key] || {};\r\n\r\n initialOptionsPart[key].formElements = {\r\n ...opt?.formElements, // Global defaults first\r\n ...opt?.validation,\r\n ...(initialOptionsPart[key].formElements || {}), // State-specific overrides\r\n };\r\n const existingOptions = getInitialOptions(key);\r\n\r\n if (!existingOptions) {\r\n getGlobalStore\r\n .getState()\r\n .setInitialStateOptions(key, initialOptionsPart[key]);\r\n }\r\n });\r\n }\r\n\r\n getGlobalStore.getState().setInitialStates(statePart);\r\n getGlobalStore.getState().setCreatedState(statePart);\r\n type StateKeys = keyof typeof statePart;\r\n\r\n const useCogsState = <StateKey extends StateKeys>(\r\n stateKey: StateKey,\r\n options?: OptionsType<(typeof statePart)[StateKey]>\r\n ) => {\r\n const [componentId] = useState(options?.componentId ?? uuidv4());\r\n\r\n setOptions({\r\n stateKey,\r\n options,\r\n initialOptionsPart,\r\n });\r\n\r\n const thiState =\r\n getGlobalStore.getState().cogsStateStore[stateKey as string] ||\r\n statePart[stateKey as string];\r\n const partialState = options?.modifyState\r\n ? options.modifyState(thiState)\r\n : thiState;\r\n\r\n const [state, updater] = useCogsStateFn<(typeof statePart)[StateKey]>(\r\n partialState,\r\n {\r\n stateKey: stateKey as string,\r\n syncUpdate: options?.syncUpdate,\r\n componentId,\r\n localStorage: options?.localStorage,\r\n middleware: options?.middleware,\r\n enabledSync: options?.enabledSync,\r\n reactiveType: options?.reactiveType,\r\n reactiveDeps: options?.reactiveDeps,\r\n initialState: options?.initialState as any,\r\n dependencies: options?.dependencies,\r\n serverState: options?.serverState,\r\n }\r\n );\r\n\r\n return updater;\r\n };\r\n\r\n function setCogsOptions<StateKey extends StateKeys>(\r\n stateKey: StateKey,\r\n options: OptionsType<(typeof statePart)[StateKey]>\r\n ) {\r\n setOptions({ stateKey, options, initialOptionsPart });\r\n\r\n if (options.localStorage) {\r\n loadAndApplyLocalStorage(stateKey as string, options);\r\n }\r\n\r\n notifyComponents(stateKey as string);\r\n }\r\n\r\n return { useCogsState, setCogsOptions };\r\n};\r\n\r\nconst {\r\n setUpdaterState,\r\n setState,\r\n getInitialOptions,\r\n getKeyState,\r\n getValidationErrors,\r\n setStateLog,\r\n updateInitialStateGlobal,\r\n addValidationError,\r\n removeValidationError,\r\n setServerSyncActions,\r\n} = getGlobalStore.getState();\r\nconst saveToLocalStorage = <T,>(\r\n state: T,\r\n thisKey: string,\r\n currentInitialOptions: any,\r\n sessionId?: string,\r\n lastSyncedWithServer?: number\r\n) => {\r\n if (currentInitialOptions?.log) {\r\n console.log(\r\n \"saving to localstorage\",\r\n thisKey,\r\n currentInitialOptions.localStorage?.key,\r\n sessionId\r\n );\r\n }\r\n\r\n const key = isFunction(currentInitialOptions?.localStorage?.key)\r\n ? currentInitialOptions.localStorage?.key(state)\r\n : currentInitialOptions?.localStorage?.key;\r\n\r\n if (key && sessionId) {\r\n const storageKey = `${sessionId}-${thisKey}-${key}`;\r\n\r\n // Get existing data to preserve lastSyncedWithServer if not explicitly updating it\r\n let existingLastSynced: number | undefined;\r\n try {\r\n const existing = loadFromLocalStorage(storageKey);\r\n existingLastSynced = existing?.lastSyncedWithServer;\r\n } catch {\r\n // Ignore errors, will use undefined\r\n }\r\n\r\n const data: LocalStorageData<T> = {\r\n state,\r\n lastUpdated: Date.now(),\r\n lastSyncedWithServer: lastSyncedWithServer ?? existingLastSynced,\r\n };\r\n\r\n // Use SuperJSON serialize to get the json part only\r\n const superJsonResult = superjson.serialize(data);\r\n window.localStorage.setItem(\r\n storageKey,\r\n JSON.stringify(superJsonResult.json)\r\n );\r\n }\r\n};\r\n\r\nconst loadFromLocalStorage = (localStorageKey: string) => {\r\n if (!localStorageKey) return null;\r\n\r\n try {\r\n const storedData = window.localStorage.getItem(localStorageKey);\r\n if (!storedData) return null;\r\n\r\n // Parse the json part back normally\r\n const parsedData = JSON.parse(storedData);\r\n\r\n return parsedData;\r\n } catch (error) {\r\n console.error(\"Error loading from localStorage:\", error);\r\n return null;\r\n }\r\n};\r\nconst loadAndApplyLocalStorage = (stateKey: string, options: any) => {\r\n const currentState = getGlobalStore.getState().cogsStateStore[stateKey];\r\n const { sessionId } = useCogsConfig();\r\n const localkey = isFunction(options?.localStorage?.key)\r\n ? options.localStorage.key(currentState)\r\n : options?.localStorage?.key;\r\n\r\n if (localkey && sessionId) {\r\n const localData = loadFromLocalStorage(\r\n `${sessionId}-${stateKey}-${localkey}`\r\n );\r\n\r\n if (\r\n localData &&\r\n localData.lastUpdated > (localData.lastSyncedWithServer || 0)\r\n ) {\r\n setState(stateKey, localData.state);\r\n\r\n notifyComponents(stateKey);\r\n return true;\r\n }\r\n }\r\n return false;\r\n};\r\n\r\ntype LocalStorageData<T> = {\r\n state: T;\r\n lastUpdated: number;\r\n lastSyncedWithServer?: number;\r\n baseServerState?: T; // Add this to track what server state our changes are based on\r\n};\r\n\r\nconst updateGlobalState = (\r\n thisKey: string,\r\n initialState: any,\r\n newState: any,\r\n effectiveSetState: EffectiveSetState<any>,\r\n componentId: string,\r\n sessionId?: string\r\n) => {\r\n // Update all global state at once\r\n const updates = {\r\n initialState: initialState,\r\n updaterState: createProxyHandler(\r\n thisKey,\r\n effectiveSetState,\r\n componentId,\r\n sessionId\r\n ),\r\n state: newState,\r\n };\r\n\r\n updateInitialStateGlobal(thisKey, updates.initialState);\r\n setUpdaterState(thisKey, updates.updaterState);\r\n setState(thisKey, updates.state);\r\n};\r\n\r\nconst notifyComponents = (thisKey: string) => {\r\n const stateEntry = getGlobalStore.getState().stateComponents.get(thisKey);\r\n if (!stateEntry) return;\r\n\r\n // Batch component updates\r\n const updates = new Set<() => void>();\r\n stateEntry.components.forEach((component) => {\r\n const reactiveTypes = component\r\n ? Array.isArray(component.reactiveType)\r\n ? component.reactiveType\r\n : [component.reactiveType || \"component\"]\r\n : null;\r\n if (!reactiveTypes?.includes(\"none\")) {\r\n updates.add(() => component.forceUpdate());\r\n }\r\n });\r\n\r\n // Schedule updates in the next tick to allow batching\r\n queueMicrotask(() => {\r\n updates.forEach((update) => update());\r\n });\r\n};\r\n\r\nexport const notifyComponent = (stateKey: string, componentId: string) => {\r\n const stateEntry = getGlobalStore.getState().stateComponents.get(stateKey);\r\n if (stateEntry) {\r\n const fullComponentId = `${stateKey}////${componentId}`;\r\n const component = stateEntry.components.get(fullComponentId);\r\n const reactiveTypes = component\r\n ? Array.isArray(component.reactiveType)\r\n ? component.reactiveType\r\n : [component.reactiveType || \"component\"]\r\n : null;\r\n\r\n // Skip if reactivity is disabled\r\n if (reactiveTypes?.includes(\"none\")) {\r\n return;\r\n }\r\n\r\n if (component) {\r\n // Force an update to ensure the current value is saved\r\n\r\n component.forceUpdate();\r\n }\r\n }\r\n};\r\nconst getUpdateValues = (\r\n updateType: string,\r\n prevValue: any,\r\n payload: any,\r\n path: string[]\r\n) => {\r\n switch (updateType) {\r\n case \"update\":\r\n return {\r\n oldValue: getNestedValue(prevValue, path),\r\n newValue: getNestedValue(payload, path),\r\n };\r\n case \"insert\":\r\n return {\r\n oldValue: null, // or undefined\r\n newValue: getNestedValue(payload, path),\r\n };\r\n case \"cut\":\r\n return {\r\n oldValue: getNestedValue(prevValue, path),\r\n newValue: null, // or undefined\r\n };\r\n default:\r\n return { oldValue: null, newValue: null };\r\n }\r\n};\r\nexport function useCogsStateFn<TStateObject extends unknown>(\r\n stateObject: TStateObject,\r\n {\r\n stateKey,\r\n serverSync,\r\n localStorage,\r\n formElements,\r\n reactiveDeps,\r\n reactiveType,\r\n componentId,\r\n initialState,\r\n syncUpdate,\r\n dependencies,\r\n serverState,\r\n }: {\r\n stateKey?: string;\r\n componentId?: string;\r\n initialState?: TStateObject;\r\n } & OptionsType<TStateObject> = {}\r\n) {\r\n const [reactiveForce, forceUpdate] = useState({}); //this is the key to reactivity\r\n const { sessionId } = useCogsConfig();\r\n\r\n let noStateKey = stateKey ? false : true;\r\n const [thisKey] = useState(stateKey ?? uuidv4());\r\n const stateLog = getGlobalStore.getState().stateLog[thisKey];\r\n const componentUpdatesRef = useRef(new Set<string>());\r\n const componentIdRef = useRef(componentId ?? uuidv4());\r\n const latestInitialOptionsRef = useRef<OptionsType<TStateObject> | null>(\r\n null\r\n );\r\n latestInitialOptionsRef.current = (getInitialOptions(thisKey as string) ??\r\n null) as OptionsType<TStateObject> | null;\r\n\r\n useEffect(() => {\r\n if (syncUpdate && syncUpdate.stateKey === thisKey && syncUpdate.path?.[0]) {\r\n // Update the actual state value\r\n setState(thisKey, (prevState: any) => ({\r\n ...prevState,\r\n [syncUpdate.path![0]!]: syncUpdate.newValue,\r\n }));\r\n\r\n // Create combined key and update sync info\r\n const syncKey = `${syncUpdate.stateKey}:${syncUpdate.path.join(\".\")}`;\r\n getGlobalStore.getState().setSyncInfo(syncKey, {\r\n timeStamp: syncUpdate.timeStamp!,\r\n userId: syncUpdate.userId!,\r\n });\r\n }\r\n }, [syncUpdate]);\r\n useEffect(() => {\r\n // Only proceed if initialState is provided\r\n if (initialState) {\r\n setAndMergeOptions(thisKey as string, {\r\n initialState,\r\n });\r\n\r\n const options = latestInitialOptionsRef.current;\r\n const hasServerId = options?.serverState?.id !== undefined;\r\n const hasServerData =\r\n hasServerId &&\r\n options?.serverState?.status === \"success\" &&\r\n options?.serverState?.data;\r\n\r\n const currentGloballyStoredInitialState =\r\n getGlobalStore.getState().initialStateGlobal[thisKey];\r\n\r\n const initialStateChanged =\r\n (currentGloballyStoredInitialState &&\r\n !isDeepEqual(currentGloballyStoredInitialState, initialState)) ||\r\n !currentGloballyStoredInitialState;\r\n\r\n if (!initialStateChanged && !hasServerData) {\r\n return;\r\n }\r\n\r\n let localData = null;\r\n const localkey = isFunction(options?.localStorage?.key)\r\n ? options?.localStorage?.key(initialState)\r\n : options?.localStorage?.key;\r\n\r\n if (localkey && sessionId) {\r\n localData = loadFromLocalStorage(`${sessionId}-${thisKey}-${localkey}`);\r\n }\r\n\r\n let newState = initialState;\r\n let isFromServer = false;\r\n\r\n const serverTimestamp = hasServerData ? Date.now() : 0;\r\n const localTimestamp = localData?.lastUpdated || 0;\r\n const lastSyncTimestamp = localData?.lastSyncedWithServer || 0;\r\n\r\n if (hasServerData && serverTimestamp > localTimestamp) {\r\n newState = options.serverState!.data!;\r\n isFromServer = true;\r\n } else if (localData && localTimestamp > lastSyncTimestamp) {\r\n newState = localData.state;\r\n if (options?.localStorage?.onChange) {\r\n options?.localStorage?.onChange(newState);\r\n }\r\n }\r\n getGlobalStore.getState().initializeShadowState(thisKey, initialState);\r\n // Update the global state\r\n updateGlobalState(\r\n thisKey,\r\n initialState,\r\n newState,\r\n effectiveSetState,\r\n componentIdRef.current,\r\n sessionId\r\n );\r\n\r\n // Save to localStorage if we used server data\r\n if (isFromServer && localkey && sessionId) {\r\n saveToLocalStorage(newState, thisKey, options, sessionId, Date.now());\r\n }\r\n\r\n // Notify components of the change\r\n notifyComponents(thisKey);\r\n\r\n const reactiveTypes = Array.isArray(reactiveType)\r\n ? reactiveType\r\n : [reactiveType || \"component\"];\r\n\r\n if (!reactiveTypes.includes(\"none\")) {\r\n forceUpdate({});\r\n }\r\n }\r\n }, [\r\n initialState,\r\n serverState?.status,\r\n serverState?.data,\r\n ...(dependencies || []),\r\n ]);\r\n useLayoutEffect(() => {\r\n if (noStateKey) {\r\n setAndMergeOptions(thisKey as string, {\r\n serverSync,\r\n formElements,\r\n initialState,\r\n localStorage,\r\n middleware: latestInitialOptionsRef.current?.middleware,\r\n });\r\n }\r\n\r\n const componentKey = `${thisKey}////${componentIdRef.current}`;\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(thisKey) || {\r\n components: new Map(),\r\n };\r\n\r\n stateEntry.components.set(componentKey, {\r\n forceUpdate: () => forceUpdate({}),\r\n paths: new Set(),\r\n deps: [],\r\n depsFunction: reactiveDeps || undefined,\r\n reactiveType: reactiveType ?? [\"component\", \"deps\"],\r\n });\r\n\r\n getGlobalStore.getState().stateComponents.set(thisKey, stateEntry);\r\n //need to force update to create the stateUpdates references\r\n forceUpdate({});\r\n return () => {\r\n if (stateEntry) {\r\n stateEntry.components.delete(componentKey);\r\n if (stateEntry.components.size === 0) {\r\n getGlobalStore.getState().stateComponents.delete(thisKey);\r\n }\r\n }\r\n };\r\n }, []);\r\n\r\n const effectiveSetState = (\r\n newStateOrFunction: UpdateArg<TStateObject>,\r\n path: string[],\r\n updateObj: { updateType: \"insert\" | \"cut\" | \"update\" },\r\n validationKey?: string\r\n ) => {\r\n if (Array.isArray(path)) {\r\n const pathKey = `${thisKey}-${path.join(\".\")}`;\r\n componentUpdatesRef.current.add(pathKey);\r\n }\r\n setState(thisKey, (prevValue: TStateObject) => {\r\n const payload = isFunction<TStateObject>(newStateOrFunction)\r\n ? newStateOrFunction(prevValue as TStateObject)\r\n : newStateOrFunction;\r\n\r\n const signalId = `${thisKey}-${path.join(\".\")}`;\r\n if (signalId) {\r\n let isArrayOperation = false;\r\n let elements = getGlobalStore\r\n .getState()\r\n .signalDomElements.get(signalId);\r\n\r\n if (\r\n (!elements || elements.size === 0) &&\r\n (updateObj.updateType === \"insert\" || updateObj.updateType === \"cut\")\r\n ) {\r\n // Remove last segment (index) from path\r\n const arrayPath = path.slice(0, -1);\r\n const arrayValue = getNestedValue(payload, arrayPath);\r\n // If it's an array, use that path for signal\r\n if (Array.isArray(arrayValue)) {\r\n isArrayOperation = true;\r\n const arraySignalId = `${thisKey}-${arrayPath.join(\".\")}`;\r\n elements = getGlobalStore\r\n .getState()\r\n .signalDomElements.get(arraySignalId);\r\n }\r\n }\r\n\r\n if (elements) {\r\n const newValue = isArrayOperation\r\n ? getNestedValue(payload, path.slice(0, -1))\r\n : getNestedValue(payload, path);\r\n elements.forEach(({ parentId, position, effect }) => {\r\n const parent = document.querySelector(\r\n `[data-parent-id=\"${parentId}\"]`\r\n );\r\n if (parent) {\r\n const childNodes = Array.from(parent.childNodes);\r\n if (childNodes[position]) {\r\n const displayValue = effect\r\n ? new Function(\"state\", `return (${effect})(state)`)(newValue)\r\n : newValue;\r\n childNodes[position].textContent = String(displayValue);\r\n }\r\n }\r\n });\r\n }\r\n }\r\n\r\n const shadowUpdate = () => {\r\n const store = getGlobalStore.getState();\r\n\r\n switch (updateObj.updateType) {\r\n case \"update\":\r\n // For updates, just mirror the structure at the path\r\n store.updateShadowAtPath(thisKey, path, payload);\r\n break;\r\n\r\n case \"insert\":\r\n // For array insert, add empty element to shadow array\r\n const parentPath = path.slice(0, -1);\r\n store.insertShadowArrayElement(thisKey, parentPath);\r\n break;\r\n\r\n case \"cut\":\r\n // For array cut, remove element from shadow array\r\n const arrayPath = path.slice(0, -1);\r\n const index = parseInt(path[path.length - 1]!);\r\n store.removeShadowArrayElement(thisKey, arrayPath, index);\r\n break;\r\n }\r\n };\r\n\r\n shadowUpdate();\r\n console.log(\"shadowState\", getGlobalStore.getState().shadowStateStore);\r\n if (\r\n updateObj.updateType === \"update\" &&\r\n (validationKey || latestInitialOptionsRef.current?.validation?.key) &&\r\n path\r\n ) {\r\n removeValidationError(\r\n (validationKey || latestInitialOptionsRef.current?.validation?.key) +\r\n \".\" +\r\n path.join(\".\")\r\n );\r\n }\r\n const arrayWithoutIndex = path.slice(0, path.length - 1);\r\n if (\r\n updateObj.updateType === \"cut\" &&\r\n latestInitialOptionsRef.current?.validation?.key\r\n ) {\r\n removeValidationError(\r\n latestInitialOptionsRef.current?.validation?.key +\r\n \".\" +\r\n arrayWithoutIndex.join(\".\")\r\n );\r\n }\r\n if (\r\n updateObj.updateType === \"insert\" &&\r\n latestInitialOptionsRef.current?.validation?.key\r\n ) {\r\n let getValidation = getValidationErrors(\r\n latestInitialOptionsRef.current?.validation?.key +\r\n \".\" +\r\n arrayWithoutIndex.join(\".\")\r\n );\r\n\r\n //TODO this is untested its supposed to cahnge teh validation errors alreaady stored when a new entry is push\r\n\r\n getValidation.filter(([k, v]) => {\r\n let length = k?.split(\".\").length;\r\n\r\n if (\r\n k == arrayWithoutIndex.join(\".\") &&\r\n length == arrayWithoutIndex.length - 1\r\n ) {\r\n // console.log(length, pathWithoutIndex.length);\r\n let newKey = k + \".\" + arrayWithoutIndex;\r\n removeValidationError(k!);\r\n addValidationError(newKey, v!);\r\n }\r\n });\r\n }\r\n\r\n const stateEntry = getGlobalStore.getState().stateComponents.get(thisKey);\r\n console.log(\"stateEntry >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>\", stateEntry);\r\n if (stateEntry) {\r\n const changedPaths = getDifferences(prevValue, payload);\r\n const changedPathsSet = new Set(changedPaths);\r\n const primaryPathToCheck =\r\n updateObj.updateType === \"update\"\r\n ? path.join(\".\")\r\n : path.slice(0, -1).join(\".\") || \"\";\r\n\r\n for (const [\r\n componentKey,\r\n component,\r\n ] of stateEntry.components.entries()) {\r\n let shouldUpdate = false;\r\n const reactiveTypes = Array.isArray(component.reactiveType)\r\n ? component.reactiveType\r\n : [component.reactiveType || \"component\"];\r\n console.log(\"component\", component);\r\n if (reactiveTypes.includes(\"none\")) continue;\r\n if (reactiveTypes.includes(\"all\")) {\r\n component.forceUpdate();\r\n continue;\r\n }\r\n\r\n if (reactiveTypes.includes(\"component\")) {\r\n if (\r\n component.paths.has(primaryPathToCheck) ||\r\n component.paths.has(\"\")\r\n ) {\r\n shouldUpdate = true;\r\n }\r\n\r\n if (!shouldUpdate) {\r\n for (const changedPath of changedPathsSet) {\r\n let currentPathToCheck = changedPath;\r\n while (true) {\r\n if (component.paths.has(currentPathToCheck)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n const lastDotIndex = currentPathToCheck.lastIndexOf(\".\");\r\n if (lastDotIndex !== -1) {\r\n const parentPath = currentPathToCheck.substring(\r\n 0,\r\n lastDotIndex\r\n );\r\n if (\r\n !isNaN(\r\n Number(currentPathToCheck.substring(lastDotIndex + 1))\r\n )\r\n ) {\r\n if (component.paths.has(parentPath)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n }\r\n currentPathToCheck = parentPath;\r\n } else {\r\n currentPathToCheck = \"\";\r\n }\r\n if (currentPathToCheck === \"\") {\r\n break;\r\n }\r\n }\r\n if (shouldUpdate) break;\r\n }\r\n }\r\n }\r\n\r\n if (!shouldUpdate && reactiveTypes.includes(\"deps\")) {\r\n if (component.depsFunction) {\r\n const depsResult = component.depsFunction(payload);\r\n let depsChanged = false;\r\n if (typeof depsResult === \"boolean\") {\r\n if (depsResult) depsChanged = true;\r\n } else if (!isDeepEqual(component.deps, depsResult)) {\r\n component.deps = depsResult;\r\n depsChanged = true;\r\n }\r\n if (depsChanged) {\r\n shouldUpdate = true;\r\n }\r\n }\r\n }\r\n if (shouldUpdate) {\r\n component.forceUpdate();\r\n }\r\n }\r\n }\r\n const timeStamp = Date.now();\r\n\r\n path = path.map((p, i) => {\r\n const arrayPath = path.slice(0, -1);\r\n const arrayValue = getNestedValue(payload, arrayPath);\r\n\r\n return i === path.length - 1 &&\r\n [\"insert\", \"cut\"].includes(updateObj.updateType)\r\n ? (arrayValue.length - 1).toString()\r\n : p;\r\n });\r\n\r\n const { oldValue, newValue } = getUpdateValues(\r\n updateObj.updateType,\r\n prevValue,\r\n payload,\r\n path\r\n );\r\n const newUpdate = {\r\n timeStamp,\r\n stateKey: thisKey,\r\n path,\r\n updateType: updateObj.updateType,\r\n status: \"new\" as const,\r\n oldValue,\r\n newValue,\r\n } satisfies UpdateTypeDetail;\r\n\r\n setStateLog(thisKey, (prevLogs) => {\r\n const logs = [...(prevLogs ?? []), newUpdate];\r\n\r\n // Aggregate the updates by stateKey and path\r\n const aggregatedLogs = logs.reduce((acc, log) => {\r\n const uniqueKey = `${log.stateKey}:${JSON.stringify(log.path)}`;\r\n const existing = acc.get(uniqueKey);\r\n\r\n if (existing) {\r\n // Update the existing entry with the most recent details\r\n existing.timeStamp = Math.max(existing.timeStamp, log.timeStamp);\r\n existing.newValue = log.newValue; // Overwrite with the latest value\r\n existing.oldValue = existing.oldValue ?? log.oldValue; // Retain the initial oldValue\r\n existing.updateType = log.updateType; // Update to the most recent type\r\n } else {\r\n // Add the log if no existing match is found\r\n acc.set(uniqueKey, { ...(log as any) });\r\n }\r\n\r\n return acc;\r\n }, new Map<string, typeof newUpdate>());\r\n\r\n // Convert the aggregated map back to an array\r\n return Array.from(aggregatedLogs.values());\r\n });\r\n\r\n saveToLocalStorage(\r\n payload,\r\n thisKey,\r\n latestInitialOptionsRef.current,\r\n sessionId\r\n );\r\n\r\n if (latestInitialOptionsRef.current?.middleware) {\r\n latestInitialOptionsRef.current!.middleware({\r\n updateLog: stateLog,\r\n update: newUpdate,\r\n });\r\n }\r\n if (latestInitialOptionsRef.current?.serverSync) {\r\n const serverStateStore = getGlobalStore.getState().serverState[thisKey];\r\n const serverSync = latestInitialOptionsRef.current?.serverSync;\r\n setServerSyncActions(thisKey, {\r\n syncKey:\r\n typeof serverSync.syncKey == \"string\"\r\n ? serverSync.syncKey\r\n : serverSync.syncKey({ state: payload }),\r\n rollBackState: serverStateStore,\r\n actionTimeStamp: Date.now() + (serverSync.debounce ?? 3000),\r\n status: \"waiting\",\r\n });\r\n }\r\n\r\n return payload;\r\n });\r\n };\r\n if (!getGlobalStore.getState().updaterState[thisKey]) {\r\n setUpdaterState(\r\n thisKey,\r\n createProxyHandler(\r\n thisKey,\r\n effectiveSetState,\r\n componentIdRef.current,\r\n sessionId\r\n )\r\n );\r\n if (!getGlobalStore.getState().cogsStateStore[thisKey]) {\r\n setState(thisKey, stateObject);\r\n }\r\n if (!getGlobalStore.getState().initialStateGlobal[thisKey]) {\r\n updateInitialStateGlobal(thisKey, stateObject);\r\n }\r\n }\r\n\r\n const updaterFinal = useMemo(() => {\r\n // Create proxy with baseObject as target\r\n return createProxyHandler<TStateObject>(\r\n thisKey,\r\n effectiveSetState,\r\n componentIdRef.current,\r\n sessionId\r\n );\r\n }, [thisKey, sessionId]);\r\n\r\n return [getKeyState(thisKey), updaterFinal] as [\r\n TStateObject,\r\n StateObject<TStateObject>,\r\n ];\r\n}\r\n\r\nfunction createProxyHandler<T>(\r\n stateKey: string,\r\n effectiveSetState: EffectiveSetState<T>,\r\n componentId: string,\r\n sessionId?: string\r\n): StateObject<T> {\r\n // ADDED: Enhanced cache with versioning\r\n type CacheEntry = {\r\n proxy: any;\r\n stateVersion: number;\r\n };\r\n const shapeCache = new Map<string, CacheEntry>();\r\n let stateVersion = 0;\r\n\r\n // ADDED: Cache invalidation helper\r\n const invalidateCachePath = (path: string[]) => {\r\n const pathKey = path.join(\".\");\r\n for (const [key] of shapeCache) {\r\n if (key === pathKey || key.startsWith(pathKey + \".\")) {\r\n shapeCache.delete(key);\r\n }\r\n }\r\n stateVersion++;\r\n };\r\n\r\n const baseObj = {\r\n removeValidation: (obj?: { validationKey?: string }) => {\r\n if (obj?.validationKey) {\r\n removeValidationError(obj.validationKey);\r\n }\r\n },\r\n\r\n revertToInitialState: (obj?: { validationKey?: string }) => {\r\n const init = getGlobalStore\r\n .getState()\r\n .getInitialOptions(stateKey)?.validation;\r\n if (init?.key) {\r\n removeValidationError(init?.key);\r\n }\r\n\r\n if (obj?.validationKey) {\r\n removeValidationError(obj.validationKey);\r\n }\r\n\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n\r\n getGlobalStore.getState().clearSelectedIndexesForState(stateKey);\r\n // ADDED: Clear cache on revert\r\n shapeCache.clear();\r\n stateVersion++;\r\n\r\n const newProxy = rebuildStateShape(initialState, []);\r\n const initalOptionsGet = getInitialOptions(stateKey as string);\r\n const localKey = isFunction(initalOptionsGet?.localStorage?.key)\r\n ? initalOptionsGet?.localStorage?.key(initialState)\r\n : initalOptionsGet?.localStorage?.key;\r\n\r\n const storageKey = `${sessionId}-${stateKey}-${localKey}`;\r\n\r\n if (storageKey) {\r\n localStorage.removeItem(storageKey);\r\n }\r\n\r\n setUpdaterState(stateKey, newProxy);\r\n setState(stateKey, initialState);\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n if (stateEntry) {\r\n stateEntry.components.forEach((component) => {\r\n component.forceUpdate();\r\n });\r\n }\r\n\r\n return initialState;\r\n },\r\n updateInitialState: (newState: T) => {\r\n // ADDED: Clear cache on initial state update\r\n shapeCache.clear();\r\n stateVersion++;\r\n\r\n const newUpdaterState = createProxyHandler(\r\n stateKey,\r\n effectiveSetState,\r\n componentId,\r\n sessionId\r\n );\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n const initalOptionsGet = getInitialOptions(stateKey as string);\r\n const localKey = isFunction(initalOptionsGet?.localStorage?.key)\r\n ? initalOptionsGet?.localStorage?.key(initialState)\r\n : initalOptionsGet?.localStorage?.key;\r\n\r\n const storageKey = `${sessionId}-${stateKey}-${localKey}`;\r\n\r\n if (localStorage.getItem(storageKey)) {\r\n localStorage.removeItem(storageKey);\r\n }\r\n startTransition(() => {\r\n updateInitialStateGlobal(stateKey, newState);\r\n setUpdaterState(stateKey, newUpdaterState);\r\n setState(stateKey, newState);\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n\r\n if (stateEntry) {\r\n stateEntry.components.forEach((component) => {\r\n component.forceUpdate();\r\n });\r\n }\r\n });\r\n\r\n return {\r\n fetchId: (field: keyof T) => newUpdaterState.get()[field],\r\n };\r\n },\r\n _initialState: getGlobalStore.getState().initialStateGlobal[stateKey],\r\n _serverState: getGlobalStore.getState().serverState[stateKey],\r\n _isLoading: getGlobalStore.getState().isLoadingGlobal[stateKey],\r\n _isServerSynced: () => {\r\n const serverState = getGlobalStore.getState().serverState[stateKey];\r\n return Boolean(\r\n serverState && isDeepEqual(serverState, getKeyState(stateKey))\r\n );\r\n },\r\n };\r\n\r\n function rebuildStateShape(\r\n currentState: T,\r\n path: string[] = [],\r\n meta?: { filtered?: string[][]; validIndices?: number[] }\r\n ): any {\r\n const cacheKey = path.map(String).join(\".\");\r\n\r\n // MODIFIED: Cache check with version\r\n const cachedEntry = shapeCache.get(cacheKey);\r\n\r\n type CallableStateObject<T> = {\r\n (): T;\r\n } & {\r\n [key: string]: any;\r\n };\r\n\r\n const baseFunction = function () {\r\n return getGlobalStore().getNestedState(stateKey, path);\r\n } as unknown as CallableStateObject<T>;\r\n\r\n // Copy properties from baseObj to the function with type assertion\r\n Object.keys(baseObj).forEach((key) => {\r\n (baseFunction as any)[key] = (baseObj as any)[key];\r\n });\r\n\r\n const handler = {\r\n apply(target: any, thisArg: any, args: any[]) {\r\n console.log(\r\n `PROXY APPLY TRAP HIT: stateKey=${stateKey}, path=${path.join(\".\")}`\r\n ); // <--- ADD LOGGING\r\n console.trace(\"Apply trap stack trace\");\r\n return getGlobalStore().getNestedState(stateKey, path);\r\n },\r\n\r\n get(target: any, prop: string) {\r\n if (meta?.validIndices && !Array.isArray(currentState)) {\r\n meta = { ...meta, validIndices: undefined };\r\n }\r\n const mutationMethods = new Set([\r\n \"insert\",\r\n \"cut\",\r\n \"cutByValue\",\r\n \"toggleByValue\",\r\n \"uniqueInsert\",\r\n \"update\",\r\n \"applyJsonPatch\",\r\n \"setSelected\",\r\n \"toggleSelected\",\r\n \"clearSelected\",\r\n \"sync\",\r\n \"validateZodSchema\",\r\n \"revertToInitialState\",\r\n \"updateInitialState\",\r\n \"removeValidation\",\r\n \"setValidation\",\r\n \"removeStorage\",\r\n \"middleware\",\r\n \"_componentId\",\r\n \"_stateKey\",\r\n \"getComponents\",\r\n ]);\r\n if (\r\n prop !== \"then\" &&\r\n !prop.startsWith(\"$\") &&\r\n prop !== \"stateMapNoRender\" &&\r\n !mutationMethods.has(prop)\r\n ) {\r\n const fullComponentId = `${stateKey}////${componentId}`;\r\n // console.log(\"adding path\", fullComponentId, path, prop);\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n\r\n if (stateEntry) {\r\n const component = stateEntry.components.get(fullComponentId);\r\n\r\n if (component) {\r\n // Mark as initialized immediately to prevent re-processing\r\n\r\n // Now do the path tracking logic ONCE\r\n if (!component.paths.has(\"\")) {\r\n const currentPath = path.join(\".\");\r\n let needsAdd = true;\r\n for (const existingPath of component.paths) {\r\n if (\r\n currentPath.startsWith(existingPath) &&\r\n (currentPath === existingPath ||\r\n currentPath[existingPath.length] === \".\")\r\n ) {\r\n needsAdd = false;\r\n break;\r\n }\r\n }\r\n\r\n if (needsAdd) {\r\n component.paths.add(currentPath);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n if (prop === \"getDifferences\") {\r\n return () => {\r\n const differences = getDifferences(\r\n getGlobalStore.getState().cogsStateStore[stateKey],\r\n getGlobalStore.getState().initialStateGlobal[stateKey]\r\n );\r\n return differences;\r\n };\r\n }\r\n if (prop === \"sync\" && path.length === 0) {\r\n return async function () {\r\n // Get the options for this state key\r\n const options = getGlobalStore\r\n .getState()\r\n .getInitialOptions(stateKey);\r\n const sync = options?.sync;\r\n\r\n if (!sync) {\r\n console.error(`No mutation defined for state key \"${stateKey}\"`);\r\n return { success: false, error: `No mutation defined` };\r\n }\r\n\r\n // Get the root state\r\n const state = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, []);\r\n\r\n // Get validation key\r\n const validationKey = options?.validation?.key;\r\n\r\n try {\r\n // Execute the mutation action\r\n const response = await sync.action(state);\r\n\r\n // Handle validation errors\r\n if (\r\n response &&\r\n !response.success &&\r\n response.errors &&\r\n validationKey\r\n ) {\r\n // Clear existing errors\r\n getGlobalStore.getState().removeValidationError(validationKey);\r\n\r\n // Add new validation errors\r\n response.errors.forEach((error) => {\r\n const errorPath = [validationKey, ...error.path].join(\".\");\r\n\r\n getGlobalStore\r\n .getState()\r\n .addValidationError(errorPath, error.message);\r\n });\r\n\r\n // Notify components to update\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n if (stateEntry) {\r\n stateEntry.components.forEach((component) => {\r\n component.forceUpdate();\r\n });\r\n }\r\n }\r\n\r\n // Call success/error callbacks\r\n if (response?.success && sync.onSuccess) {\r\n sync.onSuccess(response.data);\r\n } else if (!response?.success && sync.onError) {\r\n sync.onError(response.error);\r\n }\r\n\r\n return response;\r\n } catch (error) {\r\n if (sync.onError) {\r\n sync.onError(error);\r\n }\r\n return { success: false, error };\r\n }\r\n };\r\n }\r\n if (prop === \"_status\") {\r\n // Get current state at this path (non-reactive version)\r\n const thisReactiveState = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path);\r\n\r\n // Get initial state at this path\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n const initialStateAtPath = getNestedValue(initialState, path);\r\n\r\n // Simply compare current state with initial state\r\n if (isDeepEqual(thisReactiveState, initialStateAtPath)) {\r\n return \"fresh\"; // Matches initial state\r\n } else {\r\n return \"stale\"; // Different from initial state\r\n }\r\n }\r\n if (prop === \"getStatus\") {\r\n return function () {\r\n // Get current state at this path (reactive version)\r\n const thisReactiveState = getGlobalStore().getNestedState(\r\n stateKey,\r\n path\r\n );\r\n\r\n // Get initial state at this path\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n const initialStateAtPath = getNestedValue(initialState, path);\r\n // Simply compare current state with initial state\r\n if (isDeepEqual(thisReactiveState, initialStateAtPath)) {\r\n return \"fresh\"; // Matches initial state\r\n } else {\r\n return \"stale\"; // Different from initial state\r\n }\r\n };\r\n }\r\n if (prop === \"removeStorage\") {\r\n return () => {\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n const initalOptionsGet = getInitialOptions(stateKey as string);\r\n const localKey = isFunction(initalOptionsGet?.localStorage?.key)\r\n ? initalOptionsGet?.localStorage?.key(initialState)\r\n : initalOptionsGet?.localStorage?.key;\r\n\r\n const storageKey = `${sessionId}-${stateKey}-${localKey}`;\r\n\r\n if (storageKey) {\r\n localStorage.removeItem(storageKey);\r\n }\r\n };\r\n }\r\n if (prop === \"showValidationErrors\") {\r\n return () => {\r\n const init = getGlobalStore\r\n .getState()\r\n .getInitialOptions(stateKey)?.validation;\r\n\r\n if (!init?.key) {\r\n throw new Error(\"Validation key not found\");\r\n }\r\n const errors = getGlobalStore\r\n .getState()\r\n .getValidationErrors(init.key + \".\" + path.join(\".\"));\r\n\r\n return errors;\r\n };\r\n }\r\n if (Array.isArray(currentState)) {\r\n const getSourceArrayAndIndices = (): {\r\n item: any;\r\n originalIndex: number;\r\n }[] => {\r\n // If meta exists, we're in a chain. Use the currentState and map it to its original index.\r\n if (meta?.validIndices) {\r\n return (currentState as any[]).map((item, index) => ({\r\n item,\r\n originalIndex: meta!.validIndices![index]!,\r\n }));\r\n }\r\n // Otherwise, this is the first operation. Use the full array from the global store.\r\n const sourceArray = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n return sourceArray.map((item, index) => ({\r\n item,\r\n originalIndex: index,\r\n }));\r\n };\r\n if (prop === \"getSelected\") {\r\n return () => {\r\n const selectedIndex = getGlobalStore\r\n .getState()\r\n .getSelectedIndex(stateKey, path.join(\".\"));\r\n if (selectedIndex === undefined) return undefined;\r\n return rebuildStateShape(\r\n currentState[selectedIndex],\r\n [...path, selectedIndex.toString()],\r\n meta\r\n );\r\n };\r\n }\r\n if (prop === \"clearSelected\") {\r\n return () => {\r\n getGlobalStore.getState().clearSelectedIndex({ stateKey, path });\r\n };\r\n }\r\n if (prop === \"getSelectedIndex\") {\r\n return () => {\r\n const selectedIndex = getGlobalStore\r\n .getState()\r\n .getSelectedIndex(stateKey, path.join(\".\"));\r\n\r\n return selectedIndex ?? -1;\r\n };\r\n }\r\n\r\n if (prop === \"useVirtualView\") {\r\n return (\r\n options: VirtualViewOptions\r\n ): VirtualStateObjectResult<any[]> => {\r\n const {\r\n itemHeight,\r\n overscan = 5,\r\n stickToBottom = false,\r\n } = options;\r\n\r\n const containerRef = useRef<HTMLDivElement | null>(null);\r\n const [range, setRange] = useState({\r\n startIndex: 0,\r\n endIndex: 10,\r\n });\r\n\r\n // --- State Tracking Refs ---\r\n const isAtBottomRef = useRef(stickToBottom);\r\n const previousTotalCountRef = useRef(0);\r\n // NEW: Ref to explicitly track if this is the component's first render cycle.\r\n const isInitialMountRef = useRef(true);\r\n\r\n const sourceArray = getGlobalStore().getNestedState(\r\n stateKey,\r\n path\r\n ) as any[];\r\n const totalCount = sourceArray.length;\r\n\r\n const virtualState = useMemo(() => {\r\n const start = Math.max(0, range.startIndex);\r\n const end = Math.min(totalCount, range.endIndex);\r\n const validIndices = Array.from(\r\n { length: end - start },\r\n (_, i) => start + i\r\n );\r\n const slicedArray = validIndices.map((idx) => sourceArray[idx]);\r\n return rebuildStateShape(slicedArray as any, path, {\r\n ...meta,\r\n validIndices,\r\n });\r\n }, [range.startIndex, range.endIndex, sourceArray, totalCount]);\r\n\r\n useLayoutEffect(() => {\r\n const container = containerRef.current;\r\n if (!container) return;\r\n\r\n const wasAtBottom = isAtBottomRef.current;\r\n const listGrew = totalCount > previousTotalCountRef.current;\r\n previousTotalCountRef.current = totalCount;\r\n\r\n const handleScroll = () => {\r\n const { scrollTop, clientHeight, scrollHeight } = container;\r\n isAtBottomRef.current =\r\n scrollHeight - scrollTop - clientHeight < 10;\r\n const start = Math.max(\r\n 0,\r\n Math.floor(scrollTop / itemHeight) - overscan\r\n );\r\n const end = Math.min(\r\n totalCount,\r\n Math.ceil((scrollTop + clientHeight) / itemHeight) +\r\n overscan\r\n );\r\n setRange((prevRange) => {\r\n if (\r\n prevRange.startIndex !== start ||\r\n prevRange.endIndex !== end\r\n ) {\r\n return { startIndex: start, endIndex: end };\r\n }\r\n return prevRange;\r\n });\r\n };\r\n\r\n container.addEventListener(\"scroll\", handleScroll, {\r\n passive: true,\r\n });\r\n\r\n // --- THE CORRECTED DECISION LOGIC ---\r\n if (stickToBottom) {\r\n if (isInitialMountRef.current) {\r\n // SCENARIO 1: First render of the component.\r\n // Go to the bottom unconditionally. Use `auto` scroll for an instant jump.\r\n container.scrollTo({\r\n top: container.scrollHeight,\r\n behavior: \"auto\",\r\n });\r\n } else if (wasAtBottom && listGrew) {\r\n // SCENARIO 2: Subsequent renders (new messages arrive).\r\n // Only scroll if the user was already at the bottom.\r\n // Use `smooth` for a nice animated scroll for new messages.\r\n requestAnimationFrame(() => {\r\n container.scrollTo({\r\n top: container.scrollHeight,\r\n behavior: \"smooth\",\r\n });\r\n });\r\n }\r\n }\r\n\r\n // After the logic runs, it's no longer the initial mount.\r\n isInitialMountRef.current = false;\r\n\r\n // Always run handleScroll once to set the initial visible window.\r\n handleScroll();\r\n\r\n return () =>\r\n container.removeEventListener(\"scroll\", handleScroll);\r\n }, [totalCount, itemHeight, overscan, stickToBottom]);\r\n\r\n const scrollToBottom = useCallback(\r\n (behavior: ScrollBehavior = \"smooth\") => {\r\n if (containerRef.current) {\r\n containerRef.current.scrollTo({\r\n top: containerRef.current.scrollHeight,\r\n behavior,\r\n });\r\n }\r\n },\r\n []\r\n );\r\n\r\n const scrollToIndex = useCallback(\r\n (index: number, behavior: ScrollBehavior = \"smooth\") => {\r\n if (containerRef.current) {\r\n containerRef.current.scrollTo({\r\n top: index * itemHeight,\r\n behavior,\r\n });\r\n }\r\n },\r\n [itemHeight]\r\n );\r\n\r\n // Same virtualizer props as before\r\n const virtualizerProps = {\r\n outer: {\r\n ref: containerRef,\r\n style: { overflowY: \"auto\", height: \"100%\" },\r\n },\r\n inner: {\r\n style: {\r\n height: `${totalCount * itemHeight}px`,\r\n position: \"relative\",\r\n },\r\n },\r\n list: {\r\n style: {\r\n transform: `translateY(${range.startIndex * itemHeight}px)`,\r\n },\r\n },\r\n };\r\n\r\n return {\r\n virtualState,\r\n virtualizerProps: virtualizerProps as any,\r\n scrollToBottom,\r\n scrollToIndex,\r\n };\r\n };\r\n }\r\n if (prop === \"stateSort\") {\r\n return (\r\n compareFn: (\r\n a: InferArrayElement<T>,\r\n b: InferArrayElement<T>\r\n ) => number\r\n ) => {\r\n const sourceWithIndices = getSourceArrayAndIndices();\r\n const sortedResult = [...sourceWithIndices].sort((a, b) =>\r\n compareFn(a.item, b.item)\r\n );\r\n const newCurrentState = sortedResult.map(({ item }) => item);\r\n // We construct the meta object with the CORRECT property name: `validIndices`.\r\n const newMeta = {\r\n ...meta,\r\n validIndices: sortedResult.map(\r\n ({ originalIndex }) => originalIndex\r\n ),\r\n };\r\n return rebuildStateShape(newCurrentState as any, path, newMeta);\r\n };\r\n }\r\n\r\n if (prop === \"stateFilter\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n index: number\r\n ) => boolean\r\n ) => {\r\n const sourceWithIndices = getSourceArrayAndIndices();\r\n const filteredResult = sourceWithIndices.filter(\r\n ({ item }, index) => callbackfn(item, index)\r\n );\r\n const newCurrentState = filteredResult.map(({ item }) => item);\r\n // We construct the meta object with the CORRECT property name: `validIndices`.\r\n const newMeta = {\r\n ...meta,\r\n validIndices: filteredResult.map(\r\n ({ originalIndex }) => originalIndex\r\n ),\r\n };\r\n return rebuildStateShape(newCurrentState as any, path, newMeta);\r\n };\r\n }\r\n\r\n if (prop === \"stateMap\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n setter: StateObject<InferArrayElement<T>>,\r\n info: {\r\n register: () => void;\r\n index: number;\r\n originalIndex: number;\r\n }\r\n ) => any\r\n ) => {\r\n const arrayToMap = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n\r\n // Defensive check to make sure we are mapping over an array\r\n if (!Array.isArray(arrayToMap)) {\r\n console.warn(\r\n `stateMap called on a non-array value at path: ${path.join(\".\")}. The current value is:`,\r\n arrayToMap\r\n );\r\n return null;\r\n }\r\n\r\n // If we have validIndices, only map those items\r\n const indicesToMap =\r\n meta?.validIndices ||\r\n Array.from({ length: arrayToMap.length }, (_, i) => i);\r\n\r\n return indicesToMap.map((originalIndex, localIndex) => {\r\n const item = arrayToMap[originalIndex];\r\n const finalPath = [...path, originalIndex.toString()];\r\n const setter = rebuildStateShape(item, finalPath, meta);\r\n\r\n // Create the register function right here. It closes over the necessary variables.\r\n const register = () => {\r\n const [, forceUpdate] = useState({});\r\n const itemComponentId = `${componentId}-${path.join(\".\")}-${originalIndex}`;\r\n\r\n useLayoutEffect(() => {\r\n const fullComponentId = `${stateKey}////${itemComponentId}`;\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey) || {\r\n components: new Map(),\r\n };\r\n\r\n stateEntry.components.set(fullComponentId, {\r\n forceUpdate: () => forceUpdate({}),\r\n paths: new Set([finalPath.join(\".\")]),\r\n });\r\n\r\n getGlobalStore\r\n .getState()\r\n .stateComponents.set(stateKey, stateEntry);\r\n\r\n return () => {\r\n const currentEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n if (currentEntry) {\r\n currentEntry.components.delete(fullComponentId);\r\n }\r\n };\r\n }, [stateKey, itemComponentId]);\r\n };\r\n\r\n return callbackfn(item, setter, {\r\n register,\r\n index: localIndex,\r\n originalIndex,\r\n });\r\n });\r\n };\r\n }\r\n if (prop === \"stateMapNoRender\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n setter: StateObject<InferArrayElement<T>>,\r\n index: number,\r\n array: T,\r\n arraySetter: StateObject<T>\r\n ) => any\r\n ) => {\r\n const arrayToMap = currentState as any[];\r\n return arrayToMap.map((item, index) => {\r\n let originalIndex: number;\r\n // We READ from the meta object using the CORRECT property name: `validIndices`.\r\n if (\r\n meta?.validIndices &&\r\n meta.validIndices[index] !== undefined\r\n ) {\r\n originalIndex = meta.validIndices[index]!;\r\n } else {\r\n originalIndex = index;\r\n }\r\n const finalPath = [...path, originalIndex.toString()];\r\n\r\n const setter = rebuildStateShape(item, finalPath, meta); // Pass meta through\r\n return callbackfn(\r\n item,\r\n setter,\r\n index,\r\n currentState as any,\r\n rebuildStateShape(currentState as any, path, meta)\r\n );\r\n });\r\n };\r\n }\r\n if (prop === \"$stateMap\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n setter: StateObject<InferArrayElement<T>>,\r\n index: number,\r\n array: T,\r\n arraySetter: StateObject<T>\r\n ) => void\r\n ) => {\r\n return createElement(SignalMapRenderer, {\r\n proxy: {\r\n _stateKey: stateKey,\r\n _path: path,\r\n _mapFn: callbackfn as any, // Pass the actual function, not string\r\n },\r\n\r\n rebuildStateShape,\r\n });\r\n };\r\n }\r\n\r\n if (prop === \"stateFlattenOn\") {\r\n return (fieldName: string) => {\r\n const arrayToMap = currentState as any[];\r\n shapeCache.clear();\r\n stateVersion++;\r\n const flattenedResults = arrayToMap.flatMap(\r\n (val: any) => val[fieldName] ?? []\r\n );\r\n return rebuildStateShape(\r\n flattenedResults as any,\r\n [...path, \"[*]\", fieldName],\r\n meta\r\n );\r\n };\r\n }\r\n\r\n if (prop === \"index\") {\r\n return (index: number) => {\r\n const indexValue = currentState[index];\r\n return rebuildStateShape(indexValue, [...path, index.toString()]);\r\n };\r\n }\r\n if (prop === \"last\") {\r\n // Added handler for 'last'\r\n return () => {\r\n const currentArray = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n if (currentArray.length === 0) return undefined;\r\n const lastIndex = currentArray.length - 1;\r\n const lastValue = currentArray[lastIndex];\r\n const newPath = [...path, lastIndex.toString()];\r\n // shapeCache.clear(); // Decide if you need cache invalidation for 'last' access\r\n // stateVersion++;\r\n return rebuildStateShape(lastValue, newPath);\r\n };\r\n }\r\n if (prop === \"insert\") {\r\n return (payload: UpdateArg<T>) => {\r\n // ADDED: Invalidate cache on insert\r\n invalidateCachePath(path);\r\n pushFunc(effectiveSetState, payload, path, stateKey);\r\n return rebuildStateShape(\r\n getGlobalStore.getState().getNestedState(stateKey, path),\r\n path\r\n );\r\n };\r\n }\r\n\r\n if (prop === \"uniqueInsert\") {\r\n return (\r\n payload: UpdateArg<T>,\r\n fields?: (keyof InferArrayElement<T>)[],\r\n onMatch?: (existingItem: any) => any\r\n ) => {\r\n const currentArray = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n const newValue = isFunction<T>(payload)\r\n ? payload(currentArray as any)\r\n : (payload as any);\r\n\r\n let matchedItem: any = null;\r\n const isUnique = !currentArray.some((item) => {\r\n if (fields) {\r\n const isMatch = fields.every((field) =>\r\n isDeepEqual(item[field], newValue[field])\r\n );\r\n if (isMatch) {\r\n matchedItem = item;\r\n }\r\n return isMatch;\r\n }\r\n const isMatch = isDeepEqual(item, newValue);\r\n if (isMatch) {\r\n matchedItem = item;\r\n }\r\n return isMatch;\r\n });\r\n\r\n if (isUnique) {\r\n invalidateCachePath(path);\r\n pushFunc(effectiveSetState, newValue, path, stateKey);\r\n } else if (onMatch && matchedItem) {\r\n const updatedItem = onMatch(matchedItem);\r\n const updatedArray = currentArray.map((item) =>\r\n isDeepEqual(item, matchedItem) ? updatedItem : item\r\n );\r\n invalidateCachePath(path);\r\n updateFn(effectiveSetState, updatedArray as any, path);\r\n }\r\n };\r\n }\r\n\r\n if (prop === \"cut\") {\r\n return (index: number, options?: { waitForSync?: boolean }) => {\r\n if (options?.waitForSync) return;\r\n // ADDED: Invalidate cache on cut\r\n invalidateCachePath(path);\r\n cutFunc(effectiveSetState, path, stateKey, index);\r\n return rebuildStateShape(\r\n getGlobalStore.getState().getNestedState(stateKey, path),\r\n path\r\n );\r\n };\r\n }\r\n if (prop === \"cutByValue\") {\r\n return (value: string | number | boolean) => {\r\n for (let index = 0; index < currentState.length; index++) {\r\n if (currentState[index] === value) {\r\n cutFunc(effectiveSetState, path, stateKey, index);\r\n }\r\n }\r\n };\r\n }\r\n if (prop === \"toggleByValue\") {\r\n return (value: string | number | boolean) => {\r\n const index = currentState.findIndex((item) => item === value);\r\n if (index > -1) {\r\n // Value exists, so cut it\r\n cutFunc(effectiveSetState, path, stateKey, index);\r\n } else {\r\n // Value doesn't exist, so insert it\r\n pushFunc(effectiveSetState, value as any, path, stateKey);\r\n }\r\n };\r\n }\r\n if (prop === \"stateFind\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n index: number\r\n ) => boolean\r\n ) => {\r\n const sourceWithIndices = getSourceArrayAndIndices();\r\n const found = sourceWithIndices.find(({ item }, index) =>\r\n callbackfn(item, index)\r\n );\r\n if (!found) return undefined;\r\n const finalPath = [...path, found.originalIndex.toString()];\r\n return rebuildStateShape(found.item, finalPath, meta);\r\n };\r\n }\r\n\r\n if (prop === \"findWith\") {\r\n return (thisKey: keyof InferArrayElement<T>, thisValue: any) => {\r\n const sourceWithIndices = getSourceArrayAndIndices();\r\n const found = sourceWithIndices.find(\r\n ({ item }) => item[thisKey] === thisValue\r\n );\r\n if (!found) return undefined;\r\n const finalPath = [...path, found.originalIndex.toString()];\r\n return rebuildStateShape(found.item, finalPath, meta);\r\n };\r\n }\r\n }\r\n const lastPathElement = path[path.length - 1];\r\n if (!isNaN(Number(lastPathElement))) {\r\n const parentPath = path.slice(0, -1);\r\n const parentValue = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, parentPath);\r\n\r\n if (Array.isArray(parentValue) && prop === \"cut\") {\r\n return () =>\r\n cutFunc(\r\n effectiveSetState,\r\n parentPath,\r\n stateKey,\r\n Number(lastPathElement)\r\n );\r\n }\r\n }\r\n\r\n if (prop === \"get\") {\r\n return () => {\r\n if (meta?.validIndices && Array.isArray(currentState)) {\r\n // For filtered arrays, return only the items at validIndices\r\n const fullArray = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n return meta.validIndices.map((index) => fullArray[index]);\r\n }\r\n return getGlobalStore.getState().getNestedState(stateKey, path);\r\n };\r\n }\r\n if (prop === \"$derive\") {\r\n return (fn: any) =>\r\n $cogsSignal({\r\n _stateKey: stateKey,\r\n _path: path,\r\n _effect: fn.toString(),\r\n });\r\n }\r\n\r\n if (prop === \"$get\") {\r\n return () =>\r\n $cogsSignal({\r\n _stateKey: stateKey,\r\n _path: path,\r\n });\r\n }\r\n if (prop === \"lastSynced\") {\r\n const syncKey = `${stateKey}:${path.join(\".\")}`;\r\n return getGlobalStore.getState().getSyncInfo(syncKey);\r\n }\r\n\r\n if (prop == \"getLocalStorage\") {\r\n return (key: string) =>\r\n loadFromLocalStorage(sessionId + \"-\" + stateKey + \"-\" + key);\r\n }\r\n if (prop === \"_selected\") {\r\n const parentPath = path.slice(0, -1);\r\n const parentKey = parentPath.join(\".\");\r\n const parent = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, parentPath);\r\n if (Array.isArray(parent)) {\r\n const currentIndex = Number(path[path.length - 1]);\r\n return (\r\n currentIndex ===\r\n getGlobalStore.getState().getSelectedIndex(stateKey, parentKey)\r\n );\r\n }\r\n return undefined;\r\n }\r\n if (prop === \"setSelected\") {\r\n return (value: boolean) => {\r\n const parentPath = path.slice(0, -1);\r\n const thisIndex = Number(path[path.length - 1]);\r\n const parentKey = parentPath.join(\".\");\r\n\r\n if (value) {\r\n getGlobalStore\r\n .getState()\r\n .setSelectedIndex(stateKey, parentKey, thisIndex);\r\n } else {\r\n getGlobalStore\r\n .getState()\r\n .setSelectedIndex(stateKey, parentKey, undefined);\r\n }\r\n\r\n const nested = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, [...parentPath]);\r\n updateFn(effectiveSetState, nested, parentPath);\r\n\r\n // Invalidate cache for this path\r\n invalidateCachePath(parentPath);\r\n };\r\n }\r\n if (prop === \"toggleSelected\") {\r\n return () => {\r\n const parentPath = path.slice(0, -1);\r\n const thisIndex = Number(path[path.length - 1]);\r\n const parentKey = parentPath.join(\".\");\r\n const selectedIndex = getGlobalStore\r\n .getState()\r\n .getSelectedIndex(stateKey, parentKey);\r\n\r\n getGlobalStore\r\n .getState()\r\n .setSelectedIndex(\r\n stateKey,\r\n parentKey,\r\n selectedIndex === thisIndex ? undefined : thisIndex\r\n );\r\n const nested = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, [...parentPath]);\r\n updateFn(effectiveSetState, nested, parentPath);\r\n\r\n invalidateCachePath(parentPath);\r\n };\r\n }\r\n if (path.length == 0) {\r\n if (prop === \"applyJsonPatch\") {\r\n return (patches: any[]) => {\r\n // This part is correct.\r\n const currentState =\r\n getGlobalStore.getState().cogsStateStore[stateKey];\r\n const patchResult = applyPatch(currentState, patches);\r\n const newState = patchResult.newDocument;\r\n\r\n // This is also correct.\r\n updateGlobalState(\r\n stateKey,\r\n getGlobalStore.getState().initialStateGlobal[stateKey],\r\n newState,\r\n effectiveSetState,\r\n componentId,\r\n sessionId\r\n );\r\n\r\n // ===================================================================\r\n // REPLACE THE OLD LOGIC WITH THIS DIRECT COPY\r\n // ===================================================================\r\n\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey); // Use stateKey here\r\n\r\n if (stateEntry) {\r\n // Use `getDifferences` between the state before and after the patch.\r\n const changedPaths = getDifferences(currentState, newState);\r\n const changedPathsSet = new Set(changedPaths);\r\n\r\n // There is no single `primaryPathToCheck` for a patch, so we just check against the full set.\r\n\r\n for (const [\r\n componentKey,\r\n component,\r\n ] of stateEntry.components.entries()) {\r\n let shouldUpdate = false;\r\n const reactiveTypes = Array.isArray(component.reactiveType)\r\n ? component.reactiveType\r\n : [component.reactiveType || \"component\"];\r\n\r\n if (reactiveTypes.includes(\"none\")) continue;\r\n if (reactiveTypes.includes(\"all\")) {\r\n component.forceUpdate();\r\n continue;\r\n }\r\n\r\n if (reactiveTypes.includes(\"component\")) {\r\n // This is the core logic that needs to be copied.\r\n // Check if any of the component's watched paths are in the set of changed paths.\r\n if (component.paths.has(\"\")) {\r\n // Always update for root listeners\r\n shouldUpdate = true;\r\n }\r\n\r\n if (!shouldUpdate) {\r\n for (const changedPath of changedPathsSet) {\r\n // Direct match first (fastest)\r\n if (component.paths.has(changedPath)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n\r\n // Check parent paths more efficiently\r\n let dotIndex = changedPath.lastIndexOf(\".\");\r\n while (dotIndex !== -1) {\r\n const parentPath = changedPath.substring(0, dotIndex);\r\n if (component.paths.has(parentPath)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n // Skip numeric segments more efficiently\r\n const lastSegment = changedPath.substring(\r\n dotIndex + 1\r\n );\r\n if (!isNaN(Number(lastSegment))) {\r\n // For array indices, check the parent collection path\r\n const parentDotIndex = parentPath.lastIndexOf(\".\");\r\n if (parentDotIndex !== -1) {\r\n const grandParentPath = parentPath.substring(\r\n 0,\r\n parentDotIndex\r\n );\r\n if (component.paths.has(grandParentPath)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n }\r\n }\r\n dotIndex = parentPath.lastIndexOf(\".\");\r\n }\r\n\r\n if (shouldUpdate) break;\r\n }\r\n }\r\n }\r\n\r\n if (!shouldUpdate && reactiveTypes.includes(\"deps\")) {\r\n // Use `newState` (the result of the patch) for dependency checks.\r\n if (component.depsFunction) {\r\n const depsResult = component.depsFunction(newState);\r\n let depsChanged = false;\r\n if (typeof depsResult === \"boolean\") {\r\n if (depsResult) depsChanged = true;\r\n } else if (!isDeepEqual(component.deps, depsResult)) {\r\n component.deps = depsResult;\r\n depsChanged = true;\r\n }\r\n if (depsChanged) {\r\n shouldUpdate = true;\r\n }\r\n }\r\n }\r\n\r\n if (shouldUpdate) {\r\n component.forceUpdate();\r\n }\r\n }\r\n }\r\n };\r\n }\r\n if (prop === \"validateZodSchema\") {\r\n return () => {\r\n const init = getGlobalStore\r\n .getState()\r\n .getInitialOptions(stateKey)?.validation;\r\n const addValidationError =\r\n getGlobalStore.getState().addValidationError;\r\n\r\n if (!init?.zodSchema) {\r\n throw new Error(\"Zod schema not found\");\r\n }\r\n\r\n if (!init?.key) {\r\n throw new Error(\"Validation key not found\");\r\n }\r\n removeValidationError(init.key);\r\n const thisObject =\r\n getGlobalStore.getState().cogsStateStore[stateKey];\r\n\r\n try {\r\n // First clear any existing validation errors for this schema\r\n // This ensures we don't have stale errors\r\n const existingErrors = getGlobalStore\r\n .getState()\r\n .getValidationErrors(init.key);\r\n if (existingErrors && existingErrors.length > 0) {\r\n existingErrors.forEach(([errorPath]) => {\r\n if (errorPath && errorPath.startsWith(init.key!)) {\r\n removeValidationError(errorPath);\r\n }\r\n });\r\n }\r\n\r\n // Attempt to validate with Zod\r\n const result = init.zodSchema.safeParse(thisObject);\r\n\r\n if (!result.success) {\r\n // Process Zod errors and add them to the validation store\r\n const zodErrors = result.error.errors;\r\n\r\n zodErrors.forEach((error) => {\r\n const errorPath = error.path;\r\n const errorMessage = error.message;\r\n\r\n // Build the full path for the validation error\r\n // Format: validationKey.path.to.field\r\n const fullErrorPath = [init.key, ...errorPath].join(\".\");\r\n\r\n // Add the error to the store\r\n addValidationError(fullErrorPath, errorMessage);\r\n });\r\n\r\n notifyComponents(stateKey);\r\n\r\n return false;\r\n }\r\n\r\n return true;\r\n } catch (error) {\r\n console.error(\"Zod schema validation failed\", error);\r\n return false;\r\n }\r\n };\r\n }\r\n if (prop === \"_componentId\") return componentId;\r\n if (prop === \"getComponents\") {\r\n return () => getGlobalStore().stateComponents.get(stateKey);\r\n }\r\n if (prop === \"getAllFormRefs\") {\r\n return () => {\r\n return formRefStore.getState().getFormRefsByStateKey(stateKey);\r\n };\r\n }\r\n\r\n if (prop === \"_initialState\")\r\n return getGlobalStore.getState().initialStateGlobal[stateKey];\r\n if (prop === \"_serverState\")\r\n return getGlobalStore.getState().serverState[stateKey];\r\n if (prop === \"_isLoading\")\r\n return getGlobalStore.getState().isLoadingGlobal[stateKey];\r\n if (prop === \"revertToInitialState\")\r\n return baseObj.revertToInitialState;\r\n if (prop === \"updateInitialState\") return baseObj.updateInitialState;\r\n if (prop === \"removeValidation\") return baseObj.removeValidation;\r\n }\r\n if (prop === \"getFormRef\") {\r\n return () => {\r\n return formRefStore\r\n .getState()\r\n .getFormRef(stateKey + \".\" + path.join(\".\"));\r\n };\r\n }\r\n\r\n if (prop === \"validationWrapper\") {\r\n return ({\r\n children,\r\n hideMessage,\r\n }: {\r\n children: React.ReactNode;\r\n hideMessage?: boolean;\r\n }) => (\r\n <ValidationWrapper\r\n formOpts={\r\n hideMessage ? { validation: { message: \"\" } } : undefined\r\n }\r\n path={path}\r\n validationKey={\r\n getGlobalStore.getState().getInitialOptions(stateKey)\r\n ?.validation?.key || \"\"\r\n }\r\n stateKey={stateKey}\r\n validIndices={meta?.validIndices}\r\n >\r\n {children}\r\n </ValidationWrapper>\r\n );\r\n }\r\n\r\n if (prop === \"_stateKey\") return stateKey;\r\n if (prop === \"_path\") return path;\r\n if (prop === \"_isServerSynced\") return baseObj._isServerSynced;\r\n\r\n if (prop === \"update\") {\r\n return (payload: UpdateArg<T>, opts?: UpdateOpts<T>) => {\r\n // ADDED: Invalidate cache on update\r\n if (opts?.debounce) {\r\n debounce(() => {\r\n updateFn(effectiveSetState, payload, path, \"\");\r\n const newValue = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path);\r\n if (opts?.afterUpdate) opts.afterUpdate(newValue);\r\n }, opts.debounce);\r\n } else {\r\n updateFn(effectiveSetState, payload, path, \"\");\r\n const newValue = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path);\r\n if (opts?.afterUpdate) opts.afterUpdate(newValue);\r\n }\r\n invalidateCachePath(path);\r\n };\r\n }\r\n\r\n if (prop === \"formElement\") {\r\n return (child: FormControl<T>, formOpts?: FormOptsType) => {\r\n return (\r\n <FormControlComponent<T>\r\n setState={effectiveSetState}\r\n stateKey={stateKey}\r\n path={path}\r\n child={child}\r\n formOpts={formOpts}\r\n />\r\n );\r\n };\r\n }\r\n\r\n const nextPath = [...path, prop];\r\n const nextValue = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, nextPath);\r\n return rebuildStateShape(nextValue, nextPath, meta);\r\n },\r\n };\r\n\r\n const proxyInstance = new Proxy(baseFunction, handler);\r\n\r\n shapeCache.set(cacheKey, {\r\n proxy: proxyInstance,\r\n stateVersion: stateVersion,\r\n });\r\n\r\n return proxyInstance;\r\n }\r\n\r\n return rebuildStateShape(\r\n getGlobalStore.getState().getNestedState(stateKey, [])\r\n );\r\n}\r\n\r\nexport function $cogsSignal(proxy: {\r\n _path: string[];\r\n _stateKey: string;\r\n _effect?: string;\r\n}) {\r\n return createElement(SignalRenderer, { proxy });\r\n}\r\n\r\nfunction SignalMapRenderer({\r\n proxy,\r\n\r\n rebuildStateShape,\r\n}: {\r\n proxy: {\r\n _stateKey: string;\r\n _path: string[];\r\n _mapFn: (\r\n value: any,\r\n setter: any,\r\n index: number,\r\n array: any[],\r\n arraySetter: any\r\n ) => ReactNode;\r\n };\r\n\r\n rebuildStateShape: (\r\n currentState: any,\r\n path: string[],\r\n meta?: { filtered?: string[][]; validIndices?: number[] }\r\n ) => any;\r\n}) {\r\n const value = getGlobalStore().getNestedState(proxy._stateKey, proxy._path);\r\n\r\n if (!Array.isArray(value)) {\r\n return null;\r\n }\r\n const arraySetter = rebuildStateShape(\r\n value,\r\n proxy._path\r\n ) as ArrayEndType<any>;\r\n // Use existing global state management\r\n return arraySetter.stateMapNoRender(\r\n (item, setter, index, value, arraysetter) => {\r\n // Execute map function in React context with existing state/proxies\r\n return proxy._mapFn(item, setter, index, value, arraysetter);\r\n }\r\n );\r\n}\r\nfunction SignalRenderer({\r\n proxy,\r\n}: {\r\n proxy: {\r\n _path: string[];\r\n _stateKey: string;\r\n _effect?: string;\r\n };\r\n}) {\r\n const elementRef = useRef<HTMLSpanElement>(null);\r\n const signalId = `${proxy._stateKey}-${proxy._path.join(\".\")}`;\r\n\r\n useEffect(() => {\r\n const element = elementRef.current;\r\n if (!element || !element.parentElement) return;\r\n\r\n const parentElement = element.parentElement;\r\n const childNodes = Array.from(parentElement.childNodes);\r\n const position = childNodes.indexOf(element);\r\n\r\n let parentId = parentElement.getAttribute(\"data-parent-id\");\r\n if (!parentId) {\r\n parentId = `parent-${crypto.randomUUID()}`;\r\n parentElement.setAttribute(\"data-parent-id\", parentId);\r\n }\r\n\r\n const instanceId = `instance-${crypto.randomUUID()}`;\r\n const elementInfo = {\r\n instanceId,\r\n parentId,\r\n position,\r\n effect: proxy._effect,\r\n };\r\n\r\n getGlobalStore.getState().addSignalElement(signalId, elementInfo);\r\n\r\n // Get the raw value from the store\r\n const value = getGlobalStore\r\n .getState()\r\n .getNestedState(proxy._stateKey, proxy._path);\r\n\r\n let displayValue;\r\n if (proxy._effect) {\r\n try {\r\n displayValue = new Function(\r\n \"state\",\r\n `return (${proxy._effect})(state)`\r\n )(value);\r\n } catch (err) {\r\n console.error(\"Error evaluating effect function during mount:\", err);\r\n displayValue = value; // Fallback to raw value\r\n }\r\n } else {\r\n displayValue = value;\r\n }\r\n\r\n if (displayValue !== null && typeof displayValue === \"object\") {\r\n displayValue = JSON.stringify(displayValue);\r\n }\r\n\r\n const textNode = document.createTextNode(String(displayValue));\r\n element.replaceWith(textNode);\r\n }, [proxy._stateKey, proxy._path.join(\".\"), proxy._effect]);\r\n\r\n return createElement(\"span\", {\r\n ref: elementRef,\r\n style: { display: \"none\" },\r\n \"data-signal-id\": signalId,\r\n });\r\n}\r\nexport function $cogsSignalStore(proxy: {\r\n _path: string[];\r\n _stateKey: string;\r\n}) {\r\n const value = useSyncExternalStore(\r\n (notify) => {\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(proxy._stateKey) || {\r\n components: new Map(),\r\n };\r\n stateEntry.components.set(proxy._stateKey, {\r\n forceUpdate: notify,\r\n paths: new Set([proxy._path.join(\".\")]),\r\n });\r\n return () => stateEntry.components.delete(proxy._stateKey);\r\n },\r\n () => getGlobalStore.getState().getNestedState(proxy._stateKey, proxy._path)\r\n );\r\n return createElement(\"text\", {}, String(value));\r\n}\r\n// This is an internal component. It should NOT be exported.\r\nfunction CogsItemWrapper({\r\n stateKey,\r\n itemComponentId,\r\n itemPath,\r\n children,\r\n}: {\r\n stateKey: string;\r\n itemComponentId: string;\r\n itemPath: string[];\r\n children: React.ReactNode;\r\n}) {\r\n // This is a real component, so we can safely call hooks.\r\n const [, forceUpdate] = useState({});\r\n\r\n // We use useLayoutEffect to register the component and clean up when it unmounts.\r\n useLayoutEffect(() => {\r\n const fullComponentId = `${stateKey}////${itemComponentId}`;\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey) || {\r\n components: new Map(),\r\n };\r\n\r\n // Register the component with its unique ID and its specific, atomic path.\r\n stateEntry.components.set(fullComponentId, {\r\n forceUpdate: () => forceUpdate({}),\r\n paths: new Set([itemPath.join(\".\")]), // ATOMIC: Subscribes only to this item's path.\r\n });\r\n\r\n getGlobalStore.getState().stateComponents.set(stateKey, stateEntry);\r\n\r\n // Return a cleanup function to unregister on unmount.\r\n return () => {\r\n const currentEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n if (currentEntry) {\r\n currentEntry.components.delete(fullComponentId);\r\n }\r\n };\r\n }, [stateKey, itemComponentId, itemPath.join(\".\")]); // Effect dependency array is stable.\r\n\r\n // Render the actual component the user provided.\r\n return <>{children}</>;\r\n}\r\n"],"names":["setAndMergeOptions","stateKey","newOptions","getInitialOptions","getGlobalStore","setInitialStateOptions","initialOptions","setOptions","options","initialOptionsPart","initialOptionsPartState","mergedOptions","needToAdd","key","isDeepEqual","addStateOptions","initialState","formElements","validation","createCogsState","opt","newInitialState","statePart","transformStateFunc","useCogsState","componentId","useState","uuidv4","thiState","partialState","state","updater","useCogsStateFn","setCogsOptions","loadAndApplyLocalStorage","notifyComponents","setUpdaterState","setState","getKeyState","getValidationErrors","setStateLog","updateInitialStateGlobal","addValidationError","removeValidationError","setServerSyncActions","saveToLocalStorage","thisKey","currentInitialOptions","sessionId","lastSyncedWithServer","isFunction","storageKey","existingLastSynced","loadFromLocalStorage","data","superJsonResult","superjson","localStorageKey","storedData","error","currentState","useCogsConfig","localkey","localData","updateGlobalState","newState","effectiveSetState","updates","createProxyHandler","stateEntry","component","update","notifyComponent","fullComponentId","getUpdateValues","updateType","prevValue","payload","path","getNestedValue","stateObject","serverSync","localStorage","reactiveDeps","reactiveType","syncUpdate","dependencies","serverState","reactiveForce","forceUpdate","noStateKey","stateLog","componentUpdatesRef","useRef","componentIdRef","latestInitialOptionsRef","useEffect","prevState","syncKey","hasServerData","currentGloballyStoredInitialState","isFromServer","serverTimestamp","localTimestamp","lastSyncTimestamp","useLayoutEffect","componentKey","newStateOrFunction","updateObj","validationKey","pathKey","signalId","isArrayOperation","elements","arrayPath","arrayValue","arraySignalId","newValue","parentId","position","effect","parent","childNodes","displayValue","store","parentPath","index","arrayWithoutIndex","k","v","length","newKey","changedPaths","getDifferences","changedPathsSet","primaryPathToCheck","shouldUpdate","reactiveTypes","changedPath","currentPathToCheck","lastDotIndex","depsResult","depsChanged","timeStamp","p","i","oldValue","newUpdate","prevLogs","aggregatedLogs","acc","log","uniqueKey","existing","serverStateStore","updaterFinal","useMemo","shapeCache","stateVersion","invalidateCachePath","baseObj","obj","init","newProxy","rebuildStateShape","initalOptionsGet","localKey","newUpdaterState","startTransition","field","meta","cacheKey","baseFunction","handler","target","thisArg","args","prop","mutationMethods","currentPath","needsAdd","existingPath","sync","response","errorPath","thisReactiveState","initialStateAtPath","getSourceArrayAndIndices","item","selectedIndex","itemHeight","overscan","stickToBottom","containerRef","range","setRange","isAtBottomRef","previousTotalCountRef","isInitialMountRef","sourceArray","totalCount","virtualState","start","end","validIndices","_","slicedArray","idx","container","wasAtBottom","listGrew","handleScroll","scrollTop","clientHeight","scrollHeight","prevRange","scrollToBottom","useCallback","behavior","scrollToIndex","virtualizerProps","compareFn","sortedResult","a","b","newCurrentState","newMeta","originalIndex","callbackfn","filteredResult","arrayToMap","localIndex","finalPath","setter","itemComponentId","currentEntry","createElement","SignalMapRenderer","fieldName","flattenedResults","val","indexValue","currentArray","lastIndex","lastValue","newPath","pushFunc","fields","onMatch","matchedItem","isMatch","updatedItem","updatedArray","updateFn","cutFunc","value","found","thisValue","lastPathElement","parentValue","fullArray","fn","$cogsSignal","parentKey","thisIndex","nested","patches","applyPatch","dotIndex","lastSegment","parentDotIndex","grandParentPath","thisObject","existingErrors","result","errorMessage","fullErrorPath","formRefStore","children","hideMessage","jsx","ValidationWrapper","opts","debounce","child","formOpts","FormControlComponent","nextPath","nextValue","proxyInstance","proxy","SignalRenderer","arraysetter","elementRef","element","parentElement","elementInfo","err","textNode","$cogsSignalStore","useSyncExternalStore","notify"],"mappings":"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"}
1
+ {"version":3,"file":"CogsState.jsx","sources":["../src/CogsState.tsx"],"sourcesContent":["\"use client\";\r\n\r\nimport {\r\n createElement,\r\n startTransition,\r\n useCallback,\r\n useEffect,\r\n useLayoutEffect,\r\n useMemo,\r\n useRef,\r\n useState,\r\n useSyncExternalStore,\r\n type CSSProperties,\r\n type ReactNode,\r\n type RefObject,\r\n} from \"react\";\r\n\r\nimport {\r\n debounce,\r\n getDifferences,\r\n getNestedValue,\r\n isFunction,\r\n type GenericObject,\r\n} from \"./utility.js\";\r\nimport {\r\n cutFunc,\r\n FormControlComponent,\r\n pushFunc,\r\n updateFn,\r\n ValidationWrapper,\r\n} from \"./Functions.js\";\r\nimport { isDeepEqual, transformStateFunc } from \"./utility.js\";\r\nimport superjson from \"superjson\";\r\nimport { v4 as uuidv4 } from \"uuid\";\r\nimport { z } from \"zod\";\r\n\r\nimport { formRefStore, getGlobalStore, type ComponentsType } from \"./store.js\";\r\nimport { useCogsConfig } from \"./CogsStateClient.js\";\r\nimport { applyPatch } from \"fast-json-patch\";\r\n\r\ntype Prettify<T> = { [K in keyof T]: T[K] } & {};\r\n\r\nexport type VirtualViewOptions = {\r\n itemHeight: number;\r\n overscan?: number;\r\n stickToBottom?: boolean;\r\n};\r\n\r\n// The result now returns a real StateObject\r\nexport type VirtualStateObjectResult<T extends any[]> = {\r\n /**\r\n * A new, fully-functional StateObject that represents the virtualized slice.\r\n * You can use `.get()`, `.stateMap()`, `.insert()`, `.cut()` etc. on this object.\r\n */\r\n virtualState: StateObject<T>;\r\n /**\r\n * Props to be spread onto your DOM elements to enable virtualization.\r\n */\r\n virtualizerProps: {\r\n outer: { ref: RefObject<HTMLDivElement>; style: CSSProperties };\r\n inner: { style: CSSProperties };\r\n list: { style: CSSProperties };\r\n };\r\n scrollToBottom: (behavior?: ScrollBehavior) => void;\r\n scrollToIndex: (index: number, behavior?: ScrollBehavior) => void;\r\n};\r\n\r\nexport type ServerSyncStatus = {\r\n isFresh: boolean;\r\n isFreshTime: number;\r\n isStale: boolean;\r\n isStaleTime: number;\r\n isSyncing: boolean;\r\n isSyncingTime: number;\r\n};\r\n\r\nexport type SyncInfo = {\r\n timeStamp: number;\r\n userId: number;\r\n};\r\n\r\nexport type FormElementParams<T> = {\r\n get: () => T;\r\n\r\n set: UpdateType<T>;\r\n syncStatus: (SyncInfo & { date: Date }) | null;\r\n path: string[];\r\n validationErrors: () => string[];\r\n addValidationError: (message?: string) => void;\r\n\r\n inputProps: {\r\n ref?: React.RefObject<any>;\r\n value?: T extends boolean ? never : T;\r\n onChange?: (\r\n event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>\r\n ) => void;\r\n onBlur?: () => void;\r\n };\r\n};\r\n\r\nexport type StateKeys = string;\r\n\r\ntype findWithFuncType<U> = (\r\n thisKey: keyof U,\r\n thisValue: U[keyof U]\r\n) => EndType<U> & StateObject<U>;\r\nexport type PushArgs<U, T> = (\r\n update:\r\n | Prettify<U>\r\n | ((prevState: NonNullable<Prettify<U>>[]) => NonNullable<Prettify<U>>),\r\n opts?: UpdateOpts<U>\r\n) => StateObject<T>;\r\n\r\ntype CutFunctionType<T> = (\r\n index?: number,\r\n options?: { waitForSync?: boolean }\r\n) => StateObject<T>;\r\n\r\nexport type InferArrayElement<T> = T extends (infer U)[] ? U : never;\r\ntype ArraySpecificPrototypeKeys =\r\n | \"concat\"\r\n | \"copyWithin\"\r\n | \"fill\"\r\n | \"find\"\r\n | \"findIndex\"\r\n | \"flat\"\r\n | \"flatMap\"\r\n | \"includes\"\r\n | \"indexOf\"\r\n | \"join\"\r\n | \"keys\"\r\n | \"lastIndexOf\"\r\n | \"map\"\r\n | \"pop\"\r\n | \"push\"\r\n | \"reduce\"\r\n | \"reduceRight\"\r\n | \"reverse\"\r\n | \"shift\"\r\n | \"slice\"\r\n | \"some\"\r\n | \"sort\"\r\n | \"splice\"\r\n | \"unshift\"\r\n | \"values\"\r\n | \"entries\"\r\n | \"every\"\r\n | \"filter\"\r\n | \"forEach\"\r\n | \"with\";\r\n\r\nexport type ArrayEndType<TShape extends unknown> = {\r\n findWith: findWithFuncType<InferArrayElement<TShape>>;\r\n index: (index: number) => StateObject<InferArrayElement<TShape>> & {\r\n insert: PushArgs<InferArrayElement<TShape>, TShape>;\r\n cut: CutFunctionType<TShape>;\r\n _index: number;\r\n } & EndType<InferArrayElement<TShape>>;\r\n insert: PushArgs<InferArrayElement<TShape>, TShape>;\r\n cut: CutFunctionType<TShape>;\r\n cutByValue: (value: string | number | boolean) => void;\r\n toggleByValue: (value: string | number | boolean) => void;\r\n stateSort: (\r\n compareFn: (\r\n a: InferArrayElement<TShape>,\r\n b: InferArrayElement<TShape>\r\n ) => number\r\n ) => ArrayEndType<TShape>;\r\n useVirtualView: (\r\n options: VirtualViewOptions\r\n ) => VirtualStateObjectResult<InferArrayElement<TShape>[]>;\r\n\r\n stateMapNoRender: (\r\n callbackfn: (\r\n value: InferArrayElement<TShape>,\r\n setter: StateObject<InferArrayElement<TShape>>,\r\n index: number,\r\n array: TShape,\r\n arraySetter: StateObject<TShape>\r\n ) => void\r\n ) => any;\r\n stateMap: (\r\n callbackfn: (\r\n value: InferArrayElement<TShape>,\r\n setter: StateObject<InferArrayElement<TShape>>,\r\n index: number,\r\n array: TShape,\r\n arraySetter: StateObject<TShape>\r\n ) => void\r\n ) => any;\r\n $stateMap: (\r\n callbackfn: (\r\n value: InferArrayElement<TShape>,\r\n setter: StateObject<InferArrayElement<TShape>>,\r\n index: number,\r\n array: TShape,\r\n arraySetter: StateObject<TShape>\r\n ) => void\r\n ) => any;\r\n stateFlattenOn: <K extends keyof InferArrayElement<TShape>>(\r\n field: K\r\n ) => StateObject<InferArrayElement<InferArrayElement<TShape>[K]>[]>;\r\n uniqueInsert: (\r\n payload: UpdateArg<InferArrayElement<TShape>>,\r\n fields?: (keyof InferArrayElement<TShape>)[],\r\n onMatch?: (existingItem: any) => any\r\n ) => void;\r\n stateFind: (\r\n callbackfn: (value: InferArrayElement<TShape>, index: number) => boolean\r\n ) => StateObject<InferArrayElement<TShape>> | undefined;\r\n stateFilter: (\r\n callbackfn: (value: InferArrayElement<TShape>, index: number) => void\r\n ) => ArrayEndType<TShape>;\r\n getSelected: () => StateObject<InferArrayElement<TShape>> | undefined;\r\n clearSelected: () => void;\r\n getSelectedIndex: () => number;\r\n last: () => StateObject<InferArrayElement<TShape>> | undefined;\r\n} & EndType<TShape>;\r\n\r\nexport type FormOptsType = {\r\n key?: string;\r\n validation?: {\r\n hideMessage?: boolean;\r\n message?: string;\r\n stretch?: boolean;\r\n props?: GenericObject;\r\n disable?: boolean;\r\n };\r\n formElements?: boolean;\r\n debounceTime?: number;\r\n stateServerDifferences?: string[][];\r\n};\r\n\r\nexport type FormControl<T> = (obj: FormElementParams<T>) => JSX.Element;\r\n\r\nexport type UpdateArg<S> = S | ((prevState: S) => S);\r\n\r\nexport type UpdateType<T> = (\r\n payload: UpdateArg<T>,\r\n opts?: UpdateOpts<T>\r\n) => void;\r\n\r\nexport type UpdateOpts<T> = {\r\n afterUpdate?: (state: T) => void;\r\n debounce?: number;\r\n};\r\nexport type ObjectEndType<T> = EndType<T> & {\r\n [K in keyof T]-?: ObjectEndType<T[K]>;\r\n} & {\r\n stateObject: (callbackfn: (value: T, setter: StateObject<T>) => void) => any;\r\n delete: () => void;\r\n};\r\ntype EffectFunction<T, R> = (state: T) => R;\r\nexport type EndType<T, IsArrayElement = false> = {\r\n applyJsonPatch: (patches: any[]) => void;\r\n update: UpdateType<T>;\r\n _path: string[];\r\n _stateKey: string;\r\n formElement: (control: FormControl<T>, opts?: FormOptsType) => JSX.Element;\r\n get: () => T;\r\n $get: () => T;\r\n $derive: <R>(fn: EffectFunction<T, R>) => R;\r\n _status: \"fresh\" | \"stale\" | \"synced\";\r\n getStatus: () => \"fresh\" | \"stale\";\r\n\r\n showValidationErrors: () => string[];\r\n setValidation: (ctx: string) => void;\r\n removeValidation: (ctx: string) => void;\r\n ignoreFields: (fields: string[]) => StateObject<T>;\r\n _selected: boolean;\r\n setSelected: (value: boolean) => void;\r\n toggleSelected: () => void;\r\n getFormRef: () => React.RefObject<any> | undefined;\r\n removeStorage: () => void;\r\n sync: () => void;\r\n validationWrapper: ({\r\n children,\r\n hideMessage,\r\n }: {\r\n children: React.ReactNode;\r\n hideMessage?: boolean;\r\n }) => JSX.Element;\r\n lastSynced?: SyncInfo;\r\n} & (IsArrayElement extends true ? { cut: () => void } : {});\r\n\r\nexport type StateObject<T> = (T extends any[]\r\n ? ArrayEndType<T>\r\n : T extends Record<string, unknown> | object\r\n ? { [K in keyof T]-?: StateObject<T[K]> } & ObjectEndType<T>\r\n : T extends string | number | boolean | null\r\n ? T\r\n : never) &\r\n EndType<T, true> & {\r\n getAllFormRefs: () => Map<string, React.RefObject<any>>;\r\n _componentId: string | null;\r\n getComponents: () => ComponentsType;\r\n validateZodSchema: () => void;\r\n _initialState: T;\r\n updateInitialState: (newState: T | null) => {\r\n fetchId: (field: keyof T) => string | number;\r\n };\r\n _isLoading: boolean;\r\n _serverState: T;\r\n revertToInitialState: (obj?: { validationKey?: string }) => T;\r\n getDifferences: () => string[];\r\n middleware: (\r\n middles: ({\r\n updateLog,\r\n update,\r\n }: {\r\n updateLog: UpdateTypeDetail[] | undefined;\r\n update: UpdateTypeDetail;\r\n }) => void\r\n ) => void;\r\n _isServerSynced: () => boolean;\r\n getLocalStorage: (key: string) => LocalStorageData<T> | null;\r\n };\r\n\r\nexport type CogsUpdate<T extends unknown> = UpdateType<T>;\r\n\r\nexport type EffectiveSetState<TStateObject> = (\r\n newStateOrFunction: UpdateArg<TStateObject>,\r\n path: string[],\r\n updateObj: { updateType: \"update\" | \"insert\" | \"cut\" },\r\n validationKey?: string,\r\n opts?: UpdateOpts<TStateObject>\r\n) => void;\r\n\r\nexport type UpdateTypeDetail = {\r\n timeStamp: number;\r\n stateKey: string;\r\n updateType: \"update\" | \"insert\" | \"cut\";\r\n path: string[];\r\n status: \"new\" | \"sent\" | \"synced\";\r\n oldValue: any;\r\n newValue: any;\r\n userId?: number;\r\n};\r\n\r\nexport type ActionsType<T> = {\r\n type: \"onChange\";\r\n action: ({ state, actionType }: { state: T; actionType: string }) => void;\r\n debounce?: number;\r\n}[];\r\n\r\ntype ArrayToObject<T extends string[]> = Record<T[number], string>;\r\ntype CookieType<T> = {\r\n timeStamp: number;\r\n value: T;\r\n cookieName: string;\r\n OnUnMountCookie?: Boolean;\r\n};\r\nexport type CogsCookiesType<T extends string[] = string[]> = CookieType<\r\n ArrayToObject<T>\r\n>;\r\nexport type ReactivityType = \"none\" | \"component\" | \"deps\" | \"all\";\r\n\r\ntype ValidationOptionsType = {\r\n key?: string;\r\n zodSchema?: z.ZodTypeAny;\r\n onBlur?: boolean;\r\n};\r\n\r\nexport type OptionsType<T extends unknown = unknown> = {\r\n log?: boolean;\r\n componentId?: string;\r\n serverSync?: ServerSyncType<T>;\r\n validation?: ValidationOptionsType;\r\n enableServerState?: boolean;\r\n serverState?: {\r\n id?: string | number;\r\n data?: T;\r\n status?: \"pending\" | \"error\" | \"success\";\r\n };\r\n sync?: {\r\n action: (state: T) => Promise<{\r\n success: boolean;\r\n data?: any;\r\n error?: any;\r\n errors?: Array<{\r\n path: (string | number)[];\r\n message: string;\r\n }>;\r\n }>;\r\n onSuccess?: (data: any) => void;\r\n onError?: (error: any) => void;\r\n };\r\n middleware?: ({\r\n updateLog,\r\n update,\r\n }: {\r\n updateLog: UpdateTypeDetail[] | undefined;\r\n update: UpdateTypeDetail;\r\n }) => void;\r\n\r\n modifyState?: (state: T) => T;\r\n localStorage?: {\r\n key: string | ((state: T) => string);\r\n onChange?: (state: T) => void;\r\n };\r\n formElements?: FormsElementsType;\r\n enabledSync?: (state: T) => boolean;\r\n reactiveDeps?: (state: T) => any[] | true;\r\n reactiveType?: ReactivityType[] | ReactivityType;\r\n syncUpdate?: Partial<UpdateTypeDetail>;\r\n\r\n initialState?: T;\r\n dependencies?: any[];\r\n};\r\nexport type ServerSyncType<T> = {\r\n testKey?: string;\r\n syncKey: (({ state }: { state: T }) => string) | string;\r\n syncFunction: ({ state }: { state: T }) => void;\r\n debounce?: number;\r\n\r\n snapshot?: {\r\n name: (({ state }: { state: T }) => string) | string;\r\n stateKeys: StateKeys[];\r\n currentUrl: string;\r\n currentParams?: URLSearchParams;\r\n };\r\n};\r\nexport type SyncActionsType<T> = {\r\n syncKey: string;\r\n\r\n rollBackState?: T;\r\n actionTimeStamp: number;\r\n retryCount?: number;\r\n status:\r\n | \"success\"\r\n | \"waiting\"\r\n | \"rolledBack\"\r\n | \"error\"\r\n | \"cancelled\"\r\n | \"failed\";\r\n snapshot?: {\r\n name: string;\r\n stateKeys: StateKeys[];\r\n currentUrl: string;\r\n currentParams?: URLSearchParams;\r\n };\r\n};\r\n\r\nexport type ValidationWrapperOptions<T extends unknown = unknown> = {\r\n children: React.ReactNode;\r\n active: boolean;\r\n stretch?: boolean;\r\n path: string[];\r\n message?: string;\r\n data?: T;\r\n key?: string;\r\n};\r\nexport type SyncRenderOptions<T extends unknown = unknown> = {\r\n children: React.ReactNode;\r\n time: number;\r\n data?: T;\r\n key?: string;\r\n};\r\n\r\ntype FormsElementsType<T extends unknown = unknown> = {\r\n validation?: (options: ValidationWrapperOptions<T>) => React.ReactNode;\r\n syncRender?: (options: SyncRenderOptions<T>) => React.ReactNode;\r\n};\r\n\r\nexport type InitialStateInnerType<T extends unknown = unknown> = {\r\n initialState: T;\r\n} & OptionsType<T>;\r\n\r\nexport type InitialStateType<T> = {\r\n [key: string]: InitialStateInnerType<T>;\r\n};\r\n\r\nexport type AllStateTypes<T extends unknown> = Record<string, T>;\r\n\r\nexport type CogsInitialState<T> = {\r\n initialState: T;\r\n formElements?: FormsElementsType<T>;\r\n};\r\n\r\nexport type TransformedStateType<T> = {\r\n [P in keyof T]: T[P] extends CogsInitialState<infer U> ? U : T[P];\r\n};\r\n\r\nfunction setAndMergeOptions(stateKey: string, newOptions: OptionsType<any>) {\r\n const getInitialOptions = getGlobalStore.getState().getInitialOptions;\r\n const setInitialStateOptions =\r\n getGlobalStore.getState().setInitialStateOptions;\r\n\r\n const initialOptions = getInitialOptions(stateKey as string) || {};\r\n\r\n setInitialStateOptions(stateKey as string, {\r\n ...initialOptions,\r\n ...newOptions,\r\n });\r\n}\r\n\r\n// Fix for the setOptions function\r\nfunction setOptions<StateKey, Opt>({\r\n stateKey,\r\n options,\r\n initialOptionsPart,\r\n}: {\r\n stateKey: StateKey;\r\n options?: OptionsType<any>;\r\n initialOptionsPart: Record<string, any>;\r\n}) {\r\n const initialOptions = getInitialOptions(stateKey as string) || {};\r\n const initialOptionsPartState = initialOptionsPart[stateKey as string] || {};\r\n const setInitialStateOptions =\r\n getGlobalStore.getState().setInitialStateOptions;\r\n const mergedOptions = { ...initialOptionsPartState, ...initialOptions };\r\n\r\n let needToAdd = false;\r\n if (options) {\r\n for (const key in options) {\r\n if (!mergedOptions.hasOwnProperty(key)) {\r\n needToAdd = true;\r\n mergedOptions[key] = options[key as keyof typeof options];\r\n } else {\r\n if (\r\n key == \"localStorage\" &&\r\n options[key] &&\r\n mergedOptions[key].key !== options[key]?.key\r\n ) {\r\n needToAdd = true;\r\n mergedOptions[key] = options[key];\r\n }\r\n if (\r\n key == \"initialState\" &&\r\n options[key] &&\r\n mergedOptions[key] !== options[key] && // Different references\r\n !isDeepEqual(mergedOptions[key], options[key]) // And different values\r\n ) {\r\n needToAdd = true;\r\n mergedOptions[key] = options[key];\r\n }\r\n }\r\n }\r\n }\r\n\r\n if (needToAdd) {\r\n setInitialStateOptions(stateKey as string, mergedOptions);\r\n }\r\n}\r\nexport function addStateOptions<T extends unknown>(\r\n initialState: T,\r\n { formElements, validation }: OptionsType<T>\r\n) {\r\n return { initialState: initialState, formElements, validation } as T;\r\n}\r\n\r\nexport const createCogsState = <State extends Record<string, unknown>>(\r\n initialState: State,\r\n opt?: { formElements?: FormsElementsType; validation?: ValidationOptionsType }\r\n) => {\r\n let newInitialState = initialState;\r\n\r\n // Extract state parts and options using transformStateFunc\r\n const [statePart, initialOptionsPart] =\r\n transformStateFunc<State>(newInitialState);\r\n\r\n // Apply global formElements as defaults to each state key's options\r\n if (\r\n Object.keys(initialOptionsPart).length > 0 ||\r\n (opt && Object.keys(opt).length > 0)\r\n ) {\r\n Object.keys(initialOptionsPart).forEach((key) => {\r\n // Get the existing options for this state key\r\n initialOptionsPart[key] = initialOptionsPart[key] || {};\r\n\r\n initialOptionsPart[key].formElements = {\r\n ...opt?.formElements, // Global defaults first\r\n ...opt?.validation,\r\n ...(initialOptionsPart[key].formElements || {}), // State-specific overrides\r\n };\r\n const existingOptions = getInitialOptions(key);\r\n\r\n if (!existingOptions) {\r\n getGlobalStore\r\n .getState()\r\n .setInitialStateOptions(key, initialOptionsPart[key]);\r\n }\r\n });\r\n }\r\n\r\n getGlobalStore.getState().setInitialStates(statePart);\r\n getGlobalStore.getState().setCreatedState(statePart);\r\n type StateKeys = keyof typeof statePart;\r\n\r\n const useCogsState = <StateKey extends StateKeys>(\r\n stateKey: StateKey,\r\n options?: OptionsType<(typeof statePart)[StateKey]>\r\n ) => {\r\n const [componentId] = useState(options?.componentId ?? uuidv4());\r\n\r\n setOptions({\r\n stateKey,\r\n options,\r\n initialOptionsPart,\r\n });\r\n\r\n const thiState =\r\n getGlobalStore.getState().cogsStateStore[stateKey as string] ||\r\n statePart[stateKey as string];\r\n const partialState = options?.modifyState\r\n ? options.modifyState(thiState)\r\n : thiState;\r\n\r\n const [state, updater] = useCogsStateFn<(typeof statePart)[StateKey]>(\r\n partialState,\r\n {\r\n stateKey: stateKey as string,\r\n syncUpdate: options?.syncUpdate,\r\n componentId,\r\n localStorage: options?.localStorage,\r\n middleware: options?.middleware,\r\n enabledSync: options?.enabledSync,\r\n reactiveType: options?.reactiveType,\r\n reactiveDeps: options?.reactiveDeps,\r\n initialState: options?.initialState as any,\r\n dependencies: options?.dependencies,\r\n serverState: options?.serverState,\r\n }\r\n );\r\n\r\n return updater;\r\n };\r\n\r\n function setCogsOptions<StateKey extends StateKeys>(\r\n stateKey: StateKey,\r\n options: OptionsType<(typeof statePart)[StateKey]>\r\n ) {\r\n setOptions({ stateKey, options, initialOptionsPart });\r\n\r\n if (options.localStorage) {\r\n loadAndApplyLocalStorage(stateKey as string, options);\r\n }\r\n\r\n notifyComponents(stateKey as string);\r\n }\r\n\r\n return { useCogsState, setCogsOptions };\r\n};\r\n\r\nconst {\r\n setUpdaterState,\r\n setState,\r\n getInitialOptions,\r\n getKeyState,\r\n getValidationErrors,\r\n setStateLog,\r\n updateInitialStateGlobal,\r\n addValidationError,\r\n removeValidationError,\r\n setServerSyncActions,\r\n} = getGlobalStore.getState();\r\nconst saveToLocalStorage = <T,>(\r\n state: T,\r\n thisKey: string,\r\n currentInitialOptions: any,\r\n sessionId?: string,\r\n lastSyncedWithServer?: number\r\n) => {\r\n if (currentInitialOptions?.log) {\r\n console.log(\r\n \"saving to localstorage\",\r\n thisKey,\r\n currentInitialOptions.localStorage?.key,\r\n sessionId\r\n );\r\n }\r\n\r\n const key = isFunction(currentInitialOptions?.localStorage?.key)\r\n ? currentInitialOptions.localStorage?.key(state)\r\n : currentInitialOptions?.localStorage?.key;\r\n\r\n if (key && sessionId) {\r\n const storageKey = `${sessionId}-${thisKey}-${key}`;\r\n\r\n // Get existing data to preserve lastSyncedWithServer if not explicitly updating it\r\n let existingLastSynced: number | undefined;\r\n try {\r\n const existing = loadFromLocalStorage(storageKey);\r\n existingLastSynced = existing?.lastSyncedWithServer;\r\n } catch {\r\n // Ignore errors, will use undefined\r\n }\r\n\r\n const data: LocalStorageData<T> = {\r\n state,\r\n lastUpdated: Date.now(),\r\n lastSyncedWithServer: lastSyncedWithServer ?? existingLastSynced,\r\n };\r\n\r\n // Use SuperJSON serialize to get the json part only\r\n const superJsonResult = superjson.serialize(data);\r\n window.localStorage.setItem(\r\n storageKey,\r\n JSON.stringify(superJsonResult.json)\r\n );\r\n }\r\n};\r\n\r\nconst loadFromLocalStorage = (localStorageKey: string) => {\r\n if (!localStorageKey) return null;\r\n\r\n try {\r\n const storedData = window.localStorage.getItem(localStorageKey);\r\n if (!storedData) return null;\r\n\r\n // Parse the json part back normally\r\n const parsedData = JSON.parse(storedData);\r\n\r\n return parsedData;\r\n } catch (error) {\r\n console.error(\"Error loading from localStorage:\", error);\r\n return null;\r\n }\r\n};\r\nconst loadAndApplyLocalStorage = (stateKey: string, options: any) => {\r\n const currentState = getGlobalStore.getState().cogsStateStore[stateKey];\r\n const { sessionId } = useCogsConfig();\r\n const localkey = isFunction(options?.localStorage?.key)\r\n ? options.localStorage.key(currentState)\r\n : options?.localStorage?.key;\r\n\r\n if (localkey && sessionId) {\r\n const localData = loadFromLocalStorage(\r\n `${sessionId}-${stateKey}-${localkey}`\r\n );\r\n\r\n if (\r\n localData &&\r\n localData.lastUpdated > (localData.lastSyncedWithServer || 0)\r\n ) {\r\n setState(stateKey, localData.state);\r\n\r\n notifyComponents(stateKey);\r\n return true;\r\n }\r\n }\r\n return false;\r\n};\r\n\r\ntype LocalStorageData<T> = {\r\n state: T;\r\n lastUpdated: number;\r\n lastSyncedWithServer?: number;\r\n baseServerState?: T; // Add this to track what server state our changes are based on\r\n};\r\n\r\nconst updateGlobalState = (\r\n thisKey: string,\r\n initialState: any,\r\n newState: any,\r\n effectiveSetState: EffectiveSetState<any>,\r\n componentId: string,\r\n sessionId?: string\r\n) => {\r\n // Update all global state at once\r\n const updates = {\r\n initialState: initialState,\r\n updaterState: createProxyHandler(\r\n thisKey,\r\n effectiveSetState,\r\n componentId,\r\n sessionId\r\n ),\r\n state: newState,\r\n };\r\n\r\n updateInitialStateGlobal(thisKey, updates.initialState);\r\n setUpdaterState(thisKey, updates.updaterState);\r\n setState(thisKey, updates.state);\r\n};\r\n\r\nconst notifyComponents = (thisKey: string) => {\r\n const stateEntry = getGlobalStore.getState().stateComponents.get(thisKey);\r\n if (!stateEntry) return;\r\n\r\n // Batch component updates\r\n const updates = new Set<() => void>();\r\n stateEntry.components.forEach((component) => {\r\n const reactiveTypes = component\r\n ? Array.isArray(component.reactiveType)\r\n ? component.reactiveType\r\n : [component.reactiveType || \"component\"]\r\n : null;\r\n if (!reactiveTypes?.includes(\"none\")) {\r\n updates.add(() => component.forceUpdate());\r\n }\r\n });\r\n\r\n // Schedule updates in the next tick to allow batching\r\n queueMicrotask(() => {\r\n updates.forEach((update) => update());\r\n });\r\n};\r\n\r\nexport const notifyComponent = (stateKey: string, componentId: string) => {\r\n const stateEntry = getGlobalStore.getState().stateComponents.get(stateKey);\r\n if (stateEntry) {\r\n const fullComponentId = `${stateKey}////${componentId}`;\r\n const component = stateEntry.components.get(fullComponentId);\r\n const reactiveTypes = component\r\n ? Array.isArray(component.reactiveType)\r\n ? component.reactiveType\r\n : [component.reactiveType || \"component\"]\r\n : null;\r\n\r\n // Skip if reactivity is disabled\r\n if (reactiveTypes?.includes(\"none\")) {\r\n return;\r\n }\r\n\r\n if (component) {\r\n // Force an update to ensure the current value is saved\r\n\r\n component.forceUpdate();\r\n }\r\n }\r\n};\r\nconst getUpdateValues = (\r\n updateType: string,\r\n prevValue: any,\r\n payload: any,\r\n path: string[]\r\n) => {\r\n switch (updateType) {\r\n case \"update\":\r\n return {\r\n oldValue: getNestedValue(prevValue, path),\r\n newValue: getNestedValue(payload, path),\r\n };\r\n case \"insert\":\r\n return {\r\n oldValue: null, // or undefined\r\n newValue: getNestedValue(payload, path),\r\n };\r\n case \"cut\":\r\n return {\r\n oldValue: getNestedValue(prevValue, path),\r\n newValue: null, // or undefined\r\n };\r\n default:\r\n return { oldValue: null, newValue: null };\r\n }\r\n};\r\nexport function useCogsStateFn<TStateObject extends unknown>(\r\n stateObject: TStateObject,\r\n {\r\n stateKey,\r\n serverSync,\r\n localStorage,\r\n formElements,\r\n reactiveDeps,\r\n reactiveType,\r\n componentId,\r\n initialState,\r\n syncUpdate,\r\n dependencies,\r\n serverState,\r\n }: {\r\n stateKey?: string;\r\n componentId?: string;\r\n initialState?: TStateObject;\r\n } & OptionsType<TStateObject> = {}\r\n) {\r\n const [reactiveForce, forceUpdate] = useState({}); //this is the key to reactivity\r\n const { sessionId } = useCogsConfig();\r\n\r\n let noStateKey = stateKey ? false : true;\r\n const [thisKey] = useState(stateKey ?? uuidv4());\r\n const stateLog = getGlobalStore.getState().stateLog[thisKey];\r\n const componentUpdatesRef = useRef(new Set<string>());\r\n const componentIdRef = useRef(componentId ?? uuidv4());\r\n const latestInitialOptionsRef = useRef<OptionsType<TStateObject> | null>(\r\n null\r\n );\r\n latestInitialOptionsRef.current = (getInitialOptions(thisKey as string) ??\r\n null) as OptionsType<TStateObject> | null;\r\n\r\n useEffect(() => {\r\n if (syncUpdate && syncUpdate.stateKey === thisKey && syncUpdate.path?.[0]) {\r\n // Update the actual state value\r\n setState(thisKey, (prevState: any) => ({\r\n ...prevState,\r\n [syncUpdate.path![0]!]: syncUpdate.newValue,\r\n }));\r\n\r\n // Create combined key and update sync info\r\n const syncKey = `${syncUpdate.stateKey}:${syncUpdate.path.join(\".\")}`;\r\n getGlobalStore.getState().setSyncInfo(syncKey, {\r\n timeStamp: syncUpdate.timeStamp!,\r\n userId: syncUpdate.userId!,\r\n });\r\n }\r\n }, [syncUpdate]);\r\n useEffect(() => {\r\n // Only proceed if initialState is provided\r\n if (initialState) {\r\n setAndMergeOptions(thisKey as string, {\r\n initialState,\r\n });\r\n\r\n const options = latestInitialOptionsRef.current;\r\n const hasServerId = options?.serverState?.id !== undefined;\r\n const hasServerData =\r\n hasServerId &&\r\n options?.serverState?.status === \"success\" &&\r\n options?.serverState?.data;\r\n\r\n const currentGloballyStoredInitialState =\r\n getGlobalStore.getState().initialStateGlobal[thisKey];\r\n\r\n const initialStateChanged =\r\n (currentGloballyStoredInitialState &&\r\n !isDeepEqual(currentGloballyStoredInitialState, initialState)) ||\r\n !currentGloballyStoredInitialState;\r\n\r\n if (!initialStateChanged && !hasServerData) {\r\n return;\r\n }\r\n\r\n let localData = null;\r\n const localkey = isFunction(options?.localStorage?.key)\r\n ? options?.localStorage?.key(initialState)\r\n : options?.localStorage?.key;\r\n\r\n if (localkey && sessionId) {\r\n localData = loadFromLocalStorage(`${sessionId}-${thisKey}-${localkey}`);\r\n }\r\n\r\n let newState = initialState;\r\n let isFromServer = false;\r\n\r\n const serverTimestamp = hasServerData ? Date.now() : 0;\r\n const localTimestamp = localData?.lastUpdated || 0;\r\n const lastSyncTimestamp = localData?.lastSyncedWithServer || 0;\r\n\r\n if (hasServerData && serverTimestamp > localTimestamp) {\r\n newState = options.serverState!.data!;\r\n isFromServer = true;\r\n } else if (localData && localTimestamp > lastSyncTimestamp) {\r\n newState = localData.state;\r\n if (options?.localStorage?.onChange) {\r\n options?.localStorage?.onChange(newState);\r\n }\r\n }\r\n getGlobalStore.getState().initializeShadowState(thisKey, initialState);\r\n // Update the global state\r\n updateGlobalState(\r\n thisKey,\r\n initialState,\r\n newState,\r\n effectiveSetState,\r\n componentIdRef.current,\r\n sessionId\r\n );\r\n\r\n // Save to localStorage if we used server data\r\n if (isFromServer && localkey && sessionId) {\r\n saveToLocalStorage(newState, thisKey, options, sessionId, Date.now());\r\n }\r\n\r\n // Notify components of the change\r\n notifyComponents(thisKey);\r\n\r\n const reactiveTypes = Array.isArray(reactiveType)\r\n ? reactiveType\r\n : [reactiveType || \"component\"];\r\n\r\n if (!reactiveTypes.includes(\"none\")) {\r\n forceUpdate({});\r\n }\r\n }\r\n }, [\r\n initialState,\r\n serverState?.status,\r\n serverState?.data,\r\n ...(dependencies || []),\r\n ]);\r\n useLayoutEffect(() => {\r\n if (noStateKey) {\r\n setAndMergeOptions(thisKey as string, {\r\n serverSync,\r\n formElements,\r\n initialState,\r\n localStorage,\r\n middleware: latestInitialOptionsRef.current?.middleware,\r\n });\r\n }\r\n\r\n const componentKey = `${thisKey}////${componentIdRef.current}`;\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(thisKey) || {\r\n components: new Map(),\r\n };\r\n\r\n stateEntry.components.set(componentKey, {\r\n forceUpdate: () => forceUpdate({}),\r\n paths: new Set(),\r\n deps: [],\r\n depsFunction: reactiveDeps || undefined,\r\n reactiveType: reactiveType ?? [\"component\", \"deps\"],\r\n });\r\n\r\n getGlobalStore.getState().stateComponents.set(thisKey, stateEntry);\r\n //need to force update to create the stateUpdates references\r\n forceUpdate({});\r\n return () => {\r\n if (stateEntry) {\r\n stateEntry.components.delete(componentKey);\r\n if (stateEntry.components.size === 0) {\r\n getGlobalStore.getState().stateComponents.delete(thisKey);\r\n }\r\n }\r\n };\r\n }, []);\r\n\r\n const effectiveSetState = (\r\n newStateOrFunction: UpdateArg<TStateObject>,\r\n path: string[],\r\n updateObj: { updateType: \"insert\" | \"cut\" | \"update\" },\r\n validationKey?: string\r\n ) => {\r\n if (Array.isArray(path)) {\r\n const pathKey = `${thisKey}-${path.join(\".\")}`;\r\n componentUpdatesRef.current.add(pathKey);\r\n }\r\n setState(thisKey, (prevValue: TStateObject) => {\r\n const payload = isFunction<TStateObject>(newStateOrFunction)\r\n ? newStateOrFunction(prevValue as TStateObject)\r\n : newStateOrFunction;\r\n\r\n const signalId = `${thisKey}-${path.join(\".\")}`;\r\n if (signalId) {\r\n let isArrayOperation = false;\r\n let elements = getGlobalStore\r\n .getState()\r\n .signalDomElements.get(signalId);\r\n\r\n if (\r\n (!elements || elements.size === 0) &&\r\n (updateObj.updateType === \"insert\" || updateObj.updateType === \"cut\")\r\n ) {\r\n // Remove last segment (index) from path\r\n const arrayPath = path.slice(0, -1);\r\n const arrayValue = getNestedValue(payload, arrayPath);\r\n // If it's an array, use that path for signal\r\n if (Array.isArray(arrayValue)) {\r\n isArrayOperation = true;\r\n const arraySignalId = `${thisKey}-${arrayPath.join(\".\")}`;\r\n elements = getGlobalStore\r\n .getState()\r\n .signalDomElements.get(arraySignalId);\r\n }\r\n }\r\n\r\n if (elements) {\r\n const newValue = isArrayOperation\r\n ? getNestedValue(payload, path.slice(0, -1))\r\n : getNestedValue(payload, path);\r\n elements.forEach(({ parentId, position, effect }) => {\r\n const parent = document.querySelector(\r\n `[data-parent-id=\"${parentId}\"]`\r\n );\r\n if (parent) {\r\n const childNodes = Array.from(parent.childNodes);\r\n if (childNodes[position]) {\r\n const displayValue = effect\r\n ? new Function(\"state\", `return (${effect})(state)`)(newValue)\r\n : newValue;\r\n childNodes[position].textContent = String(displayValue);\r\n }\r\n }\r\n });\r\n }\r\n }\r\n\r\n const shadowUpdate = () => {\r\n const store = getGlobalStore.getState();\r\n\r\n switch (updateObj.updateType) {\r\n case \"update\":\r\n // For updates, just mirror the structure at the path\r\n store.updateShadowAtPath(thisKey, path, payload);\r\n break;\r\n\r\n case \"insert\":\r\n // For array insert, add empty element to shadow array\r\n const parentPath = path.slice(0, -1);\r\n store.insertShadowArrayElement(thisKey, parentPath);\r\n break;\r\n\r\n case \"cut\":\r\n // For array cut, remove element from shadow array\r\n const arrayPath = path.slice(0, -1);\r\n const index = parseInt(path[path.length - 1]!);\r\n store.removeShadowArrayElement(thisKey, arrayPath, index);\r\n break;\r\n }\r\n };\r\n\r\n shadowUpdate();\r\n console.log(\"shadowState\", getGlobalStore.getState().shadowStateStore);\r\n if (\r\n updateObj.updateType === \"update\" &&\r\n (validationKey || latestInitialOptionsRef.current?.validation?.key) &&\r\n path\r\n ) {\r\n removeValidationError(\r\n (validationKey || latestInitialOptionsRef.current?.validation?.key) +\r\n \".\" +\r\n path.join(\".\")\r\n );\r\n }\r\n const arrayWithoutIndex = path.slice(0, path.length - 1);\r\n if (\r\n updateObj.updateType === \"cut\" &&\r\n latestInitialOptionsRef.current?.validation?.key\r\n ) {\r\n removeValidationError(\r\n latestInitialOptionsRef.current?.validation?.key +\r\n \".\" +\r\n arrayWithoutIndex.join(\".\")\r\n );\r\n }\r\n if (\r\n updateObj.updateType === \"insert\" &&\r\n latestInitialOptionsRef.current?.validation?.key\r\n ) {\r\n let getValidation = getValidationErrors(\r\n latestInitialOptionsRef.current?.validation?.key +\r\n \".\" +\r\n arrayWithoutIndex.join(\".\")\r\n );\r\n\r\n //TODO this is untested its supposed to cahnge teh validation errors alreaady stored when a new entry is push\r\n\r\n getValidation.filter(([k, v]) => {\r\n let length = k?.split(\".\").length;\r\n\r\n if (\r\n k == arrayWithoutIndex.join(\".\") &&\r\n length == arrayWithoutIndex.length - 1\r\n ) {\r\n // console.log(length, pathWithoutIndex.length);\r\n let newKey = k + \".\" + arrayWithoutIndex;\r\n removeValidationError(k!);\r\n addValidationError(newKey, v!);\r\n }\r\n });\r\n }\r\n\r\n const stateEntry = getGlobalStore.getState().stateComponents.get(thisKey);\r\n console.log(\"stateEntry >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>\", stateEntry);\r\n if (stateEntry) {\r\n const changedPaths = getDifferences(prevValue, payload);\r\n const changedPathsSet = new Set(changedPaths);\r\n const primaryPathToCheck =\r\n updateObj.updateType === \"update\"\r\n ? path.join(\".\")\r\n : path.slice(0, -1).join(\".\") || \"\";\r\n\r\n for (const [\r\n componentKey,\r\n component,\r\n ] of stateEntry.components.entries()) {\r\n let shouldUpdate = false;\r\n const reactiveTypes = Array.isArray(component.reactiveType)\r\n ? component.reactiveType\r\n : [component.reactiveType || \"component\"];\r\n console.log(\"component\", component);\r\n if (reactiveTypes.includes(\"none\")) continue;\r\n if (reactiveTypes.includes(\"all\")) {\r\n component.forceUpdate();\r\n continue;\r\n }\r\n\r\n if (reactiveTypes.includes(\"component\")) {\r\n if (\r\n component.paths.has(primaryPathToCheck) ||\r\n component.paths.has(\"\")\r\n ) {\r\n shouldUpdate = true;\r\n }\r\n\r\n if (!shouldUpdate) {\r\n for (const changedPath of changedPathsSet) {\r\n let currentPathToCheck = changedPath;\r\n while (true) {\r\n if (component.paths.has(currentPathToCheck)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n const lastDotIndex = currentPathToCheck.lastIndexOf(\".\");\r\n if (lastDotIndex !== -1) {\r\n const parentPath = currentPathToCheck.substring(\r\n 0,\r\n lastDotIndex\r\n );\r\n if (\r\n !isNaN(\r\n Number(currentPathToCheck.substring(lastDotIndex + 1))\r\n )\r\n ) {\r\n if (component.paths.has(parentPath)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n }\r\n currentPathToCheck = parentPath;\r\n } else {\r\n currentPathToCheck = \"\";\r\n }\r\n if (currentPathToCheck === \"\") {\r\n break;\r\n }\r\n }\r\n if (shouldUpdate) break;\r\n }\r\n }\r\n }\r\n\r\n if (!shouldUpdate && reactiveTypes.includes(\"deps\")) {\r\n if (component.depsFunction) {\r\n const depsResult = component.depsFunction(payload);\r\n let depsChanged = false;\r\n if (typeof depsResult === \"boolean\") {\r\n if (depsResult) depsChanged = true;\r\n } else if (!isDeepEqual(component.deps, depsResult)) {\r\n component.deps = depsResult;\r\n depsChanged = true;\r\n }\r\n if (depsChanged) {\r\n shouldUpdate = true;\r\n }\r\n }\r\n }\r\n if (shouldUpdate) {\r\n component.forceUpdate();\r\n }\r\n }\r\n }\r\n const timeStamp = Date.now();\r\n\r\n path = path.map((p, i) => {\r\n const arrayPath = path.slice(0, -1);\r\n const arrayValue = getNestedValue(payload, arrayPath);\r\n\r\n return i === path.length - 1 &&\r\n [\"insert\", \"cut\"].includes(updateObj.updateType)\r\n ? (arrayValue.length - 1).toString()\r\n : p;\r\n });\r\n\r\n const { oldValue, newValue } = getUpdateValues(\r\n updateObj.updateType,\r\n prevValue,\r\n payload,\r\n path\r\n );\r\n const newUpdate = {\r\n timeStamp,\r\n stateKey: thisKey,\r\n path,\r\n updateType: updateObj.updateType,\r\n status: \"new\" as const,\r\n oldValue,\r\n newValue,\r\n } satisfies UpdateTypeDetail;\r\n\r\n setStateLog(thisKey, (prevLogs) => {\r\n const logs = [...(prevLogs ?? []), newUpdate];\r\n\r\n // Aggregate the updates by stateKey and path\r\n const aggregatedLogs = logs.reduce((acc, log) => {\r\n const uniqueKey = `${log.stateKey}:${JSON.stringify(log.path)}`;\r\n const existing = acc.get(uniqueKey);\r\n\r\n if (existing) {\r\n // Update the existing entry with the most recent details\r\n existing.timeStamp = Math.max(existing.timeStamp, log.timeStamp);\r\n existing.newValue = log.newValue; // Overwrite with the latest value\r\n existing.oldValue = existing.oldValue ?? log.oldValue; // Retain the initial oldValue\r\n existing.updateType = log.updateType; // Update to the most recent type\r\n } else {\r\n // Add the log if no existing match is found\r\n acc.set(uniqueKey, { ...(log as any) });\r\n }\r\n\r\n return acc;\r\n }, new Map<string, typeof newUpdate>());\r\n\r\n // Convert the aggregated map back to an array\r\n return Array.from(aggregatedLogs.values());\r\n });\r\n\r\n saveToLocalStorage(\r\n payload,\r\n thisKey,\r\n latestInitialOptionsRef.current,\r\n sessionId\r\n );\r\n\r\n if (latestInitialOptionsRef.current?.middleware) {\r\n latestInitialOptionsRef.current!.middleware({\r\n updateLog: stateLog,\r\n update: newUpdate,\r\n });\r\n }\r\n if (latestInitialOptionsRef.current?.serverSync) {\r\n const serverStateStore = getGlobalStore.getState().serverState[thisKey];\r\n const serverSync = latestInitialOptionsRef.current?.serverSync;\r\n setServerSyncActions(thisKey, {\r\n syncKey:\r\n typeof serverSync.syncKey == \"string\"\r\n ? serverSync.syncKey\r\n : serverSync.syncKey({ state: payload }),\r\n rollBackState: serverStateStore,\r\n actionTimeStamp: Date.now() + (serverSync.debounce ?? 3000),\r\n status: \"waiting\",\r\n });\r\n }\r\n\r\n return payload;\r\n });\r\n };\r\n if (!getGlobalStore.getState().updaterState[thisKey]) {\r\n setUpdaterState(\r\n thisKey,\r\n createProxyHandler(\r\n thisKey,\r\n effectiveSetState,\r\n componentIdRef.current,\r\n sessionId\r\n )\r\n );\r\n if (!getGlobalStore.getState().cogsStateStore[thisKey]) {\r\n setState(thisKey, stateObject);\r\n }\r\n if (!getGlobalStore.getState().initialStateGlobal[thisKey]) {\r\n updateInitialStateGlobal(thisKey, stateObject);\r\n }\r\n }\r\n\r\n const updaterFinal = useMemo(() => {\r\n // Create proxy with baseObject as target\r\n return createProxyHandler<TStateObject>(\r\n thisKey,\r\n effectiveSetState,\r\n componentIdRef.current,\r\n sessionId\r\n );\r\n }, [thisKey, sessionId]);\r\n\r\n return [getKeyState(thisKey), updaterFinal] as [\r\n TStateObject,\r\n StateObject<TStateObject>,\r\n ];\r\n}\r\n\r\nfunction createProxyHandler<T>(\r\n stateKey: string,\r\n effectiveSetState: EffectiveSetState<T>,\r\n componentId: string,\r\n sessionId?: string\r\n): StateObject<T> {\r\n // ADDED: Enhanced cache with versioning\r\n type CacheEntry = {\r\n proxy: any;\r\n stateVersion: number;\r\n };\r\n const shapeCache = new Map<string, CacheEntry>();\r\n let stateVersion = 0;\r\n\r\n // ADDED: Cache invalidation helper\r\n const invalidateCachePath = (path: string[]) => {\r\n const pathKey = path.join(\".\");\r\n for (const [key] of shapeCache) {\r\n if (key === pathKey || key.startsWith(pathKey + \".\")) {\r\n shapeCache.delete(key);\r\n }\r\n }\r\n stateVersion++;\r\n };\r\n\r\n const baseObj = {\r\n removeValidation: (obj?: { validationKey?: string }) => {\r\n if (obj?.validationKey) {\r\n removeValidationError(obj.validationKey);\r\n }\r\n },\r\n\r\n revertToInitialState: (obj?: { validationKey?: string }) => {\r\n const init = getGlobalStore\r\n .getState()\r\n .getInitialOptions(stateKey)?.validation;\r\n if (init?.key) {\r\n removeValidationError(init?.key);\r\n }\r\n\r\n if (obj?.validationKey) {\r\n removeValidationError(obj.validationKey);\r\n }\r\n\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n\r\n getGlobalStore.getState().clearSelectedIndexesForState(stateKey);\r\n // ADDED: Clear cache on revert\r\n shapeCache.clear();\r\n stateVersion++;\r\n\r\n const newProxy = rebuildStateShape(initialState, []);\r\n const initalOptionsGet = getInitialOptions(stateKey as string);\r\n const localKey = isFunction(initalOptionsGet?.localStorage?.key)\r\n ? initalOptionsGet?.localStorage?.key(initialState)\r\n : initalOptionsGet?.localStorage?.key;\r\n\r\n const storageKey = `${sessionId}-${stateKey}-${localKey}`;\r\n\r\n if (storageKey) {\r\n localStorage.removeItem(storageKey);\r\n }\r\n\r\n setUpdaterState(stateKey, newProxy);\r\n setState(stateKey, initialState);\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n if (stateEntry) {\r\n stateEntry.components.forEach((component) => {\r\n component.forceUpdate();\r\n });\r\n }\r\n\r\n return initialState;\r\n },\r\n updateInitialState: (newState: T) => {\r\n // ADDED: Clear cache on initial state update\r\n shapeCache.clear();\r\n stateVersion++;\r\n\r\n const newUpdaterState = createProxyHandler(\r\n stateKey,\r\n effectiveSetState,\r\n componentId,\r\n sessionId\r\n );\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n const initalOptionsGet = getInitialOptions(stateKey as string);\r\n const localKey = isFunction(initalOptionsGet?.localStorage?.key)\r\n ? initalOptionsGet?.localStorage?.key(initialState)\r\n : initalOptionsGet?.localStorage?.key;\r\n\r\n const storageKey = `${sessionId}-${stateKey}-${localKey}`;\r\n\r\n if (localStorage.getItem(storageKey)) {\r\n localStorage.removeItem(storageKey);\r\n }\r\n startTransition(() => {\r\n updateInitialStateGlobal(stateKey, newState);\r\n getGlobalStore.getState().initializeShadowState(stateKey, newState);\r\n setUpdaterState(stateKey, newUpdaterState);\r\n setState(stateKey, newState);\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n\r\n if (stateEntry) {\r\n stateEntry.components.forEach((component) => {\r\n component.forceUpdate();\r\n });\r\n }\r\n });\r\n\r\n return {\r\n fetchId: (field: keyof T) => newUpdaterState.get()[field],\r\n };\r\n },\r\n _initialState: getGlobalStore.getState().initialStateGlobal[stateKey],\r\n _serverState: getGlobalStore.getState().serverState[stateKey],\r\n _isLoading: getGlobalStore.getState().isLoadingGlobal[stateKey],\r\n _isServerSynced: () => {\r\n const serverState = getGlobalStore.getState().serverState[stateKey];\r\n return Boolean(\r\n serverState && isDeepEqual(serverState, getKeyState(stateKey))\r\n );\r\n },\r\n };\r\n\r\n function rebuildStateShape(\r\n currentState: T,\r\n path: string[] = [],\r\n meta?: { filtered?: string[][]; validIndices?: number[] }\r\n ): any {\r\n const cacheKey = path.map(String).join(\".\");\r\n\r\n // MODIFIED: Cache check with version\r\n const cachedEntry = shapeCache.get(cacheKey);\r\n\r\n type CallableStateObject<T> = {\r\n (): T;\r\n } & {\r\n [key: string]: any;\r\n };\r\n\r\n const baseFunction = function () {\r\n return getGlobalStore().getNestedState(stateKey, path);\r\n } as unknown as CallableStateObject<T>;\r\n\r\n // Copy properties from baseObj to the function with type assertion\r\n Object.keys(baseObj).forEach((key) => {\r\n (baseFunction as any)[key] = (baseObj as any)[key];\r\n });\r\n\r\n const handler = {\r\n apply(target: any, thisArg: any, args: any[]) {\r\n console.log(\r\n `PROXY APPLY TRAP HIT: stateKey=${stateKey}, path=${path.join(\".\")}`\r\n ); // <--- ADD LOGGING\r\n console.trace(\"Apply trap stack trace\");\r\n return getGlobalStore().getNestedState(stateKey, path);\r\n },\r\n\r\n get(target: any, prop: string) {\r\n if (meta?.validIndices && !Array.isArray(currentState)) {\r\n meta = { ...meta, validIndices: undefined };\r\n }\r\n const mutationMethods = new Set([\r\n \"insert\",\r\n \"cut\",\r\n \"cutByValue\",\r\n \"toggleByValue\",\r\n \"uniqueInsert\",\r\n \"update\",\r\n \"applyJsonPatch\",\r\n \"setSelected\",\r\n \"toggleSelected\",\r\n \"clearSelected\",\r\n \"sync\",\r\n \"validateZodSchema\",\r\n \"revertToInitialState\",\r\n \"updateInitialState\",\r\n \"removeValidation\",\r\n \"setValidation\",\r\n \"removeStorage\",\r\n \"middleware\",\r\n \"_componentId\",\r\n \"_stateKey\",\r\n \"getComponents\",\r\n ]);\r\n if (\r\n prop !== \"then\" &&\r\n !prop.startsWith(\"$\") &&\r\n prop !== \"stateMapNoRender\" &&\r\n !mutationMethods.has(prop)\r\n ) {\r\n const fullComponentId = `${stateKey}////${componentId}`;\r\n // console.log(\"adding path\", fullComponentId, path, prop);\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n\r\n if (stateEntry) {\r\n const component = stateEntry.components.get(fullComponentId);\r\n\r\n if (component) {\r\n // Mark as initialized immediately to prevent re-processing\r\n\r\n // Now do the path tracking logic ONCE\r\n if (!component.paths.has(\"\")) {\r\n const currentPath = path.join(\".\");\r\n let needsAdd = true;\r\n for (const existingPath of component.paths) {\r\n if (\r\n currentPath.startsWith(existingPath) &&\r\n (currentPath === existingPath ||\r\n currentPath[existingPath.length] === \".\")\r\n ) {\r\n needsAdd = false;\r\n break;\r\n }\r\n }\r\n\r\n if (needsAdd) {\r\n component.paths.add(currentPath);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n if (prop === \"getDifferences\") {\r\n return () => {\r\n const differences = getDifferences(\r\n getGlobalStore.getState().cogsStateStore[stateKey],\r\n getGlobalStore.getState().initialStateGlobal[stateKey]\r\n );\r\n return differences;\r\n };\r\n }\r\n if (prop === \"sync\" && path.length === 0) {\r\n return async function () {\r\n // Get the options for this state key\r\n const options = getGlobalStore\r\n .getState()\r\n .getInitialOptions(stateKey);\r\n const sync = options?.sync;\r\n\r\n if (!sync) {\r\n console.error(`No mutation defined for state key \"${stateKey}\"`);\r\n return { success: false, error: `No mutation defined` };\r\n }\r\n\r\n // Get the root state\r\n const state = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, []);\r\n\r\n // Get validation key\r\n const validationKey = options?.validation?.key;\r\n\r\n try {\r\n // Execute the mutation action\r\n const response = await sync.action(state);\r\n\r\n // Handle validation errors\r\n if (\r\n response &&\r\n !response.success &&\r\n response.errors &&\r\n validationKey\r\n ) {\r\n // Clear existing errors\r\n getGlobalStore.getState().removeValidationError(validationKey);\r\n\r\n // Add new validation errors\r\n response.errors.forEach((error) => {\r\n const errorPath = [validationKey, ...error.path].join(\".\");\r\n\r\n getGlobalStore\r\n .getState()\r\n .addValidationError(errorPath, error.message);\r\n });\r\n\r\n // Notify components to update\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n if (stateEntry) {\r\n stateEntry.components.forEach((component) => {\r\n component.forceUpdate();\r\n });\r\n }\r\n }\r\n\r\n // Call success/error callbacks\r\n if (response?.success && sync.onSuccess) {\r\n sync.onSuccess(response.data);\r\n } else if (!response?.success && sync.onError) {\r\n sync.onError(response.error);\r\n }\r\n\r\n return response;\r\n } catch (error) {\r\n if (sync.onError) {\r\n sync.onError(error);\r\n }\r\n return { success: false, error };\r\n }\r\n };\r\n }\r\n if (prop === \"_status\") {\r\n // Get current state at this path (non-reactive version)\r\n const thisReactiveState = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path);\r\n\r\n // Get initial state at this path\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n const initialStateAtPath = getNestedValue(initialState, path);\r\n\r\n // Simply compare current state with initial state\r\n if (isDeepEqual(thisReactiveState, initialStateAtPath)) {\r\n return \"fresh\"; // Matches initial state\r\n } else {\r\n return \"stale\"; // Different from initial state\r\n }\r\n }\r\n if (prop === \"getStatus\") {\r\n return function () {\r\n // Get current state at this path (reactive version)\r\n const thisReactiveState = getGlobalStore().getNestedState(\r\n stateKey,\r\n path\r\n );\r\n\r\n // Get initial state at this path\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n const initialStateAtPath = getNestedValue(initialState, path);\r\n // Simply compare current state with initial state\r\n if (isDeepEqual(thisReactiveState, initialStateAtPath)) {\r\n return \"fresh\"; // Matches initial state\r\n } else {\r\n return \"stale\"; // Different from initial state\r\n }\r\n };\r\n }\r\n if (prop === \"removeStorage\") {\r\n return () => {\r\n const initialState =\r\n getGlobalStore.getState().initialStateGlobal[stateKey];\r\n const initalOptionsGet = getInitialOptions(stateKey as string);\r\n const localKey = isFunction(initalOptionsGet?.localStorage?.key)\r\n ? initalOptionsGet?.localStorage?.key(initialState)\r\n : initalOptionsGet?.localStorage?.key;\r\n\r\n const storageKey = `${sessionId}-${stateKey}-${localKey}`;\r\n\r\n if (storageKey) {\r\n localStorage.removeItem(storageKey);\r\n }\r\n };\r\n }\r\n if (prop === \"showValidationErrors\") {\r\n return () => {\r\n const init = getGlobalStore\r\n .getState()\r\n .getInitialOptions(stateKey)?.validation;\r\n\r\n if (!init?.key) {\r\n throw new Error(\"Validation key not found\");\r\n }\r\n const errors = getGlobalStore\r\n .getState()\r\n .getValidationErrors(init.key + \".\" + path.join(\".\"));\r\n\r\n return errors;\r\n };\r\n }\r\n if (Array.isArray(currentState)) {\r\n const getSourceArrayAndIndices = (): {\r\n item: any;\r\n originalIndex: number;\r\n }[] => {\r\n // If meta exists, we're in a chain. Use the currentState and map it to its original index.\r\n if (meta?.validIndices) {\r\n return (currentState as any[]).map((item, index) => ({\r\n item,\r\n originalIndex: meta!.validIndices![index]!,\r\n }));\r\n }\r\n // Otherwise, this is the first operation. Use the full array from the global store.\r\n const sourceArray = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n return sourceArray.map((item, index) => ({\r\n item,\r\n originalIndex: index,\r\n }));\r\n };\r\n if (prop === \"getSelected\") {\r\n return () => {\r\n const selectedIndex = getGlobalStore\r\n .getState()\r\n .getSelectedIndex(stateKey, path.join(\".\"));\r\n if (selectedIndex === undefined) return undefined;\r\n return rebuildStateShape(\r\n currentState[selectedIndex],\r\n [...path, selectedIndex.toString()],\r\n meta\r\n );\r\n };\r\n }\r\n if (prop === \"clearSelected\") {\r\n return () => {\r\n getGlobalStore.getState().clearSelectedIndex({ stateKey, path });\r\n };\r\n }\r\n if (prop === \"getSelectedIndex\") {\r\n return () => {\r\n const selectedIndex = getGlobalStore\r\n .getState()\r\n .getSelectedIndex(stateKey, path.join(\".\"));\r\n\r\n return selectedIndex ?? -1;\r\n };\r\n }\r\n\r\n if (prop === \"useVirtualView\") {\r\n return (\r\n options: VirtualViewOptions\r\n ): VirtualStateObjectResult<any[]> => {\r\n const {\r\n itemHeight,\r\n overscan = 5,\r\n stickToBottom = false,\r\n } = options;\r\n\r\n const containerRef = useRef<HTMLDivElement | null>(null);\r\n const [range, setRange] = useState({\r\n startIndex: 0,\r\n endIndex: 10,\r\n });\r\n\r\n // --- State Tracking Refs ---\r\n const isAtBottomRef = useRef(stickToBottom);\r\n const previousTotalCountRef = useRef(0);\r\n // NEW: Ref to explicitly track if this is the component's first render cycle.\r\n const isInitialMountRef = useRef(true);\r\n\r\n const sourceArray = getGlobalStore().getNestedState(\r\n stateKey,\r\n path\r\n ) as any[];\r\n const totalCount = sourceArray.length;\r\n\r\n const virtualState = useMemo(() => {\r\n const start = Math.max(0, range.startIndex);\r\n const end = Math.min(totalCount, range.endIndex);\r\n const validIndices = Array.from(\r\n { length: end - start },\r\n (_, i) => start + i\r\n );\r\n const slicedArray = validIndices.map((idx) => sourceArray[idx]);\r\n return rebuildStateShape(slicedArray as any, path, {\r\n ...meta,\r\n validIndices,\r\n });\r\n }, [range.startIndex, range.endIndex, sourceArray, totalCount]);\r\n\r\n useLayoutEffect(() => {\r\n const container = containerRef.current;\r\n if (!container) return;\r\n\r\n const wasAtBottom = isAtBottomRef.current;\r\n const listGrew = totalCount > previousTotalCountRef.current;\r\n previousTotalCountRef.current = totalCount;\r\n\r\n const handleScroll = () => {\r\n const { scrollTop, clientHeight, scrollHeight } = container;\r\n isAtBottomRef.current =\r\n scrollHeight - scrollTop - clientHeight < 10;\r\n const start = Math.max(\r\n 0,\r\n Math.floor(scrollTop / itemHeight) - overscan\r\n );\r\n const end = Math.min(\r\n totalCount,\r\n Math.ceil((scrollTop + clientHeight) / itemHeight) +\r\n overscan\r\n );\r\n setRange((prevRange) => {\r\n if (\r\n prevRange.startIndex !== start ||\r\n prevRange.endIndex !== end\r\n ) {\r\n return { startIndex: start, endIndex: end };\r\n }\r\n return prevRange;\r\n });\r\n };\r\n\r\n container.addEventListener(\"scroll\", handleScroll, {\r\n passive: true,\r\n });\r\n\r\n // --- THE CORRECTED DECISION LOGIC ---\r\n if (stickToBottom) {\r\n if (isInitialMountRef.current) {\r\n // SCENARIO 1: First render of the component.\r\n // Go to the bottom unconditionally. Use `auto` scroll for an instant jump.\r\n container.scrollTo({\r\n top: container.scrollHeight,\r\n behavior: \"auto\",\r\n });\r\n } else if (wasAtBottom && listGrew) {\r\n // SCENARIO 2: Subsequent renders (new messages arrive).\r\n // Only scroll if the user was already at the bottom.\r\n // Use `smooth` for a nice animated scroll for new messages.\r\n requestAnimationFrame(() => {\r\n container.scrollTo({\r\n top: container.scrollHeight,\r\n behavior: \"smooth\",\r\n });\r\n });\r\n }\r\n }\r\n\r\n // After the logic runs, it's no longer the initial mount.\r\n isInitialMountRef.current = false;\r\n\r\n // Always run handleScroll once to set the initial visible window.\r\n handleScroll();\r\n\r\n return () =>\r\n container.removeEventListener(\"scroll\", handleScroll);\r\n }, [totalCount, itemHeight, overscan, stickToBottom]);\r\n\r\n const scrollToBottom = useCallback(\r\n (behavior: ScrollBehavior = \"smooth\") => {\r\n if (containerRef.current) {\r\n containerRef.current.scrollTo({\r\n top: containerRef.current.scrollHeight,\r\n behavior,\r\n });\r\n }\r\n },\r\n []\r\n );\r\n\r\n const scrollToIndex = useCallback(\r\n (index: number, behavior: ScrollBehavior = \"smooth\") => {\r\n if (containerRef.current) {\r\n containerRef.current.scrollTo({\r\n top: index * itemHeight,\r\n behavior,\r\n });\r\n }\r\n },\r\n [itemHeight]\r\n );\r\n\r\n // Same virtualizer props as before\r\n const virtualizerProps = {\r\n outer: {\r\n ref: containerRef,\r\n style: { overflowY: \"auto\", height: \"100%\" },\r\n },\r\n inner: {\r\n style: {\r\n height: `${totalCount * itemHeight}px`,\r\n position: \"relative\",\r\n },\r\n },\r\n list: {\r\n style: {\r\n transform: `translateY(${range.startIndex * itemHeight}px)`,\r\n },\r\n },\r\n };\r\n\r\n return {\r\n virtualState,\r\n virtualizerProps: virtualizerProps as any,\r\n scrollToBottom,\r\n scrollToIndex,\r\n };\r\n };\r\n }\r\n if (prop === \"stateSort\") {\r\n return (\r\n compareFn: (\r\n a: InferArrayElement<T>,\r\n b: InferArrayElement<T>\r\n ) => number\r\n ) => {\r\n const sourceWithIndices = getSourceArrayAndIndices();\r\n const sortedResult = [...sourceWithIndices].sort((a, b) =>\r\n compareFn(a.item, b.item)\r\n );\r\n const newCurrentState = sortedResult.map(({ item }) => item);\r\n // We construct the meta object with the CORRECT property name: `validIndices`.\r\n const newMeta = {\r\n ...meta,\r\n validIndices: sortedResult.map(\r\n ({ originalIndex }) => originalIndex\r\n ),\r\n };\r\n return rebuildStateShape(newCurrentState as any, path, newMeta);\r\n };\r\n }\r\n\r\n if (prop === \"stateFilter\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n index: number\r\n ) => boolean\r\n ) => {\r\n const sourceWithIndices = getSourceArrayAndIndices();\r\n const filteredResult = sourceWithIndices.filter(\r\n ({ item }, index) => callbackfn(item, index)\r\n );\r\n const newCurrentState = filteredResult.map(({ item }) => item);\r\n // We construct the meta object with the CORRECT property name: `validIndices`.\r\n const newMeta = {\r\n ...meta,\r\n validIndices: filteredResult.map(\r\n ({ originalIndex }) => originalIndex\r\n ),\r\n };\r\n return rebuildStateShape(newCurrentState as any, path, newMeta);\r\n };\r\n }\r\n\r\n if (prop === \"stateMap\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n setter: StateObject<InferArrayElement<T>>,\r\n info: {\r\n register: () => void;\r\n index: number;\r\n originalIndex: number;\r\n }\r\n ) => any\r\n ) => {\r\n const arrayToMap = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n\r\n // Defensive check to make sure we are mapping over an array\r\n if (!Array.isArray(arrayToMap)) {\r\n console.warn(\r\n `stateMap called on a non-array value at path: ${path.join(\".\")}. The current value is:`,\r\n arrayToMap\r\n );\r\n return null;\r\n }\r\n\r\n // If we have validIndices, only map those items\r\n const indicesToMap =\r\n meta?.validIndices ||\r\n Array.from({ length: arrayToMap.length }, (_, i) => i);\r\n\r\n return indicesToMap.map((originalIndex, localIndex) => {\r\n const item = arrayToMap[originalIndex];\r\n const finalPath = [...path, originalIndex.toString()];\r\n const setter = rebuildStateShape(item, finalPath, meta);\r\n\r\n // Create the register function right here. It closes over the necessary variables.\r\n const register = () => {\r\n const [, forceUpdate] = useState({});\r\n const itemComponentId = `${componentId}-${path.join(\".\")}-${originalIndex}`;\r\n\r\n useLayoutEffect(() => {\r\n const fullComponentId = `${stateKey}////${itemComponentId}`;\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey) || {\r\n components: new Map(),\r\n };\r\n\r\n stateEntry.components.set(fullComponentId, {\r\n forceUpdate: () => forceUpdate({}),\r\n paths: new Set([finalPath.join(\".\")]),\r\n });\r\n\r\n getGlobalStore\r\n .getState()\r\n .stateComponents.set(stateKey, stateEntry);\r\n\r\n return () => {\r\n const currentEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n if (currentEntry) {\r\n currentEntry.components.delete(fullComponentId);\r\n }\r\n };\r\n }, [stateKey, itemComponentId]);\r\n };\r\n\r\n return callbackfn(item, setter, {\r\n register,\r\n index: localIndex,\r\n originalIndex,\r\n });\r\n });\r\n };\r\n }\r\n if (prop === \"stateMapNoRender\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n setter: StateObject<InferArrayElement<T>>,\r\n index: number,\r\n array: T,\r\n arraySetter: StateObject<T>\r\n ) => any\r\n ) => {\r\n const arrayToMap = currentState as any[];\r\n return arrayToMap.map((item, index) => {\r\n let originalIndex: number;\r\n // We READ from the meta object using the CORRECT property name: `validIndices`.\r\n if (\r\n meta?.validIndices &&\r\n meta.validIndices[index] !== undefined\r\n ) {\r\n originalIndex = meta.validIndices[index]!;\r\n } else {\r\n originalIndex = index;\r\n }\r\n const finalPath = [...path, originalIndex.toString()];\r\n\r\n const setter = rebuildStateShape(item, finalPath, meta); // Pass meta through\r\n return callbackfn(\r\n item,\r\n setter,\r\n index,\r\n currentState as any,\r\n rebuildStateShape(currentState as any, path, meta)\r\n );\r\n });\r\n };\r\n }\r\n if (prop === \"$stateMap\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n setter: StateObject<InferArrayElement<T>>,\r\n index: number,\r\n array: T,\r\n arraySetter: StateObject<T>\r\n ) => void\r\n ) => {\r\n return createElement(SignalMapRenderer, {\r\n proxy: {\r\n _stateKey: stateKey,\r\n _path: path,\r\n _mapFn: callbackfn as any, // Pass the actual function, not string\r\n },\r\n\r\n rebuildStateShape,\r\n });\r\n };\r\n }\r\n\r\n if (prop === \"stateFlattenOn\") {\r\n return (fieldName: string) => {\r\n const arrayToMap = currentState as any[];\r\n shapeCache.clear();\r\n stateVersion++;\r\n const flattenedResults = arrayToMap.flatMap(\r\n (val: any) => val[fieldName] ?? []\r\n );\r\n return rebuildStateShape(\r\n flattenedResults as any,\r\n [...path, \"[*]\", fieldName],\r\n meta\r\n );\r\n };\r\n }\r\n\r\n if (prop === \"index\") {\r\n return (index: number) => {\r\n const indexValue = currentState[index];\r\n return rebuildStateShape(indexValue, [...path, index.toString()]);\r\n };\r\n }\r\n if (prop === \"last\") {\r\n // Added handler for 'last'\r\n return () => {\r\n const currentArray = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n if (currentArray.length === 0) return undefined;\r\n const lastIndex = currentArray.length - 1;\r\n const lastValue = currentArray[lastIndex];\r\n const newPath = [...path, lastIndex.toString()];\r\n // shapeCache.clear(); // Decide if you need cache invalidation for 'last' access\r\n // stateVersion++;\r\n return rebuildStateShape(lastValue, newPath);\r\n };\r\n }\r\n if (prop === \"insert\") {\r\n return (payload: UpdateArg<T>) => {\r\n // ADDED: Invalidate cache on insert\r\n invalidateCachePath(path);\r\n pushFunc(effectiveSetState, payload, path, stateKey);\r\n return rebuildStateShape(\r\n getGlobalStore.getState().getNestedState(stateKey, path),\r\n path\r\n );\r\n };\r\n }\r\n\r\n if (prop === \"uniqueInsert\") {\r\n return (\r\n payload: UpdateArg<T>,\r\n fields?: (keyof InferArrayElement<T>)[],\r\n onMatch?: (existingItem: any) => any\r\n ) => {\r\n const currentArray = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n const newValue = isFunction<T>(payload)\r\n ? payload(currentArray as any)\r\n : (payload as any);\r\n\r\n let matchedItem: any = null;\r\n const isUnique = !currentArray.some((item) => {\r\n if (fields) {\r\n const isMatch = fields.every((field) =>\r\n isDeepEqual(item[field], newValue[field])\r\n );\r\n if (isMatch) {\r\n matchedItem = item;\r\n }\r\n return isMatch;\r\n }\r\n const isMatch = isDeepEqual(item, newValue);\r\n if (isMatch) {\r\n matchedItem = item;\r\n }\r\n return isMatch;\r\n });\r\n\r\n if (isUnique) {\r\n invalidateCachePath(path);\r\n pushFunc(effectiveSetState, newValue, path, stateKey);\r\n } else if (onMatch && matchedItem) {\r\n const updatedItem = onMatch(matchedItem);\r\n const updatedArray = currentArray.map((item) =>\r\n isDeepEqual(item, matchedItem) ? updatedItem : item\r\n );\r\n invalidateCachePath(path);\r\n updateFn(effectiveSetState, updatedArray as any, path);\r\n }\r\n };\r\n }\r\n\r\n if (prop === \"cut\") {\r\n return (index: number, options?: { waitForSync?: boolean }) => {\r\n if (options?.waitForSync) return;\r\n // ADDED: Invalidate cache on cut\r\n invalidateCachePath(path);\r\n cutFunc(effectiveSetState, path, stateKey, index);\r\n return rebuildStateShape(\r\n getGlobalStore.getState().getNestedState(stateKey, path),\r\n path\r\n );\r\n };\r\n }\r\n if (prop === \"cutByValue\") {\r\n return (value: string | number | boolean) => {\r\n for (let index = 0; index < currentState.length; index++) {\r\n if (currentState[index] === value) {\r\n cutFunc(effectiveSetState, path, stateKey, index);\r\n }\r\n }\r\n };\r\n }\r\n if (prop === \"toggleByValue\") {\r\n return (value: string | number | boolean) => {\r\n const index = currentState.findIndex((item) => item === value);\r\n if (index > -1) {\r\n // Value exists, so cut it\r\n cutFunc(effectiveSetState, path, stateKey, index);\r\n } else {\r\n // Value doesn't exist, so insert it\r\n pushFunc(effectiveSetState, value as any, path, stateKey);\r\n }\r\n };\r\n }\r\n if (prop === \"stateFind\") {\r\n return (\r\n callbackfn: (\r\n value: InferArrayElement<T>,\r\n index: number\r\n ) => boolean\r\n ) => {\r\n const sourceWithIndices = getSourceArrayAndIndices();\r\n const found = sourceWithIndices.find(({ item }, index) =>\r\n callbackfn(item, index)\r\n );\r\n if (!found) return undefined;\r\n const finalPath = [...path, found.originalIndex.toString()];\r\n return rebuildStateShape(found.item, finalPath, meta);\r\n };\r\n }\r\n\r\n if (prop === \"findWith\") {\r\n return (thisKey: keyof InferArrayElement<T>, thisValue: any) => {\r\n const sourceWithIndices = getSourceArrayAndIndices();\r\n const found = sourceWithIndices.find(\r\n ({ item }) => item[thisKey] === thisValue\r\n );\r\n if (!found) return undefined;\r\n const finalPath = [...path, found.originalIndex.toString()];\r\n return rebuildStateShape(found.item, finalPath, meta);\r\n };\r\n }\r\n }\r\n const lastPathElement = path[path.length - 1];\r\n if (!isNaN(Number(lastPathElement))) {\r\n const parentPath = path.slice(0, -1);\r\n const parentValue = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, parentPath);\r\n\r\n if (Array.isArray(parentValue) && prop === \"cut\") {\r\n return () =>\r\n cutFunc(\r\n effectiveSetState,\r\n parentPath,\r\n stateKey,\r\n Number(lastPathElement)\r\n );\r\n }\r\n }\r\n\r\n if (prop === \"get\") {\r\n return () => {\r\n if (meta?.validIndices && Array.isArray(currentState)) {\r\n // For filtered arrays, return only the items at validIndices\r\n const fullArray = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path) as any[];\r\n return meta.validIndices.map((index) => fullArray[index]);\r\n }\r\n return getGlobalStore.getState().getNestedState(stateKey, path);\r\n };\r\n }\r\n if (prop === \"$derive\") {\r\n return (fn: any) =>\r\n $cogsSignal({\r\n _stateKey: stateKey,\r\n _path: path,\r\n _effect: fn.toString(),\r\n });\r\n }\r\n\r\n if (prop === \"$get\") {\r\n return () =>\r\n $cogsSignal({\r\n _stateKey: stateKey,\r\n _path: path,\r\n });\r\n }\r\n if (prop === \"lastSynced\") {\r\n const syncKey = `${stateKey}:${path.join(\".\")}`;\r\n return getGlobalStore.getState().getSyncInfo(syncKey);\r\n }\r\n\r\n if (prop == \"getLocalStorage\") {\r\n return (key: string) =>\r\n loadFromLocalStorage(sessionId + \"-\" + stateKey + \"-\" + key);\r\n }\r\n if (prop === \"_selected\") {\r\n const parentPath = path.slice(0, -1);\r\n const parentKey = parentPath.join(\".\");\r\n const parent = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, parentPath);\r\n if (Array.isArray(parent)) {\r\n const currentIndex = Number(path[path.length - 1]);\r\n return (\r\n currentIndex ===\r\n getGlobalStore.getState().getSelectedIndex(stateKey, parentKey)\r\n );\r\n }\r\n return undefined;\r\n }\r\n if (prop === \"setSelected\") {\r\n return (value: boolean) => {\r\n const parentPath = path.slice(0, -1);\r\n const thisIndex = Number(path[path.length - 1]);\r\n const parentKey = parentPath.join(\".\");\r\n\r\n if (value) {\r\n getGlobalStore\r\n .getState()\r\n .setSelectedIndex(stateKey, parentKey, thisIndex);\r\n } else {\r\n getGlobalStore\r\n .getState()\r\n .setSelectedIndex(stateKey, parentKey, undefined);\r\n }\r\n\r\n const nested = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, [...parentPath]);\r\n updateFn(effectiveSetState, nested, parentPath);\r\n\r\n // Invalidate cache for this path\r\n invalidateCachePath(parentPath);\r\n };\r\n }\r\n if (prop === \"toggleSelected\") {\r\n return () => {\r\n const parentPath = path.slice(0, -1);\r\n const thisIndex = Number(path[path.length - 1]);\r\n const parentKey = parentPath.join(\".\");\r\n const selectedIndex = getGlobalStore\r\n .getState()\r\n .getSelectedIndex(stateKey, parentKey);\r\n\r\n getGlobalStore\r\n .getState()\r\n .setSelectedIndex(\r\n stateKey,\r\n parentKey,\r\n selectedIndex === thisIndex ? undefined : thisIndex\r\n );\r\n const nested = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, [...parentPath]);\r\n updateFn(effectiveSetState, nested, parentPath);\r\n\r\n invalidateCachePath(parentPath);\r\n };\r\n }\r\n if (path.length == 0) {\r\n if (prop === \"applyJsonPatch\") {\r\n return (patches: any[]) => {\r\n // This part is correct.\r\n const currentState =\r\n getGlobalStore.getState().cogsStateStore[stateKey];\r\n const patchResult = applyPatch(currentState, patches);\r\n const newState = patchResult.newDocument;\r\n\r\n // This is also correct.\r\n updateGlobalState(\r\n stateKey,\r\n getGlobalStore.getState().initialStateGlobal[stateKey],\r\n newState,\r\n effectiveSetState,\r\n componentId,\r\n sessionId\r\n );\r\n\r\n // ===================================================================\r\n // REPLACE THE OLD LOGIC WITH THIS DIRECT COPY\r\n // ===================================================================\r\n\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey); // Use stateKey here\r\n\r\n if (stateEntry) {\r\n // Use `getDifferences` between the state before and after the patch.\r\n const changedPaths = getDifferences(currentState, newState);\r\n const changedPathsSet = new Set(changedPaths);\r\n\r\n // There is no single `primaryPathToCheck` for a patch, so we just check against the full set.\r\n\r\n for (const [\r\n componentKey,\r\n component,\r\n ] of stateEntry.components.entries()) {\r\n let shouldUpdate = false;\r\n const reactiveTypes = Array.isArray(component.reactiveType)\r\n ? component.reactiveType\r\n : [component.reactiveType || \"component\"];\r\n\r\n if (reactiveTypes.includes(\"none\")) continue;\r\n if (reactiveTypes.includes(\"all\")) {\r\n component.forceUpdate();\r\n continue;\r\n }\r\n\r\n if (reactiveTypes.includes(\"component\")) {\r\n // This is the core logic that needs to be copied.\r\n // Check if any of the component's watched paths are in the set of changed paths.\r\n if (component.paths.has(\"\")) {\r\n // Always update for root listeners\r\n shouldUpdate = true;\r\n }\r\n\r\n if (!shouldUpdate) {\r\n for (const changedPath of changedPathsSet) {\r\n // Direct match first (fastest)\r\n if (component.paths.has(changedPath)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n\r\n // Check parent paths more efficiently\r\n let dotIndex = changedPath.lastIndexOf(\".\");\r\n while (dotIndex !== -1) {\r\n const parentPath = changedPath.substring(0, dotIndex);\r\n if (component.paths.has(parentPath)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n // Skip numeric segments more efficiently\r\n const lastSegment = changedPath.substring(\r\n dotIndex + 1\r\n );\r\n if (!isNaN(Number(lastSegment))) {\r\n // For array indices, check the parent collection path\r\n const parentDotIndex = parentPath.lastIndexOf(\".\");\r\n if (parentDotIndex !== -1) {\r\n const grandParentPath = parentPath.substring(\r\n 0,\r\n parentDotIndex\r\n );\r\n if (component.paths.has(grandParentPath)) {\r\n shouldUpdate = true;\r\n break;\r\n }\r\n }\r\n }\r\n dotIndex = parentPath.lastIndexOf(\".\");\r\n }\r\n\r\n if (shouldUpdate) break;\r\n }\r\n }\r\n }\r\n\r\n if (!shouldUpdate && reactiveTypes.includes(\"deps\")) {\r\n // Use `newState` (the result of the patch) for dependency checks.\r\n if (component.depsFunction) {\r\n const depsResult = component.depsFunction(newState);\r\n let depsChanged = false;\r\n if (typeof depsResult === \"boolean\") {\r\n if (depsResult) depsChanged = true;\r\n } else if (!isDeepEqual(component.deps, depsResult)) {\r\n component.deps = depsResult;\r\n depsChanged = true;\r\n }\r\n if (depsChanged) {\r\n shouldUpdate = true;\r\n }\r\n }\r\n }\r\n\r\n if (shouldUpdate) {\r\n component.forceUpdate();\r\n }\r\n }\r\n }\r\n };\r\n }\r\n if (prop === \"validateZodSchema\") {\r\n return () => {\r\n const init = getGlobalStore\r\n .getState()\r\n .getInitialOptions(stateKey)?.validation;\r\n const addValidationError =\r\n getGlobalStore.getState().addValidationError;\r\n\r\n if (!init?.zodSchema) {\r\n throw new Error(\"Zod schema not found\");\r\n }\r\n\r\n if (!init?.key) {\r\n throw new Error(\"Validation key not found\");\r\n }\r\n removeValidationError(init.key);\r\n const thisObject =\r\n getGlobalStore.getState().cogsStateStore[stateKey];\r\n\r\n try {\r\n // First clear any existing validation errors for this schema\r\n // This ensures we don't have stale errors\r\n const existingErrors = getGlobalStore\r\n .getState()\r\n .getValidationErrors(init.key);\r\n if (existingErrors && existingErrors.length > 0) {\r\n existingErrors.forEach(([errorPath]) => {\r\n if (errorPath && errorPath.startsWith(init.key!)) {\r\n removeValidationError(errorPath);\r\n }\r\n });\r\n }\r\n\r\n // Attempt to validate with Zod\r\n const result = init.zodSchema.safeParse(thisObject);\r\n\r\n if (!result.success) {\r\n // Process Zod errors and add them to the validation store\r\n const zodErrors = result.error.errors;\r\n\r\n zodErrors.forEach((error) => {\r\n const errorPath = error.path;\r\n const errorMessage = error.message;\r\n\r\n // Build the full path for the validation error\r\n // Format: validationKey.path.to.field\r\n const fullErrorPath = [init.key, ...errorPath].join(\".\");\r\n\r\n // Add the error to the store\r\n addValidationError(fullErrorPath, errorMessage);\r\n });\r\n\r\n notifyComponents(stateKey);\r\n\r\n return false;\r\n }\r\n\r\n return true;\r\n } catch (error) {\r\n console.error(\"Zod schema validation failed\", error);\r\n return false;\r\n }\r\n };\r\n }\r\n if (prop === \"_componentId\") return componentId;\r\n if (prop === \"getComponents\") {\r\n return () => getGlobalStore().stateComponents.get(stateKey);\r\n }\r\n if (prop === \"getAllFormRefs\") {\r\n return () => {\r\n return formRefStore.getState().getFormRefsByStateKey(stateKey);\r\n };\r\n }\r\n\r\n if (prop === \"_initialState\")\r\n return getGlobalStore.getState().initialStateGlobal[stateKey];\r\n if (prop === \"_serverState\")\r\n return getGlobalStore.getState().serverState[stateKey];\r\n if (prop === \"_isLoading\")\r\n return getGlobalStore.getState().isLoadingGlobal[stateKey];\r\n if (prop === \"revertToInitialState\")\r\n return baseObj.revertToInitialState;\r\n if (prop === \"updateInitialState\") return baseObj.updateInitialState;\r\n if (prop === \"removeValidation\") return baseObj.removeValidation;\r\n }\r\n if (prop === \"getFormRef\") {\r\n return () => {\r\n return formRefStore\r\n .getState()\r\n .getFormRef(stateKey + \".\" + path.join(\".\"));\r\n };\r\n }\r\n\r\n if (prop === \"validationWrapper\") {\r\n return ({\r\n children,\r\n hideMessage,\r\n }: {\r\n children: React.ReactNode;\r\n hideMessage?: boolean;\r\n }) => (\r\n <ValidationWrapper\r\n formOpts={\r\n hideMessage ? { validation: { message: \"\" } } : undefined\r\n }\r\n path={path}\r\n validationKey={\r\n getGlobalStore.getState().getInitialOptions(stateKey)\r\n ?.validation?.key || \"\"\r\n }\r\n stateKey={stateKey}\r\n validIndices={meta?.validIndices}\r\n >\r\n {children}\r\n </ValidationWrapper>\r\n );\r\n }\r\n\r\n if (prop === \"_stateKey\") return stateKey;\r\n if (prop === \"_path\") return path;\r\n if (prop === \"_isServerSynced\") return baseObj._isServerSynced;\r\n\r\n if (prop === \"update\") {\r\n return (payload: UpdateArg<T>, opts?: UpdateOpts<T>) => {\r\n // ADDED: Invalidate cache on update\r\n if (opts?.debounce) {\r\n debounce(() => {\r\n updateFn(effectiveSetState, payload, path, \"\");\r\n const newValue = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path);\r\n if (opts?.afterUpdate) opts.afterUpdate(newValue);\r\n }, opts.debounce);\r\n } else {\r\n updateFn(effectiveSetState, payload, path, \"\");\r\n const newValue = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, path);\r\n if (opts?.afterUpdate) opts.afterUpdate(newValue);\r\n }\r\n invalidateCachePath(path);\r\n };\r\n }\r\n\r\n if (prop === \"formElement\") {\r\n return (child: FormControl<T>, formOpts?: FormOptsType) => {\r\n return (\r\n <FormControlComponent<T>\r\n setState={effectiveSetState}\r\n stateKey={stateKey}\r\n path={path}\r\n child={child}\r\n formOpts={formOpts}\r\n />\r\n );\r\n };\r\n }\r\n\r\n const nextPath = [...path, prop];\r\n const nextValue = getGlobalStore\r\n .getState()\r\n .getNestedState(stateKey, nextPath);\r\n return rebuildStateShape(nextValue, nextPath, meta);\r\n },\r\n };\r\n\r\n const proxyInstance = new Proxy(baseFunction, handler);\r\n\r\n shapeCache.set(cacheKey, {\r\n proxy: proxyInstance,\r\n stateVersion: stateVersion,\r\n });\r\n\r\n return proxyInstance;\r\n }\r\n\r\n return rebuildStateShape(\r\n getGlobalStore.getState().getNestedState(stateKey, [])\r\n );\r\n}\r\n\r\nexport function $cogsSignal(proxy: {\r\n _path: string[];\r\n _stateKey: string;\r\n _effect?: string;\r\n}) {\r\n return createElement(SignalRenderer, { proxy });\r\n}\r\n\r\nfunction SignalMapRenderer({\r\n proxy,\r\n\r\n rebuildStateShape,\r\n}: {\r\n proxy: {\r\n _stateKey: string;\r\n _path: string[];\r\n _mapFn: (\r\n value: any,\r\n setter: any,\r\n index: number,\r\n array: any[],\r\n arraySetter: any\r\n ) => ReactNode;\r\n };\r\n\r\n rebuildStateShape: (\r\n currentState: any,\r\n path: string[],\r\n meta?: { filtered?: string[][]; validIndices?: number[] }\r\n ) => any;\r\n}) {\r\n const value = getGlobalStore().getNestedState(proxy._stateKey, proxy._path);\r\n\r\n if (!Array.isArray(value)) {\r\n return null;\r\n }\r\n const arraySetter = rebuildStateShape(\r\n value,\r\n proxy._path\r\n ) as ArrayEndType<any>;\r\n // Use existing global state management\r\n return arraySetter.stateMapNoRender(\r\n (item, setter, index, value, arraysetter) => {\r\n // Execute map function in React context with existing state/proxies\r\n return proxy._mapFn(item, setter, index, value, arraysetter);\r\n }\r\n );\r\n}\r\nfunction SignalRenderer({\r\n proxy,\r\n}: {\r\n proxy: {\r\n _path: string[];\r\n _stateKey: string;\r\n _effect?: string;\r\n };\r\n}) {\r\n const elementRef = useRef<HTMLSpanElement>(null);\r\n const signalId = `${proxy._stateKey}-${proxy._path.join(\".\")}`;\r\n\r\n useEffect(() => {\r\n const element = elementRef.current;\r\n if (!element || !element.parentElement) return;\r\n\r\n const parentElement = element.parentElement;\r\n const childNodes = Array.from(parentElement.childNodes);\r\n const position = childNodes.indexOf(element);\r\n\r\n let parentId = parentElement.getAttribute(\"data-parent-id\");\r\n if (!parentId) {\r\n parentId = `parent-${crypto.randomUUID()}`;\r\n parentElement.setAttribute(\"data-parent-id\", parentId);\r\n }\r\n\r\n const instanceId = `instance-${crypto.randomUUID()}`;\r\n const elementInfo = {\r\n instanceId,\r\n parentId,\r\n position,\r\n effect: proxy._effect,\r\n };\r\n\r\n getGlobalStore.getState().addSignalElement(signalId, elementInfo);\r\n\r\n // Get the raw value from the store\r\n const value = getGlobalStore\r\n .getState()\r\n .getNestedState(proxy._stateKey, proxy._path);\r\n\r\n let displayValue;\r\n if (proxy._effect) {\r\n try {\r\n displayValue = new Function(\r\n \"state\",\r\n `return (${proxy._effect})(state)`\r\n )(value);\r\n } catch (err) {\r\n console.error(\"Error evaluating effect function during mount:\", err);\r\n displayValue = value; // Fallback to raw value\r\n }\r\n } else {\r\n displayValue = value;\r\n }\r\n\r\n if (displayValue !== null && typeof displayValue === \"object\") {\r\n displayValue = JSON.stringify(displayValue);\r\n }\r\n\r\n const textNode = document.createTextNode(String(displayValue));\r\n element.replaceWith(textNode);\r\n }, [proxy._stateKey, proxy._path.join(\".\"), proxy._effect]);\r\n\r\n return createElement(\"span\", {\r\n ref: elementRef,\r\n style: { display: \"none\" },\r\n \"data-signal-id\": signalId,\r\n });\r\n}\r\nexport function $cogsSignalStore(proxy: {\r\n _path: string[];\r\n _stateKey: string;\r\n}) {\r\n const value = useSyncExternalStore(\r\n (notify) => {\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(proxy._stateKey) || {\r\n components: new Map(),\r\n };\r\n stateEntry.components.set(proxy._stateKey, {\r\n forceUpdate: notify,\r\n paths: new Set([proxy._path.join(\".\")]),\r\n });\r\n return () => stateEntry.components.delete(proxy._stateKey);\r\n },\r\n () => getGlobalStore.getState().getNestedState(proxy._stateKey, proxy._path)\r\n );\r\n return createElement(\"text\", {}, String(value));\r\n}\r\n// This is an internal component. It should NOT be exported.\r\nfunction CogsItemWrapper({\r\n stateKey,\r\n itemComponentId,\r\n itemPath,\r\n children,\r\n}: {\r\n stateKey: string;\r\n itemComponentId: string;\r\n itemPath: string[];\r\n children: React.ReactNode;\r\n}) {\r\n // This is a real component, so we can safely call hooks.\r\n const [, forceUpdate] = useState({});\r\n\r\n // We use useLayoutEffect to register the component and clean up when it unmounts.\r\n useLayoutEffect(() => {\r\n const fullComponentId = `${stateKey}////${itemComponentId}`;\r\n const stateEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey) || {\r\n components: new Map(),\r\n };\r\n\r\n // Register the component with its unique ID and its specific, atomic path.\r\n stateEntry.components.set(fullComponentId, {\r\n forceUpdate: () => forceUpdate({}),\r\n paths: new Set([itemPath.join(\".\")]), // ATOMIC: Subscribes only to this item's path.\r\n });\r\n\r\n getGlobalStore.getState().stateComponents.set(stateKey, stateEntry);\r\n\r\n // Return a cleanup function to unregister on unmount.\r\n return () => {\r\n const currentEntry = getGlobalStore\r\n .getState()\r\n .stateComponents.get(stateKey);\r\n if (currentEntry) {\r\n currentEntry.components.delete(fullComponentId);\r\n }\r\n };\r\n }, [stateKey, itemComponentId, itemPath.join(\".\")]); // Effect dependency array is stable.\r\n\r\n // Render the actual component the user provided.\r\n return <>{children}</>;\r\n}\r\n"],"names":["setAndMergeOptions","stateKey","newOptions","getInitialOptions","getGlobalStore","setInitialStateOptions","initialOptions","setOptions","options","initialOptionsPart","initialOptionsPartState","mergedOptions","needToAdd","key","isDeepEqual","addStateOptions","initialState","formElements","validation","createCogsState","opt","newInitialState","statePart","transformStateFunc","useCogsState","componentId","useState","uuidv4","thiState","partialState","state","updater","useCogsStateFn","setCogsOptions","loadAndApplyLocalStorage","notifyComponents","setUpdaterState","setState","getKeyState","getValidationErrors","setStateLog","updateInitialStateGlobal","addValidationError","removeValidationError","setServerSyncActions","saveToLocalStorage","thisKey","currentInitialOptions","sessionId","lastSyncedWithServer","isFunction","storageKey","existingLastSynced","loadFromLocalStorage","data","superJsonResult","superjson","localStorageKey","storedData","error","currentState","useCogsConfig","localkey","localData","updateGlobalState","newState","effectiveSetState","updates","createProxyHandler","stateEntry","component","update","notifyComponent","fullComponentId","getUpdateValues","updateType","prevValue","payload","path","getNestedValue","stateObject","serverSync","localStorage","reactiveDeps","reactiveType","syncUpdate","dependencies","serverState","reactiveForce","forceUpdate","noStateKey","stateLog","componentUpdatesRef","useRef","componentIdRef","latestInitialOptionsRef","useEffect","prevState","syncKey","hasServerData","currentGloballyStoredInitialState","isFromServer","serverTimestamp","localTimestamp","lastSyncTimestamp","useLayoutEffect","componentKey","newStateOrFunction","updateObj","validationKey","pathKey","signalId","isArrayOperation","elements","arrayPath","arrayValue","arraySignalId","newValue","parentId","position","effect","parent","childNodes","displayValue","store","parentPath","index","arrayWithoutIndex","k","v","length","newKey","changedPaths","getDifferences","changedPathsSet","primaryPathToCheck","shouldUpdate","reactiveTypes","changedPath","currentPathToCheck","lastDotIndex","depsResult","depsChanged","timeStamp","p","i","oldValue","newUpdate","prevLogs","aggregatedLogs","acc","log","uniqueKey","existing","serverStateStore","updaterFinal","useMemo","shapeCache","stateVersion","invalidateCachePath","baseObj","obj","init","newProxy","rebuildStateShape","initalOptionsGet","localKey","newUpdaterState","startTransition","field","meta","cacheKey","baseFunction","handler","target","thisArg","args","prop","mutationMethods","currentPath","needsAdd","existingPath","sync","response","errorPath","thisReactiveState","initialStateAtPath","getSourceArrayAndIndices","item","selectedIndex","itemHeight","overscan","stickToBottom","containerRef","range","setRange","isAtBottomRef","previousTotalCountRef","isInitialMountRef","sourceArray","totalCount","virtualState","start","end","validIndices","_","slicedArray","idx","container","wasAtBottom","listGrew","handleScroll","scrollTop","clientHeight","scrollHeight","prevRange","scrollToBottom","useCallback","behavior","scrollToIndex","virtualizerProps","compareFn","sortedResult","a","b","newCurrentState","newMeta","originalIndex","callbackfn","filteredResult","arrayToMap","localIndex","finalPath","setter","itemComponentId","currentEntry","createElement","SignalMapRenderer","fieldName","flattenedResults","val","indexValue","currentArray","lastIndex","lastValue","newPath","pushFunc","fields","onMatch","matchedItem","isMatch","updatedItem","updatedArray","updateFn","cutFunc","value","found","thisValue","lastPathElement","parentValue","fullArray","fn","$cogsSignal","parentKey","thisIndex","nested","patches","applyPatch","dotIndex","lastSegment","parentDotIndex","grandParentPath","thisObject","existingErrors","result","errorMessage","fullErrorPath","formRefStore","children","hideMessage","jsx","ValidationWrapper","opts","debounce","child","formOpts","FormControlComponent","nextPath","nextValue","proxyInstance","proxy","SignalRenderer","arraysetter","elementRef","element","parentElement","elementInfo","err","textNode","$cogsSignalStore","useSyncExternalStore","notify"],"mappings":";;;;;;;;;;;AAmeA,SAASA,GAAmBC,GAAkBC,GAA8B;AACpEC,QAAAA,IAAoBC,EAAe,SAAA,EAAW,mBAC9CC,IACJD,EAAe,SAAA,EAAW,wBAEtBE,IAAiBH,EAAkBF,CAAkB,KAAK,CAAC;AAEjE,EAAAI,EAAuBJ,GAAoB;AAAA,IACzC,GAAGK;AAAA,IACH,GAAGJ;AAAA,EAAA,CACJ;AACH;AAGA,SAASK,GAA0B;AAAA,EACjC,UAAAN;AAAA,EACA,SAAAO;AAAA,EACA,oBAAAC;AACF,GAIG;AACD,QAAMH,IAAiBH,EAAkBF,CAAkB,KAAK,CAAC,GAC3DS,IAA0BD,EAAmBR,CAAkB,KAAK,CAAC,GACrEI,IACJD,EAAe,SAAA,EAAW,wBACtBO,IAAgB,EAAE,GAAGD,GAAyB,GAAGJ,EAAe;AAEtE,MAAIM,IAAY;AAChB,MAAIJ;AACF,eAAWK,KAAOL;AAChB,MAAKG,EAAc,eAAeE,CAAG,KAKjCA,KAAO,kBACPL,EAAQK,CAAG,KACXF,EAAcE,CAAG,EAAE,QAAQL,EAAQK,CAAG,GAAG,QAE7BD,IAAA,IACED,EAAAE,CAAG,IAAIL,EAAQK,CAAG,IAGhCA,KAAO,kBACPL,EAAQK,CAAG,KACXF,EAAcE,CAAG,MAAML,EAAQK,CAAG;AAAA,MAClC,CAACC,EAAYH,EAAcE,CAAG,GAAGL,EAAQK,CAAG,CAAC,MAEjCD,IAAA,IACED,EAAAE,CAAG,IAAIL,EAAQK,CAAG,OAlBtBD,IAAA,IACED,EAAAE,CAAG,IAAIL,EAAQK,CAA2B;AAuB9D,EAAID,KACFP,EAAuBJ,GAAoBU,CAAa;AAE5D;AACO,SAASI,GACdC,GACA,EAAE,cAAAC,GAAc,YAAAC,KAChB;AACO,SAAA,EAAE,cAAAF,GAA4B,cAAAC,GAAc,YAAAC,EAAW;AAChE;AAEa,MAAAC,KAAkB,CAC7BH,GACAI,MACG;AACH,MAAIC,IAAkBL;AAGtB,QAAM,CAACM,GAAWb,CAAkB,IAClCc,GAA0BF,CAAe;AAG3C,GACE,OAAO,KAAKZ,CAAkB,EAAE,SAAS,KACxCW,KAAO,OAAO,KAAKA,CAAG,EAAE,SAAS,MAElC,OAAO,KAAKX,CAAkB,EAAE,QAAQ,CAACI,MAAQ;AAE/C,IAAAJ,EAAmBI,CAAG,IAAIJ,EAAmBI,CAAG,KAAK,CAAC,GAEnCJ,EAAAI,CAAG,EAAE,eAAe;AAAA,MACrC,GAAGO,GAAK;AAAA;AAAA,MACR,GAAGA,GAAK;AAAA,MACR,GAAIX,EAAmBI,CAAG,EAAE,gBAAgB,CAAA;AAAA;AAAA,IAC9C,GACwBV,EAAkBU,CAAG,KAG3CT,EACG,WACA,uBAAuBS,GAAKJ,EAAmBI,CAAG,CAAC;AAAA,EACxD,CACD,GAGYT,EAAA,SAAA,EAAW,iBAAiBkB,CAAS,GACrClB,EAAA,SAAA,EAAW,gBAAgBkB,CAAS;AAG7C,QAAAE,IAAe,CACnBvB,GACAO,MACG;AACH,UAAM,CAACiB,CAAW,IAAIC,GAASlB,GAAS,eAAemB,IAAQ;AAEpD,IAAApB,GAAA;AAAA,MACT,UAAAN;AAAA,MACA,SAAAO;AAAA,MACA,oBAAAC;AAAA,IAAA,CACD;AAEK,UAAAmB,IACJxB,EAAe,SAAS,EAAE,eAAeH,CAAkB,KAC3DqB,EAAUrB,CAAkB,GACxB4B,IAAerB,GAAS,cAC1BA,EAAQ,YAAYoB,CAAQ,IAC5BA,GAEE,CAACE,GAAOC,CAAO,IAAIC;AAAA,MACvBH;AAAA,MACA;AAAA,QACE,UAAA5B;AAAA,QACA,YAAYO,GAAS;AAAA,QACrB,aAAAiB;AAAA,QACA,cAAcjB,GAAS;AAAA,QACvB,YAAYA,GAAS;AAAA,QACrB,aAAaA,GAAS;AAAA,QACtB,cAAcA,GAAS;AAAA,QACvB,cAAcA,GAAS;AAAA,QACvB,cAAcA,GAAS;AAAA,QACvB,cAAcA,GAAS;AAAA,QACvB,aAAaA,GAAS;AAAA,MAAA;AAAA,IAE1B;AAEO,WAAAuB;AAAA,EACT;AAES,WAAAE,EACPhC,GACAO,GACA;AACA,IAAAD,GAAW,EAAE,UAAAN,GAAU,SAAAO,GAAS,oBAAAC,EAAA,CAAoB,GAEhDD,EAAQ,gBACV0B,GAAyBjC,GAAoBO,CAAO,GAGtD2B,GAAiBlC,CAAkB;AAAA,EAAA;AAG9B,SAAA,EAAE,cAAAuB,GAAc,gBAAAS,EAAe;AACxC,GAEM;AAAA,EACJ,iBAAAG;AAAA,EACA,UAAAC;AAAA,EACA,mBAAAlC;AAAA,EACA,aAAAmC;AAAA,EACA,qBAAAC;AAAA,EACA,aAAAC;AAAA,EACA,0BAAAC;AAAA,EACA,oBAAAC;AAAA,EACA,uBAAAC;AAAA,EACA,sBAAAC;AACF,IAAIxC,EAAe,SAAS,GACtByC,KAAqB,CACzBf,GACAgB,GACAC,GACAC,GACAC,MACG;AACH,EAAIF,GAAuB,OACjB,QAAA;AAAA,IACN;AAAA,IACAD;AAAA,IACAC,EAAsB,cAAc;AAAA,IACpCC;AAAA,EACF;AAGF,QAAMnC,IAAMqC,EAAWH,GAAuB,cAAc,GAAG,IAC3DA,EAAsB,cAAc,IAAIjB,CAAK,IAC7CiB,GAAuB,cAAc;AAEzC,MAAIlC,KAAOmC,GAAW;AACpB,UAAMG,IAAa,GAAGH,CAAS,IAAIF,CAAO,IAAIjC,CAAG;AAG7C,QAAAuC;AACA,QAAA;AAEF,MAAAA,IADiBC,GAAqBF,CAAU,GACjB;AAAA,IAAA,QACzB;AAAA,IAAA;AAIR,UAAMG,IAA4B;AAAA,MAChC,OAAAxB;AAAA,MACA,aAAa,KAAK,IAAI;AAAA,MACtB,sBAAsBmB,KAAwBG;AAAA,IAChD,GAGMG,IAAkBC,GAAU,UAAUF,CAAI;AAChD,WAAO,aAAa;AAAA,MAClBH;AAAA,MACA,KAAK,UAAUI,EAAgB,IAAI;AAAA,IACrC;AAAA,EAAA;AAEJ,GAEMF,KAAuB,CAACI,MAA4B;AACpD,MAAA,CAACA,EAAwB,QAAA;AAEzB,MAAA;AACF,UAAMC,IAAa,OAAO,aAAa,QAAQD,CAAe;AAC1D,WAACC,IAGc,KAAK,MAAMA,CAAU,IAHhB;AAAA,WAMjBC,GAAO;AACN,mBAAA,MAAM,oCAAoCA,CAAK,GAChD;AAAA,EAAA;AAEX,GACMzB,KAA2B,CAACjC,GAAkBO,MAAiB;AACnE,QAAMoD,IAAexD,EAAe,SAAS,EAAE,eAAeH,CAAQ,GAChE,EAAE,WAAA+C,EAAU,IAAIa,GAAc,GAC9BC,IAAWZ,EAAW1C,GAAS,cAAc,GAAG,IAClDA,EAAQ,aAAa,IAAIoD,CAAY,IACrCpD,GAAS,cAAc;AAE3B,MAAIsD,KAAYd,GAAW;AACzB,UAAMe,IAAYV;AAAA,MAChB,GAAGL,CAAS,IAAI/C,CAAQ,IAAI6D,CAAQ;AAAA,IACtC;AAEA,QACEC,KACAA,EAAU,eAAeA,EAAU,wBAAwB;AAElD,aAAA1B,EAAApC,GAAU8D,EAAU,KAAK,GAElC5B,GAAiBlC,CAAQ,GAClB;AAAA,EACT;AAEK,SAAA;AACT,GASM+D,KAAoB,CACxBlB,GACA9B,GACAiD,GACAC,GACAzC,GACAuB,MACG;AAEH,QAAMmB,IAAU;AAAA,IACd,cAAAnD;AAAA,IACA,cAAcoD;AAAA,MACZtB;AAAA,MACAoB;AAAA,MACAzC;AAAA,MACAuB;AAAA,IACF;AAAA,IACA,OAAOiB;AAAA,EACT;AAEyB,EAAAxB,GAAAK,GAASqB,EAAQ,YAAY,GACtC/B,GAAAU,GAASqB,EAAQ,YAAY,GACpC9B,EAAAS,GAASqB,EAAQ,KAAK;AACjC,GAEMhC,KAAmB,CAACW,MAAoB;AAC5C,QAAMuB,IAAajE,EAAe,SAAW,EAAA,gBAAgB,IAAI0C,CAAO;AACxE,MAAI,CAACuB,EAAY;AAGX,QAAAF,wBAAc,IAAgB;AACzB,EAAAE,EAAA,WAAW,QAAQ,CAACC,MAAc;AAM3C,KALsBA,IAClB,MAAM,QAAQA,EAAU,YAAY,IAClCA,EAAU,eACV,CAACA,EAAU,gBAAgB,WAAW,IACxC,OACgB,SAAS,MAAM,KACjCH,EAAQ,IAAI,MAAMG,EAAU,YAAA,CAAa;AAAA,EAC3C,CACD,GAGD,eAAe,MAAM;AACnB,IAAAH,EAAQ,QAAQ,CAACI,MAAWA,EAAA,CAAQ;AAAA,EAAA,CACrC;AACH,GAEaC,KAAkB,CAACvE,GAAkBwB,MAAwB;AACxE,QAAM4C,IAAajE,EAAe,SAAW,EAAA,gBAAgB,IAAIH,CAAQ;AACzE,MAAIoE,GAAY;AACd,UAAMI,IAAkB,GAAGxE,CAAQ,OAAOwB,CAAW,IAC/C6C,IAAYD,EAAW,WAAW,IAAII,CAAe;AAQvD,SAPkBH,IAClB,MAAM,QAAQA,EAAU,YAAY,IAClCA,EAAU,eACV,CAACA,EAAU,gBAAgB,WAAW,IACxC,OAGe,SAAS,MAAM;AAChC;AAGF,IAAIA,KAGFA,EAAU,YAAY;AAAA,EACxB;AAEJ,GACMI,KAAkB,CACtBC,GACAC,GACAC,GACAC,MACG;AACH,UAAQH,GAAY;AAAA,IAClB,KAAK;AACI,aAAA;AAAA,QACL,UAAUI,EAAeH,GAAWE,CAAI;AAAA,QACxC,UAAUC,EAAeF,GAASC,CAAI;AAAA,MACxC;AAAA,IACF,KAAK;AACI,aAAA;AAAA,QACL,UAAU;AAAA;AAAA,QACV,UAAUC,EAAeF,GAASC,CAAI;AAAA,MACxC;AAAA,IACF,KAAK;AACI,aAAA;AAAA,QACL,UAAUC,EAAeH,GAAWE,CAAI;AAAA,QACxC,UAAU;AAAA;AAAA,MACZ;AAAA,IACF;AACE,aAAO,EAAE,UAAU,MAAM,UAAU,KAAK;AAAA,EAAA;AAE9C;AACO,SAAS9C,GACdgD,GACA;AAAA,EACE,UAAA/E;AAAA,EACA,YAAAgF;AAAA,EACA,cAAAC;AAAAA,EACA,cAAAjE;AAAA,EACA,cAAAkE;AAAA,EACA,cAAAC;AAAA,EACA,aAAA3D;AAAA,EACA,cAAAT;AAAA,EACA,YAAAqE;AAAA,EACA,cAAAC;AAAA,EACA,aAAAC;AACF,IAIgC,IAChC;AACA,QAAM,CAACC,GAAeC,CAAW,IAAI/D,GAAS,CAAA,CAAE,GAC1C,EAAE,WAAAsB,EAAU,IAAIa,GAAc;AAEhC,MAAA6B,IAAa,CAAAzF;AACjB,QAAM,CAAC6C,CAAO,IAAIpB,GAASzB,KAAY0B,IAAQ,GACzCgE,IAAWvF,EAAe,SAAS,EAAE,SAAS0C,CAAO,GACrD8C,KAAsBC,EAAW,oBAAA,KAAa,GAC9CC,IAAiBD,EAAOpE,KAAeE,GAAA,CAAQ,GAC/CoE,IAA0BF;AAAA,IAC9B;AAAA,EACF;AACwB,EAAAE,EAAA,UAAW5F,EAAkB2C,CAAiB,KACpE,MAEFkD,GAAU,MAAM;AACd,QAAIX,KAAcA,EAAW,aAAavC,KAAWuC,EAAW,OAAO,CAAC,GAAG;AAEhE,MAAAhD,EAAAS,GAAS,CAACmD,OAAoB;AAAA,QACrC,GAAGA;AAAA,QACH,CAACZ,EAAW,KAAM,CAAC,CAAE,GAAGA,EAAW;AAAA,MAAA,EACnC;AAGI,YAAAa,IAAU,GAAGb,EAAW,QAAQ,IAAIA,EAAW,KAAK,KAAK,GAAG,CAAC;AACpD,MAAAjF,EAAA,SAAA,EAAW,YAAY8F,GAAS;AAAA,QAC7C,WAAWb,EAAW;AAAA,QACtB,QAAQA,EAAW;AAAA,MAAA,CACpB;AAAA,IAAA;AAAA,EACH,GACC,CAACA,CAAU,CAAC,GACfW,GAAU,MAAM;AAEd,QAAIhF,GAAc;AAChB,MAAAhB,GAAmB8C,GAAmB;AAAA,QACpC,cAAA9B;AAAA,MAAA,CACD;AAED,YAAMR,IAAUuF,EAAwB,SAElCI,IADc3F,GAAS,aAAa,OAAO,UAG/CA,GAAS,aAAa,WAAW,aACjCA,GAAS,aAAa,MAElB4F,IACJhG,EAAe,SAAS,EAAE,mBAAmB0C,CAAO;AAOlD,UAAA,EAJDsD,KACC,CAACtF,EAAYsF,GAAmCpF,CAAY,KAC9D,CAACoF,MAEyB,CAACD;AAC3B;AAGF,UAAIpC,IAAY;AAChB,YAAMD,IAAWZ,EAAW1C,GAAS,cAAc,GAAG,IAClDA,GAAS,cAAc,IAAIQ,CAAY,IACvCR,GAAS,cAAc;AAE3B,MAAIsD,KAAYd,MACde,IAAYV,GAAqB,GAAGL,CAAS,IAAIF,CAAO,IAAIgB,CAAQ,EAAE;AAGxE,UAAIG,IAAWjD,GACXqF,IAAe;AAEnB,YAAMC,IAAkBH,IAAgB,KAAK,IAAQ,IAAA,GAC/CI,IAAiBxC,GAAW,eAAe,GAC3CyC,IAAoBzC,GAAW,wBAAwB;AAEzD,MAAAoC,KAAiBG,IAAkBC,KACrCtC,IAAWzD,EAAQ,YAAa,MACjB6F,IAAA,MACNtC,KAAawC,IAAiBC,MACvCvC,IAAWF,EAAU,OACjBvD,GAAS,cAAc,YAChBA,GAAA,cAAc,SAASyD,CAAQ,IAG5C7D,EAAe,SAAS,EAAE,sBAAsB0C,GAAS9B,CAAY,GAErEgD;AAAA,QACElB;AAAA,QACA9B;AAAA,QACAiD;AAAA,QACAC;AAAA,QACA4B,EAAe;AAAA,QACf9C;AAAA,MACF,GAGIqD,KAAgBvC,KAAYd,KAC9BH,GAAmBoB,GAAUnB,GAAStC,GAASwC,GAAW,KAAK,KAAK,GAItEb,GAAiBW,CAAO,IAEF,MAAM,QAAQsC,CAAY,IAC5CA,IACA,CAACA,KAAgB,WAAW,GAEb,SAAS,MAAM,KAChCK,EAAY,CAAA,CAAE;AAAA,IAChB;AAAA,EACF,GACC;AAAA,IACDzE;AAAA,IACAuE,GAAa;AAAA,IACbA,GAAa;AAAA,IACb,GAAID,KAAgB,CAAA;AAAA,EAAC,CACtB,GACDmB,GAAgB,MAAM;AACpB,IAAIf,KACF1F,GAAmB8C,GAAmB;AAAA,MACpC,YAAAmC;AAAA,MACA,cAAAhE;AAAA,MACA,cAAAD;AAAA,MACA,cAAAkE;AAAAA,MACA,YAAYa,EAAwB,SAAS;AAAA,IAAA,CAC9C;AAGH,UAAMW,IAAe,GAAG5D,CAAO,OAAOgD,EAAe,OAAO,IACtDzB,IAAajE,EAChB,SAAA,EACA,gBAAgB,IAAI0C,CAAO,KAAK;AAAA,MACjC,gCAAgB,IAAI;AAAA,IACtB;AAEW,WAAAuB,EAAA,WAAW,IAAIqC,GAAc;AAAA,MACtC,aAAa,MAAMjB,EAAY,EAAE;AAAA,MACjC,2BAAW,IAAI;AAAA,MACf,MAAM,CAAC;AAAA,MACP,cAAcN,KAAgB;AAAA,MAC9B,cAAcC,KAAgB,CAAC,aAAa,MAAM;AAAA,IAAA,CACnD,GAEDhF,EAAe,SAAS,EAAE,gBAAgB,IAAI0C,GAASuB,CAAU,GAEjEoB,EAAY,CAAA,CAAE,GACP,MAAM;AACX,MAAIpB,MACSA,EAAA,WAAW,OAAOqC,CAAY,GACrCrC,EAAW,WAAW,SAAS,KACjCjE,EAAe,SAAS,EAAE,gBAAgB,OAAO0C,CAAO;AAAA,IAG9D;AAAA,EACF,GAAG,EAAE;AAEL,QAAMoB,IAAoB,CACxByC,GACA7B,GACA8B,GACAC,MACG;AACC,QAAA,MAAM,QAAQ/B,CAAI,GAAG;AACvB,YAAMgC,IAAU,GAAGhE,CAAO,IAAIgC,EAAK,KAAK,GAAG,CAAC;AACxB,MAAAc,GAAA,QAAQ,IAAIkB,CAAO;AAAA,IAAA;AAEhC,IAAAzE,EAAAS,GAAS,CAAC8B,MAA4B;AAC7C,YAAMC,IAAU3B,EAAyByD,CAAkB,IACvDA,EAAmB/B,CAAyB,IAC5C+B,GAEEI,IAAW,GAAGjE,CAAO,IAAIgC,EAAK,KAAK,GAAG,CAAC;AAC7C,UAAIiC,GAAU;AACZ,YAAIC,IAAmB,IACnBC,IAAW7G,EACZ,SACA,EAAA,kBAAkB,IAAI2G,CAAQ;AAG9B,aAAA,CAACE,KAAYA,EAAS,SAAS,OAC/BL,EAAU,eAAe,YAAYA,EAAU,eAAe,QAC/D;AAEA,gBAAMM,IAAYpC,EAAK,MAAM,GAAG,EAAE,GAC5BqC,IAAapC,EAAeF,GAASqC,CAAS;AAEhD,cAAA,MAAM,QAAQC,CAAU,GAAG;AACV,YAAAH,IAAA;AACnB,kBAAMI,IAAgB,GAAGtE,CAAO,IAAIoE,EAAU,KAAK,GAAG,CAAC;AACvD,YAAAD,IAAW7G,EACR,SAAA,EACA,kBAAkB,IAAIgH,CAAa;AAAA,UAAA;AAAA,QACxC;AAGF,YAAIH,GAAU;AACZ,gBAAMI,IAAWL,IACbjC,EAAeF,GAASC,EAAK,MAAM,GAAG,EAAE,CAAC,IACzCC,EAAeF,GAASC,CAAI;AAChC,UAAAmC,EAAS,QAAQ,CAAC,EAAE,UAAAK,GAAU,UAAAC,GAAU,QAAAC,QAAa;AACnD,kBAAMC,IAAS,SAAS;AAAA,cACtB,oBAAoBH,CAAQ;AAAA,YAC9B;AACA,gBAAIG,GAAQ;AACV,oBAAMC,IAAa,MAAM,KAAKD,EAAO,UAAU;AAC3C,kBAAAC,EAAWH,CAAQ,GAAG;AAClB,sBAAAI,IAAeH,IACjB,IAAI,SAAS,SAAS,WAAWA,CAAM,UAAU,EAAEH,CAAQ,IAC3DA;AACJ,gBAAAK,EAAWH,CAAQ,EAAE,cAAc,OAAOI,CAAY;AAAA,cAAA;AAAA,YACxD;AAAA,UACF,CACD;AAAA,QAAA;AAAA,MACH;AA2BW,OAxBQ,MAAM;AACnB,cAAAC,IAAQxH,EAAe,SAAS;AAEtC,gBAAQwG,EAAU,YAAY;AAAA,UAC5B,KAAK;AAEG,YAAAgB,EAAA,mBAAmB9E,GAASgC,GAAMD,CAAO;AAC/C;AAAA,UAEF,KAAK;AAEH,kBAAMgD,IAAa/C,EAAK,MAAM,GAAG,EAAE;AAC7B,YAAA8C,EAAA,yBAAyB9E,GAAS+E,CAAU;AAClD;AAAA,UAEF,KAAK;AAEH,kBAAMX,IAAYpC,EAAK,MAAM,GAAG,EAAE,GAC5BgD,IAAQ,SAAShD,EAAKA,EAAK,SAAS,CAAC,CAAE;AACvC,YAAA8C,EAAA,yBAAyB9E,GAASoE,GAAWY,CAAK;AACxD;AAAA,QAAA;AAAA,MAEN,GAEa,GACb,QAAQ,IAAI,eAAe1H,EAAe,SAAA,EAAW,gBAAgB,GAEnEwG,EAAU,eAAe,aACxBC,KAAiBd,EAAwB,SAAS,YAAY,QAC/DjB,KAEAnC;AAAA,SACGkE,KAAiBd,EAAwB,SAAS,YAAY,OAC7D,MACAjB,EAAK,KAAK,GAAG;AAAA,MACjB;AAEF,YAAMiD,IAAoBjD,EAAK,MAAM,GAAGA,EAAK,SAAS,CAAC;AACvD,MACE8B,EAAU,eAAe,SACzBb,EAAwB,SAAS,YAAY,OAE7CpD;AAAA,QACEoD,EAAwB,SAAS,YAAY,MAC3C,MACAgC,EAAkB,KAAK,GAAG;AAAA,MAC9B,GAGAnB,EAAU,eAAe,YACzBb,EAAwB,SAAS,YAAY,OAEzBxD;AAAA,QAClBwD,EAAwB,SAAS,YAAY,MAC3C,MACAgC,EAAkB,KAAK,GAAG;AAAA,MAC9B,EAIc,OAAO,CAAC,CAACC,GAAGC,CAAC,MAAM;AAC/B,YAAIC,IAASF,GAAG,MAAM,GAAG,EAAE;AAGzB,YAAAA,KAAKD,EAAkB,KAAK,GAAG,KAC/BG,KAAUH,EAAkB,SAAS,GACrC;AAEI,cAAAI,IAASH,IAAI,MAAMD;AACvB,UAAApF,EAAsBqF,CAAE,GACxBtF,GAAmByF,GAAQF,CAAE;AAAA,QAAA;AAAA,MAC/B,CACD;AAGH,YAAM5D,IAAajE,EAAe,SAAW,EAAA,gBAAgB,IAAI0C,CAAO;AAExE,UADQ,QAAA,IAAI,8CAA8CuB,CAAU,GAChEA,GAAY;AACR,cAAA+D,IAAeC,GAAezD,GAAWC,CAAO,GAChDyD,IAAkB,IAAI,IAAIF,CAAY,GACtCG,IACJ3B,EAAU,eAAe,WACrB9B,EAAK,KAAK,GAAG,IACbA,EAAK,MAAM,GAAG,EAAE,EAAE,KAAK,GAAG,KAAK;AAE1B,mBAAA;AAAA,UACT4B;AAAA,UACApC;AAAA,QAAA,KACGD,EAAW,WAAW,WAAW;AACpC,cAAImE,IAAe;AACb,gBAAAC,IAAgB,MAAM,QAAQnE,EAAU,YAAY,IACtDA,EAAU,eACV,CAACA,EAAU,gBAAgB,WAAW;AAEtC,cADI,QAAA,IAAI,aAAaA,CAAS,GAC9B,CAAAmE,EAAc,SAAS,MAAM,GAC7B;AAAA,gBAAAA,EAAc,SAAS,KAAK,GAAG;AACjC,cAAAnE,EAAU,YAAY;AACtB;AAAA,YAAA;AAGE,gBAAAmE,EAAc,SAAS,WAAW,OAElCnE,EAAU,MAAM,IAAIiE,CAAkB,KACtCjE,EAAU,MAAM,IAAI,EAAE,OAEPkE,IAAA,KAGb,CAACA;AACH,yBAAWE,KAAeJ,GAAiB;AACzC,oBAAIK,IAAqBD;AACzB,2BAAa;AACX,sBAAIpE,EAAU,MAAM,IAAIqE,CAAkB,GAAG;AAC5B,oBAAAH,IAAA;AACf;AAAA,kBAAA;AAEI,wBAAAI,IAAeD,EAAmB,YAAY,GAAG;AACvD,sBAAIC,MAAiB,IAAI;AACvB,0BAAMf,KAAac,EAAmB;AAAA,sBACpC;AAAA,sBACAC;AAAA,oBACF;AACA,wBACE,CAAC;AAAA,sBACC,OAAOD,EAAmB,UAAUC,IAAe,CAAC,CAAC;AAAA,oBAAA,KAGnDtE,EAAU,MAAM,IAAIuD,EAAU,GAAG;AACpB,sBAAAW,IAAA;AACf;AAAA,oBAAA;AAGiB,oBAAAG,IAAAd;AAAA,kBAAA;AAEA,oBAAAc,IAAA;AAEvB,sBAAIA,MAAuB;AACzB;AAAA,gBACF;AAEF,oBAAIH,EAAc;AAAA,cAAA;AAKxB,gBAAI,CAACA,KAAgBC,EAAc,SAAS,MAAM,KAC5CnE,EAAU,cAAc;AACpB,oBAAAuE,IAAavE,EAAU,aAAaO,CAAO;AACjD,kBAAIiE,IAAc;AACd,cAAA,OAAOD,KAAe,YACpBA,MAA0BC,IAAA,MACpBhI,EAAYwD,EAAU,MAAMuE,CAAU,MAChDvE,EAAU,OAAOuE,GACHC,IAAA,KAEZA,MACaN,IAAA;AAAA,YACjB;AAGJ,YAAIA,KACFlE,EAAU,YAAY;AAAA;AAAA,QACxB;AAAA,MACF;AAEI,YAAAyE,IAAY,KAAK,IAAI;AAE3B,MAAAjE,IAAOA,EAAK,IAAI,CAACkE,GAAGC,MAAM;AACxB,cAAM/B,IAAYpC,EAAK,MAAM,GAAG,EAAE,GAC5BqC,IAAapC,EAAeF,GAASqC,CAAS;AAEpD,eAAO+B,MAAMnE,EAAK,SAAS,KACzB,CAAC,UAAU,KAAK,EAAE,SAAS8B,EAAU,UAAU,KAC5CO,EAAW,SAAS,GAAG,aACxB6B;AAAA,MAAA,CACL;AAEK,YAAA,EAAE,UAAAE,GAAU,UAAA7B,EAAA,IAAa3C;AAAA,QAC7BkC,EAAU;AAAA,QACVhC;AAAA,QACAC;AAAA,QACAC;AAAA,MACF,GACMqE,IAAY;AAAA,QAChB,WAAAJ;AAAA,QACA,UAAUjG;AAAA,QACV,MAAAgC;AAAA,QACA,YAAY8B,EAAU;AAAA,QACtB,QAAQ;AAAA,QACR,UAAAsC;AAAA,QACA,UAAA7B;AAAA,MACF;AAyCI,UAvCQ7E,GAAAM,GAAS,CAACsG,MAAa;AAIjC,cAAMC,IAHO,CAAC,GAAID,KAAY,CAAA,GAAKD,CAAS,EAGhB,OAAO,CAACG,GAAKC,MAAQ;AACzC,gBAAAC,IAAY,GAAGD,EAAI,QAAQ,IAAI,KAAK,UAAUA,EAAI,IAAI,CAAC,IACvDE,IAAWH,EAAI,IAAIE,CAAS;AAElC,iBAAIC,KAEFA,EAAS,YAAY,KAAK,IAAIA,EAAS,WAAWF,EAAI,SAAS,GAC/DE,EAAS,WAAWF,EAAI,UACfE,EAAA,WAAWA,EAAS,YAAYF,EAAI,UAC7CE,EAAS,aAAaF,EAAI,cAG1BD,EAAI,IAAIE,GAAW,EAAE,GAAID,GAAa,GAGjCD;AAAA,QAAA,GACF,oBAAA,IAAA,CAA+B;AAGtC,eAAO,MAAM,KAAKD,EAAe,OAAA,CAAQ;AAAA,MAAA,CAC1C,GAEDxG;AAAA,QACEgC;AAAA,QACA/B;AAAA,QACAiD,EAAwB;AAAA,QACxB/C;AAAA,MACF,GAEI+C,EAAwB,SAAS,cACnCA,EAAwB,QAAS,WAAW;AAAA,QAC1C,WAAWJ;AAAA,QACX,QAAQwD;AAAA,MAAA,CACT,GAECpD,EAAwB,SAAS,YAAY;AAC/C,cAAM2D,IAAmBtJ,EAAe,SAAS,EAAE,YAAY0C,CAAO,GAChEmC,IAAac,EAAwB,SAAS;AACpD,QAAAnD,GAAqBE,GAAS;AAAA,UAC5B,SACE,OAAOmC,EAAW,WAAW,WACzBA,EAAW,UACXA,EAAW,QAAQ,EAAE,OAAOJ,EAAA,CAAS;AAAA,UAC3C,eAAe6E;AAAA,UACf,iBAAiB,KAAK,IAAI,KAAKzE,EAAW,YAAY;AAAA,UACtD,QAAQ;AAAA,QAAA,CACT;AAAA,MAAA;AAGI,aAAAJ;AAAA,IAAA,CACR;AAAA,EACH;AACA,EAAKzE,EAAe,SAAW,EAAA,aAAa0C,CAAO,MACjDV;AAAA,IACEU;AAAA,IACAsB;AAAA,MACEtB;AAAA,MACAoB;AAAA,MACA4B,EAAe;AAAA,MACf9C;AAAA,IAAA;AAAA,EAEJ,GACK5C,EAAe,SAAW,EAAA,eAAe0C,CAAO,KACnDT,EAASS,GAASkC,CAAW,GAE1B5E,EAAe,SAAW,EAAA,mBAAmB0C,CAAO,KACvDL,GAAyBK,GAASkC,CAAW;AAI3C,QAAA2E,IAAeC,GAAQ,MAEpBxF;AAAA,IACLtB;AAAA,IACAoB;AAAA,IACA4B,EAAe;AAAA,IACf9C;AAAA,EACF,GACC,CAACF,GAASE,CAAS,CAAC;AAEvB,SAAO,CAACV,GAAYQ,CAAO,GAAG6G,CAAY;AAI5C;AAEA,SAASvF,GACPnE,GACAiE,GACAzC,GACAuB,GACgB;AAMV,QAAA6G,wBAAiB,IAAwB;AAC/C,MAAIC,IAAe;AAGb,QAAAC,IAAsB,CAACjF,MAAmB;AACxC,UAAAgC,IAAUhC,EAAK,KAAK,GAAG;AAClB,eAAA,CAACjE,CAAG,KAAKgJ;AAClB,OAAIhJ,MAAQiG,KAAWjG,EAAI,WAAWiG,IAAU,GAAG,MACjD+C,EAAW,OAAOhJ,CAAG;AAGzB,IAAAiJ;AAAA,EACF,GAEME,IAAU;AAAA,IACd,kBAAkB,CAACC,MAAqC;AACtD,MAAIA,GAAK,iBACPtH,EAAsBsH,EAAI,aAAa;AAAA,IAE3C;AAAA,IAEA,sBAAsB,CAACA,MAAqC;AAC1D,YAAMC,IAAO9J,EACV,SACA,EAAA,kBAAkBH,CAAQ,GAAG;AAChC,MAAIiK,GAAM,OACRvH,EAAsBuH,GAAM,GAAG,GAG7BD,GAAK,iBACPtH,EAAsBsH,EAAI,aAAa;AAGzC,YAAMjJ,IACJZ,EAAe,SAAS,EAAE,mBAAmBH,CAAQ;AAExC,MAAAG,EAAA,SAAA,EAAW,6BAA6BH,CAAQ,GAE/D4J,EAAW,MAAM,GACjBC;AAEA,YAAMK,IAAWC,EAAkBpJ,GAAc,EAAE,GAC7CqJ,IAAmBlK,EAAkBF,CAAkB,GACvDqK,IAAWpH,EAAWmH,GAAkB,cAAc,GAAG,IAC3DA,GAAkB,cAAc,IAAIrJ,CAAY,IAChDqJ,GAAkB,cAAc,KAE9BlH,IAAa,GAAGH,CAAS,IAAI/C,CAAQ,IAAIqK,CAAQ;AAEvD,MAAInH,KACF,aAAa,WAAWA,CAAU,GAGpCf,GAAgBnC,GAAUkK,CAAQ,GAClC9H,EAASpC,GAAUe,CAAY;AAC/B,YAAMqD,IAAajE,EAChB,SACA,EAAA,gBAAgB,IAAIH,CAAQ;AAC/B,aAAIoE,KACSA,EAAA,WAAW,QAAQ,CAACC,MAAc;AAC3C,QAAAA,EAAU,YAAY;AAAA,MAAA,CACvB,GAGItD;AAAA,IACT;AAAA,IACA,oBAAoB,CAACiD,MAAgB;AAEnC,MAAA4F,EAAW,MAAM,GACjBC;AAEA,YAAMS,IAAkBnG;AAAA,QACtBnE;AAAA,QACAiE;AAAA,QACAzC;AAAA,QACAuB;AAAA,MACF,GACMhC,IACJZ,EAAe,SAAS,EAAE,mBAAmBH,CAAQ,GACjDoK,IAAmBlK,EAAkBF,CAAkB,GACvDqK,IAAWpH,EAAWmH,GAAkB,cAAc,GAAG,IAC3DA,GAAkB,cAAc,IAAIrJ,CAAY,IAChDqJ,GAAkB,cAAc,KAE9BlH,IAAa,GAAGH,CAAS,IAAI/C,CAAQ,IAAIqK,CAAQ;AAEnD,aAAA,aAAa,QAAQnH,CAAU,KACjC,aAAa,WAAWA,CAAU,GAEpCqH,GAAgB,MAAM;AACpB,QAAA/H,GAAyBxC,GAAUgE,CAAQ,GAC3C7D,EAAe,SAAS,EAAE,sBAAsBH,GAAUgE,CAAQ,GAClE7B,GAAgBnC,GAAUsK,CAAe,GACzClI,EAASpC,GAAUgE,CAAQ;AAC3B,cAAMI,IAAajE,EAChB,SACA,EAAA,gBAAgB,IAAIH,CAAQ;AAE/B,QAAIoE,KACSA,EAAA,WAAW,QAAQ,CAACC,MAAc;AAC3C,UAAAA,EAAU,YAAY;AAAA,QAAA,CACvB;AAAA,MACH,CACD,GAEM;AAAA,QACL,SAAS,CAACmG,MAAmBF,EAAgB,MAAME,CAAK;AAAA,MAC1D;AAAA,IACF;AAAA,IACA,eAAerK,EAAe,WAAW,mBAAmBH,CAAQ;AAAA,IACpE,cAAcG,EAAe,WAAW,YAAYH,CAAQ;AAAA,IAC5D,YAAYG,EAAe,WAAW,gBAAgBH,CAAQ;AAAA,IAC9D,iBAAiB,MAAM;AACrB,YAAMsF,IAAcnF,EAAe,SAAS,EAAE,YAAYH,CAAQ;AAC3D,aAAA,GACLsF,KAAezE,EAAYyE,GAAajD,GAAYrC,CAAQ,CAAC;AAAA,IAC/D;AAAA,EAEJ;AAEA,WAASmK,EACPxG,GACAkB,IAAiB,CAAA,GACjB4F,GACK;AACL,UAAMC,IAAW7F,EAAK,IAAI,MAAM,EAAE,KAAK,GAAG;AAGtB,IAAA+E,EAAW,IAAIc,CAAQ;AAQ3C,UAAMC,IAAe,WAAY;AAC/B,aAAOxK,EAAe,EAAE,eAAeH,GAAU6E,CAAI;AAAA,IACvD;AAGA,WAAO,KAAKkF,CAAO,EAAE,QAAQ,CAACnJ,MAAQ;AACnC,MAAA+J,EAAqB/J,CAAG,IAAKmJ,EAAgBnJ,CAAG;AAAA,IAAA,CAClD;AAED,UAAMgK,IAAU;AAAA,MACd,MAAMC,GAAaC,GAAcC,IAAa;AACpC,uBAAA;AAAA,UACN,kCAAkC/K,CAAQ,UAAU6E,EAAK,KAAK,GAAG,CAAC;AAAA,QACpE,GACA,QAAQ,MAAM,wBAAwB,GAC/B1E,EAAe,EAAE,eAAeH,GAAU6E,CAAI;AAAA,MACvD;AAAA,MAEA,IAAIgG,GAAaG,GAAc;AAC7B,QAAIP,GAAM,gBAAgB,CAAC,MAAM,QAAQ9G,CAAY,MACnD8G,IAAO,EAAE,GAAGA,GAAM,cAAc,OAAU;AAEtC,cAAAQ,yBAAsB,IAAI;AAAA,UAC9B;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QAAA,CACD;AACD,YACED,MAAS,UACT,CAACA,EAAK,WAAW,GAAG,KACpBA,MAAS,sBACT,CAACC,GAAgB,IAAID,CAAI,GACzB;AACA,gBAAMxG,IAAkB,GAAGxE,CAAQ,OAAOwB,CAAW,IAE/C4C,IAAajE,EAChB,SACA,EAAA,gBAAgB,IAAIH,CAAQ;AAE/B,cAAIoE,GAAY;AACd,kBAAMC,IAAYD,EAAW,WAAW,IAAII,CAAe;AAE3D,gBAAIH,KAIE,CAACA,EAAU,MAAM,IAAI,EAAE,GAAG;AACtB,oBAAA6G,IAAcrG,EAAK,KAAK,GAAG;AACjC,kBAAIsG,IAAW;AACJ,yBAAAC,KAAgB/G,EAAU;AAEjC,oBAAA6G,EAAY,WAAWE,CAAY,MAClCF,MAAgBE,KACfF,EAAYE,EAAa,MAAM,MAAM,MACvC;AACW,kBAAAD,IAAA;AACX;AAAA,gBAAA;AAIJ,cAAIA,KACQ9G,EAAA,MAAM,IAAI6G,CAAW;AAAA,YACjC;AAAA,UAEJ;AAAA,QACF;AAEF,YAAIF,MAAS;AACX,iBAAO,MACe5C;AAAA,YAClBjI,EAAe,SAAA,EAAW,eAAeH,CAAQ;AAAA,YACjDG,EAAe,WAAW,mBAAmBH,CAAQ;AAAA,UACvD;AAIJ,YAAIgL,MAAS,UAAUnG,EAAK,WAAW;AACrC,iBAAO,iBAAkB;AAEvB,kBAAMtE,IAAUJ,EACb,SAAS,EACT,kBAAkBH,CAAQ,GACvBqL,IAAO9K,GAAS;AAEtB,gBAAI,CAAC8K;AACK,6BAAA,MAAM,sCAAsCrL,CAAQ,GAAG,GACxD,EAAE,SAAS,IAAO,OAAO,sBAAsB;AAIxD,kBAAM6B,IAAQ1B,EACX,WACA,eAAeH,GAAU,EAAE,GAGxB4G,IAAgBrG,GAAS,YAAY;AAEvC,gBAAA;AAEF,oBAAM+K,IAAW,MAAMD,EAAK,OAAOxJ,CAAK;AAGxC,kBACEyJ,KACA,CAACA,EAAS,WACVA,EAAS,UACT1E,GACA;AAEe,gBAAAzG,EAAA,SAAA,EAAW,sBAAsByG,CAAa,GAGpD0E,EAAA,OAAO,QAAQ,CAAC5H,MAAU;AAC3B,wBAAA6H,IAAY,CAAC3E,GAAe,GAAGlD,EAAM,IAAI,EAAE,KAAK,GAAG;AAEzD,kBAAAvD,EACG,SAAS,EACT,mBAAmBoL,GAAW7H,EAAM,OAAO;AAAA,gBAAA,CAC/C;AAGD,sBAAMU,IAAajE,EAChB,SACA,EAAA,gBAAgB,IAAIH,CAAQ;AAC/B,gBAAIoE,KACSA,EAAA,WAAW,QAAQ,CAACC,MAAc;AAC3C,kBAAAA,EAAU,YAAY;AAAA,gBAAA,CACvB;AAAA,cACH;AAIE,qBAAAiH,GAAU,WAAWD,EAAK,YACvBA,EAAA,UAAUC,EAAS,IAAI,IACnB,CAACA,GAAU,WAAWD,EAAK,WAC/BA,EAAA,QAAQC,EAAS,KAAK,GAGtBA;AAAA,qBACA5H,GAAO;AACd,qBAAI2H,EAAK,WACPA,EAAK,QAAQ3H,CAAK,GAEb,EAAE,SAAS,IAAO,OAAAA,EAAM;AAAA,YAAA;AAAA,UAEnC;AAEF,YAAIsH,MAAS,WAAW;AAEtB,gBAAMQ,IAAoBrL,EACvB,SACA,EAAA,eAAeH,GAAU6E,CAAI,GAG1B9D,IACJZ,EAAe,SAAS,EAAE,mBAAmBH,CAAQ,GACjDyL,IAAqB3G,EAAe/D,GAAc8D,CAAI;AAGxD,iBAAAhE,EAAY2K,GAAmBC,CAAkB,IAC5C,UAEA;AAAA,QACT;AAEF,YAAIT,MAAS;AACX,iBAAO,WAAY;AAEX,kBAAAQ,IAAoBrL,IAAiB;AAAA,cACzCH;AAAA,cACA6E;AAAA,YACF,GAGM9D,IACJZ,EAAe,SAAS,EAAE,mBAAmBH,CAAQ,GACjDyL,IAAqB3G,EAAe/D,GAAc8D,CAAI;AAExD,mBAAAhE,EAAY2K,GAAmBC,CAAkB,IAC5C,UAEA;AAAA,UAEX;AAEF,YAAIT,MAAS;AACX,iBAAO,MAAM;AACX,kBAAMjK,IACJZ,EAAe,SAAS,EAAE,mBAAmBH,CAAQ,GACjDoK,IAAmBlK,EAAkBF,CAAkB,GACvDqK,IAAWpH,EAAWmH,GAAkB,cAAc,GAAG,IAC3DA,GAAkB,cAAc,IAAIrJ,CAAY,IAChDqJ,GAAkB,cAAc,KAE9BlH,IAAa,GAAGH,CAAS,IAAI/C,CAAQ,IAAIqK,CAAQ;AAEvD,YAAInH,KACF,aAAa,WAAWA,CAAU;AAAA,UAEtC;AAEF,YAAI8H,MAAS;AACX,iBAAO,MAAM;AACX,kBAAMf,IAAO9J,EACV,SACA,EAAA,kBAAkBH,CAAQ,GAAG;AAE5B,gBAAA,CAACiK,GAAM;AACH,oBAAA,IAAI,MAAM,0BAA0B;AAMrC,mBAJQ9J,EACZ,SAAA,EACA,oBAAoB8J,EAAK,MAAM,MAAMpF,EAAK,KAAK,GAAG,CAAC;AAAA,UAGxD;AAEE,YAAA,MAAM,QAAQlB,CAAY,GAAG;AAC/B,gBAAM+H,IAA2B,MAK3BjB,GAAM,eACA9G,EAAuB,IAAI,CAACgI,GAAM9D,OAAW;AAAA,YACnD,MAAA8D;AAAA,YACA,eAAelB,EAAM,aAAc5C,CAAK;AAAA,UAAA,EACxC,IAGgB1H,EACjB,SACA,EAAA,eAAeH,GAAU6E,CAAI,EACb,IAAI,CAAC8G,GAAM9D,OAAW;AAAA,YACvC,MAAA8D;AAAA,YACA,eAAe9D;AAAA,UAAA,EACf;AAEJ,cAAImD,MAAS;AACX,mBAAO,MAAM;AACL,oBAAAY,IAAgBzL,EACnB,WACA,iBAAiBH,GAAU6E,EAAK,KAAK,GAAG,CAAC;AACxC,kBAAA+G,MAAkB;AACf,uBAAAzB;AAAA,kBACLxG,EAAaiI,CAAa;AAAA,kBAC1B,CAAC,GAAG/G,GAAM+G,EAAc,UAAU;AAAA,kBAClCnB;AAAA,gBACF;AAAA,YACF;AAEF,cAAIO,MAAS;AACX,mBAAO,MAAM;AACX,cAAA7K,EAAe,WAAW,mBAAmB,EAAE,UAAAH,GAAU,MAAA6E,GAAM;AAAA,YACjE;AAEF,cAAImG,MAAS;AACX,mBAAO,MACiB7K,EACnB,WACA,iBAAiBH,GAAU6E,EAAK,KAAK,GAAG,CAAC,KAEpB;AAI5B,cAAImG,MAAS;AACX,mBAAO,CACLzK,MACoC;AAC9B,oBAAA;AAAA,gBACJ,YAAAsL;AAAA,gBACA,UAAAC,IAAW;AAAA,gBACX,eAAAC,IAAgB;AAAA,cAAA,IACdxL,GAEEyL,IAAepG,EAA8B,IAAI,GACjD,CAACqG,GAAOC,CAAQ,IAAIzK,GAAS;AAAA,gBACjC,YAAY;AAAA,gBACZ,UAAU;AAAA,cAAA,CACX,GAGK0K,IAAgBvG,EAAOmG,CAAa,GACpCK,IAAwBxG,EAAO,CAAC,GAEhCyG,IAAoBzG,EAAO,EAAI,GAE/B0G,IAAcnM,IAAiB;AAAA,gBACnCH;AAAA,gBACA6E;AAAA,cACF,GACM0H,IAAaD,EAAY,QAEzBE,IAAe7C,GAAQ,MAAM;AACjC,sBAAM8C,IAAQ,KAAK,IAAI,GAAGR,EAAM,UAAU,GACpCS,IAAM,KAAK,IAAIH,GAAYN,EAAM,QAAQ,GACzCU,IAAe,MAAM;AAAA,kBACzB,EAAE,QAAQD,IAAMD,EAAM;AAAA,kBACtB,CAACG,GAAG5D,MAAMyD,IAAQzD;AAAA,gBACpB,GACM6D,IAAcF,EAAa,IAAI,CAACG,MAAQR,EAAYQ,CAAG,CAAC;AACvD,uBAAA3C,EAAkB0C,GAAoBhI,GAAM;AAAA,kBACjD,GAAG4F;AAAA,kBACH,cAAAkC;AAAA,gBAAA,CACD;AAAA,cAAA,GACA,CAACV,EAAM,YAAYA,EAAM,UAAUK,GAAaC,CAAU,CAAC;AAE9D,cAAA/F,GAAgB,MAAM;AACpB,sBAAMuG,IAAYf,EAAa;AAC/B,oBAAI,CAACe,EAAW;AAEhB,sBAAMC,IAAcb,EAAc,SAC5Bc,IAAWV,IAAaH,EAAsB;AACpD,gBAAAA,EAAsB,UAAUG;AAEhC,sBAAMW,IAAe,MAAM;AACzB,wBAAM,EAAE,WAAAC,GAAW,cAAAC,GAAc,cAAAC,EAAiB,IAAAN;AACpC,kBAAAZ,EAAA,UACZkB,IAAeF,IAAYC,IAAe;AAC5C,wBAAMX,IAAQ,KAAK;AAAA,oBACjB;AAAA,oBACA,KAAK,MAAMU,IAAYtB,CAAU,IAAIC;AAAA,kBACvC,GACMY,KAAM,KAAK;AAAA,oBACfH;AAAA,oBACA,KAAK,MAAMY,IAAYC,KAAgBvB,CAAU,IAC/CC;AAAA,kBACJ;AACA,kBAAAI,EAAS,CAACoB,OAENA,GAAU,eAAeb,KACzBa,GAAU,aAAaZ,KAEhB,EAAE,YAAYD,GAAO,UAAUC,GAAI,IAErCY,EACR;AAAA,gBACH;AAEU,uBAAAP,EAAA,iBAAiB,UAAUG,GAAc;AAAA,kBACjD,SAAS;AAAA,gBAAA,CACV,GAGGnB,MACEM,EAAkB,UAGpBU,EAAU,SAAS;AAAA,kBACjB,KAAKA,EAAU;AAAA,kBACf,UAAU;AAAA,gBAAA,CACX,IACQC,KAAeC,KAIxB,sBAAsB,MAAM;AAC1B,kBAAAF,EAAU,SAAS;AAAA,oBACjB,KAAKA,EAAU;AAAA,oBACf,UAAU;AAAA,kBAAA,CACX;AAAA,gBAAA,CACF,IAKLV,EAAkB,UAAU,IAGfa,EAAA,GAEN,MACLH,EAAU,oBAAoB,UAAUG,CAAY;AAAA,iBACrD,CAACX,GAAYV,GAAYC,GAAUC,CAAa,CAAC;AAEpD,oBAAMwB,IAAiBC;AAAA,gBACrB,CAACC,IAA2B,aAAa;AACvC,kBAAIzB,EAAa,WACfA,EAAa,QAAQ,SAAS;AAAA,oBAC5B,KAAKA,EAAa,QAAQ;AAAA,oBAC1B,UAAAyB;AAAA,kBAAA,CACD;AAAA,gBAEL;AAAA,gBACA,CAAA;AAAA,cACF,GAEMC,IAAgBF;AAAA,gBACpB,CAAC3F,GAAe4F,IAA2B,aAAa;AACtD,kBAAIzB,EAAa,WACfA,EAAa,QAAQ,SAAS;AAAA,oBAC5B,KAAKnE,IAAQgE;AAAA,oBACb,UAAA4B;AAAA,kBAAA,CACD;AAAA,gBAEL;AAAA,gBACA,CAAC5B,CAAU;AAAA,cACb,GAGM8B,IAAmB;AAAA,gBACvB,OAAO;AAAA,kBACL,KAAK3B;AAAA,kBACL,OAAO,EAAE,WAAW,QAAQ,QAAQ,OAAO;AAAA,gBAC7C;AAAA,gBACA,OAAO;AAAA,kBACL,OAAO;AAAA,oBACL,QAAQ,GAAGO,IAAaV,CAAU;AAAA,oBAClC,UAAU;AAAA,kBAAA;AAAA,gBAEd;AAAA,gBACA,MAAM;AAAA,kBACJ,OAAO;AAAA,oBACL,WAAW,cAAcI,EAAM,aAAaJ,CAAU;AAAA,kBAAA;AAAA,gBACxD;AAAA,cAEJ;AAEO,qBAAA;AAAA,gBACL,cAAAW;AAAA,gBACA,kBAAAmB;AAAA,gBACA,gBAAAJ;AAAA,gBACA,eAAAG;AAAA,cACF;AAAA,YACF;AAEF,cAAI1C,MAAS;AACX,mBAAO,CACL4C,MAIG;AAEH,oBAAMC,IAAe,CAAC,GADInC,EAAyB,CACT,EAAE;AAAA,gBAAK,CAACoC,GAAGC,MACnDH,EAAUE,EAAE,MAAMC,EAAE,IAAI;AAAA,cAC1B,GACMC,IAAkBH,EAAa,IAAI,CAAC,EAAE,MAAAlC,QAAWA,CAAI,GAErDsC,IAAU;AAAA,gBACd,GAAGxD;AAAA,gBACH,cAAcoD,EAAa;AAAA,kBACzB,CAAC,EAAE,eAAAK,EAAA,MAAoBA;AAAA,gBAAA;AAAA,cAE3B;AACO,qBAAA/D,EAAkB6D,GAAwBnJ,GAAMoJ,CAAO;AAAA,YAChE;AAGF,cAAIjD,MAAS;AACX,mBAAO,CACLmD,MAIG;AAEH,oBAAMC,IADoB1C,EAAyB,EACV;AAAA,gBACvC,CAAC,EAAE,MAAAC,KAAQ9D,MAAUsG,EAAWxC,GAAM9D,CAAK;AAAA,cAC7C,GACMmG,IAAkBI,EAAe,IAAI,CAAC,EAAE,MAAAzC,QAAWA,CAAI,GAEvDsC,IAAU;AAAA,gBACd,GAAGxD;AAAA,gBACH,cAAc2D,EAAe;AAAA,kBAC3B,CAAC,EAAE,eAAAF,EAAA,MAAoBA;AAAA,gBAAA;AAAA,cAE3B;AACO,qBAAA/D,EAAkB6D,GAAwBnJ,GAAMoJ,CAAO;AAAA,YAChE;AAGF,cAAIjD,MAAS;AACX,mBAAO,CACLmD,MASG;AACH,oBAAME,IAAalO,EAChB,SACA,EAAA,eAAeH,GAAU6E,CAAI;AAGhC,qBAAK,MAAM,QAAQwJ,CAAU,KAU3B5D,GAAM,gBACN,MAAM,KAAK,EAAE,QAAQ4D,EAAW,OAAO,GAAG,CAACzB,GAAG5D,MAAMA,CAAC,GAEnC,IAAI,CAACkF,GAAeI,MAAe;AAC/C,sBAAA3C,IAAO0C,EAAWH,CAAa,GAC/BK,IAAY,CAAC,GAAG1J,GAAMqJ,EAAc,UAAU,GAC9CM,IAASrE,EAAkBwB,GAAM4C,GAAW9D,CAAI;AAmC/C,uBAAA0D,EAAWxC,GAAM6C,GAAQ;AAAA,kBAC9B,UAjCe,MAAM;AACrB,0BAAM,GAAGhJ,CAAW,IAAI/D,GAAS,EAAE,GAC7BgN,IAAkB,GAAGjN,CAAW,IAAIqD,EAAK,KAAK,GAAG,CAAC,IAAIqJ,CAAa;AAEzE,oBAAA1H,GAAgB,MAAM;AACpB,4BAAMhC,IAAkB,GAAGxE,CAAQ,OAAOyO,CAAe,IACnDrK,IAAajE,EAChB,SAAA,EACA,gBAAgB,IAAIH,CAAQ,KAAK;AAAA,wBAClC,gCAAgB,IAAI;AAAA,sBACtB;AAEW,6BAAAoE,EAAA,WAAW,IAAII,GAAiB;AAAA,wBACzC,aAAa,MAAMgB,EAAY,EAAE;AAAA,wBACjC,2BAAW,IAAI,CAAC+I,EAAU,KAAK,GAAG,CAAC,CAAC;AAAA,sBAAA,CACrC,GAEDpO,EACG,SAAS,EACT,gBAAgB,IAAIH,GAAUoE,CAAU,GAEpC,MAAM;AACX,8BAAMsK,IAAevO,EAClB,SACA,EAAA,gBAAgB,IAAIH,CAAQ;AAC/B,wBAAI0O,KACWA,EAAA,WAAW,OAAOlK,CAAe;AAAA,sBAElD;AAAA,oBAAA,GACC,CAACxE,GAAUyO,CAAe,CAAC;AAAA,kBAChC;AAAA,kBAIE,OAAOH;AAAA,kBACP,eAAAJ;AAAA,gBAAA,CACD;AAAA,cAAA,CACF,KAvDS,QAAA;AAAA,gBACN,iDAAiDrJ,EAAK,KAAK,GAAG,CAAC;AAAA,gBAC/DwJ;AAAA,cACF,GACO;AAAA,YAoDX;AAEF,cAAIrD,MAAS;AACX,mBAAO,CACLmD,MAQmBxK,EACD,IAAI,CAACgI,GAAM9D,MAAU;AACjC,kBAAAqG;AAEJ,cACEzD,GAAM,gBACNA,EAAK,aAAa5C,CAAK,MAAM,SAEbqG,IAAAzD,EAAK,aAAa5C,CAAK,IAEvBqG,IAAArG;AAElB,oBAAM0G,IAAY,CAAC,GAAG1J,GAAMqJ,EAAc,UAAU,GAE9CM,IAASrE,EAAkBwB,GAAM4C,GAAW9D,CAAI;AAC/C,qBAAA0D;AAAA,gBACLxC;AAAA,gBACA6C;AAAA,gBACA3G;AAAA,gBACAlE;AAAA,gBACAwG,EAAkBxG,GAAqBkB,GAAM4F,CAAI;AAAA,cACnD;AAAA,YAAA,CACD;AAGL,cAAIO,MAAS;AACX,mBAAO,CACLmD,MAQOQ,GAAcC,IAAmB;AAAA,cACtC,OAAO;AAAA,gBACL,WAAW5O;AAAA,gBACX,OAAO6E;AAAA,gBACP,QAAQsJ;AAAA;AAAA,cACV;AAAA,cAEA,mBAAAhE;AAAA,YAAA,CACD;AAIL,cAAIa,MAAS;AACX,mBAAO,CAAC6D,MAAsB;AAC5B,oBAAMR,IAAa1K;AACnB,cAAAiG,EAAW,MAAM,GACjBC;AACA,oBAAMiF,IAAmBT,EAAW;AAAA,gBAClC,CAACU,MAAaA,EAAIF,CAAS,KAAK,CAAA;AAAA,cAClC;AACO,qBAAA1E;AAAA,gBACL2E;AAAA,gBACA,CAAC,GAAGjK,GAAM,OAAOgK,CAAS;AAAA,gBAC1BpE;AAAA,cACF;AAAA,YACF;AAGF,cAAIO,MAAS;AACX,mBAAO,CAACnD,MAAkB;AAClB,oBAAAmH,IAAarL,EAAakE,CAAK;AAC9B,qBAAAsC,EAAkB6E,GAAY,CAAC,GAAGnK,GAAMgD,EAAM,SAAA,CAAU,CAAC;AAAA,YAClE;AAEF,cAAImD,MAAS;AAEX,mBAAO,MAAM;AACX,oBAAMiE,IAAe9O,EAClB,SACA,EAAA,eAAeH,GAAU6E,CAAI;AAC5B,kBAAAoK,EAAa,WAAW,EAAU;AAChC,oBAAAC,IAAYD,EAAa,SAAS,GAClCE,IAAYF,EAAaC,CAAS,GAClCE,IAAU,CAAC,GAAGvK,GAAMqK,EAAU,UAAU;AAGvC,qBAAA/E,EAAkBgF,GAAWC,CAAO;AAAA,YAC7C;AAEF,cAAIpE,MAAS;AACX,mBAAO,CAACpG,OAENkF,EAAoBjF,CAAI,GACfwK,GAAApL,GAAmBW,GAASC,GAAM7E,CAAQ,GAC5CmK;AAAA,cACLhK,EAAe,SAAW,EAAA,eAAeH,GAAU6E,CAAI;AAAA,cACvDA;AAAA,YACF;AAIJ,cAAImG,MAAS;AACJ,mBAAA,CACLpG,GACA0K,GACAC,MACG;AACH,oBAAMN,IAAe9O,EAClB,SACA,EAAA,eAAeH,GAAU6E,CAAI,GAC1BuC,IAAWnE,EAAc2B,CAAO,IAClCA,EAAQqK,CAAmB,IAC1BrK;AAEL,kBAAI4K,IAAmB;AAkBvB,kBAjBiB,CAACP,EAAa,KAAK,CAACtD,MAAS;AAC5C,oBAAI2D,GAAQ;AACV,wBAAMG,IAAUH,EAAO;AAAA,oBAAM,CAAC9E,MAC5B3J,EAAY8K,EAAKnB,CAAK,GAAGpD,EAASoD,CAAK,CAAC;AAAA,kBAC1C;AACA,yBAAIiF,MACYD,IAAA7D,IAET8D;AAAAA,gBAAA;AAEH,sBAAAA,IAAU5O,EAAY8K,GAAMvE,CAAQ;AAC1C,uBAAIqI,MACYD,IAAA7D,IAET8D;AAAA,cAAA,CACR;AAGC,gBAAA3F,EAAoBjF,CAAI,GACfwK,GAAApL,GAAmBmD,GAAUvC,GAAM7E,CAAQ;AAAA,uBAC3CuP,KAAWC,GAAa;AAC3B,sBAAAE,IAAcH,EAAQC,CAAW,GACjCG,IAAeV,EAAa;AAAA,kBAAI,CAACtD,MACrC9K,EAAY8K,GAAM6D,CAAW,IAAIE,IAAc/D;AAAA,gBACjD;AACA,gBAAA7B,EAAoBjF,CAAI,GACf+K,GAAA3L,GAAmB0L,GAAqB9K,CAAI;AAAA,cAAA;AAAA,YAEzD;AAGF,cAAImG,MAAS;AACJ,mBAAA,CAACnD,GAAetH,MAAwC;AAC7D,kBAAI,CAAAA,GAAS;AAEb,uBAAAuJ,EAAoBjF,CAAI,GAChBgL,GAAA5L,GAAmBY,GAAM7E,GAAU6H,CAAK,GACzCsC;AAAA,kBACLhK,EAAe,SAAW,EAAA,eAAeH,GAAU6E,CAAI;AAAA,kBACvDA;AAAA,gBACF;AAAA,YACF;AAEF,cAAImG,MAAS;AACX,mBAAO,CAAC8E,MAAqC;AAC3C,uBAASjI,IAAQ,GAAGA,IAAQlE,EAAa,QAAQkE;AAC3C,gBAAAlE,EAAakE,CAAK,MAAMiI,KAClBD,GAAA5L,GAAmBY,GAAM7E,GAAU6H,CAAK;AAAA,YAGtD;AAEF,cAAImD,MAAS;AACX,mBAAO,CAAC8E,MAAqC;AAC3C,oBAAMjI,IAAQlE,EAAa,UAAU,CAACgI,MAASA,MAASmE,CAAK;AAC7D,cAAIjI,IAAQ,KAEFgI,GAAA5L,GAAmBY,GAAM7E,GAAU6H,CAAK,IAGvCwH,GAAApL,GAAmB6L,GAAcjL,GAAM7E,CAAQ;AAAA,YAE5D;AAEF,cAAIgL,MAAS;AACX,mBAAO,CACLmD,MAIG;AAEH,oBAAM4B,IADoBrE,EAAyB,EACnB;AAAA,gBAAK,CAAC,EAAE,MAAAC,KAAQ9D,MAC9CsG,EAAWxC,GAAM9D,CAAK;AAAA,cACxB;AACI,kBAAA,CAACkI,EAAc;AACnB,oBAAMxB,IAAY,CAAC,GAAG1J,GAAMkL,EAAM,cAAc,UAAU;AAC1D,qBAAO5F,EAAkB4F,EAAM,MAAMxB,GAAW9D,CAAI;AAAA,YACtD;AAGF,cAAIO,MAAS;AACJ,mBAAA,CAACnI,GAAqCmN,MAAmB;AAE9D,oBAAMD,IADoBrE,EAAyB,EACnB;AAAA,gBAC9B,CAAC,EAAE,MAAAC,EAAA,MAAWA,EAAK9I,CAAO,MAAMmN;AAAA,cAClC;AACI,kBAAA,CAACD,EAAc;AACnB,oBAAMxB,IAAY,CAAC,GAAG1J,GAAMkL,EAAM,cAAc,UAAU;AAC1D,qBAAO5F,EAAkB4F,EAAM,MAAMxB,GAAW9D,CAAI;AAAA,YACtD;AAAA,QACF;AAEF,cAAMwF,IAAkBpL,EAAKA,EAAK,SAAS,CAAC;AAC5C,YAAI,CAAC,MAAM,OAAOoL,CAAe,CAAC,GAAG;AACnC,gBAAMrI,IAAa/C,EAAK,MAAM,GAAG,EAAE,GAC7BqL,IAAc/P,EACjB,SACA,EAAA,eAAeH,GAAU4H,CAAU;AAEtC,cAAI,MAAM,QAAQsI,CAAW,KAAKlF,MAAS;AACzC,mBAAO,MACL6E;AAAA,cACE5L;AAAA,cACA2D;AAAA,cACA5H;AAAA,cACA,OAAOiQ,CAAe;AAAA,YACxB;AAAA,QACJ;AAGF,YAAIjF,MAAS;AACX,iBAAO,MAAM;AACX,gBAAIP,GAAM,gBAAgB,MAAM,QAAQ9G,CAAY,GAAG;AAErD,oBAAMwM,IAAYhQ,EACf,SACA,EAAA,eAAeH,GAAU6E,CAAI;AAChC,qBAAO4F,EAAK,aAAa,IAAI,CAAC5C,MAAUsI,EAAUtI,CAAK,CAAC;AAAA,YAAA;AAE1D,mBAAO1H,EAAe,SAAA,EAAW,eAAeH,GAAU6E,CAAI;AAAA,UAChE;AAEF,YAAImG,MAAS;AACJ,iBAAA,CAACoF,MACNC,GAAY;AAAA,YACV,WAAWrQ;AAAA,YACX,OAAO6E;AAAA,YACP,SAASuL,EAAG,SAAS;AAAA,UAAA,CACtB;AAGL,YAAIpF,MAAS;AACX,iBAAO,MACLqF,GAAY;AAAA,YACV,WAAWrQ;AAAA,YACX,OAAO6E;AAAA,UAAA,CACR;AAEL,YAAImG,MAAS,cAAc;AACzB,gBAAM/E,IAAU,GAAGjG,CAAQ,IAAI6E,EAAK,KAAK,GAAG,CAAC;AAC7C,iBAAO1E,EAAe,WAAW,YAAY8F,CAAO;AAAA,QAAA;AAGtD,YAAI+E,KAAQ;AACV,iBAAO,CAACpK,MACNwC,GAAqBL,IAAY,MAAM/C,IAAW,MAAMY,CAAG;AAE/D,YAAIoK,MAAS,aAAa;AACxB,gBAAMpD,IAAa/C,EAAK,MAAM,GAAG,EAAE,GAC7ByL,IAAY1I,EAAW,KAAK,GAAG,GAC/BJ,IAASrH,EACZ,SACA,EAAA,eAAeH,GAAU4H,CAAU;AAClC,iBAAA,MAAM,QAAQJ,CAAM,IACD,OAAO3C,EAAKA,EAAK,SAAS,CAAC,CAAC,MAG/C1E,EAAe,SAAW,EAAA,iBAAiBH,GAAUsQ,CAAS,IAG3D;AAAA,QAAA;AAET,YAAItF,MAAS;AACX,iBAAO,CAAC8E,MAAmB;AACzB,kBAAMlI,IAAa/C,EAAK,MAAM,GAAG,EAAE,GAC7B0L,IAAY,OAAO1L,EAAKA,EAAK,SAAS,CAAC,CAAC,GACxCyL,IAAY1I,EAAW,KAAK,GAAG;AAErC,YAAIkI,IACF3P,EACG,SAAS,EACT,iBAAiBH,GAAUsQ,GAAWC,CAAS,IAElDpQ,EACG,SAAS,EACT,iBAAiBH,GAAUsQ,GAAW,MAAS;AAG9C,kBAAAE,IAASrQ,EACZ,SAAS,EACT,eAAeH,GAAU,CAAC,GAAG4H,CAAU,CAAC;AAClC,YAAAgI,GAAA3L,GAAmBuM,GAAQ5I,CAAU,GAG9CkC,EAAoBlC,CAAU;AAAA,UAChC;AAEF,YAAIoD,MAAS;AACX,iBAAO,MAAM;AACX,kBAAMpD,IAAa/C,EAAK,MAAM,GAAG,EAAE,GAC7B0L,IAAY,OAAO1L,EAAKA,EAAK,SAAS,CAAC,CAAC,GACxCyL,IAAY1I,EAAW,KAAK,GAAG,GAC/BgE,IAAgBzL,EACnB,SACA,EAAA,iBAAiBH,GAAUsQ,CAAS;AAEvC,YAAAnQ,EACG,WACA;AAAA,cACCH;AAAA,cACAsQ;AAAA,cACA1E,MAAkB2E,IAAY,SAAYA;AAAA,YAC5C;AACI,kBAAAC,IAASrQ,EACZ,SAAS,EACT,eAAeH,GAAU,CAAC,GAAG4H,CAAU,CAAC;AAClC,YAAAgI,GAAA3L,GAAmBuM,GAAQ5I,CAAU,GAE9CkC,EAAoBlC,CAAU;AAAA,UAChC;AAEE,YAAA/C,EAAK,UAAU,GAAG;AACpB,cAAImG,MAAS;AACX,mBAAO,CAACyF,MAAmB;AAEzB,oBAAM9M,IACJxD,EAAe,SAAS,EAAE,eAAeH,CAAQ,GAE7CgE,IADc0M,GAAW/M,GAAc8M,CAAO,EACvB;AAG7B,cAAA1M;AAAA,gBACE/D;AAAA,gBACAG,EAAe,SAAA,EAAW,mBAAmBH,CAAQ;AAAA,gBACrDgE;AAAA,gBACAC;AAAA,gBACAzC;AAAA,gBACAuB;AAAA,cACF;AAMA,oBAAMqB,IAAajE,EAChB,SACA,EAAA,gBAAgB,IAAIH,CAAQ;AAE/B,kBAAIoE,GAAY;AAER,sBAAA+D,IAAeC,GAAezE,GAAcK,CAAQ,GACpDqE,IAAkB,IAAI,IAAIF,CAAY;AAIjC,2BAAA;AAAA,kBACT1B;AAAA,kBACApC;AAAA,gBAAA,KACGD,EAAW,WAAW,WAAW;AACpC,sBAAImE,IAAe;AACb,wBAAAC,IAAgB,MAAM,QAAQnE,EAAU,YAAY,IACtDA,EAAU,eACV,CAACA,EAAU,gBAAgB,WAAW;AAEtC,sBAAA,CAAAmE,EAAc,SAAS,MAAM,GAC7B;AAAA,wBAAAA,EAAc,SAAS,KAAK,GAAG;AACjC,sBAAAnE,EAAU,YAAY;AACtB;AAAA,oBAAA;AAGE,wBAAAmE,EAAc,SAAS,WAAW,MAGhCnE,EAAU,MAAM,IAAI,EAAE,MAETkE,IAAA,KAGb,CAACA;AACH,iCAAWE,KAAeJ,GAAiB;AAEzC,4BAAIhE,EAAU,MAAM,IAAIoE,CAAW,GAAG;AACrB,0BAAAF,IAAA;AACf;AAAA,wBAAA;AAIE,4BAAAoI,IAAWlI,EAAY,YAAY,GAAG;AAC1C,+BAAOkI,MAAa,MAAI;AACtB,gCAAM/I,IAAaa,EAAY,UAAU,GAAGkI,CAAQ;AACpD,8BAAItM,EAAU,MAAM,IAAIuD,CAAU,GAAG;AACpB,4BAAAW,IAAA;AACf;AAAA,0BAAA;AAGF,gCAAMqI,IAAcnI,EAAY;AAAA,4BAC9BkI,IAAW;AAAA,0BACb;AACA,8BAAI,CAAC,MAAM,OAAOC,CAAW,CAAC,GAAG;AAEzB,kCAAAC,IAAiBjJ,EAAW,YAAY,GAAG;AACjD,gCAAIiJ,MAAmB,IAAI;AACzB,oCAAMC,IAAkBlJ,EAAW;AAAA,gCACjC;AAAA,gCACAiJ;AAAA,8BACF;AACA,kCAAIxM,EAAU,MAAM,IAAIyM,CAAe,GAAG;AACzB,gCAAAvI,IAAA;AACf;AAAA,8BAAA;AAAA,4BACF;AAAA,0BACF;AAES,0BAAAoI,IAAA/I,EAAW,YAAY,GAAG;AAAA,wBAAA;AAGvC,4BAAIW,EAAc;AAAA,sBAAA;AAKxB,wBAAI,CAACA,KAAgBC,EAAc,SAAS,MAAM,KAE5CnE,EAAU,cAAc;AACpB,4BAAAuE,IAAavE,EAAU,aAAaL,CAAQ;AAClD,0BAAI6E,IAAc;AACd,sBAAA,OAAOD,KAAe,YACpBA,MAA0BC,IAAA,MACpBhI,EAAYwD,EAAU,MAAMuE,CAAU,MAChDvE,EAAU,OAAOuE,GACHC,IAAA,KAEZA,MACaN,IAAA;AAAA,oBACjB;AAIJ,oBAAIA,KACFlE,EAAU,YAAY;AAAA;AAAA,gBACxB;AAAA,cACF;AAAA,YAEJ;AAEF,cAAI2G,MAAS;AACX,mBAAO,MAAM;AACX,oBAAMf,IAAO9J,EACV,SACA,EAAA,kBAAkBH,CAAQ,GAAG,YAC1ByC,IACJtC,EAAe,SAAA,EAAW;AAExB,kBAAA,CAAC8J,GAAM;AACH,sBAAA,IAAI,MAAM,sBAAsB;AAGpC,kBAAA,CAACA,GAAM;AACH,sBAAA,IAAI,MAAM,0BAA0B;AAE5C,cAAAvH,EAAsBuH,EAAK,GAAG;AAC9B,oBAAM8G,IACJ5Q,EAAe,SAAS,EAAE,eAAeH,CAAQ;AAE/C,kBAAA;AAGF,sBAAMgR,IAAiB7Q,EACpB,SACA,EAAA,oBAAoB8J,EAAK,GAAG;AAC3B,gBAAA+G,KAAkBA,EAAe,SAAS,KAC5CA,EAAe,QAAQ,CAAC,CAACzF,CAAS,MAAM;AACtC,kBAAIA,KAAaA,EAAU,WAAWtB,EAAK,GAAI,KAC7CvH,EAAsB6I,CAAS;AAAA,gBACjC,CACD;AAIH,sBAAM0F,IAAShH,EAAK,UAAU,UAAU8G,CAAU;AAE9C,uBAACE,EAAO,UAqBL,MAnBaA,EAAO,MAAM,OAErB,QAAQ,CAACvN,MAAU;AAC3B,wBAAM6H,IAAY7H,EAAM,MAClBwN,IAAexN,EAAM,SAIrByN,IAAgB,CAAClH,EAAK,KAAK,GAAGsB,CAAS,EAAE,KAAK,GAAG;AAGvD9I,kBAAAA,EAAmB0O,GAAeD,CAAY;AAAA,gBAAA,CAC/C,GAEDhP,GAAiBlC,CAAQ,GAElB;AAAA,uBAIF0D,GAAO;AACN,+BAAA,MAAM,gCAAgCA,CAAK,GAC5C;AAAA,cAAA;AAAA,YAEX;AAEE,cAAAsH,MAAS,eAAuB,QAAAxJ;AACpC,cAAIwJ,MAAS;AACX,mBAAO,MAAM7K,EAAiB,EAAA,gBAAgB,IAAIH,CAAQ;AAE5D,cAAIgL,MAAS;AACX,mBAAO,MACEoG,GAAa,WAAW,sBAAsBpR,CAAQ;AAIjE,cAAIgL,MAAS;AACX,mBAAO7K,EAAe,WAAW,mBAAmBH,CAAQ;AAC9D,cAAIgL,MAAS;AACX,mBAAO7K,EAAe,WAAW,YAAYH,CAAQ;AACvD,cAAIgL,MAAS;AACX,mBAAO7K,EAAe,WAAW,gBAAgBH,CAAQ;AAC3D,cAAIgL,MAAS;AACX,mBAAOjB,EAAQ;AACb,cAAAiB,MAAS,qBAAsB,QAAOjB,EAAQ;AAC9C,cAAAiB,MAAS,mBAAoB,QAAOjB,EAAQ;AAAA,QAAA;AAElD,YAAIiB,MAAS;AACX,iBAAO,MACEoG,GACJ,SACA,EAAA,WAAWpR,IAAW,MAAM6E,EAAK,KAAK,GAAG,CAAC;AAIjD,YAAImG,MAAS;AACX,iBAAO,CAAC;AAAA,YACN,UAAAqG;AAAA,YACA,aAAAC;AAAA,UAAA,MAKA,gBAAAC;AAAA,YAACC;AAAA,YAAA;AAAA,cACC,UACEF,IAAc,EAAE,YAAY,EAAE,SAAS,SAAS;AAAA,cAElD,MAAAzM;AAAA,cACA,eACE1E,EAAe,WAAW,kBAAkBH,CAAQ,GAChD,YAAY,OAAO;AAAA,cAEzB,UAAAA;AAAA,cACA,cAAcyK,GAAM;AAAA,cAEnB,UAAA4G;AAAA,YAAA;AAAA,UACH;AAIA,YAAArG,MAAS,YAAoB,QAAAhL;AAC7B,YAAAgL,MAAS,QAAgB,QAAAnG;AACzB,YAAAmG,MAAS,kBAAmB,QAAOjB,EAAQ;AAE/C,YAAIiB,MAAS;AACJ,iBAAA,CAACpG,GAAuB6M,MAAyB;AAEtD,gBAAIA,GAAM;AACR,cAAAC,GAAS,MAAM;AACJ,gBAAA9B,GAAA3L,GAAmBW,GAASC,GAAM,EAAE;AAC7C,sBAAMuC,IAAWjH,EACd,SACA,EAAA,eAAeH,GAAU6E,CAAI;AAChC,gBAAI4M,GAAM,eAAkBA,EAAA,YAAYrK,CAAQ;AAAA,cAAA,GAC/CqK,EAAK,QAAQ;AAAA,iBACX;AACI,cAAA7B,GAAA3L,GAAmBW,GAASC,GAAM,EAAE;AAC7C,oBAAMuC,IAAWjH,EACd,SACA,EAAA,eAAeH,GAAU6E,CAAI;AAChC,cAAI4M,GAAM,eAAkBA,EAAA,YAAYrK,CAAQ;AAAA,YAAA;AAElD,YAAA0C,EAAoBjF,CAAI;AAAA,UAC1B;AAGF,YAAImG,MAAS;AACJ,iBAAA,CAAC2G,GAAuBC,MAE3B,gBAAAL;AAAA,YAACM;AAAA,YAAA;AAAA,cACC,UAAU5N;AAAA,cACV,UAAAjE;AAAA,cACA,MAAA6E;AAAA,cACA,OAAA8M;AAAA,cACA,UAAAC;AAAA,YAAA;AAAA,UACF;AAKN,cAAME,IAAW,CAAC,GAAGjN,GAAMmG,CAAI,GACzB+G,IAAY5R,EACf,SACA,EAAA,eAAeH,GAAU8R,CAAQ;AAC7B,eAAA3H,EAAkB4H,GAAWD,GAAUrH,CAAI;AAAA,MAAA;AAAA,IAEtD,GAEMuH,IAAgB,IAAI,MAAMrH,GAAcC,CAAO;AAErD,WAAAhB,EAAW,IAAIc,GAAU;AAAA,MACvB,OAAOsH;AAAA,MACP,cAAAnI;AAAA,IAAA,CACD,GAEMmI;AAAA,EAAA;AAGF,SAAA7H;AAAA,IACLhK,EAAe,SAAS,EAAE,eAAeH,GAAU,CAAE,CAAA;AAAA,EACvD;AACF;AAEO,SAASqQ,GAAY4B,GAIzB;AACD,SAAOtD,GAAcuD,IAAgB,EAAE,OAAAD,GAAO;AAChD;AAEA,SAASrD,GAAkB;AAAA,EACzB,OAAAqD;AAAA,EAEA,mBAAA9H;AACF,GAkBG;AACD,QAAM2F,IAAQ3P,IAAiB,eAAe8R,EAAM,WAAWA,EAAM,KAAK;AAE1E,SAAK,MAAM,QAAQnC,CAAK,IAGJ3F;AAAA,IAClB2F;AAAA,IACAmC,EAAM;AAAA,EACR,EAEmB;AAAA,IACjB,CAACtG,GAAM6C,GAAQ3G,GAAOiI,GAAOqC,MAEpBF,EAAM,OAAOtG,GAAM6C,GAAQ3G,GAAOiI,GAAOqC,CAAW;AAAA,EAE/D,IAZS;AAaX;AACA,SAASD,GAAe;AAAA,EACtB,OAAAD;AACF,GAMG;AACK,QAAAG,IAAaxM,EAAwB,IAAI,GACzCkB,IAAW,GAAGmL,EAAM,SAAS,IAAIA,EAAM,MAAM,KAAK,GAAG,CAAC;AAE5D,SAAAlM,GAAU,MAAM;AACd,UAAMsM,IAAUD,EAAW;AAC3B,QAAI,CAACC,KAAW,CAACA,EAAQ,cAAe;AAExC,UAAMC,IAAgBD,EAAQ,eAExB/K,IADa,MAAM,KAAKgL,EAAc,UAAU,EAC1B,QAAQD,CAAO;AAEvC,QAAAhL,IAAWiL,EAAc,aAAa,gBAAgB;AAC1D,IAAKjL,MACQA,IAAA,UAAU,OAAO,WAAY,CAAA,IAC1BiL,EAAA,aAAa,kBAAkBjL,CAAQ;AAIvD,UAAMkL,IAAc;AAAA,MAClB,YAFiB,YAAY,OAAO,WAAY,CAAA;AAAA,MAGhD,UAAAlL;AAAA,MACA,UAAAC;AAAA,MACA,QAAQ2K,EAAM;AAAA,IAChB;AAEA,IAAA9R,EAAe,SAAS,EAAE,iBAAiB2G,GAAUyL,CAAW;AAG1D,UAAAzC,IAAQ3P,EACX,SAAS,EACT,eAAe8R,EAAM,WAAWA,EAAM,KAAK;AAE1C,QAAAvK;AACJ,QAAIuK,EAAM;AACJ,UAAA;AACF,QAAAvK,IAAe,IAAI;AAAA,UACjB;AAAA,UACA,WAAWuK,EAAM,OAAO;AAAA,UACxBnC,CAAK;AAAA,eACA0C,GAAK;AACJ,gBAAA,MAAM,kDAAkDA,CAAG,GACpD9K,IAAAoI;AAAA,MAAA;AAAA;AAGF,MAAApI,IAAAoI;AAGjB,IAAIpI,MAAiB,QAAQ,OAAOA,KAAiB,aACpCA,IAAA,KAAK,UAAUA,CAAY;AAG5C,UAAM+K,IAAW,SAAS,eAAe,OAAO/K,CAAY,CAAC;AAC7D,IAAA2K,EAAQ,YAAYI,CAAQ;AAAA,EAAA,GAC3B,CAACR,EAAM,WAAWA,EAAM,MAAM,KAAK,GAAG,GAAGA,EAAM,OAAO,CAAC,GAEnDtD,GAAc,QAAQ;AAAA,IAC3B,KAAKyD;AAAA,IACL,OAAO,EAAE,SAAS,OAAO;AAAA,IACzB,kBAAkBtL;AAAA,EAAA,CACnB;AACH;AACO,SAAS4L,GAAiBT,GAG9B;AACD,QAAMnC,IAAQ6C;AAAA,IACZ,CAACC,MAAW;AACJ,YAAAxO,IAAajE,EAChB,SAAS,EACT,gBAAgB,IAAI8R,EAAM,SAAS,KAAK;AAAA,QACzC,gCAAgB,IAAI;AAAA,MACtB;AACW,aAAA7N,EAAA,WAAW,IAAI6N,EAAM,WAAW;AAAA,QACzC,aAAaW;AAAA,QACb,2BAAW,IAAI,CAACX,EAAM,MAAM,KAAK,GAAG,CAAC,CAAC;AAAA,MAAA,CACvC,GACM,MAAM7N,EAAW,WAAW,OAAO6N,EAAM,SAAS;AAAA,IAC3D;AAAA,IACA,MAAM9R,EAAe,WAAW,eAAe8R,EAAM,WAAWA,EAAM,KAAK;AAAA,EAC7E;AACA,SAAOtD,GAAc,QAAQ,CAAI,GAAA,OAAOmB,CAAK,CAAC;AAChD;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cogsbox-state",
3
- "version": "0.5.278",
3
+ "version": "0.5.279",
4
4
  "description": "React state management library with form controls and server sync",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
package/src/CogsState.tsx CHANGED
@@ -1464,6 +1464,7 @@ function createProxyHandler<T>(
1464
1464
  }
1465
1465
  startTransition(() => {
1466
1466
  updateInitialStateGlobal(stateKey, newState);
1467
+ getGlobalStore.getState().initializeShadowState(stateKey, newState);
1467
1468
  setUpdaterState(stateKey, newUpdaterState);
1468
1469
  setState(stateKey, newState);
1469
1470
  const stateEntry = getGlobalStore