cogsbox-state 0.5.381 → 0.5.383

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,17 +1,17 @@
1
1
  "use client";
2
2
  import { jsx as we } from "react/jsx-runtime";
3
- import { useState as Q, useRef as J, useEffect as oe, useLayoutEffect as le, useMemo as Ee, createElement as de, useSyncExternalStore as De, startTransition as Ue, useCallback as $e } from "react";
4
- import { transformStateFunc as je, isDeepEqual as q, isFunction as K, getNestedValue as Z, getDifferences as _e, debounce as Fe } from "./utility.js";
5
- import { pushFunc as pe, updateFn as ce, cutFunc as me, ValidationWrapper as He, FormControlComponent as We } from "./Functions.jsx";
6
- import Be from "superjson";
3
+ import { useState as K, useRef as J, useEffect as oe, useLayoutEffect as ce, useMemo as Oe, createElement as le, useSyncExternalStore as De, startTransition as Ue, useCallback as $e } from "react";
4
+ import { transformStateFunc as je, isDeepEqual as q, isFunction as ee, getNestedValue as Y, getDifferences as _e, debounce as He } from "./utility.js";
5
+ import { pushFunc as Ee, updateFn as ie, cutFunc as me, ValidationWrapper as Fe, FormControlComponent as Be } from "./Functions.jsx";
6
+ import We from "superjson";
7
7
  import { v4 as Ae } from "uuid";
8
8
  import "zod";
9
- import { getGlobalStore as o, formRefStore as ke } from "./store.js";
10
- import { useCogsConfig as Ve } from "./CogsStateClient.jsx";
9
+ import { getGlobalStore as r, formRefStore as ke } from "./store.js";
10
+ import { useCogsConfig as Pe } from "./CogsStateClient.jsx";
11
11
  import { applyPatch as ze } from "fast-json-patch";
12
12
  import qe from "react-use-measure";
