@logixjs/sandbox 0.0.1 → 0.0.2
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/LICENSE +201 -0
- package/package.json +3 -1
- package/public/sandbox/chunks/chunk-2AUQRESB.js +1114 -0
- package/public/sandbox/chunks/chunk-2F72LQKW.js +194 -0
- package/public/sandbox/chunks/chunk-2PYDGDD3.js +4071 -0
- package/public/sandbox/chunks/chunk-2UGKSXDZ.js +16 -0
- package/public/sandbox/chunks/chunk-2XVE7F26.js +153 -0
- package/public/sandbox/chunks/chunk-3A7TFNZN.js +219 -0
- package/public/sandbox/chunks/chunk-3BHC6JAV.js +1070 -0
- package/public/sandbox/chunks/chunk-3U4CAKCX.js +61 -0
- package/public/sandbox/chunks/chunk-3VU3JLZO.js +272 -0
- package/public/sandbox/chunks/chunk-4CPONKWY.js +1170 -0
- package/public/sandbox/chunks/chunk-4GMUQTWH.js +850 -0
- package/public/sandbox/chunks/chunk-4KIYG5E4.js +749 -0
- package/public/sandbox/chunks/chunk-4MY35XR3.js +175 -0
- package/public/sandbox/chunks/chunk-5DNHJMHA.js +69 -0
- package/public/sandbox/chunks/chunk-5EC4S7X6.js +42 -0
- package/public/sandbox/chunks/chunk-5FB7QFSH.js +227 -0
- package/public/sandbox/chunks/chunk-5GEYCJW2.js +206 -0
- package/public/sandbox/chunks/chunk-5PT7Q5SS.js +373 -0
- package/public/sandbox/chunks/chunk-5WN5IGKA.js +166 -0
- package/public/sandbox/chunks/chunk-5XOBKSOT.js +213 -0
- package/public/sandbox/chunks/chunk-67RVISUC.js +313 -0
- package/public/sandbox/chunks/chunk-6ELJEKZS.js +12 -0
- package/public/sandbox/chunks/chunk-6FKWRVP4.js +85 -0
- package/public/sandbox/chunks/chunk-6JRP52YT.js +34 -0
- package/public/sandbox/chunks/chunk-6JYAC3G6.js +42 -0
- package/public/sandbox/chunks/chunk-6TUOP63Q.js +86 -0
- package/public/sandbox/chunks/{chunk-A6JFUNQQ.js → chunk-74C5VW7Z.js} +2 -2
- package/public/sandbox/chunks/chunk-75DQFC5M.js +16 -0
- package/public/sandbox/chunks/{chunk-UCFEP3BH.js → chunk-7GPAF2UK.js} +1 -1
- package/public/sandbox/chunks/chunk-7KQFTS2Y.js +135 -0
- package/public/sandbox/chunks/chunk-7POKWYE3.js +112 -0
- package/public/sandbox/chunks/chunk-7VUEF5F3.js +395 -0
- package/public/sandbox/chunks/chunk-7W5APZS2.js +77 -0
- package/public/sandbox/chunks/chunk-A6OFCXDQ.js +397 -0
- package/public/sandbox/chunks/chunk-A7HLOSO6.js +216 -0
- package/public/sandbox/chunks/chunk-AGF4RRCB.js +408 -0
- package/public/sandbox/chunks/chunk-ASJSJAAL.js +122 -0
- package/public/sandbox/chunks/chunk-ASVMK364.js +283 -0
- package/public/sandbox/chunks/chunk-AUDTI2BQ.js +895 -0
- package/public/sandbox/chunks/chunk-B2SZTA3M.js +16 -0
- package/public/sandbox/chunks/chunk-B6YS2UMV.js +372 -0
- package/public/sandbox/chunks/chunk-BCEO3MGD.js +244 -0
- package/public/sandbox/chunks/chunk-BCOO65D4.js +373 -0
- package/public/sandbox/chunks/chunk-BJOWSSEL.js +38 -0
- package/public/sandbox/chunks/chunk-BS2WBFW4.js +373 -0
- package/public/sandbox/chunks/chunk-BUVHG3NJ.js +439 -0
- package/public/sandbox/chunks/chunk-BVE33AN6.js +42 -0
- package/public/sandbox/chunks/chunk-BWTGJZVP.js +19 -0
- package/public/sandbox/chunks/chunk-BXD7GZC3.js +1025 -0
- package/public/sandbox/chunks/chunk-BZH4EUUD.js +164 -0
- package/public/sandbox/chunks/{chunk-HFV5GJPK.js → chunk-C2MYMMO4.js} +3 -3
- package/public/sandbox/chunks/chunk-CRE4NJJ6.js +271 -0
- package/public/sandbox/chunks/chunk-CVZPRIDB.js +706 -0
- package/public/sandbox/chunks/chunk-CWOXD5NG.js +991 -0
- package/public/sandbox/chunks/chunk-D6DOC3BJ.js +373 -0
- package/public/sandbox/chunks/chunk-DEPSGFSY.js +1698 -0
- package/public/sandbox/chunks/chunk-DM7C5NP5.js +819 -0
- package/public/sandbox/chunks/chunk-DN33LMOF.js +1112 -0
- package/public/sandbox/chunks/{chunk-S46P7MC6.js → chunk-DT7YIIWE.js} +2 -2
- package/public/sandbox/chunks/chunk-DVB5WRCI.js +260 -0
- package/public/sandbox/chunks/{chunk-TOHCFMQS.js → chunk-E3EVW7NR.js} +11 -18
- package/public/sandbox/chunks/chunk-E5BV567Q.js +417 -0
- package/public/sandbox/chunks/chunk-E7BIWMQQ.js +203 -0
- package/public/sandbox/chunks/chunk-EAKGPSOQ.js +83 -0
- package/public/sandbox/chunks/chunk-EGUYL2ER.js +75 -0
- package/public/sandbox/chunks/chunk-EP5GQYZ5.js +85 -0
- package/public/sandbox/chunks/chunk-ET6CJEHC.js +221 -0
- package/public/sandbox/chunks/chunk-EU67YZHZ.js +1070 -0
- package/public/sandbox/chunks/{chunk-PTSJJANP.js → chunk-EYNDQLSB.js} +1 -1
- package/public/sandbox/chunks/{chunk-CEGSWZ5S.js → chunk-EZTMVCJF.js} +1 -1
- package/public/sandbox/chunks/chunk-F5CLVIS6.js +907 -0
- package/public/sandbox/chunks/chunk-F743SKYD.js +85 -0
- package/public/sandbox/chunks/chunk-FEGFZ5OX.js +86 -0
- package/public/sandbox/chunks/chunk-FG5B7ZX3.js +373 -0
- package/public/sandbox/chunks/chunk-FKZPYMDG.js +373 -0
- package/public/sandbox/chunks/chunk-FNLXHWIU.js +220 -0
- package/public/sandbox/chunks/chunk-FQRUTYAD.js +1991 -0
- package/public/sandbox/chunks/{chunk-VLYP4WUS.js → chunk-FY5A73NK.js} +5 -5
- package/public/sandbox/chunks/chunk-G7FAOG3O.js +221 -0
- package/public/sandbox/chunks/chunk-GFXHUC7Y.js +73 -0
- package/public/sandbox/chunks/chunk-GIPXUIZQ.js +534 -0
- package/public/sandbox/chunks/chunk-GP37MEGJ.js +52 -0
- package/public/sandbox/chunks/chunk-GXL5QCMF.js +4511 -0
- package/public/sandbox/chunks/chunk-GZ2NSE6A.js +177 -0
- package/public/sandbox/chunks/chunk-GZATW4YD.js +69 -0
- package/public/sandbox/chunks/chunk-H4EBXROQ.js +166 -0
- package/public/sandbox/chunks/chunk-HETCPK6Z.js +153 -0
- package/public/sandbox/chunks/chunk-HGUFQ2QC.js +4431 -0
- package/public/sandbox/chunks/chunk-HGV3VNH3.js +255 -0
- package/public/sandbox/chunks/chunk-HIJ67QWR.js +5397 -0
- package/public/sandbox/chunks/chunk-IDHERBKW.js +1114 -0
- package/public/sandbox/chunks/chunk-IDTK4FIY.js +102 -0
- package/public/sandbox/chunks/chunk-ILFVY7H5.js +164 -0
- package/public/sandbox/chunks/chunk-ISGSRYGO.js +57 -0
- package/public/sandbox/chunks/chunk-J45VPU24.js +408 -0
- package/public/sandbox/chunks/chunk-JAUIM3O5.js +42 -0
- package/public/sandbox/chunks/chunk-JB7OQEM6.js +373 -0
- package/public/sandbox/chunks/chunk-JCKW6NHD.js +15 -0
- package/public/sandbox/chunks/chunk-JMA7GY7Z.js +221 -0
- package/public/sandbox/chunks/chunk-JY46J6IL.js +836 -0
- package/public/sandbox/chunks/{chunk-X72PZOFA.js → chunk-K2MQ66O7.js} +1 -1
- package/public/sandbox/chunks/chunk-KA7PZA6F.js +464 -0
- package/public/sandbox/chunks/chunk-KDEQTUID.js +102 -0
- package/public/sandbox/chunks/chunk-KDJR27JV.js +1696 -0
- package/public/sandbox/chunks/chunk-KFE3JO6N.js +77 -0
- package/public/sandbox/chunks/chunk-KLDSYWT5.js +536 -0
- package/public/sandbox/chunks/chunk-KQWWFYBF.js +203 -0
- package/public/sandbox/chunks/chunk-KTFZSXOW.js +6473 -0
- package/public/sandbox/chunks/chunk-KXVIC55U.js +108 -0
- package/public/sandbox/chunks/{chunk-HNEDTEGQ.js → chunk-L4PNO2H6.js} +1 -1
- package/public/sandbox/chunks/{chunk-WE4STGO2.js → chunk-L4ZNW5DI.js} +2 -2
- package/public/sandbox/chunks/chunk-LBUINGZ4.js +836 -0
- package/public/sandbox/chunks/chunk-LIYPPU6I.js +112 -0
- package/public/sandbox/chunks/chunk-LJHTOJXW.js +221 -0
- package/public/sandbox/chunks/{chunk-BWSNPKO5.js → chunk-LQL23SWJ.js} +2 -2
- package/public/sandbox/chunks/chunk-LTFCYZQ6.js +46 -0
- package/public/sandbox/chunks/chunk-LTWLVCKQ.js +166 -0
- package/public/sandbox/chunks/chunk-LWI7BXFN.js +395 -0
- package/public/sandbox/chunks/chunk-LYBBX6WM.js +225 -0
- package/public/sandbox/chunks/chunk-MXE7HIBM.js +474 -0
- package/public/sandbox/chunks/chunk-MYBDYNK4.js +6004 -0
- package/public/sandbox/chunks/chunk-NC2MIWZX.js +732 -0
- package/public/sandbox/chunks/chunk-NE447XAF.js +597 -0
- package/public/sandbox/chunks/chunk-NEAYV5C2.js +255 -0
- package/public/sandbox/chunks/chunk-NMGFJZ4I.js +26 -0
- package/public/sandbox/chunks/chunk-NWCJJZNQ.js +71 -0
- package/public/sandbox/chunks/chunk-O57OZBDR.js +214 -0
- package/public/sandbox/chunks/chunk-OJJT664Q.js +731 -0
- package/public/sandbox/chunks/chunk-OKTBUTCH.js +1175 -0
- package/public/sandbox/chunks/chunk-OQ4SYV5D.js +534 -0
- package/public/sandbox/chunks/chunk-OTVVIHJD.js +219 -0
- package/public/sandbox/chunks/chunk-OWTMSCF7.js +1052 -0
- package/public/sandbox/chunks/chunk-P5ZQNFC3.js +122 -0
- package/public/sandbox/chunks/chunk-PBPT2U2N.js +1698 -0
- package/public/sandbox/chunks/chunk-PHBJLCP3.js +836 -0
- package/public/sandbox/chunks/chunk-PHV4HYHB.js +397 -0
- package/public/sandbox/chunks/chunk-PIXQ6SOX.js +4071 -0
- package/public/sandbox/chunks/chunk-PKJL6YLK.js +73 -0
- package/public/sandbox/chunks/chunk-PKPOITIU.js +221 -0
- package/public/sandbox/chunks/{chunk-NQW73ACJ.js → chunk-PMXBOYQI.js} +1 -1
- package/public/sandbox/chunks/chunk-PQLZD7NR.js +836 -0
- package/public/sandbox/chunks/chunk-QEESVOZU.js +16 -0
- package/public/sandbox/chunks/chunk-QGIM3FQK.js +159 -0
- package/public/sandbox/chunks/chunk-QL5JNEDO.js +69 -0
- package/public/sandbox/chunks/chunk-QQOZ3RMH.js +867 -0
- package/public/sandbox/chunks/chunk-QUMEVT2F.js +194 -0
- package/public/sandbox/chunks/chunk-QVZBXYVY.js +102 -0
- package/public/sandbox/chunks/chunk-R5HQS6RB.js +135 -0
- package/public/sandbox/chunks/chunk-R75Q2CTT.js +900 -0
- package/public/sandbox/chunks/chunk-RBB6SHW2.js +253 -0
- package/public/sandbox/chunks/chunk-RDHNRWQP.js +383 -0
- package/public/sandbox/chunks/chunk-RIWOEI3T.js +1101 -0
- package/public/sandbox/chunks/chunk-RS5FFPUV.js +103 -0
- package/public/sandbox/chunks/chunk-RYSSJBGX.js +203 -0
- package/public/sandbox/chunks/chunk-S3KBAE5Z.js +1114 -0
- package/public/sandbox/chunks/chunk-S6ZZHV6G.js +244 -0
- package/public/sandbox/chunks/chunk-SFXJ24HY.js +499 -0
- package/public/sandbox/chunks/chunk-SH7TP5CJ.js +1109 -0
- package/public/sandbox/chunks/chunk-SI5OKFFY.js +317 -0
- package/public/sandbox/chunks/chunk-SIXNQNIR.js +86 -0
- package/public/sandbox/chunks/chunk-ST353BOX.js +42 -0
- package/public/sandbox/chunks/chunk-SYEHKMLP.js +1140 -0
- package/public/sandbox/chunks/chunk-SZ4KQUJU.js +69 -0
- package/public/sandbox/chunks/{chunk-5SOP6EKV.js → chunk-SZI65PSP.js} +5 -10
- package/public/sandbox/chunks/chunk-T7RLTSMX.js +78 -0
- package/public/sandbox/chunks/chunk-TJ2RLUTW.js +57 -0
- package/public/sandbox/chunks/chunk-TJB73XPN.js +4071 -0
- package/public/sandbox/chunks/chunk-TXJCYO56.js +4046 -0
- package/public/sandbox/chunks/chunk-U5J3LCYI.js +731 -0
- package/public/sandbox/chunks/chunk-UABFN3NH.js +208 -0
- package/public/sandbox/chunks/chunk-UBMUY7WO.js +13 -0
- package/public/sandbox/chunks/chunk-UC27CE32.js +69 -0
- package/public/sandbox/chunks/chunk-UJGVDFZN.js +147 -0
- package/public/sandbox/chunks/chunk-UNVLTK4N.js +122 -0
- package/public/sandbox/chunks/chunk-UQKQ6V3V.js +208 -0
- package/public/sandbox/chunks/chunk-UZZBHWIO.js +703 -0
- package/public/sandbox/chunks/chunk-VKZIJERL.js +1114 -0
- package/public/sandbox/chunks/chunk-VQQEAGID.js +372 -0
- package/public/sandbox/chunks/{chunk-3LX3KIQQ.js → chunk-W365QUZ5.js} +3 -5
- package/public/sandbox/chunks/chunk-WJY2LSWG.js +1052 -0
- package/public/sandbox/chunks/chunk-WNOBN3DX.js +391 -0
- package/public/sandbox/chunks/chunk-X2Z5VYG3.js +245 -0
- package/public/sandbox/chunks/chunk-X74KU74D.js +959 -0
- package/public/sandbox/chunks/chunk-XE7ULSGQ.js +46 -0
- package/public/sandbox/chunks/chunk-XRXUJZ3X.js +431 -0
- package/public/sandbox/chunks/chunk-XWHIN7CC.js +85 -0
- package/public/sandbox/chunks/chunk-Y2TVGGVL.js +527 -0
- package/public/sandbox/chunks/chunk-YMVMZA3U.js +1395 -0
- package/public/sandbox/chunks/chunk-YOBLFWDV.js +431 -0
- package/public/sandbox/chunks/chunk-YR2RFEZA.js +11 -0
- package/public/sandbox/chunks/chunk-YTD6A35P.js +836 -0
- package/public/sandbox/chunks/chunk-Z5L7EZXS.js +81 -0
- package/public/sandbox/chunks/chunk-Z65I5ET2.js +108 -0
- package/public/sandbox/chunks/chunk-Z6LV34RO.js +390 -0
- package/public/sandbox/chunks/chunk-ZAKUP6QG.js +1634 -0
- package/public/sandbox/chunks/chunk-ZHNYE2YH.js +731 -0
- package/public/sandbox/chunks/chunk-ZHQX3B3Y.js +867 -0
- package/public/sandbox/chunks/chunk-ZIXDFRHJ.js +731 -0
- package/public/sandbox/chunks/chunk-ZPZ2MZ4D.js +528 -0
- package/public/sandbox/chunks/chunk-ZQD6NZXB.js +373 -0
- package/public/sandbox/chunks/chunk-ZVVBP7ON.js +16 -0
- package/public/sandbox/chunks/chunk-ZWE3P6X2.js +11 -0
- package/public/sandbox/logix-core/Bound.js +14 -14
- package/public/sandbox/logix-core/Debug.js +12 -10
- package/public/sandbox/logix-core/EffectOp.js +3 -4
- package/public/sandbox/logix-core/Env.js +5 -2
- package/public/sandbox/logix-core/ExternalStore.js +239 -0
- package/public/sandbox/logix-core/Flow.js +7 -8
- package/public/sandbox/logix-core/Kernel.js +7 -4
- package/public/sandbox/logix-core/Link.js +33 -25
- package/public/sandbox/logix-core/Middleware.js +13 -11
- package/public/sandbox/logix-core/Module.js +93 -30
- package/public/sandbox/logix-core/ModuleTag.js +28 -25
- package/public/sandbox/logix-core/Observability.js +21 -19
- package/public/sandbox/logix-core/Process.js +27 -22
- package/public/sandbox/logix-core/ReadQuery.js +7 -11
- package/public/sandbox/logix-core/Reflection.js +173 -53
- package/public/sandbox/logix-core/Resource.js +6 -3
- package/public/sandbox/logix-core/Root.js +7 -3
- package/public/sandbox/logix-core/Runtime.js +54 -40
- package/public/sandbox/logix-core/ScopeRegistry.js +6 -3
- package/public/sandbox/logix-core/StateTrait.js +17 -14
- package/public/sandbox/logix-core/TraitLifecycle.js +8 -8
- package/public/sandbox/logix-core/Workflow.js +332 -0
- package/public/sandbox/logix-core.js +11133 -6622
- package/public/sandbox/logix-core.manifest.json +4 -2
- package/public/sandbox/worker.js +3 -3
- package/public/sandbox/chunks/chunk-4LRLOTMA.js +0 -1698
- package/public/sandbox/chunks/chunk-CDLXJHXY.js +0 -120
- package/public/sandbox/chunks/chunk-CZRI7MHA.js +0 -46
- package/public/sandbox/chunks/chunk-EJDFUZ4B.js +0 -408
- package/public/sandbox/chunks/chunk-IP63FME6.js +0 -282
- package/public/sandbox/chunks/chunk-JIXTOQXJ.js +0 -1103
- package/public/sandbox/chunks/chunk-MPUSOFJ3.js +0 -1928
- package/public/sandbox/chunks/chunk-ON2LY6HJ.js +0 -135
- package/public/sandbox/chunks/chunk-POIBXAH5.js +0 -995
- package/public/sandbox/chunks/chunk-PQ652ULI.js +0 -6359
- package/public/sandbox/chunks/chunk-RJQ4PG2F.js +0 -77
- package/public/sandbox/chunks/chunk-S4EXG3OS.js +0 -533
- package/public/sandbox/chunks/chunk-SUXDGXVE.js +0 -390
- package/public/sandbox/chunks/chunk-TOQ6SJ6O.js +0 -244
- package/public/sandbox/chunks/chunk-UKYAF3NL.js +0 -1036
- package/public/sandbox/chunks/chunk-UMVN3AWO.js +0 -395
- package/public/sandbox/chunks/chunk-WFV5PPWJ.js +0 -194
- package/public/sandbox/chunks/chunk-YF6IO732.js +0 -206
- package/public/sandbox/chunks/chunk-ZUBABAAO.js +0 -86
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
// @logix/core subpath bundles for @logix/sandbox
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
// ../logix-core/src/internal/field-path.ts
|
|
5
|
+
var isFieldPathSegment = (seg) => {
|
|
6
|
+
if (!seg) return false;
|
|
7
|
+
if (seg === "*") return false;
|
|
8
|
+
if (/^\d+$/.test(seg)) return false;
|
|
9
|
+
if (seg.includes("[") || seg.includes("]")) return false;
|
|
10
|
+
return true;
|
|
11
|
+
};
|
|
12
|
+
var normalizeFieldPath = (input) => {
|
|
13
|
+
const segs = typeof input === "string" ? splitSegments(input) : input.slice();
|
|
14
|
+
if (!segs || segs.length === 0) return void 0;
|
|
15
|
+
const normalized = segs.filter(isFieldPathSegment);
|
|
16
|
+
return normalized.length > 0 ? normalized : void 0;
|
|
17
|
+
};
|
|
18
|
+
var compareFieldPath = (a, b) => {
|
|
19
|
+
const len = Math.min(a.length, b.length);
|
|
20
|
+
for (let i = 0; i < len; i++) {
|
|
21
|
+
const as = a[i];
|
|
22
|
+
const bs = b[i];
|
|
23
|
+
if (as === bs) continue;
|
|
24
|
+
return as < bs ? -1 : 1;
|
|
25
|
+
}
|
|
26
|
+
return a.length - b.length;
|
|
27
|
+
};
|
|
28
|
+
var isPrefixOf = (prefix, full) => {
|
|
29
|
+
if (prefix.length > full.length) return false;
|
|
30
|
+
for (let i = 0; i < prefix.length; i++) {
|
|
31
|
+
if (prefix[i] !== full[i]) return false;
|
|
32
|
+
}
|
|
33
|
+
return true;
|
|
34
|
+
};
|
|
35
|
+
var toPathString = (path) => path.join(".");
|
|
36
|
+
var canonicalizeRootsFast = (roots) => {
|
|
37
|
+
const sorted = Array.from(roots).sort(compareFieldPath);
|
|
38
|
+
const out = [];
|
|
39
|
+
for (const next of sorted) {
|
|
40
|
+
const prev = out[out.length - 1];
|
|
41
|
+
if (prev && isPrefixOf(prev, next)) continue;
|
|
42
|
+
out.push(next);
|
|
43
|
+
}
|
|
44
|
+
return out;
|
|
45
|
+
};
|
|
46
|
+
var makeFieldPathIdRegistry = (fieldPaths) => {
|
|
47
|
+
const root = { children: /* @__PURE__ */ new Map() };
|
|
48
|
+
for (let id = 0; id < fieldPaths.length; id++) {
|
|
49
|
+
const path = fieldPaths[id];
|
|
50
|
+
let node = root;
|
|
51
|
+
for (const seg of path) {
|
|
52
|
+
const children = node.children;
|
|
53
|
+
let next = children.get(seg);
|
|
54
|
+
if (!next) {
|
|
55
|
+
next = { children: /* @__PURE__ */ new Map() };
|
|
56
|
+
children.set(seg, next);
|
|
57
|
+
}
|
|
58
|
+
node = next;
|
|
59
|
+
}
|
|
60
|
+
node.id = id;
|
|
61
|
+
}
|
|
62
|
+
return { fieldPaths, root };
|
|
63
|
+
};
|
|
64
|
+
var getFieldPathId = (registry, path) => {
|
|
65
|
+
let node = registry.root;
|
|
66
|
+
for (const seg of path) {
|
|
67
|
+
const next = node.children.get(seg);
|
|
68
|
+
if (!next) return void 0;
|
|
69
|
+
node = next;
|
|
70
|
+
}
|
|
71
|
+
return node.id;
|
|
72
|
+
};
|
|
73
|
+
var hashFieldPathIds = (ids) => {
|
|
74
|
+
let hash = 2166136261 >>> 0;
|
|
75
|
+
for (const id of ids) {
|
|
76
|
+
hash ^= id >>> 0;
|
|
77
|
+
hash = Math.imul(hash, 16777619);
|
|
78
|
+
}
|
|
79
|
+
return hash >>> 0;
|
|
80
|
+
};
|
|
81
|
+
var dirtyPathsToDirtySet = (dirtyPaths) => {
|
|
82
|
+
let sawStar = false;
|
|
83
|
+
let hasInvalid = false;
|
|
84
|
+
const roots = [];
|
|
85
|
+
for (const raw of dirtyPaths ?? []) {
|
|
86
|
+
if (raw === "*") {
|
|
87
|
+
sawStar = true;
|
|
88
|
+
continue;
|
|
89
|
+
}
|
|
90
|
+
const normalized = normalizeFieldPath(raw);
|
|
91
|
+
if (!normalized) {
|
|
92
|
+
hasInvalid = true;
|
|
93
|
+
continue;
|
|
94
|
+
}
|
|
95
|
+
roots.push(normalized);
|
|
96
|
+
}
|
|
97
|
+
if (hasInvalid) {
|
|
98
|
+
return { dirtyAll: true, reason: "nonTrackablePatch" };
|
|
99
|
+
}
|
|
100
|
+
const canonical = canonicalizeRootsFast(roots).map(toPathString);
|
|
101
|
+
if (canonical.length === 0) {
|
|
102
|
+
return { dirtyAll: true, reason: sawStar ? "unknownWrite" : "unknownWrite" };
|
|
103
|
+
}
|
|
104
|
+
return { dirtyAll: false, paths: canonical };
|
|
105
|
+
};
|
|
106
|
+
var dirtyPathsToRootIds = (options) => {
|
|
107
|
+
let sawStar = false;
|
|
108
|
+
let hasInvalid = false;
|
|
109
|
+
const roots = [];
|
|
110
|
+
for (const raw of options.dirtyPaths ?? []) {
|
|
111
|
+
if (raw === "*") {
|
|
112
|
+
sawStar = true;
|
|
113
|
+
continue;
|
|
114
|
+
}
|
|
115
|
+
const normalized = normalizeFieldPath(raw);
|
|
116
|
+
if (!normalized) {
|
|
117
|
+
hasInvalid = true;
|
|
118
|
+
continue;
|
|
119
|
+
}
|
|
120
|
+
roots.push(normalized);
|
|
121
|
+
}
|
|
122
|
+
const canonical = canonicalizeRootsFast(roots);
|
|
123
|
+
const rootIds = [];
|
|
124
|
+
let missing = false;
|
|
125
|
+
for (const root of canonical) {
|
|
126
|
+
const id = getFieldPathId(options.registry, root);
|
|
127
|
+
if (id == null) {
|
|
128
|
+
missing = true;
|
|
129
|
+
continue;
|
|
130
|
+
}
|
|
131
|
+
rootIds.push(id);
|
|
132
|
+
}
|
|
133
|
+
const hasSpecific = rootIds.length > 0;
|
|
134
|
+
if (hasInvalid) {
|
|
135
|
+
return {
|
|
136
|
+
dirtyAll: true,
|
|
137
|
+
reason: "nonTrackablePatch",
|
|
138
|
+
rootIds: [],
|
|
139
|
+
rootCount: 0,
|
|
140
|
+
keySize: 0,
|
|
141
|
+
keyHash: 0
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
rootIds.sort((a, b) => a - b);
|
|
145
|
+
if (missing) {
|
|
146
|
+
return {
|
|
147
|
+
dirtyAll: true,
|
|
148
|
+
reason: "fallbackPolicy",
|
|
149
|
+
rootIds: [],
|
|
150
|
+
rootCount: 0,
|
|
151
|
+
keySize: 0,
|
|
152
|
+
keyHash: 0
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
if (!hasSpecific && sawStar) {
|
|
156
|
+
return {
|
|
157
|
+
dirtyAll: true,
|
|
158
|
+
reason: "unknownWrite",
|
|
159
|
+
rootIds: [],
|
|
160
|
+
rootCount: 0,
|
|
161
|
+
keySize: 0,
|
|
162
|
+
keyHash: 0
|
|
163
|
+
};
|
|
164
|
+
}
|
|
165
|
+
const keyHash = hashFieldPathIds(rootIds);
|
|
166
|
+
return {
|
|
167
|
+
dirtyAll: false,
|
|
168
|
+
rootIds,
|
|
169
|
+
rootCount: rootIds.length,
|
|
170
|
+
keySize: rootIds.length,
|
|
171
|
+
keyHash
|
|
172
|
+
};
|
|
173
|
+
};
|
|
174
|
+
var splitSegments = (path) => {
|
|
175
|
+
if (!path) return void 0;
|
|
176
|
+
if (path === "*") return void 0;
|
|
177
|
+
const parts = path.split(".").filter((p) => p.length > 0);
|
|
178
|
+
const segs = [];
|
|
179
|
+
for (const part of parts) {
|
|
180
|
+
if (!part) continue;
|
|
181
|
+
if (part === "*") {
|
|
182
|
+
return void 0;
|
|
183
|
+
}
|
|
184
|
+
if (part.endsWith("[]")) {
|
|
185
|
+
const base = part.slice(0, -2);
|
|
186
|
+
if (base) segs.push(base);
|
|
187
|
+
continue;
|
|
188
|
+
}
|
|
189
|
+
const bracket = /^(.+)\[(\d+)\]$/.exec(part);
|
|
190
|
+
if (bracket) {
|
|
191
|
+
segs.push(bracket[1]);
|
|
192
|
+
continue;
|
|
193
|
+
}
|
|
194
|
+
if (/^\d+$/.test(part)) {
|
|
195
|
+
continue;
|
|
196
|
+
}
|
|
197
|
+
if (part.includes("[") || part.includes("]")) {
|
|
198
|
+
return void 0;
|
|
199
|
+
}
|
|
200
|
+
segs.push(part);
|
|
201
|
+
}
|
|
202
|
+
return segs;
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
export {
|
|
206
|
+
normalizeFieldPath,
|
|
207
|
+
compareFieldPath,
|
|
208
|
+
makeFieldPathIdRegistry,
|
|
209
|
+
getFieldPathId,
|
|
210
|
+
dirtyPathsToDirtySet,
|
|
211
|
+
dirtyPathsToRootIds
|
|
212
|
+
};
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../logix-core/src/internal/field-path.ts"],
  "sourcesContent": ["export type FieldPath = ReadonlyArray<string>\nexport type FieldPathId = number\n\nexport type DirtyAllReason =\n  | \"unknownWrite\"\n  | \"customMutation\"\n  | \"nonTrackablePatch\"\n  | \"fallbackPolicy\"\n\nexport type DirtySet =\n  | {\n      readonly dirtyAll: true\n      readonly reason: DirtyAllReason\n    }\n  | {\n      readonly dirtyAll: false\n      readonly paths: ReadonlyArray<string>\n    }\n\ninterface FieldPathTrieNode {\n  id?: FieldPathId\n  children: Map<string, FieldPathTrieNode>\n}\n\nexport interface FieldPathIdRegistry {\n  readonly fieldPaths: ReadonlyArray<FieldPath>\n  readonly root: FieldPathTrieNode\n}\n\nexport const isFieldPathSegment = (seg: string): boolean => {\n  if (!seg) return false\n  if (seg === \"*\") return false\n  if (/^\\d+$/.test(seg)) return false\n  if (seg.includes(\"[\") || seg.includes(\"]\")) return false\n  return true\n}\n\nexport const normalizeFieldPath = (input: string | FieldPath): FieldPath | undefined => {\n  const segs = typeof input === \"string\"\n    ? splitSegments(input)\n    : input.slice()\n\n  if (!segs || segs.length === 0) return undefined\n  const normalized = segs.filter(isFieldPathSegment)\n  return normalized.length > 0 ? normalized : undefined\n}\n\nexport const compareFieldPath = (a: FieldPath, b: FieldPath): number => {\n  const len = Math.min(a.length, b.length)\n  for (let i = 0; i < len; i++) {\n    const as = a[i]!\n    const bs = b[i]!\n    if (as === bs) continue\n    return as < bs ? -1 : 1\n  }\n  return a.length - b.length\n}\n\nexport const isPrefixOf = (prefix: FieldPath, full: FieldPath): boolean => {\n  if (prefix.length > full.length) return false\n  for (let i = 0; i < prefix.length; i++) {\n    if (prefix[i] !== full[i]) return false\n  }\n  return true\n}\n\nexport const toKey = (path: FieldPath): string => JSON.stringify(path)\n\nexport const toPathString = (path: FieldPath): string => path.join(\".\")\n\nexport const canonicalizeRoots = (\n  roots: Iterable<FieldPath>,\n): ReadonlyArray<FieldPath> => {\n  const byKey = new Map<string, FieldPath>()\n  for (const root of roots) {\n    const key = toKey(root)\n    if (!byKey.has(key)) byKey.set(key, root)\n  }\n\n  const sorted = Array.from(byKey.values()).sort(compareFieldPath)\n  const out: Array<FieldPath> = []\n  for (const next of sorted) {\n    const prev = out[out.length - 1]\n    if (prev && isPrefixOf(prev, next)) {\n      continue\n    }\n    out.push(next)\n  }\n  return out\n}\n\nexport const canonicalizeRootsFast = (\n  roots: Iterable<FieldPath>,\n): ReadonlyArray<FieldPath> => {\n  const sorted = Array.from(roots).sort(compareFieldPath)\n  const out: Array<FieldPath> = []\n  for (const next of sorted) {\n    const prev = out[out.length - 1]\n    if (prev && isPrefixOf(prev, next)) continue\n    out.push(next)\n  }\n  return out\n}\n\nexport const makeFieldPathIdRegistry = (\n  fieldPaths: ReadonlyArray<FieldPath>,\n): FieldPathIdRegistry => {\n  const root: FieldPathTrieNode = { children: new Map() }\n\n  for (let id = 0; id < fieldPaths.length; id++) {\n    const path = fieldPaths[id]!\n    let node = root\n    for (const seg of path) {\n      const children = node.children\n      let next = children.get(seg)\n      if (!next) {\n        next = { children: new Map() }\n        children.set(seg, next)\n      }\n      node = next\n    }\n    node.id = id\n  }\n\n  return { fieldPaths, root }\n}\n\nexport const getFieldPathId = (\n  registry: FieldPathIdRegistry,\n  path: FieldPath,\n): FieldPathId | undefined => {\n  let node = registry.root\n  for (const seg of path) {\n    const next = node.children.get(seg)\n    if (!next) return undefined\n    node = next\n  }\n  return node.id\n}\n\nexport const getFieldPathIdFromString = (\n  registry: FieldPathIdRegistry,\n  path: string,\n): FieldPathId | undefined => {\n  if (!path || path === \"*\") return undefined\n  const normalized = normalizeFieldPath(path)\n  if (!normalized) return undefined\n  return getFieldPathId(registry, normalized)\n}\n\nexport const hashFieldPathIds = (ids: ReadonlyArray<number>): number => {\n  // FNV-1a (32-bit)\n  let hash = 2166136261 >>> 0\n  for (const id of ids) {\n    hash ^= (id >>> 0)\n    hash = Math.imul(hash, 16777619)\n  }\n  return hash >>> 0\n}\n\nexport interface DirtyRootIds {\n  readonly dirtyAll: boolean\n  readonly reason?: DirtyAllReason\n  readonly rootIds: ReadonlyArray<FieldPathId>\n  readonly rootCount: number\n  readonly keySize: number\n  readonly keyHash: number\n}\n\nexport const dirtyPathsToDirtySet = (dirtyPaths?: Iterable<string>): DirtySet => {\n  let sawStar = false\n  let hasInvalid = false\n\n  const roots: Array<FieldPath> = []\n  for (const raw of dirtyPaths ?? []) {\n    if (raw === \"*\") {\n      sawStar = true\n      continue\n    }\n    const normalized = normalizeFieldPath(raw)\n    if (!normalized) {\n      hasInvalid = true\n      continue\n    }\n    roots.push(normalized)\n  }\n\n  if (hasInvalid) {\n    return { dirtyAll: true, reason: \"nonTrackablePatch\" }\n  }\n\n  const canonical = canonicalizeRootsFast(roots).map(toPathString)\n\n  if (canonical.length === 0) {\n    return { dirtyAll: true, reason: sawStar ? \"unknownWrite\" : \"unknownWrite\" }\n  }\n\n  return { dirtyAll: false, paths: canonical }\n}\n\nexport const dirtyPathsToRootIds = (options: {\n  readonly dirtyPaths?: Iterable<string>\n  readonly registry: FieldPathIdRegistry\n}): DirtyRootIds => {\n  let sawStar = false\n  let hasInvalid = false\n\n  const roots: Array<FieldPath> = []\n  for (const raw of options.dirtyPaths ?? []) {\n    if (raw === \"*\") {\n      sawStar = true\n      continue\n    }\n    const normalized = normalizeFieldPath(raw)\n    if (!normalized) {\n      hasInvalid = true\n      continue\n    }\n    roots.push(normalized)\n  }\n\n  const canonical = canonicalizeRootsFast(roots)\n  const rootIds: Array<number> = []\n  let missing = false\n  for (const root of canonical) {\n    const id = getFieldPathId(options.registry, root)\n    if (id == null) {\n      missing = true\n      continue\n    }\n    rootIds.push(id)\n  }\n\n  const hasSpecific = rootIds.length > 0\n  if (hasInvalid) {\n    return {\n      dirtyAll: true,\n      reason: \"nonTrackablePatch\",\n      rootIds: [],\n      rootCount: 0,\n      keySize: 0,\n      keyHash: 0,\n    }\n  }\n\n  rootIds.sort((a, b) => a - b)\n\n  if (missing) {\n    return {\n      dirtyAll: true,\n      reason: \"fallbackPolicy\",\n      rootIds: [],\n      rootCount: 0,\n      keySize: 0,\n      keyHash: 0,\n    }\n  }\n\n  if (!hasSpecific && sawStar) {\n    return {\n      dirtyAll: true,\n      reason: \"unknownWrite\",\n      rootIds: [],\n      rootCount: 0,\n      keySize: 0,\n      keyHash: 0,\n    }\n  }\n\n  const keyHash = hashFieldPathIds(rootIds)\n  return {\n    dirtyAll: false,\n    rootIds,\n    rootCount: rootIds.length,\n    keySize: rootIds.length,\n    keyHash,\n  }\n}\n\nconst splitSegments = (path: string): Array<string> | undefined => {\n  if (!path) return undefined\n  if (path === \"*\") return undefined\n\n  const parts = path.split(\".\").filter((p) => p.length > 0)\n  const segs: Array<string> = []\n\n  for (const part of parts) {\n    if (!part) continue\n    if (part === \"*\") {\n      return undefined\n    }\n    if (part.endsWith(\"[]\")) {\n      const base = part.slice(0, -2)\n      if (base) segs.push(base)\n      continue\n    }\n    const bracket = /^(.+)\\[(\\d+)\\]$/.exec(part)\n    if (bracket) {\n      segs.push(bracket[1]!)\n      continue\n    }\n    if (/^\\d+$/.test(part)) {\n      continue\n    }\n    if (part.includes(\"[\") || part.includes(\"]\")) {\n      return undefined\n    }\n    segs.push(part)\n  }\n\n  return segs\n}\n"],
  "mappings": ";;;;AA6BO,IAAM,qBAAqB,CAAC,QAAyB;AAC1D,MAAI,CAAC,IAAK,QAAO;AACjB,MAAI,QAAQ,IAAK,QAAO;AACxB,MAAI,QAAQ,KAAK,GAAG,EAAG,QAAO;AAC9B,MAAI,IAAI,SAAS,GAAG,KAAK,IAAI,SAAS,GAAG,EAAG,QAAO;AACnD,SAAO;AACT;AAEO,IAAM,qBAAqB,CAAC,UAAqD;AACtF,QAAM,OAAO,OAAO,UAAU,WAC1B,cAAc,KAAK,IACnB,MAAM,MAAM;AAEhB,MAAI,CAAC,QAAQ,KAAK,WAAW,EAAG,QAAO;AACvC,QAAM,aAAa,KAAK,OAAO,kBAAkB;AACjD,SAAO,WAAW,SAAS,IAAI,aAAa;AAC9C;AAEO,IAAM,mBAAmB,CAAC,GAAc,MAAyB;AACtE,QAAM,MAAM,KAAK,IAAI,EAAE,QAAQ,EAAE,MAAM;AACvC,WAAS,IAAI,GAAG,IAAI,KAAK,KAAK;AAC5B,UAAM,KAAK,EAAE,CAAC;AACd,UAAM,KAAK,EAAE,CAAC;AACd,QAAI,OAAO,GAAI;AACf,WAAO,KAAK,KAAK,KAAK;AAAA,EACxB;AACA,SAAO,EAAE,SAAS,EAAE;AACtB;AAEO,IAAM,aAAa,CAAC,QAAmB,SAA6B;AACzE,MAAI,OAAO,SAAS,KAAK,OAAQ,QAAO;AACxC,WAAS,IAAI,GAAG,IAAI,OAAO,QAAQ,KAAK;AACtC,QAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAG,QAAO;AAAA,EACpC;AACA,SAAO;AACT;AAIO,IAAM,eAAe,CAAC,SAA4B,KAAK,KAAK,GAAG;AAuB/D,IAAM,wBAAwB,CACnC,UAC6B;AAC7B,QAAM,SAAS,MAAM,KAAK,KAAK,EAAE,KAAK,gBAAgB;AACtD,QAAM,MAAwB,CAAC;AAC/B,aAAW,QAAQ,QAAQ;AACzB,UAAM,OAAO,IAAI,IAAI,SAAS,CAAC;AAC/B,QAAI,QAAQ,WAAW,MAAM,IAAI,EAAG;AACpC,QAAI,KAAK,IAAI;AAAA,EACf;AACA,SAAO;AACT;AAEO,IAAM,0BAA0B,CACrC,eACwB;AACxB,QAAM,OAA0B,EAAE,UAAU,oBAAI,IAAI,EAAE;AAEtD,WAAS,KAAK,GAAG,KAAK,WAAW,QAAQ,MAAM;AAC7C,UAAM,OAAO,WAAW,EAAE;AAC1B,QAAI,OAAO;AACX,eAAW,OAAO,MAAM;AACtB,YAAM,WAAW,KAAK;AACtB,UAAI,OAAO,SAAS,IAAI,GAAG;AAC3B,UAAI,CAAC,MAAM;AACT,eAAO,EAAE,UAAU,oBAAI,IAAI,EAAE;AAC7B,iBAAS,IAAI,KAAK,IAAI;AAAA,MACxB;AACA,aAAO;AAAA,IACT;AACA,SAAK,KAAK;AAAA,EACZ;AAEA,SAAO,EAAE,YAAY,KAAK;AAC5B;AAEO,IAAM,iBAAiB,CAC5B,UACA,SAC4B;AAC5B,MAAI,OAAO,SAAS;AACpB,aAAW,OAAO,MAAM;AACtB,UAAM,OAAO,KAAK,SAAS,IAAI,GAAG;AAClC,QAAI,CAAC,KAAM,QAAO;AAClB,WAAO;AAAA,EACT;AACA,SAAO,KAAK;AACd;AAYO,IAAM,mBAAmB,CAAC,QAAuC;AAEtE,MAAI,OAAO,eAAe;AAC1B,aAAW,MAAM,KAAK;AACpB,YAAS,OAAO;AAChB,WAAO,KAAK,KAAK,MAAM,QAAQ;AAAA,EACjC;AACA,SAAO,SAAS;AAClB;AAWO,IAAM,uBAAuB,CAAC,eAA4C;AAC/E,MAAI,UAAU;AACd,MAAI,aAAa;AAEjB,QAAM,QAA0B,CAAC;AACjC,aAAW,OAAO,cAAc,CAAC,GAAG;AAClC,QAAI,QAAQ,KAAK;AACf,gBAAU;AACV;AAAA,IACF;AACA,UAAM,aAAa,mBAAmB,GAAG;AACzC,QAAI,CAAC,YAAY;AACf,mBAAa;AACb;AAAA,IACF;AACA,UAAM,KAAK,UAAU;AAAA,EACvB;AAEA,MAAI,YAAY;AACd,WAAO,EAAE,UAAU,MAAM,QAAQ,oBAAoB;AAAA,EACvD;AAEA,QAAM,YAAY,sBAAsB,KAAK,EAAE,IAAI,YAAY;AAE/D,MAAI,UAAU,WAAW,GAAG;AAC1B,WAAO,EAAE,UAAU,MAAM,QAAQ,UAAU,iBAAiB,eAAe;AAAA,EAC7E;AAEA,SAAO,EAAE,UAAU,OAAO,OAAO,UAAU;AAC7C;AAEO,IAAM,sBAAsB,CAAC,YAGhB;AAClB,MAAI,UAAU;AACd,MAAI,aAAa;AAEjB,QAAM,QAA0B,CAAC;AACjC,aAAW,OAAO,QAAQ,cAAc,CAAC,GAAG;AAC1C,QAAI,QAAQ,KAAK;AACf,gBAAU;AACV;AAAA,IACF;AACA,UAAM,aAAa,mBAAmB,GAAG;AACzC,QAAI,CAAC,YAAY;AACf,mBAAa;AACb;AAAA,IACF;AACA,UAAM,KAAK,UAAU;AAAA,EACvB;AAEA,QAAM,YAAY,sBAAsB,KAAK;AAC7C,QAAM,UAAyB,CAAC;AAChC,MAAI,UAAU;AACd,aAAW,QAAQ,WAAW;AAC5B,UAAM,KAAK,eAAe,QAAQ,UAAU,IAAI;AAChD,QAAI,MAAM,MAAM;AACd,gBAAU;AACV;AAAA,IACF;AACA,YAAQ,KAAK,EAAE;AAAA,EACjB;AAEA,QAAM,cAAc,QAAQ,SAAS;AACrC,MAAI,YAAY;AACd,WAAO;AAAA,MACL,UAAU;AAAA,MACV,QAAQ;AAAA,MACR,SAAS,CAAC;AAAA,MACV,WAAW;AAAA,MACX,SAAS;AAAA,MACT,SAAS;AAAA,IACX;AAAA,EACF;AAEA,UAAQ,KAAK,CAAC,GAAG,MAAM,IAAI,CAAC;AAE5B,MAAI,SAAS;AACX,WAAO;AAAA,MACL,UAAU;AAAA,MACV,QAAQ;AAAA,MACR,SAAS,CAAC;AAAA,MACV,WAAW;AAAA,MACX,SAAS;AAAA,MACT,SAAS;AAAA,IACX;AAAA,EACF;AAEA,MAAI,CAAC,eAAe,SAAS;AAC3B,WAAO;AAAA,MACL,UAAU;AAAA,MACV,QAAQ;AAAA,MACR,SAAS,CAAC;AAAA,MACV,WAAW;AAAA,MACX,SAAS;AAAA,MACT,SAAS;AAAA,IACX;AAAA,EACF;AAEA,QAAM,UAAU,iBAAiB,OAAO;AACxC,SAAO;AAAA,IACL,UAAU;AAAA,IACV;AAAA,IACA,WAAW,QAAQ;AAAA,IACnB,SAAS,QAAQ;AAAA,IACjB;AAAA,EACF;AACF;AAEA,IAAM,gBAAgB,CAAC,SAA4C;AACjE,MAAI,CAAC,KAAM,QAAO;AAClB,MAAI,SAAS,IAAK,QAAO;AAEzB,QAAM,QAAQ,KAAK,MAAM,GAAG,EAAE,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC;AACxD,QAAM,OAAsB,CAAC;AAE7B,aAAW,QAAQ,OAAO;AACxB,QAAI,CAAC,KAAM;AACX,QAAI,SAAS,KAAK;AAChB,aAAO;AAAA,IACT;AACA,QAAI,KAAK,SAAS,IAAI,GAAG;AACvB,YAAM,OAAO,KAAK,MAAM,GAAG,EAAE;AAC7B,UAAI,KAAM,MAAK,KAAK,IAAI;AACxB;AAAA,IACF;AACA,UAAM,UAAU,kBAAkB,KAAK,IAAI;AAC3C,QAAI,SAAS;AACX,WAAK,KAAK,QAAQ,CAAC,CAAE;AACrB;AAAA,IACF;AACA,QAAI,QAAQ,KAAK,IAAI,GAAG;AACtB;AAAA,IACF;AACA,QAAI,KAAK,SAAS,GAAG,KAAK,KAAK,SAAS,GAAG,GAAG;AAC5C,aAAO;AAAA,IACT;AACA,SAAK,KAAK,IAAI;AAAA,EAChB;AAEA,SAAO;AACT;",
  "names": []
}

|
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
// @logix/core subpath bundles for @logix/sandbox
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
// ../logix-core/src/internal/state-trait/rowid.ts
|
|
5
|
+
var parseSegments = (path) => {
|
|
6
|
+
if (!path) return [];
|
|
7
|
+
return path.split(".").map(
|
|
8
|
+
(seg) => /^[0-9]+$/.test(seg) ? Number(seg) : seg
|
|
9
|
+
);
|
|
10
|
+
};
|
|
11
|
+
var getAtPath = (state, path) => {
|
|
12
|
+
if (!path || state == null) return state;
|
|
13
|
+
const segments = parseSegments(path);
|
|
14
|
+
let current = state;
|
|
15
|
+
for (const seg of segments) {
|
|
16
|
+
if (current == null) return void 0;
|
|
17
|
+
if (typeof seg === "number") {
|
|
18
|
+
current = Array.isArray(current) ? current[seg] : current[String(seg)];
|
|
19
|
+
continue;
|
|
20
|
+
}
|
|
21
|
+
current = current[seg];
|
|
22
|
+
}
|
|
23
|
+
return current;
|
|
24
|
+
};
|
|
25
|
+
var setAtPathMutating = (draft, path, value) => {
|
|
26
|
+
if (!path) return;
|
|
27
|
+
const segments = parseSegments(path);
|
|
28
|
+
if (segments.length === 0) return;
|
|
29
|
+
let current = draft;
|
|
30
|
+
for (let i = 0; i < segments.length - 1; i++) {
|
|
31
|
+
const key = segments[i];
|
|
32
|
+
const nextKey = segments[i + 1];
|
|
33
|
+
const next = current?.[key];
|
|
34
|
+
if (next == null || typeof next !== "object") {
|
|
35
|
+
current[key] = typeof nextKey === "number" ? [] : {};
|
|
36
|
+
}
|
|
37
|
+
current = current[key];
|
|
38
|
+
}
|
|
39
|
+
const last = segments[segments.length - 1];
|
|
40
|
+
current[last] = value;
|
|
41
|
+
};
|
|
42
|
+
var unsetAtPathMutating = (draft, path) => {
|
|
43
|
+
if (!path) return;
|
|
44
|
+
const segments = parseSegments(path);
|
|
45
|
+
if (segments.length === 0) return;
|
|
46
|
+
let current = draft;
|
|
47
|
+
for (let i = 0; i < segments.length - 1; i++) {
|
|
48
|
+
const key = segments[i];
|
|
49
|
+
const next = current?.[key];
|
|
50
|
+
if (next == null || typeof next !== "object") {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
current = next;
|
|
54
|
+
}
|
|
55
|
+
const last = segments[segments.length - 1];
|
|
56
|
+
if (Array.isArray(current) && typeof last === "number") {
|
|
57
|
+
current[last] = void 0;
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
if (current && typeof current === "object") {
|
|
61
|
+
delete current[last];
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
var parseListItemFieldPath = (fieldPath) => {
|
|
65
|
+
const idx = fieldPath.indexOf("[]");
|
|
66
|
+
if (idx < 0) return void 0;
|
|
67
|
+
if (fieldPath.indexOf("[]", idx + 2) >= 0) return void 0;
|
|
68
|
+
const listPath = fieldPath.slice(0, idx);
|
|
69
|
+
const rest = fieldPath.slice(idx + 2);
|
|
70
|
+
const itemPath = rest.startsWith(".") ? rest.slice(1) : rest;
|
|
71
|
+
return { listPath, itemPath };
|
|
72
|
+
};
|
|
73
|
+
var toListItemValuePath = (listPath, index, itemPath) => itemPath ? `${listPath}.${index}.${itemPath}` : `${listPath}.${index}`;
|
|
74
|
+
var readTrackBy = (item, trackBy) => {
|
|
75
|
+
if (!item || typeof item !== "object") return void 0;
|
|
76
|
+
const segments = trackBy.split(".");
|
|
77
|
+
let current = item;
|
|
78
|
+
for (const seg of segments) {
|
|
79
|
+
if (current == null) return void 0;
|
|
80
|
+
current = current[seg];
|
|
81
|
+
}
|
|
82
|
+
return current;
|
|
83
|
+
};
|
|
84
|
+
var didReorderByReference = (prevItems, nextItems) => {
|
|
85
|
+
const buckets = /* @__PURE__ */ new Map();
|
|
86
|
+
for (let i = 0; i < prevItems.length; i++) {
|
|
87
|
+
const item = prevItems[i];
|
|
88
|
+
const list = buckets.get(item) ?? [];
|
|
89
|
+
list.push(i);
|
|
90
|
+
buckets.set(item, list);
|
|
91
|
+
}
|
|
92
|
+
for (let nextIndex = 0; nextIndex < nextItems.length; nextIndex++) {
|
|
93
|
+
const item = nextItems[nextIndex];
|
|
94
|
+
const q = buckets.get(item);
|
|
95
|
+
if (!q || q.length === 0) continue;
|
|
96
|
+
const prevIndex = q.shift();
|
|
97
|
+
if (prevIndex !== nextIndex) {
|
|
98
|
+
return true;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
return false;
|
|
102
|
+
};
|
|
103
|
+
var hasStableTrackByKeys = (items, trackBy) => items.every((item) => readTrackBy(item, trackBy) !== void 0);
|
|
104
|
+
var isSameTrackBySequence = (prevItems, nextItems, trackBy) => {
|
|
105
|
+
if (prevItems.length !== nextItems.length) return false;
|
|
106
|
+
for (let i = 0; i < prevItems.length; i++) {
|
|
107
|
+
if (!Object.is(
|
|
108
|
+
readTrackBy(prevItems[i], trackBy),
|
|
109
|
+
readTrackBy(nextItems[i], trackBy)
|
|
110
|
+
)) {
|
|
111
|
+
return false;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
return true;
|
|
115
|
+
};
|
|
116
|
+
var reconcileIds = (prev, nextItems, trackBy, makeRowId) => {
|
|
117
|
+
const nextRowId = makeRowId ?? /* @__PURE__ */ (() => {
|
|
118
|
+
let rowSeq = 0;
|
|
119
|
+
return () => {
|
|
120
|
+
rowSeq += 1;
|
|
121
|
+
return `r${rowSeq}`;
|
|
122
|
+
};
|
|
123
|
+
})();
|
|
124
|
+
if (!prev) {
|
|
125
|
+
return {
|
|
126
|
+
ids: nextItems.map(() => nextRowId()),
|
|
127
|
+
removed: []
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
if (prev.itemsRef === nextItems) {
|
|
131
|
+
return {
|
|
132
|
+
ids: prev.ids,
|
|
133
|
+
removed: []
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
const sameLength = prev.itemsRef.length === nextItems.length;
|
|
137
|
+
if (sameLength) {
|
|
138
|
+
if (trackBy) {
|
|
139
|
+
const canUseKeys = hasStableTrackByKeys(prev.itemsRef, trackBy) && hasStableTrackByKeys(nextItems, trackBy);
|
|
140
|
+
if (canUseKeys) {
|
|
141
|
+
if (isSameTrackBySequence(prev.itemsRef, nextItems, trackBy)) {
|
|
142
|
+
return {
|
|
143
|
+
ids: prev.ids,
|
|
144
|
+
removed: []
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
} else {
|
|
148
|
+
if (!didReorderByReference(prev.itemsRef, nextItems)) {
|
|
149
|
+
return {
|
|
150
|
+
ids: prev.ids,
|
|
151
|
+
removed: []
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
} else if (!didReorderByReference(prev.itemsRef, nextItems)) {
|
|
156
|
+
return {
|
|
157
|
+
ids: prev.ids,
|
|
158
|
+
removed: []
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
const keyOf = (item) => {
|
|
163
|
+
if (!trackBy) return item;
|
|
164
|
+
const k = readTrackBy(item, trackBy);
|
|
165
|
+
return k !== void 0 ? k : item;
|
|
166
|
+
};
|
|
167
|
+
const buckets = /* @__PURE__ */ new Map();
|
|
168
|
+
for (let i = 0; i < prev.itemsRef.length; i++) {
|
|
169
|
+
const key = keyOf(prev.itemsRef[i]);
|
|
170
|
+
const list = buckets.get(key) ?? [];
|
|
171
|
+
list.push(prev.ids[i]);
|
|
172
|
+
buckets.set(key, list);
|
|
173
|
+
}
|
|
174
|
+
const ids = [];
|
|
175
|
+
for (let i = 0; i < nextItems.length; i++) {
|
|
176
|
+
const key = keyOf(nextItems[i]);
|
|
177
|
+
const list = buckets.get(key);
|
|
178
|
+
if (list && list.length > 0) {
|
|
179
|
+
ids.push(list.shift());
|
|
180
|
+
} else {
|
|
181
|
+
ids.push(nextRowId());
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
const removed = [];
|
|
185
|
+
for (const list of buckets.values()) {
|
|
186
|
+
removed.push(...list);
|
|
187
|
+
}
|
|
188
|
+
return { ids, removed };
|
|
189
|
+
};
|
|
190
|
+
var buildIndexById = (ids) => {
|
|
191
|
+
const map = /* @__PURE__ */ new Map();
|
|
192
|
+
for (let i = 0; i < ids.length; i++) {
|
|
193
|
+
map.set(ids[i], i);
|
|
194
|
+
}
|
|
195
|
+
return map;
|
|
196
|
+
};
|
|
197
|
+
var RowIdStore = class {
|
|
198
|
+
constructor(instanceId) {
|
|
199
|
+
this.instanceId = instanceId;
|
|
200
|
+
this.lists = /* @__PURE__ */ new Map();
|
|
201
|
+
this.removalListeners = /* @__PURE__ */ new Map();
|
|
202
|
+
this.nextRowSeq = 0;
|
|
203
|
+
this.makeRowId = () => {
|
|
204
|
+
this.nextRowSeq += 1;
|
|
205
|
+
return this.instanceId ? `${this.instanceId}::r${this.nextRowSeq}` : `r${this.nextRowSeq}`;
|
|
206
|
+
};
|
|
207
|
+
}
|
|
208
|
+
onRemoved(listPath, listener) {
|
|
209
|
+
const set = this.removalListeners.get(listPath) ?? /* @__PURE__ */ new Set();
|
|
210
|
+
set.add(listener);
|
|
211
|
+
this.removalListeners.set(listPath, set);
|
|
212
|
+
return () => {
|
|
213
|
+
const current = this.removalListeners.get(listPath);
|
|
214
|
+
if (!current) return;
|
|
215
|
+
current.delete(listener);
|
|
216
|
+
if (current.size === 0) this.removalListeners.delete(listPath);
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
getRowId(listPath, index) {
|
|
220
|
+
const state = this.lists.get(listPath);
|
|
221
|
+
return state ? state.ids[index] : void 0;
|
|
222
|
+
}
|
|
223
|
+
getIndex(listPath, rowId) {
|
|
224
|
+
const state = this.lists.get(listPath);
|
|
225
|
+
if (!state) return void 0;
|
|
226
|
+
return state.indexById.get(rowId);
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* ensureList:
|
|
230
|
+
* - 让指定 listPath 的 RowID 映射与当前 items 对齐;
|
|
231
|
+
* - 返回最新的 ids(index -> RowId)。
|
|
232
|
+
*/
|
|
233
|
+
ensureList(listPath, items, trackBy) {
|
|
234
|
+
const prev = this.lists.get(listPath);
|
|
235
|
+
const { ids, removed } = reconcileIds(prev, items, trackBy ?? prev?.trackBy, this.makeRowId);
|
|
236
|
+
const next = {
|
|
237
|
+
itemsRef: items,
|
|
238
|
+
ids,
|
|
239
|
+
indexById: buildIndexById(ids),
|
|
240
|
+
trackBy: trackBy ?? prev?.trackBy
|
|
241
|
+
};
|
|
242
|
+
this.lists.set(listPath, next);
|
|
243
|
+
if (removed.length > 0) {
|
|
244
|
+
const listeners = this.removalListeners.get(listPath);
|
|
245
|
+
if (listeners && listeners.size > 0) {
|
|
246
|
+
for (const rowId of removed) {
|
|
247
|
+
for (const fn of listeners) {
|
|
248
|
+
try {
|
|
249
|
+
fn(rowId);
|
|
250
|
+
} catch {
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
return ids;
|
|
257
|
+
}
|
|
258
|
+
/**
|
|
259
|
+
* updateAll:
|
|
260
|
+
* - 在每次提交后对齐所有已知 list 的 RowID 映射;
|
|
261
|
+
* - configs 来自 StateTraitProgram.spec 中的 list 声明(可携带 trackBy)。
|
|
262
|
+
*/
|
|
263
|
+
updateAll(state, configs) {
|
|
264
|
+
for (const cfg of configs) {
|
|
265
|
+
const value = getAtPath(state, cfg.path);
|
|
266
|
+
const items = Array.isArray(value) ? value : [];
|
|
267
|
+
this.ensureList(cfg.path, items, cfg.trackBy);
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
};
|
|
271
|
+
var collectListConfigs = (spec) => {
|
|
272
|
+
const configs = [];
|
|
273
|
+
for (const key in spec) {
|
|
274
|
+
if (!Object.prototype.hasOwnProperty.call(spec, key)) continue;
|
|
275
|
+
const raw = spec[key];
|
|
276
|
+
if (!raw || typeof raw !== "object") continue;
|
|
277
|
+
const tag = raw._tag;
|
|
278
|
+
if (tag !== "StateTraitList") continue;
|
|
279
|
+
const trackBy = raw.identityHint?.trackBy;
|
|
280
|
+
configs.push({
|
|
281
|
+
path: key,
|
|
282
|
+
trackBy: typeof trackBy === "string" ? trackBy : void 0
|
|
283
|
+
});
|
|
284
|
+
}
|
|
285
|
+
return configs;
|
|
286
|
+
};
|
|
287
|
+
|
|
288
|
+
// ../logix-core/src/internal/runtime/core/ReplayLog.ts
|
|
289
|
+
import { Context, Effect, Layer } from "../effect.js";
|
|
290
|
+
var ReplayLog = class extends Context.Tag("@logix/core/ReplayLog")() {
|
|
291
|
+
};
|
|
292
|
+
var snapshot = Effect.gen(function* () {
|
|
293
|
+
const log = yield* ReplayLog;
|
|
294
|
+
return yield* log.snapshot;
|
|
295
|
+
});
|
|
296
|
+
var resetCursor = Effect.gen(
|
|
297
|
+
function* () {
|
|
298
|
+
const log = yield* ReplayLog;
|
|
299
|
+
yield* log.resetCursor;
|
|
300
|
+
}
|
|
301
|
+
);
|
|
302
|
+
|
|
303
|
+
export {
|
|
304
|
+
ReplayLog,
|
|
305
|
+
getAtPath,
|
|
306
|
+
setAtPathMutating,
|
|
307
|
+
unsetAtPathMutating,
|
|
308
|
+
parseListItemFieldPath,
|
|
309
|
+
toListItemValuePath,
|
|
310
|
+
RowIdStore,
|
|
311
|
+
collectListConfigs
|
|
312
|
+
};
|
|
313
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../logix-core/src/internal/state-trait/rowid.ts", "../../../../logix-core/src/internal/runtime/core/ReplayLog.ts"],
  "sourcesContent": ["export type RowId = string\n\nexport interface ListConfig {\n  readonly path: string\n  readonly trackBy?: string\n}\n\nexport type ListRemovalListener = (rowId: RowId) => void\n\ntype Segment = string | number\n\nconst parseSegments = (path: string): ReadonlyArray<Segment> => {\n  if (!path) return []\n  return path.split(\".\").map((seg) =>\n    /^[0-9]+$/.test(seg) ? Number(seg) : seg,\n  )\n}\n\nexport const getAtPath = (state: any, path: string): any => {\n  if (!path || state == null) return state\n  const segments = parseSegments(path)\n  let current: any = state\n  for (const seg of segments) {\n    if (current == null) return undefined\n    if (typeof seg === \"number\") {\n      current = Array.isArray(current) ? current[seg] : current[String(seg)]\n      continue\n    }\n    current = current[seg]\n  }\n  return current\n}\n\nexport const setAtPathMutating = (draft: any, path: string, value: any): void => {\n  if (!path) return\n  const segments = parseSegments(path)\n  if (segments.length === 0) return\n\n  let current: any = draft\n  for (let i = 0; i < segments.length - 1; i++) {\n    const key = segments[i]!\n    const nextKey = segments[i + 1]!\n\n    const next = current?.[key as any]\n    if (next == null || typeof next !== \"object\") {\n      current[key as any] = typeof nextKey === \"number\" ? [] : {}\n    }\n    current = current[key as any]\n  }\n\n  const last = segments[segments.length - 1]!\n  current[last as any] = value\n}\n\nexport const unsetAtPathMutating = (draft: any, path: string): void => {\n  if (!path) return\n  const segments = parseSegments(path)\n  if (segments.length === 0) return\n\n  let current: any = draft\n  for (let i = 0; i < segments.length - 1; i++) {\n    const key = segments[i]!\n    const next = current?.[key as any]\n    if (next == null || typeof next !== \"object\") {\n      return\n    }\n    current = next\n  }\n\n  const last = segments[segments.length - 1]!\n  if (Array.isArray(current) && typeof last === \"number\") {\n    current[last] = undefined\n    return\n  }\n\n  if (current && typeof current === \"object\") {\n    delete current[last as any]\n  }\n}\n\nexport const joinPath = (prefix: string, suffix: string): string => {\n  if (!prefix) return suffix\n  if (!suffix) return prefix\n  return `${prefix}.${suffix}`\n}\n\nexport interface ListItemFieldPath {\n  readonly listPath: string\n  readonly itemPath: string\n}\n\n/**\n * parseListItemFieldPath\uFF1A\n * - \u8BC6\u522B\u5F62\u5982 \"items[].profileResource\" \u7684 list.item \u5B57\u6BB5\u8DEF\u5F84\uFF1B\n * - \u4EC5\u652F\u6301\u5355\u5C42 \"[]\"\uFF0C\u591A\u5C42\u5D4C\u5957\u6570\u7EC4\u5728\u540E\u7EED\u9636\u6BB5\u518D\u589E\u5F3A\u3002\n */\nexport const parseListItemFieldPath = (fieldPath: string): ListItemFieldPath | undefined => {\n  const idx = fieldPath.indexOf(\"[]\")\n  if (idx < 0) return undefined\n  if (fieldPath.indexOf(\"[]\", idx + 2) >= 0) return undefined\n\n  const listPath = fieldPath.slice(0, idx)\n  const rest = fieldPath.slice(idx + 2)\n  const itemPath = rest.startsWith(\".\") ? rest.slice(1) : rest\n  return { listPath, itemPath }\n}\n\nexport const toListItemValuePath = (\n  listPath: string,\n  index: number,\n  itemPath: string,\n): string =>\n  itemPath ? `${listPath}.${index}.${itemPath}` : `${listPath}.${index}`\n\ntype ListState = {\n  readonly itemsRef: ReadonlyArray<unknown>\n  readonly ids: ReadonlyArray<RowId>\n  readonly indexById: ReadonlyMap<RowId, number>\n  readonly trackBy?: string\n}\n\nconst readTrackBy = (item: unknown, trackBy: string): unknown => {\n  if (!item || typeof item !== \"object\") return undefined\n  const segments = trackBy.split(\".\")\n  let current: any = item\n  for (const seg of segments) {\n    if (current == null) return undefined\n    current = current[seg as any]\n  }\n  return current\n}\n\nconst didReorderByReference = (\n  prevItems: ReadonlyArray<unknown>,\n  nextItems: ReadonlyArray<unknown>,\n): boolean => {\n  const buckets = new Map<unknown, Array<number>>()\n  for (let i = 0; i < prevItems.length; i++) {\n    const item = prevItems[i]\n    const list = buckets.get(item) ?? []\n    list.push(i)\n    buckets.set(item, list)\n  }\n\n  for (let nextIndex = 0; nextIndex < nextItems.length; nextIndex++) {\n    const item = nextItems[nextIndex]\n    const q = buckets.get(item)\n    if (!q || q.length === 0) continue\n    const prevIndex = q.shift()!\n    if (prevIndex !== nextIndex) {\n      return true\n    }\n  }\n\n  return false\n}\n\nconst hasStableTrackByKeys = (\n  items: ReadonlyArray<unknown>,\n  trackBy: string,\n): boolean => items.every((item) => readTrackBy(item, trackBy) !== undefined)\n\nconst isSameTrackBySequence = (\n  prevItems: ReadonlyArray<unknown>,\n  nextItems: ReadonlyArray<unknown>,\n  trackBy: string,\n): boolean => {\n  if (prevItems.length !== nextItems.length) return false\n  for (let i = 0; i < prevItems.length; i++) {\n    if (\n      !Object.is(\n        readTrackBy(prevItems[i], trackBy),\n        readTrackBy(nextItems[i], trackBy),\n      )\n    ) {\n      return false\n    }\n  }\n  return true\n}\n\nconst reconcileIds = (\n  prev: ListState | undefined,\n  nextItems: ReadonlyArray<unknown>,\n  trackBy?: string,\n  makeRowId?: () => RowId,\n): { readonly ids: ReadonlyArray<RowId>; readonly removed: ReadonlyArray<RowId> } => {\n  const nextRowId =\n    makeRowId ??\n    (() => {\n      let rowSeq = 0\n      return () => {\n        rowSeq += 1\n        return `r${rowSeq}`\n      }\n    })()\n\n  if (!prev) {\n    return {\n      ids: nextItems.map(() => nextRowId()),\n      removed: [],\n    }\n  }\n\n  if (prev.itemsRef === nextItems) {\n    return {\n      ids: prev.ids,\n      removed: [],\n    }\n  }\n\n  // \u91CD\u8981\uFF1A\u4FDD\u6301 RowId \u5728\u201C\u975E\u7ED3\u6784\u53D8\u66F4\u201D\uFF08\u4EC5\u5B57\u6BB5\u66F4\u65B0/\u5BF9\u8C61\u514B\u9686\uFF09\u4E0B\u7684\u7A33\u5B9A\u6027\uFF0C\n  // \u5426\u5219 in-flight / \u7F13\u5B58 \u4F1A\u88AB\u65E0\u610F\u4E49\u5730\u5931\u6548\u3002\n  const sameLength = prev.itemsRef.length === nextItems.length\n  if (sameLength) {\n    // trackBy \u573A\u666F\uFF1A\u82E5 key \u5E8F\u5217\u4E00\u81F4\uFF0C\u5219\u53EF\u76F4\u63A5\u590D\u7528\u65E7 ids\uFF1B\n    // \u5426\u5219\u5FC5\u987B\u8D70 key-based reconcile\uFF08\u907F\u514D clone + reorder \u65F6\u8BEF\u5224\u4E3A\u201C\u672A\u91CD\u6392\u201D\uFF09\u3002\n    if (trackBy) {\n      const canUseKeys =\n        hasStableTrackByKeys(prev.itemsRef, trackBy) &&\n        hasStableTrackByKeys(nextItems, trackBy)\n      if (canUseKeys) {\n        if (isSameTrackBySequence(prev.itemsRef, nextItems, trackBy)) {\n          return {\n            ids: prev.ids,\n            removed: [],\n          }\n        }\n      } else {\n        // trackBy key \u4E0D\u53EF\u7528\u65F6\u9000\u56DE\u5230\u5F15\u7528\u7EA7\u4FA6\u6D4B\uFF08\u5C3D\u91CF\u4FDD\u6301\u201C\u514B\u9686\u4F46\u4E0D\u91CD\u6392\u201D\u7684\u7A33\u5B9A\u6027\uFF09\u3002\n        if (!didReorderByReference(prev.itemsRef, nextItems)) {\n          return {\n            ids: prev.ids,\n            removed: [],\n          }\n        }\n      }\n    } else if (!didReorderByReference(prev.itemsRef, nextItems)) {\n      return {\n        ids: prev.ids,\n        removed: [],\n      }\n    }\n  }\n\n  const keyOf = (item: unknown): unknown => {\n    if (!trackBy) return item\n    const k = readTrackBy(item, trackBy)\n    return k !== undefined ? k : item\n  }\n\n  const buckets = new Map<unknown, Array<RowId>>()\n  for (let i = 0; i < prev.itemsRef.length; i++) {\n    const key = keyOf(prev.itemsRef[i])\n    const list = buckets.get(key) ?? []\n    list.push(prev.ids[i]!)\n    buckets.set(key, list)\n  }\n\n  const ids: Array<RowId> = []\n  for (let i = 0; i < nextItems.length; i++) {\n    const key = keyOf(nextItems[i])\n    const list = buckets.get(key)\n    if (list && list.length > 0) {\n      ids.push(list.shift()!)\n    } else {\n      ids.push(nextRowId())\n    }\n  }\n\n  const removed: Array<RowId> = []\n  for (const list of buckets.values()) {\n    removed.push(...list)\n  }\n\n  return { ids, removed }\n}\n\nconst buildIndexById = (ids: ReadonlyArray<RowId>): ReadonlyMap<RowId, number> => {\n  const map = new Map<RowId, number>()\n  for (let i = 0; i < ids.length; i++) {\n    map.set(ids[i]!, i)\n  }\n  return map\n}\n\nexport class RowIdStore {\n  private readonly lists = new Map<string, ListState>()\n  private readonly removalListeners = new Map<string, Set<ListRemovalListener>>()\n  private nextRowSeq = 0\n\n  constructor(\n    private readonly instanceId?: string,\n  ) {}\n\n  private makeRowId = (): RowId => {\n    this.nextRowSeq += 1\n    return this.instanceId ? `${this.instanceId}::r${this.nextRowSeq}` : `r${this.nextRowSeq}`\n  }\n\n  onRemoved(listPath: string, listener: ListRemovalListener): () => void {\n    const set = this.removalListeners.get(listPath) ?? new Set<ListRemovalListener>()\n    set.add(listener)\n    this.removalListeners.set(listPath, set)\n    return () => {\n      const current = this.removalListeners.get(listPath)\n      if (!current) return\n      current.delete(listener)\n      if (current.size === 0) this.removalListeners.delete(listPath)\n    }\n  }\n\n  getRowId(listPath: string, index: number): RowId | undefined {\n    const state = this.lists.get(listPath)\n    return state ? state.ids[index] : undefined\n  }\n\n  getIndex(listPath: string, rowId: RowId): number | undefined {\n    const state = this.lists.get(listPath)\n    if (!state) return undefined\n    return state.indexById.get(rowId)\n  }\n\n  /**\n   * ensureList\uFF1A\n   * - \u8BA9\u6307\u5B9A listPath \u7684 RowID \u6620\u5C04\u4E0E\u5F53\u524D items \u5BF9\u9F50\uFF1B\n   * - \u8FD4\u56DE\u6700\u65B0\u7684 ids\uFF08index -> RowId\uFF09\u3002\n   */\n  ensureList(\n    listPath: string,\n    items: ReadonlyArray<unknown>,\n    trackBy?: string,\n  ): ReadonlyArray<RowId> {\n    const prev = this.lists.get(listPath)\n    const { ids, removed } = reconcileIds(prev, items, trackBy ?? prev?.trackBy, this.makeRowId)\n\n    const next: ListState = {\n      itemsRef: items,\n      ids,\n      indexById: buildIndexById(ids),\n      trackBy: trackBy ?? prev?.trackBy,\n    }\n    this.lists.set(listPath, next)\n\n    if (removed.length > 0) {\n      const listeners = this.removalListeners.get(listPath)\n      if (listeners && listeners.size > 0) {\n        for (const rowId of removed) {\n          for (const fn of listeners) {\n            try {\n              fn(rowId)\n            } catch {\n              // listener failures should never break runtime behavior\n            }\n          }\n        }\n      }\n    }\n\n    return ids\n  }\n\n  /**\n   * updateAll\uFF1A\n   * - \u5728\u6BCF\u6B21\u63D0\u4EA4\u540E\u5BF9\u9F50\u6240\u6709\u5DF2\u77E5 list \u7684 RowID \u6620\u5C04\uFF1B\n   * - configs \u6765\u81EA StateTraitProgram.spec \u4E2D\u7684 list \u58F0\u660E\uFF08\u53EF\u643A\u5E26 trackBy\uFF09\u3002\n   */\n  updateAll(state: unknown, configs: ReadonlyArray<ListConfig>): void {\n    for (const cfg of configs) {\n      const value = getAtPath(state as any, cfg.path)\n      const items = Array.isArray(value) ? (value as ReadonlyArray<unknown>) : []\n      this.ensureList(cfg.path, items, cfg.trackBy)\n    }\n  }\n}\n\nexport const collectListConfigs = (spec: Record<string, unknown>): ReadonlyArray<ListConfig> => {\n  const configs: Array<ListConfig> = []\n  for (const key in spec) {\n    if (!Object.prototype.hasOwnProperty.call(spec, key)) continue\n    const raw = spec[key]\n    if (!raw || typeof raw !== \"object\") continue\n    const tag = (raw as any)._tag\n    if (tag !== \"StateTraitList\") continue\n    const trackBy = (raw as any).identityHint?.trackBy\n    configs.push({\n      path: key,\n      trackBy: typeof trackBy === \"string\" ? trackBy : undefined,\n    })\n  }\n  return configs\n}\n", "import { Context, Effect, Layer } from \"effect\"\n\nexport type ResourceSnapshotPhase = \"idle\" | \"loading\" | \"success\" | \"error\"\n\nexport type ReplayLogEvent =\n  | {\n      readonly _tag: \"ResourceSnapshot\"\n      readonly resourceId: string\n      readonly fieldPath: string\n      readonly keyHash?: string\n      readonly phase: ResourceSnapshotPhase\n      readonly snapshot: unknown\n      readonly timestamp: number\n      readonly moduleId?: string\n      readonly instanceId?: string\n    }\n  | {\n      readonly _tag: \"InvalidateRequest\"\n      readonly timestamp: number\n      readonly moduleId?: string\n      readonly instanceId?: string\n      readonly kind: \"resource\" | \"query\"\n      readonly target: string\n      readonly meta?: unknown\n    }\n\nexport type ResourceSnapshotEvent = Extract<ReplayLogEvent, { readonly _tag: \"ResourceSnapshot\" }>\n\nexport interface ReplayLogService {\n  readonly record: (event: ReplayLogEvent) => Effect.Effect<void>\n  readonly snapshot: Effect.Effect<ReadonlyArray<ReplayLogEvent>>\n  readonly resetCursor: Effect.Effect<void>\n  readonly consumeNext: (\n    predicate: (event: ReplayLogEvent) => boolean,\n  ) => Effect.Effect<ReplayLogEvent | undefined>\n  readonly consumeNextResourceSnapshot: (params: {\n    readonly resourceId: string\n    readonly fieldPath: string\n    readonly keyHash?: string\n    readonly phase?: ResourceSnapshotPhase\n  }) => Effect.Effect<ResourceSnapshotEvent | undefined>\n}\n\nexport class ReplayLog extends Context.Tag(\"@logix/core/ReplayLog\")<\n  ReplayLog,\n  ReplayLogService\n>() {}\n\nexport const make = (\n  initial?: ReadonlyArray<ReplayLogEvent>,\n): ReplayLogService => {\n  const events: Array<ReplayLogEvent> = initial ? Array.from(initial) : []\n  let cursor = 0\n\n  const consumeNext = (\n    predicate: (event: ReplayLogEvent) => boolean,\n  ): Effect.Effect<ReplayLogEvent | undefined> =>\n    Effect.sync(() => {\n      for (let i = cursor; i < events.length; i++) {\n        const event = events[i]\n        if (!predicate(event)) continue\n        cursor = i + 1\n        return event\n      }\n      return undefined\n    })\n\n  const consumeNextResourceSnapshot = (params: {\n    readonly resourceId: string\n    readonly fieldPath: string\n    readonly keyHash?: string\n    readonly phase?: ResourceSnapshotPhase\n  }): Effect.Effect<ResourceSnapshotEvent | undefined> =>\n    consumeNext((event): event is ResourceSnapshotEvent => {\n      if (event._tag !== \"ResourceSnapshot\") return false\n      if (event.resourceId !== params.resourceId) return false\n      if (event.fieldPath !== params.fieldPath) return false\n      if (params.keyHash !== undefined && event.keyHash !== params.keyHash) {\n        return false\n      }\n      if (params.phase !== undefined && event.phase !== params.phase) {\n        return false\n      }\n      return true\n    }).pipe(Effect.map((event) => event as ResourceSnapshotEvent | undefined))\n\n  return {\n    record: (event) => Effect.sync(() => events.push(event)),\n    snapshot: Effect.sync(() => events.slice()),\n    resetCursor: Effect.sync(() => {\n      cursor = 0\n    }),\n    consumeNext,\n    consumeNextResourceSnapshot,\n  }\n}\n\nexport const layer = (\n  initial?: ReadonlyArray<ReplayLogEvent>,\n): Layer.Layer<ReplayLog, never, never> =>\n  Layer.succeed(ReplayLog, make(initial))\n\nexport const record = (\n  event: ReplayLogEvent,\n): Effect.Effect<void, never, ReplayLog> =>\n  Effect.gen(function* () {\n    const log = yield* ReplayLog\n    yield* log.record(event)\n  })\n\nexport const snapshot: Effect.Effect<\n  ReadonlyArray<ReplayLogEvent>,\n  never,\n  ReplayLog\n> = Effect.gen(function* () {\n  const log = yield* ReplayLog\n  return yield* log.snapshot\n})\n\nexport const resetCursor: Effect.Effect<void, never, ReplayLog> = Effect.gen(\n  function* () {\n    const log = yield* ReplayLog\n    yield* log.resetCursor\n  },\n)\n\nexport const consumeNextResourceSnapshot = (params: {\n  readonly resourceId: string\n  readonly fieldPath: string\n  readonly keyHash?: string\n  readonly phase?: ResourceSnapshotPhase\n}): Effect.Effect<ResourceSnapshotEvent | undefined, never, ReplayLog> =>\n  Effect.gen(function* () {\n    const log = yield* ReplayLog\n    return yield* log.consumeNextResourceSnapshot(params)\n  })\n"],
  "mappings": ";;;;AAWA,IAAM,gBAAgB,CAAC,SAAyC;AAC9D,MAAI,CAAC,KAAM,QAAO,CAAC;AACnB,SAAO,KAAK,MAAM,GAAG,EAAE;AAAA,IAAI,CAAC,QAC1B,WAAW,KAAK,GAAG,IAAI,OAAO,GAAG,IAAI;AAAA,EACvC;AACF;AAEO,IAAM,YAAY,CAAC,OAAY,SAAsB;AAC1D,MAAI,CAAC,QAAQ,SAAS,KAAM,QAAO;AACnC,QAAM,WAAW,cAAc,IAAI;AACnC,MAAI,UAAe;AACnB,aAAW,OAAO,UAAU;AAC1B,QAAI,WAAW,KAAM,QAAO;AAC5B,QAAI,OAAO,QAAQ,UAAU;AAC3B,gBAAU,MAAM,QAAQ,OAAO,IAAI,QAAQ,GAAG,IAAI,QAAQ,OAAO,GAAG,CAAC;AACrE;AAAA,IACF;AACA,cAAU,QAAQ,GAAG;AAAA,EACvB;AACA,SAAO;AACT;AAEO,IAAM,oBAAoB,CAAC,OAAY,MAAc,UAAqB;AAC/E,MAAI,CAAC,KAAM;AACX,QAAM,WAAW,cAAc,IAAI;AACnC,MAAI,SAAS,WAAW,EAAG;AAE3B,MAAI,UAAe;AACnB,WAAS,IAAI,GAAG,IAAI,SAAS,SAAS,GAAG,KAAK;AAC5C,UAAM,MAAM,SAAS,CAAC;AACtB,UAAM,UAAU,SAAS,IAAI,CAAC;AAE9B,UAAM,OAAO,UAAU,GAAU;AACjC,QAAI,QAAQ,QAAQ,OAAO,SAAS,UAAU;AAC5C,cAAQ,GAAU,IAAI,OAAO,YAAY,WAAW,CAAC,IAAI,CAAC;AAAA,IAC5D;AACA,cAAU,QAAQ,GAAU;AAAA,EAC9B;AAEA,QAAM,OAAO,SAAS,SAAS,SAAS,CAAC;AACzC,UAAQ,IAAW,IAAI;AACzB;AAEO,IAAM,sBAAsB,CAAC,OAAY,SAAuB;AACrE,MAAI,CAAC,KAAM;AACX,QAAM,WAAW,cAAc,IAAI;AACnC,MAAI,SAAS,WAAW,EAAG;AAE3B,MAAI,UAAe;AACnB,WAAS,IAAI,GAAG,IAAI,SAAS,SAAS,GAAG,KAAK;AAC5C,UAAM,MAAM,SAAS,CAAC;AACtB,UAAM,OAAO,UAAU,GAAU;AACjC,QAAI,QAAQ,QAAQ,OAAO,SAAS,UAAU;AAC5C;AAAA,IACF;AACA,cAAU;AAAA,EACZ;AAEA,QAAM,OAAO,SAAS,SAAS,SAAS,CAAC;AACzC,MAAI,MAAM,QAAQ,OAAO,KAAK,OAAO,SAAS,UAAU;AACtD,YAAQ,IAAI,IAAI;AAChB;AAAA,EACF;AAEA,MAAI,WAAW,OAAO,YAAY,UAAU;AAC1C,WAAO,QAAQ,IAAW;AAAA,EAC5B;AACF;AAkBO,IAAM,yBAAyB,CAAC,cAAqD;AAC1F,QAAM,MAAM,UAAU,QAAQ,IAAI;AAClC,MAAI,MAAM,EAAG,QAAO;AACpB,MAAI,UAAU,QAAQ,MAAM,MAAM,CAAC,KAAK,EAAG,QAAO;AAElD,QAAM,WAAW,UAAU,MAAM,GAAG,GAAG;AACvC,QAAM,OAAO,UAAU,MAAM,MAAM,CAAC;AACpC,QAAM,WAAW,KAAK,WAAW,GAAG,IAAI,KAAK,MAAM,CAAC,IAAI;AACxD,SAAO,EAAE,UAAU,SAAS;AAC9B;AAEO,IAAM,sBAAsB,CACjC,UACA,OACA,aAEA,WAAW,GAAG,QAAQ,IAAI,KAAK,IAAI,QAAQ,KAAK,GAAG,QAAQ,IAAI,KAAK;AAStE,IAAM,cAAc,CAAC,MAAe,YAA6B;AAC/D,MAAI,CAAC,QAAQ,OAAO,SAAS,SAAU,QAAO;AAC9C,QAAM,WAAW,QAAQ,MAAM,GAAG;AAClC,MAAI,UAAe;AACnB,aAAW,OAAO,UAAU;AAC1B,QAAI,WAAW,KAAM,QAAO;AAC5B,cAAU,QAAQ,GAAU;AAAA,EAC9B;AACA,SAAO;AACT;AAEA,IAAM,wBAAwB,CAC5B,WACA,cACY;AACZ,QAAM,UAAU,oBAAI,IAA4B;AAChD,WAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AACzC,UAAM,OAAO,UAAU,CAAC;AACxB,UAAM,OAAO,QAAQ,IAAI,IAAI,KAAK,CAAC;AACnC,SAAK,KAAK,CAAC;AACX,YAAQ,IAAI,MAAM,IAAI;AAAA,EACxB;AAEA,WAAS,YAAY,GAAG,YAAY,UAAU,QAAQ,aAAa;AACjE,UAAM,OAAO,UAAU,SAAS;AAChC,UAAM,IAAI,QAAQ,IAAI,IAAI;AAC1B,QAAI,CAAC,KAAK,EAAE,WAAW,EAAG;AAC1B,UAAM,YAAY,EAAE,MAAM;AAC1B,QAAI,cAAc,WAAW;AAC3B,aAAO;AAAA,IACT;AAAA,EACF;AAEA,SAAO;AACT;AAEA,IAAM,uBAAuB,CAC3B,OACA,YACY,MAAM,MAAM,CAAC,SAAS,YAAY,MAAM,OAAO,MAAM,MAAS;AAE5E,IAAM,wBAAwB,CAC5B,WACA,WACA,YACY;AACZ,MAAI,UAAU,WAAW,UAAU,OAAQ,QAAO;AAClD,WAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AACzC,QACE,CAAC,OAAO;AAAA,MACN,YAAY,UAAU,CAAC,GAAG,OAAO;AAAA,MACjC,YAAY,UAAU,CAAC,GAAG,OAAO;AAAA,IACnC,GACA;AACA,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO;AACT;AAEA,IAAM,eAAe,CACnB,MACA,WACA,SACA,cACmF;AACnF,QAAM,YACJ,aACC,uBAAM;AACL,QAAI,SAAS;AACb,WAAO,MAAM;AACX,gBAAU;AACV,aAAO,IAAI,MAAM;AAAA,IACnB;AAAA,EACF,GAAG;AAEL,MAAI,CAAC,MAAM;AACT,WAAO;AAAA,MACL,KAAK,UAAU,IAAI,MAAM,UAAU,CAAC;AAAA,MACpC,SAAS,CAAC;AAAA,IACZ;AAAA,EACF;AAEA,MAAI,KAAK,aAAa,WAAW;AAC/B,WAAO;AAAA,MACL,KAAK,KAAK;AAAA,MACV,SAAS,CAAC;AAAA,IACZ;AAAA,EACF;AAIA,QAAM,aAAa,KAAK,SAAS,WAAW,UAAU;AACtD,MAAI,YAAY;AAGd,QAAI,SAAS;AACX,YAAM,aACJ,qBAAqB,KAAK,UAAU,OAAO,KAC3C,qBAAqB,WAAW,OAAO;AACzC,UAAI,YAAY;AACd,YAAI,sBAAsB,KAAK,UAAU,WAAW,OAAO,GAAG;AAC5D,iBAAO;AAAA,YACL,KAAK,KAAK;AAAA,YACV,SAAS,CAAC;AAAA,UACZ;AAAA,QACF;AAAA,MACF,OAAO;AAEL,YAAI,CAAC,sBAAsB,KAAK,UAAU,SAAS,GAAG;AACpD,iBAAO;AAAA,YACL,KAAK,KAAK;AAAA,YACV,SAAS,CAAC;AAAA,UACZ;AAAA,QACF;AAAA,MACF;AAAA,IACF,WAAW,CAAC,sBAAsB,KAAK,UAAU,SAAS,GAAG;AAC3D,aAAO;AAAA,QACL,KAAK,KAAK;AAAA,QACV,SAAS,CAAC;AAAA,MACZ;AAAA,IACF;AAAA,EACF;AAEA,QAAM,QAAQ,CAAC,SAA2B;AACxC,QAAI,CAAC,QAAS,QAAO;AACrB,UAAM,IAAI,YAAY,MAAM,OAAO;AACnC,WAAO,MAAM,SAAY,IAAI;AAAA,EAC/B;AAEA,QAAM,UAAU,oBAAI,IAA2B;AAC/C,WAAS,IAAI,GAAG,IAAI,KAAK,SAAS,QAAQ,KAAK;AAC7C,UAAM,MAAM,MAAM,KAAK,SAAS,CAAC,CAAC;AAClC,UAAM,OAAO,QAAQ,IAAI,GAAG,KAAK,CAAC;AAClC,SAAK,KAAK,KAAK,IAAI,CAAC,CAAE;AACtB,YAAQ,IAAI,KAAK,IAAI;AAAA,EACvB;AAEA,QAAM,MAAoB,CAAC;AAC3B,WAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AACzC,UAAM,MAAM,MAAM,UAAU,CAAC,CAAC;AAC9B,UAAM,OAAO,QAAQ,IAAI,GAAG;AAC5B,QAAI,QAAQ,KAAK,SAAS,GAAG;AAC3B,UAAI,KAAK,KAAK,MAAM,CAAE;AAAA,IACxB,OAAO;AACL,UAAI,KAAK,UAAU,CAAC;AAAA,IACtB;AAAA,EACF;AAEA,QAAM,UAAwB,CAAC;AAC/B,aAAW,QAAQ,QAAQ,OAAO,GAAG;AACnC,YAAQ,KAAK,GAAG,IAAI;AAAA,EACtB;AAEA,SAAO,EAAE,KAAK,QAAQ;AACxB;AAEA,IAAM,iBAAiB,CAAC,QAA0D;AAChF,QAAM,MAAM,oBAAI,IAAmB;AACnC,WAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACnC,QAAI,IAAI,IAAI,CAAC,GAAI,CAAC;AAAA,EACpB;AACA,SAAO;AACT;AAEO,IAAM,aAAN,MAAiB;AAAA,EAKtB,YACmB,YACjB;AADiB;AALnB,SAAiB,QAAQ,oBAAI,IAAuB;AACpD,SAAiB,mBAAmB,oBAAI,IAAsC;AAC9E,SAAQ,aAAa;AAMrB,SAAQ,YAAY,MAAa;AAC/B,WAAK,cAAc;AACnB,aAAO,KAAK,aAAa,GAAG,KAAK,UAAU,MAAM,KAAK,UAAU,KAAK,IAAI,KAAK,UAAU;AAAA,IAC1F;AAAA,EALG;AAAA,EAOH,UAAU,UAAkB,UAA2C;AACrE,UAAM,MAAM,KAAK,iBAAiB,IAAI,QAAQ,KAAK,oBAAI,IAAyB;AAChF,QAAI,IAAI,QAAQ;AAChB,SAAK,iBAAiB,IAAI,UAAU,GAAG;AACvC,WAAO,MAAM;AACX,YAAM,UAAU,KAAK,iBAAiB,IAAI,QAAQ;AAClD,UAAI,CAAC,QAAS;AACd,cAAQ,OAAO,QAAQ;AACvB,UAAI,QAAQ,SAAS,EAAG,MAAK,iBAAiB,OAAO,QAAQ;AAAA,IAC/D;AAAA,EACF;AAAA,EAEA,SAAS,UAAkB,OAAkC;AAC3D,UAAM,QAAQ,KAAK,MAAM,IAAI,QAAQ;AACrC,WAAO,QAAQ,MAAM,IAAI,KAAK,IAAI;AAAA,EACpC;AAAA,EAEA,SAAS,UAAkB,OAAkC;AAC3D,UAAM,QAAQ,KAAK,MAAM,IAAI,QAAQ;AACrC,QAAI,CAAC,MAAO,QAAO;AACnB,WAAO,MAAM,UAAU,IAAI,KAAK;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,WACE,UACA,OACA,SACsB;AACtB,UAAM,OAAO,KAAK,MAAM,IAAI,QAAQ;AACpC,UAAM,EAAE,KAAK,QAAQ,IAAI,aAAa,MAAM,OAAO,WAAW,MAAM,SAAS,KAAK,SAAS;AAE3F,UAAM,OAAkB;AAAA,MACtB,UAAU;AAAA,MACV;AAAA,MACA,WAAW,eAAe,GAAG;AAAA,MAC7B,SAAS,WAAW,MAAM;AAAA,IAC5B;AACA,SAAK,MAAM,IAAI,UAAU,IAAI;AAE7B,QAAI,QAAQ,SAAS,GAAG;AACtB,YAAM,YAAY,KAAK,iBAAiB,IAAI,QAAQ;AACpD,UAAI,aAAa,UAAU,OAAO,GAAG;AACnC,mBAAW,SAAS,SAAS;AAC3B,qBAAW,MAAM,WAAW;AAC1B,gBAAI;AACF,iBAAG,KAAK;AAAA,YACV,QAAQ;AAAA,YAER;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,UAAU,OAAgB,SAA0C;AAClE,eAAW,OAAO,SAAS;AACzB,YAAM,QAAQ,UAAU,OAAc,IAAI,IAAI;AAC9C,YAAM,QAAQ,MAAM,QAAQ,KAAK,IAAK,QAAmC,CAAC;AAC1E,WAAK,WAAW,IAAI,MAAM,OAAO,IAAI,OAAO;AAAA,IAC9C;AAAA,EACF;AACF;AAEO,IAAM,qBAAqB,CAAC,SAA6D;AAC9F,QAAM,UAA6B,CAAC;AACpC,aAAW,OAAO,MAAM;AACtB,QAAI,CAAC,OAAO,UAAU,eAAe,KAAK,MAAM,GAAG,EAAG;AACtD,UAAM,MAAM,KAAK,GAAG;AACpB,QAAI,CAAC,OAAO,OAAO,QAAQ,SAAU;AACrC,UAAM,MAAO,IAAY;AACzB,QAAI,QAAQ,iBAAkB;AAC9B,UAAM,UAAW,IAAY,cAAc;AAC3C,YAAQ,KAAK;AAAA,MACX,MAAM;AAAA,MACN,SAAS,OAAO,YAAY,WAAW,UAAU;AAAA,IACnD,CAAC;AAAA,EACH;AACA,SAAO;AACT;;;ACvYA,SAAS,SAAS,QAAQ,aAAa;AA2ChC,IAAM,YAAN,cAAwB,QAAQ,IAAI,uBAAuB,EAGhE,EAAE;AAAC;AAgEE,IAAM,WAIT,OAAO,IAAI,aAAa;AAC1B,QAAM,MAAM,OAAO;AACnB,SAAO,OAAO,IAAI;AACpB,CAAC;AAEM,IAAM,cAAqD,OAAO;AAAA,EACvE,aAAa;AACX,UAAM,MAAM,OAAO;AACnB,WAAO,IAAI;AAAA,EACb;AACF;",
  "names": []
}

|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// @logix/core subpath bundles for @logix/sandbox
|
|
2
|
+
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __export = (target, all) => {
|
|
5
|
+
for (var name in all)
|
|
6
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
export {
|
|
10
|
+
__export
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
|