@adaas/a-frame 0.1.1 → 0.1.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/.conf/tsconfig.browser.json +7 -1
- package/.conf/tsconfig.node.json +7 -1
- package/dist/browser/A-FrameBrowserStorageBlobs.context-CZTTvpn2.d.mts +53 -0
- package/dist/browser/A-FrameBrowserStorageBlobs.context-CaGTyatz.d.mts +40 -0
- package/dist/browser/A-FrameBrowserStorageBlobs.context-DjeEH8cn.d.mts +53 -0
- package/dist/browser/A-FrameBrowserStorageBlobs.context-vCsuTea9.d.mts +40 -0
- package/dist/browser/A-FrameBundle.types-LzfgdMiQ.d.mts +71 -0
- package/dist/browser/A-FrameChannel.component-4mTNctXL.d.mts +704 -0
- package/dist/browser/A-FrameChannel.types-BXEKJK9t.d.mts +205 -0
- package/dist/browser/A-FrameChannel.types-Ba3wgUZj.d.mts +199 -0
- package/dist/browser/A-FrameChannel.types-BfINhQZe.d.mts +145 -0
- package/dist/browser/A-FrameChannel.types-DfacgYL1.d.mts +199 -0
- package/dist/browser/A-FrameCompletion.entity-Dzy9sIa8.d.mts +72 -0
- package/dist/browser/A-FrameDefinition.entity-C1aK-gdl.d.mts +370 -0
- package/dist/browser/A-FrameDefinition.entity-CKPXsarS.d.mts +358 -0
- package/dist/browser/A-FrameDefinition.entity-yA0GsBoe.d.mts +143 -0
- package/dist/browser/A-FrameDefinition.types-BT02yAhQ.d.mts +232 -0
- package/dist/browser/A-FrameDynamicContentOperation.context-CoViNb19.d.mts +297 -0
- package/dist/browser/A-FrameDynamicContentOperation.context-Dd7Lb7X2.d.mts +266 -0
- package/dist/browser/A-FrameDynamicPatch.entity-BRuF1tqs.d.mts +29 -0
- package/dist/browser/A-FrameDynamicStructure.entity-DMvI_EPT.d.mts +210 -0
- package/dist/browser/A-FrameDynamicStructure.entity-DxkPP9mR.d.mts +235 -0
- package/dist/browser/A-FrameEnv.types-DnK-CYVk.d.mts +21 -0
- package/dist/browser/A-FrameNamespace.entity-BDg1FUgo.d.mts +136 -0
- package/dist/browser/A-FrameSchema.entity-DjYIhsoj.d.mts +141 -0
- package/dist/browser/A-FrameSegment.entity-D1xjjWvG.d.mts +161 -0
- package/dist/browser/A-FrameSegment.entity-D7Aj39Wh.d.mts +146 -0
- package/dist/browser/bundle.d.mts +6 -2
- package/dist/browser/bundle.mjs +1 -1
- package/dist/browser/bundle.mjs.map +1 -1
- package/dist/browser/channel.d.mts +51 -74
- package/dist/browser/channel.mjs +1 -2
- package/dist/browser/channel.mjs.map +1 -1
- package/dist/browser/chunk-2RNFZSBL.mjs +2 -0
- package/dist/browser/chunk-2RNFZSBL.mjs.map +1 -0
- package/dist/browser/chunk-46LRNZRG.mjs +2 -0
- package/dist/browser/chunk-46LRNZRG.mjs.map +1 -0
- package/dist/browser/chunk-52HFO3OY.mjs +2 -0
- package/dist/browser/chunk-52HFO3OY.mjs.map +1 -0
- package/dist/browser/chunk-643KGQKR.mjs +3 -0
- package/dist/browser/chunk-643KGQKR.mjs.map +1 -0
- package/dist/browser/chunk-66BBIZAM.mjs +3 -0
- package/dist/browser/chunk-66BBIZAM.mjs.map +1 -0
- package/dist/browser/chunk-6NPQURSO.mjs +2 -0
- package/dist/browser/chunk-6NPQURSO.mjs.map +1 -0
- package/dist/browser/chunk-6WAOMX7M.mjs +2 -0
- package/dist/browser/chunk-6WAOMX7M.mjs.map +1 -0
- package/dist/browser/chunk-77HU5SRQ.mjs +2 -0
- package/dist/browser/chunk-77HU5SRQ.mjs.map +1 -0
- package/dist/browser/chunk-AET6XULU.mjs +2 -0
- package/dist/browser/chunk-AET6XULU.mjs.map +1 -0
- package/dist/browser/chunk-BIBPE2GT.mjs +3 -0
- package/dist/browser/chunk-BIBPE2GT.mjs.map +1 -0
- package/dist/browser/chunk-CDJKU4DK.mjs +2 -0
- package/dist/browser/chunk-CDJKU4DK.mjs.map +1 -0
- package/dist/browser/chunk-CT67Y46H.mjs +3 -0
- package/dist/browser/chunk-CT67Y46H.mjs.map +1 -0
- package/dist/browser/chunk-EFC7OUNO.mjs +2 -0
- package/dist/browser/chunk-EFC7OUNO.mjs.map +1 -0
- package/dist/browser/chunk-EJIX7H7A.mjs +2 -0
- package/dist/browser/chunk-EJIX7H7A.mjs.map +1 -0
- package/dist/browser/chunk-FHJ5ATND.mjs +3 -0
- package/dist/browser/chunk-FHJ5ATND.mjs.map +1 -0
- package/dist/browser/chunk-FVH2EEVP.mjs +3 -0
- package/dist/browser/chunk-FVH2EEVP.mjs.map +1 -0
- package/dist/browser/chunk-G6ULYKSU.mjs +2 -0
- package/dist/browser/chunk-G6ULYKSU.mjs.map +1 -0
- package/dist/browser/chunk-G7MKGKG5.mjs +2 -0
- package/dist/browser/chunk-G7MKGKG5.mjs.map +1 -0
- package/dist/browser/chunk-GOMJPGVB.mjs +3 -0
- package/dist/browser/chunk-GOMJPGVB.mjs.map +1 -0
- package/dist/browser/chunk-INQV5UZA.mjs +2 -0
- package/dist/browser/chunk-INQV5UZA.mjs.map +1 -0
- package/dist/browser/chunk-INXPVBTZ.mjs +2 -0
- package/dist/browser/chunk-INXPVBTZ.mjs.map +1 -0
- package/dist/browser/chunk-KFMVTZ7T.mjs +2 -0
- package/dist/browser/chunk-KFMVTZ7T.mjs.map +1 -0
- package/dist/browser/chunk-LK6C7C3S.mjs +2 -0
- package/dist/browser/chunk-LK6C7C3S.mjs.map +1 -0
- package/dist/browser/chunk-LOGRQOWP.mjs +3 -0
- package/dist/browser/chunk-LOGRQOWP.mjs.map +1 -0
- package/dist/browser/chunk-LZACYSUC.mjs +3 -0
- package/dist/browser/chunk-LZACYSUC.mjs.map +1 -0
- package/dist/browser/chunk-NTOIVRX3.mjs +2 -0
- package/dist/browser/chunk-NTOIVRX3.mjs.map +1 -0
- package/dist/browser/chunk-OES2N3X7.mjs +3 -0
- package/dist/browser/chunk-OES2N3X7.mjs.map +1 -0
- package/dist/browser/chunk-OFKV5GNB.mjs +1 -1
- package/dist/browser/chunk-OFKV5GNB.mjs.map +1 -1
- package/dist/browser/chunk-OVLM5A32.mjs +3 -0
- package/dist/browser/chunk-OVLM5A32.mjs.map +1 -0
- package/dist/browser/chunk-QATIN7CO.mjs +1 -1
- package/dist/browser/chunk-QATIN7CO.mjs.map +1 -1
- package/dist/browser/chunk-QOL7CAUZ.mjs +2 -0
- package/dist/browser/chunk-QOL7CAUZ.mjs.map +1 -0
- package/dist/browser/chunk-RCB3PX4V.mjs +2 -0
- package/dist/browser/chunk-RCB3PX4V.mjs.map +1 -0
- package/dist/browser/chunk-RWQSCROK.mjs +3 -0
- package/dist/browser/chunk-RWQSCROK.mjs.map +1 -0
- package/dist/browser/chunk-TIAUMK2X.mjs +2 -0
- package/dist/browser/chunk-TIAUMK2X.mjs.map +1 -0
- package/dist/browser/chunk-TQPC5MYM.mjs +3 -0
- package/dist/browser/chunk-TQPC5MYM.mjs.map +1 -0
- package/dist/browser/chunk-UNIKTCXL.mjs +3 -0
- package/dist/browser/chunk-UNIKTCXL.mjs.map +1 -0
- package/dist/browser/chunk-UULJJ5C5.mjs +3 -0
- package/dist/browser/chunk-UULJJ5C5.mjs.map +1 -0
- package/dist/browser/chunk-VSSANMPF.mjs +2 -0
- package/dist/browser/chunk-VSSANMPF.mjs.map +1 -0
- package/dist/browser/chunk-VW2BZYNY.mjs +2 -0
- package/dist/browser/chunk-VW2BZYNY.mjs.map +1 -0
- package/dist/browser/chunk-WAXBOWM6.mjs +3 -0
- package/dist/browser/chunk-WAXBOWM6.mjs.map +1 -0
- package/dist/browser/chunk-WXCQCHAX.mjs +2 -0
- package/dist/browser/chunk-WXCQCHAX.mjs.map +1 -0
- package/dist/browser/chunk-XKKBIIZG.mjs +3 -0
- package/dist/browser/chunk-XKKBIIZG.mjs.map +1 -0
- package/dist/browser/chunk-XR7FVA5M.mjs +3 -0
- package/dist/browser/chunk-XR7FVA5M.mjs.map +1 -0
- package/dist/browser/chunk-YQJFTBGV.mjs +1 -1
- package/dist/browser/chunk-YQJFTBGV.mjs.map +1 -1
- package/dist/browser/chunk-YTAMZDWC.mjs +3 -0
- package/dist/browser/chunk-YTAMZDWC.mjs.map +1 -0
- package/dist/browser/chunk-ZEONOTRL.mjs +2 -0
- package/dist/browser/chunk-ZEONOTRL.mjs.map +1 -0
- package/dist/browser/completion.d.mts +10 -0
- package/dist/browser/completion.mjs +2 -0
- package/dist/browser/completion.mjs.map +1 -0
- package/dist/browser/core.d.mts +7 -6
- package/dist/browser/core.mjs +1 -1
- package/dist/browser/core.mjs.map +1 -1
- package/dist/browser/credentials.d.mts +74 -0
- package/dist/browser/credentials.mjs +2 -0
- package/dist/browser/credentials.mjs.map +1 -0
- package/dist/browser/definition.d.mts +3 -2
- package/dist/browser/definition.mjs +1 -1
- package/dist/browser/dynamic-content.d.mts +13 -0
- package/dist/browser/dynamic-content.mjs +2 -0
- package/dist/browser/dynamic-content.mjs.map +1 -0
- package/dist/browser/dynamic-feature.d.mts +66 -6
- package/dist/browser/dynamic-feature.mjs +3 -1
- package/dist/browser/dynamic-feature.mjs.map +1 -1
- package/dist/browser/dynamic-structure.d.mts +77 -3
- package/dist/browser/dynamic-structure.mjs +1 -1
- package/dist/browser/dynamic-structure.mjs.map +1 -1
- package/dist/browser/env.d.mts +16 -2
- package/dist/browser/env.mjs +1 -1
- package/dist/browser/frame-index.d.mts +70 -9
- package/dist/browser/frame-index.mjs +1 -1
- package/dist/browser/models.d.mts +64 -0
- package/dist/browser/models.mjs +2 -0
- package/dist/browser/models.mjs.map +1 -0
- package/dist/browser/namespace.d.mts +1 -1
- package/dist/browser/namespace.mjs +1 -1
- package/dist/browser/schema.d.mts +10 -0
- package/dist/browser/schema.mjs +2 -0
- package/dist/browser/schema.mjs.map +1 -0
- package/dist/browser/segment.d.mts +13 -0
- package/dist/browser/segment.mjs +2 -0
- package/dist/browser/segment.mjs.map +1 -0
- package/dist/browser/storage.d.mts +13 -7
- package/dist/browser/storage.mjs +1 -1
- package/dist/browser/vector.d.mts +7 -0
- package/dist/browser/vector.mjs +1 -1
- package/dist/cli.cjs +5593 -0
- package/dist/cli.cjs.map +1 -0
- package/dist/node/A-FrameChannel.component--YErPxf4.d.mts +97 -0
- package/dist/node/A-FrameChannel.component-BjgqMh1B.d.ts +97 -0
- package/dist/node/A-FrameChannel.component-C0O3TaRD.d.ts +679 -0
- package/dist/node/A-FrameChannel.component-CgBZYBz0.d.mts +379 -0
- package/dist/node/A-FrameChannel.component-CkZserv3.d.ts +97 -0
- package/dist/node/A-FrameChannel.component-DMA-3sUB.d.mts +679 -0
- package/dist/node/A-FrameChannel.component-DYV8omYR.d.ts +379 -0
- package/dist/node/A-FrameChannel.component-DwgYNfFn.d.mts +97 -0
- package/dist/node/A-FrameChannel.types-B3_xWKEO.d.mts +151 -0
- package/dist/node/A-FrameChannel.types-BGcVXTqa.d.ts +205 -0
- package/dist/node/A-FrameChannel.types-Boi8QqDK.d.mts +205 -0
- package/dist/node/A-FrameChannel.types-BsE6bNky.d.mts +205 -0
- package/dist/node/A-FrameChannel.types-C-gxXl8m.d.ts +151 -0
- package/dist/node/A-FrameChannel.types-DD2B11rf.d.ts +205 -0
- package/dist/node/A-FrameChannel.types-DYMgRiCF.d.mts +205 -0
- package/dist/node/A-FrameChannel.types-DwyZRsOy.d.ts +205 -0
- package/dist/node/A-FrameCompletion.entity-Brx11JMp.d.ts +72 -0
- package/dist/node/A-FrameCompletion.entity-Dzy9sIa8.d.mts +72 -0
- package/dist/node/A-FrameDefinition.entity-BIF0sclD.d.ts +370 -0
- package/dist/node/A-FrameDefinition.entity-Bt9ua6cn.d.ts +358 -0
- package/dist/node/A-FrameDefinition.entity-C0kzaGJ0.d.ts +143 -0
- package/dist/node/A-FrameDefinition.entity-C1aK-gdl.d.mts +370 -0
- package/dist/node/A-FrameDefinition.entity-CKPXsarS.d.mts +358 -0
- package/dist/node/A-FrameDefinition.entity-yA0GsBoe.d.mts +143 -0
- package/dist/node/A-FrameDefinition.types-BA_pLGpo.d.ts +232 -0
- package/dist/node/A-FrameDefinition.types-BT02yAhQ.d.mts +232 -0
- package/dist/node/A-FrameDynamicContentOperation.context-C_aH1gEn.d.ts +297 -0
- package/dist/node/A-FrameDynamicContentOperation.context-CoViNb19.d.mts +297 -0
- package/dist/node/A-FrameDynamicContentOperation.context-DRqH2c3o.d.ts +266 -0
- package/dist/node/A-FrameDynamicContentOperation.context-Dd7Lb7X2.d.mts +266 -0
- package/dist/node/A-FrameDynamicPatch.entity-BRuF1tqs.d.mts +29 -0
- package/dist/node/A-FrameDynamicPatch.entity-BRuF1tqs.d.ts +29 -0
- package/dist/node/A-FrameDynamicStructure.entity-BVCbolMd.d.ts +210 -0
- package/dist/node/A-FrameDynamicStructure.entity-DMvI_EPT.d.mts +210 -0
- package/dist/node/A-FrameDynamicStructure.entity-DxkPP9mR.d.mts +235 -0
- package/dist/node/A-FrameDynamicStructure.entity-DxkPP9mR.d.ts +235 -0
- package/dist/node/A-FrameLogger.component.env-node-DIDBeuiz.d.mts +114 -0
- package/dist/node/A-FrameLogger.component.env-node-DIDBeuiz.d.ts +114 -0
- package/dist/node/A-FrameNamespace.entity-BDg1FUgo.d.mts +136 -0
- package/dist/node/A-FrameNamespace.entity-HDXcLGcS.d.ts +136 -0
- package/dist/node/A-FrameSchema.entity-DjYIhsoj.d.mts +141 -0
- package/dist/node/A-FrameSchema.entity-DjYIhsoj.d.ts +141 -0
- package/dist/node/A-FrameSegment.entity-C0izuOmC.d.ts +161 -0
- package/dist/node/A-FrameSegment.entity-CMCgFCWU.d.ts +146 -0
- package/dist/node/A-FrameSegment.entity-D1xjjWvG.d.mts +161 -0
- package/dist/node/A-FrameSegment.entity-D7Aj39Wh.d.mts +146 -0
- package/dist/node/A-FrameStorage.component-BnNKzvpY.d.mts +107 -0
- package/dist/node/A-FrameStorage.component-CDztogHV.d.mts +107 -0
- package/dist/node/A-FrameStorage.component-CW0YgKDI.d.mts +107 -0
- package/dist/node/A-FrameStorage.component-D4UEkIBx.d.mts +107 -0
- package/dist/node/A-FrameStorage.component-DV_jwK6r.d.ts +107 -0
- package/dist/node/A-FrameStorage.component-Di4EvbtC.d.ts +107 -0
- package/dist/node/A-FrameStorage.component-emIH1a1M.d.ts +107 -0
- package/dist/node/A-FrameStorage.component-y-JPiIQ4.d.ts +107 -0
- package/dist/node/bundle.cjs +66 -21
- package/dist/node/bundle.cjs.map +1 -1
- package/dist/node/bundle.d.mts +88 -24
- package/dist/node/bundle.d.ts +88 -24
- package/dist/node/bundle.mjs +65 -20
- package/dist/node/bundle.mjs.map +1 -1
- package/dist/node/channel.cjs +33 -26
- package/dist/node/channel.d.mts +10 -6
- package/dist/node/channel.d.ts +10 -6
- package/dist/node/channel.mjs +13 -6
- package/dist/node/chunk-2HUSP34L.mjs +55 -0
- package/dist/node/chunk-2HUSP34L.mjs.map +1 -0
- package/dist/node/chunk-2KXGI2E5.cjs +474 -0
- package/dist/node/chunk-2KXGI2E5.cjs.map +1 -0
- package/dist/node/chunk-2OQMOIR5.mjs +170 -0
- package/dist/node/chunk-2OQMOIR5.mjs.map +1 -0
- package/dist/node/chunk-2UI7RJ4Q.mjs +207 -0
- package/dist/node/chunk-2UI7RJ4Q.mjs.map +1 -0
- package/dist/node/chunk-3SLICJ3L.cjs +265 -0
- package/dist/node/chunk-3SLICJ3L.cjs.map +1 -0
- package/dist/node/chunk-3ZDHQOIU.cjs +92 -0
- package/dist/node/chunk-3ZDHQOIU.cjs.map +1 -0
- package/dist/node/chunk-5BKCX2RO.mjs +1 -1
- package/dist/node/chunk-5BKCX2RO.mjs.map +1 -1
- package/dist/node/chunk-5NCGXLP2.mjs +6 -0
- package/dist/node/chunk-5NCGXLP2.mjs.map +1 -0
- package/dist/node/chunk-5OTXZ7BB.mjs +53 -0
- package/dist/node/chunk-5OTXZ7BB.mjs.map +1 -0
- package/dist/node/chunk-5PYIATGT.mjs +469 -0
- package/dist/node/chunk-5PYIATGT.mjs.map +1 -0
- package/dist/node/chunk-64QCZG53.cjs +57 -0
- package/dist/node/chunk-64QCZG53.cjs.map +1 -0
- package/dist/node/chunk-652OEICJ.cjs +4 -0
- package/dist/node/chunk-652OEICJ.cjs.map +1 -0
- package/dist/node/chunk-674ZX6XJ.mjs +187 -0
- package/dist/node/chunk-674ZX6XJ.mjs.map +1 -0
- package/dist/node/chunk-6ID2IXYX.mjs +6 -0
- package/dist/node/chunk-6ID2IXYX.mjs.map +1 -0
- package/dist/node/chunk-7EM3Q7HA.mjs +655 -0
- package/dist/node/chunk-7EM3Q7HA.mjs.map +1 -0
- package/dist/node/chunk-7MVVMISA.cjs +293 -0
- package/dist/node/chunk-7MVVMISA.cjs.map +1 -0
- package/dist/node/chunk-7NSLGCAZ.mjs +1395 -0
- package/dist/node/chunk-7NSLGCAZ.mjs.map +1 -0
- package/dist/node/chunk-7OLLATCC.mjs +1289 -0
- package/dist/node/chunk-7OLLATCC.mjs.map +1 -0
- package/dist/node/chunk-7SEZMRLI.cjs +183 -0
- package/dist/node/chunk-7SEZMRLI.cjs.map +1 -0
- package/dist/node/chunk-A4CVDMSV.mjs +608 -0
- package/dist/node/chunk-A4CVDMSV.mjs.map +1 -0
- package/dist/node/chunk-A7CJIUYY.cjs +4 -0
- package/dist/node/chunk-A7CJIUYY.cjs.map +1 -0
- package/dist/node/chunk-ALFFUJ2J.mjs +163 -0
- package/dist/node/chunk-ALFFUJ2J.mjs.map +1 -0
- package/dist/node/chunk-AMMQ76RJ.mjs +179 -0
- package/dist/node/chunk-AMMQ76RJ.mjs.map +1 -0
- package/dist/node/chunk-AUKWKGVA.cjs +688 -0
- package/dist/node/chunk-AUKWKGVA.cjs.map +1 -0
- package/dist/node/chunk-AY6UMDWD.cjs +270 -0
- package/dist/node/chunk-AY6UMDWD.cjs.map +1 -0
- package/dist/node/chunk-B7ZDJXD3.cjs +1 -1
- package/dist/node/chunk-B7ZDJXD3.cjs.map +1 -1
- package/dist/node/chunk-BBYOL3LM.cjs +1308 -0
- package/dist/node/chunk-BBYOL3LM.cjs.map +1 -0
- package/dist/node/chunk-BINGAHFW.cjs +1308 -0
- package/dist/node/chunk-BINGAHFW.cjs.map +1 -0
- package/dist/node/chunk-BSBY37MG.cjs +55 -0
- package/dist/node/chunk-BSBY37MG.cjs.map +1 -0
- package/dist/node/chunk-BWX7HFTH.cjs +209 -0
- package/dist/node/chunk-BWX7HFTH.cjs.map +1 -0
- package/dist/node/chunk-C37B34MH.cjs +188 -0
- package/dist/node/chunk-C37B34MH.cjs.map +1 -0
- package/dist/node/chunk-C6BBKHQG.cjs +250 -0
- package/dist/node/chunk-C6BBKHQG.cjs.map +1 -0
- package/dist/node/chunk-CLCAS67N.cjs +8 -0
- package/dist/node/chunk-CLCAS67N.cjs.map +1 -0
- package/dist/node/chunk-CNU3CRTR.mjs +43 -0
- package/dist/node/chunk-CNU3CRTR.mjs.map +1 -0
- package/dist/node/chunk-CV5FPKU6.mjs +6 -0
- package/dist/node/chunk-CV5FPKU6.mjs.map +1 -0
- package/dist/node/chunk-CZYOAFIR.mjs +129 -0
- package/dist/node/chunk-CZYOAFIR.mjs.map +1 -0
- package/dist/node/chunk-D2HTYEJZ.cjs +209 -0
- package/dist/node/chunk-D2HTYEJZ.cjs.map +1 -0
- package/dist/node/chunk-EMLZZPOT.cjs +1446 -0
- package/dist/node/chunk-EMLZZPOT.cjs.map +1 -0
- package/dist/node/chunk-EOIXXXBV.cjs +55 -0
- package/dist/node/chunk-EOIXXXBV.cjs.map +1 -0
- package/dist/node/chunk-F4UCOZW5.mjs +1 -1
- package/dist/node/chunk-F4UCOZW5.mjs.map +1 -1
- package/dist/node/chunk-F64CK4NI.mjs +53 -0
- package/dist/node/chunk-F64CK4NI.mjs.map +1 -0
- package/dist/node/chunk-FAV62EUG.cjs +35 -0
- package/dist/node/chunk-FAV62EUG.cjs.map +1 -0
- package/dist/node/chunk-GHSPKZUN.mjs +529 -0
- package/dist/node/chunk-GHSPKZUN.mjs.map +1 -0
- package/dist/node/chunk-GRNVK7DW.mjs +97 -0
- package/dist/node/chunk-GRNVK7DW.mjs.map +1 -0
- package/dist/node/chunk-H5VGRPD5.cjs +8 -0
- package/dist/node/chunk-H5VGRPD5.cjs.map +1 -0
- package/dist/node/chunk-HAMDDCPS.cjs +8 -0
- package/dist/node/chunk-HAMDDCPS.cjs.map +1 -0
- package/dist/node/chunk-HAORARSB.cjs +75 -0
- package/dist/node/chunk-HAORARSB.cjs.map +1 -0
- package/dist/node/chunk-HELNAM5Y.cjs +8 -0
- package/dist/node/chunk-HELNAM5Y.cjs.map +1 -0
- package/dist/node/chunk-HET6L5PD.mjs +530 -0
- package/dist/node/chunk-HET6L5PD.mjs.map +1 -0
- package/dist/node/chunk-HI5SEX53.mjs +264 -0
- package/dist/node/chunk-HI5SEX53.mjs.map +1 -0
- package/dist/node/chunk-HZGFXE4Q.mjs +6 -0
- package/dist/node/chunk-HZGFXE4Q.mjs.map +1 -0
- package/dist/node/chunk-IAL2NK2V.mjs +73 -0
- package/dist/node/chunk-IAL2NK2V.mjs.map +1 -0
- package/dist/node/chunk-IHELFDCW.mjs +327 -0
- package/dist/node/chunk-IHELFDCW.mjs.map +1 -0
- package/dist/node/chunk-ILD6OSYW.mjs +966 -0
- package/dist/node/chunk-ILD6OSYW.mjs.map +1 -0
- package/dist/node/chunk-IP6DFAO7.mjs +264 -0
- package/dist/node/chunk-IP6DFAO7.mjs.map +1 -0
- package/dist/node/chunk-IYEDO7OQ.cjs +276 -0
- package/dist/node/chunk-IYEDO7OQ.cjs.map +1 -0
- package/dist/node/chunk-JFPGFPQD.mjs +1413 -0
- package/dist/node/chunk-JFPGFPQD.mjs.map +1 -0
- package/dist/node/chunk-JHZGTVYF.cjs +999 -0
- package/dist/node/chunk-JHZGTVYF.cjs.map +1 -0
- package/dist/node/chunk-JN3UJBUH.mjs +608 -0
- package/dist/node/chunk-JN3UJBUH.mjs.map +1 -0
- package/dist/node/chunk-JNPDXCCN.mjs +530 -0
- package/dist/node/chunk-JNPDXCCN.mjs.map +1 -0
- package/dist/node/chunk-JQBYDEMW.mjs +1 -1
- package/dist/node/chunk-JQBYDEMW.mjs.map +1 -1
- package/dist/node/chunk-JQJ7N4NL.cjs +267 -0
- package/dist/node/chunk-JQJ7N4NL.cjs.map +1 -0
- package/dist/node/chunk-K4AJBPPY.cjs +174 -0
- package/dist/node/chunk-K4AJBPPY.cjs.map +1 -0
- package/dist/node/chunk-K7SXPJPK.cjs +131 -0
- package/dist/node/chunk-K7SXPJPK.cjs.map +1 -0
- package/dist/node/chunk-KFW4GE7H.mjs +1289 -0
- package/dist/node/chunk-KFW4GE7H.mjs.map +1 -0
- package/dist/node/chunk-KKL2DF2D.cjs +518 -0
- package/dist/node/chunk-KKL2DF2D.cjs.map +1 -0
- package/dist/node/chunk-KKMKQGTR.cjs +620 -0
- package/dist/node/chunk-KKMKQGTR.cjs.map +1 -0
- package/dist/node/chunk-KNTO7FCZ.mjs +207 -0
- package/dist/node/chunk-KNTO7FCZ.mjs.map +1 -0
- package/dist/node/chunk-KTKVW3PH.mjs +286 -0
- package/dist/node/chunk-KTKVW3PH.mjs.map +1 -0
- package/dist/node/chunk-KZPSF32W.mjs +33 -0
- package/dist/node/chunk-KZPSF32W.mjs.map +1 -0
- package/dist/node/chunk-LWKFCMA7.mjs +129 -0
- package/dist/node/chunk-LWKFCMA7.mjs.map +1 -0
- package/dist/node/chunk-M2ZSE6YJ.mjs +512 -0
- package/dist/node/chunk-M2ZSE6YJ.mjs.map +1 -0
- package/dist/node/chunk-M6DJYGDO.cjs +167 -0
- package/dist/node/chunk-M6DJYGDO.cjs.map +1 -0
- package/dist/node/chunk-MAHKDTOQ.mjs +3 -0
- package/dist/node/chunk-MAHKDTOQ.mjs.map +1 -0
- package/dist/node/chunk-MM2R2OM6.cjs +541 -0
- package/dist/node/chunk-MM2R2OM6.cjs.map +1 -0
- package/dist/node/chunk-MSOD5UQH.cjs +45 -0
- package/dist/node/chunk-MSOD5UQH.cjs.map +1 -0
- package/dist/node/chunk-MVAWR76Q.cjs +276 -0
- package/dist/node/chunk-MVAWR76Q.cjs.map +1 -0
- package/dist/node/chunk-MXUO7OR5.cjs +97 -0
- package/dist/node/chunk-MXUO7OR5.cjs.map +1 -0
- package/dist/node/chunk-N4THTV6P.cjs +131 -0
- package/dist/node/chunk-N4THTV6P.cjs.map +1 -0
- package/dist/node/chunk-NIXKAQVP.cjs +1 -1
- package/dist/node/chunk-NIXKAQVP.cjs.map +1 -1
- package/dist/node/chunk-NUPXUUPM.cjs +1428 -0
- package/dist/node/chunk-NUPXUUPM.cjs.map +1 -0
- package/dist/node/chunk-NWOUVAIS.cjs +45 -0
- package/dist/node/chunk-NWOUVAIS.cjs.map +1 -0
- package/dist/node/chunk-OK7I5OQ3.mjs +89 -0
- package/dist/node/chunk-OK7I5OQ3.mjs.map +1 -0
- package/dist/node/chunk-OMGYXCFM.mjs +248 -0
- package/dist/node/chunk-OMGYXCFM.mjs.map +1 -0
- package/dist/node/chunk-OYZAQMKD.mjs +263 -0
- package/dist/node/chunk-OYZAQMKD.mjs.map +1 -0
- package/dist/node/chunk-P2LULMNL.cjs +189 -0
- package/dist/node/chunk-P2LULMNL.cjs.map +1 -0
- package/dist/node/chunk-PABEFHCO.mjs +63 -0
- package/dist/node/chunk-PABEFHCO.mjs.map +1 -0
- package/dist/node/chunk-Q5NYJQP2.cjs +8 -0
- package/dist/node/chunk-Q5NYJQP2.cjs.map +1 -0
- package/dist/node/chunk-QCEWWJ3N.cjs +65 -0
- package/dist/node/chunk-QCEWWJ3N.cjs.map +1 -0
- package/dist/node/chunk-QW4AZ3Z2.cjs +542 -0
- package/dist/node/chunk-QW4AZ3Z2.cjs.map +1 -0
- package/dist/node/chunk-RK5WSZ5J.mjs +43 -0
- package/dist/node/chunk-RK5WSZ5J.mjs.map +1 -0
- package/dist/node/chunk-RPHYBPXT.mjs +30 -0
- package/dist/node/chunk-RPHYBPXT.mjs.map +1 -0
- package/dist/node/chunk-RVXASBMQ.mjs +273 -0
- package/dist/node/chunk-RVXASBMQ.mjs.map +1 -0
- package/dist/node/chunk-RVZTZD32.mjs +187 -0
- package/dist/node/chunk-RVZTZD32.mjs.map +1 -0
- package/dist/node/chunk-RWLKISZQ.mjs +273 -0
- package/dist/node/chunk-RWLKISZQ.mjs.map +1 -0
- package/dist/node/chunk-SESXQJDD.cjs +999 -0
- package/dist/node/chunk-SESXQJDD.cjs.map +1 -0
- package/dist/node/chunk-SKIEPTFS.mjs +6 -0
- package/dist/node/chunk-SKIEPTFS.mjs.map +1 -0
- package/dist/node/chunk-SL7FT5R5.mjs +94 -0
- package/dist/node/chunk-SL7FT5R5.mjs.map +1 -0
- package/dist/node/chunk-SXHQW74T.mjs +43 -0
- package/dist/node/chunk-SXHQW74T.mjs.map +1 -0
- package/dist/node/chunk-TEJKDVNT.cjs +620 -0
- package/dist/node/chunk-TEJKDVNT.cjs.map +1 -0
- package/dist/node/chunk-TQS5WYND.cjs +352 -0
- package/dist/node/chunk-TQS5WYND.cjs.map +1 -0
- package/dist/node/chunk-UCAWV2IG.mjs +184 -0
- package/dist/node/chunk-UCAWV2IG.mjs.map +1 -0
- package/dist/node/chunk-UDUJDEAO.cjs +189 -0
- package/dist/node/chunk-UDUJDEAO.cjs.map +1 -0
- package/dist/node/chunk-VMJDL4SS.cjs +542 -0
- package/dist/node/chunk-VMJDL4SS.cjs.map +1 -0
- package/dist/node/chunk-VNOZTB3B.cjs +8 -0
- package/dist/node/chunk-VNOZTB3B.cjs.map +1 -0
- package/dist/node/chunk-VPMBZGYR.mjs +327 -0
- package/dist/node/chunk-VPMBZGYR.mjs.map +1 -0
- package/dist/node/chunk-WEPNBKOA.mjs +6 -0
- package/dist/node/chunk-WEPNBKOA.mjs.map +1 -0
- package/dist/node/chunk-WTBRJXFG.cjs +100 -0
- package/dist/node/chunk-WTBRJXFG.cjs.map +1 -0
- package/dist/node/chunk-WXCQCHAX.mjs +3 -0
- package/dist/node/chunk-WXCQCHAX.mjs.map +1 -0
- package/dist/node/chunk-X3TRPYGV.cjs +352 -0
- package/dist/node/chunk-X3TRPYGV.cjs.map +1 -0
- package/dist/node/chunk-XFUF7SDO.cjs +1 -1
- package/dist/node/chunk-XFUF7SDO.cjs.map +1 -1
- package/dist/node/chunk-XP2EPEBM.mjs +966 -0
- package/dist/node/chunk-XP2EPEBM.mjs.map +1 -0
- package/dist/node/chunk-XPIJ6BKP.cjs +45 -0
- package/dist/node/chunk-XPIJ6BKP.cjs.map +1 -0
- package/dist/node/chunk-YRVBMP7I.cjs +542 -0
- package/dist/node/chunk-YRVBMP7I.cjs.map +1 -0
- package/dist/node/chunk-ZIHSN5EE.mjs +530 -0
- package/dist/node/chunk-ZIHSN5EE.mjs.map +1 -0
- package/dist/node/chunk-ZNQMUU7I.cjs +32 -0
- package/dist/node/chunk-ZNQMUU7I.cjs.map +1 -0
- package/dist/node/completion.cjs +23 -0
- package/dist/node/completion.cjs.map +1 -0
- package/dist/node/completion.d.mts +10 -0
- package/dist/node/completion.d.ts +10 -0
- package/dist/node/completion.mjs +6 -0
- package/dist/node/completion.mjs.map +1 -0
- package/dist/node/core.cjs +67 -38
- package/dist/node/core.cjs.map +1 -1
- package/dist/node/core.d.mts +13 -8
- package/dist/node/core.d.ts +13 -8
- package/dist/node/core.mjs +58 -29
- package/dist/node/core.mjs.map +1 -1
- package/dist/node/credentials.cjs +17 -0
- package/dist/node/credentials.cjs.map +1 -0
- package/dist/node/credentials.d.mts +74 -0
- package/dist/node/credentials.d.ts +74 -0
- package/dist/node/credentials.mjs +4 -0
- package/dist/node/credentials.mjs.map +1 -0
- package/dist/node/definition.cjs +6 -4
- package/dist/node/definition.d.mts +3 -2
- package/dist/node/definition.d.ts +3 -2
- package/dist/node/definition.mjs +4 -2
- package/dist/node/dynamic-content.cjs +30 -0
- package/dist/node/dynamic-content.cjs.map +1 -0
- package/dist/node/dynamic-content.d.mts +13 -0
- package/dist/node/dynamic-content.d.ts +13 -0
- package/dist/node/dynamic-content.mjs +9 -0
- package/dist/node/dynamic-content.mjs.map +1 -0
- package/dist/node/dynamic-feature.cjs +41 -7
- package/dist/node/dynamic-feature.cjs.map +1 -1
- package/dist/node/dynamic-feature.d.mts +66 -6
- package/dist/node/dynamic-feature.d.ts +66 -6
- package/dist/node/dynamic-feature.mjs +16 -9
- package/dist/node/dynamic-feature.mjs.map +1 -1
- package/dist/node/dynamic-structure.cjs +45 -136
- package/dist/node/dynamic-structure.cjs.map +1 -1
- package/dist/node/dynamic-structure.d.mts +77 -3
- package/dist/node/dynamic-structure.d.ts +77 -3
- package/dist/node/dynamic-structure.mjs +16 -135
- package/dist/node/dynamic-structure.mjs.map +1 -1
- package/dist/node/env.cjs +3 -3
- package/dist/node/env.d.mts +26 -0
- package/dist/node/env.d.ts +26 -0
- package/dist/node/env.mjs +2 -2
- package/dist/node/frame-index.cjs +7 -4
- package/dist/node/frame-index.d.mts +70 -9
- package/dist/node/frame-index.d.ts +70 -9
- package/dist/node/frame-index.mjs +6 -3
- package/dist/node/logger.d.mts +4 -113
- package/dist/node/logger.d.ts +4 -113
- package/dist/node/models.cjs +14 -0
- package/dist/node/models.cjs.map +1 -0
- package/dist/node/models.d.mts +64 -0
- package/dist/node/models.d.ts +64 -0
- package/dist/node/models.mjs +5 -0
- package/dist/node/models.mjs.map +1 -0
- package/dist/node/namespace.cjs +7 -5
- package/dist/node/namespace.d.mts +1 -1
- package/dist/node/namespace.d.ts +1 -1
- package/dist/node/namespace.mjs +4 -2
- package/dist/node/schema.cjs +22 -0
- package/dist/node/schema.cjs.map +1 -0
- package/dist/node/schema.d.mts +10 -0
- package/dist/node/schema.d.ts +10 -0
- package/dist/node/schema.mjs +5 -0
- package/dist/node/schema.mjs.map +1 -0
- package/dist/node/segment.cjs +25 -0
- package/dist/node/segment.cjs.map +1 -0
- package/dist/node/segment.d.mts +13 -0
- package/dist/node/segment.d.ts +13 -0
- package/dist/node/segment.mjs +8 -0
- package/dist/node/segment.mjs.map +1 -0
- package/dist/node/storage.cjs +17 -14
- package/dist/node/storage.d.mts +18 -6
- package/dist/node/storage.d.ts +18 -6
- package/dist/node/storage.mjs +11 -8
- package/dist/node/vector.cjs +2 -2
- package/dist/node/vector.d.mts +7 -0
- package/dist/node/vector.d.ts +7 -0
- package/dist/node/vector.mjs +1 -1
- package/examples/article/main.ts +358 -0
- package/examples/components.ts +660 -0
- package/examples/feature/file-system.components.ts +211 -0
- package/examples/feature/main.ts +374 -0
- package/examples/interaction/main.ts +426 -0
- package/examples/logger.ts +126 -0
- package/examples/structure/main.ts +195 -0
- package/examples/structure/renderer.ts +296 -0
- package/examples/structure/server-app.components.ts +387 -0
- package/jest.config.browser.ts +9 -0
- package/jest.config.examples.ts +49 -0
- package/jest.config.integration.ts +38 -0
- package/jest.config.ts +56 -27
- package/jest.config.unit.ts +38 -0
- package/package.json +75 -7
- package/src/index.ts +13 -0
- package/src/lib/A-Frame/A-Frame.component.env-browser.ts +14 -3
- package/src/lib/A-Frame/A-Frame.component.env-node.ts +45 -15
- package/src/lib/A-Frame/A-Frame.context.ts +9 -8
- package/src/lib/A-Frame/decorators/A-FrameDefine.decorator.ts +4 -4
- package/src/lib/A-FrameBundle/A-FrameBundle.builder.env-node.ts +95 -25
- package/src/lib/A-FrameBundle/A-FrameBundle.constants.ts +1 -1
- package/src/lib/A-FrameBundle/A-FrameBundle.types.ts +54 -13
- package/src/lib/A-FrameBundle/index.browser.ts +1 -1
- package/src/lib/A-FrameBundle/index.ts +1 -1
- package/src/lib/A-FrameCLI/A-FrameCLI.container.ts +18 -7
- package/src/lib/A-FrameChannel/A-FrameChannel.component.env-browser.ts +0 -2
- package/src/lib/A-FrameChannel/A-FrameChannel.component.env-node.ts +14 -15
- package/src/lib/A-FrameChannel/A-FrameChannel.component.ts +542 -7
- package/src/lib/A-FrameChannel/A-FrameChannel.constants.ts +2 -0
- package/src/lib/A-FrameChannel/A-FrameChannel.types.ts +65 -1
- package/src/lib/A-FrameChannel/A-FrameChannelDsgStream.entity.ts +112 -0
- package/src/lib/A-FrameChannel/A-FrameChannelStream.entity.ts +1 -0
- package/src/lib/A-FrameChannel/index.browser.ts +5 -0
- package/src/lib/A-FrameCompletion/A-FrameCompletion.constants.ts +3 -0
- package/src/lib/A-FrameCompletion/A-FrameCompletion.entity.ts +128 -0
- package/src/lib/A-FrameCompletion/A-FrameCompletion.types.ts +40 -0
- package/src/lib/A-FrameCompletion/index.ts +3 -0
- package/src/lib/A-FrameCredentials/A-FrameCredentials.constants.ts +5 -0
- package/src/lib/A-FrameCredentials/A-FrameCredentials.entity.ts +120 -0
- package/src/lib/A-FrameCredentials/A-FrameCredentials.types.ts +39 -0
- package/src/lib/A-FrameCredentials/index.ts +3 -0
- package/src/lib/A-FrameDefinition/A-FrameDefinition.entity.ts +23 -1
- package/src/lib/A-FrameDefinition/A-FrameDefinition.types.ts +34 -1
- package/src/lib/A-FrameDynamicContent/A-FrameDynamicContent.constants.ts +5 -0
- package/src/lib/A-FrameDynamicContent/A-FrameDynamicContent.entity.ts +348 -0
- package/src/lib/A-FrameDynamicContent/A-FrameDynamicContent.error.ts +10 -0
- package/src/lib/A-FrameDynamicContent/A-FrameDynamicContent.types.ts +116 -0
- package/src/lib/A-FrameDynamicContent/A-FrameDynamicContentIndex.context.ts +288 -0
- package/src/lib/A-FrameDynamicContent/A-FrameDynamicContentOperation.context.ts +26 -0
- package/src/lib/A-FrameDynamicContent/index.ts +5 -0
- package/src/lib/A-FrameDynamicFeature/A-FrameDynamicFeature.constants.ts +6 -0
- package/src/lib/A-FrameDynamicFeature/A-FrameDynamicFeature.entity.ts +253 -4
- package/src/lib/A-FrameDynamicFeature/A-FrameDynamicFeature.error.ts +11 -0
- package/src/lib/A-FrameDynamicFeature/A-FrameDynamicFeature.types.ts +188 -4
- package/src/lib/A-FrameDynamicFeature/A-FrameDynamicFeatureOperation.context.ts +33 -0
- package/src/lib/A-FrameDynamicFeature/A-FrameMethodMapIndex.context.ts +99 -0
- package/src/lib/A-FrameDynamicFeature/A-FrameMethodMapper.component.ts +182 -0
- package/src/lib/A-FrameDynamicFeature/index.ts +6 -1
- package/src/lib/A-FrameDynamicPatch/index.ts +2 -0
- package/src/lib/A-FrameDynamicStructure/A-FrameComponentMapIndex.context.ts +99 -0
- package/src/lib/A-FrameDynamicStructure/A-FrameComponentMapper.component.ts +320 -0
- package/src/lib/A-FrameDynamicStructure/A-FrameDynamicStructure.constants.ts +2 -1
- package/src/lib/A-FrameDynamicStructure/A-FrameDynamicStructure.entity.ts +240 -128
- package/src/lib/A-FrameDynamicStructure/A-FrameDynamicStructure.types.ts +183 -87
- package/src/lib/A-FrameDynamicStructure/index.ts +3 -0
- package/src/lib/A-FrameEnv/A-FrameEnv.fragment.env-browser.ts +5 -1
- package/src/lib/A-FrameEnv/A-FrameEnv.fragment.env-node.ts +23 -1
- package/src/lib/A-FrameEnv/A-FrameEnv.types.ts +12 -0
- package/src/lib/A-FrameIndex/A-FrameIndex.context.ts +63 -13
- package/src/lib/A-FrameIndex/A-FrameIndex.types.ts +53 -0
- package/src/lib/A-FrameModels/A-FrameModels.constants.ts +75 -0
- package/src/lib/A-FrameModels/index.ts +1 -0
- package/src/lib/A-FrameNamespace/A-FrameNamespace.entity.ts +10 -3
- package/src/lib/A-FrameNamespace/A-FrameNamespace.types.ts +5 -0
- package/src/lib/A-FrameSchema/A-FrameSchema.constants.ts +4 -0
- package/src/lib/A-FrameSchema/A-FrameSchema.entity.ts +154 -0
- package/src/lib/A-FrameSchema/A-FrameSchema.types.ts +88 -0
- package/src/lib/A-FrameSchema/index.ts +3 -0
- package/src/lib/A-FrameSegment/A-FrameSegment.constants.ts +12 -0
- package/src/lib/A-FrameSegment/A-FrameSegment.entity.ts +221 -0
- package/src/lib/A-FrameSegment/A-FrameSegment.types.ts +91 -0
- package/src/lib/A-FrameSegment/index.ts +3 -0
- package/src/lib/A-FrameStorage/A-FrameStorage.codec.ts +10 -4
- package/src/lib/A-FrameStorage/browser/A-FrameBrowserStorage.component.ts +21 -0
- package/src/lib/A-FrameStorage/browser/A-FrameBrowserStorageBlobs.context.ts +39 -21
- package/src/lib/A-FrameStorage/node/A-FrameNodeStorage.component.ts +124 -42
- package/src/lib/A-FrameVector/A-FrameVector.entity.ts +24 -0
- package/tests/A-Frame.browser.test.ts +167 -57
- package/tests/A-FrameDynamicContent.browser.test.ts +74 -0
- package/tests/integration/A-Frame.integration.test.ts +272 -0
- package/tests/integration/A-FrameCompletion.integration.test.ts +88 -0
- package/tests/integration/A-FrameContentMapping.integration.test.ts +261 -0
- package/tests/integration/A-FrameDefinition.integration.test.ts +154 -0
- package/tests/integration/A-FrameDynamicContent.integration.test.ts +126 -0
- package/tests/integration/A-FrameDynamicFeature.integration.test.ts +337 -0
- package/tests/integration/A-FrameDynamicStructure.integration.test.ts +264 -0
- package/tests/integration/A-FrameNamespace.integration.test.ts +109 -0
- package/tests/integration/A-FrameSchema.integration.test.ts +74 -0
- package/tests/integration/A-FrameSegment.integration.test.ts +102 -0
- package/tests/integration/A-FrameStorage.integration.test.ts +598 -0
- package/tests/jest.setup.browser.ts +1 -1
- package/tests/jest.setup.ts +4 -0
- package/tests/jest.setup.unit.ts +30 -0
- package/tests/unit/A-FrameChannel.unit.test.ts +124 -0
- package/tests/unit/A-FrameCompletion.unit.test.ts +25 -0
- package/tests/unit/A-FrameDefinition.unit.test.ts +36 -0
- package/tests/unit/A-FrameDynamicContent.unit.test.ts +28 -0
- package/tests/unit/A-FrameNamespace.unit.test.ts +35 -0
- package/tests/unit/A-FrameSchema.unit.test.ts +31 -0
- package/tests/unit/A-FrameSegment.unit.test.ts +20 -0
- package/tests/unit/mocks/MockA_FrameChannel.ts +112 -0
- package/tsconfig.browser.json +2 -0
- package/tsconfig.json +6 -0
- package/tsup.config.ts +52 -0
- package/tests/A-Frame.test.ts +0 -98
|
@@ -1,10 +1,194 @@
|
|
|
1
|
-
import { A_TYPES__Entity_Serialized } from "@adaas/a-concept"
|
|
1
|
+
import { A_Component, A_Fragment, A_TYPES__Ctor, A_TYPES__Entity_Serialized } from "@adaas/a-concept";
|
|
2
|
+
import { A_FrameDynamicPatch_Serialized } from "../A-FrameDynamicPatch/A-FrameDynamicPatch.types";
|
|
3
|
+
import { A_FrameDynamicFeatureFeatures } from "./A-FrameDynamicFeature.constants";
|
|
2
4
|
|
|
3
5
|
|
|
4
|
-
|
|
6
|
+
// ── Options ────────────────────────────────────────────────────────────────────
|
|
5
7
|
|
|
6
|
-
|
|
8
|
+
export type A_FrameDynamicFeatureOptions = {
|
|
9
|
+
/**
|
|
10
|
+
* Which AI model to use for workflow generation.
|
|
11
|
+
* Defaults to `A_FRAME_MODELS.PULSAR` — the architecture model.
|
|
12
|
+
*/
|
|
13
|
+
model?: string;
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Additional context hint forwarded to the AI — e.g. "microservices",
|
|
17
|
+
* "monolith", "event-driven".
|
|
18
|
+
*/
|
|
19
|
+
context?: string;
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Only consider methods whose owning class's base is in this allowlist.
|
|
23
|
+
* Accepts string names or constructors.
|
|
24
|
+
*/
|
|
25
|
+
includeBases?: Array<string | A_TYPES__Ctor<A_Component | A_Fragment>>;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Exclude methods whose owning class's base is in this denylist.
|
|
29
|
+
*/
|
|
30
|
+
excludeBases?: Array<string | A_TYPES__Ctor<A_Component | A_Fragment>>;
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Explicit allowlist of component/fragment names the AI may reference.
|
|
34
|
+
*/
|
|
35
|
+
enabledComponents?: Array<string | A_TYPES__Ctor<A_Component | A_Fragment>>;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Minimum cosine-similarity score (0–1) for a workflow step to be matched
|
|
39
|
+
* to a registered method. Default: `0.7`
|
|
40
|
+
*/
|
|
41
|
+
minScore?: number;
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* How many server refinement retries before a step is marked unmatched.
|
|
45
|
+
* Default: `3`
|
|
46
|
+
*/
|
|
47
|
+
maxRetries?: number;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
// ── Init / Serialized ──────────────────────────────────────────────────────────
|
|
52
|
+
|
|
53
|
+
export type A_FrameDynamicFeature_Init = {
|
|
54
|
+
/** Goal or capability driving workflow generation. */
|
|
55
|
+
prompt: string;
|
|
56
|
+
/** Optional generation / filtering options. */
|
|
57
|
+
options?: Partial<A_FrameDynamicFeatureOptions>;
|
|
58
|
+
};
|
|
7
59
|
|
|
8
60
|
export type A_FrameDynamicFeature_Serialized = {
|
|
61
|
+
name: string;
|
|
62
|
+
description?: string;
|
|
63
|
+
metadata?: Record<string, unknown>;
|
|
64
|
+
history: Array<A_FrameDynamicPatch_Serialized>;
|
|
65
|
+
} & A_TYPES__Entity_Serialized;
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
// ── Feature name union ──────────────────────────────────────────────────────
|
|
69
|
+
|
|
70
|
+
export type A_FrameDynamicFeatureFeatureNames =
|
|
71
|
+
typeof A_FrameDynamicFeatureFeatures[keyof typeof A_FrameDynamicFeatureFeatures];
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
// ── Domain types ───────────────────────────────────────────────────────────────
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* A single parameter in a workflow step — describes what the caller should
|
|
78
|
+
* provide or what the step will produce.
|
|
79
|
+
*/
|
|
80
|
+
export type A_FrameDynamicFeatureParam = {
|
|
81
|
+
/** Parameter name (camelCase). */
|
|
82
|
+
name: string;
|
|
83
|
+
/** TypeScript type string, e.g. `"string"`, `"number"`, `"UserEntity"`. */
|
|
84
|
+
type: string;
|
|
85
|
+
/** Human-readable purpose of this parameter. */
|
|
86
|
+
description: string;
|
|
87
|
+
/** Whether this parameter must be provided (`true`) or is optional. */
|
|
88
|
+
required: boolean;
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* A single step in the generated workflow definition.
|
|
93
|
+
* Each step corresponds to one method call on a component or fragment.
|
|
94
|
+
*/
|
|
95
|
+
export type A_FrameDynamicFeatureStep = {
|
|
96
|
+
/**
|
|
97
|
+
* One-sentence description of this step's purpose — used as the primary
|
|
98
|
+
* key for semantic matching against the A_FrameIndex.
|
|
99
|
+
*/
|
|
100
|
+
prompt: string;
|
|
101
|
+
/** Ordered list of input parameters for this step. */
|
|
102
|
+
inputs: A_FrameDynamicFeatureParam[];
|
|
103
|
+
/** Ordered list of output values produced by this step. */
|
|
104
|
+
outputs: A_FrameDynamicFeatureParam[];
|
|
105
|
+
/** @internal Server-computed search vector (consumed during mapping). */
|
|
106
|
+
embedding?: number[];
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
/**
|
|
110
|
+
* Full workflow definition produced by `generate()` or `patch()`.
|
|
111
|
+
*/
|
|
112
|
+
export type A_FrameDynamicFeatureDefinition = {
|
|
113
|
+
/**
|
|
114
|
+
* Short title for the workflow, e.g. "User Registration".
|
|
115
|
+
*/
|
|
116
|
+
title: string;
|
|
117
|
+
/**
|
|
118
|
+
* Description of what the workflow accomplishes end-to-end,
|
|
119
|
+
* what the caller must supply, and what will be returned.
|
|
120
|
+
*/
|
|
121
|
+
description: string;
|
|
122
|
+
/** Ordered sequence of steps that make up the workflow. */
|
|
123
|
+
steps: A_FrameDynamicFeatureStep[];
|
|
124
|
+
/**
|
|
125
|
+
* Supporting components (stateless services / controllers) whose methods
|
|
126
|
+
* are used in the steps. No container grouping — workflows are
|
|
127
|
+
* cross-cutting by nature.
|
|
128
|
+
*/
|
|
129
|
+
components: Array<{ prompt: string; embedding?: number[] }>;
|
|
130
|
+
/** Supporting fragments (stateful context objects) referenced in the steps. */
|
|
131
|
+
fragments: Array<{ prompt: string; embedding?: number[] }>;
|
|
132
|
+
/** Supporting entities / domain models referenced in step parameters. */
|
|
133
|
+
entities: Array<{ prompt: string; embedding?: number[]; parameters?: A_FrameDynamicFeatureParam[] }>;
|
|
134
|
+
};
|
|
135
|
+
|
|
136
|
+
|
|
137
|
+
// ── Map types ──────────────────────────────────────────────────────────────────
|
|
138
|
+
|
|
139
|
+
/**
|
|
140
|
+
* Result of matching one workflow step against the A_FrameIndex.
|
|
141
|
+
*/
|
|
142
|
+
export type A_FrameDynamicFeatureStepMapEntry = {
|
|
143
|
+
prompt: string;
|
|
144
|
+
inputs: A_FrameDynamicFeatureParam[];
|
|
145
|
+
outputs: A_FrameDynamicFeatureParam[];
|
|
146
|
+
/** Matched class name, or `null` if unresolved. */
|
|
147
|
+
matchedClass: string | null;
|
|
148
|
+
/** Matched method name, or `null` if unresolved. */
|
|
149
|
+
matchedMethod: string | null;
|
|
150
|
+
/** Cosine-similarity score of the best match (0–1). */
|
|
151
|
+
matchScore: number;
|
|
152
|
+
/** Error details when matching failed after all retries. */
|
|
153
|
+
matchError?: { title: string; description: string } | null;
|
|
154
|
+
};
|
|
155
|
+
|
|
156
|
+
/**
|
|
157
|
+
* Result of matching a supporting element (component / fragment / entity)
|
|
158
|
+
* against the A_FrameIndex.
|
|
159
|
+
*/
|
|
160
|
+
export type A_FrameDynamicFeatureElementMapEntry = {
|
|
161
|
+
prompt: string;
|
|
162
|
+
matchedClass: string | null;
|
|
163
|
+
matchScore: number;
|
|
164
|
+
matchError?: { title: string; description: string } | null;
|
|
165
|
+
};
|
|
166
|
+
|
|
167
|
+
/**
|
|
168
|
+
* Full map result produced by `map()` after matching every element against
|
|
169
|
+
* the local A_FrameIndex.
|
|
170
|
+
*/
|
|
171
|
+
export type A_FrameDynamicFeatureMapResult = {
|
|
172
|
+
steps: A_FrameDynamicFeatureStepMapEntry[];
|
|
173
|
+
components: A_FrameDynamicFeatureElementMapEntry[];
|
|
174
|
+
fragments: A_FrameDynamicFeatureElementMapEntry[];
|
|
175
|
+
entities: A_FrameDynamicFeatureElementMapEntry[];
|
|
176
|
+
};
|
|
177
|
+
|
|
178
|
+
|
|
179
|
+
// ── Wire transport types ───────────────────────────────────────────────────────
|
|
180
|
+
|
|
181
|
+
export interface A_FrameFeatureGenerateResponse {
|
|
182
|
+
definition: A_FrameDynamicFeatureDefinition;
|
|
183
|
+
model: string;
|
|
184
|
+
date: string;
|
|
185
|
+
meta: { server_version: string };
|
|
186
|
+
}
|
|
9
187
|
|
|
10
|
-
|
|
188
|
+
export interface A_FrameFeaturePatchResponse {
|
|
189
|
+
patchSummary: string;
|
|
190
|
+
definition: A_FrameDynamicFeatureDefinition;
|
|
191
|
+
model: string;
|
|
192
|
+
date: string;
|
|
193
|
+
meta: { server_version: string };
|
|
194
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { A_Fragment } from "@adaas/a-concept";
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Thin context fragment that carries parameters for a single DynamicFeature
|
|
6
|
+
* operation (generate or patch). Injected into the feature execution scope and
|
|
7
|
+
* resolved by channel feature-extension handlers via `@A_Inject`.
|
|
8
|
+
*/
|
|
9
|
+
export class A_FrameDynamicFeatureOperation<
|
|
10
|
+
_InputParams = any,
|
|
11
|
+
> extends A_Fragment {
|
|
12
|
+
|
|
13
|
+
protected _meta: Map<string, any> = new Map();
|
|
14
|
+
|
|
15
|
+
constructor(
|
|
16
|
+
params: _InputParams = {} as _InputParams
|
|
17
|
+
) {
|
|
18
|
+
super({ name: 'a-frame-dynamic-feature-operation-context' });
|
|
19
|
+
this._meta.set('params', params);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
get params(): _InputParams {
|
|
23
|
+
return this._meta.get('params');
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
get(key: string): any {
|
|
27
|
+
return this._meta.get(key);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
set(key: string, value: any): void {
|
|
31
|
+
this._meta.set(key, value);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { A_Fragment } from "@adaas/a-concept";
|
|
2
|
+
import {
|
|
3
|
+
A_FrameDynamicFeatureDefinition,
|
|
4
|
+
A_FrameDynamicFeatureElementMapEntry,
|
|
5
|
+
A_FrameDynamicFeatureMapResult,
|
|
6
|
+
A_FrameDynamicFeatureStep,
|
|
7
|
+
A_FrameDynamicFeatureStepMapEntry,
|
|
8
|
+
} from "./A-FrameDynamicFeature.types";
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Context fragment that accumulates the method/component-mapping results
|
|
13
|
+
* produced by `A_FrameMethodMapper.mapFeature()`.
|
|
14
|
+
*
|
|
15
|
+
* Uses `prompt` as the unique key — same approach as `A_FrameComponentMapIndex`.
|
|
16
|
+
* Call `toResult(definition)` after the mapper finishes to build the fully
|
|
17
|
+
* structured `A_FrameDynamicFeatureMapResult`.
|
|
18
|
+
*/
|
|
19
|
+
export class A_FrameMethodMapIndex extends A_Fragment {
|
|
20
|
+
|
|
21
|
+
private _stepEntries: Map<string, A_FrameDynamicFeatureStepMapEntry> = new Map();
|
|
22
|
+
private _elementEntries: Map<string, A_FrameDynamicFeatureElementMapEntry> = new Map();
|
|
23
|
+
|
|
24
|
+
constructor() {
|
|
25
|
+
super({ name: 'a-frame-method-map-index' });
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
// ── Step entries ─────────────────────────────────────────────────────────
|
|
29
|
+
|
|
30
|
+
setStep(entry: A_FrameDynamicFeatureStepMapEntry): void {
|
|
31
|
+
this._stepEntries.set(entry.prompt, entry);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
getStep(prompt: string): A_FrameDynamicFeatureStepMapEntry | undefined {
|
|
35
|
+
return this._stepEntries.get(prompt);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// ── Element entries (components / fragments / entities) ───────────────────
|
|
39
|
+
|
|
40
|
+
setElement(entry: A_FrameDynamicFeatureElementMapEntry): void {
|
|
41
|
+
this._elementEntries.set(entry.prompt, entry);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
getElement(prompt: string): A_FrameDynamicFeatureElementMapEntry | undefined {
|
|
45
|
+
return this._elementEntries.get(prompt);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// ── Accessors ─────────────────────────────────────────────────────────────
|
|
49
|
+
|
|
50
|
+
clear(): void {
|
|
51
|
+
this._stepEntries.clear();
|
|
52
|
+
this._elementEntries.clear();
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
get stepCount(): number { return this._stepEntries.size; }
|
|
56
|
+
get elementCount(): number { return this._elementEntries.size; }
|
|
57
|
+
|
|
58
|
+
get matchedSteps(): A_FrameDynamicFeatureStepMapEntry[] {
|
|
59
|
+
return Array.from(this._stepEntries.values()).filter(e => e.matchedMethod !== null);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
get unmatchedSteps(): A_FrameDynamicFeatureStepMapEntry[] {
|
|
63
|
+
return Array.from(this._stepEntries.values()).filter(e => e.matchedMethod === null);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// ── Result building ───────────────────────────────────────────────────────
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Construct a fully structured `A_FrameDynamicFeatureMapResult` from the
|
|
70
|
+
* accumulated entries and the provided definition.
|
|
71
|
+
*/
|
|
72
|
+
toResult(definition: A_FrameDynamicFeatureDefinition): A_FrameDynamicFeatureMapResult {
|
|
73
|
+
const getStep = (step: A_FrameDynamicFeatureStep): A_FrameDynamicFeatureStepMapEntry => {
|
|
74
|
+
const existing = this._stepEntries.get(step.prompt);
|
|
75
|
+
if (existing) return existing;
|
|
76
|
+
return {
|
|
77
|
+
prompt: step.prompt,
|
|
78
|
+
inputs: step.inputs,
|
|
79
|
+
outputs: step.outputs,
|
|
80
|
+
matchedClass: null,
|
|
81
|
+
matchedMethod: null,
|
|
82
|
+
matchScore: 0,
|
|
83
|
+
};
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
const getElement = (el: { prompt: string }): A_FrameDynamicFeatureElementMapEntry => {
|
|
87
|
+
const existing = this._elementEntries.get(el.prompt);
|
|
88
|
+
if (existing) return existing;
|
|
89
|
+
return { prompt: el.prompt, matchedClass: null, matchScore: 0 };
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
return {
|
|
93
|
+
steps: definition.steps.map(getStep),
|
|
94
|
+
components: definition.components.map(getElement),
|
|
95
|
+
fragments: definition.fragments.map(getElement),
|
|
96
|
+
entities: definition.entities.map(getElement),
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
}
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
import { A_Caller, A_Component, A_Context, A_Feature, A_Inject, A_Scope } from "@adaas/a-concept";
|
|
2
|
+
import { A_FrameChannel } from "../A-FrameChannel/A-FrameChannel.component";
|
|
3
|
+
import { A_FrameFeatures } from "../A-FrameChannel/A-FrameChannel.constants";
|
|
4
|
+
import { A_FrameChannelRequest } from "../A-FrameChannel/A-FrameChannelRequest.context";
|
|
5
|
+
import { A_FrameIndex } from "../A-FrameIndex/A-FrameIndex.context";
|
|
6
|
+
import { A_FrameVector } from "../A-FrameVector/A-FrameVector.entity";
|
|
7
|
+
import { A_FrameDynamicFeature } from "./A-FrameDynamicFeature.entity";
|
|
8
|
+
import { A_FrameDynamicFeatureFeatures } from "./A-FrameDynamicFeature.constants";
|
|
9
|
+
import { A_FrameDynamicFeatureError } from "./A-FrameDynamicFeature.error";
|
|
10
|
+
import {
|
|
11
|
+
A_FrameDynamicFeatureDefinition,
|
|
12
|
+
A_FrameDynamicFeatureElementMapEntry,
|
|
13
|
+
A_FrameDynamicFeatureStep,
|
|
14
|
+
A_FrameDynamicFeatureStepMapEntry,
|
|
15
|
+
A_FrameFeaturePatchResponse,
|
|
16
|
+
} from "./A-FrameDynamicFeature.types";
|
|
17
|
+
import { A_FrameMethodMapIndex } from "./A-FrameMethodMapIndex.context";
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Stateless component that implements the `Map` feature for
|
|
22
|
+
* `A_FrameDynamicFeature`.
|
|
23
|
+
*
|
|
24
|
+
* Algorithm:
|
|
25
|
+
* 1. Read `feature.definition` (includes server-computed embeddings on steps
|
|
26
|
+
* and supporting elements).
|
|
27
|
+
* 2. Run cosine-similarity search against `A_FrameIndex` for every step and
|
|
28
|
+
* every supporting element.
|
|
29
|
+
* 3. For steps that remain unmatched, issue a server patch to refine their
|
|
30
|
+
* descriptions (up to `feature.maxRetries` times), then re-match.
|
|
31
|
+
* 4. Mark any still-unmatched steps with a `matchError`.
|
|
32
|
+
* 5. Hydrate the feature with `mapIndex.toResult(def)`.
|
|
33
|
+
*/
|
|
34
|
+
export class A_FrameMethodMapper extends A_Component {
|
|
35
|
+
|
|
36
|
+
@A_Feature.Extend({
|
|
37
|
+
name: A_FrameDynamicFeatureFeatures.Map,
|
|
38
|
+
scope: [A_FrameDynamicFeature],
|
|
39
|
+
})
|
|
40
|
+
async mapFeature(
|
|
41
|
+
@A_Inject(A_Caller) feature: A_FrameDynamicFeature,
|
|
42
|
+
@A_Inject(A_FrameMethodMapIndex) mapIndex: A_FrameMethodMapIndex,
|
|
43
|
+
@A_Inject(A_FrameIndex) frameIndex: A_FrameIndex,
|
|
44
|
+
@A_Inject(A_FrameChannel) channel: A_FrameChannel,
|
|
45
|
+
): Promise<void> {
|
|
46
|
+
|
|
47
|
+
const def = feature.definition;
|
|
48
|
+
if (!def) return;
|
|
49
|
+
|
|
50
|
+
// ── helpers ──────────────────────────────────────────────────────────
|
|
51
|
+
|
|
52
|
+
const tryMatchStep = (
|
|
53
|
+
step: A_FrameDynamicFeatureStep,
|
|
54
|
+
minScore: number,
|
|
55
|
+
): Pick<A_FrameDynamicFeatureStepMapEntry, 'matchedClass' | 'matchedMethod' | 'matchScore'> => {
|
|
56
|
+
if (!step.embedding?.length) {
|
|
57
|
+
return { matchedClass: null, matchedMethod: null, matchScore: 0 };
|
|
58
|
+
}
|
|
59
|
+
const results = frameIndex.search(new A_FrameVector(step.embedding), { topK: 1 });
|
|
60
|
+
const top = results[0];
|
|
61
|
+
if (top && top.score >= minScore) {
|
|
62
|
+
// Method definitions store name = "methodName" and dependency.name = "ClassName".
|
|
63
|
+
// Class definitions store both name and dependency.name as the class name.
|
|
64
|
+
const matchedClass = top.record.dependency.name;
|
|
65
|
+
const matchedMethod = top.record.name;
|
|
66
|
+
return { matchedClass, matchedMethod, matchScore: top.score };
|
|
67
|
+
}
|
|
68
|
+
return { matchedClass: null, matchedMethod: null, matchScore: top?.score ?? 0 };
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
const tryMatchElement = (
|
|
72
|
+
el: { prompt: string; class?: string; embedding?: number[] },
|
|
73
|
+
minScore: number,
|
|
74
|
+
): Pick<A_FrameDynamicFeatureElementMapEntry, 'matchedClass' | 'matchScore'> => {
|
|
75
|
+
if (!el.embedding?.length) {
|
|
76
|
+
return { matchedClass: null, matchScore: 0 };
|
|
77
|
+
}
|
|
78
|
+
const results = frameIndex.search(new A_FrameVector(el.embedding), { topK: 1 });
|
|
79
|
+
const top = results[0];
|
|
80
|
+
if (top && top.score >= minScore) {
|
|
81
|
+
return { matchedClass: top.record.name, matchScore: top.score };
|
|
82
|
+
}
|
|
83
|
+
return { matchedClass: null, matchScore: top?.score ?? 0 };
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
const stripEmbeddings = (d: A_FrameDynamicFeatureDefinition): A_FrameDynamicFeatureDefinition => {
|
|
87
|
+
const strip = (el: any): any => { const { embedding, ...rest } = el; return rest; };
|
|
88
|
+
return {
|
|
89
|
+
...d,
|
|
90
|
+
steps: d.steps.map(strip),
|
|
91
|
+
components: d.components.map(strip),
|
|
92
|
+
fragments: d.fragments.map(strip),
|
|
93
|
+
entities: d.entities.map(strip),
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
const matchAll = (d: A_FrameDynamicFeatureDefinition): void => {
|
|
98
|
+
mapIndex.clear();
|
|
99
|
+
for (const step of d.steps) {
|
|
100
|
+
mapIndex.setStep({
|
|
101
|
+
prompt: step.prompt,
|
|
102
|
+
inputs: step.inputs,
|
|
103
|
+
outputs: step.outputs,
|
|
104
|
+
...tryMatchStep(step, feature.minScore),
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
for (const el of d.components) {
|
|
108
|
+
mapIndex.setElement({ prompt: el.prompt, ...tryMatchElement(el, feature.minScore) });
|
|
109
|
+
}
|
|
110
|
+
for (const el of d.fragments) {
|
|
111
|
+
mapIndex.setElement({ prompt: el.prompt, ...tryMatchElement(el, feature.minScore) });
|
|
112
|
+
}
|
|
113
|
+
for (const el of d.entities) {
|
|
114
|
+
mapIndex.setElement({ prompt: el.prompt, ...tryMatchElement(el, feature.minScore) });
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
|
|
118
|
+
// ── initial matching pass ─────────────────────────────────────────────
|
|
119
|
+
|
|
120
|
+
let workingDef = def;
|
|
121
|
+
matchAll(workingDef);
|
|
122
|
+
|
|
123
|
+
// ── retry loop: refine unmatched steps via server patch ───────────────
|
|
124
|
+
|
|
125
|
+
for (let retry = 0; retry < feature.maxRetries; retry++) {
|
|
126
|
+
const unmatchedSteps = workingDef.steps.filter(
|
|
127
|
+
step => step.embedding?.length && mapIndex.getStep(step.prompt)?.matchedMethod === null,
|
|
128
|
+
);
|
|
129
|
+
if (unmatchedSteps.length === 0) break;
|
|
130
|
+
|
|
131
|
+
const refinementInstruction = [
|
|
132
|
+
`The following workflow steps could not be matched to any registered method.`,
|
|
133
|
+
`Please re-describe each step with more specific, method-oriented language:`,
|
|
134
|
+
unmatchedSteps.map(s => `- "${s.prompt}"`).join('\n'),
|
|
135
|
+
].join('\n');
|
|
136
|
+
|
|
137
|
+
const patchReq = new A_FrameChannelRequest<A_FrameFeaturePatchResponse>(
|
|
138
|
+
'POST',
|
|
139
|
+
'/api/v1/feature/patch',
|
|
140
|
+
{
|
|
141
|
+
originalPrompt: feature.prompt,
|
|
142
|
+
definition: stripEmbeddings(workingDef),
|
|
143
|
+
patchInstruction: refinementInstruction,
|
|
144
|
+
model: feature.modelName,
|
|
145
|
+
context: feature.contextHint,
|
|
146
|
+
},
|
|
147
|
+
);
|
|
148
|
+
|
|
149
|
+
const patchScope = new A_Scope({
|
|
150
|
+
name: `A_FrameMethodMapper.mapFeature:retry${retry}`,
|
|
151
|
+
fragments: [patchReq],
|
|
152
|
+
}).inherit(A_Context.scope(channel));
|
|
153
|
+
|
|
154
|
+
await channel.call(A_FrameFeatures.Request, patchScope);
|
|
155
|
+
patchScope.destroy();
|
|
156
|
+
|
|
157
|
+
if (!patchReq.response) break;
|
|
158
|
+
|
|
159
|
+
workingDef = patchReq.response.definition;
|
|
160
|
+
matchAll(workingDef);
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
// ── finalize: mark remaining unmatched steps with an error ────────────
|
|
164
|
+
|
|
165
|
+
for (const step of workingDef.steps) {
|
|
166
|
+
const entry = mapIndex.getStep(step.prompt);
|
|
167
|
+
if (entry && entry.matchedMethod === null && step.embedding?.length) {
|
|
168
|
+
mapIndex.setStep({
|
|
169
|
+
...entry,
|
|
170
|
+
matchError: {
|
|
171
|
+
title: A_FrameDynamicFeatureError.MethodNotFound,
|
|
172
|
+
description: `Unable to match "${step.prompt}" to any registered method after ${feature.maxRetries} retries.`,
|
|
173
|
+
},
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
// ── hydrate the feature with the map result ───────────────────────────
|
|
179
|
+
|
|
180
|
+
feature.hydrateFromMap(mapIndex.toResult(workingDef));
|
|
181
|
+
}
|
|
182
|
+
}
|
|
@@ -1,2 +1,7 @@
|
|
|
1
|
+
export * from './A-FrameDynamicFeature.constants';
|
|
1
2
|
export * from './A-FrameDynamicFeature.entity';
|
|
2
|
-
export * from './A-FrameDynamicFeature.types';
|
|
3
|
+
export * from './A-FrameDynamicFeature.types';
|
|
4
|
+
export * from './A-FrameDynamicFeature.error';
|
|
5
|
+
export * from './A-FrameDynamicFeatureOperation.context';
|
|
6
|
+
export * from './A-FrameMethodMapIndex.context';
|
|
7
|
+
export * from './A-FrameMethodMapper.component';
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { A_Fragment } from "@adaas/a-concept";
|
|
2
|
+
import {
|
|
3
|
+
A_FrameComponentMapEntry,
|
|
4
|
+
A_FrameComponentMapResult,
|
|
5
|
+
A_FrameDynamicStructureDefinition,
|
|
6
|
+
A_FrameDynamicStructureDefinitionEntity,
|
|
7
|
+
} from "./A-FrameDynamicStructure.types";
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Context fragment that accumulates component-mapping results produced by
|
|
12
|
+
* `A_FrameComponentMapper.mapStructure()`.
|
|
13
|
+
*
|
|
14
|
+
* Uses a flat `prompt → A_FrameComponentMapEntry` map so lookups are O(1).
|
|
15
|
+
* Call `toResult(definition)` after the mapper has finished to build the
|
|
16
|
+
* structured `A_FrameComponentMapResult` that mirrors the definition layout.
|
|
17
|
+
*/
|
|
18
|
+
export class A_FrameComponentMapIndex extends A_Fragment {
|
|
19
|
+
|
|
20
|
+
private _entries: Map<string, A_FrameComponentMapEntry> = new Map();
|
|
21
|
+
|
|
22
|
+
constructor() {
|
|
23
|
+
super({ name: 'a-frame-component-map-index' });
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// ── Basic mutation ───────────────────────────────────────────────────────
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Store (or overwrite) a map entry for the element identified by `entry.prompt`.
|
|
30
|
+
*/
|
|
31
|
+
set(entry: A_FrameComponentMapEntry): void {
|
|
32
|
+
this._entries.set(entry.prompt, entry);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Retrieve the map entry for the given prompt, or `undefined` if not yet stored.
|
|
37
|
+
*/
|
|
38
|
+
get(prompt: string): A_FrameComponentMapEntry | undefined {
|
|
39
|
+
return this._entries.get(prompt);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/** Remove all stored entries. */
|
|
43
|
+
clear(): void {
|
|
44
|
+
this._entries.clear();
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// ── Accessors ────────────────────────────────────────────────────────────
|
|
48
|
+
|
|
49
|
+
/** Total number of stored entries. */
|
|
50
|
+
get size(): number {
|
|
51
|
+
return this._entries.size;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/** All stored entries in insertion order. */
|
|
55
|
+
list(): A_FrameComponentMapEntry[] {
|
|
56
|
+
return Array.from(this._entries.values());
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/** Entries that have been successfully matched to a registered class. */
|
|
60
|
+
get matched(): A_FrameComponentMapEntry[] {
|
|
61
|
+
return this.list().filter(e => e.matchedClass !== null);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/** Entries where no matching registered class was found. */
|
|
65
|
+
get unmatched(): A_FrameComponentMapEntry[] {
|
|
66
|
+
return this.list().filter(e => e.matchedClass === null);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// ── Result building ──────────────────────────────────────────────────────
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* Construct a fully structured `A_FrameComponentMapResult` from the
|
|
73
|
+
* accumulated entries and the provided definition.
|
|
74
|
+
*
|
|
75
|
+
* For each element in the definition the method looks up its entry by
|
|
76
|
+
* prompt. If no entry exists (element had no server embedding), a default
|
|
77
|
+
* unmatched entry is generated so the result shape always matches the
|
|
78
|
+
* definition shape.
|
|
79
|
+
*/
|
|
80
|
+
toResult(definition: A_FrameDynamicStructureDefinition): A_FrameComponentMapResult {
|
|
81
|
+
const getEntry = (el: A_FrameDynamicStructureDefinitionEntity): A_FrameComponentMapEntry => {
|
|
82
|
+
const existing = this._entries.get(el.prompt);
|
|
83
|
+
if (existing) return existing;
|
|
84
|
+
return { prompt: el.prompt, role: el.role, class: el.class, matchedClass: null, matchScore: 0 };
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
return {
|
|
88
|
+
containers: definition.containers.map(c => ({
|
|
89
|
+
...getEntry(c),
|
|
90
|
+
components: (c.components ?? []).map(getEntry),
|
|
91
|
+
fragments: (c.fragments ?? []).map(getEntry),
|
|
92
|
+
entities: (c.entities ?? []).map(getEntry),
|
|
93
|
+
})),
|
|
94
|
+
components: definition.components.map(getEntry),
|
|
95
|
+
fragments: definition.fragments.map(getEntry),
|
|
96
|
+
entities: definition.entities.map(getEntry),
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
}
|