unspaghettit 0.2.0 → 0.4.0
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/README.md +56 -18
- package/build/client/_app/immutable/assets/0.DCOD5ne_.css +1 -0
- package/build/client/_app/immutable/assets/0.DCOD5ne_.css.br +0 -0
- package/build/client/_app/immutable/assets/0.DCOD5ne_.css.gz +0 -0
- package/build/client/_app/immutable/assets/12.nv0I59TU.css.gz +0 -0
- package/build/client/_app/immutable/assets/3.B3akUL9A.css.gz +0 -0
- package/build/client/_app/immutable/assets/BehaviorGraph.Bk0xQRZk.css +1 -0
- package/build/client/_app/immutable/assets/BehaviorGraph.Bk0xQRZk.css.br +0 -0
- package/build/client/_app/immutable/assets/BehaviorGraph.Bk0xQRZk.css.gz +0 -0
- package/build/client/_app/immutable/chunks/B3vnQs252.js +1 -0
- package/build/client/_app/immutable/chunks/B3vnQs252.js.br +0 -0
- package/build/client/_app/immutable/chunks/B3vnQs252.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{CxyLMlpt2.js → BANF9BhQ2.js} +1 -1
- package/build/client/_app/immutable/chunks/BANF9BhQ2.js.br +0 -0
- package/build/client/_app/immutable/chunks/BANF9BhQ2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BJdTO_n6.js +1 -0
- package/build/client/_app/immutable/chunks/BJdTO_n6.js.br +0 -0
- package/build/client/_app/immutable/chunks/BJdTO_n6.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BPl9BITm.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BQ9GodWX2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bcyn5YUg.js +4 -0
- package/build/client/_app/immutable/chunks/Bcyn5YUg.js.br +0 -0
- package/build/client/_app/immutable/chunks/Bcyn5YUg.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bfc9rQXP.js +1 -0
- package/build/client/_app/immutable/chunks/Bfc9rQXP.js.br +0 -0
- package/build/client/_app/immutable/chunks/Bfc9rQXP.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{BfMYiIUi.js → BjxqhpPG.js} +1 -1
- package/build/client/_app/immutable/chunks/BjxqhpPG.js.br +0 -0
- package/build/client/_app/immutable/chunks/BjxqhpPG.js.gz +0 -0
- package/build/client/_app/immutable/chunks/ByaoVvNB.js +1 -0
- package/build/client/_app/immutable/chunks/ByaoVvNB.js.br +0 -0
- package/build/client/_app/immutable/chunks/ByaoVvNB.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BzLd0mTH.js.gz +0 -0
- package/build/client/_app/immutable/chunks/C8b3IMj8.js +1 -0
- package/build/client/_app/immutable/chunks/C8b3IMj8.js.br +0 -0
- package/build/client/_app/immutable/chunks/C8b3IMj8.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CXvvf4uQ.js +1 -0
- package/build/client/_app/immutable/chunks/CXvvf4uQ.js.br +0 -0
- package/build/client/_app/immutable/chunks/CXvvf4uQ.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Cl7Z3e6-.js.gz +0 -0
- package/build/client/_app/immutable/chunks/ClC4qR7W2.js +2 -0
- package/build/client/_app/immutable/chunks/ClC4qR7W2.js.br +0 -0
- package/build/client/_app/immutable/chunks/ClC4qR7W2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CuGlh1c2.js +1 -0
- package/build/client/_app/immutable/chunks/CuGlh1c2.js.br +0 -0
- package/build/client/_app/immutable/chunks/CuGlh1c2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CwzIdrQR.js +1 -0
- package/build/client/_app/immutable/chunks/CwzIdrQR.js.br +0 -0
- package/build/client/_app/immutable/chunks/CwzIdrQR.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D5speDV82.js +908 -0
- package/build/client/_app/immutable/chunks/D5speDV82.js.br +0 -0
- package/build/client/_app/immutable/chunks/D5speDV82.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D64sGJRN.js +1 -0
- package/build/client/_app/immutable/chunks/D64sGJRN.js.br +0 -0
- package/build/client/_app/immutable/chunks/D64sGJRN.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DNaA4QRO2.js +1 -0
- package/build/client/_app/immutable/chunks/DNaA4QRO2.js.br +0 -0
- package/build/client/_app/immutable/chunks/DNaA4QRO2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Da59TXPe.js +1 -0
- package/build/client/_app/immutable/chunks/Da59TXPe.js.br +2 -0
- package/build/client/_app/immutable/chunks/Da59TXPe.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DhTiE3j02.js +2 -0
- package/build/client/_app/immutable/chunks/DhTiE3j02.js.br +0 -0
- package/build/client/_app/immutable/chunks/DhTiE3j02.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Dhqg7r_2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DmyaDy4d2.js +1 -0
- package/build/client/_app/immutable/chunks/DmyaDy4d2.js.br +0 -0
- package/build/client/_app/immutable/chunks/DmyaDy4d2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DryaQyjN2.js +1 -0
- package/build/client/_app/immutable/chunks/DryaQyjN2.js.br +0 -0
- package/build/client/_app/immutable/chunks/DryaQyjN2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DtK8qK5Q2.js +1 -0
- package/build/client/_app/immutable/chunks/DtK8qK5Q2.js.br +0 -0
- package/build/client/_app/immutable/chunks/DtK8qK5Q2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DtblIi6X2.js +1 -0
- package/build/client/_app/immutable/chunks/DtblIi6X2.js.br +1 -0
- package/build/client/_app/immutable/chunks/DtblIi6X2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/UkzDDeO42.js +1 -0
- package/build/client/_app/immutable/chunks/UkzDDeO42.js.br +0 -0
- package/build/client/_app/immutable/chunks/UkzDDeO42.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Vu8LzrwP2.js +1 -0
- package/build/client/_app/immutable/chunks/Vu8LzrwP2.js.br +0 -0
- package/build/client/_app/immutable/chunks/Vu8LzrwP2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/_b612aVb.js +1 -0
- package/build/client/_app/immutable/chunks/_b612aVb.js.br +0 -0
- package/build/client/_app/immutable/chunks/_b612aVb.js.gz +0 -0
- package/build/client/_app/immutable/chunks/aNMRV4sP2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/cMamJTsF.js.gz +0 -0
- package/build/client/_app/immutable/chunks/ib21i2T_.js.gz +0 -0
- package/build/client/_app/immutable/chunks/kNaey6uv.js.gz +0 -0
- package/build/client/_app/immutable/chunks/oVMDLirx.js +1 -0
- package/build/client/_app/immutable/chunks/oVMDLirx.js.br +0 -0
- package/build/client/_app/immutable/chunks/oVMDLirx.js.gz +0 -0
- package/build/client/_app/immutable/chunks/olAc024e.js +1 -0
- package/build/client/_app/immutable/chunks/olAc024e.js.br +0 -0
- package/build/client/_app/immutable/chunks/olAc024e.js.gz +0 -0
- package/build/client/_app/immutable/chunks/suTxxv1t.js.gz +0 -0
- package/build/client/_app/immutable/chunks/wXIHzLMQ2.js +1 -0
- package/build/client/_app/immutable/chunks/wXIHzLMQ2.js.br +0 -0
- package/build/client/_app/immutable/chunks/wXIHzLMQ2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/wrqalH0a.js +1 -0
- package/build/client/_app/immutable/chunks/wrqalH0a.js.br +0 -0
- package/build/client/_app/immutable/chunks/wrqalH0a.js.gz +0 -0
- package/build/client/_app/immutable/chunks/x60Tn5kT.js +1 -0
- package/build/client/_app/immutable/chunks/x60Tn5kT.js.br +0 -0
- package/build/client/_app/immutable/chunks/x60Tn5kT.js.gz +0 -0
- package/build/client/_app/immutable/chunks/xihTtKlq.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{BOrLmFwJ.js → yShDxCNj.js} +1 -1
- package/build/client/_app/immutable/chunks/yShDxCNj.js.br +2 -0
- package/build/client/_app/immutable/chunks/yShDxCNj.js.gz +0 -0
- package/build/client/_app/immutable/entry/app.Etd-exTb.js +2 -0
- package/build/client/_app/immutable/entry/app.Etd-exTb.js.br +0 -0
- package/build/client/_app/immutable/entry/app.Etd-exTb.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.DY2B3u4g.js +1 -0
- package/build/client/_app/immutable/entry/start.DY2B3u4g.js.br +0 -0
- package/build/client/_app/immutable/entry/start.DY2B3u4g.js.gz +0 -0
- package/build/client/_app/immutable/nodes/0.tKfYV3__.js +8 -0
- package/build/client/_app/immutable/nodes/0.tKfYV3__.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.tKfYV3__.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{1.KYdA6ppX.js → 1.CER5ICKt.js} +1 -1
- package/build/client/_app/immutable/nodes/1.CER5ICKt.js.br +1 -0
- package/build/client/_app/immutable/nodes/1.CER5ICKt.js.gz +0 -0
- package/build/client/_app/immutable/nodes/10.rT7cD8kX.js +1 -0
- package/build/client/_app/immutable/nodes/10.rT7cD8kX.js.br +0 -0
- package/build/client/_app/immutable/nodes/10.rT7cD8kX.js.gz +0 -0
- package/build/client/_app/immutable/nodes/11.BAnV_Y5Y.js +2 -0
- package/build/client/_app/immutable/nodes/11.BAnV_Y5Y.js.br +0 -0
- package/build/client/_app/immutable/nodes/11.BAnV_Y5Y.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{9.CMW6a2Lg.js → 12.DCTRFMqo.js} +4 -3
- package/build/client/_app/immutable/nodes/12.DCTRFMqo.js.br +0 -0
- package/build/client/_app/immutable/nodes/12.DCTRFMqo.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{2.DBz20KgG.js → 2.CF488WWF.js} +1 -1
- package/build/client/_app/immutable/nodes/2.CF488WWF.js.br +0 -0
- package/build/client/_app/immutable/nodes/2.CF488WWF.js.gz +0 -0
- package/build/client/_app/immutable/nodes/3.CP7CPPVH.js +1 -0
- package/build/client/_app/immutable/nodes/3.CP7CPPVH.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.CP7CPPVH.js.gz +0 -0
- package/build/client/_app/immutable/nodes/4.D1bxCSiM.js +3 -0
- package/build/client/_app/immutable/nodes/4.D1bxCSiM.js.br +0 -0
- package/build/client/_app/immutable/nodes/4.D1bxCSiM.js.gz +0 -0
- package/build/client/_app/immutable/nodes/5.D6jZgh9y.js +48 -0
- package/build/client/_app/immutable/nodes/5.D6jZgh9y.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.D6jZgh9y.js.gz +0 -0
- package/build/client/_app/immutable/nodes/6.BrBFUA0s.js +1 -0
- package/build/client/_app/immutable/nodes/6.BrBFUA0s.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.BrBFUA0s.js.gz +0 -0
- package/build/client/_app/immutable/nodes/7.pajo8MfM.js +3 -0
- package/build/client/_app/immutable/nodes/7.pajo8MfM.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.pajo8MfM.js.gz +0 -0
- package/build/client/_app/immutable/nodes/8.Cc80_Igi.js +5 -0
- package/build/client/_app/immutable/nodes/8.Cc80_Igi.js.br +0 -0
- package/build/client/_app/immutable/nodes/8.Cc80_Igi.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{7.CemgNJfw.js → 9.D72NaL3l.js} +1 -1
- package/build/client/_app/immutable/nodes/9.D72NaL3l.js.br +1 -0
- package/build/client/_app/immutable/nodes/9.D72NaL3l.js.gz +0 -0
- package/build/client/_app/version.json +1 -1
- package/build/client/_app/version.json.br +0 -0
- package/build/client/_app/version.json.gz +0 -0
- package/build/client/lyriks_logo.svg +148 -0
- package/build/client/lyriks_logo.svg.br +0 -0
- package/build/client/lyriks_logo.svg.gz +0 -0
- package/build/server/chunks/0-8YZc572z.js +15 -0
- package/build/server/chunks/0-8YZc572z.js.map +1 -0
- package/build/server/chunks/1-DxkfSJLu.js +9 -0
- package/build/server/chunks/{1-DPpKAKXV.js.map → 1-DxkfSJLu.js.map} +1 -1
- package/build/server/chunks/10-DkObdGtU.js +9 -0
- package/build/server/chunks/10-DkObdGtU.js.map +1 -0
- package/build/server/chunks/11-DL94HxpZ.js +9 -0
- package/build/server/chunks/11-DL94HxpZ.js.map +1 -0
- package/build/server/chunks/12-CI74sCkt.js +9 -0
- package/build/server/chunks/12-CI74sCkt.js.map +1 -0
- package/build/server/chunks/2-qhWwQ4eL.js +9 -0
- package/build/server/chunks/2-qhWwQ4eL.js.map +1 -0
- package/build/server/chunks/3-CzoZtSTp.js +16 -0
- package/build/server/chunks/3-CzoZtSTp.js.map +1 -0
- package/build/server/chunks/4-CDa9DBsh.js +16 -0
- package/build/server/chunks/4-CDa9DBsh.js.map +1 -0
- package/build/server/chunks/5-qD2xxOrq.js +9 -0
- package/build/server/chunks/5-qD2xxOrq.js.map +1 -0
- package/build/server/chunks/6-B4mWzvDn.js +9 -0
- package/build/server/chunks/6-B4mWzvDn.js.map +1 -0
- package/build/server/chunks/7-zExv-fTN.js +9 -0
- package/build/server/chunks/7-zExv-fTN.js.map +1 -0
- package/build/server/chunks/8-BVrGdQg4.js +9 -0
- package/build/server/chunks/{6-QQ7r8Rd5.js.map → 8-BVrGdQg4.js.map} +1 -1
- package/build/server/chunks/9-BnZLRMYA.js +9 -0
- package/build/server/chunks/9-BnZLRMYA.js.map +1 -0
- package/build/server/chunks/BehaviorGraph-C-9z37Sm.js +788 -0
- package/build/server/chunks/BehaviorGraph-C-9z37Sm.js.map +1 -0
- package/build/server/chunks/Clock-BfMWQpmJ.js +5 -0
- package/build/server/chunks/Clock-BfMWQpmJ.js.map +1 -0
- package/build/server/chunks/DeleteDomain-BvHEgAyp.js +24 -0
- package/build/server/chunks/DeleteDomain-BvHEgAyp.js.map +1 -0
- package/build/server/chunks/{FeatureValidator-B8qEjAUW.js → DeleteFeature-DnK8sBJI.js} +142 -77
- package/build/server/chunks/DeleteFeature-DnK8sBJI.js.map +1 -0
- package/build/server/chunks/DeleteProject-BXZcehHZ.js +41 -0
- package/build/server/chunks/DeleteProject-BXZcehHZ.js.map +1 -0
- package/build/server/chunks/Effect-BJtLR-6l.js +46 -0
- package/build/server/chunks/Effect-BJtLR-6l.js.map +1 -0
- package/build/server/chunks/{FeatureCard-BQOY6gJQ.js → FeatureCard-Bb50FEfp.js} +4 -4
- package/build/server/chunks/{FeatureCard-BQOY6gJQ.js.map → FeatureCard-Bb50FEfp.js.map} +1 -1
- package/build/server/chunks/{FeatureJson-Bv-qiOSf.js → FeatureJson-DYvMEAub.js} +2 -2
- package/build/server/chunks/{FeatureJson-Bv-qiOSf.js.map → FeatureJson-DYvMEAub.js.map} +1 -1
- package/build/server/chunks/{FeatureTransforms-UWDHmWEg.js → FeatureTransforms-B0aI_CJD.js} +10 -3
- package/build/server/chunks/FeatureTransforms-B0aI_CJD.js.map +1 -0
- package/build/server/chunks/{ManageTagsDialog-DBxA3tM2.js → ManageTagsDialog-D5xbAVNB.js} +5 -5
- package/build/server/chunks/ManageTagsDialog-D5xbAVNB.js.map +1 -0
- package/build/server/chunks/{ProgressBar-CfhccQ83.js → ProgressBar-CUC2EZqG.js} +3 -3
- package/build/server/chunks/ProgressBar-CUC2EZqG.js.map +1 -0
- package/build/server/chunks/{ProjectsIndex-CoDrvRya.js → ProjectsIndex-FgIu9dBp.js} +135 -14
- package/build/server/chunks/ProjectsIndex-FgIu9dBp.js.map +1 -0
- package/build/server/chunks/{RenameTag-BuWLMl1m.js → RenameTag-DWIIR4Bx.js} +3 -6
- package/build/server/chunks/RenameTag-DWIIR4Bx.js.map +1 -0
- package/build/server/chunks/ScenarioApplier-YPKECfZe.js +55 -0
- package/build/server/chunks/ScenarioApplier-YPKECfZe.js.map +1 -0
- package/build/server/chunks/SimulatorEngine-DM1F9nCO.js +1391 -0
- package/build/server/chunks/SimulatorEngine-DM1F9nCO.js.map +1 -0
- package/build/server/chunks/StateValue-BBjWox8f.js +105 -0
- package/build/server/chunks/StateValue-BBjWox8f.js.map +1 -0
- package/build/server/chunks/{TagDotStrip-B1XQ0m0Y.js → TagDotStrip-0rn-IJVE.js} +4 -4
- package/build/server/chunks/TagDotStrip-0rn-IJVE.js.map +1 -0
- package/build/server/chunks/{TagFilterSelect-DbO0Qduh.js → TagFilterSelect-Dbu-7Dg4.js} +5 -5
- package/build/server/chunks/{TagFilterSelect-DbO0Qduh.js.map → TagFilterSelect-Dbu-7Dg4.js.map} +1 -1
- package/build/server/chunks/{TagPalette-CtMNYCmu.js → TagPalette-CpdTiC_7.js} +101 -9
- package/build/server/chunks/TagPalette-CpdTiC_7.js.map +1 -0
- package/build/server/chunks/TransitionCatalog-CYXUANy6.js +271 -0
- package/build/server/chunks/TransitionCatalog-CYXUANy6.js.map +1 -0
- package/build/server/chunks/_layout.svelte-pSSG85WT.js +1342 -0
- package/build/server/chunks/_layout.svelte-pSSG85WT.js.map +1 -0
- package/build/server/chunks/{_page.svelte-BKTveFAj.js → _page.svelte-BNH3szkk.js} +22 -17
- package/build/server/chunks/{_page.svelte-BKTveFAj.js.map → _page.svelte-BNH3szkk.js.map} +1 -1
- package/build/server/chunks/_page.svelte-BcuGvUt1.js +37 -0
- package/build/server/chunks/{_page.svelte-B7hT3P8E.js.map → _page.svelte-BcuGvUt1.js.map} +1 -1
- package/build/server/chunks/_page.svelte-BoOMG5Y0.js +37 -0
- package/build/server/chunks/{_page.svelte-De508ek8.js.map → _page.svelte-BoOMG5Y0.js.map} +1 -1
- package/build/server/chunks/{_page.svelte-BqSC-1vK.js → _page.svelte-C4PRh_wP.js} +104 -54
- package/build/server/chunks/_page.svelte-C4PRh_wP.js.map +1 -0
- package/build/server/chunks/_page.svelte-Cqn34NXy.js +74 -0
- package/build/server/chunks/_page.svelte-Cqn34NXy.js.map +1 -0
- package/build/server/chunks/{_page.svelte-B1s7jxaQ.js → _page.svelte-DSCeOGv7.js} +15 -10
- package/build/server/chunks/_page.svelte-DSCeOGv7.js.map +1 -0
- package/build/server/chunks/_page.svelte-DqWdGt48.js +182 -0
- package/build/server/chunks/_page.svelte-DqWdGt48.js.map +1 -0
- package/build/server/chunks/_page.svelte-DsQHSEl4.js +49 -0
- package/build/server/chunks/_page.svelte-DsQHSEl4.js.map +1 -0
- package/build/server/chunks/{_page.svelte-BKKCa9H5.js → _page.svelte-Uioz8hsG.js} +18 -11
- package/build/server/chunks/{_page.svelte-BKKCa9H5.js.map → _page.svelte-Uioz8hsG.js.map} +1 -1
- package/build/server/chunks/{_page.svelte-Zf9H4KOP.js → _page.svelte-p38jot9e.js} +81 -478
- package/build/server/chunks/_page.svelte-p38jot9e.js.map +1 -0
- package/build/server/chunks/{_page.svelte-BtI2zZ_Z.js → _page.svelte-yN5kzgJ9.js} +251 -447
- package/build/server/chunks/_page.svelte-yN5kzgJ9.js.map +1 -0
- package/build/server/chunks/{_server.ts-DsbbVoOn.js → _server.ts-1CtrHhte.js} +4 -4
- package/build/server/chunks/{_server.ts-DsbbVoOn.js.map → _server.ts-1CtrHhte.js.map} +1 -1
- package/build/server/chunks/{_server.ts-CWvU15tL.js → _server.ts-71Qx1lQb.js} +4 -4
- package/build/server/chunks/{_server.ts-CWvU15tL.js.map → _server.ts-71Qx1lQb.js.map} +1 -1
- package/build/server/chunks/_server.ts-BAyekGHB.js +961 -0
- package/build/server/chunks/_server.ts-BAyekGHB.js.map +1 -0
- package/build/server/chunks/{_server.ts-BihpbxOW.js → _server.ts-BLWhU22T.js} +4 -4
- package/build/server/chunks/{_server.ts-BihpbxOW.js.map → _server.ts-BLWhU22T.js.map} +1 -1
- package/build/server/chunks/{_server.ts-YnfXkeMJ.js → _server.ts-C7EVZVxv.js} +22 -13
- package/build/server/chunks/_server.ts-C7EVZVxv.js.map +1 -0
- package/build/server/chunks/{_server.ts-vcaqdwxS.js → _server.ts-CGjYuLmo.js} +12 -7
- package/build/server/chunks/_server.ts-CGjYuLmo.js.map +1 -0
- package/build/server/chunks/{_server.ts-Dy5zQHe2.js → _server.ts-CX6H8fSE.js} +8 -31
- package/build/server/chunks/_server.ts-CX6H8fSE.js.map +1 -0
- package/build/server/chunks/{_server.ts-BuoQ02BW.js → _server.ts-CyEdTCLr.js} +4 -4
- package/build/server/chunks/{_server.ts-BuoQ02BW.js.map → _server.ts-CyEdTCLr.js.map} +1 -1
- package/build/server/chunks/_server.ts-DKVTM9Pj.js +77 -0
- package/build/server/chunks/_server.ts-DKVTM9Pj.js.map +1 -0
- package/build/server/chunks/{_server.ts-0uNTZKwF.js → _server.ts-Dip65hLJ.js} +15 -9
- package/build/server/chunks/_server.ts-Dip65hLJ.js.map +1 -0
- package/build/server/chunks/{_server.ts-D4EO0VHu.js → _server.ts-Dm0tCs2i.js} +5 -5
- package/build/server/chunks/{_server.ts-D4EO0VHu.js.map → _server.ts-Dm0tCs2i.js.map} +1 -1
- package/build/server/chunks/{_server.ts-BIBWjQI-.js → _server.ts-DsYwK_uW.js} +4 -4
- package/build/server/chunks/{_server.ts-BIBWjQI-.js.map → _server.ts-DsYwK_uW.js.map} +1 -1
- package/build/server/chunks/{_server.ts-DDa0Nk_S.js → _server.ts-RCEgegYU.js} +4 -4
- package/build/server/chunks/{_server.ts-DDa0Nk_S.js.map → _server.ts-RCEgegYU.js.map} +1 -1
- package/build/server/chunks/_server.ts-XOLAT4dd.js +146 -0
- package/build/server/chunks/_server.ts-XOLAT4dd.js.map +1 -0
- package/build/server/chunks/_server.ts-afh_zLVi.js +69 -0
- package/build/server/chunks/_server.ts-afh_zLVi.js.map +1 -0
- package/build/server/chunks/{browserContainer-CNX7ANld.js → browserContainer-BdldtueJ.js} +71 -1378
- package/build/server/chunks/browserContainer-BdldtueJ.js.map +1 -0
- package/build/server/chunks/buildSearchDocs-Cyfrnw9G.js +337 -0
- package/build/server/chunks/buildSearchDocs-Cyfrnw9G.js.map +1 -0
- package/build/server/chunks/{builderModeStore.svelte-ihupr-3p.js → builderModeStore.svelte-BEZMQEqn.js} +223 -11
- package/build/server/chunks/builderModeStore.svelte-BEZMQEqn.js.map +1 -0
- package/build/server/chunks/client-C9Cat4DK.js +51 -0
- package/build/server/chunks/{client-DfpLcAZ9.js.map → client-C9Cat4DK.js.map} +1 -1
- package/build/server/chunks/{error.svelte-C35KOpru.js → error.svelte-CzVR_A6P.js} +5 -5
- package/build/server/chunks/{error.svelte-C35KOpru.js.map → error.svelte-CzVR_A6P.js.map} +1 -1
- package/build/server/chunks/featureQueueContext-DuXpyTdC.js +32 -0
- package/build/server/chunks/featureQueueContext-DuXpyTdC.js.map +1 -0
- package/build/server/chunks/featureStore.svelte-DHZf88gu.js +162 -0
- package/build/server/chunks/featureStore.svelte-DHZf88gu.js.map +1 -0
- package/build/server/chunks/{projectsStore.svelte-QDz5PchX.js → featuresStore.svelte-bUyQBg1-.js} +95 -3
- package/build/server/chunks/featuresStore.svelte-bUyQBg1-.js.map +1 -0
- package/build/server/chunks/{hooks.server-Rv301GTB.js → hooks.server-y3jdg_sB.js} +6 -2
- package/build/server/chunks/hooks.server-y3jdg_sB.js.map +1 -0
- package/build/server/chunks/humanize-CkCPfeWi.js +53 -0
- package/build/server/chunks/humanize-CkCPfeWi.js.map +1 -0
- package/build/server/chunks/{index-server-7H0jzj0M.js → index-server-DvBux_Gf.js} +47 -2
- package/build/server/chunks/{index-server-7H0jzj0M.js.map → index-server-DvBux_Gf.js.map} +1 -1
- package/build/server/chunks/{internal-BPKrFkK1.js → internal-BFt8yDlf.js} +5 -5
- package/build/server/chunks/{internal-BPKrFkK1.js.map → internal-BFt8yDlf.js.map} +1 -1
- package/build/server/chunks/projectBundleClient-BtvWPh87.js +168 -0
- package/build/server/chunks/projectBundleClient-BtvWPh87.js.map +1 -0
- package/build/server/chunks/projectContextStore.svelte-jRJGJZ42.js +141 -0
- package/build/server/chunks/projectContextStore.svelte-jRJGJZ42.js.map +1 -0
- package/build/server/chunks/projectFeaturesStore.svelte-BwNEtDIL.js +87 -0
- package/build/server/chunks/projectFeaturesStore.svelte-BwNEtDIL.js.map +1 -0
- package/build/server/chunks/projectStore.svelte-BNuLNxk_.js +230 -0
- package/build/server/chunks/projectStore.svelte-BNuLNxk_.js.map +1 -0
- package/build/server/chunks/{reconcile-Dv7jS3C8.js → reconcile-CVG2LSlW.js} +54 -267
- package/build/server/chunks/reconcile-CVG2LSlW.js.map +1 -0
- package/build/server/chunks/registry-DqAn_hVE.js +21 -0
- package/build/server/chunks/registry-DqAn_hVE.js.map +1 -0
- package/build/server/chunks/{snapshotRepository-BPXCjX92.js → snapshotRepository-8f-2wTrb.js} +30 -5
- package/build/server/chunks/snapshotRepository-8f-2wTrb.js.map +1 -0
- package/build/server/chunks/{state-CpLVNZq7.js → state-CZZtjXLE.js} +3 -3
- package/build/server/chunks/{state-CpLVNZq7.js.map → state-CZZtjXLE.js.map} +1 -1
- package/build/server/chunks/{sync-DZ3dn761.js → sync-Bn6eSUhC.js} +3 -3
- package/build/server/chunks/{sync-DZ3dn761.js.map → sync-Bn6eSUhC.js.map} +1 -1
- package/build/server/chunks/{syncBridge-BwXzPdjJ.js → syncAwareRepositories-DvUjq5Q6.js} +27 -3
- package/build/server/chunks/syncAwareRepositories-DvUjq5Q6.js.map +1 -0
- package/build/server/chunks/{tagPaletteStore.svelte-DfZOBvgY.js → tagPaletteStore.svelte-C71bdzDl.js} +4 -4
- package/build/server/chunks/{tagPaletteStore.svelte-DfZOBvgY.js.map → tagPaletteStore.svelte-C71bdzDl.js.map} +1 -1
- package/build/server/index.js +2 -2
- package/build/server/index.js.map +1 -1
- package/build/server/manifest.js +74 -29
- package/build/server/manifest.js.map +1 -1
- package/cli/README.md +70 -2
- package/cli/commands/check.ts +190 -0
- package/cli/commands/ci.ts +71 -0
- package/cli/commands/coverage-ingest.ts +112 -0
- package/cli/commands/dashboard.ts +14 -0
- package/cli/commands/init.ts +26 -0
- package/cli/commands/scenarios-adapter.ts +96 -0
- package/cli/commands/theme.ts +62 -0
- package/cli/scenarios/adapter-scaffold.ts +99 -0
- package/cli/scenarios/codegen.ts +7 -1
- package/cli/scenarios/results.ts +85 -0
- package/cli/skills/unspa-audit/SKILL.md +19 -0
- package/cli/skills/unspa-edit/SKILL.md +20 -3
- package/cli/skills/unspa-implement/SKILL.md +28 -0
- package/cli/unspa.ts +136 -2
- package/cli/util/context-files.ts +18 -2
- package/cli/util/theme.ts +34 -0
- package/mcp-server/bin.ts +104 -104
- package/mcp-server/migrate-defaults.ts +164 -164
- package/mcp-server/repo-link.ts +142 -134
- package/mcp-server/resources/guide.ts +24 -4
- package/mcp-server/resources/operations.ts +3 -0
- package/mcp-server/seed-snapshots.ts +22 -22
- package/mcp-server/server.ts +8 -4
- package/mcp-server/sync-aware-repos.ts +79 -79
- package/mcp-server/sync-notifier.ts +180 -127
- package/mcp-server/tools/_codegen.ts +115 -115
- package/mcp-server/tools/_entity_builders.ts +30 -0
- package/mcp-server/tools/_shared.ts +210 -210
- package/mcp-server/tools/action.ts +210 -210
- package/mcp-server/tools/batch.ts +29 -5
- package/mcp-server/tools/effect.ts +139 -135
- package/mcp-server/tools/entity.ts +132 -132
- package/mcp-server/tools/entityField.ts +132 -132
- package/mcp-server/tools/event.ts +116 -116
- package/mcp-server/tools/feature.ts +264 -264
- package/mcp-server/tools/invariant.ts +275 -275
- package/mcp-server/tools/persona.ts +141 -141
- package/mcp-server/tools/project.ts +500 -391
- package/mcp-server/tools/reachabilityGoal.ts +97 -0
- package/mcp-server/tools/read.ts +526 -483
- package/mcp-server/tools/reorder.ts +114 -114
- package/mcp-server/tools/resource.ts +194 -194
- package/mcp-server/tools/rule.ts +302 -302
- package/mcp-server/tools/scenario.ts +4 -1
- package/mcp-server/tools/specGaps.ts +221 -221
- package/mcp-server/tools/state.ts +10 -2
- package/mcp-server/tools/surface.ts +102 -102
- package/mcp-server/tools/transition.ts +96 -96
- package/mcp-server/tools/verification.ts +131 -0
- package/package.json +15 -2
- package/src/app.css +208 -9
- package/src/app.html +15 -1
- package/src/features/behavior-model/application/ports/FeatureRepository.ts +16 -16
- package/src/features/behavior-model/application/use-cases/CreateFeature.ts +24 -24
- package/src/features/behavior-model/application/use-cases/DeleteFeature.ts +8 -8
- package/src/features/behavior-model/application/use-cases/GetFeature.ts +9 -9
- package/src/features/behavior-model/application/use-cases/ListFeatures.ts +10 -10
- package/src/features/behavior-model/application/use-cases/MutateFeature.ts +90 -90
- package/src/features/behavior-model/application/use-cases/SaveFeature.ts +31 -31
- package/src/features/behavior-model/domain/entities/Entity.ts +45 -45
- package/src/features/behavior-model/domain/entities/EventDefinition.ts +35 -35
- package/src/features/behavior-model/domain/entities/Feature.ts +10 -0
- package/src/features/behavior-model/domain/entities/Persona.ts +33 -33
- package/src/features/behavior-model/domain/entities/ReachabilityGoal.ts +39 -0
- package/src/features/behavior-model/domain/entities/Resource.ts +54 -54
- package/src/features/behavior-model/domain/entities/Scenario.ts +15 -0
- package/src/features/behavior-model/domain/entities/StateDefinition.ts +13 -0
- package/src/features/behavior-model/domain/entities/Surface.ts +75 -75
- package/src/features/behavior-model/domain/entities/index.ts +9 -9
- package/src/features/behavior-model/domain/services/BehaviorGraphModel.ts +556 -0
- package/src/features/behavior-model/domain/services/DerivedState.ts +67 -0
- package/src/features/behavior-model/domain/services/EffectApplier.ts +112 -3
- package/src/features/behavior-model/domain/services/EffectiveEntities.ts +166 -166
- package/src/features/behavior-model/domain/services/EntityDeducer.ts +83 -83
- package/src/features/behavior-model/domain/services/EventCatalog.ts +141 -141
- package/src/features/behavior-model/domain/services/FeatureExpressionNormalizer.ts +43 -5
- package/src/features/behavior-model/domain/services/FeatureSharedStateNormalizer.ts +24 -3
- package/src/features/behavior-model/domain/services/FeatureTransforms.ts +33 -0
- package/src/features/behavior-model/domain/services/FeatureValidator.ts +124 -16
- package/src/features/behavior-model/domain/services/PersonaApplier.ts +39 -39
- package/src/features/behavior-model/domain/services/ResourceDeducer.ts +64 -64
- package/src/features/behavior-model/domain/services/ResourceUsage.ts +79 -79
- package/src/features/behavior-model/domain/services/ScenarioApplier.ts +40 -40
- package/src/features/behavior-model/domain/services/SharedStateDefinitions.ts +32 -32
- package/src/features/behavior-model/domain/services/StatePathReferences.ts +249 -217
- package/src/features/behavior-model/domain/services/TransitionCatalog.ts +173 -173
- package/src/features/behavior-model/domain/value-objects/Effect.ts +100 -3
- package/src/features/behavior-model/domain/value-objects/EntityFieldType.ts +57 -57
- package/src/features/behavior-model/domain/value-objects/Expression.ts +22 -2
- package/src/features/behavior-model/domain/value-objects/ParameterType.ts +57 -57
- package/src/features/behavior-model/domain/value-objects/Resource.ts +210 -210
- package/src/features/behavior-model/domain/value-objects/RuleCategory.ts +57 -57
- package/src/features/behavior-model/domain/value-objects/RuleCondition.ts +52 -1
- package/src/features/behavior-model/domain/value-objects/SimulationClock.ts +35 -0
- package/src/features/behavior-model/domain/value-objects/ids.ts +2 -0
- package/src/features/behavior-model/infrastructure/io/FeatureJson.ts +89 -89
- package/src/features/behavior-model/infrastructure/persistence/HttpFeatureRepository.ts +43 -43
- package/src/features/behavior-model/infrastructure/persistence/JsonFolderFeatureRepository.ts +10 -0
- package/src/features/behavior-model/infrastructure/persistence/snapshot-discovery.ts +76 -76
- package/src/features/behavior-model/infrastructure/seed/seedStorefront.ts +967 -967
- package/src/features/behavior-model/presentation/adapters/VisBehaviorGraphRenderer.ts +501 -0
- package/src/features/behavior-model/presentation/components/ActionEditor.svelte +683 -682
- package/src/features/behavior-model/presentation/components/ActionsEditor.svelte +232 -232
- package/src/features/behavior-model/presentation/components/BehaviorGraph.svelte +568 -0
- package/src/features/behavior-model/presentation/components/EffectEditor.svelte +168 -168
- package/src/features/behavior-model/presentation/components/EntityEditor.svelte +241 -248
- package/src/features/behavior-model/presentation/components/EntityFieldRow.svelte +180 -181
- package/src/features/behavior-model/presentation/components/EntityManager.svelte +252 -251
- package/src/features/behavior-model/presentation/components/EventsManager.svelte +373 -372
- package/src/features/behavior-model/presentation/components/FeatureEditor.svelte +396 -348
- package/src/features/behavior-model/presentation/components/FeatureHeader.svelte +165 -148
- package/src/features/behavior-model/presentation/components/FeatureHealthStrip.svelte +110 -110
- package/src/features/behavior-model/presentation/components/HistoryPanel.svelte +154 -154
- package/src/features/behavior-model/presentation/components/NewFeatureForm.svelte +66 -66
- package/src/features/behavior-model/presentation/components/ParameterNameSelect.svelte +84 -84
- package/src/features/behavior-model/presentation/components/ParametersEditor.svelte +411 -411
- package/src/features/behavior-model/presentation/components/PersonaEditor.svelte +244 -244
- package/src/features/behavior-model/presentation/components/PersonasManager.svelte +130 -130
- package/src/features/behavior-model/presentation/components/ReachabilityGoalEditor.svelte +230 -0
- package/src/features/behavior-model/presentation/components/ReachabilityGoalsEditor.svelte +86 -0
- package/src/features/behavior-model/presentation/components/ResourcesManager.svelte +291 -290
- package/src/features/behavior-model/presentation/components/ScenariosEditor.svelte +496 -496
- package/src/features/behavior-model/presentation/components/StateDefinitionsEditor.svelte +356 -356
- package/src/features/behavior-model/presentation/components/SurfaceEntitiesView.svelte +88 -88
- package/src/features/behavior-model/presentation/components/SurfaceInvariantsEditor.svelte +76 -76
- package/src/features/behavior-model/presentation/components/SurfaceList.svelte +300 -300
- package/src/features/behavior-model/presentation/components/SurfaceMetaEditor.svelte +158 -156
- package/src/features/behavior-model/presentation/components/SurfacePanel.svelte +198 -198
- package/src/features/behavior-model/presentation/components/SurfacePersonasView.svelte +122 -122
- package/src/features/behavior-model/presentation/components/SurfaceResourcesView.svelte +113 -113
- package/src/features/behavior-model/presentation/components/SurfaceRulesEditor.svelte +69 -69
- package/src/features/behavior-model/presentation/components/TransitionsManager.svelte +322 -321
- package/src/features/behavior-model/presentation/context/featureQueueContext.ts +78 -0
- package/src/features/behavior-model/presentation/stores/editorStore.svelte.ts +132 -131
- package/src/features/behavior-model/presentation/stores/featureStore.svelte.ts +177 -177
- package/src/features/behavior-model/presentation/stores/featuresStore.svelte.ts +98 -98
- package/src/features/behavior-model/presentation/view-models/BehaviorGraphTheme.ts +44 -0
- package/src/features/behavior-model/presentation/view-models/factories.ts +181 -132
- package/src/features/builder-mode/domain/BuilderModeDashboard.ts +7 -1
- package/src/features/builder-mode/presentation/components/BuilderModeDashboard.svelte +78 -16
- package/src/features/builder-mode/presentation/components/BuilderTagChips.svelte +25 -0
- package/src/features/builder-mode/presentation/stores/builderModeStore.svelte.ts +247 -3
- package/src/features/domains/infrastructure/persistence/JsonFolderDomainRepository.ts +9 -0
- package/src/features/global-search/application/use-cases/LoadSearchIndex.ts +70 -0
- package/src/features/global-search/domain/SearchDoc.ts +111 -0
- package/src/features/global-search/domain/buildSearchDocs.ts +483 -0
- package/src/features/global-search/domain/searchNav.ts +58 -0
- package/src/features/global-search/domain/searchScoring.ts +81 -0
- package/src/features/global-search/infrastructure/adapters/defaultSearchHost.ts +28 -0
- package/src/features/global-search/presentation/components/GlobalSearch.svelte +262 -0
- package/src/features/global-search/presentation/ports/SearchHostPorts.ts +41 -0
- package/src/features/global-search/presentation/searchKindMeta.ts +108 -0
- package/src/features/global-search/presentation/stores/globalSearchStore.svelte.ts +171 -0
- package/src/features/implementation-queue/presentation/components/FloatingQueueWidget.svelte +264 -0
- package/src/features/implementation-queue/presentation/stores/globalQueueStore.svelte.ts +172 -0
- package/src/features/implementation-status/application/ports/ImplementationStatusRepository.ts +8 -8
- package/src/features/implementation-status/application/use-cases/GetImplementationStatus.ts +8 -8
- package/src/features/implementation-status/domain/ApplyCapturedToSpec.ts +323 -322
- package/src/features/implementation-status/domain/FieldDiff.ts +238 -236
- package/src/features/implementation-status/infrastructure/persistence/InMemoryImplementationStatusRepository.ts +21 -21
- package/src/features/implementation-status/presentation/components/ImplementationStatusPanel.svelte +831 -831
- package/src/features/implementation-status/presentation/stores/implementationStatusStore.svelte.ts +97 -97
- package/src/features/library/application/use-cases/ApplyBlueprintsToFeature.ts +33 -33
- package/src/features/library/domain/services/BlueprintApplier.ts +94 -94
- package/src/features/library/infrastructure/blueprints/auth/ResetPasswordBlueprint.ts +332 -332
- package/src/features/library/infrastructure/blueprints/auth/SignInBlueprint.ts +281 -281
- package/src/features/library/infrastructure/blueprints/auth/SignUpBlueprint.ts +299 -299
- package/src/features/library/infrastructure/blueprints/auth/VerifyEmailBlueprint.ts +288 -288
- package/src/features/library/infrastructure/blueprints/auth/shared.ts +146 -146
- package/src/features/library/infrastructure/blueprints/commerce/CartBlueprint.ts +222 -222
- package/src/features/library/infrastructure/blueprints/commerce/CatalogBlueprint.ts +190 -190
- package/src/features/library/infrastructure/blueprints/commerce/CheckoutBlueprint.ts +322 -322
- package/src/features/library/infrastructure/blueprints/commerce/OrderConfirmationBlueprint.ts +172 -172
- package/src/features/library/infrastructure/blueprints/commerce/ProductDetailsBlueprint.ts +290 -290
- package/src/features/library/infrastructure/blueprints/content/ReviewsBlueprint.ts +392 -392
- package/src/features/library/infrastructure/blueprints/onboarding/OnboardingWizardBlueprint.ts +344 -344
- package/src/features/library/infrastructure/blueprints/utility/CanvasBlueprint.ts +419 -419
- package/src/features/library/infrastructure/blueprints/utility/CookieConsentBlueprint.ts +195 -195
- package/src/features/library/infrastructure/blueprints/utility/NotFoundBlueprint.ts +86 -86
- package/src/features/library/infrastructure/blueprints/utility/SearchPaletteBlueprint.ts +192 -192
- package/src/features/library/infrastructure/blueprints/utility/StoreLocatorBlueprint.ts +221 -221
- package/src/features/library/infrastructure/blueprints/utility/TaskBoardBlueprint.ts +196 -196
- package/src/features/maturity/application/use-cases/ScoreFeature.ts +7 -7
- package/src/features/maturity/domain/MaturityReport.ts +70 -70
- package/src/features/maturity/domain/MaturityScorer.ts +1001 -985
- package/src/features/maturity/presentation/components/MaturityPanel.svelte +376 -372
- package/src/features/mcp-tools/application/tools/dryRunSimulate.ts +24 -24
- package/src/features/mcp-tools/application/tools/findStateReferences.ts +19 -19
- package/src/features/mcp-tools/application/tools/generateTypes.ts +0 -1
- package/src/features/mcp-tools/application/tools/getAction.ts +165 -165
- package/src/features/mcp-tools/application/tools/getFeature.ts +5 -5
- package/src/features/mcp-tools/application/tools/getFeatureIndex.ts +79 -79
- package/src/features/mcp-tools/application/tools/getNeighborhood.ts +319 -319
- package/src/features/mcp-tools/application/tools/getSurface.ts +86 -86
- package/src/features/mcp-tools/application/tools/index.ts +56 -56
- package/src/features/mcp-tools/application/tools/listActions.ts +49 -49
- package/src/features/mcp-tools/application/tools/listFeatures.ts +7 -7
- package/src/features/mcp-tools/application/tools/scoreFeature.ts +153 -153
- package/src/features/projects/application/ports/ProjectRepository.ts +14 -14
- package/src/features/projects/application/use-cases/AddFeatureToProject.ts +23 -23
- package/src/features/projects/application/use-cases/CreateProject.ts +16 -16
- package/src/features/projects/application/use-cases/FindProjectContainingFeature.ts +23 -23
- package/src/features/projects/application/use-cases/GetProjectAggregate.ts +131 -131
- package/src/features/projects/application/use-cases/ImportProjectBundle.ts +45 -0
- package/src/features/projects/application/use-cases/MoveFeatureInProject.ts +36 -36
- package/src/features/projects/application/use-cases/RemoveFeatureFromProject.ts +23 -23
- package/src/features/projects/domain/entities/Project.ts +12 -0
- package/src/features/projects/domain/services/InheritedFromProject.ts +130 -130
- package/src/features/projects/infrastructure/persistence/JsonFolderProjectRepository.ts +9 -0
- package/src/features/projects/presentation/components/ProjectCard.svelte +27 -8
- package/src/features/projects/presentation/components/ProjectEditor.svelte +23 -19
- package/src/features/projects/presentation/components/ProjectFeaturesPanel.svelte +433 -433
- package/src/features/projects/presentation/components/ProjectsIndex.svelte +54 -10
- package/src/features/projects/presentation/stores/projectContextStore.svelte.ts +170 -170
- package/src/features/projects/presentation/stores/projectFeaturesStore.svelte.ts +114 -114
- package/src/features/projects/presentation/stores/projectStore.svelte.ts +265 -266
- package/src/features/projects/presentation/stores/projectsStore.svelte.ts +134 -134
- package/src/features/simulator/application/use-cases/RunScenarios.ts +27 -1
- package/src/features/simulator/application/use-cases/SimulateAction.ts +47 -47
- package/src/features/simulator/domain/SimulationResult.ts +79 -79
- package/src/features/simulator/domain/SimulatorEngine.ts +43 -9
- package/src/features/simulator/domain/StateExplorer.ts +369 -0
- package/src/features/simulator/domain/SurfaceReachability.ts +130 -0
- package/src/features/simulator/presentation/components/ParameterInputs.svelte +277 -277
- package/src/features/simulator/presentation/components/PersonaPicker.svelte +52 -52
- package/src/features/simulator/presentation/components/ScenarioPicker.svelte +42 -45
- package/src/features/simulator/presentation/components/SidePanel.svelte +170 -170
- package/src/features/simulator/presentation/components/SimulationResultView.svelte +394 -394
- package/src/features/simulator/presentation/components/SimulatorPanel.svelte +293 -293
- package/src/features/simulator/presentation/components/StateInspector.svelte +101 -101
- package/src/features/simulator/presentation/stores/simulatorStore.svelte.ts +268 -268
- package/src/features/tutorial/presentation/components/CodeBlock.svelte +5 -1
- package/src/features/verification/application/ports/BehavioralIndexReader.ts +12 -0
- package/src/features/verification/application/use-cases/VerifyFeatures.ts +151 -0
- package/src/features/verification/domain/DriftReport.ts +37 -0
- package/src/features/verification/domain/EventCoherenceReport.ts +27 -0
- package/src/features/verification/domain/IndexedImplementation.ts +27 -0
- package/src/features/verification/domain/VerificationReport.ts +59 -0
- package/src/features/verification/domain/VerificationThresholds.ts +52 -0
- package/src/features/verification/domain/VerificationVerdict.ts +43 -0
- package/src/features/verification/domain/aggregateVerdict.ts +244 -0
- package/src/features/verification/domain/analyzeEventCoherence.ts +43 -0
- package/src/features/verification/domain/detectDrift.ts +166 -0
- package/src/features/verification/domain/verifiedCoverage.ts +37 -0
- package/src/features/verification/infrastructure/persistence/FileBehavioralIndexReader.ts +81 -0
- package/src/features/verification/infrastructure/persistence/StaticBehavioralIndexReader.ts +15 -0
- package/src/features/verification/presentation/components/VerifyPanel.svelte +74 -0
- package/src/features/verification/presentation/stores/verificationStore.svelte.ts +64 -0
- package/src/hooks.server.ts +11 -1
- package/src/lib/server/openLocalDirectory.ts +40 -0
- package/src/lib/server/searchIndex.ts +161 -0
- package/src/lib/server/snapshotRepository.ts +37 -37
- package/src/lib/server/sync/YDocManager.ts +391 -391
- package/src/lib/server/sync/historyStore.ts +276 -276
- package/src/lib/server/sync/wsServer.ts +1 -1
- package/src/lib/sync/protocol.ts +147 -147
- package/src/lib/sync/roomId.ts +33 -33
- package/src/lib/theme/registry.ts +77 -0
- package/src/lib/theme/themeStore.svelte.ts +64 -0
- package/src/routes/+layout.svelte +288 -30
- package/src/routes/api/domains/[id]/+server.ts +7 -3
- package/src/routes/api/projects/[id]/+server.ts +14 -4
- package/src/routes/api/projects/import/+server.ts +16 -38
- package/src/routes/api/search-index/+server.ts +16 -0
- package/src/routes/api/snapshots/[id]/+server.ts +56 -44
- package/src/routes/api/snapshots/[id]/implementation-status/+server.ts +13 -13
- package/src/routes/api/snapshots/[id]/verify/+server.ts +37 -0
- package/src/routes/api/sync/reload/+server.ts +157 -157
- package/src/routes/api/system/hub-directory/+server.ts +24 -0
- package/src/routes/features/+page.svelte +484 -484
- package/src/routes/features/[id]/+page.svelte +55 -49
- package/src/routes/features/[id]/graph/+page.svelte +39 -0
- package/src/routes/features/[id]/verify/+page.svelte +89 -0
- package/src/routes/mcp/+page.svelte +16 -1
- package/src/routes/projects/[id]/+page.svelte +70 -70
- package/src/routes/projects/[id]/graph/+page.svelte +79 -0
- package/src/routes/tutorial/+page.svelte +3 -2
- package/src/shared/infrastructure/browserContainer.ts +61 -61
- package/src/shared/presentation/components/KebabMenu.svelte +95 -0
- package/src/shared/presentation/components/MenuItem.svelte +29 -0
- package/src/shared/presentation/components/ProgressBar.svelte +1 -1
- package/src/shared/presentation/toast/SyncToast.svelte +14 -3
- package/src/shared/presentation/toast/viewLinkResolver.ts +32 -0
- package/static/lyriks_logo.svg +148 -0
- package/vite.config.ts +47 -47
- package/build/client/_app/immutable/assets/0.DFMDYAU9.css +0 -1
- package/build/client/_app/immutable/assets/0.DFMDYAU9.css.br +0 -0
- package/build/client/_app/immutable/assets/0.DFMDYAU9.css.gz +0 -0
- package/build/client/_app/immutable/assets/9.nv0I59TU.css.gz +0 -0
- package/build/client/_app/immutable/chunks/BO66rBOa2.js +0 -1
- package/build/client/_app/immutable/chunks/BO66rBOa2.js.br +0 -0
- package/build/client/_app/immutable/chunks/BO66rBOa2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BOrLmFwJ.js.br +0 -0
- package/build/client/_app/immutable/chunks/BOrLmFwJ.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BfMYiIUi.js.br +0 -0
- package/build/client/_app/immutable/chunks/BfMYiIUi.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bp2_Vghh.js +0 -1
- package/build/client/_app/immutable/chunks/Bp2_Vghh.js.br +0 -0
- package/build/client/_app/immutable/chunks/Bp2_Vghh.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Bp8HpEPe2.js +0 -4
- package/build/client/_app/immutable/chunks/Bp8HpEPe2.js.br +0 -0
- package/build/client/_app/immutable/chunks/Bp8HpEPe2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/C8rRKIXT.js +0 -1
- package/build/client/_app/immutable/chunks/C8rRKIXT.js.br +0 -0
- package/build/client/_app/immutable/chunks/C8rRKIXT.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CJjJLwzv2.js +0 -1
- package/build/client/_app/immutable/chunks/CJjJLwzv2.js.br +0 -0
- package/build/client/_app/immutable/chunks/CJjJLwzv2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CxyLMlpt2.js.br +0 -0
- package/build/client/_app/immutable/chunks/CxyLMlpt2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D6jhrpTg.js +0 -1
- package/build/client/_app/immutable/chunks/D6jhrpTg.js.br +0 -0
- package/build/client/_app/immutable/chunks/D6jhrpTg.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D8YEa1po.js +0 -1
- package/build/client/_app/immutable/chunks/D8YEa1po.js.br +0 -0
- package/build/client/_app/immutable/chunks/D8YEa1po.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D9dKmajw.js +0 -1
- package/build/client/_app/immutable/chunks/D9dKmajw.js.br +0 -0
- package/build/client/_app/immutable/chunks/D9dKmajw.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DBJWcC6Y.js +0 -1
- package/build/client/_app/immutable/chunks/DBJWcC6Y.js.br +0 -0
- package/build/client/_app/immutable/chunks/DBJWcC6Y.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DHoA038D.js +0 -1
- package/build/client/_app/immutable/chunks/DHoA038D.js.br +0 -2
- package/build/client/_app/immutable/chunks/DHoA038D.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DKgYpi6_.js +0 -1
- package/build/client/_app/immutable/chunks/DKgYpi6_.js.br +0 -0
- package/build/client/_app/immutable/chunks/DKgYpi6_.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DatGSObE.js +0 -1
- package/build/client/_app/immutable/chunks/DatGSObE.js.br +0 -0
- package/build/client/_app/immutable/chunks/DatGSObE.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Dg0acPpT.js +0 -1
- package/build/client/_app/immutable/chunks/Dg0acPpT.js.br +0 -0
- package/build/client/_app/immutable/chunks/Dg0acPpT.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DjWKKtqp.js +0 -1
- package/build/client/_app/immutable/chunks/DjWKKtqp.js.br +0 -1
- package/build/client/_app/immutable/chunks/DjWKKtqp.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Dq0DUAz1.js +0 -1
- package/build/client/_app/immutable/chunks/Dq0DUAz1.js.br +0 -0
- package/build/client/_app/immutable/chunks/Dq0DUAz1.js.gz +0 -0
- package/build/client/_app/immutable/chunks/HKLi1Yz3.js +0 -1
- package/build/client/_app/immutable/chunks/HKLi1Yz3.js.br +0 -0
- package/build/client/_app/immutable/chunks/HKLi1Yz3.js.gz +0 -0
- package/build/client/_app/immutable/chunks/N7PXjlRH.js +0 -1
- package/build/client/_app/immutable/chunks/N7PXjlRH.js.br +0 -0
- package/build/client/_app/immutable/chunks/N7PXjlRH.js.gz +0 -0
- package/build/client/_app/immutable/chunks/hpWJNn0t2.js +0 -2
- package/build/client/_app/immutable/chunks/hpWJNn0t2.js.br +0 -0
- package/build/client/_app/immutable/chunks/hpWJNn0t2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/iQu0D9Ux.js +0 -1
- package/build/client/_app/immutable/chunks/iQu0D9Ux.js.br +0 -0
- package/build/client/_app/immutable/chunks/iQu0D9Ux.js.gz +0 -0
- package/build/client/_app/immutable/entry/app.CLgh6Mx_.js +0 -2
- package/build/client/_app/immutable/entry/app.CLgh6Mx_.js.br +0 -0
- package/build/client/_app/immutable/entry/app.CLgh6Mx_.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.D5GPCQZD.js +0 -1
- package/build/client/_app/immutable/entry/start.D5GPCQZD.js.br +0 -0
- package/build/client/_app/immutable/entry/start.D5GPCQZD.js.gz +0 -0
- package/build/client/_app/immutable/nodes/0.BOoI-hsu.js +0 -4
- package/build/client/_app/immutable/nodes/0.BOoI-hsu.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.BOoI-hsu.js.gz +0 -0
- package/build/client/_app/immutable/nodes/1.KYdA6ppX.js.br +0 -2
- package/build/client/_app/immutable/nodes/1.KYdA6ppX.js.gz +0 -0
- package/build/client/_app/immutable/nodes/2.DBz20KgG.js.br +0 -0
- package/build/client/_app/immutable/nodes/2.DBz20KgG.js.gz +0 -0
- package/build/client/_app/immutable/nodes/3.19DIoFtw.js +0 -1
- package/build/client/_app/immutable/nodes/3.19DIoFtw.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.19DIoFtw.js.gz +0 -0
- package/build/client/_app/immutable/nodes/4.BvMzqBJj.js +0 -3
- package/build/client/_app/immutable/nodes/4.BvMzqBJj.js.br +0 -0
- package/build/client/_app/immutable/nodes/4.BvMzqBJj.js.gz +0 -0
- package/build/client/_app/immutable/nodes/5.Dq6obSGG.js +0 -42
- package/build/client/_app/immutable/nodes/5.Dq6obSGG.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.Dq6obSGG.js.gz +0 -0
- package/build/client/_app/immutable/nodes/6.BOHISqs-.js +0 -5
- package/build/client/_app/immutable/nodes/6.BOHISqs-.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.BOHISqs-.js.gz +0 -0
- package/build/client/_app/immutable/nodes/7.CemgNJfw.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.CemgNJfw.js.gz +0 -0
- package/build/client/_app/immutable/nodes/8.DejSfIYh.js +0 -5
- package/build/client/_app/immutable/nodes/8.DejSfIYh.js.br +0 -0
- package/build/client/_app/immutable/nodes/8.DejSfIYh.js.gz +0 -0
- package/build/client/_app/immutable/nodes/9.CMW6a2Lg.js.br +0 -0
- package/build/client/_app/immutable/nodes/9.CMW6a2Lg.js.gz +0 -0
- package/build/server/chunks/0-C_o0oz-N.js +0 -15
- package/build/server/chunks/0-C_o0oz-N.js.map +0 -1
- package/build/server/chunks/1-DPpKAKXV.js +0 -9
- package/build/server/chunks/2-AlfFqtL1.js +0 -9
- package/build/server/chunks/2-AlfFqtL1.js.map +0 -1
- package/build/server/chunks/3-vbjUt_51.js +0 -16
- package/build/server/chunks/3-vbjUt_51.js.map +0 -1
- package/build/server/chunks/4-BNow4x6D.js +0 -16
- package/build/server/chunks/4-BNow4x6D.js.map +0 -1
- package/build/server/chunks/5-D7OCJpxD.js +0 -9
- package/build/server/chunks/5-D7OCJpxD.js.map +0 -1
- package/build/server/chunks/6-QQ7r8Rd5.js +0 -9
- package/build/server/chunks/7-CbPLGaIG.js +0 -9
- package/build/server/chunks/7-CbPLGaIG.js.map +0 -1
- package/build/server/chunks/8-CVO-E-sf.js +0 -9
- package/build/server/chunks/8-CVO-E-sf.js.map +0 -1
- package/build/server/chunks/9-DxT1baO5.js +0 -9
- package/build/server/chunks/9-DxT1baO5.js.map +0 -1
- package/build/server/chunks/FeatureTransforms-UWDHmWEg.js.map +0 -1
- package/build/server/chunks/FeatureValidator-B8qEjAUW.js.map +0 -1
- package/build/server/chunks/ManageTagsDialog-DBxA3tM2.js.map +0 -1
- package/build/server/chunks/ProgressBar-CfhccQ83.js.map +0 -1
- package/build/server/chunks/ProjectsIndex-CoDrvRya.js.map +0 -1
- package/build/server/chunks/RenameTag-BuWLMl1m.js.map +0 -1
- package/build/server/chunks/TagDotStrip-B1XQ0m0Y.js.map +0 -1
- package/build/server/chunks/TagPalette-CtMNYCmu.js.map +0 -1
- package/build/server/chunks/_layout.svelte-BREws55o.js +0 -616
- package/build/server/chunks/_layout.svelte-BREws55o.js.map +0 -1
- package/build/server/chunks/_page.svelte-B1s7jxaQ.js.map +0 -1
- package/build/server/chunks/_page.svelte-B7hT3P8E.js +0 -29
- package/build/server/chunks/_page.svelte-BqSC-1vK.js.map +0 -1
- package/build/server/chunks/_page.svelte-BtI2zZ_Z.js.map +0 -1
- package/build/server/chunks/_page.svelte-De508ek8.js +0 -29
- package/build/server/chunks/_page.svelte-Zf9H4KOP.js.map +0 -1
- package/build/server/chunks/_server.ts-0uNTZKwF.js.map +0 -1
- package/build/server/chunks/_server.ts-DcZPhyhK.js +0 -59
- package/build/server/chunks/_server.ts-DcZPhyhK.js.map +0 -1
- package/build/server/chunks/_server.ts-Dy5zQHe2.js.map +0 -1
- package/build/server/chunks/_server.ts-YnfXkeMJ.js.map +0 -1
- package/build/server/chunks/_server.ts-vcaqdwxS.js.map +0 -1
- package/build/server/chunks/browserContainer-CNX7ANld.js.map +0 -1
- package/build/server/chunks/builderModeStore.svelte-ihupr-3p.js.map +0 -1
- package/build/server/chunks/client-DfpLcAZ9.js +0 -24
- package/build/server/chunks/featuresStore.svelte-DR1gYZyu.js +0 -98
- package/build/server/chunks/featuresStore.svelte-DR1gYZyu.js.map +0 -1
- package/build/server/chunks/hooks.server-Rv301GTB.js.map +0 -1
- package/build/server/chunks/identityStore.svelte-IIvW2_3b.js +0 -59
- package/build/server/chunks/identityStore.svelte-IIvW2_3b.js.map +0 -1
- package/build/server/chunks/projectsStore.svelte-QDz5PchX.js.map +0 -1
- package/build/server/chunks/reconcile-Dv7jS3C8.js.map +0 -1
- package/build/server/chunks/snapshotRepository-BPXCjX92.js.map +0 -1
- package/build/server/chunks/syncBridge-BwXzPdjJ.js.map +0 -1
- package/src/features/implementation-queue/presentation/components/QueuePanel.svelte +0 -204
- package/src/features/implementation-queue/presentation/stores/queueStore.svelte.ts +0 -143
- /package/build/client/_app/immutable/assets/{9.nv0I59TU.css → 12.nv0I59TU.css} +0 -0
- /package/build/client/_app/immutable/assets/{9.nv0I59TU.css.br → 12.nv0I59TU.css.br} +0 -0
|
@@ -1,174 +1,174 @@
|
|
|
1
|
-
import type { Feature } from '../entities/Feature';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Where a surface→surface transition was authored. Used by the UI to deep-link
|
|
5
|
-
* back to the source and to show *why* a navigation can happen.
|
|
6
|
-
*/
|
|
7
|
-
export type TransitionOrigin =
|
|
8
|
-
| 'declared'
|
|
9
|
-
| 'action_effect'
|
|
10
|
-
| 'action_rule_effect'
|
|
11
|
-
| 'surface_rule_effect';
|
|
12
|
-
|
|
13
|
-
export type TransitionSource = {
|
|
14
|
-
readonly surfaceId: string;
|
|
15
|
-
readonly surfaceName: string;
|
|
16
|
-
readonly actionId?: string;
|
|
17
|
-
readonly actionName?: string;
|
|
18
|
-
readonly origin: TransitionOrigin;
|
|
19
|
-
/** Optional rationale (rule.description, transition.label, …) */
|
|
20
|
-
readonly description?: string;
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
export type TransitionEntry = {
|
|
24
|
-
readonly fromSurfaceId: string;
|
|
25
|
-
readonly fromSurfaceName: string;
|
|
26
|
-
readonly toSurfaceId: string;
|
|
27
|
-
readonly toSurfaceName: string;
|
|
28
|
-
readonly sources: readonly TransitionSource[];
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Walk every surface and collect every authored transition between two
|
|
33
|
-
* surfaces, regardless of where it lives in the model:
|
|
34
|
-
* - `surface.transitions` (declared navigation hints)
|
|
35
|
-
* - action default effects of type `transition_surface`
|
|
36
|
-
* - action rule effects of type `transition_surface`
|
|
37
|
-
* - surface-level rule effects of type `transition_surface`
|
|
38
|
-
*
|
|
39
|
-
* Edges with the same (from, to) pair collapse into one entry whose
|
|
40
|
-
* `sources` lists every contribution. Output is sorted by source surface
|
|
1
|
+
import type { Feature } from '../entities/Feature';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Where a surface→surface transition was authored. Used by the UI to deep-link
|
|
5
|
+
* back to the source and to show *why* a navigation can happen.
|
|
6
|
+
*/
|
|
7
|
+
export type TransitionOrigin =
|
|
8
|
+
| 'declared'
|
|
9
|
+
| 'action_effect'
|
|
10
|
+
| 'action_rule_effect'
|
|
11
|
+
| 'surface_rule_effect';
|
|
12
|
+
|
|
13
|
+
export type TransitionSource = {
|
|
14
|
+
readonly surfaceId: string;
|
|
15
|
+
readonly surfaceName: string;
|
|
16
|
+
readonly actionId?: string;
|
|
17
|
+
readonly actionName?: string;
|
|
18
|
+
readonly origin: TransitionOrigin;
|
|
19
|
+
/** Optional rationale (rule.description, transition.label, …) */
|
|
20
|
+
readonly description?: string;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
export type TransitionEntry = {
|
|
24
|
+
readonly fromSurfaceId: string;
|
|
25
|
+
readonly fromSurfaceName: string;
|
|
26
|
+
readonly toSurfaceId: string;
|
|
27
|
+
readonly toSurfaceName: string;
|
|
28
|
+
readonly sources: readonly TransitionSource[];
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Walk every surface and collect every authored transition between two
|
|
33
|
+
* surfaces, regardless of where it lives in the model:
|
|
34
|
+
* - `surface.transitions` (declared navigation hints)
|
|
35
|
+
* - action default effects of type `transition_surface`
|
|
36
|
+
* - action rule effects of type `transition_surface`
|
|
37
|
+
* - surface-level rule effects of type `transition_surface`
|
|
38
|
+
*
|
|
39
|
+
* Edges with the same (from, to) pair collapse into one entry whose
|
|
40
|
+
* `sources` lists every contribution. Output is sorted by source surface
|
|
41
41
|
* order (matches the feature editor's surface list), then by target surface name.
|
|
42
|
-
*/
|
|
43
|
-
export const buildTransitionCatalog = (
|
|
44
|
-
feature: Feature
|
|
45
|
-
): readonly TransitionEntry[] => {
|
|
46
|
-
const surfaceById = new Map<string, { name: string; index: number }>();
|
|
47
|
-
feature.surfaces.forEach((s, index) => {
|
|
48
|
-
surfaceById.set(s.id as unknown as string, { name: s.name, index });
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
type Acc = { sources: TransitionSource[]; fromIndex: number };
|
|
52
|
-
const byEdge = new Map<string, Acc>();
|
|
53
|
-
|
|
54
|
-
const targetExists = (id: string | undefined): id is string =>
|
|
55
|
-
id !== undefined && surfaceById.has(id);
|
|
56
|
-
|
|
57
|
-
const push = (
|
|
58
|
-
fromId: string,
|
|
59
|
-
toId: string,
|
|
60
|
-
source: TransitionSource
|
|
61
|
-
) => {
|
|
62
|
-
if (!targetExists(toId)) return; // dangling targets don't make a real edge
|
|
63
|
-
const key = `${fromId}__${toId}`;
|
|
64
|
-
let acc = byEdge.get(key);
|
|
65
|
-
if (!acc) {
|
|
66
|
-
acc = { sources: [], fromIndex: surfaceById.get(fromId)?.index ?? 0 };
|
|
67
|
-
byEdge.set(key, acc);
|
|
68
|
-
}
|
|
69
|
-
acc.sources.push(source);
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
for (const surface of feature.surfaces) {
|
|
73
|
-
const fromId = surface.id as unknown as string;
|
|
74
|
-
const fromName = surface.name;
|
|
75
|
-
|
|
76
|
-
for (const transition of surface.transitions) {
|
|
77
|
-
push(fromId, transition.target as unknown as string, {
|
|
78
|
-
surfaceId: fromId,
|
|
79
|
-
surfaceName: fromName,
|
|
80
|
-
origin: 'declared',
|
|
81
|
-
description: transition.label ?? transition.description
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
for (const cap of surface.actions) {
|
|
86
|
-
// Default effects.
|
|
87
|
-
for (const effect of cap.effects) {
|
|
88
|
-
if (effect.type === 'transition_surface') {
|
|
89
|
-
push(fromId, effect.target as unknown as string, {
|
|
90
|
-
surfaceId: fromId,
|
|
91
|
-
surfaceName: fromName,
|
|
92
|
-
actionId: cap.id as unknown as string,
|
|
93
|
-
actionName: cap.name,
|
|
94
|
-
origin: 'action_effect',
|
|
95
|
-
description: effect.description
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
// Rule effects.
|
|
100
|
-
for (const rule of cap.rules) {
|
|
101
|
-
if (rule.effect.type === 'transition_surface') {
|
|
102
|
-
push(fromId, rule.effect.target as unknown as string, {
|
|
103
|
-
surfaceId: fromId,
|
|
104
|
-
surfaceName: fromName,
|
|
105
|
-
actionId: cap.id as unknown as string,
|
|
106
|
-
actionName: cap.name,
|
|
107
|
-
origin: 'action_rule_effect',
|
|
108
|
-
description: rule.description
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
for (const rule of surface.rules) {
|
|
115
|
-
if (rule.effect.type === 'transition_surface') {
|
|
116
|
-
push(fromId, rule.effect.target as unknown as string, {
|
|
117
|
-
surfaceId: fromId,
|
|
118
|
-
surfaceName: fromName,
|
|
119
|
-
origin: 'surface_rule_effect',
|
|
120
|
-
description: rule.description
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
const entries: TransitionEntry[] = [];
|
|
127
|
-
for (const [key, acc] of byEdge) {
|
|
128
|
-
const [fromId, toId] = key.split('__') as [string, string];
|
|
129
|
-
const from = surfaceById.get(fromId);
|
|
130
|
-
const to = surfaceById.get(toId);
|
|
131
|
-
if (!from || !to) continue;
|
|
132
|
-
entries.push({
|
|
133
|
-
fromSurfaceId: fromId,
|
|
134
|
-
fromSurfaceName: from.name,
|
|
135
|
-
toSurfaceId: toId,
|
|
136
|
-
toSurfaceName: to.name,
|
|
137
|
-
sources: acc.sources
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
entries.sort((a, b) => {
|
|
141
|
-
const fa = surfaceById.get(a.fromSurfaceId)?.index ?? 0;
|
|
142
|
-
const fb = surfaceById.get(b.fromSurfaceId)?.index ?? 0;
|
|
143
|
-
if (fa !== fb) return fa - fb;
|
|
144
|
-
const ta = surfaceById.get(a.toSurfaceId)?.index ?? 0;
|
|
145
|
-
const tb = surfaceById.get(b.toSurfaceId)?.index ?? 0;
|
|
146
|
-
return ta - tb;
|
|
147
|
-
});
|
|
148
|
-
return entries;
|
|
149
|
-
};
|
|
150
|
-
|
|
151
|
-
export type TransitionGroup = {
|
|
152
|
-
readonly fromSurfaceId: string;
|
|
153
|
-
readonly fromSurfaceName: string;
|
|
154
|
-
readonly transitions: readonly TransitionEntry[];
|
|
155
|
-
};
|
|
156
|
-
|
|
157
|
-
export const groupTransitionCatalog = (
|
|
158
|
-
entries: readonly TransitionEntry[]
|
|
159
|
-
): readonly TransitionGroup[] => {
|
|
160
|
-
const map = new Map<string, TransitionGroup>();
|
|
161
|
-
for (const entry of entries) {
|
|
162
|
-
let group = map.get(entry.fromSurfaceId);
|
|
163
|
-
if (!group) {
|
|
164
|
-
group = {
|
|
165
|
-
fromSurfaceId: entry.fromSurfaceId,
|
|
166
|
-
fromSurfaceName: entry.fromSurfaceName,
|
|
167
|
-
transitions: []
|
|
168
|
-
};
|
|
169
|
-
map.set(entry.fromSurfaceId, group);
|
|
170
|
-
}
|
|
171
|
-
(group.transitions as TransitionEntry[]).push(entry);
|
|
172
|
-
}
|
|
173
|
-
return Array.from(map.values());
|
|
174
|
-
};
|
|
42
|
+
*/
|
|
43
|
+
export const buildTransitionCatalog = (
|
|
44
|
+
feature: Feature
|
|
45
|
+
): readonly TransitionEntry[] => {
|
|
46
|
+
const surfaceById = new Map<string, { name: string; index: number }>();
|
|
47
|
+
feature.surfaces.forEach((s, index) => {
|
|
48
|
+
surfaceById.set(s.id as unknown as string, { name: s.name, index });
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
type Acc = { sources: TransitionSource[]; fromIndex: number };
|
|
52
|
+
const byEdge = new Map<string, Acc>();
|
|
53
|
+
|
|
54
|
+
const targetExists = (id: string | undefined): id is string =>
|
|
55
|
+
id !== undefined && surfaceById.has(id);
|
|
56
|
+
|
|
57
|
+
const push = (
|
|
58
|
+
fromId: string,
|
|
59
|
+
toId: string,
|
|
60
|
+
source: TransitionSource
|
|
61
|
+
) => {
|
|
62
|
+
if (!targetExists(toId)) return; // dangling targets don't make a real edge
|
|
63
|
+
const key = `${fromId}__${toId}`;
|
|
64
|
+
let acc = byEdge.get(key);
|
|
65
|
+
if (!acc) {
|
|
66
|
+
acc = { sources: [], fromIndex: surfaceById.get(fromId)?.index ?? 0 };
|
|
67
|
+
byEdge.set(key, acc);
|
|
68
|
+
}
|
|
69
|
+
acc.sources.push(source);
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
for (const surface of feature.surfaces) {
|
|
73
|
+
const fromId = surface.id as unknown as string;
|
|
74
|
+
const fromName = surface.name;
|
|
75
|
+
|
|
76
|
+
for (const transition of surface.transitions) {
|
|
77
|
+
push(fromId, transition.target as unknown as string, {
|
|
78
|
+
surfaceId: fromId,
|
|
79
|
+
surfaceName: fromName,
|
|
80
|
+
origin: 'declared',
|
|
81
|
+
description: transition.label ?? transition.description
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
for (const cap of surface.actions) {
|
|
86
|
+
// Default effects.
|
|
87
|
+
for (const effect of cap.effects) {
|
|
88
|
+
if (effect.type === 'transition_surface') {
|
|
89
|
+
push(fromId, effect.target as unknown as string, {
|
|
90
|
+
surfaceId: fromId,
|
|
91
|
+
surfaceName: fromName,
|
|
92
|
+
actionId: cap.id as unknown as string,
|
|
93
|
+
actionName: cap.name,
|
|
94
|
+
origin: 'action_effect',
|
|
95
|
+
description: effect.description
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
// Rule effects.
|
|
100
|
+
for (const rule of cap.rules) {
|
|
101
|
+
if (rule.effect.type === 'transition_surface') {
|
|
102
|
+
push(fromId, rule.effect.target as unknown as string, {
|
|
103
|
+
surfaceId: fromId,
|
|
104
|
+
surfaceName: fromName,
|
|
105
|
+
actionId: cap.id as unknown as string,
|
|
106
|
+
actionName: cap.name,
|
|
107
|
+
origin: 'action_rule_effect',
|
|
108
|
+
description: rule.description
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
for (const rule of surface.rules) {
|
|
115
|
+
if (rule.effect.type === 'transition_surface') {
|
|
116
|
+
push(fromId, rule.effect.target as unknown as string, {
|
|
117
|
+
surfaceId: fromId,
|
|
118
|
+
surfaceName: fromName,
|
|
119
|
+
origin: 'surface_rule_effect',
|
|
120
|
+
description: rule.description
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
const entries: TransitionEntry[] = [];
|
|
127
|
+
for (const [key, acc] of byEdge) {
|
|
128
|
+
const [fromId, toId] = key.split('__') as [string, string];
|
|
129
|
+
const from = surfaceById.get(fromId);
|
|
130
|
+
const to = surfaceById.get(toId);
|
|
131
|
+
if (!from || !to) continue;
|
|
132
|
+
entries.push({
|
|
133
|
+
fromSurfaceId: fromId,
|
|
134
|
+
fromSurfaceName: from.name,
|
|
135
|
+
toSurfaceId: toId,
|
|
136
|
+
toSurfaceName: to.name,
|
|
137
|
+
sources: acc.sources
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
entries.sort((a, b) => {
|
|
141
|
+
const fa = surfaceById.get(a.fromSurfaceId)?.index ?? 0;
|
|
142
|
+
const fb = surfaceById.get(b.fromSurfaceId)?.index ?? 0;
|
|
143
|
+
if (fa !== fb) return fa - fb;
|
|
144
|
+
const ta = surfaceById.get(a.toSurfaceId)?.index ?? 0;
|
|
145
|
+
const tb = surfaceById.get(b.toSurfaceId)?.index ?? 0;
|
|
146
|
+
return ta - tb;
|
|
147
|
+
});
|
|
148
|
+
return entries;
|
|
149
|
+
};
|
|
150
|
+
|
|
151
|
+
export type TransitionGroup = {
|
|
152
|
+
readonly fromSurfaceId: string;
|
|
153
|
+
readonly fromSurfaceName: string;
|
|
154
|
+
readonly transitions: readonly TransitionEntry[];
|
|
155
|
+
};
|
|
156
|
+
|
|
157
|
+
export const groupTransitionCatalog = (
|
|
158
|
+
entries: readonly TransitionEntry[]
|
|
159
|
+
): readonly TransitionGroup[] => {
|
|
160
|
+
const map = new Map<string, TransitionGroup>();
|
|
161
|
+
for (const entry of entries) {
|
|
162
|
+
let group = map.get(entry.fromSurfaceId);
|
|
163
|
+
if (!group) {
|
|
164
|
+
group = {
|
|
165
|
+
fromSurfaceId: entry.fromSurfaceId,
|
|
166
|
+
fromSurfaceName: entry.fromSurfaceName,
|
|
167
|
+
transitions: []
|
|
168
|
+
};
|
|
169
|
+
map.set(entry.fromSurfaceId, group);
|
|
170
|
+
}
|
|
171
|
+
(group.transitions as TransitionEntry[]).push(entry);
|
|
172
|
+
}
|
|
173
|
+
return Array.from(map.values());
|
|
174
|
+
};
|
|
@@ -10,7 +10,11 @@ export type EffectType =
|
|
|
10
10
|
| 'emit_event'
|
|
11
11
|
| 'block_action'
|
|
12
12
|
| 'allow_action'
|
|
13
|
-
| 'transition_surface'
|
|
13
|
+
| 'transition_surface'
|
|
14
|
+
| 'append_to_list'
|
|
15
|
+
| 'remove_from_list'
|
|
16
|
+
| 'update_list_item'
|
|
17
|
+
| 'advance_time';
|
|
14
18
|
|
|
15
19
|
/**
|
|
16
20
|
* Writes `value` (or the result of `value` if it is an `Expression`) to the
|
|
@@ -61,13 +65,94 @@ export type TransitionSurfaceEffect = {
|
|
|
61
65
|
readonly description?: string;
|
|
62
66
|
};
|
|
63
67
|
|
|
68
|
+
/**
|
|
69
|
+
* Predicate that selects elements inside an array-typed state path. Matches
|
|
70
|
+
* an object element when `element[field]` deep-equals the resolved `equals`
|
|
71
|
+
* value (an Expression so the comparand can be a param, another state path,
|
|
72
|
+
* or a literal). Used by `remove_from_list` and `update_list_item` so a modeler
|
|
73
|
+
* can say "the cart line whose productId equals the `productId` parameter"
|
|
74
|
+
* without numeric indices (which state paths can't express).
|
|
75
|
+
*/
|
|
76
|
+
export type ListItemMatch = {
|
|
77
|
+
readonly field: string;
|
|
78
|
+
readonly equals: StateValue | Expression;
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Appends `item` to the array at `path`. When the path holds no array yet
|
|
83
|
+
* (undefined / wrong type) the engine treats it as an empty list and writes
|
|
84
|
+
* `[item]`, so "add the first item to an empty cart" needs no separate seed.
|
|
85
|
+
* `item` may be an Expression (e.g. a `param` carrying the object to push, or
|
|
86
|
+
* an arithmetic result for an array of numbers). The grow half of collection
|
|
87
|
+
* support that `set_state` (whole-value overwrite) could never express.
|
|
88
|
+
*/
|
|
89
|
+
export type AppendToListEffect = {
|
|
90
|
+
readonly id: EffectId;
|
|
91
|
+
readonly type: 'append_to_list';
|
|
92
|
+
readonly path: StatePath;
|
|
93
|
+
readonly item: StateValue | Expression;
|
|
94
|
+
readonly description?: string;
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* Removes elements from the array at `path`. Selector is exactly one of:
|
|
99
|
+
* - `where`: drop object elements matching the field predicate.
|
|
100
|
+
* - `value`: drop elements deep-equal to the resolved value (arrays of
|
|
101
|
+
* scalars, or whole-object equality).
|
|
102
|
+
* With neither selector the effect is a no-op — we never implicitly clear a
|
|
103
|
+
* whole list (use `set_state` with `[]` for that, explicitly).
|
|
104
|
+
*/
|
|
105
|
+
export type RemoveFromListEffect = {
|
|
106
|
+
readonly id: EffectId;
|
|
107
|
+
readonly type: 'remove_from_list';
|
|
108
|
+
readonly path: StatePath;
|
|
109
|
+
readonly where?: ListItemMatch;
|
|
110
|
+
readonly value?: StateValue | Expression;
|
|
111
|
+
readonly description?: string;
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* Sets `field` to the resolved `value` on every object element of the array
|
|
116
|
+
* at `path` that matches the `where` predicate. The in-place mutation half of
|
|
117
|
+
* collection support: "set qty to the `qty` param on the cart line whose
|
|
118
|
+
* productId matches" without rebuilding the whole array. Set multiple fields
|
|
119
|
+
* with multiple effects.
|
|
120
|
+
*/
|
|
121
|
+
export type UpdateListItemEffect = {
|
|
122
|
+
readonly id: EffectId;
|
|
123
|
+
readonly type: 'update_list_item';
|
|
124
|
+
readonly path: StatePath;
|
|
125
|
+
readonly where: ListItemMatch;
|
|
126
|
+
readonly field: string;
|
|
127
|
+
readonly value: StateValue | Expression;
|
|
128
|
+
readonly description?: string;
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
/**
|
|
132
|
+
* Advances the simulation clock (`clock.now`) forward by `by` logical time
|
|
133
|
+
* units. Time never runs backward — a non-positive delta is a no-op. Lets an
|
|
134
|
+
* action model "extend the session by 30", or a Tick action push time so a
|
|
135
|
+
* deadline rule ("now >= token.expiresAt → expire") becomes reachable. `by`
|
|
136
|
+
* may be an Expression (e.g. a `param` carrying the duration).
|
|
137
|
+
*/
|
|
138
|
+
export type AdvanceTimeEffect = {
|
|
139
|
+
readonly id: EffectId;
|
|
140
|
+
readonly type: 'advance_time';
|
|
141
|
+
readonly by: StateValue | Expression;
|
|
142
|
+
readonly description?: string;
|
|
143
|
+
};
|
|
144
|
+
|
|
64
145
|
export type Effect =
|
|
65
146
|
| SetStateEffect
|
|
66
147
|
| ShowMessageEffect
|
|
67
148
|
| EmitEventEffect
|
|
68
149
|
| BlockActionEffect
|
|
69
150
|
| AllowActionEffect
|
|
70
|
-
| TransitionSurfaceEffect
|
|
151
|
+
| TransitionSurfaceEffect
|
|
152
|
+
| AppendToListEffect
|
|
153
|
+
| RemoveFromListEffect
|
|
154
|
+
| UpdateListItemEffect
|
|
155
|
+
| AdvanceTimeEffect;
|
|
71
156
|
|
|
72
157
|
export const ALL_EFFECT_TYPES: readonly EffectType[] = [
|
|
73
158
|
'set_state',
|
|
@@ -75,7 +160,11 @@ export const ALL_EFFECT_TYPES: readonly EffectType[] = [
|
|
|
75
160
|
'emit_event',
|
|
76
161
|
'block_action',
|
|
77
162
|
'allow_action',
|
|
78
|
-
'transition_surface'
|
|
163
|
+
'transition_surface',
|
|
164
|
+
'append_to_list',
|
|
165
|
+
'remove_from_list',
|
|
166
|
+
'update_list_item',
|
|
167
|
+
'advance_time'
|
|
79
168
|
];
|
|
80
169
|
|
|
81
170
|
export const effectTypeLabel = (t: EffectType): string => {
|
|
@@ -92,6 +181,14 @@ export const effectTypeLabel = (t: EffectType): string => {
|
|
|
92
181
|
return 'Allow action';
|
|
93
182
|
case 'transition_surface':
|
|
94
183
|
return 'Transition to surface';
|
|
184
|
+
case 'append_to_list':
|
|
185
|
+
return 'Append to list';
|
|
186
|
+
case 'remove_from_list':
|
|
187
|
+
return 'Remove from list';
|
|
188
|
+
case 'update_list_item':
|
|
189
|
+
return 'Update list item';
|
|
190
|
+
case 'advance_time':
|
|
191
|
+
return 'Advance time';
|
|
95
192
|
}
|
|
96
193
|
};
|
|
97
194
|
|
|
@@ -1,57 +1,57 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Field types for Entity entities. Broader than `StateType` because Entity is
|
|
3
|
-
* documentation of arbitrary JSON-shaped data. Including dates, timestamps,
|
|
4
|
-
* raw JSON blobs, and the null literal.
|
|
5
|
-
*/
|
|
6
|
-
export type EntityFieldType =
|
|
7
|
-
| 'string'
|
|
8
|
-
| 'number'
|
|
9
|
-
| 'boolean'
|
|
10
|
-
| 'enum'
|
|
11
|
-
| 'object'
|
|
12
|
-
| 'array'
|
|
13
|
-
| 'date'
|
|
14
|
-
| 'timestamp'
|
|
15
|
-
| 'null'
|
|
16
|
-
| 'json';
|
|
17
|
-
|
|
18
|
-
export const ALL_DATA_FIELD_TYPES: readonly EntityFieldType[] = [
|
|
19
|
-
'string',
|
|
20
|
-
'number',
|
|
21
|
-
'boolean',
|
|
22
|
-
'enum',
|
|
23
|
-
'object',
|
|
24
|
-
'array',
|
|
25
|
-
'date',
|
|
26
|
-
'timestamp',
|
|
27
|
-
'null',
|
|
28
|
-
'json'
|
|
29
|
-
];
|
|
30
|
-
|
|
31
|
-
export const dataFieldTypeLabel = (t: EntityFieldType): string => {
|
|
32
|
-
switch (t) {
|
|
33
|
-
case 'string':
|
|
34
|
-
return 'string';
|
|
35
|
-
case 'number':
|
|
36
|
-
return 'number';
|
|
37
|
-
case 'boolean':
|
|
38
|
-
return 'boolean';
|
|
39
|
-
case 'enum':
|
|
40
|
-
return 'enum';
|
|
41
|
-
case 'object':
|
|
42
|
-
return 'object';
|
|
43
|
-
case 'array':
|
|
44
|
-
return 'array';
|
|
45
|
-
case 'date':
|
|
46
|
-
return 'date';
|
|
47
|
-
case 'timestamp':
|
|
48
|
-
return 'timestamp';
|
|
49
|
-
case 'null':
|
|
50
|
-
return 'null';
|
|
51
|
-
case 'json':
|
|
52
|
-
return 'json';
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
export const dataFieldTypeIsContainer = (t: EntityFieldType): boolean =>
|
|
57
|
-
t === 'object' || t === 'array';
|
|
1
|
+
/**
|
|
2
|
+
* Field types for Entity entities. Broader than `StateType` because Entity is
|
|
3
|
+
* documentation of arbitrary JSON-shaped data. Including dates, timestamps,
|
|
4
|
+
* raw JSON blobs, and the null literal.
|
|
5
|
+
*/
|
|
6
|
+
export type EntityFieldType =
|
|
7
|
+
| 'string'
|
|
8
|
+
| 'number'
|
|
9
|
+
| 'boolean'
|
|
10
|
+
| 'enum'
|
|
11
|
+
| 'object'
|
|
12
|
+
| 'array'
|
|
13
|
+
| 'date'
|
|
14
|
+
| 'timestamp'
|
|
15
|
+
| 'null'
|
|
16
|
+
| 'json';
|
|
17
|
+
|
|
18
|
+
export const ALL_DATA_FIELD_TYPES: readonly EntityFieldType[] = [
|
|
19
|
+
'string',
|
|
20
|
+
'number',
|
|
21
|
+
'boolean',
|
|
22
|
+
'enum',
|
|
23
|
+
'object',
|
|
24
|
+
'array',
|
|
25
|
+
'date',
|
|
26
|
+
'timestamp',
|
|
27
|
+
'null',
|
|
28
|
+
'json'
|
|
29
|
+
];
|
|
30
|
+
|
|
31
|
+
export const dataFieldTypeLabel = (t: EntityFieldType): string => {
|
|
32
|
+
switch (t) {
|
|
33
|
+
case 'string':
|
|
34
|
+
return 'string';
|
|
35
|
+
case 'number':
|
|
36
|
+
return 'number';
|
|
37
|
+
case 'boolean':
|
|
38
|
+
return 'boolean';
|
|
39
|
+
case 'enum':
|
|
40
|
+
return 'enum';
|
|
41
|
+
case 'object':
|
|
42
|
+
return 'object';
|
|
43
|
+
case 'array':
|
|
44
|
+
return 'array';
|
|
45
|
+
case 'date':
|
|
46
|
+
return 'date';
|
|
47
|
+
case 'timestamp':
|
|
48
|
+
return 'timestamp';
|
|
49
|
+
case 'null':
|
|
50
|
+
return 'null';
|
|
51
|
+
case 'json':
|
|
52
|
+
return 'json';
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
export const dataFieldTypeIsContainer = (t: EntityFieldType): boolean =>
|
|
57
|
+
t === 'object' || t === 'array';
|
|
@@ -4,6 +4,7 @@ import type { StateValue } from './StateValue';
|
|
|
4
4
|
import {
|
|
5
5
|
isCompositeCondition,
|
|
6
6
|
isParamLeft,
|
|
7
|
+
isQuantifierCondition,
|
|
7
8
|
type RuleCondition
|
|
8
9
|
} from './RuleCondition';
|
|
9
10
|
import type { Operator } from './Operator';
|
|
@@ -167,6 +168,24 @@ export const evaluateConditionInternal = (
|
|
|
167
168
|
context: EvaluationContext
|
|
168
169
|
): boolean => {
|
|
169
170
|
if (condition === undefined || condition === null) return true;
|
|
171
|
+
if (isQuantifierCondition(condition)) {
|
|
172
|
+
const arr = readPath(context.snapshot, condition.overPath);
|
|
173
|
+
// Missing / non-array source: ∀ is vacuously true, ∃ is false.
|
|
174
|
+
if (!Array.isArray(arr)) return condition.kind === 'all_match';
|
|
175
|
+
for (const element of arr) {
|
|
176
|
+
// Bind the current element under `as` so the body reads `as` (scalars)
|
|
177
|
+
// or `as.field` (objects) while still seeing every outer state path.
|
|
178
|
+
const scoped: StateSnapshot = { ...context.snapshot, [condition.as]: element };
|
|
179
|
+
const held = evaluateConditionInternal(condition.where, {
|
|
180
|
+
...context,
|
|
181
|
+
snapshot: scoped
|
|
182
|
+
});
|
|
183
|
+
if (condition.kind === 'all_match' && !held) return false;
|
|
184
|
+
if (condition.kind === 'any_match' && held) return true;
|
|
185
|
+
}
|
|
186
|
+
// Walked every element: all held ⇒ all_match true; none held ⇒ any_match false.
|
|
187
|
+
return condition.kind === 'all_match';
|
|
188
|
+
}
|
|
170
189
|
if (isCompositeCondition(condition)) {
|
|
171
190
|
if (condition.kind === 'not') {
|
|
172
191
|
return !evaluateConditionInternal(condition.condition, context);
|
|
@@ -192,8 +211,9 @@ export const evaluateConditionInternal = (
|
|
|
192
211
|
|
|
193
212
|
// Structural equality for two StateValue-shaped values. Inlined here (not
|
|
194
213
|
// imported from RuleEvaluator) so this module stays an evaluator with no
|
|
195
|
-
// upward dependency.
|
|
196
|
-
|
|
214
|
+
// upward dependency. Exported so collection-mutation effects (remove/update by
|
|
215
|
+
// match) compare element fields with the exact same semantics conditions use.
|
|
216
|
+
export const deepEqualValue = (a: unknown, b: unknown): boolean => {
|
|
197
217
|
if (a === b) return true;
|
|
198
218
|
if (a === null || b === null) return false;
|
|
199
219
|
if (typeof a !== typeof b) return false;
|