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