13
13
  function be(e, i) {
14
- const m = o.getState().getInitialOptions, g = o.getState().setInitialStateOptions, T = m(e) || {};
14
+ const m = r.getState().getInitialOptions, g = r.getState().setInitialStateOptions, T = m(e) || {};
15
15
  g(e, {
16
16
  ...T,
17
17
  ...i
@@ -22,92 +22,92 @@ function xe({
22
22
  options: i,
23
23
  initialOptionsPart: m
24
24
  }) {
25
- const g = re(e) || {}, T = m[e] || {}, O = o.getState().setInitialStateOptions, w = { ...T, ...g };
26
- let y = !1;
25
+ const g = re(e) || {}, T = m[e] || {}, C = r.getState().setInitialStateOptions, p = { ...T, ...g };
26
+ let v = !1;
27
27
  if (i)
28
- for (const s in i)
29
- w.hasOwnProperty(s) ? (s == "localStorage" && i[s] && w[s].key !== i[s]?.key && (y = !0, w[s] = i[s]), s == "initialState" && i[s] && w[s] !== i[s] && // Different references
30
- !q(w[s], i[s]) && (y = !0, w[s] = i[s])) : (y = !0, w[s] = i[s]);
31
- y && O(e, w);
28
+ for (const a in i)
29
+ p.hasOwnProperty(a) ? (a == "localStorage" && i[a] && p[a].key !== i[a]?.key && (v = !0, p[a] = i[a]), a == "initialState" && i[a] && p[a] !== i[a] && // Different references
30
+ !q(p[a], i[a]) && (v = !0, p[a] = i[a])) : (v = !0, p[a] = i[a]);
31
+ v && C(e, p);
32
32
  }
33
- function mt(e, { formElements: i, validation: m }) {
33
+ function It(e, { formElements: i, validation: m }) {
34
34
  return { initialState: e, formElements: i, validation: m };
35
35
  }
36
36
  const ht = (e, i) => {
37
37
  let m = e;
38
38
  const [g, T] = je(m);
39
- (Object.keys(T).length > 0 || i && Object.keys(i).length > 0) && Object.keys(T).forEach((y) => {
40
- T[y] = T[y] || {}, T[y].formElements = {
39
+ (Object.keys(T).length > 0 || i && Object.keys(i).length > 0) && Object.keys(T).forEach((v) => {
40
+ T[v] = T[v] || {}, T[v].formElements = {
41
41
  ...i?.formElements,
42
42
  // Global defaults first
43
43
  ...i?.validation,
44
- ...T[y].formElements || {}
44
+ ...T[v].formElements || {}
45
45
  // State-specific overrides
46
- }, re(y) || o.getState().setInitialStateOptions(y, T[y]);
47
- }), o.getState().setInitialStates(g), o.getState().setCreatedState(g);
48
- const O = (y, s) => {
49
- const [I] = Q(s?.componentId ?? Ae());
46
+ }, re(v) || r.getState().setInitialStateOptions(v, T[v]);
47
+ }), r.getState().setInitialStates(g), r.getState().setCreatedState(g);
48
+ const C = (v, a) => {
49
+ const [h] = K(a?.componentId ?? Ae());
50
50
  xe({
51
- stateKey: y,
52
- options: s,
51
+ stateKey: v,
52
+ options: a,
53
53
  initialOptionsPart: T
54
54
  });
55
- const n = o.getState().cogsStateStore[y] || g[y], S = s?.modifyState ? s.modifyState(n) : n, [W, G] = et(
55
+ const n = r.getState().cogsStateStore[v] || g[v], S = a?.modifyState ? a.modifyState(n) : n, [B, R] = et(
56
56
  S,
57
57
  {
58
- stateKey: y,
59
- syncUpdate: s?.syncUpdate,
60
- componentId: I,
61
- localStorage: s?.localStorage,
62
- middleware: s?.middleware,
63
- enabledSync: s?.enabledSync,
64
- reactiveType: s?.reactiveType,
65
- reactiveDeps: s?.reactiveDeps,
66
- initialState: s?.initialState,
67
- dependencies: s?.dependencies,
68
- serverState: s?.serverState
58
+ stateKey: v,
59
+ syncUpdate: a?.syncUpdate,
60
+ componentId: h,
61
+ localStorage: a?.localStorage,
62
+ middleware: a?.middleware,
63
+ enabledSync: a?.enabledSync,
64
+ reactiveType: a?.reactiveType,
65
+ reactiveDeps: a?.reactiveDeps,
66
+ initialState: a?.initialState,
67
+ dependencies: a?.dependencies,
68
+ serverState: a?.serverState
69
69
  }
70
70
  );
71
- return G;
71
+ return R;
72
72
  };
73
- function w(y, s) {
74
- xe({ stateKey: y, options: s, initialOptionsPart: T }), s.localStorage && Qe(y, s), ve(y);
73
+ function p(v, a) {
74
+ xe({ stateKey: v, options: a, initialOptionsPart: T }), a.localStorage && Qe(v, a), ve(v);
75
75
  }
76
- return { useCogsState: O, setCogsOptions: w };
76
+ return { useCogsState: C, setCogsOptions: p };
77
77
  }, {
78
- setUpdaterState: he,
78
+ setUpdaterState: Ie,
79
79
  setState: ne,
80
80
  getInitialOptions: re,
81
- getKeyState: Ge,
81
+ getKeyState: Le,
82
82
  getValidationErrors: Je,
83
83
  setStateLog: Ye,
84
- updateInitialStateGlobal: Oe,
84
+ updateInitialStateGlobal: Ne,
85
85
  addValidationError: Ze,
86
- removeValidationError: X,
86
+ removeValidationError: Q,
87
87
  setServerSyncActions: Xe
88
- } = o.getState(), Me = (e, i, m, g, T) => {
88
+ } = r.getState(), Me = (e, i, m, g, T) => {
89
89
  m?.log && console.log(
90
90
  "saving to localstorage",
91
91
  i,
92
92
  m.localStorage?.key,
93
93
  g
94
94
  );
95
- const O = K(m?.localStorage?.key) ? m.localStorage?.key(e) : m?.localStorage?.key;
96
- if (O && g) {
97
- const w = `${g}-${i}-${O}`;
98
- let y;
95
+ const C = ee(m?.localStorage?.key) ? m.localStorage?.key(e) : m?.localStorage?.key;
96
+ if (C && g) {
97
+ const p = `${g}-${i}-${C}`;
98
+ let v;
99
99
  try {
100
- y = Te(w)?.lastSyncedWithServer;
100
+ v = Te(p)?.lastSyncedWithServer;
101
101
  } catch {
102
102
  }
103
- const s = {
103
+ const a = {
104
104
  state: e,
105
105
  lastUpdated: Date.now(),
106
- lastSyncedWithServer: T ?? y
107
- }, I = Be.serialize(s);
106
+ lastSyncedWithServer: T ?? v
107
+ }, h = We.serialize(a);
108
108
  window.localStorage.setItem(
109
- w,
110
- JSON.stringify(I.json)
109
+ p,
110
+ JSON.stringify(h.json)
111
111
  );
112
112
  }
113
113
  }, Te = (e) => {
@@ -119,29 +119,29 @@ const ht = (e, i) => {
119
119
  return console.error("Error loading from localStorage:", i), null;
120
120
  }
121
121
  }, Qe = (e, i) => {
122
- const m = o.getState().cogsStateStore[e], { sessionId: g } = Ve(), T = K(i?.localStorage?.key) ? i.localStorage.key(m) : i?.localStorage?.key;
122
+ const m = r.getState().cogsStateStore[e], { sessionId: g } = Pe(), T = ee(i?.localStorage?.key) ? i.localStorage.key(m) : i?.localStorage?.key;
123
123
  if (T && g) {
124
- const O = Te(
124
+ const C = Te(
125
125
  `${g}-${e}-${T}`
126
126
  );
127
- if (O && O.lastUpdated > (O.lastSyncedWithServer || 0))
128
- return ne(e, O.state), ve(e), !0;
127
+ if (C && C.lastUpdated > (C.lastSyncedWithServer || 0))
128
+ return ne(e, C.state), ve(e), !0;
129
129
  }
130
130
  return !1;
131
- }, Le = (e, i, m, g, T, O) => {
132
- const w = {
131
+ }, Ge = (e, i, m, g, T, C) => {
132
+ const p = {
133
133
  initialState: i,
134
- updaterState: Ie(
134
+ updaterState: he(
135
135
  e,
136
136
  g,
137
137
  T,
138
- O
138
+ C
139
139
  ),
140
140
  state: m
141
141
  };
142
- Oe(e, w.initialState), he(e, w.updaterState), ne(e, w.state);
142
+ Ne(e, p.initialState), Ie(e, p.updaterState), ne(e, p.state);
143
143
  }, ve = (e) => {
144
- const i = o.getState().stateComponents.get(e);
144
+ const i = r.getState().stateComponents.get(e);
145
145
  if (!i) return;
146
146
  const m = /* @__PURE__ */ new Set();
147
147
  i.components.forEach((g) => {
@@ -149,8 +149,8 @@ const ht = (e, i) => {
149
149
  }), queueMicrotask(() => {
150
150
  m.forEach((g) => g());
151
151
  });
152
- }, It = (e, i) => {
153
- const m = o.getState().stateComponents.get(e);
152
+ }, Tt = (e, i) => {
153
+ const m = r.getState().stateComponents.get(e);
154
154
  if (m) {
155
155
  const g = `${e}////${i}`, T = m.components.get(g);
156
156
  if ((T ? Array.isArray(T.reactiveType) ? T.reactiveType : [T.reactiveType || "component"] : null)?.includes("none"))
@@ -161,18 +161,18 @@ const ht = (e, i) => {
161
161
  switch (e) {
162
162
  case "update":
163
163
  return {
164
- oldValue: Z(i, g),
165
- newValue: Z(m, g)
164
+ oldValue: Y(i, g),
165
+ newValue: Y(m, g)
166
166
  };
167
167
  case "insert":
168
168
  return {
169
169
  oldValue: null,
170
170
  // or undefined
171
- newValue: Z(m, g)
171
+ newValue: Y(m, g)
172
172
  };
173
173
  case "cut":
174
174
  return {
175
- oldValue: Z(i, g),
175
+ oldValue: Y(i, g),
176
176
  newValue: null
177
177
  // or undefined
178
178
  };
@@ -185,322 +185,322 @@ function et(e, {
185
185
  serverSync: m,
186
186
  localStorage: g,
187
187
  formElements: T,
188
- reactiveDeps: O,
189
- reactiveType: w,
190
- componentId: y,
191
- initialState: s,
192
- syncUpdate: I,
188
+ reactiveDeps: C,
189
+ reactiveType: p,
190
+ componentId: v,
191
+ initialState: a,
192
+ syncUpdate: h,
193
193
  dependencies: n,
194
194
  serverState: S
195
195
  } = {}) {
196
- const [W, G] = Q({}), { sessionId: L } = Ve();
197
- let B = !i;
198
- const [h] = Q(i ?? Ae()), l = o.getState().stateLog[h], ue = J(/* @__PURE__ */ new Set()), ee = J(y ?? Ae()), P = J(
196
+ const [B, R] = K({}), { sessionId: D } = Pe();
197
+ let W = !i;
198
+ const [I] = K(i ?? Ae()), l = r.getState().stateLog[I], de = J(/* @__PURE__ */ new Set()), te = J(v ?? Ae()), L = J(
199
199
  null
200
200
  );
201
- P.current = re(h) ?? null, oe(() => {
202
- if (I && I.stateKey === h && I.path?.[0]) {
203
- ne(h, (r) => ({
204
- ...r,
205
- [I.path[0]]: I.newValue
201
+ L.current = re(I) ?? null, oe(() => {
202
+ if (h && h.stateKey === I && h.path?.[0]) {
203
+ ne(I, (o) => ({
204
+ ...o,
205
+ [h.path[0]]: h.newValue
206
206
  }));
207
- const t = `${I.stateKey}:${I.path.join(".")}`;
208
- o.getState().setSyncInfo(t, {
209
- timeStamp: I.timeStamp,
210
- userId: I.userId
207
+ const t = `${h.stateKey}:${h.path.join(".")}`;
208
+ r.getState().setSyncInfo(t, {
209
+ timeStamp: h.timeStamp,
210
+ userId: h.userId
211
211
  });
212
212
  }
213
- }, [I]), oe(() => {
214
- if (s) {
215
- be(h, {
216
- initialState: s
213
+ }, [h]), oe(() => {
214
+ if (a) {
215
+ be(I, {
216
+ initialState: a
217
217
  });
218
- const t = P.current, a = t?.serverState?.id !== void 0 && t?.serverState?.status === "success" && t?.serverState?.data, c = o.getState().initialStateGlobal[h];
219
- if (!(c && !q(c, s) || !c) && !a)
218
+ const t = L.current, s = t?.serverState?.id !== void 0 && t?.serverState?.status === "success" && t?.serverState?.data, c = r.getState().initialStateGlobal[I];
219
+ if (!(c && !q(c, a) || !c) && !s)
220
220
  return;
221
221
  let u = null;
222
- const E = K(t?.localStorage?.key) ? t?.localStorage?.key(s) : t?.localStorage?.key;
223
- E && L && (u = Te(`${L}-${h}-${E}`));
224
- let p = s, _ = !1;
225
- const C = a ? Date.now() : 0, A = u?.lastUpdated || 0, b = u?.lastSyncedWithServer || 0;
226
- a && C > A ? (p = t.serverState.data, _ = !0) : u && A > b && (p = u.state, t?.localStorage?.onChange && t?.localStorage?.onChange(p)), o.getState().initializeShadowState(h, s), Le(
227
- h,
228
- s,
229
- p,
222
+ const y = ee(t?.localStorage?.key) ? t?.localStorage?.key(a) : t?.localStorage?.key;
223
+ y && D && (u = Te(`${D}-${I}-${y}`));
224
+ let E = a, w = !1;
225
+ const N = s ? Date.now() : 0, k = u?.lastUpdated || 0, x = u?.lastSyncedWithServer || 0;
226
+ s && N > k ? (E = t.serverState.data, w = !0) : u && k > x && (E = u.state, t?.localStorage?.onChange && t?.localStorage?.onChange(E)), r.getState().initializeShadowState(I, a), Ge(
227
+ I,
228
+ a,
229
+ E,
230
230
  ae,
231
- ee.current,
232
- L
233
- ), _ && E && L && Me(p, h, t, L, Date.now()), ve(h), (Array.isArray(w) ? w : [w || "component"]).includes("none") || G({});
231
+ te.current,
232
+ D
233
+ ), w && y && D && Me(E, I, t, D, Date.now()), ve(I), (Array.isArray(p) ? p : [p || "component"]).includes("none") || R({});
234
234
  }
235
235
  }, [
236
- s,
236
+ a,
237
237
  S?.status,
238
238
  S?.data,
239
239
  ...n || []
240
- ]), le(() => {
241
- B && be(h, {
240
+ ]), ce(() => {
241
+ W && be(I, {
242
242
  serverSync: m,
243
243
  formElements: T,
244
- initialState: s,
244
+ initialState: a,
245
245
  localStorage: g,
246
- middleware: P.current?.middleware
246
+ middleware: L.current?.middleware
247
247
  });
248
- const t = `${h}////${ee.current}`, r = o.getState().stateComponents.get(h) || {
248
+ const t = `${I}////${te.current}`, o = r.getState().stateComponents.get(I) || {
249
249
  components: /* @__PURE__ */ new Map()
250
250
  };
251
- return r.components.set(t, {
252
- forceUpdate: () => G({}),
251
+ return o.components.set(t, {
252
+ forceUpdate: () => R({}),
253
253
  paths: /* @__PURE__ */ new Set(),
254
254
  deps: [],
255
- depsFunction: O || void 0,
256
- reactiveType: w ?? ["component", "deps"]
257
- }), o.getState().stateComponents.set(h, r), G({}), () => {
258
- r && (r.components.delete(t), r.components.size === 0 && o.getState().stateComponents.delete(h));
255
+ depsFunction: C || void 0,
256
+ reactiveType: p ?? ["component", "deps"]
257
+ }), r.getState().stateComponents.set(I, o), R({}), () => {
258
+ o && (o.components.delete(t), o.components.size === 0 && r.getState().stateComponents.delete(I));
259
259
  };
260
260
  }, []);
261
- const ae = (t, r, a, c) => {
262
- if (Array.isArray(r)) {
263
- const u = `${h}-${r.join(".")}`;
264
- ue.current.add(u);
261
+ const ae = (t, o, s, c) => {
262
+ if (Array.isArray(o)) {
263
+ const u = `${I}-${o.join(".")}`;
264
+ de.current.add(u);
265
265
  }
266
- const f = o.getState();
267
- ne(h, (u) => {
268
- const E = K(t) ? t(u) : t, p = `${h}-${r.join(".")}`;
269
- if (p) {
270
- let x = !1, N = f.signalDomElements.get(p);
271
- if ((!N || N.size === 0) && (a.updateType === "insert" || a.updateType === "cut")) {
272
- const V = r.slice(0, -1), R = Z(E, V);
273
- if (Array.isArray(R)) {
274
- x = !0;
275
- const v = `${h}-${V.join(".")}`;
276
- N = f.signalDomElements.get(v);
266
+ const f = r.getState();
267
+ ne(I, (u) => {
268
+ const y = ee(t) ? t(u) : t, E = `${I}-${o.join(".")}`;
269
+ if (E) {
270
+ let P = !1, A = f.signalDomElements.get(E);
271
+ if ((!A || A.size === 0) && (s.updateType === "insert" || s.updateType === "cut")) {
272
+ const M = o.slice(0, -1), O = Y(y, M);
273
+ if (Array.isArray(O)) {
274
+ P = !0;
275
+ const _ = `${I}-${M.join(".")}`;
276
+ A = f.signalDomElements.get(_);
277
277
  }
278
278
  }
279
- if (N) {
280
- const V = x ? Z(E, r.slice(0, -1)) : Z(E, r);
281
- N.forEach(({ parentId: R, position: v, effect: D }) => {
282
- const $ = document.querySelector(
283
- `[data-parent-id="${R}"]`
279
+ if (A) {
280
+ const M = P ? Y(y, o.slice(0, -1)) : Y(y, o);
281
+ A.forEach(({ parentId: O, position: _, effect: b }) => {
282
+ const G = document.querySelector(
283
+ `[data-parent-id="${O}"]`
284
284
  );
285
- if ($) {
286
- const z = Array.from($.childNodes);
287
- if (z[v]) {
288
- const j = D ? new Function("state", `return (${D})(state)`)(V) : V;
289
- z[v].textContent = String(j);
285
+ if (G) {
286
+ const z = Array.from(G.childNodes);
287
+ if (z[_]) {
288
+ const U = b ? new Function("state", `return (${b})(state)`)(M) : M;
289
+ z[_].textContent = String(U);
290
290
  }
291
291
  }
292
292
  });
293
293
  }
294
294
  }
295
- console.log("shadowState", f.shadowStateStore), a.updateType === "update" && (c || P.current?.validation?.key) && r && X(
296
- (c || P.current?.validation?.key) + "." + r.join(".")
295
+ console.log("shadowState", f.shadowStateStore), s.updateType === "update" && (c || L.current?.validation?.key) && o && Q(
296
+ (c || L.current?.validation?.key) + "." + o.join(".")
297
297
  );
298
- const _ = r.slice(0, r.length - 1);
299
- a.updateType === "cut" && P.current?.validation?.key && X(
300
- P.current?.validation?.key + "." + _.join(".")
301
- ), a.updateType === "insert" && P.current?.validation?.key && Je(
302
- P.current?.validation?.key + "." + _.join(".")
303
- ).filter(([N, V]) => {
304
- let R = N?.split(".").length;
305
- if (N == _.join(".") && R == _.length - 1) {
306
- let v = N + "." + _;
307
- X(N), Ze(v, V);
298
+ const w = o.slice(0, o.length - 1);
299
+ s.updateType === "cut" && L.current?.validation?.key && Q(
300
+ L.current?.validation?.key + "." + w.join(".")
301
+ ), s.updateType === "insert" && L.current?.validation?.key && Je(
302
+ L.current?.validation?.key + "." + w.join(".")
303
+ ).filter(([A, M]) => {
304
+ let O = A?.split(".").length;
305
+ if (A == w.join(".") && O == w.length - 1) {
306
+ let _ = A + "." + w;
307
+ Q(A), Ze(_, M);
308
308
  }
309
309
  });
310
- const C = f.stateComponents.get(h);
311
- if (console.log("stateEntry >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>", C), C) {
312
- const x = _e(u, E), N = new Set(x), V = a.updateType === "update" ? r.join(".") : r.slice(0, -1).join(".") || "";
310
+ const N = f.stateComponents.get(I);
311
+ if (console.log("stateEntry >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>", N), N) {
312
+ const P = _e(u, y), A = new Set(P), M = s.updateType === "update" ? o.join(".") : o.slice(0, -1).join(".") || "";
313
313
  for (const [
314
- R,
315
- v
316
- ] of C.components.entries()) {
317
- let D = !1;
318
- const $ = Array.isArray(v.reactiveType) ? v.reactiveType : [v.reactiveType || "component"];
319
- if (console.log("component", v), !$.includes("none")) {
320
- if ($.includes("all")) {
321
- v.forceUpdate();
314
+ O,
315
+ _
316
+ ] of N.components.entries()) {
317
+ let b = !1;
318
+ const G = Array.isArray(_.reactiveType) ? _.reactiveType : [_.reactiveType || "component"];
319
+ if (console.log("component", _), !G.includes("none")) {
320
+ if (G.includes("all")) {
321
+ _.forceUpdate();
322
322
  continue;
323
323
  }
324
- if ($.includes("component") && ((v.paths.has(V) || v.paths.has("")) && (D = !0), !D))
325
- for (const z of N) {
326
- let j = z;
324
+ if (G.includes("component") && ((_.paths.has(M) || _.paths.has("")) && (b = !0), !b))
325
+ for (const z of A) {
326
+ let U = z;
327
327
  for (; ; ) {
328
- if (v.paths.has(j)) {
329
- D = !0;
328
+ if (_.paths.has(U)) {
329
+ b = !0;
330
330
  break;
331
331
  }
332
- const se = j.lastIndexOf(".");
332
+ const se = U.lastIndexOf(".");
333
333
  if (se !== -1) {
334
- const ge = j.substring(
334
+ const $ = U.substring(
335
335
  0,
336
336
  se
337
337
  );
338
338
  if (!isNaN(
339
- Number(j.substring(se + 1))
340
- ) && v.paths.has(ge)) {
341
- D = !0;
339
+ Number(U.substring(se + 1))
340
+ ) && _.paths.has($)) {
341
+ b = !0;
342
342
  break;
343
343
  }
344
- j = ge;
344
+ U = $;
345
345
  } else
346
- j = "";
347
- if (j === "")
346
+ U = "";
347
+ if (U === "")
348
348
  break;
349
349
  }
350
- if (D) break;
350
+ if (b) break;
351
351
  }
352
- if (!D && $.includes("deps") && v.depsFunction) {
353
- const z = v.depsFunction(E);
354
- let j = !1;
355
- typeof z == "boolean" ? z && (j = !0) : q(v.deps, z) || (v.deps = z, j = !0), j && (D = !0);
352
+ if (!b && G.includes("deps") && _.depsFunction) {
353
+ const z = _.depsFunction(y);
354
+ let U = !1;
355
+ typeof z == "boolean" ? z && (U = !0) : q(_.deps, z) || (_.deps = z, U = !0), U && (b = !0);
356
356
  }
357
- D && v.forceUpdate();
357
+ b && _.forceUpdate();
358
358
  }
359
359
  }
360
360
  }
361
- const A = Date.now();
362
- r = r.map((x, N) => {
363
- const V = r.slice(0, -1), R = Z(E, V);
364
- return N === r.length - 1 && ["insert", "cut"].includes(a.updateType) ? (R.length - 1).toString() : x;
361
+ const k = Date.now();
362
+ o = o.map((P, A) => {
363
+ const M = o.slice(0, -1), O = Y(y, M);
364
+ return A === o.length - 1 && ["insert", "cut"].includes(s.updateType) ? (O.length - 1).toString() : P;
365
365
  });
366
- const { oldValue: b, newValue: U } = Ke(
367
- a.updateType,
366
+ const { oldValue: x, newValue: j } = Ke(
367
+ s.updateType,
368
368
  u,
369
- E,
370
- r
371
- ), Y = {
372
- timeStamp: A,
373
- stateKey: h,
374
- path: r,
375
- updateType: a.updateType,
369
+ y,
370
+ o
371
+ ), Z = {
372
+ timeStamp: k,
373
+ stateKey: I,
374
+ path: o,
375
+ updateType: s.updateType,
376
376
  status: "new",
377
- oldValue: b,
378
- newValue: U
377
+ oldValue: x,
378
+ newValue: j
379
379
  };
380
- switch (a.updateType) {
380
+ switch (s.updateType) {
381
381
  case "update":
382
- f.updateShadowAtPath(h, r, E);
382
+ f.updateShadowAtPath(I, o, y);
383
383
  break;
384
384
  case "insert":
385
- const x = r.slice(0, -1);
386
- f.insertShadowArrayElement(h, x, U);
385
+ const P = o.slice(0, -1);
386
+ f.insertShadowArrayElement(I, P, j);
387
387
  break;
388
388
  case "cut":
389
- const N = r.slice(0, -1), V = parseInt(r[r.length - 1]);
390
- f.removeShadowArrayElement(h, N, V);
389
+ const A = o.slice(0, -1), M = parseInt(o[o.length - 1]);
390
+ f.removeShadowArrayElement(I, A, M);
391
391
  break;
392
392
  }
393
- if (Ye(h, (x) => {
394
- const V = [...x ?? [], Y].reduce((R, v) => {
395
- const D = `${v.stateKey}:${JSON.stringify(v.path)}`, $ = R.get(D);
396
- return $ ? ($.timeStamp = Math.max($.timeStamp, v.timeStamp), $.newValue = v.newValue, $.oldValue = $.oldValue ?? v.oldValue, $.updateType = v.updateType) : R.set(D, { ...v }), R;
393
+ if (Ye(I, (P) => {
394
+ const M = [...P ?? [], Z].reduce((O, _) => {
395
+ const b = `${_.stateKey}:${JSON.stringify(_.path)}`, G = O.get(b);
396
+ return G ? (G.timeStamp = Math.max(G.timeStamp, _.timeStamp), G.newValue = _.newValue, G.oldValue = G.oldValue ?? _.oldValue, G.updateType = _.updateType) : O.set(b, { ..._ }), O;
397
397
  }, /* @__PURE__ */ new Map());
398
- return Array.from(V.values());
398
+ return Array.from(M.values());
399
399
  }), Me(
400
- E,
401
- h,
402
- P.current,
403
- L
404
- ), P.current?.middleware && P.current.middleware({
400
+ y,
401
+ I,
402
+ L.current,
403
+ D
404
+ ), L.current?.middleware && L.current.middleware({
405
405
  updateLog: l,
406
- update: Y
407
- }), P.current?.serverSync) {
408
- const x = f.serverState[h], N = P.current?.serverSync;
409
- Xe(h, {
410
- syncKey: typeof N.syncKey == "string" ? N.syncKey : N.syncKey({ state: E }),
411
- rollBackState: x,
412
- actionTimeStamp: Date.now() + (N.debounce ?? 3e3),
406
+ update: Z
407
+ }), L.current?.serverSync) {
408
+ const P = f.serverState[I], A = L.current?.serverSync;
409
+ Xe(I, {
410
+ syncKey: typeof A.syncKey == "string" ? A.syncKey : A.syncKey({ state: y }),
411
+ rollBackState: P,
412
+ actionTimeStamp: Date.now() + (A.debounce ?? 3e3),
413
413
  status: "waiting"
414
414
  });
415
415
  }
416
- return E;
416
+ return y;
417
417
  });
418
418
  };
419
- o.getState().updaterState[h] || (he(
420
- h,
421
- Ie(
422
- h,
419
+ r.getState().updaterState[I] || (Ie(
420
+ I,
421
+ he(
422
+ I,
423
423
  ae,
424
- ee.current,
425
- L
424
+ te.current,
425
+ D
426
426
  )
427
- ), o.getState().cogsStateStore[h] || ne(h, e), o.getState().initialStateGlobal[h] || Oe(h, e));
428
- const d = Ee(() => Ie(
429
- h,
427
+ ), r.getState().cogsStateStore[I] || ne(I, e), r.getState().initialStateGlobal[I] || Ne(I, e));
428
+ const d = Oe(() => he(
429
+ I,
430
430
  ae,
431
- ee.current,
432
- L
433
- ), [h, L]);
434
- return [Ge(h), d];
431
+ te.current,
432
+ D
433
+ ), [I, D]);
434
+ return [Le(I), d];
435
435
  }
436
- function Ie(e, i, m, g) {
436
+ function he(e, i, m, g) {
437
437
  const T = /* @__PURE__ */ new Map();
438
- let O = 0;
439
- const w = (I) => {
440
- const n = I.join(".");
438
+ let C = 0;
439
+ const p = (h) => {
440
+ const n = h.join(".");
441
441
  for (const [S] of T)
442
442
  (S === n || S.startsWith(n + ".")) && T.delete(S);
443
- O++;
444
- }, y = {
445
- removeValidation: (I) => {
446
- I?.validationKey && X(I.validationKey);
443
+ C++;
444
+ }, v = {
445
+ removeValidation: (h) => {
446
+ h?.validationKey && Q(h.validationKey);
447
447
  },
448
- revertToInitialState: (I) => {
449
- const n = o.getState().getInitialOptions(e)?.validation;
450
- n?.key && X(n?.key), I?.validationKey && X(I.validationKey);
451
- const S = o.getState().initialStateGlobal[e];
452
- o.getState().clearSelectedIndexesForState(e), T.clear(), O++;
453
- const W = s(S, []), G = re(e), L = K(G?.localStorage?.key) ? G?.localStorage?.key(S) : G?.localStorage?.key, B = `${g}-${e}-${L}`;
454
- B && localStorage.removeItem(B), he(e, W), ne(e, S);
455
- const h = o.getState().stateComponents.get(e);
456
- return h && h.components.forEach((l) => {
448
+ revertToInitialState: (h) => {
449
+ const n = r.getState().getInitialOptions(e)?.validation;
450
+ n?.key && Q(n?.key), h?.validationKey && Q(h.validationKey);
451
+ const S = r.getState().initialStateGlobal[e];
452
+ r.getState().clearSelectedIndexesForState(e), T.clear(), C++;
453
+ const B = a(S, []), R = re(e), D = ee(R?.localStorage?.key) ? R?.localStorage?.key(S) : R?.localStorage?.key, W = `${g}-${e}-${D}`;
454
+ W && localStorage.removeItem(W), Ie(e, B), ne(e, S);
455
+ const I = r.getState().stateComponents.get(e);
456
+ return I && I.components.forEach((l) => {
457
457
  l.forceUpdate();
458
458
  }), S;
459
459
  },
460
- updateInitialState: (I) => {
461
- T.clear(), O++;
462
- const n = Ie(
460
+ updateInitialState: (h) => {
461
+ T.clear(), C++;
462
+ const n = he(
463
463
  e,
464
464
  i,
465
465
  m,
466
466
  g
467
- ), S = o.getState().initialStateGlobal[e], W = re(e), G = K(W?.localStorage?.key) ? W?.localStorage?.key(S) : W?.localStorage?.key, L = `${g}-${e}-${G}`;
468
- return localStorage.getItem(L) && localStorage.removeItem(L), Ue(() => {
469
- Oe(e, I), o.getState().initializeShadowState(e, I), he(e, n), ne(e, I);
470
- const B = o.getState().stateComponents.get(e);
471
- B && B.components.forEach((h) => {
472
- h.forceUpdate();
467
+ ), S = r.getState().initialStateGlobal[e], B = re(e), R = ee(B?.localStorage?.key) ? B?.localStorage?.key(S) : B?.localStorage?.key, D = `${g}-${e}-${R}`;
468
+ return localStorage.getItem(D) && localStorage.removeItem(D), Ue(() => {
469
+ Ne(e, h), r.getState().initializeShadowState(e, h), Ie(e, n), ne(e, h);
470
+ const W = r.getState().stateComponents.get(e);
471
+ W && W.components.forEach((I) => {
472
+ I.forceUpdate();
473
473
  });
474
474
  }), {
475
- fetchId: (B) => n.get()[B]
475
+ fetchId: (W) => n.get()[W]
476
476
  };
477
477
  },
478
- _initialState: o.getState().initialStateGlobal[e],
479
- _serverState: o.getState().serverState[e],
480
- _isLoading: o.getState().isLoadingGlobal[e],
478
+ _initialState: r.getState().initialStateGlobal[e],
479
+ _serverState: r.getState().serverState[e],
480
+ _isLoading: r.getState().isLoadingGlobal[e],
481
481
  _isServerSynced: () => {
482
- const I = o.getState().serverState[e];
483
- return !!(I && q(I, Ge(e)));
482
+ const h = r.getState().serverState[e];
483
+ return !!(h && q(h, Le(e)));
484
484
  }
485
485
  };
486
- function s(I, n = [], S) {
487
- const W = n.map(String).join(".");
488
- T.get(W);
489
- const G = function() {
490
- return o().getNestedState(e, n);
486
+ function a(h, n = [], S) {
487
+ const B = n.map(String).join(".");
488
+ T.get(B);
489
+ const R = function() {
490
+ return r().getNestedState(e, n);
491
491
  };
492
- Object.keys(y).forEach((h) => {
493
- G[h] = y[h];
492
+ Object.keys(v).forEach((I) => {
493
+ R[I] = v[I];
494
494
  });
495
- const L = {
496
- apply(h, l, ue) {
495
+ const D = {
496
+ apply(I, l, de) {
497
497
  return console.log(
498
498
  `PROXY APPLY TRAP HIT: stateKey=${e}, path=${n.join(".")}`
499
- ), console.trace("Apply trap stack trace"), o().getNestedState(e, n);
499
+ ), console.trace("Apply trap stack trace"), r().getNestedState(e, n);
500
500
  },
501
- get(h, l) {
502
- S?.validIndices && !Array.isArray(I) && (S = { ...S, validIndices: void 0 });
503
- const ue = /* @__PURE__ */ new Set([
501
+ get(I, l) {
502
+ S?.validIndices && !Array.isArray(h) && (S = { ...S, validIndices: void 0 });
503
+ const de = /* @__PURE__ */ new Set([
504
504
  "insert",
505
505
  "cut",
506
506
  "cutByValue",
@@ -523,41 +523,41 @@ function Ie(e, i, m, g) {
523
523
  "_stateKey",
524
524
  "getComponents"
525
525
  ]);
526
- if (l !== "then" && !l.startsWith("$") && l !== "stateMapNoRender" && !ue.has(l)) {
527
- const d = `${e}////${m}`, t = o.getState().stateComponents.get(e);
526
+ if (l !== "then" && !l.startsWith("$") && l !== "stateMapNoRender" && !de.has(l)) {
527
+ const d = `${e}////${m}`, t = r.getState().stateComponents.get(e);
528
528
  if (t) {
529
- const r = t.components.get(d);
530
- if (r && !r.paths.has("")) {
531
- const a = n.join(".");
529
+ const o = t.components.get(d);
530
+ if (o && !o.paths.has("")) {
531
+ const s = n.join(".");
532
532
  let c = !0;
533
- for (const f of r.paths)
534
- if (a.startsWith(f) && (a === f || a[f.length] === ".")) {
533
+ for (const f of o.paths)
534
+ if (s.startsWith(f) && (s === f || s[f.length] === ".")) {
535
535
  c = !1;
536
536
  break;
537
537
  }
538
- c && r.paths.add(a);
538
+ c && o.paths.add(s);
539
539
  }
540
540
  }
541
541
  }
542
542
  if (l === "getDifferences")
543
543
  return () => _e(
544
- o.getState().cogsStateStore[e],
545
- o.getState().initialStateGlobal[e]
544
+ r.getState().cogsStateStore[e],
545
+ r.getState().initialStateGlobal[e]
546
546
  );
547
547
  if (l === "sync" && n.length === 0)
548
548
  return async function() {
549
- const d = o.getState().getInitialOptions(e), t = d?.sync;
549
+ const d = r.getState().getInitialOptions(e), t = d?.sync;
550
550
  if (!t)
551
551
  return console.error(`No mutation defined for state key "${e}"`), { success: !1, error: "No mutation defined" };
552
- const r = o.getState().getNestedState(e, []), a = d?.validation?.key;
552
+ const o = r.getState().getNestedState(e, []), s = d?.validation?.key;
553
553
  try {
554
- const c = await t.action(r);
555
- if (c && !c.success && c.errors && a) {
556
- o.getState().removeValidationError(a), c.errors.forEach((u) => {
557
- const E = [a, ...u.path].join(".");
558
- o.getState().addValidationError(E, u.message);
554
+ const c = await t.action(o);
555
+ if (c && !c.success && c.errors && s) {
556
+ r.getState().removeValidationError(s), c.errors.forEach((u) => {
557
+ const y = [s, ...u.path].join(".");
558
+ r.getState().addValidationError(y, u.message);
559
559
  });
560
- const f = o.getState().stateComponents.get(e);
560
+ const f = r.getState().stateComponents.get(e);
561
561
  f && f.components.forEach((u) => {
562
562
  u.forceUpdate();
563
563
  });
@@ -568,310 +568,314 @@ function Ie(e, i, m, g) {
568
568
  }
569
569
  };
570
570
  if (l === "_status") {
571
- const d = o.getState().getNestedState(e, n), t = o.getState().initialStateGlobal[e], r = Z(t, n);
572
- return q(d, r) ? "fresh" : "stale";
571
+ const d = r.getState().getNestedState(e, n), t = r.getState().initialStateGlobal[e], o = Y(t, n);
572
+ return q(d, o) ? "fresh" : "stale";
573
573
  }
574
574
  if (l === "getStatus")
575
575
  return function() {
576
- const d = o().getNestedState(
576
+ const d = r().getNestedState(
577
577
  e,
578
578
  n
579
- ), t = o.getState().initialStateGlobal[e], r = Z(t, n);
580
- return q(d, r) ? "fresh" : "stale";
579
+ ), t = r.getState().initialStateGlobal[e], o = Y(t, n);
580
+ return q(d, o) ? "fresh" : "stale";
581
581
  };
582
582
  if (l === "removeStorage")
583
583
  return () => {
584
- const d = o.getState().initialStateGlobal[e], t = re(e), r = K(t?.localStorage?.key) ? t?.localStorage?.key(d) : t?.localStorage?.key, a = `${g}-${e}-${r}`;
585
- a && localStorage.removeItem(a);
584
+ const d = r.getState().initialStateGlobal[e], t = re(e), o = ee(t?.localStorage?.key) ? t?.localStorage?.key(d) : t?.localStorage?.key, s = `${g}-${e}-${o}`;
585
+ s && localStorage.removeItem(s);
586
586
  };
587
587
  if (l === "showValidationErrors")
588
588
  return () => {
589
- const d = o.getState().getInitialOptions(e)?.validation;
589
+ const d = r.getState().getInitialOptions(e)?.validation;
590
590
  if (!d?.key)
591
591
  throw new Error("Validation key not found");
592
- return o.getState().getValidationErrors(d.key + "." + n.join("."));
592
+ return r.getState().getValidationErrors(d.key + "." + n.join("."));
593
593
  };
594
- if (Array.isArray(I)) {
595
- const d = () => S?.validIndices ? I.map((r, a) => ({
596
- item: r,
597
- originalIndex: S.validIndices[a]
598
- })) : o.getState().getNestedState(e, n).map((r, a) => ({
599
- item: r,
600
- originalIndex: a
594
+ if (Array.isArray(h)) {
595
+ const d = () => S?.validIndices ? h.map((o, s) => ({
596
+ item: o,
597
+ originalIndex: S.validIndices[s]
598
+ })) : r.getState().getNestedState(e, n).map((o, s) => ({
599
+ item: o,
600
+ originalIndex: s
601
601
  }));
602
602
  if (l === "getSelected")
603
603
  return () => {
604
- const t = o.getState().getSelectedIndex(e, n.join("."));
604
+ const t = r.getState().getSelectedIndex(e, n.join("."));
605
605
  if (t !== void 0)
606
- return s(
607
- I[t],
606
+ return a(
607
+ h[t],
608
608
  [...n, t.toString()],
609
609
  S
610
610
  );
611
611
  };
612
612
  if (l === "clearSelected")
613
613
  return () => {
614
- o.getState().clearSelectedIndex({ stateKey: e, path: n });
614
+ r.getState().clearSelectedIndex({ stateKey: e, path: n });
615
615
  };
616
616
  if (l === "getSelectedIndex")
617
- return () => o.getState().getSelectedIndex(e, n.join(".")) ?? -1;
617
+ return () => r.getState().getSelectedIndex(e, n.join(".")) ?? -1;
618
618
  if (l === "useVirtualView")
619
619
  return (t) => {
620
620
  const {
621
- itemHeight: r = 50,
622
- overscan: a = 6,
621
+ itemHeight: o = 50,
622
+ overscan: s = 6,
623
623
  stickToBottom: c = !1,
624
624
  dependencies: f = []
625
- } = t, u = J(!1), E = J(null), [p, _] = Q({
625
+ } = t, u = J(null), [y, E] = K({
626
626
  startIndex: 0,
627
627
  endIndex: 10
628
- }), [C, A] = Q("IDLE_AT_TOP"), b = J(!1), U = J(0), Y = J(f), x = J(0), [N, V] = Q(0);
629
- oe(() => o.getState().subscribeToShadowState(e, () => {
630
- V((M) => M + 1);
628
+ }), [w, N] = K("IDLE_AT_TOP"), k = J(!1), x = J(0), j = J(f), [Z, P] = K(0), A = J(null);
629
+ oe(() => r.getState().subscribeToShadowState(e, () => {
630
+ P((V) => V + 1);
631
631
  }), [e]);
632
- const R = o().getNestedState(
632
+ const M = r().getNestedState(
633
633
  e,
634
634
  n
635
- ), v = R.length, { totalHeight: D, positions: $ } = Ee(() => {
636
- const k = o.getState().getShadowMetadata(e, n) || [];
637
- let M = 0;
635
+ ), O = M.length, { totalHeight: _, positions: b } = Oe(() => {
636
+ const $ = r.getState().getShadowMetadata(e, n) || [];
637
+ let V = 0;
638
638
  const H = [];
639
- for (let F = 0; F < v; F++) {
640
- H[F] = M;
641
- const te = k[F]?.virtualizer?.itemHeight;
642
- M += te || r;
639
+ for (let F = 0; F < O; F++) {
640
+ H[F] = V;
641
+ const X = $[F]?.virtualizer?.itemHeight;
642
+ V += X || o;
643
643
  }
644
- return { totalHeight: M, positions: H };
644
+ return { totalHeight: V, positions: H };
645
645
  }, [
646
- v,
646
+ O,
647
647
  e,
648
648
  n.join("."),
649
- r,
650
- N
651
- ]), z = Ee(() => {
652
- const k = Math.max(0, p.startIndex), M = Math.min(v, p.endIndex), H = Array.from(
653
- { length: M - k },
654
- (te, ie) => k + ie
655
- ), F = H.map((te) => R[te]);
656
- return s(F, n, {
649
+ o,
650
+ Z
651
+ ]), G = Oe(() => {
652
+ const $ = Math.max(0, y.startIndex), V = Math.min(O, y.endIndex), H = Array.from(
653
+ { length: V - $ },
654
+ (X, ue) => $ + ue
655
+ ), F = H.map((X) => M[X]);
656
+ return a(F, n, {
657
657
  ...S,
658
658
  validIndices: H
659
659
  });
660
- }, [p.startIndex, p.endIndex, R, v]);
661
- le(() => {
662
- const k = !q(
660
+ }, [y.startIndex, y.endIndex, M, O]);
661
+ ce(() => {
662
+ const $ = u.current;
663
+ if (!$) return;
664
+ const V = O > x.current;
665
+ !q(
663
666
  f,
664
- Y.current
665
- ), M = v > U.current;
666
- if (k) {
667
- console.log("TRANSITION: Deps changed -> IDLE_AT_TOP"), A("IDLE_AT_TOP");
668
- return;
669
- }
670
- M && C === "LOCKED_AT_BOTTOM" && c && (console.log(
667
+ j.current
668
+ ) ? (console.log(
669
+ "TRANSITION (Hard Reset): Deps changed -> IDLE_AT_TOP"
670
+ ), N("IDLE_AT_TOP"), $.scrollTo({ top: 0 })) : V && w === "LOCKED_AT_BOTTOM" && c ? (console.log(
671
671
  "TRANSITION: New items arrived while locked -> GETTING_HEIGHTS"
672
- ), A("GETTING_HEIGHTS")), U.current = v, Y.current = f;
673
- }, [v, ...f]), le(() => {
674
- const k = E.current;
675
- if (!k) return;
676
- let M;
677
- if (C === "IDLE_AT_TOP" && c && v > 0)
678
- console.log(
679
- "ACTION (IDLE_AT_TOP): Data has arrived -> GETTING_HEIGHTS"
680
- ), A("GETTING_HEIGHTS");
681
- else if (C === "GETTING_HEIGHTS")
672
+ ), N("GETTING_HEIGHTS")) : V && A.current && (console.log(
673
+ "ACTION: Maintaining scroll position after new items added."
674
+ ), $.scrollTop = A.current.scrollTop + ($.scrollHeight - A.current.scrollHeight)), x.current = O, j.current = f, A.current = null;
675
+ }, [O, ...f]), ce(() => {
676
+ const $ = u.current;
677
+ if (!$) return;
678
+ let V;
679
+ if (w === "IDLE_AT_TOP" && c && O > 0)
682
680
  console.log(
683
- "ACTION (GETTING_HEIGHTS): Setting range to end and starting loop."
684
- ), _({
685
- startIndex: Math.max(0, v - 10 - a),
686
- endIndex: v
687
- }), M = setInterval(() => {
688
- const H = v - 1;
689
- ((o.getState().getShadowMetadata(e, n) || [])[H]?.virtualizer?.itemHeight || 0) > 0 && (clearInterval(M), u.current || (console.log(
681
+ "ACTION (IDLE_AT_TOP): Data arrived -> GETTING_HEIGHTS"
682
+ ), N("GETTING_HEIGHTS");
683
+ else if (w === "GETTING_HEIGHTS")
684
+ console.log("ACTION (GETTING_HEIGHTS): Setting range to end"), E({
685
+ startIndex: Math.max(0, O - 10 - s),
686
+ endIndex: O
687
+ }), V = setInterval(() => {
688
+ const H = O - 1;
689
+ ((r.getState().getShadowMetadata(e, n) || [])[H]?.virtualizer?.itemHeight || 0) > 0 && (clearInterval(V), console.log(
690
690
  "ACTION (GETTING_HEIGHTS): Measurement success -> SCROLLING_TO_BOTTOM"
691
- ), A("SCROLLING_TO_BOTTOM")));
691
+ ), N("SCROLLING_TO_BOTTOM"));
692
692
  }, 100);
693
- else if (C === "SCROLLING_TO_BOTTOM") {
693
+ else if (w === "SCROLLING_TO_BOTTOM") {
694
694
  console.log(
695
695
  "ACTION (SCROLLING_TO_BOTTOM): Executing scroll."
696
- ), b.current = !0;
697
- const H = U.current === 0 ? "auto" : "smooth";
698
- k.scrollTo({
699
- top: k.scrollHeight,
696
+ ), k.current = !0;
697
+ const H = x.current === 0 ? "auto" : "smooth";
698
+ $.scrollTo({
699
+ top: $.scrollHeight,
700
700
  behavior: H
701
701
  });
702
702
  const F = setTimeout(
703
703
  () => {
704
- console.log(
705
- "ACTION (SCROLLING_TO_BOTTOM): Scroll finished -> LOCKED_AT_BOTTOM"
706
- ), b.current = !1, u.current = !1, A("LOCKED_AT_BOTTOM");
704
+ k.current = !1, N("LOCKED_AT_BOTTOM");
707
705
  },
708
706
  H === "smooth" ? 500 : 50
709
707
  );
710
708
  return () => clearTimeout(F);
711
709
  }
712
710
  return () => {
713
- M && clearInterval(M);
711
+ V && clearInterval(V);
714
712
  };
715
- }, [C, v, $]), oe(() => {
716
- const k = E.current;
717
- if (!k) return;
718
- const M = r, H = () => {
719
- if (b.current)
720
- return;
721
- const F = k.scrollTop;
722
- if (Math.abs(F - x.current) < M)
713
+ }, [w, O, b]), oe(() => {
714
+ const $ = u.current;
715
+ if (!$) return;
716
+ const V = 10, H = () => {
717
+ if (k.current)
723
718
  return;
724
- console.log(
725
- `Threshold passed at ${F}px. Recalculating range...`
726
- );
727
- const { clientHeight: te } = k;
728
- let ie = v - 1, ye = 0, Ne = 0;
729
- for (; ye <= ie; ) {
730
- const Se = Math.floor((ye + ie) / 2);
731
- $[Se] < F ? (Ne = Se, ye = Se + 1) : ie = Se - 1;
719
+ const { scrollTop: F, clientHeight: X, scrollHeight: ue } = $;
720
+ A.current = { scrollTop: F, scrollHeight: ue }, ue - F - X < V ? w !== "LOCKED_AT_BOTTOM" && (console.log(
721
+ "SCROLL EVENT: Reached bottom -> LOCKED_AT_BOTTOM"
722
+ ), N("LOCKED_AT_BOTTOM")) : w !== "IDLE_NOT_AT_BOTTOM" && (console.log(
723
+ "SCROLL EVENT: Scrolled up -> IDLE_NOT_AT_BOTTOM"
724
+ ), N("IDLE_NOT_AT_BOTTOM"));
725
+ let ye = O - 1, pe = 0, Ce = 0;
726
+ for (; pe <= ye; ) {
727
+ const Se = Math.floor((pe + ye) / 2);
728
+ b[Se] < F ? (Ce = Se, pe = Se + 1) : ye = Se - 1;
732
729
  }
733
- const Ce = Math.max(0, Ne - a);
734
- let fe = Ce;
735
- const Re = F + te;
736
- for (; fe < v && $[fe] < Re; )
730
+ const ge = Math.max(
731
+ 0,
732
+ Ce - s
733
+ );
734
+ if (ge === y.startIndex)
735
+ return;
736
+ let fe = ge;
737
+ const Re = F + X;
738
+ for (; fe < O && b[fe] < Re; )
737
739
  fe++;
738
- _({
739
- startIndex: Ce,
740
- endIndex: Math.min(v, fe + a)
741
- }), x.current = F;
740
+ console.log(
741
+ `Index changed from ${y.startIndex} to ${ge}. Updating range.`
742
+ ), E({
743
+ startIndex: ge,
744
+ endIndex: Math.min(O, fe + s)
745
+ });
742
746
  };
743
- return k.addEventListener("scroll", H, {
747
+ return $.addEventListener("scroll", H, {
744
748
  passive: !0
745
- }), () => k.removeEventListener("scroll", H);
746
- }, [v, $, r, a, C]);
747
- const j = $e(() => {
749
+ }), () => $.removeEventListener("scroll", H);
750
+ }, [O, b, w, y.startIndex]);
751
+ const z = $e(() => {
748
752
  console.log(
749
753
  "USER ACTION: Clicked scroll button -> SCROLLING_TO_BOTTOM"
750
- ), A("SCROLLING_TO_BOTTOM");
751
- }, []), se = $e(
752
- (k, M = "smooth") => {
753
- E.current && $[k] !== void 0 && (A("IDLE_NOT_AT_BOTTOM"), E.current.scrollTo({
754
- top: $[k],
755
- behavior: M
754
+ ), O !== 0 && N("SCROLLING_TO_BOTTOM");
755
+ }, [O]), U = $e(
756
+ ($, V = "smooth") => {
757
+ u.current && b[$] !== void 0 && (N("IDLE_NOT_AT_BOTTOM"), u.current.scrollTo({
758
+ top: b[$],
759
+ behavior: V
756
760
  }));
757
761
  },
758
- [$]
759
- ), ge = {
762
+ [b]
763
+ ), se = {
760
764
  outer: {
761
- ref: E,
765
+ ref: u,
762
766
  style: { overflowY: "auto", height: "100%" }
763
767
  },
764
768
  inner: {
765
769
  style: {
766
- height: `${D}px`,
770
+ height: `${_}px`,
767
771
  position: "relative"
768
772
  }
769
773
  },
770
774
  list: {
771
775
  style: {
772
- transform: `translateY(${$[p.startIndex] || 0}px)`
776
+ transform: `translateY(${b[y.startIndex] || 0}px)`
773
777
  }
774
778
  }
775
779
  };
776
780
  return {
777
- virtualState: z,
778
- virtualizerProps: ge,
779
- scrollToBottom: j,
780
- scrollToIndex: se
781
+ virtualState: G,
782
+ virtualizerProps: se,
783
+ scrollToBottom: z,
784
+ scrollToIndex: U
781
785
  };
782
786
  };
783
787
  if (l === "stateSort")
784
788
  return (t) => {
785
- const a = [...d()].sort(
786
- (u, E) => t(u.item, E.item)
787
- ), c = a.map(({ item: u }) => u), f = {
789
+ const s = [...d()].sort(
790
+ (u, y) => t(u.item, y.item)
791
+ ), c = s.map(({ item: u }) => u), f = {
788
792
  ...S,
789
- validIndices: a.map(
793
+ validIndices: s.map(
790
794
  ({ originalIndex: u }) => u
791
795
  )
792
796
  };
793
- return s(c, n, f);
797
+ return a(c, n, f);
794
798
  };
795
799
  if (l === "stateFilter")
796
800
  return (t) => {
797
- const a = d().filter(
798
- ({ item: u }, E) => t(u, E)
799
- ), c = a.map(({ item: u }) => u), f = {
801
+ const s = d().filter(
802
+ ({ item: u }, y) => t(u, y)
803
+ ), c = s.map(({ item: u }) => u), f = {
800
804
  ...S,
801
- validIndices: a.map(
805
+ validIndices: s.map(
802
806
  ({ originalIndex: u }) => u
803
807
  )
804
808
  };
805
- return s(c, n, f);
809
+ return a(c, n, f);
806
810
  };
807
811
  if (l === "stateMap")
808
812
  return (t) => {
809
- const r = o.getState().getNestedState(e, n);
810
- return Array.isArray(r) ? (S?.validIndices || Array.from({ length: r.length }, (c, f) => f)).map((c, f) => {
811
- const u = r[c], E = [...n, c.toString()], p = s(u, E, S);
812
- return t(u, p, {
813
+ const o = r.getState().getNestedState(e, n);
814
+ return Array.isArray(o) ? (S?.validIndices || Array.from({ length: o.length }, (c, f) => f)).map((c, f) => {
815
+ const u = o[c], y = [...n, c.toString()], E = a(u, y, S);
816
+ return t(u, E, {
813
817
  register: () => {
814
- const [, C] = Q({}), A = `${m}-${n.join(".")}-${c}`;
815
- le(() => {
816
- const b = `${e}////${A}`, U = o.getState().stateComponents.get(e) || {
818
+ const [, N] = K({}), k = `${m}-${n.join(".")}-${c}`;
819
+ ce(() => {
820
+ const x = `${e}////${k}`, j = r.getState().stateComponents.get(e) || {
817
821
  components: /* @__PURE__ */ new Map()
818
822
  };
819
- return U.components.set(b, {
820
- forceUpdate: () => C({}),
821
- paths: /* @__PURE__ */ new Set([E.join(".")])
822
- }), o.getState().stateComponents.set(e, U), () => {
823
- const Y = o.getState().stateComponents.get(e);
824
- Y && Y.components.delete(b);
823
+ return j.components.set(x, {
824
+ forceUpdate: () => N({}),
825
+ paths: /* @__PURE__ */ new Set([y.join(".")])
826
+ }), r.getState().stateComponents.set(e, j), () => {
827
+ const Z = r.getState().stateComponents.get(e);
828
+ Z && Z.components.delete(x);
825
829
  };
826
- }, [e, A]);
830
+ }, [e, k]);
827
831
  },
828
832
  index: f,
829
833
  originalIndex: c
830
834
  });
831
835
  }) : (console.warn(
832
836
  `stateMap called on a non-array value at path: ${n.join(".")}. The current value is:`,
833
- r
837
+ o
834
838
  ), null);
835
839
  };
836
840
  if (l === "stateMapNoRender")
837
- return (t) => I.map((a, c) => {
841
+ return (t) => h.map((s, c) => {
838
842
  let f;
839
843
  S?.validIndices && S.validIndices[c] !== void 0 ? f = S.validIndices[c] : f = c;
840
- const u = [...n, f.toString()], E = s(a, u, S);
844
+ const u = [...n, f.toString()], y = a(s, u, S);
841
845
  return t(
842
- a,
843
- E,
846
+ s,
847
+ y,
844
848
  c,
845
- I,
846
- s(I, n, S)
849
+ h,
850
+ a(h, n, S)
847
851
  );
848
852
  });
849
853
  if (l === "$stateMap")
850
- return (t) => de(tt, {
854
+ return (t) => le(tt, {
851
855
  proxy: {
852
856
  _stateKey: e,
853
857
  _path: n,
854
858
  _mapFn: t
855
859
  // Pass the actual function, not string
856
860
  },
857
- rebuildStateShape: s
861
+ rebuildStateShape: a
858
862
  });
859
863
  if (l === "stateList")
860
864
  return (t) => {
861
- const r = o.getState().getNestedState(e, n);
862
- return Array.isArray(r) ? (S?.validIndices || Array.from({ length: r.length }, (c, f) => f)).map((c, f) => {
863
- const u = r[c], E = [...n, c.toString()], p = s(u, E, S), _ = `${m}-${n.join(".")}-${c}`;
864
- return de(rt, {
865
+ const o = r.getState().getNestedState(e, n);
866
+ return Array.isArray(o) ? (S?.validIndices || Array.from({ length: o.length }, (c, f) => f)).map((c, f) => {
867
+ const u = o[c], y = [...n, c.toString()], E = a(u, y, S), w = `${m}-${n.join(".")}-${c}`;
868
+ return le(rt, {
865
869
  key: c,
866
870
  stateKey: e,
867
- itemComponentId: _,
868
- itemPath: E,
871
+ itemComponentId: w,
872
+ itemPath: y,
869
873
  children: t(
870
874
  u,
871
- p,
875
+ E,
872
876
  f,
873
- r,
874
- s(r, n, S)
877
+ o,
878
+ a(o, n, S)
875
879
  )
876
880
  });
877
881
  }) : (console.warn(
@@ -880,258 +884,258 @@ function Ie(e, i, m, g) {
880
884
  };
881
885
  if (l === "stateFlattenOn")
882
886
  return (t) => {
883
- const r = I;
884
- T.clear(), O++;
885
- const a = r.flatMap(
887
+ const o = h;
888
+ T.clear(), C++;
889
+ const s = o.flatMap(
886
890
  (c) => c[t] ?? []
887
891
  );
888
- return s(
889
- a,
892
+ return a(
893
+ s,
890
894
  [...n, "[*]", t],
891
895
  S
892
896
  );
893
897
  };
894
898
  if (l === "index")
895
899
  return (t) => {
896
- const r = I[t];
897
- return s(r, [...n, t.toString()]);
900
+ const o = h[t];
901
+ return a(o, [...n, t.toString()]);
898
902
  };
899
903
  if (l === "last")
900
904
  return () => {
901
- const t = o.getState().getNestedState(e, n);
905
+ const t = r.getState().getNestedState(e, n);
902
906
  if (t.length === 0) return;
903
- const r = t.length - 1, a = t[r], c = [...n, r.toString()];
904
- return s(a, c);
907
+ const o = t.length - 1, s = t[o], c = [...n, o.toString()];
908
+ return a(s, c);
905
909
  };
906
910
  if (l === "insert")
907
- return (t) => (w(n), pe(i, t, n, e), s(
908
- o.getState().getNestedState(e, n),
911
+ return (t) => (p(n), Ee(i, t, n, e), a(
912
+ r.getState().getNestedState(e, n),
909
913
  n
910
914
  ));
911
915
  if (l === "uniqueInsert")
912
- return (t, r, a) => {
913
- const c = o.getState().getNestedState(e, n), f = K(t) ? t(c) : t;
916
+ return (t, o, s) => {
917
+ const c = r.getState().getNestedState(e, n), f = ee(t) ? t(c) : t;
914
918
  let u = null;
915
- if (!c.some((p) => {
916
- if (r) {
917
- const C = r.every(
918
- (A) => q(p[A], f[A])
919
+ if (!c.some((E) => {
920
+ if (o) {
921
+ const N = o.every(
922
+ (k) => q(E[k], f[k])
919
923
  );
920
- return C && (u = p), C;
924
+ return N && (u = E), N;
921
925
  }
922
- const _ = q(p, f);
923
- return _ && (u = p), _;
926
+ const w = q(E, f);
927
+ return w && (u = E), w;
924
928
  }))
925
- w(n), pe(i, f, n, e);
926
- else if (a && u) {
927
- const p = a(u), _ = c.map(
928
- (C) => q(C, u) ? p : C
929
+ p(n), Ee(i, f, n, e);
930
+ else if (s && u) {
931
+ const E = s(u), w = c.map(
932
+ (N) => q(N, u) ? E : N
929
933
  );
930
- w(n), ce(i, _, n);
934
+ p(n), ie(i, w, n);
931
935
  }
932
936
  };
933
937
  if (l === "cut")
934
- return (t, r) => {
935
- if (!r?.waitForSync)
936
- return w(n), me(i, n, e, t), s(
937
- o.getState().getNestedState(e, n),
938
+ return (t, o) => {
939
+ if (!o?.waitForSync)
940
+ return p(n), me(i, n, e, t), a(
941
+ r.getState().getNestedState(e, n),
938
942
  n
939
943
  );
940
944
  };
941
945
  if (l === "cutByValue")
942
946
  return (t) => {
943
- for (let r = 0; r < I.length; r++)
944
- I[r] === t && me(i, n, e, r);
947
+ for (let o = 0; o < h.length; o++)
948
+ h[o] === t && me(i, n, e, o);
945
949
  };
946
950
  if (l === "toggleByValue")
947
951
  return (t) => {
948
- const r = I.findIndex((a) => a === t);
949
- r > -1 ? me(i, n, e, r) : pe(i, t, n, e);
952
+ const o = h.findIndex((s) => s === t);
953
+ o > -1 ? me(i, n, e, o) : Ee(i, t, n, e);
950
954
  };
951
955
  if (l === "stateFind")
952
956
  return (t) => {
953
- const a = d().find(
957
+ const s = d().find(
954
958
  ({ item: f }, u) => t(f, u)
955
959
  );
956
- if (!a) return;
957
- const c = [...n, a.originalIndex.toString()];
958
- return s(a.item, c, S);
960
+ if (!s) return;
961
+ const c = [...n, s.originalIndex.toString()];
962
+ return a(s.item, c, S);
959
963
  };
960
964
  if (l === "findWith")
961
- return (t, r) => {
965
+ return (t, o) => {
962
966
  const c = d().find(
963
- ({ item: u }) => u[t] === r
967
+ ({ item: u }) => u[t] === o
964
968
  );
965
969
  if (!c) return;
966
970
  const f = [...n, c.originalIndex.toString()];
967
- return s(c.item, f, S);
971
+ return a(c.item, f, S);
968
972
  };
969
973
  }
970
- const ee = n[n.length - 1];
971
- if (!isNaN(Number(ee))) {
972
- const d = n.slice(0, -1), t = o.getState().getNestedState(e, d);
974
+ const te = n[n.length - 1];
975
+ if (!isNaN(Number(te))) {
976
+ const d = n.slice(0, -1), t = r.getState().getNestedState(e, d);
973
977
  if (Array.isArray(t) && l === "cut")
974
978
  return () => me(
975
979
  i,
976
980
  d,
977
981
  e,
978
- Number(ee)
982
+ Number(te)
979
983
  );
980
984
  }
981
985
  if (l === "get")
982
986
  return () => {
983
- if (S?.validIndices && Array.isArray(I)) {
984
- const d = o.getState().getNestedState(e, n);
987
+ if (S?.validIndices && Array.isArray(h)) {
988
+ const d = r.getState().getNestedState(e, n);
985
989
  return S.validIndices.map((t) => d[t]);
986
990
  }
987
- return o.getState().getNestedState(e, n);
991
+ return r.getState().getNestedState(e, n);
988
992
  };
989
993
  if (l === "$derive")
990
- return (d) => Pe({
994
+ return (d) => Ve({
991
995
  _stateKey: e,
992
996
  _path: n,
993
997
  _effect: d.toString()
994
998
  });
995
999
  if (l === "$get")
996
- return () => Pe({
1000
+ return () => Ve({
997
1001
  _stateKey: e,
998
1002
  _path: n
999
1003
  });
1000
1004
  if (l === "lastSynced") {
1001
1005
  const d = `${e}:${n.join(".")}`;
1002
- return o.getState().getSyncInfo(d);
1006
+ return r.getState().getSyncInfo(d);
1003
1007
  }
1004
1008
  if (l == "getLocalStorage")
1005
1009
  return (d) => Te(g + "-" + e + "-" + d);
1006
1010
  if (l === "_selected") {
1007
- const d = n.slice(0, -1), t = d.join("."), r = o.getState().getNestedState(e, d);
1008
- return Array.isArray(r) ? Number(n[n.length - 1]) === o.getState().getSelectedIndex(e, t) : void 0;
1011
+ const d = n.slice(0, -1), t = d.join("."), o = r.getState().getNestedState(e, d);
1012
+ return Array.isArray(o) ? Number(n[n.length - 1]) === r.getState().getSelectedIndex(e, t) : void 0;
1009
1013
  }
1010
1014
  if (l === "setSelected")
1011
1015
  return (d) => {
1012
- const t = n.slice(0, -1), r = Number(n[n.length - 1]), a = t.join(".");
1013
- d ? o.getState().setSelectedIndex(e, a, r) : o.getState().setSelectedIndex(e, a, void 0);
1014
- const c = o.getState().getNestedState(e, [...t]);
1015
- ce(i, c, t), w(t);
1016
+ const t = n.slice(0, -1), o = Number(n[n.length - 1]), s = t.join(".");
1017
+ d ? r.getState().setSelectedIndex(e, s, o) : r.getState().setSelectedIndex(e, s, void 0);
1018
+ const c = r.getState().getNestedState(e, [...t]);
1019
+ ie(i, c, t), p(t);
1016
1020
  };
1017
1021
  if (l === "toggleSelected")
1018
1022
  return () => {
1019
- const d = n.slice(0, -1), t = Number(n[n.length - 1]), r = d.join("."), a = o.getState().getSelectedIndex(e, r);
1020
- o.getState().setSelectedIndex(
1023
+ const d = n.slice(0, -1), t = Number(n[n.length - 1]), o = d.join("."), s = r.getState().getSelectedIndex(e, o);
1024
+ r.getState().setSelectedIndex(
1021
1025
  e,
1022
- r,
1023
- a === t ? void 0 : t
1026
+ o,
1027
+ s === t ? void 0 : t
1024
1028
  );
1025
- const c = o.getState().getNestedState(e, [...d]);
1026
- ce(i, c, d), w(d);
1029
+ const c = r.getState().getNestedState(e, [...d]);
1030
+ ie(i, c, d), p(d);
1027
1031
  };
1028
1032
  if (n.length == 0) {
1029
1033
  if (l === "applyJsonPatch")
1030
1034
  return (d) => {
1031
- const t = o.getState().cogsStateStore[e], a = ze(t, d).newDocument;
1032
- Le(
1035
+ const t = r.getState().cogsStateStore[e], s = ze(t, d).newDocument;
1036
+ Ge(
1033
1037
  e,
1034
- o.getState().initialStateGlobal[e],
1035
- a,
1038
+ r.getState().initialStateGlobal[e],
1039
+ s,
1036
1040
  i,
1037
1041
  m,
1038
1042
  g
1039
1043
  );
1040
- const c = o.getState().stateComponents.get(e);
1044
+ const c = r.getState().stateComponents.get(e);
1041
1045
  if (c) {
1042
- const f = _e(t, a), u = new Set(f);
1046
+ const f = _e(t, s), u = new Set(f);
1043
1047
  for (const [
1044
- E,
1045
- p
1048
+ y,
1049
+ E
1046
1050
  ] of c.components.entries()) {
1047
- let _ = !1;
1048
- const C = Array.isArray(p.reactiveType) ? p.reactiveType : [p.reactiveType || "component"];
1049
- if (!C.includes("none")) {
1050
- if (C.includes("all")) {
1051
- p.forceUpdate();
1051
+ let w = !1;
1052
+ const N = Array.isArray(E.reactiveType) ? E.reactiveType : [E.reactiveType || "component"];
1053
+ if (!N.includes("none")) {
1054
+ if (N.includes("all")) {
1055
+ E.forceUpdate();
1052
1056
  continue;
1053
1057
  }
1054
- if (C.includes("component") && (p.paths.has("") && (_ = !0), !_))
1055
- for (const A of u) {
1056
- if (p.paths.has(A)) {
1057
- _ = !0;
1058
+ if (N.includes("component") && (E.paths.has("") && (w = !0), !w))
1059
+ for (const k of u) {
1060
+ if (E.paths.has(k)) {
1061
+ w = !0;
1058
1062
  break;
1059
1063
  }
1060
- let b = A.lastIndexOf(".");
1061
- for (; b !== -1; ) {
1062
- const U = A.substring(0, b);
1063
- if (p.paths.has(U)) {
1064
- _ = !0;
1064
+ let x = k.lastIndexOf(".");
1065
+ for (; x !== -1; ) {
1066
+ const j = k.substring(0, x);
1067
+ if (E.paths.has(j)) {
1068
+ w = !0;
1065
1069
  break;
1066
1070
  }
1067
- const Y = A.substring(
1068
- b + 1
1071
+ const Z = k.substring(
1072
+ x + 1
1069
1073
  );
1070
- if (!isNaN(Number(Y))) {
1071
- const x = U.lastIndexOf(".");
1072
- if (x !== -1) {
1073
- const N = U.substring(
1074
+ if (!isNaN(Number(Z))) {
1075
+ const P = j.lastIndexOf(".");
1076
+ if (P !== -1) {
1077
+ const A = j.substring(
1074
1078
  0,
1075
- x
1079
+ P
1076
1080
  );
1077
- if (p.paths.has(N)) {
1078
- _ = !0;
1081
+ if (E.paths.has(A)) {
1082
+ w = !0;
1079
1083
  break;
1080
1084
  }
1081
1085
  }
1082
1086
  }
1083
- b = U.lastIndexOf(".");
1087
+ x = j.lastIndexOf(".");
1084
1088
  }
1085
- if (_) break;
1089
+ if (w) break;
1086
1090
  }
1087
- if (!_ && C.includes("deps") && p.depsFunction) {
1088
- const A = p.depsFunction(a);
1089
- let b = !1;
1090
- typeof A == "boolean" ? A && (b = !0) : q(p.deps, A) || (p.deps = A, b = !0), b && (_ = !0);
1091
+ if (!w && N.includes("deps") && E.depsFunction) {
1092
+ const k = E.depsFunction(s);
1093
+ let x = !1;
1094
+ typeof k == "boolean" ? k && (x = !0) : q(E.deps, k) || (E.deps = k, x = !0), x && (w = !0);
1091
1095
  }
1092
- _ && p.forceUpdate();
1096
+ w && E.forceUpdate();
1093
1097
  }
1094
1098
  }
1095
1099
  }
1096
1100
  };
1097
1101
  if (l === "validateZodSchema")
1098
1102
  return () => {
1099
- const d = o.getState().getInitialOptions(e)?.validation, t = o.getState().addValidationError;
1103
+ const d = r.getState().getInitialOptions(e)?.validation, t = r.getState().addValidationError;
1100
1104
  if (!d?.zodSchema)
1101
1105
  throw new Error("Zod schema not found");
1102
1106
  if (!d?.key)
1103
1107
  throw new Error("Validation key not found");
1104
- X(d.key);
1105
- const r = o.getState().cogsStateStore[e];
1108
+ Q(d.key);
1109
+ const o = r.getState().cogsStateStore[e];
1106
1110
  try {
1107
- const a = o.getState().getValidationErrors(d.key);
1108
- a && a.length > 0 && a.forEach(([f]) => {
1109
- f && f.startsWith(d.key) && X(f);
1111
+ const s = r.getState().getValidationErrors(d.key);
1112
+ s && s.length > 0 && s.forEach(([f]) => {
1113
+ f && f.startsWith(d.key) && Q(f);
1110
1114
  });
1111
- const c = d.zodSchema.safeParse(r);
1115
+ const c = d.zodSchema.safeParse(o);
1112
1116
  return c.success ? !0 : (c.error.errors.forEach((u) => {
1113
- const E = u.path, p = u.message, _ = [d.key, ...E].join(".");
1114
- t(_, p);
1117
+ const y = u.path, E = u.message, w = [d.key, ...y].join(".");
1118
+ t(w, E);
1115
1119
  }), ve(e), !1);
1116
- } catch (a) {
1117
- return console.error("Zod schema validation failed", a), !1;
1120
+ } catch (s) {
1121
+ return console.error("Zod schema validation failed", s), !1;
1118
1122
  }
1119
1123
  };
1120
1124
  if (l === "_componentId") return m;
1121
1125
  if (l === "getComponents")
1122
- return () => o().stateComponents.get(e);
1126
+ return () => r().stateComponents.get(e);
1123
1127
  if (l === "getAllFormRefs")
1124
1128
  return () => ke.getState().getFormRefsByStateKey(e);
1125
1129
  if (l === "_initialState")
1126
- return o.getState().initialStateGlobal[e];
1130
+ return r.getState().initialStateGlobal[e];
1127
1131
  if (l === "_serverState")
1128
- return o.getState().serverState[e];
1132
+ return r.getState().serverState[e];
1129
1133
  if (l === "_isLoading")
1130
- return o.getState().isLoadingGlobal[e];
1134
+ return r.getState().isLoadingGlobal[e];
1131
1135
  if (l === "revertToInitialState")
1132
- return y.revertToInitialState;
1133
- if (l === "updateInitialState") return y.updateInitialState;
1134
- if (l === "removeValidation") return y.removeValidation;
1136
+ return v.revertToInitialState;
1137
+ if (l === "updateInitialState") return v.updateInitialState;
1138
+ if (l === "removeValidation") return v.removeValidation;
1135
1139
  }
1136
1140
  if (l === "getFormRef")
1137
1141
  return () => ke.getState().getFormRef(e + "." + n.join("."));
@@ -1140,11 +1144,11 @@ function Ie(e, i, m, g) {
1140
1144
  children: d,
1141
1145
  hideMessage: t
1142
1146
  }) => /* @__PURE__ */ we(
1143
- He,
1147
+ Fe,
1144
1148
  {
1145
1149
  formOpts: t ? { validation: { message: "" } } : void 0,
1146
1150
  path: n,
1147
- validationKey: o.getState().getInitialOptions(e)?.validation?.key || "",
1151
+ validationKey: r.getState().getInitialOptions(e)?.validation?.key || "",
1148
1152
  stateKey: e,
1149
1153
  validIndices: S?.validIndices,
1150
1154
  children: d
@@ -1152,25 +1156,25 @@ function Ie(e, i, m, g) {
1152
1156
  );
1153
1157
  if (l === "_stateKey") return e;
1154
1158
  if (l === "_path") return n;
1155
- if (l === "_isServerSynced") return y._isServerSynced;
1159
+ if (l === "_isServerSynced") return v._isServerSynced;
1156
1160
  if (l === "update")
1157
1161
  return (d, t) => {
1158
1162
  if (t?.debounce)
1159
- Fe(() => {
1160
- ce(i, d, n, "");
1161
- const r = o.getState().getNestedState(e, n);
1162
- t?.afterUpdate && t.afterUpdate(r);
1163
+ He(() => {
1164
+ ie(i, d, n, "");
1165
+ const o = r.getState().getNestedState(e, n);
1166
+ t?.afterUpdate && t.afterUpdate(o);
1163
1167
  }, t.debounce);
1164
1168
  else {
1165
- ce(i, d, n, "");
1166
- const r = o.getState().getNestedState(e, n);
1167
- t?.afterUpdate && t.afterUpdate(r);
1169
+ ie(i, d, n, "");
1170
+ const o = r.getState().getNestedState(e, n);
1171
+ t?.afterUpdate && t.afterUpdate(o);
1168
1172
  }
1169
- w(n);
1173
+ p(n);
1170
1174
  };
1171
1175
  if (l === "formElement")
1172
1176
  return (d, t) => /* @__PURE__ */ we(
1173
- We,
1177
+ Be,
1174
1178
  {
1175
1179
  setState: i,
1176
1180
  stateKey: e,
@@ -1179,32 +1183,32 @@ function Ie(e, i, m, g) {
1179
1183
  formOpts: t
1180
1184
  }
1181
1185
  );
1182
- const P = [...n, l], ae = o.getState().getNestedState(e, P);
1183
- return s(ae, P, S);
1186
+ const L = [...n, l], ae = r.getState().getNestedState(e, L);
1187
+ return a(ae, L, S);
1184
1188
  }
1185
- }, B = new Proxy(G, L);
1186
- return T.set(W, {
1187
- proxy: B,
1188
- stateVersion: O
1189
- }), B;
1189
+ }, W = new Proxy(R, D);
1190
+ return T.set(B, {
1191
+ proxy: W,
1192
+ stateVersion: C
1193
+ }), W;
1190
1194
  }
1191
- return s(
1192
- o.getState().getNestedState(e, [])
1195
+ return a(
1196
+ r.getState().getNestedState(e, [])
1193
1197
  );
1194
1198
  }
1195
- function Pe(e) {
1196
- return de(nt, { proxy: e });
1199
+ function Ve(e) {
1200
+ return le(nt, { proxy: e });
1197
1201
  }
1198
1202
  function tt({
1199
1203
  proxy: e,
1200
1204
  rebuildStateShape: i
1201
1205
  }) {
1202
- const m = o().getNestedState(e._stateKey, e._path);
1206
+ const m = r().getNestedState(e._stateKey, e._path);
1203
1207
  return Array.isArray(m) ? i(
1204
1208
  m,
1205
1209
  e._path
1206
1210
  ).stateMapNoRender(
1207
- (T, O, w, y, s) => e._mapFn(T, O, w, y, s)
1211
+ (T, C, p, v, a) => e._mapFn(T, C, p, v, a)
1208
1212
  ) : null;
1209
1213
  }
1210
1214
  function nt({
@@ -1214,17 +1218,17 @@ function nt({
1214
1218
  return oe(() => {
1215
1219
  const g = i.current;
1216
1220
  if (!g || !g.parentElement) return;
1217
- const T = g.parentElement, w = Array.from(T.childNodes).indexOf(g);
1218
- let y = T.getAttribute("data-parent-id");
1219
- y || (y = `parent-${crypto.randomUUID()}`, T.setAttribute("data-parent-id", y));
1220
- const I = {
1221
+ const T = g.parentElement, p = Array.from(T.childNodes).indexOf(g);
1222
+ let v = T.getAttribute("data-parent-id");
1223
+ v || (v = `parent-${crypto.randomUUID()}`, T.setAttribute("data-parent-id", v));
1224
+ const h = {
1221
1225
  instanceId: `instance-${crypto.randomUUID()}`,
1222
- parentId: y,
1223
- position: w,
1226
+ parentId: v,
1227
+ position: p,
1224
1228
  effect: e._effect
1225
1229
  };
1226
- o.getState().addSignalElement(m, I);
1227
- const n = o.getState().getNestedState(e._stateKey, e._path);
1230
+ r.getState().addSignalElement(m, h);
1231
+ const n = r.getState().getNestedState(e._stateKey, e._path);
1228
1232
  let S;
1229
1233
  if (e._effect)
1230
1234
  try {
@@ -1232,24 +1236,24 @@ function nt({
1232
1236
  "state",
1233
1237
  `return (${e._effect})(state)`
1234
1238
  )(n);
1235
- } catch (G) {
1236
- console.error("Error evaluating effect function during mount:", G), S = n;
1239
+ } catch (R) {
1240
+ console.error("Error evaluating effect function during mount:", R), S = n;
1237
1241
  }
1238
1242
  else
1239
1243
  S = n;
1240
1244
  S !== null && typeof S == "object" && (S = JSON.stringify(S));
1241
- const W = document.createTextNode(String(S));
1242
- g.replaceWith(W);
1243
- }, [e._stateKey, e._path.join("."), e._effect]), de("span", {
1245
+ const B = document.createTextNode(String(S));
1246
+ g.replaceWith(B);
1247
+ }, [e._stateKey, e._path.join("."), e._effect]), le("span", {
1244
1248
  ref: i,
1245
1249
  style: { display: "none" },
1246
1250
  "data-signal-id": m
1247
1251
  });
1248
1252
  }
1249
- function Tt(e) {
1253
+ function vt(e) {
1250
1254
  const i = De(
1251
1255
  (m) => {
1252
- const g = o.getState().stateComponents.get(e._stateKey) || {
1256
+ const g = r.getState().stateComponents.get(e._stateKey) || {
1253
1257
  components: /* @__PURE__ */ new Map()
1254
1258
  };
1255
1259
  return g.components.set(e._stateKey, {
@@ -1257,9 +1261,9 @@ function Tt(e) {
1257
1261
  paths: /* @__PURE__ */ new Set([e._path.join(".")])
1258
1262
  }), () => g.components.delete(e._stateKey);
1259
1263
  },
1260
- () => o.getState().getNestedState(e._stateKey, e._path)
1264
+ () => r.getState().getNestedState(e._stateKey, e._path)
1261
1265
  );
1262
- return de("text", {}, String(i));
1266
+ return le("text", {}, String(i));
1263
1267
  }
1264
1268
  function rt({
1265
1269
  stateKey: e,
@@ -1267,32 +1271,32 @@ function rt({
1267
1271
  itemPath: m,
1268
1272
  children: g
1269
1273
  }) {
1270
- const [, T] = Q({}), [O, w] = qe(), y = J(null);
1274
+ const [, T] = K({}), [C, p] = qe(), v = J(null);
1271
1275
  return oe(() => {
1272
- w.height > 0 && w.height !== y.current && (y.current = w.height, o.getState().setShadowMetadata(e, m, {
1276
+ p.height > 0 && p.height !== v.current && (v.current = p.height, r.getState().setShadowMetadata(e, m, {
1273
1277
  virtualizer: {
1274
- itemHeight: w.height
1278
+ itemHeight: p.height
1275
1279
  }
1276
1280
  }));
1277
- }, [w.height, e, m]), le(() => {
1278
- const s = `${e}////${i}`, I = o.getState().stateComponents.get(e) || {
1281
+ }, [p.height, e, m]), ce(() => {
1282
+ const a = `${e}////${i}`, h = r.getState().stateComponents.get(e) || {
1279
1283
  components: /* @__PURE__ */ new Map()
1280
1284
  };
1281
- return I.components.set(s, {
1285
+ return h.components.set(a, {
1282
1286
  forceUpdate: () => T({}),
1283
1287
  paths: /* @__PURE__ */ new Set([m.join(".")])
1284
- }), o.getState().stateComponents.set(e, I), () => {
1285
- const n = o.getState().stateComponents.get(e);
1286
- n && n.components.delete(s);
1288
+ }), r.getState().stateComponents.set(e, h), () => {
1289
+ const n = r.getState().stateComponents.get(e);
1290
+ n && n.components.delete(a);
1287
1291
  };
1288
- }, [e, i, m.join(".")]), /* @__PURE__ */ we("div", { ref: O, children: g });
1292
+ }, [e, i, m.join(".")]), /* @__PURE__ */ we("div", { ref: C, children: g });
1289
1293
  }
1290
1294
  export {
1291
- Pe as $cogsSignal,
1292
- Tt as $cogsSignalStore,
1293
- mt as addStateOptions,
1295
+ Ve as $cogsSignal,
1296
+ vt as $cogsSignalStore,
1297
+ It as addStateOptions,
1294
1298
  ht as createCogsState,
1295
- It as notifyComponent,
1299
+ Tt as notifyComponent,
1296
1300
  et as useCogsStateFn
1297
1301
  };
1298
1302
  //# sourceMappingURL=CogsState.jsx.map