cogsbox-state 0.5.381 → 0.5.382

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
- 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";
2
+ import { jsx as pe } from "react/jsx-runtime";
3
+ import { useState as Q, useRef as Z, useEffect as oe, useLayoutEffect as ie, useMemo as Ee, createElement as ce, useSyncExternalStore as Re, startTransition as De, useCallback as Ce } from "react";
4
+ import { transformStateFunc as Ue, isDeepEqual as q, isFunction as K, getNestedValue as J, getDifferences as _e, debounce as je } from "./utility.js";
5
+ import { pushFunc as ye, updateFn as se, cutFunc as fe, ValidationWrapper as He, FormControlComponent as Fe } from "./Functions.jsx";
6
6
  import Be from "superjson";
7
- import { v4 as Ae } from "uuid";
7
+ import { v4 as we } from "uuid";
8
8
  import "zod";
9
- import { getGlobalStore as o, formRefStore as ke } from "./store.js";
9
+ import { getGlobalStore as r, formRefStore as $e } from "./store.js";
10
10
  import { useCogsConfig as Ve } from "./CogsStateClient.jsx";
11
- import { applyPatch as ze } from "fast-json-patch";
12
- import qe from "react-use-measure";
13
- function be(e, i) {
14
- const m = o.getState().getInitialOptions, g = o.getState().setInitialStateOptions, T = m(e) || {};
11
+ import { applyPatch as We } from "fast-json-patch";
12
+ import ze from "react-use-measure";
13
+ function ke(e, i) {
14
+ const m = r.getState().getInitialOptions, g = r.getState().setInitialStateOptions, T = m(e) || {};
15
15
  g(e, {
16
16
  ...T,
17
17
  ...i
@@ -22,95 +22,95 @@ 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 St(e, { formElements: i, validation: m }) {
34
34
  return { initialState: e, formElements: i, validation: m };
35
35
  }
36
- const ht = (e, i) => {
36
+ const mt = (e, i) => {
37
37
  let m = e;
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 = {
38
+ const [g, T] = Ue(m);
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] = Q(a?.componentId ?? we());
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, [F, L] = Ke(
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 L;
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 && Xe(v, a), he(v);
75
75
  }
76
- return { useCogsState: O, setCogsOptions: w };
76
+ return { useCogsState: C, setCogsOptions: p };
77
77
  }, {
78
- setUpdaterState: he,
78
+ setUpdaterState: Se,
79
79
  setState: ne,
80
80
  getInitialOptions: re,
81
- getKeyState: Ge,
82
- getValidationErrors: Je,
83
- setStateLog: Ye,
81
+ getKeyState: Pe,
82
+ getValidationErrors: qe,
83
+ setStateLog: Je,
84
84
  updateInitialStateGlobal: Oe,
85
- addValidationError: Ze,
85
+ addValidationError: Ye,
86
86
  removeValidationError: X,
87
- setServerSyncActions: Xe
88
- } = o.getState(), Me = (e, i, m, g, T) => {
87
+ setServerSyncActions: Ze
88
+ } = r.getState(), be = (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 = K(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 = Ie(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 = Be.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
- }, Te = (e) => {
113
+ }, Ie = (e) => {
114
114
  if (!e) return null;
115
115
  try {
116
116
  const i = window.localStorage.getItem(e);
@@ -118,30 +118,30 @@ const ht = (e, i) => {
118
118
  } catch (i) {
119
119
  return console.error("Error loading from localStorage:", i), null;
120
120
  }
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;
121
+ }, Xe = (e, i) => {
122
+ const m = r.getState().cogsStateStore[e], { sessionId: g } = Ve(), T = K(i?.localStorage?.key) ? i.localStorage.key(m) : i?.localStorage?.key;
123
123
  if (T && g) {
124
- const O = Te(
124
+ const C = Ie(
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), he(e), !0;
129
129
  }
130
130
  return !1;
131
- }, Le = (e, i, m, g, T, O) => {
132
- const w = {
131
+ }, Le = (e, i, m, g, T, C) => {
132
+ const p = {
133
133
  initialState: i,
134
- updaterState: Ie(
134
+ updaterState: me(
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);
143
- }, ve = (e) => {
144
- const i = o.getState().stateComponents.get(e);
142
+ Oe(e, p.initialState), Se(e, p.updaterState), ne(e, p.state);
143
+ }, he = (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) => {
@@ -150,29 +150,29 @@ const ht = (e, i) => {
150
150
  m.forEach((g) => g());
151
151
  });
152
152
  }, It = (e, i) => {
153
- const m = o.getState().stateComponents.get(e);
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"))
157
157
  return;
158
158
  T && T.forceUpdate();
159
159
  }
160
- }, Ke = (e, i, m, g) => {
160
+ }, Qe = (e, i, m, g) => {
161
161
  switch (e) {
162
162
  case "update":
163
163
  return {
164
- oldValue: Z(i, g),
165
- newValue: Z(m, g)
164
+ oldValue: J(i, g),
165
+ newValue: J(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: J(m, g)
172
172
  };
173
173
  case "cut":
174
174
  return {
175
- oldValue: Z(i, g),
175
+ oldValue: J(i, g),
176
176
  newValue: null
177
177
  // or undefined
178
178
  };
@@ -180,327 +180,327 @@ const ht = (e, i) => {
180
180
  return { oldValue: null, newValue: null };
181
181
  }
182
182
  };
183
- function et(e, {
183
+ function Ke(e, {
184
184
  stateKey: i,
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();
196
+ const [F, L] = Q({}), { sessionId: G } = Ve();
197
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(
198
+ const [I] = Q(i ?? we()), l = r.getState().stateLog[I], le = Z(/* @__PURE__ */ new Set()), ee = Z(v ?? we()), V = Z(
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
+ V.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
+ ke(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 = V.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 = K(t?.localStorage?.key) ? t?.localStorage?.key(a) : t?.localStorage?.key;
223
+ y && G && (u = Ie(`${G}-${I}-${y}`));
224
+ let E = a, w = !1;
225
+ const A = s ? Date.now() : 0, $ = u?.lastUpdated || 0, b = u?.lastSyncedWithServer || 0;
226
+ s && A > $ ? (E = t.serverState.data, w = !0) : u && $ > b && (E = u.state, t?.localStorage?.onChange && t?.localStorage?.onChange(E)), r.getState().initializeShadowState(I, a), Le(
227
+ I,
228
+ a,
229
+ E,
230
230
  ae,
231
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({});
232
+ G
233
+ ), w && y && G && be(E, I, t, G, Date.now()), he(I), (Array.isArray(p) ? p : [p || "component"]).includes("none") || L({});
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
+ ]), ie(() => {
241
+ B && ke(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: V.current?.middleware
247
247
  });
248
- const t = `${h}////${ee.current}`, r = o.getState().stateComponents.get(h) || {
248
+ const t = `${I}////${ee.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: () => L({}),
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), L({}), () => {
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
+ le.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 = K(t) ? t(u) : t, E = `${I}-${o.join(".")}`;
269
+ if (E) {
270
+ let M = !1, N = f.signalDomElements.get(E);
271
+ if ((!N || N.size === 0) && (s.updateType === "insert" || s.updateType === "cut")) {
272
+ const O = o.slice(0, -1), j = J(y, O);
273
+ if (Array.isArray(j)) {
274
+ M = !0;
275
+ const _ = `${I}-${O.join(".")}`;
276
+ N = f.signalDomElements.get(_);
277
277
  }
278
278
  }
279
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}"]`
280
+ const O = M ? J(y, o.slice(0, -1)) : J(y, o);
281
+ N.forEach(({ parentId: j, position: _, effect: R }) => {
282
+ const P = document.querySelector(
283
+ `[data-parent-id="${j}"]`
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 (P) {
286
+ const z = Array.from(P.childNodes);
287
+ if (z[_]) {
288
+ const D = R ? new Function("state", `return (${R})(state)`)(O) : O;
289
+ z[_].textContent = String(D);
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 || V.current?.validation?.key) && o && X(
296
+ (c || V.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" && V.current?.validation?.key && X(
300
+ V.current?.validation?.key + "." + w.join(".")
301
+ ), s.updateType === "insert" && V.current?.validation?.key && qe(
302
+ V.current?.validation?.key + "." + w.join(".")
303
+ ).filter(([N, O]) => {
304
+ let j = N?.split(".").length;
305
+ if (N == w.join(".") && j == w.length - 1) {
306
+ let _ = N + "." + w;
307
+ X(N), Ye(_, O);
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 A = f.stateComponents.get(I);
311
+ if (console.log("stateEntry >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>", A), A) {
312
+ const M = _e(u, y), N = new Set(M), O = 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
+ j,
315
+ _
316
+ ] of A.components.entries()) {
317
+ let R = !1;
318
+ const P = Array.isArray(_.reactiveType) ? _.reactiveType : [_.reactiveType || "component"];
319
+ if (console.log("component", _), !P.includes("none")) {
320
+ if (P.includes("all")) {
321
+ _.forceUpdate();
322
322
  continue;
323
323
  }
324
- if ($.includes("component") && ((v.paths.has(V) || v.paths.has("")) && (D = !0), !D))
324
+ if (P.includes("component") && ((_.paths.has(O) || _.paths.has("")) && (R = !0), !R))
325
325
  for (const z of N) {
326
- let j = z;
326
+ let D = z;
327
327
  for (; ; ) {
328
- if (v.paths.has(j)) {
329
- D = !0;
328
+ if (_.paths.has(D)) {
329
+ R = !0;
330
330
  break;
331
331
  }
332
- const se = j.lastIndexOf(".");
333
- if (se !== -1) {
334
- const ge = j.substring(
332
+ const k = D.lastIndexOf(".");
333
+ if (k !== -1) {
334
+ const x = D.substring(
335
335
  0,
336
- se
336
+ k
337
337
  );
338
338
  if (!isNaN(
339
- Number(j.substring(se + 1))
340
- ) && v.paths.has(ge)) {
341
- D = !0;
339
+ Number(D.substring(k + 1))
340
+ ) && _.paths.has(x)) {
341
+ R = !0;
342
342
  break;
343
343
  }
344
- j = ge;
344
+ D = x;
345
345
  } else
346
- j = "";
347
- if (j === "")
346
+ D = "";
347
+ if (D === "")
348
348
  break;
349
349
  }
350
- if (D) break;
350
+ if (R) 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 (!R && P.includes("deps") && _.depsFunction) {
353
+ const z = _.depsFunction(y);
354
+ let D = !1;
355
+ typeof z == "boolean" ? z && (D = !0) : q(_.deps, z) || (_.deps = z, D = !0), D && (R = !0);
356
356
  }
357
- D && v.forceUpdate();
357
+ R && _.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 $ = Date.now();
362
+ o = o.map((M, N) => {
363
+ const O = o.slice(0, -1), j = J(y, O);
364
+ return N === o.length - 1 && ["insert", "cut"].includes(s.updateType) ? (j.length - 1).toString() : M;
365
365
  });
366
- const { oldValue: b, newValue: U } = Ke(
367
- a.updateType,
366
+ const { oldValue: b, newValue: U } = Qe(
367
+ s.updateType,
368
368
  u,
369
- E,
370
- r
369
+ y,
370
+ o
371
371
  ), Y = {
372
- timeStamp: A,
373
- stateKey: h,
374
- path: r,
375
- updateType: a.updateType,
372
+ timeStamp: $,
373
+ stateKey: I,
374
+ path: o,
375
+ updateType: s.updateType,
376
376
  status: "new",
377
377
  oldValue: b,
378
378
  newValue: U
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 M = o.slice(0, -1);
386
+ f.insertShadowArrayElement(I, M, U);
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 N = o.slice(0, -1), O = parseInt(o[o.length - 1]);
390
+ f.removeShadowArrayElement(I, N, O);
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 (Je(I, (M) => {
394
+ const O = [...M ?? [], Y].reduce((j, _) => {
395
+ const R = `${_.stateKey}:${JSON.stringify(_.path)}`, P = j.get(R);
396
+ return P ? (P.timeStamp = Math.max(P.timeStamp, _.timeStamp), P.newValue = _.newValue, P.oldValue = P.oldValue ?? _.oldValue, P.updateType = _.updateType) : j.set(R, { ..._ }), j;
397
397
  }, /* @__PURE__ */ new Map());
398
- return Array.from(V.values());
399
- }), Me(
400
- E,
401
- h,
402
- P.current,
403
- L
404
- ), P.current?.middleware && P.current.middleware({
398
+ return Array.from(O.values());
399
+ }), be(
400
+ y,
401
+ I,
402
+ V.current,
403
+ G
404
+ ), V.current?.middleware && V.current.middleware({
405
405
  updateLog: l,
406
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,
407
+ }), V.current?.serverSync) {
408
+ const M = f.serverState[I], N = V.current?.serverSync;
409
+ Ze(I, {
410
+ syncKey: typeof N.syncKey == "string" ? N.syncKey : N.syncKey({ state: y }),
411
+ rollBackState: M,
412
412
  actionTimeStamp: Date.now() + (N.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] || (Se(
420
+ I,
421
+ me(
422
+ I,
423
423
  ae,
424
424
  ee.current,
425
- L
425
+ G
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] || Oe(I, e));
428
+ const d = Ee(() => me(
429
+ I,
430
430
  ae,
431
431
  ee.current,
432
- L
433
- ), [h, L]);
434
- return [Ge(h), d];
432
+ G
433
+ ), [I, G]);
434
+ return [Pe(I), d];
435
435
  }
436
- function Ie(e, i, m, g) {
436
+ function me(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 && X(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 && X(n?.key), h?.validationKey && X(h.validationKey);
451
+ const S = r.getState().initialStateGlobal[e];
452
+ r.getState().clearSelectedIndexesForState(e), T.clear(), C++;
453
+ const F = a(S, []), L = re(e), G = K(L?.localStorage?.key) ? L?.localStorage?.key(S) : L?.localStorage?.key, B = `${g}-${e}-${G}`;
454
+ B && localStorage.removeItem(B), Se(e, F), 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 = me(
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], F = re(e), L = K(F?.localStorage?.key) ? F?.localStorage?.key(S) : F?.localStorage?.key, G = `${g}-${e}-${L}`;
468
+ return localStorage.getItem(G) && localStorage.removeItem(G), De(() => {
469
+ Oe(e, h), r.getState().initializeShadowState(e, h), Se(e, n), ne(e, h);
470
+ const B = r.getState().stateComponents.get(e);
471
+ B && B.components.forEach((I) => {
472
+ I.forceUpdate();
473
473
  });
474
474
  }), {
475
475
  fetchId: (B) => n.get()[B]
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, Pe(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 F = n.map(String).join(".");
488
+ T.get(F);
489
+ const L = 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
+ L[I] = v[I];
494
494
  });
495
- const L = {
496
- apply(h, l, ue) {
495
+ const G = {
496
+ apply(I, l, le) {
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 le = /* @__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" && !le.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,312 @@ 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 = J(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 = J(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 = K(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 = Z(null), [y, E] = Q({
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, A] = Q("IDLE_AT_TOP"), $ = Z(!1), b = Z(0), U = Z(f), [Y, M] = Q(0);
629
+ oe(() => r.getState().subscribeToShadowState(e, () => {
630
+ M((x) => x + 1);
631
631
  }), [e]);
632
- const R = o().getNestedState(
632
+ const N = 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 = N.length, { totalHeight: j, positions: _ } = Ee(() => {
636
+ const k = r.getState().getShadowMetadata(e, n) || [];
637
+ let x = 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 W = 0; W < O; W++) {
640
+ H[W] = x;
641
+ const te = k[W]?.virtualizer?.itemHeight;
642
+ x += te || o;
643
643
  }
644
- return { totalHeight: M, positions: H };
644
+ return { totalHeight: x, 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
+ Y
651
+ ]), R = Ee(() => {
652
+ const k = Math.max(0, y.startIndex), x = Math.min(O, y.endIndex), H = Array.from(
653
+ { length: x - k },
654
+ (te, Ae) => k + Ae
655
+ ), W = H.map((te) => N[te]);
656
+ return a(W, n, {
657
657
  ...S,
658
658
  validIndices: H
659
659
  });
660
- }, [p.startIndex, p.endIndex, R, v]);
661
- le(() => {
660
+ }, [y.startIndex, y.endIndex, N, O]);
661
+ ie(() => {
662
662
  const k = !q(
663
663
  f,
664
- Y.current
665
- ), M = v > U.current;
664
+ U.current
665
+ ), x = O > b.current;
666
666
  if (k) {
667
667
  console.log("TRANSITION: Deps changed -> IDLE_AT_TOP"), A("IDLE_AT_TOP");
668
668
  return;
669
669
  }
670
- M && C === "LOCKED_AT_BOTTOM" && c && (console.log(
670
+ x && 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;
672
+ ), A("GETTING_HEIGHTS")), b.current = O, U.current = f;
673
+ }, [O, ...f]), ie(() => {
674
+ const k = u.current;
675
675
  if (!k) return;
676
- let M;
677
- if (C === "IDLE_AT_TOP" && c && v > 0)
676
+ let x;
677
+ if (w === "IDLE_AT_TOP" && c && O > 0)
678
678
  console.log(
679
- "ACTION (IDLE_AT_TOP): Data has arrived -> GETTING_HEIGHTS"
679
+ "ACTION (IDLE_AT_TOP): Data arrived -> GETTING_HEIGHTS"
680
680
  ), A("GETTING_HEIGHTS");
681
- else if (C === "GETTING_HEIGHTS")
682
- 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
+ else if (w === "GETTING_HEIGHTS")
682
+ console.log("ACTION (GETTING_HEIGHTS): Setting range to end"), E({
683
+ startIndex: Math.max(0, O - 10 - s),
684
+ endIndex: O
685
+ }), x = setInterval(() => {
686
+ const H = O - 1;
687
+ ((r.getState().getShadowMetadata(e, n) || [])[H]?.virtualizer?.itemHeight || 0) > 0 && (clearInterval(x), console.log(
690
688
  "ACTION (GETTING_HEIGHTS): Measurement success -> SCROLLING_TO_BOTTOM"
691
- ), A("SCROLLING_TO_BOTTOM")));
689
+ ), A("SCROLLING_TO_BOTTOM"));
692
690
  }, 100);
693
- else if (C === "SCROLLING_TO_BOTTOM") {
691
+ else if (w === "SCROLLING_TO_BOTTOM") {
694
692
  console.log(
695
693
  "ACTION (SCROLLING_TO_BOTTOM): Executing scroll."
696
- ), b.current = !0;
697
- const H = U.current === 0 ? "auto" : "smooth";
694
+ ), $.current = !0;
695
+ const H = b.current === 0 ? "auto" : "smooth";
698
696
  k.scrollTo({
699
697
  top: k.scrollHeight,
700
698
  behavior: H
701
699
  });
702
- const F = setTimeout(
700
+ const W = setTimeout(
703
701
  () => {
704
- console.log(
705
- "ACTION (SCROLLING_TO_BOTTOM): Scroll finished -> LOCKED_AT_BOTTOM"
706
- ), b.current = !1, u.current = !1, A("LOCKED_AT_BOTTOM");
702
+ $.current = !1, A("LOCKED_AT_BOTTOM");
707
703
  },
708
704
  H === "smooth" ? 500 : 50
709
705
  );
710
- return () => clearTimeout(F);
706
+ return () => clearTimeout(W);
711
707
  }
712
708
  return () => {
713
- M && clearInterval(M);
709
+ x && clearInterval(x);
714
710
  };
715
- }, [C, v, $]), oe(() => {
716
- const k = E.current;
711
+ }, [w, O, _]), oe(() => {
712
+ const k = u.current;
717
713
  if (!k) return;
718
- const M = r, H = () => {
719
- if (b.current)
714
+ const x = () => {
715
+ if ($.current)
720
716
  return;
721
- const F = k.scrollTop;
722
- if (Math.abs(F - x.current) < M)
717
+ const { scrollTop: H, clientHeight: W, scrollHeight: te } = k;
718
+ te - H - W < 1 ? w !== "LOCKED_AT_BOTTOM" && (console.log(
719
+ "SCROLL EVENT: Reached bottom -> LOCKED_AT_BOTTOM"
720
+ ), A("LOCKED_AT_BOTTOM")) : w !== "IDLE_NOT_AT_BOTTOM" && (console.log(
721
+ "SCROLL EVENT: Scrolled up -> IDLE_NOT_AT_BOTTOM"
722
+ ), A("IDLE_NOT_AT_BOTTOM"));
723
+ let Te = O - 1, ve = 0, Ne = 0;
724
+ for (; ve <= Te; ) {
725
+ const ge = Math.floor((ve + Te) / 2);
726
+ _[ge] < H ? (Ne = ge, ve = ge + 1) : Te = ge - 1;
727
+ }
728
+ const de = Math.max(
729
+ 0,
730
+ Ne - s
731
+ );
732
+ if (de === y.startIndex)
723
733
  return;
734
+ let ue = de;
735
+ const Ge = H + W;
736
+ for (; ue < O && _[ue] < Ge; )
737
+ ue++;
724
738
  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;
732
- }
733
- const Ce = Math.max(0, Ne - a);
734
- let fe = Ce;
735
- const Re = F + te;
736
- for (; fe < v && $[fe] < Re; )
737
- fe++;
738
- _({
739
- startIndex: Ce,
740
- endIndex: Math.min(v, fe + a)
741
- }), x.current = F;
739
+ `Index changed from ${y.startIndex} to ${de}. Updating range.`
740
+ ), E({
741
+ startIndex: de,
742
+ endIndex: Math.min(O, ue + s)
743
+ });
742
744
  };
743
- return k.addEventListener("scroll", H, {
745
+ return k.addEventListener("scroll", x, {
744
746
  passive: !0
745
- }), () => k.removeEventListener("scroll", H);
746
- }, [v, $, r, a, C]);
747
- const j = $e(() => {
747
+ }), () => k.removeEventListener("scroll", x);
748
+ }, [O, _, w, y.startIndex]);
749
+ const P = Ce(() => {
748
750
  console.log(
749
751
  "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
752
+ ), O !== 0 && A("SCROLLING_TO_BOTTOM");
753
+ }, [O]), z = Ce(
754
+ (k, x = "smooth") => {
755
+ u.current && _[k] !== void 0 && (A("IDLE_NOT_AT_BOTTOM"), u.current.scrollTo({
756
+ top: _[k],
757
+ behavior: x
756
758
  }));
757
759
  },
758
- [$]
759
- ), ge = {
760
+ [_]
761
+ ), D = {
760
762
  outer: {
761
- ref: E,
763
+ ref: u,
762
764
  style: { overflowY: "auto", height: "100%" }
763
765
  },
764
766
  inner: {
765
767
  style: {
766
- height: `${D}px`,
768
+ height: `${j}px`,
767
769
  position: "relative"
768
770
  }
769
771
  },
770
772
  list: {
771
773
  style: {
772
- transform: `translateY(${$[p.startIndex] || 0}px)`
774
+ transform: `translateY(${_[y.startIndex] || 0}px)`
773
775
  }
774
776
  }
775
777
  };
776
778
  return {
777
- virtualState: z,
778
- virtualizerProps: ge,
779
- scrollToBottom: j,
780
- scrollToIndex: se
779
+ virtualState: R,
780
+ virtualizerProps: D,
781
+ scrollToBottom: P,
782
+ scrollToIndex: z
781
783
  };
782
784
  };
783
785
  if (l === "stateSort")
784
786
  return (t) => {
785
- const a = [...d()].sort(
786
- (u, E) => t(u.item, E.item)
787
- ), c = a.map(({ item: u }) => u), f = {
787
+ const s = [...d()].sort(
788
+ (u, y) => t(u.item, y.item)
789
+ ), c = s.map(({ item: u }) => u), f = {
788
790
  ...S,
789
- validIndices: a.map(
791
+ validIndices: s.map(
790
792
  ({ originalIndex: u }) => u
791
793
  )
792
794
  };
793
- return s(c, n, f);
795
+ return a(c, n, f);
794
796
  };
795
797
  if (l === "stateFilter")
796
798
  return (t) => {
797
- const a = d().filter(
798
- ({ item: u }, E) => t(u, E)
799
- ), c = a.map(({ item: u }) => u), f = {
799
+ const s = d().filter(
800
+ ({ item: u }, y) => t(u, y)
801
+ ), c = s.map(({ item: u }) => u), f = {
800
802
  ...S,
801
- validIndices: a.map(
803
+ validIndices: s.map(
802
804
  ({ originalIndex: u }) => u
803
805
  )
804
806
  };
805
- return s(c, n, f);
807
+ return a(c, n, f);
806
808
  };
807
809
  if (l === "stateMap")
808
810
  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, {
811
+ const o = r.getState().getNestedState(e, n);
812
+ return Array.isArray(o) ? (S?.validIndices || Array.from({ length: o.length }, (c, f) => f)).map((c, f) => {
813
+ const u = o[c], y = [...n, c.toString()], E = a(u, y, S);
814
+ return t(u, E, {
813
815
  register: () => {
814
- const [, C] = Q({}), A = `${m}-${n.join(".")}-${c}`;
815
- le(() => {
816
- const b = `${e}////${A}`, U = o.getState().stateComponents.get(e) || {
816
+ const [, A] = Q({}), $ = `${m}-${n.join(".")}-${c}`;
817
+ ie(() => {
818
+ const b = `${e}////${$}`, U = r.getState().stateComponents.get(e) || {
817
819
  components: /* @__PURE__ */ new Map()
818
820
  };
819
821
  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);
822
+ forceUpdate: () => A({}),
823
+ paths: /* @__PURE__ */ new Set([y.join(".")])
824
+ }), r.getState().stateComponents.set(e, U), () => {
825
+ const Y = r.getState().stateComponents.get(e);
824
826
  Y && Y.components.delete(b);
825
827
  };
826
- }, [e, A]);
828
+ }, [e, $]);
827
829
  },
828
830
  index: f,
829
831
  originalIndex: c
830
832
  });
831
833
  }) : (console.warn(
832
834
  `stateMap called on a non-array value at path: ${n.join(".")}. The current value is:`,
833
- r
835
+ o
834
836
  ), null);
835
837
  };
836
838
  if (l === "stateMapNoRender")
837
- return (t) => I.map((a, c) => {
839
+ return (t) => h.map((s, c) => {
838
840
  let f;
839
841
  S?.validIndices && S.validIndices[c] !== void 0 ? f = S.validIndices[c] : f = c;
840
- const u = [...n, f.toString()], E = s(a, u, S);
842
+ const u = [...n, f.toString()], y = a(s, u, S);
841
843
  return t(
842
- a,
843
- E,
844
+ s,
845
+ y,
844
846
  c,
845
- I,
846
- s(I, n, S)
847
+ h,
848
+ a(h, n, S)
847
849
  );
848
850
  });
849
851
  if (l === "$stateMap")
850
- return (t) => de(tt, {
852
+ return (t) => ce(et, {
851
853
  proxy: {
852
854
  _stateKey: e,
853
855
  _path: n,
854
856
  _mapFn: t
855
857
  // Pass the actual function, not string
856
858
  },
857
- rebuildStateShape: s
859
+ rebuildStateShape: a
858
860
  });
859
861
  if (l === "stateList")
860
862
  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, {
863
+ const o = r.getState().getNestedState(e, n);
864
+ return Array.isArray(o) ? (S?.validIndices || Array.from({ length: o.length }, (c, f) => f)).map((c, f) => {
865
+ const u = o[c], y = [...n, c.toString()], E = a(u, y, S), w = `${m}-${n.join(".")}-${c}`;
866
+ return ce(nt, {
865
867
  key: c,
866
868
  stateKey: e,
867
- itemComponentId: _,
868
- itemPath: E,
869
+ itemComponentId: w,
870
+ itemPath: y,
869
871
  children: t(
870
872
  u,
871
- p,
873
+ E,
872
874
  f,
873
- r,
874
- s(r, n, S)
875
+ o,
876
+ a(o, n, S)
875
877
  )
876
878
  });
877
879
  }) : (console.warn(
@@ -880,98 +882,98 @@ function Ie(e, i, m, g) {
880
882
  };
881
883
  if (l === "stateFlattenOn")
882
884
  return (t) => {
883
- const r = I;
884
- T.clear(), O++;
885
- const a = r.flatMap(
885
+ const o = h;
886
+ T.clear(), C++;
887
+ const s = o.flatMap(
886
888
  (c) => c[t] ?? []
887
889
  );
888
- return s(
889
- a,
890
+ return a(
891
+ s,
890
892
  [...n, "[*]", t],
891
893
  S
892
894
  );
893
895
  };
894
896
  if (l === "index")
895
897
  return (t) => {
896
- const r = I[t];
897
- return s(r, [...n, t.toString()]);
898
+ const o = h[t];
899
+ return a(o, [...n, t.toString()]);
898
900
  };
899
901
  if (l === "last")
900
902
  return () => {
901
- const t = o.getState().getNestedState(e, n);
903
+ const t = r.getState().getNestedState(e, n);
902
904
  if (t.length === 0) return;
903
- const r = t.length - 1, a = t[r], c = [...n, r.toString()];
904
- return s(a, c);
905
+ const o = t.length - 1, s = t[o], c = [...n, o.toString()];
906
+ return a(s, c);
905
907
  };
906
908
  if (l === "insert")
907
- return (t) => (w(n), pe(i, t, n, e), s(
908
- o.getState().getNestedState(e, n),
909
+ return (t) => (p(n), ye(i, t, n, e), a(
910
+ r.getState().getNestedState(e, n),
909
911
  n
910
912
  ));
911
913
  if (l === "uniqueInsert")
912
- return (t, r, a) => {
913
- const c = o.getState().getNestedState(e, n), f = K(t) ? t(c) : t;
914
+ return (t, o, s) => {
915
+ const c = r.getState().getNestedState(e, n), f = K(t) ? t(c) : t;
914
916
  let u = null;
915
- if (!c.some((p) => {
916
- if (r) {
917
- const C = r.every(
918
- (A) => q(p[A], f[A])
917
+ if (!c.some((E) => {
918
+ if (o) {
919
+ const A = o.every(
920
+ ($) => q(E[$], f[$])
919
921
  );
920
- return C && (u = p), C;
922
+ return A && (u = E), A;
921
923
  }
922
- const _ = q(p, f);
923
- return _ && (u = p), _;
924
+ const w = q(E, f);
925
+ return w && (u = E), w;
924
926
  }))
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
927
+ p(n), ye(i, f, n, e);
928
+ else if (s && u) {
929
+ const E = s(u), w = c.map(
930
+ (A) => q(A, u) ? E : A
929
931
  );
930
- w(n), ce(i, _, n);
932
+ p(n), se(i, w, n);
931
933
  }
932
934
  };
933
935
  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),
936
+ return (t, o) => {
937
+ if (!o?.waitForSync)
938
+ return p(n), fe(i, n, e, t), a(
939
+ r.getState().getNestedState(e, n),
938
940
  n
939
941
  );
940
942
  };
941
943
  if (l === "cutByValue")
942
944
  return (t) => {
943
- for (let r = 0; r < I.length; r++)
944
- I[r] === t && me(i, n, e, r);
945
+ for (let o = 0; o < h.length; o++)
946
+ h[o] === t && fe(i, n, e, o);
945
947
  };
946
948
  if (l === "toggleByValue")
947
949
  return (t) => {
948
- const r = I.findIndex((a) => a === t);
949
- r > -1 ? me(i, n, e, r) : pe(i, t, n, e);
950
+ const o = h.findIndex((s) => s === t);
951
+ o > -1 ? fe(i, n, e, o) : ye(i, t, n, e);
950
952
  };
951
953
  if (l === "stateFind")
952
954
  return (t) => {
953
- const a = d().find(
955
+ const s = d().find(
954
956
  ({ item: f }, u) => t(f, u)
955
957
  );
956
- if (!a) return;
957
- const c = [...n, a.originalIndex.toString()];
958
- return s(a.item, c, S);
958
+ if (!s) return;
959
+ const c = [...n, s.originalIndex.toString()];
960
+ return a(s.item, c, S);
959
961
  };
960
962
  if (l === "findWith")
961
- return (t, r) => {
963
+ return (t, o) => {
962
964
  const c = d().find(
963
- ({ item: u }) => u[t] === r
965
+ ({ item: u }) => u[t] === o
964
966
  );
965
967
  if (!c) return;
966
968
  const f = [...n, c.originalIndex.toString()];
967
- return s(c.item, f, S);
969
+ return a(c.item, f, S);
968
970
  };
969
971
  }
970
972
  const ee = n[n.length - 1];
971
973
  if (!isNaN(Number(ee))) {
972
- const d = n.slice(0, -1), t = o.getState().getNestedState(e, d);
974
+ const d = n.slice(0, -1), t = r.getState().getNestedState(e, d);
973
975
  if (Array.isArray(t) && l === "cut")
974
- return () => me(
976
+ return () => fe(
975
977
  i,
976
978
  d,
977
979
  e,
@@ -980,171 +982,171 @@ function Ie(e, i, m, g) {
980
982
  }
981
983
  if (l === "get")
982
984
  return () => {
983
- if (S?.validIndices && Array.isArray(I)) {
984
- const d = o.getState().getNestedState(e, n);
985
+ if (S?.validIndices && Array.isArray(h)) {
986
+ const d = r.getState().getNestedState(e, n);
985
987
  return S.validIndices.map((t) => d[t]);
986
988
  }
987
- return o.getState().getNestedState(e, n);
989
+ return r.getState().getNestedState(e, n);
988
990
  };
989
991
  if (l === "$derive")
990
- return (d) => Pe({
992
+ return (d) => Me({
991
993
  _stateKey: e,
992
994
  _path: n,
993
995
  _effect: d.toString()
994
996
  });
995
997
  if (l === "$get")
996
- return () => Pe({
998
+ return () => Me({
997
999
  _stateKey: e,
998
1000
  _path: n
999
1001
  });
1000
1002
  if (l === "lastSynced") {
1001
1003
  const d = `${e}:${n.join(".")}`;
1002
- return o.getState().getSyncInfo(d);
1004
+ return r.getState().getSyncInfo(d);
1003
1005
  }
1004
1006
  if (l == "getLocalStorage")
1005
- return (d) => Te(g + "-" + e + "-" + d);
1007
+ return (d) => Ie(g + "-" + e + "-" + d);
1006
1008
  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;
1009
+ const d = n.slice(0, -1), t = d.join("."), o = r.getState().getNestedState(e, d);
1010
+ return Array.isArray(o) ? Number(n[n.length - 1]) === r.getState().getSelectedIndex(e, t) : void 0;
1009
1011
  }
1010
1012
  if (l === "setSelected")
1011
1013
  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);
1014
+ const t = n.slice(0, -1), o = Number(n[n.length - 1]), s = t.join(".");
1015
+ d ? r.getState().setSelectedIndex(e, s, o) : r.getState().setSelectedIndex(e, s, void 0);
1016
+ const c = r.getState().getNestedState(e, [...t]);
1017
+ se(i, c, t), p(t);
1016
1018
  };
1017
1019
  if (l === "toggleSelected")
1018
1020
  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(
1021
+ const d = n.slice(0, -1), t = Number(n[n.length - 1]), o = d.join("."), s = r.getState().getSelectedIndex(e, o);
1022
+ r.getState().setSelectedIndex(
1021
1023
  e,
1022
- r,
1023
- a === t ? void 0 : t
1024
+ o,
1025
+ s === t ? void 0 : t
1024
1026
  );
1025
- const c = o.getState().getNestedState(e, [...d]);
1026
- ce(i, c, d), w(d);
1027
+ const c = r.getState().getNestedState(e, [...d]);
1028
+ se(i, c, d), p(d);
1027
1029
  };
1028
1030
  if (n.length == 0) {
1029
1031
  if (l === "applyJsonPatch")
1030
1032
  return (d) => {
1031
- const t = o.getState().cogsStateStore[e], a = ze(t, d).newDocument;
1033
+ const t = r.getState().cogsStateStore[e], s = We(t, d).newDocument;
1032
1034
  Le(
1033
1035
  e,
1034
- o.getState().initialStateGlobal[e],
1035
- a,
1036
+ r.getState().initialStateGlobal[e],
1037
+ s,
1036
1038
  i,
1037
1039
  m,
1038
1040
  g
1039
1041
  );
1040
- const c = o.getState().stateComponents.get(e);
1042
+ const c = r.getState().stateComponents.get(e);
1041
1043
  if (c) {
1042
- const f = _e(t, a), u = new Set(f);
1044
+ const f = _e(t, s), u = new Set(f);
1043
1045
  for (const [
1044
- E,
1045
- p
1046
+ y,
1047
+ E
1046
1048
  ] 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();
1049
+ let w = !1;
1050
+ const A = Array.isArray(E.reactiveType) ? E.reactiveType : [E.reactiveType || "component"];
1051
+ if (!A.includes("none")) {
1052
+ if (A.includes("all")) {
1053
+ E.forceUpdate();
1052
1054
  continue;
1053
1055
  }
1054
- if (C.includes("component") && (p.paths.has("") && (_ = !0), !_))
1055
- for (const A of u) {
1056
- if (p.paths.has(A)) {
1057
- _ = !0;
1056
+ if (A.includes("component") && (E.paths.has("") && (w = !0), !w))
1057
+ for (const $ of u) {
1058
+ if (E.paths.has($)) {
1059
+ w = !0;
1058
1060
  break;
1059
1061
  }
1060
- let b = A.lastIndexOf(".");
1062
+ let b = $.lastIndexOf(".");
1061
1063
  for (; b !== -1; ) {
1062
- const U = A.substring(0, b);
1063
- if (p.paths.has(U)) {
1064
- _ = !0;
1064
+ const U = $.substring(0, b);
1065
+ if (E.paths.has(U)) {
1066
+ w = !0;
1065
1067
  break;
1066
1068
  }
1067
- const Y = A.substring(
1069
+ const Y = $.substring(
1068
1070
  b + 1
1069
1071
  );
1070
1072
  if (!isNaN(Number(Y))) {
1071
- const x = U.lastIndexOf(".");
1072
- if (x !== -1) {
1073
+ const M = U.lastIndexOf(".");
1074
+ if (M !== -1) {
1073
1075
  const N = U.substring(
1074
1076
  0,
1075
- x
1077
+ M
1076
1078
  );
1077
- if (p.paths.has(N)) {
1078
- _ = !0;
1079
+ if (E.paths.has(N)) {
1080
+ w = !0;
1079
1081
  break;
1080
1082
  }
1081
1083
  }
1082
1084
  }
1083
1085
  b = U.lastIndexOf(".");
1084
1086
  }
1085
- if (_) break;
1087
+ if (w) break;
1086
1088
  }
1087
- if (!_ && C.includes("deps") && p.depsFunction) {
1088
- const A = p.depsFunction(a);
1089
+ if (!w && A.includes("deps") && E.depsFunction) {
1090
+ const $ = E.depsFunction(s);
1089
1091
  let b = !1;
1090
- typeof A == "boolean" ? A && (b = !0) : q(p.deps, A) || (p.deps = A, b = !0), b && (_ = !0);
1092
+ typeof $ == "boolean" ? $ && (b = !0) : q(E.deps, $) || (E.deps = $, b = !0), b && (w = !0);
1091
1093
  }
1092
- _ && p.forceUpdate();
1094
+ w && E.forceUpdate();
1093
1095
  }
1094
1096
  }
1095
1097
  }
1096
1098
  };
1097
1099
  if (l === "validateZodSchema")
1098
1100
  return () => {
1099
- const d = o.getState().getInitialOptions(e)?.validation, t = o.getState().addValidationError;
1101
+ const d = r.getState().getInitialOptions(e)?.validation, t = r.getState().addValidationError;
1100
1102
  if (!d?.zodSchema)
1101
1103
  throw new Error("Zod schema not found");
1102
1104
  if (!d?.key)
1103
1105
  throw new Error("Validation key not found");
1104
1106
  X(d.key);
1105
- const r = o.getState().cogsStateStore[e];
1107
+ const o = r.getState().cogsStateStore[e];
1106
1108
  try {
1107
- const a = o.getState().getValidationErrors(d.key);
1108
- a && a.length > 0 && a.forEach(([f]) => {
1109
+ const s = r.getState().getValidationErrors(d.key);
1110
+ s && s.length > 0 && s.forEach(([f]) => {
1109
1111
  f && f.startsWith(d.key) && X(f);
1110
1112
  });
1111
- const c = d.zodSchema.safeParse(r);
1113
+ const c = d.zodSchema.safeParse(o);
1112
1114
  return c.success ? !0 : (c.error.errors.forEach((u) => {
1113
- const E = u.path, p = u.message, _ = [d.key, ...E].join(".");
1114
- t(_, p);
1115
- }), ve(e), !1);
1116
- } catch (a) {
1117
- return console.error("Zod schema validation failed", a), !1;
1115
+ const y = u.path, E = u.message, w = [d.key, ...y].join(".");
1116
+ t(w, E);
1117
+ }), he(e), !1);
1118
+ } catch (s) {
1119
+ return console.error("Zod schema validation failed", s), !1;
1118
1120
  }
1119
1121
  };
1120
1122
  if (l === "_componentId") return m;
1121
1123
  if (l === "getComponents")
1122
- return () => o().stateComponents.get(e);
1124
+ return () => r().stateComponents.get(e);
1123
1125
  if (l === "getAllFormRefs")
1124
- return () => ke.getState().getFormRefsByStateKey(e);
1126
+ return () => $e.getState().getFormRefsByStateKey(e);
1125
1127
  if (l === "_initialState")
1126
- return o.getState().initialStateGlobal[e];
1128
+ return r.getState().initialStateGlobal[e];
1127
1129
  if (l === "_serverState")
1128
- return o.getState().serverState[e];
1130
+ return r.getState().serverState[e];
1129
1131
  if (l === "_isLoading")
1130
- return o.getState().isLoadingGlobal[e];
1132
+ return r.getState().isLoadingGlobal[e];
1131
1133
  if (l === "revertToInitialState")
1132
- return y.revertToInitialState;
1133
- if (l === "updateInitialState") return y.updateInitialState;
1134
- if (l === "removeValidation") return y.removeValidation;
1134
+ return v.revertToInitialState;
1135
+ if (l === "updateInitialState") return v.updateInitialState;
1136
+ if (l === "removeValidation") return v.removeValidation;
1135
1137
  }
1136
1138
  if (l === "getFormRef")
1137
- return () => ke.getState().getFormRef(e + "." + n.join("."));
1139
+ return () => $e.getState().getFormRef(e + "." + n.join("."));
1138
1140
  if (l === "validationWrapper")
1139
1141
  return ({
1140
1142
  children: d,
1141
1143
  hideMessage: t
1142
- }) => /* @__PURE__ */ we(
1144
+ }) => /* @__PURE__ */ pe(
1143
1145
  He,
1144
1146
  {
1145
1147
  formOpts: t ? { validation: { message: "" } } : void 0,
1146
1148
  path: n,
1147
- validationKey: o.getState().getInitialOptions(e)?.validation?.key || "",
1149
+ validationKey: r.getState().getInitialOptions(e)?.validation?.key || "",
1148
1150
  stateKey: e,
1149
1151
  validIndices: S?.validIndices,
1150
1152
  children: d
@@ -1152,25 +1154,25 @@ function Ie(e, i, m, g) {
1152
1154
  );
1153
1155
  if (l === "_stateKey") return e;
1154
1156
  if (l === "_path") return n;
1155
- if (l === "_isServerSynced") return y._isServerSynced;
1157
+ if (l === "_isServerSynced") return v._isServerSynced;
1156
1158
  if (l === "update")
1157
1159
  return (d, t) => {
1158
1160
  if (t?.debounce)
1159
- Fe(() => {
1160
- ce(i, d, n, "");
1161
- const r = o.getState().getNestedState(e, n);
1162
- t?.afterUpdate && t.afterUpdate(r);
1161
+ je(() => {
1162
+ se(i, d, n, "");
1163
+ const o = r.getState().getNestedState(e, n);
1164
+ t?.afterUpdate && t.afterUpdate(o);
1163
1165
  }, t.debounce);
1164
1166
  else {
1165
- ce(i, d, n, "");
1166
- const r = o.getState().getNestedState(e, n);
1167
- t?.afterUpdate && t.afterUpdate(r);
1167
+ se(i, d, n, "");
1168
+ const o = r.getState().getNestedState(e, n);
1169
+ t?.afterUpdate && t.afterUpdate(o);
1168
1170
  }
1169
- w(n);
1171
+ p(n);
1170
1172
  };
1171
1173
  if (l === "formElement")
1172
- return (d, t) => /* @__PURE__ */ we(
1173
- We,
1174
+ return (d, t) => /* @__PURE__ */ pe(
1175
+ Fe,
1174
1176
  {
1175
1177
  setState: i,
1176
1178
  stateKey: e,
@@ -1179,52 +1181,52 @@ function Ie(e, i, m, g) {
1179
1181
  formOpts: t
1180
1182
  }
1181
1183
  );
1182
- const P = [...n, l], ae = o.getState().getNestedState(e, P);
1183
- return s(ae, P, S);
1184
+ const V = [...n, l], ae = r.getState().getNestedState(e, V);
1185
+ return a(ae, V, S);
1184
1186
  }
1185
- }, B = new Proxy(G, L);
1186
- return T.set(W, {
1187
+ }, B = new Proxy(L, G);
1188
+ return T.set(F, {
1187
1189
  proxy: B,
1188
- stateVersion: O
1190
+ stateVersion: C
1189
1191
  }), B;
1190
1192
  }
1191
- return s(
1192
- o.getState().getNestedState(e, [])
1193
+ return a(
1194
+ r.getState().getNestedState(e, [])
1193
1195
  );
1194
1196
  }
1195
- function Pe(e) {
1196
- return de(nt, { proxy: e });
1197
+ function Me(e) {
1198
+ return ce(tt, { proxy: e });
1197
1199
  }
1198
- function tt({
1200
+ function et({
1199
1201
  proxy: e,
1200
1202
  rebuildStateShape: i
1201
1203
  }) {
1202
- const m = o().getNestedState(e._stateKey, e._path);
1204
+ const m = r().getNestedState(e._stateKey, e._path);
1203
1205
  return Array.isArray(m) ? i(
1204
1206
  m,
1205
1207
  e._path
1206
1208
  ).stateMapNoRender(
1207
- (T, O, w, y, s) => e._mapFn(T, O, w, y, s)
1209
+ (T, C, p, v, a) => e._mapFn(T, C, p, v, a)
1208
1210
  ) : null;
1209
1211
  }
1210
- function nt({
1212
+ function tt({
1211
1213
  proxy: e
1212
1214
  }) {
1213
- const i = J(null), m = `${e._stateKey}-${e._path.join(".")}`;
1215
+ const i = Z(null), m = `${e._stateKey}-${e._path.join(".")}`;
1214
1216
  return oe(() => {
1215
1217
  const g = i.current;
1216
1218
  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 = {
1219
+ const T = g.parentElement, p = Array.from(T.childNodes).indexOf(g);
1220
+ let v = T.getAttribute("data-parent-id");
1221
+ v || (v = `parent-${crypto.randomUUID()}`, T.setAttribute("data-parent-id", v));
1222
+ const h = {
1221
1223
  instanceId: `instance-${crypto.randomUUID()}`,
1222
- parentId: y,
1223
- position: w,
1224
+ parentId: v,
1225
+ position: p,
1224
1226
  effect: e._effect
1225
1227
  };
1226
- o.getState().addSignalElement(m, I);
1227
- const n = o.getState().getNestedState(e._stateKey, e._path);
1228
+ r.getState().addSignalElement(m, h);
1229
+ const n = r.getState().getNestedState(e._stateKey, e._path);
1228
1230
  let S;
1229
1231
  if (e._effect)
1230
1232
  try {
@@ -1232,24 +1234,24 @@ function nt({
1232
1234
  "state",
1233
1235
  `return (${e._effect})(state)`
1234
1236
  )(n);
1235
- } catch (G) {
1236
- console.error("Error evaluating effect function during mount:", G), S = n;
1237
+ } catch (L) {
1238
+ console.error("Error evaluating effect function during mount:", L), S = n;
1237
1239
  }
1238
1240
  else
1239
1241
  S = n;
1240
1242
  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", {
1243
+ const F = document.createTextNode(String(S));
1244
+ g.replaceWith(F);
1245
+ }, [e._stateKey, e._path.join("."), e._effect]), ce("span", {
1244
1246
  ref: i,
1245
1247
  style: { display: "none" },
1246
1248
  "data-signal-id": m
1247
1249
  });
1248
1250
  }
1249
- function Tt(e) {
1250
- const i = De(
1251
+ function ht(e) {
1252
+ const i = Re(
1251
1253
  (m) => {
1252
- const g = o.getState().stateComponents.get(e._stateKey) || {
1254
+ const g = r.getState().stateComponents.get(e._stateKey) || {
1253
1255
  components: /* @__PURE__ */ new Map()
1254
1256
  };
1255
1257
  return g.components.set(e._stateKey, {
@@ -1257,42 +1259,42 @@ function Tt(e) {
1257
1259
  paths: /* @__PURE__ */ new Set([e._path.join(".")])
1258
1260
  }), () => g.components.delete(e._stateKey);
1259
1261
  },
1260
- () => o.getState().getNestedState(e._stateKey, e._path)
1262
+ () => r.getState().getNestedState(e._stateKey, e._path)
1261
1263
  );
1262
- return de("text", {}, String(i));
1264
+ return ce("text", {}, String(i));
1263
1265
  }
1264
- function rt({
1266
+ function nt({
1265
1267
  stateKey: e,
1266
1268
  itemComponentId: i,
1267
1269
  itemPath: m,
1268
1270
  children: g
1269
1271
  }) {
1270
- const [, T] = Q({}), [O, w] = qe(), y = J(null);
1272
+ const [, T] = Q({}), [C, p] = ze(), v = Z(null);
1271
1273
  return oe(() => {
1272
- w.height > 0 && w.height !== y.current && (y.current = w.height, o.getState().setShadowMetadata(e, m, {
1274
+ p.height > 0 && p.height !== v.current && (v.current = p.height, r.getState().setShadowMetadata(e, m, {
1273
1275
  virtualizer: {
1274
- itemHeight: w.height
1276
+ itemHeight: p.height
1275
1277
  }
1276
1278
  }));
1277
- }, [w.height, e, m]), le(() => {
1278
- const s = `${e}////${i}`, I = o.getState().stateComponents.get(e) || {
1279
+ }, [p.height, e, m]), ie(() => {
1280
+ const a = `${e}////${i}`, h = r.getState().stateComponents.get(e) || {
1279
1281
  components: /* @__PURE__ */ new Map()
1280
1282
  };
1281
- return I.components.set(s, {
1283
+ return h.components.set(a, {
1282
1284
  forceUpdate: () => T({}),
1283
1285
  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);
1286
+ }), r.getState().stateComponents.set(e, h), () => {
1287
+ const n = r.getState().stateComponents.get(e);
1288
+ n && n.components.delete(a);
1287
1289
  };
1288
- }, [e, i, m.join(".")]), /* @__PURE__ */ we("div", { ref: O, children: g });
1290
+ }, [e, i, m.join(".")]), /* @__PURE__ */ pe("div", { ref: C, children: g });
1289
1291
  }
1290
1292
  export {
1291
- Pe as $cogsSignal,
1292
- Tt as $cogsSignalStore,
1293
- mt as addStateOptions,
1294
- ht as createCogsState,
1293
+ Me as $cogsSignal,
1294
+ ht as $cogsSignalStore,
1295
+ St as addStateOptions,
1296
+ mt as createCogsState,
1295
1297
  It as notifyComponent,
1296
- et as useCogsStateFn
1298
+ Ke as useCogsStateFn
1297
1299
  };
1298
1300
  //# sourceMappingURL=CogsState.jsx.map