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