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