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