cogsbox-state 0.5.383 → 0.5.384

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