@dxos/plugin-assistant 0.8.4-main.28f8d3d → 0.8.4-main.406dc2a
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/{BlueprintContainer-H7H4BQ2C.mjs → BlueprintContainer-WX2SSDVI.mjs} +6 -7
- package/dist/lib/browser/{BlueprintContainer-H7H4BQ2C.mjs.map → BlueprintContainer-WX2SSDVI.mjs.map} +3 -3
- package/dist/lib/browser/ChatCompanion-BDZ55ZRF.mjs +150 -0
- package/dist/lib/browser/ChatCompanion-BDZ55ZRF.mjs.map +7 -0
- package/dist/lib/browser/{ChatContainer-OUVSX5V5.mjs → ChatContainer-RYGNN73X.mjs} +20 -23
- package/dist/lib/browser/ChatContainer-RYGNN73X.mjs.map +7 -0
- package/dist/lib/browser/{ChatDialog-P4FLEOHG.mjs → ChatDialog-MVHH2U66.mjs} +12 -12
- package/dist/lib/browser/ChatDialog-MVHH2U66.mjs.map +7 -0
- package/dist/lib/browser/{SequenceContainer-627OQ557.mjs → SequenceContainer-2FEWMQGW.mjs} +6 -19
- package/dist/lib/browser/SequenceContainer-2FEWMQGW.mjs.map +7 -0
- package/dist/lib/browser/ai-service-ERTZBTP3.mjs +19 -0
- package/dist/lib/browser/ai-service-ERTZBTP3.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-builder-AVHHQ3KV.mjs → app-graph-builder-2U7SLCRX.mjs} +22 -34
- package/dist/lib/browser/app-graph-builder-2U7SLCRX.mjs.map +7 -0
- package/dist/lib/browser/blueprint-definition-NSJARW5U.mjs +12 -0
- package/dist/lib/browser/blueprint-definition-NSJARW5U.mjs.map +7 -0
- package/dist/lib/browser/{blueprint-definition-CMGIZAOW.mjs → chunk-2CE2KPKZ.mjs} +69 -40
- package/dist/lib/browser/chunk-2CE2KPKZ.mjs.map +7 -0
- package/dist/lib/browser/chunk-43I2LR6O.mjs +216 -0
- package/dist/lib/browser/chunk-43I2LR6O.mjs.map +7 -0
- package/dist/lib/browser/chunk-5EGXHCAZ.mjs +16 -0
- package/dist/lib/browser/chunk-5EGXHCAZ.mjs.map +7 -0
- package/dist/lib/browser/chunk-5RICKAMN.mjs +18 -0
- package/dist/lib/browser/chunk-5RICKAMN.mjs.map +7 -0
- package/dist/lib/browser/chunk-CQ7UHYTT.mjs +296 -0
- package/dist/lib/browser/chunk-CQ7UHYTT.mjs.map +7 -0
- package/dist/lib/browser/{chunk-HRLMD35M.mjs → chunk-FP56WB24.mjs} +36 -15
- package/dist/lib/browser/chunk-FP56WB24.mjs.map +7 -0
- package/dist/lib/browser/chunk-JZRZVB2A.mjs +170 -0
- package/dist/lib/browser/chunk-JZRZVB2A.mjs.map +7 -0
- package/dist/lib/browser/chunk-WRJGOT5P.mjs +1794 -0
- package/dist/lib/browser/chunk-WRJGOT5P.mjs.map +7 -0
- package/dist/lib/browser/edge-model-resolver-O6OFYIO2.mjs +18 -0
- package/dist/lib/browser/edge-model-resolver-O6OFYIO2.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +127 -54
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/{intent-resolver-MVOIEJXZ.mjs → intent-resolver-3GOJMBXJ.mjs} +48 -15
- package/dist/lib/browser/intent-resolver-3GOJMBXJ.mjs.map +7 -0
- package/dist/lib/browser/local-model-resolver-GO6ZEMLL.mjs +17 -0
- package/dist/lib/browser/local-model-resolver-GO6ZEMLL.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-4HXS3YLT.mjs → react-surface-FTKCE6GG.mjs} +20 -76
- package/dist/lib/browser/react-surface-FTKCE6GG.mjs.map +7 -0
- package/dist/lib/browser/{settings-G2EZXMWT.mjs → settings-HBF32KV6.mjs} +5 -5
- package/dist/lib/browser/{settings-G2EZXMWT.mjs.map → settings-HBF32KV6.mjs.map} +1 -1
- package/dist/lib/browser/state-LXTS54DI.mjs +21 -0
- package/dist/lib/browser/state-LXTS54DI.mjs.map +7 -0
- package/dist/lib/browser/toolkit-NQ2GXCF5.mjs +199 -0
- package/dist/lib/browser/toolkit-NQ2GXCF5.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +2 -2
- package/dist/lib/node-esm/{BlueprintContainer-VH4EE4CM.mjs → BlueprintContainer-4MKN6ZRB.mjs} +6 -7
- package/dist/lib/node-esm/{BlueprintContainer-VH4EE4CM.mjs.map → BlueprintContainer-4MKN6ZRB.mjs.map} +3 -3
- package/dist/lib/node-esm/ChatCompanion-XFNXVZIP.mjs +151 -0
- package/dist/lib/node-esm/ChatCompanion-XFNXVZIP.mjs.map +7 -0
- package/dist/lib/node-esm/{ChatContainer-D5FABDNE.mjs → ChatContainer-UTJGCQXF.mjs} +20 -23
- package/dist/lib/node-esm/ChatContainer-UTJGCQXF.mjs.map +7 -0
- package/dist/lib/node-esm/{ChatDialog-NKWVXHJP.mjs → ChatDialog-QEYZ4IOV.mjs} +12 -12
- package/dist/lib/node-esm/ChatDialog-QEYZ4IOV.mjs.map +7 -0
- package/dist/lib/node-esm/{SequenceContainer-EQ5NP2PG.mjs → SequenceContainer-PGGJUQ46.mjs} +6 -19
- package/dist/lib/node-esm/SequenceContainer-PGGJUQ46.mjs.map +7 -0
- package/dist/lib/node-esm/ai-service-MUYLV3NT.mjs +20 -0
- package/dist/lib/node-esm/ai-service-MUYLV3NT.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-builder-RMOUJMMG.mjs → app-graph-builder-OKNLR7H2.mjs} +22 -34
- package/dist/lib/node-esm/app-graph-builder-OKNLR7H2.mjs.map +7 -0
- package/dist/lib/node-esm/blueprint-definition-WD2IVMAI.mjs +13 -0
- package/dist/lib/node-esm/blueprint-definition-WD2IVMAI.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-73ABYRYX.mjs +20 -0
- package/dist/lib/node-esm/chunk-73ABYRYX.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-DSE2IILK.mjs +217 -0
- package/dist/lib/node-esm/chunk-DSE2IILK.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-E2WXZND7.mjs +297 -0
- package/dist/lib/node-esm/chunk-E2WXZND7.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-HXIBCBH4.mjs +171 -0
- package/dist/lib/node-esm/chunk-HXIBCBH4.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-F7RXCX5Y.mjs → chunk-TNR46C3L.mjs} +36 -15
- package/dist/lib/node-esm/chunk-TNR46C3L.mjs.map +7 -0
- package/dist/lib/node-esm/{blueprint-definition-AEWYMW6I.mjs → chunk-U2NYUS2N.mjs} +69 -39
- package/dist/lib/node-esm/chunk-U2NYUS2N.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-UFKLCEAE.mjs +1795 -0
- package/dist/lib/node-esm/chunk-UFKLCEAE.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-X6AANUHZ.mjs → chunk-XQGWSZ4T.mjs} +4 -4
- package/dist/lib/node-esm/chunk-XQGWSZ4T.mjs.map +7 -0
- package/dist/lib/node-esm/edge-model-resolver-2ARXDOYS.mjs +19 -0
- package/dist/lib/node-esm/edge-model-resolver-2ARXDOYS.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +127 -54
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/{intent-resolver-DTDNCX3C.mjs → intent-resolver-6XLVTRDJ.mjs} +48 -15
- package/dist/lib/node-esm/intent-resolver-6XLVTRDJ.mjs.map +7 -0
- package/dist/lib/node-esm/local-model-resolver-WOQ2D2R2.mjs +18 -0
- package/dist/lib/node-esm/local-model-resolver-WOQ2D2R2.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-V6JNEZVO.mjs → react-surface-K7ZXQLAP.mjs} +20 -76
- package/dist/lib/node-esm/react-surface-K7ZXQLAP.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-AIP5FOJG.mjs → settings-CWP6MTWP.mjs} +5 -5
- package/dist/lib/node-esm/{settings-AIP5FOJG.mjs.map → settings-CWP6MTWP.mjs.map} +1 -1
- package/dist/lib/node-esm/state-BO6GUFLB.mjs +22 -0
- package/dist/lib/node-esm/state-BO6GUFLB.mjs.map +7 -0
- package/dist/lib/node-esm/toolkit-V57PRJNG.mjs +200 -0
- package/dist/lib/node-esm/toolkit-V57PRJNG.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +2 -2
- package/dist/types/src/AssistantPlugin.d.ts +1 -1
- package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/ai-service.d.ts +2 -3
- package/dist/types/src/capabilities/ai-service.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/blueprint-definition.d.ts +5 -1
- package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/capabilities.d.ts +8 -8
- package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
- package/dist/types/src/capabilities/edge-model-resolver.d.ts +2 -3
- package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +7 -4
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/local-model-resolver.d.ts +10 -0
- package/dist/types/src/capabilities/local-model-resolver.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-surface.d.ts +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/settings.d.ts +1 -1
- package/dist/types/src/capabilities/state.d.ts +4 -0
- package/dist/types/src/capabilities/state.d.ts.map +1 -0
- package/dist/types/src/capabilities/toolkit.d.ts +2 -3
- package/dist/types/src/capabilities/toolkit.d.ts.map +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
- package/dist/types/src/components/Chat/Chat.d.ts +16 -10
- package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
- package/dist/types/src/components/Chat/events.d.ts +5 -0
- package/dist/types/src/components/Chat/events.d.ts.map +1 -1
- package/dist/types/src/components/ChatCompanion.d.ts +13 -0
- package/dist/types/src/components/ChatCompanion.d.ts.map +1 -0
- package/dist/types/src/components/ChatContainer.d.ts +3 -4
- package/dist/types/src/components/ChatContainer.d.ts.map +1 -1
- package/dist/types/src/components/ChatProgress/ChatProgress.d.ts +7 -0
- package/dist/types/src/components/ChatProgress/ChatProgress.d.ts.map +1 -0
- package/dist/types/src/components/ChatProgress/index.d.ts +2 -0
- package/dist/types/src/components/ChatProgress/index.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatActions.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts +11 -4
- package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +3 -4
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts +6 -4
- package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/ChatThread.d.ts +12 -7
- package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +112 -56
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/Link.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/reducers.d.ts +40 -0
- package/dist/types/src/components/ChatThread/reducers.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/registry.d.ts +11 -0
- package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/sync.d.ts +36 -0
- package/dist/types/src/components/ChatThread/sync.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/sync.test.d.ts +2 -0
- package/dist/types/src/components/ChatThread/sync.test.d.ts.map +1 -0
- package/dist/types/src/components/PromptSettings.d.ts.map +1 -1
- package/dist/types/src/components/SequenceContainer.d.ts.map +1 -1
- package/dist/types/src/components/SequenceEditor/SequenceEditor.d.ts +1 -1
- package/dist/types/src/components/SequenceEditor/SequenceEditor.d.ts.map +1 -1
- package/dist/types/src/components/SequenceEditor/SequenceEditor.stories.d.ts +264 -3
- package/dist/types/src/components/SequenceEditor/SequenceEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +0 -5
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +262 -7
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +259 -2
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/handlebars-extension.d.ts +12 -0
- package/dist/types/src/components/TemplateEditor/handlebars-extension.d.ts.map +1 -0
- package/dist/types/src/components/ToolBlock/ToolBlock.d.ts +19 -0
- package/dist/types/src/components/ToolBlock/ToolBlock.d.ts.map +1 -0
- package/dist/types/src/components/ToolBlock/ToolBlockWidget.d.ts +2 -0
- package/dist/types/src/components/ToolBlock/ToolBlockWidget.d.ts.map +1 -0
- package/dist/types/src/components/ToolBlock/index.d.ts +3 -0
- package/dist/types/src/components/ToolBlock/index.d.ts.map +1 -0
- package/dist/types/src/components/Toolbar/Toolbar.d.ts +5 -0
- package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +1 -0
- package/dist/types/src/components/Toolbar/index.d.ts +2 -0
- package/dist/types/src/components/Toolbar/index.d.ts.map +1 -0
- package/dist/types/src/components/Toolbar/useChatToolbarActions.d.ts +11 -0
- package/dist/types/src/components/Toolbar/useChatToolbarActions.d.ts.map +1 -0
- package/dist/types/src/components/Toolbox/Toolbox.d.ts +1 -3
- package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +263 -5
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +4 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/functions/analysis.d.ts.map +1 -1
- package/dist/types/src/functions/list.d.ts.map +1 -1
- package/dist/types/src/functions/load.d.ts +1 -1
- package/dist/types/src/functions/load.d.ts.map +1 -1
- package/dist/types/src/hooks/index.d.ts +4 -4
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useBlueprintRegistry.d.ts +5 -1
- package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatProcessor.d.ts +4 -10
- package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatServices.d.ts +5 -5
- package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
- package/dist/types/src/hooks/useContextBinder.d.ts +4 -0
- package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -0
- package/dist/types/src/hooks/useContextObjects.d.ts +15 -0
- package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -0
- package/dist/types/src/hooks/useFlush.d.ts.map +1 -0
- package/dist/types/src/hooks/useItemTypes.d.ts +4 -0
- package/dist/types/src/hooks/useItemTypes.d.ts.map +1 -0
- package/dist/types/src/hooks/usePresets.d.ts +2 -2
- package/dist/types/src/hooks/usePresets.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +2 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +1 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/processor/index.d.ts +3 -0
- package/dist/types/src/processor/index.d.ts.map +1 -0
- package/dist/types/src/{hooks → processor}/presets.d.ts +1 -1
- package/dist/types/src/processor/presets.d.ts.map +1 -0
- package/dist/types/src/processor/processor.d.ts +74 -0
- package/dist/types/src/processor/processor.d.ts.map +1 -0
- package/dist/types/src/processor/processor.test.d.ts +2 -0
- package/dist/types/src/processor/processor.test.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +1 -1
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/test-generator.d.ts +7 -0
- package/dist/types/src/testing/test-generator.d.ts.map +1 -0
- package/dist/types/src/testing/test-sequence.d.ts +0 -4
- package/dist/types/src/testing/test-sequence.d.ts.map +1 -1
- package/dist/types/src/testing/test-services.d.ts +2 -2
- package/dist/types/src/testing/test-services.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +27 -16
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Assistant.d.ts +16 -5
- package/dist/types/src/types/Assistant.d.ts.map +1 -1
- package/dist/types/src/types/AssistantAction.d.ts +23 -6
- package/dist/types/src/types/AssistantAction.d.ts.map +1 -1
- package/dist/types/src/types/service.d.ts +21 -18
- package/dist/types/src/types/service.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +90 -96
- package/src/AssistantPlugin.tsx +138 -116
- package/src/capabilities/ai-service.ts +6 -7
- package/src/capabilities/app-graph-builder.ts +39 -45
- package/src/capabilities/blueprint-definition.ts +51 -19
- package/src/capabilities/capabilities.ts +8 -12
- package/src/capabilities/edge-model-resolver.ts +17 -21
- package/src/capabilities/index.ts +5 -2
- package/src/capabilities/intent-resolver.ts +38 -15
- package/src/capabilities/local-model-resolver.ts +30 -0
- package/src/capabilities/react-surface.tsx +9 -63
- package/src/capabilities/state.ts +20 -0
- package/src/capabilities/toolkit.ts +93 -31
- package/src/components/AssistantSettings/AssistantSettings.tsx +82 -75
- package/src/components/BlueprintContainer.tsx +2 -2
- package/src/components/Chat/Chat.tsx +167 -172
- package/src/components/Chat/events.ts +7 -0
- package/src/components/ChatCompanion.tsx +136 -0
- package/src/components/ChatContainer.tsx +13 -31
- package/src/components/ChatDialog.tsx +11 -11
- package/src/components/ChatProgress/ChatProgress.tsx +67 -0
- package/src/components/ChatProgress/index.ts +5 -0
- package/src/components/ChatPrompt/ChatActions.tsx +10 -24
- package/src/components/ChatPrompt/ChatOptions.tsx +200 -34
- package/src/components/ChatPrompt/ChatPresets.tsx +1 -0
- package/src/components/ChatPrompt/ChatReferences.tsx +29 -36
- package/src/components/ChatPrompt/ChatStatusIndicator.tsx +25 -22
- package/src/components/ChatThread/ChatThread.stories.tsx +74 -205
- package/src/components/ChatThread/ChatThread.tsx +69 -29
- package/src/components/ChatThread/Link.tsx +8 -21
- package/src/components/ChatThread/reducers.ts +151 -0
- package/src/components/ChatThread/registry.tsx +184 -0
- package/src/components/ChatThread/sync.test.ts +81 -0
- package/src/components/ChatThread/sync.ts +113 -0
- package/src/components/PromptSettings.tsx +1 -0
- package/src/components/SequenceContainer.tsx +27 -29
- package/src/components/SequenceEditor/SequenceEditor.stories.tsx +8 -6
- package/src/components/SequenceEditor/SequenceEditor.tsx +2 -2
- package/src/components/TemplateEditor/TemplateEditor.stories.tsx +17 -13
- package/src/components/TemplateEditor/TemplateEditor.tsx +16 -50
- package/src/components/TemplateEditor/TemplateForm.stories.tsx +6 -8
- package/src/components/TemplateEditor/TemplateForm.tsx +2 -1
- package/src/components/TemplateEditor/handlebars-extension.ts +165 -0
- package/src/components/ToolBlock/ToolBlock.tsx +152 -0
- package/src/components/ToolBlock/ToolBlockWidget.tsx +5 -0
- package/src/components/ToolBlock/index.ts +6 -0
- package/src/components/Toolbar/Toolbar.tsx +21 -0
- package/src/components/{Timeline → Toolbar}/index.ts +1 -1
- package/src/components/Toolbar/useChatToolbarActions.ts +126 -0
- package/src/components/Toolbox/Toolbox.stories.tsx +9 -12
- package/src/components/Toolbox/Toolbox.tsx +10 -16
- package/src/components/index.ts +3 -1
- package/src/functions/analysis.ts +6 -4
- package/src/functions/list.ts +9 -3
- package/src/functions/load.ts +8 -5
- package/src/hooks/index.ts +4 -5
- package/src/hooks/useBlueprintRegistry.ts +24 -9
- package/src/hooks/useChatProcessor.ts +19 -26
- package/src/hooks/useChatServices.ts +30 -53
- package/src/hooks/useContextBinder.ts +30 -0
- package/src/hooks/useContextObjects.ts +58 -0
- package/src/hooks/useItemTypes.ts +37 -0
- package/src/hooks/usePresets.ts +4 -5
- package/src/index.ts +2 -0
- package/src/meta.ts +4 -6
- package/src/processor/index.ts +6 -0
- package/src/{hooks → processor}/presets.ts +10 -3
- package/src/processor/processor.test.ts +81 -0
- package/src/processor/processor.ts +302 -0
- package/src/queue-logger.ts +5 -5
- package/src/testing/index.ts +1 -1
- package/src/testing/test-generator.ts +261 -0
- package/src/testing/test-sequence.ts +1 -26
- package/src/testing/test-services.ts +2 -8
- package/src/translations.ts +29 -17
- package/src/types/Assistant.ts +9 -4
- package/src/types/AssistantAction.ts +11 -3
- package/src/types/service.ts +15 -7
- package/src/vite-env.d.ts +30 -0
- package/dist/lib/browser/ChatContainer-OUVSX5V5.mjs.map +0 -7
- package/dist/lib/browser/ChatDialog-P4FLEOHG.mjs.map +0 -7
- package/dist/lib/browser/SequenceContainer-627OQ557.mjs.map +0 -7
- package/dist/lib/browser/ai-service-7KJ5LXBT.mjs +0 -22
- package/dist/lib/browser/ai-service-7KJ5LXBT.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-AVHHQ3KV.mjs.map +0 -7
- package/dist/lib/browser/blueprint-definition-CMGIZAOW.mjs.map +0 -7
- package/dist/lib/browser/chunk-BRLHDHOF.mjs +0 -244
- package/dist/lib/browser/chunk-BRLHDHOF.mjs.map +0 -7
- package/dist/lib/browser/chunk-HRLMD35M.mjs.map +0 -7
- package/dist/lib/browser/chunk-LKP65RPA.mjs +0 -20
- package/dist/lib/browser/chunk-LKP65RPA.mjs.map +0 -7
- package/dist/lib/browser/chunk-NZDCKQ6W.mjs +0 -89
- package/dist/lib/browser/chunk-NZDCKQ6W.mjs.map +0 -7
- package/dist/lib/browser/chunk-QB7OVS6Z.mjs +0 -16
- package/dist/lib/browser/chunk-QB7OVS6Z.mjs.map +0 -7
- package/dist/lib/browser/chunk-VEBVAHNM.mjs +0 -2231
- package/dist/lib/browser/chunk-VEBVAHNM.mjs.map +0 -7
- package/dist/lib/browser/edge-model-resolver-2HB4PCWH.mjs +0 -24
- package/dist/lib/browser/edge-model-resolver-2HB4PCWH.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-MVOIEJXZ.mjs.map +0 -7
- package/dist/lib/browser/react-surface-4HXS3YLT.mjs.map +0 -7
- package/dist/lib/browser/toolkit-IW4FBLLB.mjs +0 -105
- package/dist/lib/browser/toolkit-IW4FBLLB.mjs.map +0 -7
- package/dist/lib/node-esm/ChatContainer-D5FABDNE.mjs.map +0 -7
- package/dist/lib/node-esm/ChatDialog-NKWVXHJP.mjs.map +0 -7
- package/dist/lib/node-esm/SequenceContainer-EQ5NP2PG.mjs.map +0 -7
- package/dist/lib/node-esm/ai-service-LDD32477.mjs +0 -23
- package/dist/lib/node-esm/ai-service-LDD32477.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-RMOUJMMG.mjs.map +0 -7
- package/dist/lib/node-esm/blueprint-definition-AEWYMW6I.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-3SOC5GOP.mjs +0 -2232
- package/dist/lib/node-esm/chunk-3SOC5GOP.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-F7RXCX5Y.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GAWXJ7K5.mjs +0 -90
- package/dist/lib/node-esm/chunk-GAWXJ7K5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-KOC6ESG7.mjs +0 -22
- package/dist/lib/node-esm/chunk-KOC6ESG7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-RD755HN3.mjs +0 -245
- package/dist/lib/node-esm/chunk-RD755HN3.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-X6AANUHZ.mjs.map +0 -7
- package/dist/lib/node-esm/edge-model-resolver-UDDR2IA6.mjs +0 -25
- package/dist/lib/node-esm/edge-model-resolver-UDDR2IA6.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-DTDNCX3C.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-V6JNEZVO.mjs.map +0 -7
- package/dist/lib/node-esm/toolkit-2VNUL77B.mjs +0 -106
- package/dist/lib/node-esm/toolkit-2VNUL77B.mjs.map +0 -7
- package/dist/types/src/components/ChatThread/ChatMessage.d.ts +0 -18
- package/dist/types/src/components/ChatThread/ChatMessage.d.ts.map +0 -1
- package/dist/types/src/components/ChatThread/ToolBlock.d.ts +0 -19
- package/dist/types/src/components/ChatThread/ToolBlock.d.ts.map +0 -1
- package/dist/types/src/components/ChatThread/reducer.d.ts +0 -12
- package/dist/types/src/components/ChatThread/reducer.d.ts.map +0 -1
- package/dist/types/src/components/Timeline/Timeline.d.ts +0 -24
- package/dist/types/src/components/Timeline/Timeline.d.ts.map +0 -1
- package/dist/types/src/components/Timeline/Timeline.stories.d.ts +0 -9
- package/dist/types/src/components/Timeline/Timeline.stories.d.ts.map +0 -1
- package/dist/types/src/components/Timeline/index.d.ts +0 -2
- package/dist/types/src/components/Timeline/index.d.ts.map +0 -1
- package/dist/types/src/hooks/chat-processor.d.ts +0 -72
- package/dist/types/src/hooks/chat-processor.d.ts.map +0 -1
- package/dist/types/src/hooks/errors.d.ts +0 -4
- package/dist/types/src/hooks/errors.d.ts.map +0 -1
- package/dist/types/src/hooks/presets.d.ts.map +0 -1
- package/dist/types/src/hooks/useResolveRef.d.ts +0 -4
- package/dist/types/src/hooks/useResolveRef.d.ts.map +0 -1
- package/dist/types/src/parser/filter-generator.d.ts +0 -4
- package/dist/types/src/parser/filter-generator.d.ts.map +0 -1
- package/dist/types/src/parser/filter-generator.test.d.ts +0 -2
- package/dist/types/src/parser/filter-generator.test.d.ts.map +0 -1
- package/dist/types/src/parser/index.d.ts +0 -4
- package/dist/types/src/parser/index.d.ts.map +0 -1
- package/dist/types/src/parser/query-parser.d.ts +0 -15
- package/dist/types/src/parser/query-parser.d.ts.map +0 -1
- package/dist/types/src/parser/query-parser.test.d.ts +0 -2
- package/dist/types/src/parser/query-parser.test.d.ts.map +0 -1
- package/dist/types/src/parser/types.d.ts +0 -24
- package/dist/types/src/parser/types.d.ts.map +0 -1
- package/dist/types/src/stories/Chat.stories.d.ts +0 -268
- package/dist/types/src/stories/Chat.stories.d.ts.map +0 -1
- package/dist/types/src/stories/components/BlueprintContainer.d.ts +0 -5
- package/dist/types/src/stories/components/BlueprintContainer.d.ts.map +0 -1
- package/dist/types/src/stories/components/ChatContainer.d.ts +0 -5
- package/dist/types/src/stories/components/ChatContainer.d.ts.map +0 -1
- package/dist/types/src/stories/components/GraphContainer.d.ts +0 -6
- package/dist/types/src/stories/components/GraphContainer.d.ts.map +0 -1
- package/dist/types/src/stories/components/LoggingContainer.d.ts +0 -5
- package/dist/types/src/stories/components/LoggingContainer.d.ts.map +0 -1
- package/dist/types/src/stories/components/SurfaceContainer.d.ts +0 -8
- package/dist/types/src/stories/components/SurfaceContainer.d.ts.map +0 -1
- package/dist/types/src/stories/components/TasksContainer.d.ts +0 -5
- package/dist/types/src/stories/components/TasksContainer.d.ts.map +0 -1
- package/dist/types/src/stories/components/index.d.ts +0 -8
- package/dist/types/src/stories/components/index.d.ts.map +0 -1
- package/dist/types/src/stories/components/types.d.ts +0 -7
- package/dist/types/src/stories/components/types.d.ts.map +0 -1
- package/dist/types/src/stories/hooks/index.d.ts +0 -3
- package/dist/types/src/stories/hooks/index.d.ts.map +0 -1
- package/dist/types/src/stories/hooks/useFlush.d.ts.map +0 -1
- package/dist/types/src/stories/hooks/useMatcherExtension.d.ts +0 -3
- package/dist/types/src/stories/hooks/useMatcherExtension.d.ts.map +0 -1
- package/dist/types/src/stories/testing/data.d.ts +0 -142
- package/dist/types/src/stories/testing/data.d.ts.map +0 -1
- package/dist/types/src/stories/testing/index.d.ts +0 -3
- package/dist/types/src/stories/testing/index.d.ts.map +0 -1
- package/dist/types/src/stories/testing/testing.d.ts +0 -26
- package/dist/types/src/stories/testing/testing.d.ts.map +0 -1
- package/dist/types/src/testing/test-functions.d.ts +0 -6
- package/dist/types/src/testing/test-functions.d.ts.map +0 -1
- package/dist/types/src/tools/function.d.ts +0 -5
- package/dist/types/src/tools/function.d.ts.map +0 -1
- package/dist/types/src/tools/index.d.ts +0 -3
- package/dist/types/src/tools/index.d.ts.map +0 -1
- package/dist/types/src/tools/openapi.d.ts +0 -10
- package/dist/types/src/tools/openapi.d.ts.map +0 -1
- package/dist/types/src/tools/openapi.test.d.ts +0 -2
- package/dist/types/src/tools/openapi.test.d.ts.map +0 -1
- package/src/components/ChatThread/ChatMessage.tsx +0 -282
- package/src/components/ChatThread/ToolBlock.tsx +0 -125
- package/src/components/ChatThread/reducer.ts +0 -52
- package/src/components/Timeline/Timeline.stories.tsx +0 -53
- package/src/components/Timeline/Timeline.tsx +0 -159
- package/src/hooks/chat-processor.ts +0 -260
- package/src/hooks/errors.ts +0 -8
- package/src/hooks/useResolveRef.ts +0 -33
- package/src/parser/filter-generator.test.ts +0 -32
- package/src/parser/filter-generator.ts +0 -74
- package/src/parser/index.ts +0 -7
- package/src/parser/query-parser.test.ts +0 -139
- package/src/parser/query-parser.ts +0 -199
- package/src/parser/types.ts +0 -34
- package/src/shims.d.ts +0 -8
- package/src/stories/Chat.stories.tsx +0 -317
- package/src/stories/components/BlueprintContainer.tsx +0 -34
- package/src/stories/components/ChatContainer.tsx +0 -80
- package/src/stories/components/GraphContainer.tsx +0 -118
- package/src/stories/components/LoggingContainer.tsx +0 -22
- package/src/stories/components/SurfaceContainer.tsx +0 -62
- package/src/stories/components/TasksContainer.tsx +0 -51
- package/src/stories/components/index.ts +0 -12
- package/src/stories/components/types.ts +0 -11
- package/src/stories/hooks/index.ts +0 -6
- package/src/stories/hooks/useMatcherExtension.ts +0 -45
- package/src/stories/testing/data.ts +0 -130
- package/src/stories/testing/index.ts +0 -6
- package/src/stories/testing/testing.tsx +0 -162
- package/src/testing/test-functions.ts +0 -16
- package/src/tools/function.ts +0 -49
- package/src/tools/index.ts +0 -6
- package/src/tools/openapi.test.ts +0 -219
- package/src/tools/openapi.ts +0 -341
- package/src/typings.d.ts +0 -9
- /package/dist/types/src/{stories/hooks → hooks}/useFlush.d.ts +0 -0
- /package/src/{stories/hooks → hooks}/useFlush.ts +0 -0
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
ChatContainer
|
|
4
|
+
} from "./chunk-E2WXZND7.mjs";
|
|
5
|
+
import "./chunk-DSE2IILK.mjs";
|
|
6
|
+
import "./chunk-HXIBCBH4.mjs";
|
|
7
|
+
import {
|
|
8
|
+
useBlueprintRegistry,
|
|
9
|
+
useContextBinder
|
|
10
|
+
} from "./chunk-UFKLCEAE.mjs";
|
|
11
|
+
import {
|
|
12
|
+
AssistantAction_exports,
|
|
13
|
+
Assistant_exports
|
|
14
|
+
} from "./chunk-TNR46C3L.mjs";
|
|
15
|
+
import "./chunk-73ABYRYX.mjs";
|
|
16
|
+
import "./chunk-HSLMI22Q.mjs";
|
|
17
|
+
|
|
18
|
+
// src/components/ChatCompanion.tsx
|
|
19
|
+
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
20
|
+
import * as Array from "effect/Array";
|
|
21
|
+
import * as Effect from "effect/Effect";
|
|
22
|
+
import * as Function from "effect/Function";
|
|
23
|
+
import * as Option from "effect/Option";
|
|
24
|
+
import React, { useMemo } from "react";
|
|
25
|
+
import { Capabilities, createIntent, useCapabilities, useIntentDispatcher } from "@dxos/app-framework";
|
|
26
|
+
import { Blueprint } from "@dxos/blueprints";
|
|
27
|
+
import { getSpace } from "@dxos/client/echo";
|
|
28
|
+
import { Filter, Obj, Query, Ref } from "@dxos/echo";
|
|
29
|
+
import { DatabaseService } from "@dxos/functions";
|
|
30
|
+
import { SpaceAction } from "@dxos/plugin-space/types";
|
|
31
|
+
import { useQuery } from "@dxos/react-client/echo";
|
|
32
|
+
import { useAsyncEffect } from "@dxos/react-ui";
|
|
33
|
+
var ChatCompanion = ({ role, data }) => {
|
|
34
|
+
var _effect = _useSignals();
|
|
35
|
+
try {
|
|
36
|
+
const companionTo = data.companionTo;
|
|
37
|
+
const space = getSpace(companionTo);
|
|
38
|
+
const chat = data.subject === "assistant-chat" ? void 0 : data.subject;
|
|
39
|
+
const blueprintRegistry = useBlueprintRegistry();
|
|
40
|
+
const binder = useContextBinder(chat);
|
|
41
|
+
const { dispatch } = useIntentDispatcher();
|
|
42
|
+
useAsyncEffect(async () => {
|
|
43
|
+
if (chat || !space) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
await Effect.gen(function* () {
|
|
47
|
+
const { objects } = yield* DatabaseService.runQuery(Query.select(Filter.ids(companionTo.id)).targetOf(Assistant_exports.CompanionTo).source());
|
|
48
|
+
let nextChat = objects.toSorted((a, b) => a.id.localeCompare(b.id)).at(-1);
|
|
49
|
+
if (!nextChat) {
|
|
50
|
+
const { object } = yield* dispatch(createIntent(AssistantAction_exports.CreateChat, {
|
|
51
|
+
space
|
|
52
|
+
}));
|
|
53
|
+
nextChat = object;
|
|
54
|
+
yield* dispatch(createIntent(SpaceAction.AddObject, {
|
|
55
|
+
object: nextChat,
|
|
56
|
+
target: space,
|
|
57
|
+
hidden: true
|
|
58
|
+
}));
|
|
59
|
+
yield* dispatch(createIntent(SpaceAction.AddRelation, {
|
|
60
|
+
space,
|
|
61
|
+
schema: Assistant_exports.CompanionTo,
|
|
62
|
+
source: nextChat,
|
|
63
|
+
target: data.companionTo
|
|
64
|
+
}));
|
|
65
|
+
}
|
|
66
|
+
yield* dispatch(createIntent(AssistantAction_exports.SetCurrentChat, {
|
|
67
|
+
companionTo,
|
|
68
|
+
chat: nextChat
|
|
69
|
+
}));
|
|
70
|
+
}).pipe(Effect.provide(DatabaseService.layer(space.db)), Effect.runPromise);
|
|
71
|
+
}, [
|
|
72
|
+
space,
|
|
73
|
+
chat,
|
|
74
|
+
companionTo
|
|
75
|
+
]);
|
|
76
|
+
const metadata = useCapabilities(Capabilities.Metadata);
|
|
77
|
+
const blueprintKeys = useMemo(() => Function.pipe(metadata, Array.findFirst((capability) => capability.id === Obj.getTypename(companionTo)), Option.flatMap((c) => Option.fromNullable(c.metadata.blueprints)), Option.getOrElse(() => [])), [
|
|
78
|
+
metadata,
|
|
79
|
+
companionTo
|
|
80
|
+
]);
|
|
81
|
+
const existingBlueprints = useQuery(space, Filter.type(Blueprint.Blueprint));
|
|
82
|
+
const pluginBlueprints = useMemo(() => existingBlueprints.filter((blueprint) => blueprintKeys.includes(blueprint.key)), [
|
|
83
|
+
existingBlueprints,
|
|
84
|
+
blueprintKeys
|
|
85
|
+
]);
|
|
86
|
+
useAsyncEffect(async () => {
|
|
87
|
+
if (!space) {
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
const { objects: existingBlueprints2 } = await space.db.query(Filter.type(Blueprint.Blueprint)).run();
|
|
91
|
+
for (const key of blueprintKeys) {
|
|
92
|
+
const existingBlueprint = existingBlueprints2.find((blueprint2) => blueprint2.key === key);
|
|
93
|
+
if (existingBlueprint) {
|
|
94
|
+
continue;
|
|
95
|
+
}
|
|
96
|
+
const blueprint = blueprintRegistry.getByKey(key);
|
|
97
|
+
if (!blueprint) {
|
|
98
|
+
continue;
|
|
99
|
+
}
|
|
100
|
+
space.db.add(Obj.clone(blueprint));
|
|
101
|
+
}
|
|
102
|
+
}, [
|
|
103
|
+
space,
|
|
104
|
+
blueprintRegistry,
|
|
105
|
+
blueprintKeys
|
|
106
|
+
]);
|
|
107
|
+
useAsyncEffect(async () => {
|
|
108
|
+
if (!binder) {
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
if (pluginBlueprints.length > 0) {
|
|
112
|
+
await binder.bind({
|
|
113
|
+
blueprints: pluginBlueprints.map((blueprint) => Ref.make(blueprint))
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
if (Obj.instanceOf(Blueprint.Blueprint, companionTo)) {
|
|
117
|
+
await binder.bind({
|
|
118
|
+
blueprints: [
|
|
119
|
+
Ref.make(companionTo)
|
|
120
|
+
]
|
|
121
|
+
});
|
|
122
|
+
} else {
|
|
123
|
+
await binder.bind({
|
|
124
|
+
objects: [
|
|
125
|
+
Ref.make(companionTo)
|
|
126
|
+
]
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}, [
|
|
130
|
+
binder,
|
|
131
|
+
companionTo,
|
|
132
|
+
pluginBlueprints
|
|
133
|
+
]);
|
|
134
|
+
if (!chat) {
|
|
135
|
+
return null;
|
|
136
|
+
}
|
|
137
|
+
return /* @__PURE__ */ React.createElement(ChatContainer, {
|
|
138
|
+
role,
|
|
139
|
+
chat,
|
|
140
|
+
companionTo
|
|
141
|
+
});
|
|
142
|
+
} finally {
|
|
143
|
+
_effect.f();
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
var ChatCompanion_default = ChatCompanion;
|
|
147
|
+
export {
|
|
148
|
+
ChatCompanion,
|
|
149
|
+
ChatCompanion_default as default
|
|
150
|
+
};
|
|
151
|
+
//# sourceMappingURL=ChatCompanion-XFNXVZIP.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/ChatCompanion.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Array from 'effect/Array';\nimport * as Effect from 'effect/Effect';\nimport * as Function from 'effect/Function';\nimport * as Option from 'effect/Option';\nimport React, { useMemo } from 'react';\n\nimport { Capabilities, createIntent, useCapabilities, useIntentDispatcher } from '@dxos/app-framework';\nimport { Blueprint } from '@dxos/blueprints';\nimport { getSpace } from '@dxos/client/echo';\nimport { Filter, Obj, Query, Ref } from '@dxos/echo';\nimport { DatabaseService } from '@dxos/functions';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { useQuery } from '@dxos/react-client/echo';\nimport { useAsyncEffect } from '@dxos/react-ui';\n\nimport { ChatContainer } from '../components';\nimport { useBlueprintRegistry, useContextBinder } from '../hooks';\nimport { Assistant, AssistantAction } from '../types';\n\nexport type ChatCompanionProps = {\n role?: string;\n data: { companionTo: Obj.Any; subject: Assistant.Chat | 'assistant-chat' };\n};\n\nexport const ChatCompanion = ({ role, data }: ChatCompanionProps) => {\n const companionTo = data.companionTo;\n const space = getSpace(companionTo);\n const chat = data.subject === 'assistant-chat' ? undefined : data.subject;\n const blueprintRegistry = useBlueprintRegistry();\n const binder = useContextBinder(chat);\n const { dispatch } = useIntentDispatcher();\n\n // Initialize companion chat if it doesn't exist.\n useAsyncEffect(async () => {\n if (chat || !space) {\n return;\n }\n\n // TODO(burdon): Garbage collection of queues?\n // TODO(wittjosiah): Figure out how to prevent companion chats from showing up in the navtree.\n await Effect.gen(function* () {\n const { objects } = yield* DatabaseService.runQuery(\n Query.select(Filter.ids(companionTo.id)).targetOf(Assistant.CompanionTo).source(),\n );\n\n // TODO(wittjosiah): This should be the default sort order.\n let nextChat = objects.toSorted((a, b) => a.id.localeCompare(b.id)).at(-1);\n if (!nextChat) {\n const { object } = yield* dispatch(createIntent(AssistantAction.CreateChat, { space }));\n nextChat = object;\n yield* dispatch(createIntent(SpaceAction.AddObject, { object: nextChat, target: space, hidden: true }));\n yield* dispatch(\n createIntent(SpaceAction.AddRelation, {\n space,\n schema: Assistant.CompanionTo,\n source: nextChat,\n target: data.companionTo,\n }),\n );\n }\n\n yield* dispatch(createIntent(AssistantAction.SetCurrentChat, { companionTo, chat: nextChat }));\n }).pipe(Effect.provide(DatabaseService.layer(space.db)), Effect.runPromise);\n }, [space, chat, companionTo]);\n\n const metadata = useCapabilities(Capabilities.Metadata);\n const blueprintKeys = useMemo(\n () =>\n Function.pipe(\n metadata,\n Array.findFirst(\n (capability): capability is { id: string; metadata: { blueprints?: string[] } } =>\n capability.id === Obj.getTypename(companionTo),\n ),\n Option.flatMap((c) => Option.fromNullable(c.metadata.blueprints)),\n Option.getOrElse(() => [] as string[]),\n ),\n [metadata, companionTo],\n );\n const existingBlueprints = useQuery(space, Filter.type(Blueprint.Blueprint));\n const pluginBlueprints = useMemo(\n () => existingBlueprints.filter((blueprint) => blueprintKeys.includes(blueprint.key)),\n [existingBlueprints, blueprintKeys],\n );\n\n // Initialize related blueprints that are not already in the space.\n useAsyncEffect(async () => {\n if (!space) {\n return;\n }\n\n // NOTE: This must be run instead of using the useQuery result to avoid duplicates.\n const { objects: existingBlueprints } = await space.db.query(Filter.type(Blueprint.Blueprint)).run();\n for (const key of blueprintKeys) {\n const existingBlueprint = existingBlueprints.find((blueprint) => blueprint.key === key);\n if (existingBlueprint) {\n continue;\n }\n\n const blueprint = blueprintRegistry.getByKey(key);\n if (!blueprint) {\n continue;\n }\n\n space.db.add(Obj.clone(blueprint));\n }\n }, [space, blueprintRegistry, blueprintKeys]);\n\n useAsyncEffect(async () => {\n if (!binder) {\n return;\n }\n\n if (pluginBlueprints.length > 0) {\n await binder.bind({ blueprints: pluginBlueprints.map((blueprint) => Ref.make(blueprint)) });\n }\n\n if (Obj.instanceOf(Blueprint.Blueprint, companionTo)) {\n await binder.bind({ blueprints: [Ref.make(companionTo)] });\n } else {\n await binder.bind({ objects: [Ref.make(companionTo)] });\n }\n }, [binder, companionTo, pluginBlueprints]);\n\n if (!chat) {\n return null;\n }\n\n return <ChatContainer role={role} chat={chat} companionTo={companionTo} />;\n};\n\nexport default ChatCompanion;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Array", "Effect", "Function", "Option", "React", "useMemo", "Capabilities", "createIntent", "useCapabilities", "useIntentDispatcher", "Blueprint", "getSpace", "Filter", "Obj", "Query", "Ref", "DatabaseService", "SpaceAction", "useQuery", "useAsyncEffect", "ChatCompanion", "role", "data", "companionTo", "space", "getSpace", "chat", "subject", "undefined", "blueprintRegistry", "useBlueprintRegistry", "binder", "useContextBinder", "dispatch", "useIntentDispatcher", "useAsyncEffect", "gen", "objects", "DatabaseService", "runQuery", "Query", "select", "Filter", "ids", "id", "targetOf", "Assistant", "CompanionTo", "source", "nextChat", "toSorted", "a", "b", "localeCompare", "at", "object", "createIntent", "AssistantAction", "CreateChat", "SpaceAction", "AddObject", "target", "hidden", "AddRelation", "schema", "SetCurrentChat", "pipe", "provide", "layer", "db", "runPromise", "metadata", "useCapabilities", "Capabilities", "Metadata", "blueprintKeys", "useMemo", "findFirst", "capability", "Obj", "getTypename", "flatMap", "c", "fromNullable", "blueprints", "getOrElse", "existingBlueprints", "useQuery", "type", "Blueprint", "pluginBlueprints", "filter", "blueprint", "includes", "key", "query", "run", "existingBlueprint", "find", "getByKey", "add", "clone", "length", "bind", "map", "Ref", "make", "instanceOf", "ChatContainer"]
|
|
7
|
+
}
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
Toolbar
|
|
4
|
+
} from "./chunk-HXIBCBH4.mjs";
|
|
2
5
|
import {
|
|
3
6
|
Chat,
|
|
4
7
|
useBlueprintRegistry,
|
|
@@ -6,64 +9,58 @@ import {
|
|
|
6
9
|
useChatServices,
|
|
7
10
|
useOnline,
|
|
8
11
|
usePresets
|
|
9
|
-
} from "./chunk-
|
|
10
|
-
import "./chunk-
|
|
11
|
-
import "./chunk-F7RXCX5Y.mjs";
|
|
12
|
+
} from "./chunk-UFKLCEAE.mjs";
|
|
13
|
+
import "./chunk-TNR46C3L.mjs";
|
|
12
14
|
import {
|
|
13
15
|
meta
|
|
14
|
-
} from "./chunk-
|
|
16
|
+
} from "./chunk-73ABYRYX.mjs";
|
|
15
17
|
import "./chunk-HSLMI22Q.mjs";
|
|
16
18
|
|
|
17
19
|
// src/components/ChatContainer.tsx
|
|
18
20
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
19
|
-
import React
|
|
21
|
+
import React from "react";
|
|
20
22
|
import { Capabilities, useCapability } from "@dxos/app-framework";
|
|
21
23
|
import { getSpace } from "@dxos/client/echo";
|
|
22
24
|
import { StackItem } from "@dxos/react-ui-stack";
|
|
23
|
-
var ChatContainer = ({ chat,
|
|
25
|
+
var ChatContainer = ({ chat, companionTo }) => {
|
|
24
26
|
var _effect = _useSignals();
|
|
25
27
|
try {
|
|
26
28
|
const space = getSpace(chat);
|
|
27
29
|
const settings = useCapability(Capabilities.SettingsStore).getStore(meta.id)?.value;
|
|
28
30
|
const services = useChatServices({
|
|
29
|
-
space
|
|
31
|
+
space,
|
|
32
|
+
chat
|
|
30
33
|
});
|
|
31
34
|
const [online, setOnline] = useOnline();
|
|
32
35
|
const { preset, ...chatProps } = usePresets(online);
|
|
33
36
|
const blueprintRegistry = useBlueprintRegistry();
|
|
34
37
|
const processor = useChatProcessor({
|
|
35
|
-
space,
|
|
36
38
|
chat,
|
|
37
39
|
preset,
|
|
38
40
|
services,
|
|
39
41
|
blueprintRegistry,
|
|
40
42
|
settings
|
|
41
43
|
});
|
|
42
|
-
|
|
43
|
-
if (processor && onProcessorReady) {
|
|
44
|
-
const timeout = setTimeout(() => onProcessorReady(processor));
|
|
45
|
-
return () => clearTimeout(timeout);
|
|
46
|
-
}
|
|
47
|
-
}, [
|
|
48
|
-
processor,
|
|
49
|
-
onProcessorReady
|
|
50
|
-
]);
|
|
51
|
-
if (!chat || !processor) {
|
|
44
|
+
if (!processor) {
|
|
52
45
|
return null;
|
|
53
46
|
}
|
|
54
47
|
return /* @__PURE__ */ React.createElement(StackItem.Content, {
|
|
55
|
-
|
|
56
|
-
}, /* @__PURE__ */ React.createElement(
|
|
48
|
+
toolbar: !!companionTo
|
|
49
|
+
}, !!companionTo && /* @__PURE__ */ React.createElement(Toolbar, {
|
|
50
|
+
chat,
|
|
51
|
+
companionTo
|
|
52
|
+
}), /* @__PURE__ */ React.createElement(Chat.Root, {
|
|
53
|
+
classNames: "container-max-width",
|
|
57
54
|
chat,
|
|
58
55
|
processor
|
|
59
56
|
}, /* @__PURE__ */ React.createElement(Chat.Thread, null), /* @__PURE__ */ React.createElement("div", {
|
|
60
57
|
className: "p-2"
|
|
61
58
|
}, /* @__PURE__ */ React.createElement(Chat.Prompt, {
|
|
62
59
|
...chatProps,
|
|
63
|
-
|
|
60
|
+
outline: true,
|
|
64
61
|
preset: preset?.id,
|
|
65
62
|
online,
|
|
66
|
-
|
|
63
|
+
onOnlineChange: setOnline
|
|
67
64
|
}))));
|
|
68
65
|
} finally {
|
|
69
66
|
_effect.f();
|
|
@@ -74,4 +71,4 @@ export {
|
|
|
74
71
|
ChatContainer,
|
|
75
72
|
ChatContainer_default as default
|
|
76
73
|
};
|
|
77
|
-
//# sourceMappingURL=ChatContainer-
|
|
74
|
+
//# sourceMappingURL=ChatContainer-UTJGCQXF.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/ChatContainer.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, useCapability } from '@dxos/app-framework';\nimport { getSpace } from '@dxos/client/echo';\nimport { type Obj } from '@dxos/echo';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { useBlueprintRegistry, useChatProcessor, useChatServices, useOnline, usePresets } from '../hooks';\nimport { meta } from '../meta';\nimport { type Assistant } from '../types';\n\nimport { Chat } from './Chat';\nimport { Toolbar } from './Toolbar';\n\nexport type ChatContainerProps = {\n chat: Assistant.Chat;\n companionTo?: Obj.Any;\n role?: string;\n};\n\nexport const ChatContainer = ({ chat, companionTo }: ChatContainerProps) => {\n const space = getSpace(chat);\n const settings = useCapability(Capabilities.SettingsStore).getStore<Assistant.Settings>(meta.id)?.value;\n const services = useChatServices({ space, chat });\n const [online, setOnline] = useOnline();\n const { preset, ...chatProps } = usePresets(online);\n const blueprintRegistry = useBlueprintRegistry();\n const processor = useChatProcessor({ chat, preset, services, blueprintRegistry, settings });\n\n if (!processor) {\n return null;\n }\n\n return (\n <StackItem.Content toolbar={!!companionTo}>\n {!!companionTo && <Toolbar chat={chat} companionTo={companionTo} />}\n <Chat.Root classNames='container-max-width' chat={chat} processor={processor}>\n <Chat.Thread />\n <div className='p-2'>\n <Chat.Prompt {...chatProps} outline preset={preset?.id} online={online} onOnlineChange={setOnline} />\n </div>\n </Chat.Root>\n </StackItem.Content>\n );\n};\n\nexport default ChatContainer;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,cAAcC,qBAAqB;AAC5C,SAASC,gBAAgB;AAEzB,SAASC,iBAAiB;AAenB,IAAMC,gBAAgB,CAAC,EAAEC,MAAMC,YAAW,MAAsB;;;AACrE,UAAMC,QAAQC,SAASH,IAAAA;AACvB,UAAMI,WAAWC,cAAcC,aAAaC,aAAa,EAAEC,SAA6BC,KAAKC,EAAE,GAAGC;AAClG,UAAMC,WAAWC,gBAAgB;MAAEX;MAAOF;IAAK,CAAA;AAC/C,UAAM,CAACc,QAAQC,SAAAA,IAAaC,UAAAA;AAC5B,UAAM,EAAEC,QAAQ,GAAGC,UAAAA,IAAcC,WAAWL,MAAAA;AAC5C,UAAMM,oBAAoBC,qBAAAA;AAC1B,UAAMC,YAAYC,iBAAiB;MAAEvB;MAAMiB;MAAQL;MAAUQ;MAAmBhB;IAAS,CAAA;AAEzF,QAAI,CAACkB,WAAW;AACd,aAAO;IACT;AAEA,WACE,sBAAA,cAACE,UAAUC,SAAO;MAACC,SAAS,CAAC,CAACzB;OAC3B,CAAC,CAACA,eAAe,sBAAA,cAAC0B,SAAAA;MAAQ3B;MAAYC;QACvC,sBAAA,cAAC2B,KAAKC,MAAI;MAACC,YAAW;MAAsB9B;MAAYsB;OACtD,sBAAA,cAACM,KAAKG,QAAM,IAAA,GACZ,sBAAA,cAACC,OAAAA;MAAIC,WAAU;OACb,sBAAA,cAACL,KAAKM,QAAM;MAAE,GAAGhB;MAAWiB,SAAAA;MAAQlB,QAAQA,QAAQP;MAAII;MAAgBsB,gBAAgBrB;;;;;AAKlG;AAEA,IAAA,wBAAehB;",
|
|
6
|
+
"names": ["React", "Capabilities", "useCapability", "getSpace", "StackItem", "ChatContainer", "chat", "companionTo", "space", "getSpace", "settings", "useCapability", "Capabilities", "SettingsStore", "getStore", "meta", "id", "value", "services", "useChatServices", "online", "setOnline", "useOnline", "preset", "chatProps", "usePresets", "blueprintRegistry", "useBlueprintRegistry", "processor", "useChatProcessor", "StackItem", "Content", "toolbar", "Toolbar", "Chat", "Root", "classNames", "Thread", "div", "className", "Prompt", "outline", "onOnlineChange"]
|
|
7
|
+
}
|
|
@@ -6,12 +6,10 @@ import {
|
|
|
6
6
|
useChatServices,
|
|
7
7
|
useOnline,
|
|
8
8
|
usePresets
|
|
9
|
-
} from "./chunk-
|
|
10
|
-
import "./chunk-X6AANUHZ.mjs";
|
|
11
|
-
import "./chunk-F7RXCX5Y.mjs";
|
|
9
|
+
} from "./chunk-UFKLCEAE.mjs";
|
|
12
10
|
import {
|
|
13
11
|
meta
|
|
14
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-73ABYRYX.mjs";
|
|
15
13
|
import "./chunk-HSLMI22Q.mjs";
|
|
16
14
|
|
|
17
15
|
// src/components/ChatDialog.tsx
|
|
@@ -20,7 +18,7 @@ import React, { useCallback, useState } from "react";
|
|
|
20
18
|
import { Capabilities, useCapability } from "@dxos/app-framework";
|
|
21
19
|
import { getSpace } from "@dxos/client/echo";
|
|
22
20
|
import { useTranslation } from "@dxos/react-ui";
|
|
23
|
-
import { ChatDialog as
|
|
21
|
+
import { ChatDialog as NaturalChatDialog } from "@dxos/react-ui-chat";
|
|
24
22
|
var ChatDialog = ({ chat }) => {
|
|
25
23
|
var _effect = _useSignals();
|
|
26
24
|
try {
|
|
@@ -28,13 +26,13 @@ var ChatDialog = ({ chat }) => {
|
|
|
28
26
|
const space = getSpace(chat);
|
|
29
27
|
const settings = useCapability(Capabilities.SettingsStore).getStore(meta.id)?.value;
|
|
30
28
|
const services = useChatServices({
|
|
31
|
-
space
|
|
29
|
+
space,
|
|
30
|
+
chat
|
|
32
31
|
});
|
|
33
32
|
const [online, setOnline] = useOnline();
|
|
34
33
|
const { preset, ...chatProps } = usePresets(online);
|
|
35
34
|
const blueprintRegistry = useBlueprintRegistry();
|
|
36
35
|
const processor = useChatProcessor({
|
|
37
|
-
space,
|
|
38
36
|
chat,
|
|
39
37
|
preset,
|
|
40
38
|
services,
|
|
@@ -62,17 +60,19 @@ var ChatDialog = ({ chat }) => {
|
|
|
62
60
|
chat,
|
|
63
61
|
processor,
|
|
64
62
|
onEvent: handleEvent
|
|
65
|
-
}, /* @__PURE__ */ React.createElement(
|
|
63
|
+
}, /* @__PURE__ */ React.createElement(NaturalChatDialog.Root, {
|
|
66
64
|
open,
|
|
67
65
|
expanded,
|
|
68
66
|
onOpenChange: setOpen
|
|
69
|
-
}, /* @__PURE__ */ React.createElement(
|
|
67
|
+
}, /* @__PURE__ */ React.createElement(NaturalChatDialog.Header, {
|
|
70
68
|
title: t("assistant dialog title")
|
|
71
|
-
}), /* @__PURE__ */ React.createElement(
|
|
69
|
+
}), /* @__PURE__ */ React.createElement(NaturalChatDialog.Content, null, /* @__PURE__ */ React.createElement(Chat.Thread, null)), /* @__PURE__ */ React.createElement(NaturalChatDialog.Footer, {
|
|
70
|
+
classNames: "p-1.5"
|
|
71
|
+
}, /* @__PURE__ */ React.createElement(Chat.Prompt, {
|
|
72
72
|
...chatProps,
|
|
73
73
|
preset: preset?.id,
|
|
74
74
|
online,
|
|
75
|
-
|
|
75
|
+
onOnlineChange: setOnline,
|
|
76
76
|
expandable: true
|
|
77
77
|
}))));
|
|
78
78
|
} finally {
|
|
@@ -84,4 +84,4 @@ export {
|
|
|
84
84
|
ChatDialog,
|
|
85
85
|
ChatDialog_default as default
|
|
86
86
|
};
|
|
87
|
-
//# sourceMappingURL=ChatDialog-
|
|
87
|
+
//# sourceMappingURL=ChatDialog-QEYZ4IOV.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/ChatDialog.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useState } from 'react';\n\nimport { Capabilities, useCapability } from '@dxos/app-framework';\nimport { getSpace } from '@dxos/client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { ChatDialog as NaturalChatDialog } from '@dxos/react-ui-chat';\n\nimport { useBlueprintRegistry, useChatProcessor, useChatServices, useOnline, usePresets } from '../hooks';\nimport { meta } from '../meta';\nimport { type Assistant } from '../types';\n\nimport { Chat, type ChatRootProps } from './Chat';\n\nexport type ChatDialogProps = {\n chat?: Assistant.Chat;\n};\n\nexport const ChatDialog = ({ chat }: ChatDialogProps) => {\n const { t } = useTranslation(meta.id);\n\n const space = getSpace(chat);\n const settings = useCapability(Capabilities.SettingsStore).getStore<Assistant.Settings>(meta.id)?.value;\n const services = useChatServices({ space, chat });\n const [online, setOnline] = useOnline();\n const { preset, ...chatProps } = usePresets(online);\n const blueprintRegistry = useBlueprintRegistry();\n const processor = useChatProcessor({ chat, preset, services, blueprintRegistry, settings });\n\n // TODO(burdon): Refocus when open.\n const [open, setOpen] = useState(true);\n const [expanded, setExpanded] = useState(false);\n const handleEvent = useCallback<NonNullable<ChatRootProps['onEvent']>>((event) => {\n switch (event.type) {\n case 'submit':\n case 'thread-open':\n setOpen(true);\n setExpanded(true);\n break;\n case 'thread-close':\n setOpen(false);\n break;\n }\n }, []);\n\n if (!chat || !processor) {\n return null;\n }\n\n return (\n <Chat.Root chat={chat} processor={processor} onEvent={handleEvent}>\n <NaturalChatDialog.Root open={open} expanded={expanded} onOpenChange={setOpen}>\n <NaturalChatDialog.Header title={t('assistant dialog title')} />\n <NaturalChatDialog.Content>\n <Chat.Thread />\n </NaturalChatDialog.Content>\n <NaturalChatDialog.Footer classNames='p-1.5'>\n <Chat.Prompt {...chatProps} preset={preset?.id} online={online} onOnlineChange={setOnline} expandable />\n </NaturalChatDialog.Footer>\n </NaturalChatDialog.Root>\n </Chat.Root>\n );\n};\n\nexport default ChatDialog;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;AAIA,OAAOA,SAASC,aAAaC,gBAAgB;AAE7C,SAASC,cAAcC,qBAAqB;AAC5C,SAASC,gBAAgB;AACzB,SAASC,sBAAsB;AAC/B,SAASC,cAAcC,yBAAyB;AAYzC,IAAMC,aAAa,CAAC,EAAEC,KAAI,MAAmB;;;AAClD,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AAEpC,UAAMC,QAAQC,SAASN,IAAAA;AACvB,UAAMO,WAAWC,cAAcC,aAAaC,aAAa,EAAEC,SAA6BR,KAAKC,EAAE,GAAGQ;AAClG,UAAMC,WAAWC,gBAAgB;MAAET;MAAOL;IAAK,CAAA;AAC/C,UAAM,CAACe,QAAQC,SAAAA,IAAaC,UAAAA;AAC5B,UAAM,EAAEC,QAAQ,GAAGC,UAAAA,IAAcC,WAAWL,MAAAA;AAC5C,UAAMM,oBAAoBC,qBAAAA;AAC1B,UAAMC,YAAYC,iBAAiB;MAAExB;MAAMkB;MAAQL;MAAUQ;MAAmBd;IAAS,CAAA;AAGzF,UAAM,CAACkB,MAAMC,OAAAA,IAAWC,SAAS,IAAA;AACjC,UAAM,CAACC,UAAUC,WAAAA,IAAeF,SAAS,KAAA;AACzC,UAAMG,cAAcC,YAAmD,CAACC,UAAAA;AACtE,cAAQA,MAAMC,MAAI;QAChB,KAAK;QACL,KAAK;AACHP,kBAAQ,IAAA;AACRG,sBAAY,IAAA;AACZ;QACF,KAAK;AACHH,kBAAQ,KAAA;AACR;MACJ;IACF,GAAG,CAAA,CAAE;AAEL,QAAI,CAAC1B,QAAQ,CAACuB,WAAW;AACvB,aAAO;IACT;AAEA,WACE,sBAAA,cAACW,KAAKC,MAAI;MAACnC;MAAYuB;MAAsBa,SAASN;OACpD,sBAAA,cAACO,kBAAkBF,MAAI;MAACV;MAAYG;MAAoBU,cAAcZ;OACpE,sBAAA,cAACW,kBAAkBE,QAAM;MAACC,OAAOvC,EAAE,wBAAA;QACnC,sBAAA,cAACoC,kBAAkBI,SAAO,MACxB,sBAAA,cAACP,KAAKQ,QAAM,IAAA,CAAA,GAEd,sBAAA,cAACL,kBAAkBM,QAAM;MAACC,YAAW;OACnC,sBAAA,cAACV,KAAKW,QAAM;MAAE,GAAG1B;MAAWD,QAAQA,QAAQd;MAAIW;MAAgB+B,gBAAgB9B;MAAW+B,YAAAA;;;;;AAKrG;AAEA,IAAA,qBAAehD;",
|
|
6
|
+
"names": ["React", "useCallback", "useState", "Capabilities", "useCapability", "getSpace", "useTranslation", "ChatDialog", "NaturalChatDialog", "ChatDialog", "chat", "t", "useTranslation", "meta", "id", "space", "getSpace", "settings", "useCapability", "Capabilities", "SettingsStore", "getStore", "value", "services", "useChatServices", "online", "setOnline", "useOnline", "preset", "chatProps", "usePresets", "blueprintRegistry", "useBlueprintRegistry", "processor", "useChatProcessor", "open", "setOpen", "useState", "expanded", "setExpanded", "handleEvent", "useCallback", "event", "type", "Chat", "Root", "onEvent", "NaturalChatDialog", "onOpenChange", "Header", "title", "Content", "Thread", "Footer", "classNames", "Prompt", "onOnlineChange", "expandable"]
|
|
7
|
+
}
|
|
@@ -1,15 +1,13 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
meta
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-73ABYRYX.mjs";
|
|
5
5
|
import "./chunk-HSLMI22Q.mjs";
|
|
6
6
|
|
|
7
7
|
// src/components/SequenceContainer.tsx
|
|
8
8
|
import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
|
|
9
9
|
import JSON5 from "json5";
|
|
10
|
-
import React2, { useCallback, useEffect,
|
|
11
|
-
import { ToolRegistry } from "@dxos/ai";
|
|
12
|
-
import { getSpace } from "@dxos/client/echo";
|
|
10
|
+
import React2, { useCallback, useEffect, useRef, useState } from "react";
|
|
13
11
|
import { Key } from "@dxos/echo";
|
|
14
12
|
import { Toolbar, useTranslation } from "@dxos/react-ui";
|
|
15
13
|
import { useSelectionManager } from "@dxos/react-ui-attention";
|
|
@@ -68,7 +66,7 @@ var parseSequence = (text) => {
|
|
|
68
66
|
return {
|
|
69
67
|
steps
|
|
70
68
|
};
|
|
71
|
-
} catch
|
|
69
|
+
} catch {
|
|
72
70
|
}
|
|
73
71
|
};
|
|
74
72
|
var SequenceContainer = ({ sequence }) => {
|
|
@@ -87,17 +85,7 @@ var SequenceContainer = ({ sequence }) => {
|
|
|
87
85
|
}, [
|
|
88
86
|
sequence
|
|
89
87
|
]);
|
|
90
|
-
const editorRef = useRef(
|
|
91
|
-
const toolRegistry = useMemo(() => {
|
|
92
|
-
const space = getSpace(sequence);
|
|
93
|
-
if (!space) {
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
const _queue = space.queues.create();
|
|
97
|
-
return new ToolRegistry([]);
|
|
98
|
-
}, [
|
|
99
|
-
sequence
|
|
100
|
-
]);
|
|
88
|
+
const editorRef = useRef(null);
|
|
101
89
|
const formatAndSave = useCallback(() => {
|
|
102
90
|
if (!sequence) {
|
|
103
91
|
return;
|
|
@@ -138,8 +126,7 @@ var SequenceContainer = ({ sequence }) => {
|
|
|
138
126
|
}, [
|
|
139
127
|
sequence,
|
|
140
128
|
formatAndSave,
|
|
141
|
-
selectionManager
|
|
142
|
-
toolRegistry
|
|
129
|
+
selectionManager
|
|
143
130
|
]);
|
|
144
131
|
return /* @__PURE__ */ React2.createElement(StackItem.Content, {
|
|
145
132
|
toolbar: true
|
|
@@ -161,4 +148,4 @@ export {
|
|
|
161
148
|
SequenceContainer,
|
|
162
149
|
SequenceContainer_default as default
|
|
163
150
|
};
|
|
164
|
-
//# sourceMappingURL=SequenceContainer-
|
|
151
|
+
//# sourceMappingURL=SequenceContainer-PGGJUQ46.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/SequenceContainer.tsx", "../../../src/components/SequenceEditor/SequenceEditor.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport JSON5 from 'json5';\nimport React, { useCallback, useEffect, useRef, useState } from 'react';\n\nimport { type Sequence, type SequenceDefinition } from '@dxos/conductor';\nimport { Key } from '@dxos/echo';\nimport { Toolbar, useTranslation } from '@dxos/react-ui';\nimport { useSelectionManager } from '@dxos/react-ui-attention';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { meta } from '../meta';\n\nimport { SequenceEditor } from './SequenceEditor';\n\n// TODO(burdon): Move to config.\nexport const EXA_API_KEY = '9c7e17ff-0c85-4cd5-827a-8b489f139e03';\n\n// TODO(burdon): Validate.\nconst parseSequence = (text: string): SequenceDefinition | undefined => {\n try {\n const json = JSON5.parse(text);\n const { steps } = json;\n return { steps };\n } catch {\n // Ignore.\n }\n};\n\nexport const SequenceContainer = ({ sequence }: { sequence: Sequence }) => {\n const { t } = useTranslation(meta.id);\n const selectionManager = useSelectionManager();\n const [definition, setDefinition] = useState<SequenceDefinition>();\n useEffect(() => {\n setDefinition({\n steps: sequence.steps.map(({ instructions, tools }) => ({ instructions, tools })),\n });\n }, [sequence]);\n\n const editorRef = useRef<EditorView>(null);\n\n // TODO(burdon): Factor out.\n // const toolRegistry = useMemo(() => {\n // const space = getSpace(sequence);\n // if (!space) {\n // return;\n // }\n\n // // TODO(burdon): How should the queue be created?\n // // eslint-disable-next-line no-unused-vars\n // const _queue = space.queues.create();\n\n // return new ToolRegistry([\n // // createExaTool({ apiKey: EXA_API_KEY }),\n // // createLocalSearchTool(space.db, queue),\n // // createGraphWriterTool({\n // // db: space.db,\n // // queue,\n // // schema: [], // TODO(burdon): Get schema from client/sequence?\n // // onDone: async (objects) => {\n // // await queue.append(objects);\n // // },\n // // }),\n // ]);\n // }, [sequence]);\n\n const formatAndSave = useCallback((): SequenceDefinition | undefined => {\n if (!sequence) {\n return;\n }\n\n const text = editorRef.current?.state.doc.toString();\n if (!text) {\n return;\n }\n\n const definition = parseSequence(text);\n if (!definition) {\n return;\n }\n\n setDefinition(definition);\n const formatted = JSON.stringify(definition, null, 2);\n editorRef.current?.dispatch({\n changes: { from: 0, to: text.length, insert: formatted },\n });\n\n sequence.steps.length = 0;\n for (const step of definition.steps) {\n sequence.steps.push({\n id: Key.ObjectId.random(),\n instructions: step.instructions,\n tools: step.tools,\n });\n }\n\n return sequence;\n }, [sequence]);\n\n // TODO(burdon): Save raw sequence separately from parsed sequence? (like Script).\n const handleSave = useCallback(() => formatAndSave(), [formatAndSave]);\n\n const handleRun = useCallback(async () => {\n // if (!aiClient?.value || !toolRegistry) {\n // return;\n // }\n // formatAndSave();\n // // Get input from selection.\n // const input = Array.from(getSelectionSet(selectionManager)).map((id) => DXN.fromLocalObjectId(id));\n // if (!input.length) {\n // return;\n // }\n // const machine = new SequenceMachine(toolRegistry, sequence).setLogger(new QueueLogger(sequence));\n // await machine.runToCompletion({ aiClient: aiClient.value, input });\n }, [sequence, formatAndSave, selectionManager]);\n\n return (\n <StackItem.Content toolbar>\n <Toolbar.Root>\n <Toolbar.Button onClick={handleSave}>{t('button save')}</Toolbar.Button>\n <Toolbar.Button onClick={handleRun}>{t('button run')}</Toolbar.Button>\n </Toolbar.Root>\n {definition && <SequenceEditor ref={editorRef} sequence={definition} />}\n </StackItem.Content>\n );\n};\n\nexport default SequenceContainer;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { forwardRef, useImperativeHandle } from 'react';\n\nimport { SequenceDefinition } from '@dxos/conductor';\nimport { Type } from '@dxos/echo';\nimport { type ThemedClassName, useThemeContext } from '@dxos/react-ui';\nimport {\n type EditorView,\n createBasicExtensions,\n createJsonExtensions,\n createThemeExtensions,\n useTextEditor,\n} from '@dxos/react-ui-editor';\nimport { mx } from '@dxos/react-ui-theme';\n\nexport type SequenceEditorProps = ThemedClassName<{\n sequence: SequenceDefinition;\n}>;\n\n// TODO(burdon): Factor out JsonEditor.\nexport const SequenceEditor = forwardRef<EditorView | null, SequenceEditorProps>(\n ({ classNames, sequence }, forwardedRef) => {\n const { themeMode } = useThemeContext();\n const { parentRef, view } = useTextEditor({\n initialValue: JSON.stringify(sequence, null, 2),\n extensions: [\n createBasicExtensions({\n lineNumbers: true,\n lineWrapping: false,\n monospace: true,\n scrollPastEnd: true,\n }),\n createThemeExtensions({\n themeMode,\n syntaxHighlighting: true,\n }),\n createJsonExtensions({\n schema: Type.toJsonSchema(SequenceDefinition, { strict: true }),\n }),\n ],\n });\n\n useImperativeHandle<EditorView | null, EditorView | null>(forwardedRef, () => view, [view]);\n\n return <div ref={parentRef} className={mx('overflow-hidden', classNames)} />;\n },\n);\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["JSON5", "React", "useCallback", "useEffect", "useRef", "useState", "Key", "Toolbar", "useTranslation", "useSelectionManager", "StackItem", "React", "forwardRef", "useImperativeHandle", "SequenceDefinition", "Type", "useThemeContext", "createBasicExtensions", "createJsonExtensions", "createThemeExtensions", "useTextEditor", "mx", "SequenceEditor", "forwardRef", "classNames", "sequence", "forwardedRef", "themeMode", "useThemeContext", "parentRef", "view", "useTextEditor", "initialValue", "JSON", "stringify", "extensions", "createBasicExtensions", "lineNumbers", "lineWrapping", "monospace", "scrollPastEnd", "createThemeExtensions", "syntaxHighlighting", "createJsonExtensions", "schema", "Type", "toJsonSchema", "SequenceDefinition", "strict", "useImperativeHandle", "div", "ref", "className", "mx", "EXA_API_KEY", "parseSequence", "text", "json", "JSON5", "parse", "steps", "SequenceContainer", "sequence", "t", "useTranslation", "meta", "id", "selectionManager", "useSelectionManager", "definition", "setDefinition", "useState", "useEffect", "map", "instructions", "tools", "editorRef", "useRef", "formatAndSave", "useCallback", "current", "state", "doc", "toString", "formatted", "JSON", "stringify", "dispatch", "changes", "from", "to", "length", "insert", "step", "push", "Key", "ObjectId", "random", "handleSave", "handleRun", "React", "StackItem", "Content", "toolbar", "Toolbar", "Root", "Button", "onClick", "SequenceEditor", "ref"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
import "./chunk-HSLMI22Q.mjs";
|
|
3
|
+
|
|
4
|
+
// src/capabilities/ai-service.ts
|
|
5
|
+
import * as Effect from "effect/Effect";
|
|
6
|
+
import * as Layer from "effect/Layer";
|
|
7
|
+
import * as AiServiceRouter from "@dxos/ai/AiServiceRouter";
|
|
8
|
+
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
9
|
+
var ai_service_default = ((context) => {
|
|
10
|
+
const resolvers = context.getCapabilities(Capabilities.AiModelResolver);
|
|
11
|
+
const combinedLayer = resolvers.reduce((acc, resolver) => resolver.pipe(Layer.provide(acc)), AiServiceRouter.AiModelResolver.fromModelMap(Effect.succeed({})));
|
|
12
|
+
return [
|
|
13
|
+
// TODO(dmaretskyi): Read config from settings.
|
|
14
|
+
contributes(Capabilities.AiServiceLayer, AiServiceRouter.AiModelResolver.buildAiService.pipe(Layer.provide(combinedLayer)))
|
|
15
|
+
];
|
|
16
|
+
});
|
|
17
|
+
export {
|
|
18
|
+
ai_service_default as default
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=ai-service-MUYLV3NT.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/ai-service.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\nimport * as Layer from 'effect/Layer';\n\nimport * as AiServiceRouter from '@dxos/ai/AiServiceRouter';\nimport { Capabilities, type PluginContext, contributes } from '@dxos/app-framework';\n\nexport default (context: PluginContext) => {\n const resolvers = context.getCapabilities(Capabilities.AiModelResolver);\n\n // TODO(dmaretskyi): Extract function to reduce them.\n const combinedLayer = resolvers.reduce(\n (acc, resolver) => resolver.pipe(Layer.provide(acc)),\n AiServiceRouter.AiModelResolver.fromModelMap(Effect.succeed({})), // Empty resolver as fallback.\n );\n\n return [\n // TODO(dmaretskyi): Read config from settings.\n contributes(\n Capabilities.AiServiceLayer,\n AiServiceRouter.AiModelResolver.buildAiService.pipe(Layer.provide(combinedLayer)),\n ),\n ];\n};\n"],
|
|
5
|
+
"mappings": ";;;;AAIA,YAAYA,YAAY;AACxB,YAAYC,WAAW;AAEvB,YAAYC,qBAAqB;AACjC,SAASC,cAAkCC,mBAAmB;AAE9D,IAAA,sBAAe,CAACC,YAAAA;AACd,QAAMC,YAAYD,QAAQE,gBAAgBC,aAAaC,eAAe;AAGtE,QAAMC,gBAAgBJ,UAAUK,OAC9B,CAACC,KAAKC,aAAaA,SAASC,KAAWC,cAAQH,GAAAA,CAAAA,GAC/BH,gCAAgBO,aAAoBC,eAAQ,CAAC,CAAA,CAAA,CAAA;AAG/D,SAAO;;IAELC,YACEV,aAAaW,gBACGV,gCAAgBW,eAAeN,KAAWC,cAAQL,aAAAA,CAAAA,CAAAA;;AAGxE;",
|
|
6
|
+
"names": ["Effect", "Layer", "AiServiceRouter", "Capabilities", "contributes", "context", "resolvers", "getCapabilities", "Capabilities", "AiModelResolver", "combinedLayer", "reduce", "acc", "resolver", "pipe", "provide", "fromModelMap", "succeed", "contributes", "AiServiceLayer", "buildAiService"]
|
|
7
|
+
}
|
|
@@ -2,31 +2,35 @@ import { createRequire } from 'node:module';const require = createRequire(import
|
|
|
2
2
|
import {
|
|
3
3
|
AssistantAction_exports,
|
|
4
4
|
Assistant_exports
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-TNR46C3L.mjs";
|
|
6
|
+
import {
|
|
7
|
+
AssistantCapabilities
|
|
8
|
+
} from "./chunk-XQGWSZ4T.mjs";
|
|
6
9
|
import {
|
|
7
10
|
ASSISTANT_DIALOG,
|
|
8
11
|
meta
|
|
9
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-73ABYRYX.mjs";
|
|
10
13
|
import "./chunk-HSLMI22Q.mjs";
|
|
11
14
|
|
|
12
15
|
// src/capabilities/app-graph-builder.ts
|
|
13
16
|
import { Rx } from "@effect-rx/rx-react";
|
|
14
|
-
import
|
|
17
|
+
import * as Function from "effect/Function";
|
|
18
|
+
import * as Option from "effect/Option";
|
|
15
19
|
import { Capabilities, LayoutAction, contributes, createIntent } from "@dxos/app-framework";
|
|
16
20
|
import { Sequence } from "@dxos/conductor";
|
|
17
21
|
import { Obj } from "@dxos/echo";
|
|
18
22
|
import { invariant } from "@dxos/invariant";
|
|
19
23
|
import { ClientCapabilities } from "@dxos/plugin-client";
|
|
20
24
|
import { ATTENDABLE_PATH_SEPARATOR, PLANK_COMPANION_TYPE } from "@dxos/plugin-deck/types";
|
|
21
|
-
import { ROOT_ID, createExtension } from "@dxos/plugin-graph";
|
|
22
|
-
import { getActiveSpace
|
|
25
|
+
import { ROOT_ID, createExtension, rxFromSignal } from "@dxos/plugin-graph";
|
|
26
|
+
import { getActiveSpace } from "@dxos/plugin-space";
|
|
23
27
|
import { SpaceAction } from "@dxos/plugin-space/types";
|
|
24
|
-
import {
|
|
28
|
+
import { Query, fullyQualifiedId } from "@dxos/react-client/echo";
|
|
25
29
|
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/capabilities/app-graph-builder.ts";
|
|
26
|
-
var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
|
|
30
|
+
var app_graph_builder_default = ((context) => contributes(Capabilities.AppGraphBuilder, [
|
|
27
31
|
createExtension({
|
|
28
32
|
id: `${meta.id}/assistant`,
|
|
29
|
-
actions: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
|
|
33
|
+
actions: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
|
|
30
34
|
{
|
|
31
35
|
id: `${LayoutAction.UpdateDialog._tag}/assistant/open`,
|
|
32
36
|
data: async () => {
|
|
@@ -68,26 +72,10 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
68
72
|
]), Option.getOrElse(() => [])))
|
|
69
73
|
}),
|
|
70
74
|
createExtension({
|
|
71
|
-
id: `${meta.id}/
|
|
75
|
+
id: `${meta.id}/companion-chat`,
|
|
72
76
|
connector: (node) => {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
const nodeOption = get(node);
|
|
76
|
-
if (Option.isNone(nodeOption)) {
|
|
77
|
-
return [];
|
|
78
|
-
}
|
|
79
|
-
const object = nodeOption.value.data;
|
|
80
|
-
if (!Obj.isObject(object)) {
|
|
81
|
-
return [];
|
|
82
|
-
}
|
|
83
|
-
const space = getSpace(object);
|
|
84
|
-
if (!space) {
|
|
85
|
-
return [];
|
|
86
|
-
}
|
|
87
|
-
if (!query) {
|
|
88
|
-
query = space.db.query(Query.select(Filter.ids(object.id)).targetOf(Assistant_exports.CompanionTo).source());
|
|
89
|
-
}
|
|
90
|
-
const chat = get(rxFromQuery(query))[0];
|
|
77
|
+
return Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.isObject(node2.data) ? Option.some(node2.data) : Option.none()), Option.map((object) => {
|
|
78
|
+
const currentChat = get(rxFromSignal(() => context.getCapability(AssistantCapabilities.State).currentChat[fullyQualifiedId(object)]));
|
|
91
79
|
return [
|
|
92
80
|
{
|
|
93
81
|
id: [
|
|
@@ -95,7 +83,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
95
83
|
"assistant-chat"
|
|
96
84
|
].join(ATTENDABLE_PATH_SEPARATOR),
|
|
97
85
|
type: PLANK_COMPANION_TYPE,
|
|
98
|
-
data:
|
|
86
|
+
data: currentChat ?? "assistant-chat",
|
|
99
87
|
properties: {
|
|
100
88
|
label: [
|
|
101
89
|
"assistant chat label",
|
|
@@ -109,12 +97,12 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
109
97
|
}
|
|
110
98
|
}
|
|
111
99
|
];
|
|
112
|
-
});
|
|
100
|
+
}), Option.getOrElse(() => [])));
|
|
113
101
|
}
|
|
114
102
|
}),
|
|
115
103
|
createExtension({
|
|
116
104
|
id: `${meta.id}/sequence-logs`,
|
|
117
|
-
connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(Sequence, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
|
|
105
|
+
connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(Sequence, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
|
|
118
106
|
{
|
|
119
107
|
id: [
|
|
120
108
|
node2.id,
|
|
@@ -135,20 +123,20 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
135
123
|
}
|
|
136
124
|
]), Option.getOrElse(() => [])))
|
|
137
125
|
})
|
|
138
|
-
]);
|
|
126
|
+
]));
|
|
139
127
|
var getOrCreateChat = async (dispatch, space) => {
|
|
140
128
|
const { objects: allChats } = await space.db.query(Query.type(Assistant_exports.Chat)).run();
|
|
141
129
|
const { objects: relatedChats } = await space.db.query(Query.type(Assistant_exports.Chat).sourceOf(Assistant_exports.CompanionTo).source()).run();
|
|
142
130
|
const chats = allChats.filter((chat) => !relatedChats.includes(chat));
|
|
143
131
|
if (chats.length > 0) {
|
|
144
|
-
return chats
|
|
132
|
+
return chats.at(-1);
|
|
145
133
|
}
|
|
146
134
|
const { data } = await dispatch(createIntent(AssistantAction_exports.CreateChat, {
|
|
147
135
|
space
|
|
148
136
|
}));
|
|
149
137
|
invariant(Obj.instanceOf(Assistant_exports.Chat, data?.object), void 0, {
|
|
150
138
|
F: __dxlog_file,
|
|
151
|
-
L:
|
|
139
|
+
L: 160,
|
|
152
140
|
S: void 0,
|
|
153
141
|
A: [
|
|
154
142
|
"Obj.instanceOf(Assistant.Chat, data?.object)",
|
|
@@ -164,4 +152,4 @@ var getOrCreateChat = async (dispatch, space) => {
|
|
|
164
152
|
export {
|
|
165
153
|
app_graph_builder_default as default
|
|
166
154
|
};
|
|
167
|
-
//# sourceMappingURL=app-graph-builder-
|
|
155
|
+
//# sourceMappingURL=app-graph-builder-OKNLR7H2.mjs.map
|