@dxos/plugin-assistant 0.8.4-main.f9ba587 → 0.8.4-main.fd6878d

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.
Files changed (405) hide show
  1. package/dist/lib/browser/{TemplateContainer-6ZGGH5T4.mjs → BlueprintContainer-H7H4BQ2C.mjs} +10 -9
  2. package/dist/lib/browser/BlueprintContainer-H7H4BQ2C.mjs.map +7 -0
  3. package/dist/lib/browser/{ChatContainer-6XNB5NEI.mjs → ChatContainer-OUVSX5V5.mjs} +36 -17
  4. package/dist/lib/browser/ChatContainer-OUVSX5V5.mjs.map +7 -0
  5. package/dist/lib/browser/{ChatDialog-IMWPRXTO.mjs → ChatDialog-P4FLEOHG.mjs} +22 -10
  6. package/dist/lib/browser/ChatDialog-P4FLEOHG.mjs.map +7 -0
  7. package/dist/lib/browser/SequenceContainer-627OQ557.mjs +163 -0
  8. package/dist/lib/browser/SequenceContainer-627OQ557.mjs.map +7 -0
  9. package/dist/lib/browser/ai-service-7KJ5LXBT.mjs +22 -0
  10. package/dist/lib/browser/ai-service-7KJ5LXBT.mjs.map +7 -0
  11. package/dist/lib/browser/{app-graph-builder-UJ5NHRGK.mjs → app-graph-builder-AVHHQ3KV.mjs} +16 -73
  12. package/dist/lib/browser/app-graph-builder-AVHHQ3KV.mjs.map +7 -0
  13. package/dist/lib/browser/blueprint-definition-CMGIZAOW.mjs +146 -0
  14. package/dist/lib/browser/blueprint-definition-CMGIZAOW.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-BRLHDHOF.mjs +244 -0
  16. package/dist/lib/browser/chunk-BRLHDHOF.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-HRLMD35M.mjs +191 -0
  18. package/dist/lib/browser/chunk-HRLMD35M.mjs.map +7 -0
  19. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  20. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  21. package/dist/lib/browser/{chunk-44HZKIAW.mjs → chunk-NZDCKQ6W.mjs} +32 -30
  22. package/dist/lib/browser/chunk-NZDCKQ6W.mjs.map +7 -0
  23. package/dist/lib/browser/{chunk-NTBGTFTV.mjs → chunk-QB7OVS6Z.mjs} +3 -2
  24. package/dist/lib/browser/chunk-QB7OVS6Z.mjs.map +7 -0
  25. package/dist/lib/browser/{chunk-TQ3QW3HJ.mjs → chunk-VEBVAHNM.mjs} +1041 -882
  26. package/dist/lib/browser/chunk-VEBVAHNM.mjs.map +7 -0
  27. package/dist/lib/browser/edge-model-resolver-2HB4PCWH.mjs +24 -0
  28. package/dist/lib/browser/edge-model-resolver-2HB4PCWH.mjs.map +7 -0
  29. package/dist/lib/browser/index.mjs +116 -88
  30. package/dist/lib/browser/index.mjs.map +3 -3
  31. package/dist/lib/browser/intent-resolver-MVOIEJXZ.mjs +81 -0
  32. package/dist/lib/browser/intent-resolver-MVOIEJXZ.mjs.map +7 -0
  33. package/dist/lib/browser/meta.json +1 -1
  34. package/dist/lib/browser/{react-surface-TMF7JJA4.mjs → react-surface-4HXS3YLT.mjs} +52 -45
  35. package/dist/lib/browser/react-surface-4HXS3YLT.mjs.map +7 -0
  36. package/dist/lib/browser/{settings-N4HEXADL.mjs → settings-G2EZXMWT.mjs} +5 -4
  37. package/dist/lib/{node-esm/settings-WQ76EG6O.mjs.map → browser/settings-G2EZXMWT.mjs.map} +1 -1
  38. package/dist/lib/browser/toolkit-IW4FBLLB.mjs +105 -0
  39. package/dist/lib/browser/toolkit-IW4FBLLB.mjs.map +7 -0
  40. package/dist/lib/browser/types/index.mjs +6 -13
  41. package/dist/lib/node-esm/{TemplateContainer-6KRNEMVE.mjs → BlueprintContainer-VH4EE4CM.mjs} +10 -9
  42. package/dist/lib/node-esm/BlueprintContainer-VH4EE4CM.mjs.map +7 -0
  43. package/dist/lib/node-esm/{ChatContainer-VOLG7J6N.mjs → ChatContainer-D5FABDNE.mjs} +36 -17
  44. package/dist/lib/node-esm/ChatContainer-D5FABDNE.mjs.map +7 -0
  45. package/dist/lib/node-esm/{ChatDialog-B2XNUNRM.mjs → ChatDialog-NKWVXHJP.mjs} +22 -10
  46. package/dist/lib/node-esm/ChatDialog-NKWVXHJP.mjs.map +7 -0
  47. package/dist/lib/node-esm/SequenceContainer-EQ5NP2PG.mjs +164 -0
  48. package/dist/lib/node-esm/SequenceContainer-EQ5NP2PG.mjs.map +7 -0
  49. package/dist/lib/node-esm/ai-service-LDD32477.mjs +23 -0
  50. package/dist/lib/node-esm/ai-service-LDD32477.mjs.map +7 -0
  51. package/dist/lib/node-esm/{app-graph-builder-MEQ5CYNI.mjs → app-graph-builder-RMOUJMMG.mjs} +16 -73
  52. package/dist/lib/node-esm/app-graph-builder-RMOUJMMG.mjs.map +7 -0
  53. package/dist/lib/node-esm/blueprint-definition-AEWYMW6I.mjs +147 -0
  54. package/dist/lib/node-esm/blueprint-definition-AEWYMW6I.mjs.map +7 -0
  55. package/dist/lib/node-esm/{chunk-D3HTVK5D.mjs → chunk-3SOC5GOP.mjs} +1041 -882
  56. package/dist/lib/node-esm/chunk-3SOC5GOP.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-F7RXCX5Y.mjs +192 -0
  58. package/dist/lib/node-esm/chunk-F7RXCX5Y.mjs.map +7 -0
  59. package/dist/lib/node-esm/{chunk-VESVUAOS.mjs → chunk-GAWXJ7K5.mjs} +32 -30
  60. package/dist/lib/node-esm/chunk-GAWXJ7K5.mjs.map +7 -0
  61. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  62. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-RD755HN3.mjs +245 -0
  64. package/dist/lib/node-esm/chunk-RD755HN3.mjs.map +7 -0
  65. package/dist/lib/node-esm/{chunk-E6V2RUQ2.mjs → chunk-X6AANUHZ.mjs} +3 -2
  66. package/dist/lib/node-esm/chunk-X6AANUHZ.mjs.map +7 -0
  67. package/dist/lib/node-esm/edge-model-resolver-UDDR2IA6.mjs +25 -0
  68. package/dist/lib/node-esm/edge-model-resolver-UDDR2IA6.mjs.map +7 -0
  69. package/dist/lib/node-esm/index.mjs +116 -88
  70. package/dist/lib/node-esm/index.mjs.map +3 -3
  71. package/dist/lib/node-esm/intent-resolver-DTDNCX3C.mjs +82 -0
  72. package/dist/lib/node-esm/intent-resolver-DTDNCX3C.mjs.map +7 -0
  73. package/dist/lib/node-esm/meta.json +1 -1
  74. package/dist/lib/node-esm/{react-surface-6XL6SWL2.mjs → react-surface-V6JNEZVO.mjs} +52 -45
  75. package/dist/lib/node-esm/react-surface-V6JNEZVO.mjs.map +7 -0
  76. package/dist/lib/node-esm/{settings-WQ76EG6O.mjs → settings-AIP5FOJG.mjs} +5 -4
  77. package/dist/lib/{browser/settings-N4HEXADL.mjs.map → node-esm/settings-AIP5FOJG.mjs.map} +1 -1
  78. package/dist/lib/node-esm/toolkit-2VNUL77B.mjs +106 -0
  79. package/dist/lib/node-esm/toolkit-2VNUL77B.mjs.map +7 -0
  80. package/dist/lib/node-esm/types/index.mjs +6 -13
  81. package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
  82. package/dist/types/src/capabilities/ai-service.d.ts +5 -0
  83. package/dist/types/src/capabilities/ai-service.d.ts.map +1 -0
  84. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  85. package/dist/types/src/capabilities/blueprint-definition.d.ts +3 -0
  86. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  87. package/dist/types/src/capabilities/capabilities.d.ts +8 -3
  88. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  89. package/dist/types/src/capabilities/edge-model-resolver.d.ts +5 -0
  90. package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +1 -0
  91. package/dist/types/src/capabilities/index.d.ts +6 -3
  92. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  93. package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
  94. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  95. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  96. package/dist/types/src/capabilities/toolkit.d.ts +5 -0
  97. package/dist/types/src/capabilities/toolkit.d.ts.map +1 -0
  98. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
  99. package/dist/types/src/components/BlueprintContainer.d.ts +8 -0
  100. package/dist/types/src/components/BlueprintContainer.d.ts.map +1 -0
  101. package/dist/types/src/components/Chat/Chat.d.ts +16 -13
  102. package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
  103. package/dist/types/src/components/Chat/events.d.ts +30 -0
  104. package/dist/types/src/components/Chat/events.d.ts.map +1 -0
  105. package/dist/types/src/components/Chat/index.d.ts +1 -0
  106. package/dist/types/src/components/Chat/index.d.ts.map +1 -1
  107. package/dist/types/src/components/ChatContainer.d.ts +5 -4
  108. package/dist/types/src/components/ChatContainer.d.ts.map +1 -1
  109. package/dist/types/src/components/ChatDialog.d.ts.map +1 -1
  110. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts +6 -5
  111. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts.map +1 -1
  112. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts +13 -0
  113. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -0
  114. package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts +11 -0
  115. package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts.map +1 -0
  116. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +3 -3
  117. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
  118. package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts +2 -1
  119. package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts.map +1 -1
  120. package/dist/types/src/components/ChatPrompt/index.d.ts +2 -2
  121. package/dist/types/src/components/ChatPrompt/index.d.ts.map +1 -1
  122. package/dist/types/src/components/ChatThread/ChatMessage.d.ts +10 -10
  123. package/dist/types/src/components/ChatThread/ChatMessage.d.ts.map +1 -1
  124. package/dist/types/src/components/ChatThread/ChatThread.d.ts +6 -12
  125. package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
  126. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +54 -60
  127. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
  128. package/dist/types/src/components/ChatThread/Link.d.ts +9 -0
  129. package/dist/types/src/components/ChatThread/Link.d.ts.map +1 -0
  130. package/dist/types/src/components/ChatThread/ToolBlock.d.ts +4 -3
  131. package/dist/types/src/components/ChatThread/ToolBlock.d.ts.map +1 -1
  132. package/dist/types/src/components/ChatThread/reducer.d.ts +4 -4
  133. package/dist/types/src/components/ChatThread/reducer.d.ts.map +1 -1
  134. package/dist/types/src/components/PromptSettings.d.ts +2 -2
  135. package/dist/types/src/components/PromptSettings.d.ts.map +1 -1
  136. package/dist/types/src/components/SequenceContainer.d.ts +1 -2
  137. package/dist/types/src/components/SequenceContainer.d.ts.map +1 -1
  138. package/dist/types/src/components/SequenceEditor/SequenceEditor.d.ts.map +1 -1
  139. package/dist/types/src/components/SequenceEditor/SequenceEditor.stories.d.ts +1 -1
  140. package/dist/types/src/components/SequenceEditor/SequenceEditor.stories.d.ts.map +1 -1
  141. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +4 -3
  142. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
  143. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +2 -2
  144. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
  145. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +5 -4
  146. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
  147. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
  148. package/dist/types/src/components/Timeline/Timeline.d.ts +24 -0
  149. package/dist/types/src/components/Timeline/Timeline.d.ts.map +1 -0
  150. package/dist/types/src/components/Timeline/Timeline.stories.d.ts +9 -0
  151. package/dist/types/src/components/Timeline/Timeline.stories.d.ts.map +1 -0
  152. package/dist/types/src/components/Timeline/index.d.ts +2 -0
  153. package/dist/types/src/components/Timeline/index.d.ts.map +1 -0
  154. package/dist/types/src/components/Toolbox/Toolbox.d.ts +6 -9
  155. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
  156. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +1 -2
  157. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
  158. package/dist/types/src/components/index.d.ts +4 -3
  159. package/dist/types/src/components/index.d.ts.map +1 -1
  160. package/dist/types/src/events.d.ts +1 -1
  161. package/dist/types/src/events.d.ts.map +1 -1
  162. package/dist/types/src/functions/analysis.d.ts +5 -0
  163. package/dist/types/src/functions/analysis.d.ts.map +1 -0
  164. package/dist/types/src/functions/index.d.ts +4 -0
  165. package/dist/types/src/functions/index.d.ts.map +1 -0
  166. package/dist/types/src/functions/list.d.ts +10 -0
  167. package/dist/types/src/functions/list.d.ts.map +1 -0
  168. package/dist/types/src/functions/load.d.ts +8 -0
  169. package/dist/types/src/functions/load.d.ts.map +1 -0
  170. package/dist/types/src/hooks/chat-processor.d.ts +34 -44
  171. package/dist/types/src/hooks/chat-processor.d.ts.map +1 -1
  172. package/dist/types/src/hooks/errors.d.ts +4 -0
  173. package/dist/types/src/hooks/errors.d.ts.map +1 -0
  174. package/dist/types/src/hooks/index.d.ts +8 -4
  175. package/dist/types/src/hooks/index.d.ts.map +1 -1
  176. package/dist/types/src/hooks/presets.d.ts +13 -0
  177. package/dist/types/src/hooks/presets.d.ts.map +1 -0
  178. package/dist/types/src/hooks/useBlueprintRegistry.d.ts +21 -0
  179. package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -0
  180. package/dist/types/src/hooks/useChatProcessor.d.ts +9 -18
  181. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
  182. package/dist/types/src/hooks/useChatServices.d.ts +13 -0
  183. package/dist/types/src/hooks/useChatServices.d.ts.map +1 -0
  184. package/dist/types/src/hooks/useOnline.d.ts +3 -0
  185. package/dist/types/src/hooks/useOnline.d.ts.map +1 -0
  186. package/dist/types/src/hooks/usePresets.d.ts +7 -0
  187. package/dist/types/src/hooks/usePresets.d.ts.map +1 -0
  188. package/dist/types/src/hooks/useReferencesProvider.d.ts +7 -0
  189. package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -0
  190. package/dist/types/src/hooks/useResolveRef.d.ts +4 -0
  191. package/dist/types/src/hooks/useResolveRef.d.ts.map +1 -0
  192. package/dist/types/src/parser/filter-generator.d.ts.map +1 -1
  193. package/dist/types/src/parser/index.d.ts +1 -1
  194. package/dist/types/src/parser/index.d.ts.map +1 -1
  195. package/dist/types/src/parser/query-parser.d.ts.map +1 -1
  196. package/dist/types/src/stories/Chat.stories.d.ts +87 -18
  197. package/dist/types/src/stories/Chat.stories.d.ts.map +1 -1
  198. package/dist/types/src/stories/components/BlueprintContainer.d.ts +5 -0
  199. package/dist/types/src/stories/components/BlueprintContainer.d.ts.map +1 -0
  200. package/dist/types/src/stories/components/ChatContainer.d.ts +5 -0
  201. package/dist/types/src/stories/components/ChatContainer.d.ts.map +1 -0
  202. package/dist/types/src/stories/components/GraphContainer.d.ts +6 -0
  203. package/dist/types/src/stories/components/GraphContainer.d.ts.map +1 -0
  204. package/dist/types/src/stories/components/LoggingContainer.d.ts +5 -0
  205. package/dist/types/src/stories/components/LoggingContainer.d.ts.map +1 -0
  206. package/dist/types/src/stories/components/SurfaceContainer.d.ts +8 -0
  207. package/dist/types/src/stories/components/SurfaceContainer.d.ts.map +1 -0
  208. package/dist/types/src/stories/components/TasksContainer.d.ts +5 -0
  209. package/dist/types/src/stories/components/TasksContainer.d.ts.map +1 -0
  210. package/dist/types/src/stories/components/index.d.ts +8 -0
  211. package/dist/types/src/stories/components/index.d.ts.map +1 -0
  212. package/dist/types/src/stories/components/types.d.ts +7 -0
  213. package/dist/types/src/stories/components/types.d.ts.map +1 -0
  214. package/dist/types/src/stories/hooks/index.d.ts +3 -0
  215. package/dist/types/src/stories/hooks/index.d.ts.map +1 -0
  216. package/dist/types/src/stories/hooks/useFlush.d.ts +6 -0
  217. package/dist/types/src/stories/hooks/useFlush.d.ts.map +1 -0
  218. package/dist/types/src/stories/hooks/useMatcherExtension.d.ts +3 -0
  219. package/dist/types/src/stories/hooks/useMatcherExtension.d.ts.map +1 -0
  220. package/dist/types/src/stories/testing/data.d.ts +142 -0
  221. package/dist/types/src/stories/testing/data.d.ts.map +1 -0
  222. package/dist/types/src/stories/testing/index.d.ts +3 -0
  223. package/dist/types/src/stories/testing/index.d.ts.map +1 -0
  224. package/dist/types/src/stories/testing/testing.d.ts +26 -0
  225. package/dist/types/src/stories/testing/testing.d.ts.map +1 -0
  226. package/dist/types/src/testing/test-functions.d.ts +5 -2
  227. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  228. package/dist/types/src/testing/test-sequence.d.ts.map +1 -1
  229. package/dist/types/src/tools/function.d.ts.map +1 -1
  230. package/dist/types/src/tools/openapi.d.ts.map +1 -1
  231. package/dist/types/src/translations.d.ts +25 -13
  232. package/dist/types/src/translations.d.ts.map +1 -1
  233. package/dist/types/src/types/Assistant.d.ts +40 -0
  234. package/dist/types/src/types/Assistant.d.ts.map +1 -0
  235. package/dist/types/src/types/AssistantAction.d.ts +90 -0
  236. package/dist/types/src/types/AssistantAction.d.ts.map +1 -0
  237. package/dist/types/src/types/defs.d.ts +2 -0
  238. package/dist/types/src/types/defs.d.ts.map +1 -0
  239. package/dist/types/src/types/index.d.ts +3 -2
  240. package/dist/types/src/types/index.d.ts.map +1 -1
  241. package/dist/types/src/types/service.d.ts +6 -6
  242. package/dist/types/src/types/service.d.ts.map +1 -1
  243. package/dist/types/tsconfig.tsbuildinfo +1 -1
  244. package/package.json +83 -73
  245. package/src/AssistantPlugin.tsx +61 -41
  246. package/src/capabilities/ai-service.ts +28 -0
  247. package/src/capabilities/app-graph-builder.ts +9 -92
  248. package/src/capabilities/blueprint-definition.ts +32 -0
  249. package/src/capabilities/capabilities.ts +11 -3
  250. package/src/capabilities/edge-model-resolver.ts +29 -0
  251. package/src/capabilities/index.ts +6 -3
  252. package/src/capabilities/intent-resolver.ts +39 -11
  253. package/src/capabilities/react-surface.tsx +35 -27
  254. package/src/capabilities/toolkit.ts +106 -0
  255. package/src/components/AssistantSettings/AssistantSettings.tsx +1 -1
  256. package/src/components/BlueprintContainer.tsx +24 -0
  257. package/src/components/Chat/Chat.tsx +148 -95
  258. package/src/components/Chat/events.ts +50 -0
  259. package/src/components/Chat/index.ts +2 -0
  260. package/src/components/ChatContainer.tsx +39 -15
  261. package/src/components/ChatDialog.tsx +10 -7
  262. package/src/components/ChatPrompt/ChatActions.tsx +15 -20
  263. package/src/components/ChatPrompt/ChatOptions.tsx +59 -0
  264. package/src/components/ChatPrompt/ChatPresets.tsx +28 -0
  265. package/src/components/ChatPrompt/ChatReferences.tsx +11 -8
  266. package/src/components/ChatPrompt/ChatStatusIndicator.tsx +17 -4
  267. package/src/components/ChatPrompt/index.ts +2 -3
  268. package/src/components/ChatThread/ChatMessage.tsx +192 -148
  269. package/src/components/ChatThread/ChatThread.stories.tsx +221 -109
  270. package/src/components/ChatThread/ChatThread.tsx +12 -23
  271. package/src/components/ChatThread/Link.tsx +39 -0
  272. package/src/components/ChatThread/ToolBlock.tsx +41 -27
  273. package/src/components/ChatThread/reducer.ts +14 -14
  274. package/src/components/PromptSettings.tsx +41 -43
  275. package/src/components/SequenceContainer.tsx +32 -38
  276. package/src/components/SequenceEditor/SequenceEditor.stories.tsx +3 -2
  277. package/src/components/SequenceEditor/SequenceEditor.tsx +1 -1
  278. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +37 -35
  279. package/src/components/TemplateEditor/TemplateEditor.tsx +39 -23
  280. package/src/components/TemplateEditor/TemplateForm.stories.tsx +23 -16
  281. package/src/components/TemplateEditor/TemplateForm.tsx +50 -55
  282. package/src/components/Timeline/Timeline.stories.tsx +53 -0
  283. package/src/components/Timeline/Timeline.tsx +159 -0
  284. package/src/components/Timeline/index.ts +5 -0
  285. package/src/components/Toolbox/Toolbox.stories.tsx +7 -13
  286. package/src/components/Toolbox/Toolbox.tsx +21 -42
  287. package/src/components/index.ts +2 -5
  288. package/src/events.ts +2 -2
  289. package/src/functions/analysis.ts +20 -0
  290. package/src/functions/index.ts +7 -0
  291. package/src/functions/list.ts +42 -0
  292. package/src/functions/load.ts +43 -0
  293. package/src/hooks/chat-processor.ts +167 -188
  294. package/src/hooks/errors.ts +8 -0
  295. package/src/hooks/index.ts +8 -4
  296. package/src/hooks/presets.ts +53 -0
  297. package/src/hooks/useBlueprintRegistry.ts +79 -0
  298. package/src/hooks/useChatProcessor.ts +81 -0
  299. package/src/hooks/useChatServices.ts +72 -0
  300. package/src/hooks/useOnline.ts +10 -0
  301. package/src/hooks/usePresets.ts +45 -0
  302. package/src/hooks/{useContextProvider.ts → useReferencesProvider.ts} +18 -22
  303. package/src/hooks/useResolveRef.ts +33 -0
  304. package/src/parser/filter-generator.ts +6 -13
  305. package/src/parser/index.ts +1 -1
  306. package/src/parser/query-parser.ts +1 -1
  307. package/src/queue-logger.ts +5 -5
  308. package/src/stories/Chat.stories.tsx +246 -198
  309. package/src/stories/components/BlueprintContainer.tsx +34 -0
  310. package/src/stories/components/ChatContainer.tsx +80 -0
  311. package/src/stories/components/GraphContainer.tsx +118 -0
  312. package/src/stories/components/LoggingContainer.tsx +22 -0
  313. package/src/stories/components/SurfaceContainer.tsx +62 -0
  314. package/src/stories/components/TasksContainer.tsx +51 -0
  315. package/src/stories/components/index.ts +12 -0
  316. package/src/stories/components/types.ts +11 -0
  317. package/src/stories/hooks/index.ts +6 -0
  318. package/src/stories/hooks/useFlush.ts +35 -0
  319. package/src/stories/hooks/useMatcherExtension.ts +45 -0
  320. package/src/stories/testing/data.ts +130 -0
  321. package/src/stories/testing/index.ts +6 -0
  322. package/src/stories/testing/testing.tsx +162 -0
  323. package/src/testing/test-functions.ts +9 -4
  324. package/src/testing/test-sequence.ts +18 -20
  325. package/src/tools/function.ts +4 -1
  326. package/src/tools/openapi.test.ts +10 -8
  327. package/src/tools/openapi.ts +4 -1
  328. package/src/translations.ts +29 -13
  329. package/src/types/Assistant.ts +59 -0
  330. package/src/types/AssistantAction.ts +54 -0
  331. package/src/types/defs.ts +5 -0
  332. package/src/types/index.ts +4 -2
  333. package/dist/lib/browser/ChatContainer-6XNB5NEI.mjs.map +0 -7
  334. package/dist/lib/browser/ChatDialog-IMWPRXTO.mjs.map +0 -7
  335. package/dist/lib/browser/SequenceContainer-6XOYB2RN.mjs +0 -322
  336. package/dist/lib/browser/SequenceContainer-6XOYB2RN.mjs.map +0 -7
  337. package/dist/lib/browser/TemplateContainer-6ZGGH5T4.mjs.map +0 -7
  338. package/dist/lib/browser/ai-client-ML7OQWAO.mjs +0 -39
  339. package/dist/lib/browser/ai-client-ML7OQWAO.mjs.map +0 -7
  340. package/dist/lib/browser/app-graph-builder-UJ5NHRGK.mjs.map +0 -7
  341. package/dist/lib/browser/chunk-44HZKIAW.mjs.map +0 -7
  342. package/dist/lib/browser/chunk-NTBGTFTV.mjs.map +0 -7
  343. package/dist/lib/browser/chunk-OZL4OHTU.mjs +0 -157
  344. package/dist/lib/browser/chunk-OZL4OHTU.mjs.map +0 -7
  345. package/dist/lib/browser/chunk-TQ3QW3HJ.mjs.map +0 -7
  346. package/dist/lib/browser/chunk-TU7UUGWQ.mjs +0 -203
  347. package/dist/lib/browser/chunk-TU7UUGWQ.mjs.map +0 -7
  348. package/dist/lib/browser/chunk-WPZ4UANI.mjs +0 -16
  349. package/dist/lib/browser/chunk-WPZ4UANI.mjs.map +0 -7
  350. package/dist/lib/browser/intent-resolver-LEAPB55Q.mjs +0 -42
  351. package/dist/lib/browser/intent-resolver-LEAPB55Q.mjs.map +0 -7
  352. package/dist/lib/browser/react-surface-TMF7JJA4.mjs.map +0 -7
  353. package/dist/lib/node-esm/ChatContainer-VOLG7J6N.mjs.map +0 -7
  354. package/dist/lib/node-esm/ChatDialog-B2XNUNRM.mjs.map +0 -7
  355. package/dist/lib/node-esm/SequenceContainer-WWG6IMN3.mjs +0 -323
  356. package/dist/lib/node-esm/SequenceContainer-WWG6IMN3.mjs.map +0 -7
  357. package/dist/lib/node-esm/TemplateContainer-6KRNEMVE.mjs.map +0 -7
  358. package/dist/lib/node-esm/ai-client-2FQ434CT.mjs +0 -40
  359. package/dist/lib/node-esm/ai-client-2FQ434CT.mjs.map +0 -7
  360. package/dist/lib/node-esm/app-graph-builder-MEQ5CYNI.mjs.map +0 -7
  361. package/dist/lib/node-esm/chunk-D3HTVK5D.mjs.map +0 -7
  362. package/dist/lib/node-esm/chunk-E6V2RUQ2.mjs.map +0 -7
  363. package/dist/lib/node-esm/chunk-HVMVHP4R.mjs +0 -158
  364. package/dist/lib/node-esm/chunk-HVMVHP4R.mjs.map +0 -7
  365. package/dist/lib/node-esm/chunk-HXKRKIN2.mjs +0 -18
  366. package/dist/lib/node-esm/chunk-HXKRKIN2.mjs.map +0 -7
  367. package/dist/lib/node-esm/chunk-VESVUAOS.mjs.map +0 -7
  368. package/dist/lib/node-esm/chunk-YYUVTTVK.mjs +0 -204
  369. package/dist/lib/node-esm/chunk-YYUVTTVK.mjs.map +0 -7
  370. package/dist/lib/node-esm/intent-resolver-4ULF3F7U.mjs +0 -43
  371. package/dist/lib/node-esm/intent-resolver-4ULF3F7U.mjs.map +0 -7
  372. package/dist/lib/node-esm/react-surface-6XL6SWL2.mjs.map +0 -7
  373. package/dist/types/src/capabilities/ai-client.d.ts +0 -5
  374. package/dist/types/src/capabilities/ai-client.d.ts.map +0 -1
  375. package/dist/types/src/components/ChatPrompt/ChatOptionsMenu.d.ts +0 -9
  376. package/dist/types/src/components/ChatPrompt/ChatOptionsMenu.d.ts.map +0 -1
  377. package/dist/types/src/components/ChatPrompt/events.d.ts +0 -17
  378. package/dist/types/src/components/ChatPrompt/events.d.ts.map +0 -1
  379. package/dist/types/src/components/TemplateContainer.d.ts +0 -9
  380. package/dist/types/src/components/TemplateContainer.d.ts.map +0 -1
  381. package/dist/types/src/hooks/chat-processor.test.d.ts +0 -2
  382. package/dist/types/src/hooks/chat-processor.test.d.ts.map +0 -1
  383. package/dist/types/src/hooks/useBlueprints.d.ts +0 -4
  384. package/dist/types/src/hooks/useBlueprints.d.ts.map +0 -1
  385. package/dist/types/src/hooks/useContextProvider.d.ts +0 -23
  386. package/dist/types/src/hooks/useContextProvider.d.ts.map +0 -1
  387. package/dist/types/src/hooks/useServiceContainer.d.ts +0 -8
  388. package/dist/types/src/hooks/useServiceContainer.d.ts.map +0 -1
  389. package/dist/types/src/hooks/useTextInputEvents.d.ts +0 -13
  390. package/dist/types/src/hooks/useTextInputEvents.d.ts.map +0 -1
  391. package/dist/types/src/types/schema.d.ts +0 -71
  392. package/dist/types/src/types/schema.d.ts.map +0 -1
  393. package/dist/types/src/types/template.d.ts +0 -56
  394. package/dist/types/src/types/template.d.ts.map +0 -1
  395. package/src/capabilities/ai-client.ts +0 -39
  396. package/src/components/ChatPrompt/ChatOptionsMenu.tsx +0 -52
  397. package/src/components/ChatPrompt/events.ts +0 -12
  398. package/src/components/TemplateContainer.tsx +0 -25
  399. package/src/hooks/chat-processor.test.ts +0 -15
  400. package/src/hooks/useBlueprints.ts +0 -31
  401. package/src/hooks/useChatProcessor.tsx +0 -142
  402. package/src/hooks/useServiceContainer.ts +0 -42
  403. package/src/hooks/useTextInputEvents.ts +0 -49
  404. package/src/types/schema.ts +0 -86
  405. package/src/types/template.ts +0 -66
@@ -13,6 +13,7 @@ import { createDocAccessor } from "@dxos/react-client/echo";
13
13
  import { useThemeContext, useTranslation } from "@dxos/react-ui";
14
14
  import { createBasicExtensions, createDataExtensions, createThemeExtensions, useTextEditor } from "@dxos/react-ui-editor";
15
15
  import { mx } from "@dxos/react-ui-theme";
16
+ import { isNotFalsy } from "@dxos/util";
16
17
  handlebarsLanguage.configure({
17
18
  props: [
18
19
  styleTags({
@@ -20,43 +21,43 @@ handlebarsLanguage.configure({
20
21
  })
21
22
  ]
22
23
  });
23
- var TemplateEditor = ({ classNames, template }) => {
24
+ var TemplateEditor = ({ id, classNames, template }) => {
24
25
  var _effect = _useSignals();
25
26
  try {
26
27
  const { t } = useTranslation(meta.id);
27
28
  const { themeMode } = useThemeContext();
28
- const { parentRef } = useTextEditor(() => ({
29
- initialValue: template.source,
30
- extensions: [
31
- createDataExtensions({
32
- id: template.id,
33
- text: template.source !== void 0 ? createDocAccessor(template, [
34
- "template"
35
- ]) : void 0
36
- }),
37
- createBasicExtensions({
38
- bracketMatching: false,
39
- lineWrapping: true,
40
- placeholder: t("template placeholder")
41
- }),
42
- createThemeExtensions({
43
- themeMode,
44
- slots: {
45
- content: {
46
- className: "!p-3"
47
- }
48
- }
49
- }),
50
- // https://github.com/xiechao/lang-handlebars
51
- new LanguageSupport(handlebarsLanguage, syntaxHighlighting(handlebarsHighlightStyle))
52
- ]
53
- }), [
29
+ const { parentRef } = useTextEditor(() => {
30
+ const text = template.source?.target;
31
+ return {
32
+ initialValue: text?.content ?? "",
33
+ extensions: [
34
+ text && createDataExtensions({
35
+ id,
36
+ text: createDocAccessor(text, [
37
+ "content"
38
+ ])
39
+ }),
40
+ createBasicExtensions({
41
+ bracketMatching: false,
42
+ lineNumbers: true,
43
+ lineWrapping: true,
44
+ monospace: true,
45
+ placeholder: t("template placeholder")
46
+ }),
47
+ createThemeExtensions({
48
+ themeMode
49
+ }),
50
+ // https://github.com/xiechao/lang-handlebars
51
+ new LanguageSupport(handlebarsLanguage, syntaxHighlighting(handlebarsHighlightStyle))
52
+ ].filter(isNotFalsy)
53
+ };
54
+ }, [
54
55
  themeMode,
55
- prompt
56
+ template.source?.target
56
57
  ]);
57
58
  return /* @__PURE__ */ React.createElement("div", {
58
59
  ref: parentRef,
59
- className: mx(classNames)
60
+ className: mx("h-full overflow-hidden", classNames)
60
61
  });
61
62
  } finally {
62
63
  _effect.f();
@@ -64,6 +65,7 @@ var TemplateEditor = ({ classNames, template }) => {
64
65
  };
65
66
  var handlebarsHighlightStyle = HighlightStyle.define([
66
67
  {
68
+ // Braces.
67
69
  tag: tags.tagName,
68
70
  class: "text-redText"
69
71
  },
@@ -85,4 +87,4 @@ export {
85
87
  TemplateEditor,
86
88
  handlebarsHighlightStyle
87
89
  };
88
- //# sourceMappingURL=chunk-VESVUAOS.mjs.map
90
+ //# sourceMappingURL=chunk-GAWXJ7K5.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/TemplateEditor/TemplateEditor.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { HighlightStyle, LanguageSupport, syntaxHighlighting } from '@codemirror/language';\nimport { styleTags, tags } from '@lezer/highlight';\nimport { handlebarsLanguage } from '@xiechao/codemirror-lang-handlebars';\nimport React from 'react';\n\nimport { type Template } from '@dxos/blueprints';\nimport { createDocAccessor } from '@dxos/react-client/echo';\nimport { type ThemedClassName, useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n createBasicExtensions,\n createDataExtensions,\n createThemeExtensions,\n useTextEditor,\n} from '@dxos/react-ui-editor';\nimport { mx } from '@dxos/react-ui-theme';\nimport { isNotFalsy } from '@dxos/util';\n\nimport { meta } from '../../meta';\n\nhandlebarsLanguage.configure({\n props: [\n styleTags({\n '---': tags.lineComment,\n }),\n ],\n});\n\nexport type TemplateEditorProps = ThemedClassName<{\n id: string;\n template: Template.Template;\n}>;\n\nexport const TemplateEditor = ({ id, classNames, template }: TemplateEditorProps) => {\n const { t } = useTranslation(meta.id);\n const { themeMode } = useThemeContext();\n const { parentRef } = useTextEditor(() => {\n const text = template.source?.target;\n return {\n initialValue: text?.content ?? '',\n extensions: [\n text &&\n createDataExtensions({\n id,\n text: createDocAccessor(text, ['content']),\n }),\n createBasicExtensions({\n bracketMatching: false,\n lineNumbers: true,\n lineWrapping: true,\n monospace: true,\n placeholder: t('template placeholder'),\n }),\n createThemeExtensions({\n themeMode,\n }),\n\n // https://github.com/xiechao/lang-handlebars\n new LanguageSupport(handlebarsLanguage, syntaxHighlighting(handlebarsHighlightStyle)),\n // createMarkdownExtensions({}),\n ].filter(isNotFalsy),\n };\n }, [themeMode, template.source?.target]);\n\n return <div ref={parentRef} className={mx('h-full overflow-hidden', classNames)} />;\n};\n\n/**\n * https://github.com/xiechao/lang-handlebars/blob/direct/src/highlight.js\n */\nexport const handlebarsHighlightStyle = HighlightStyle.define([\n {\n // Braces.\n tag: tags.tagName,\n class: 'text-redText',\n },\n {\n tag: tags.variableName,\n class: 'text-blueText',\n },\n {\n tag: tags.keyword,\n class: 'text-greenText',\n },\n {\n tag: tags.comment,\n class: 'text-subdued',\n },\n]);\n"],
5
+ "mappings": ";;;;;;;AAIA,SAASA,gBAAgBC,iBAAiBC,0BAA0B;AACpE,SAASC,WAAWC,YAAY;AAChC,SAASC,0BAA0B;AACnC,OAAOC,WAAW;AAGlB,SAASC,yBAAyB;AAClC,SAA+BC,iBAAiBC,sBAAsB;AACtE,SACEC,uBACAC,sBACAC,uBACAC,qBACK;AACP,SAASC,UAAU;AACnB,SAASC,kBAAkB;AAI3BC,mBAAmBC,UAAU;EAC3BC,OAAO;IACLC,UAAU;MACR,OAAOC,KAAKC;IACd,CAAA;;AAEJ,CAAA;AAOO,IAAMC,iBAAiB,CAAC,EAAEC,IAAIC,YAAYC,SAAQ,MAAuB;;;AAC9E,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKL,EAAE;AACpC,UAAM,EAAEM,UAAS,IAAKC,gBAAAA;AACtB,UAAM,EAAEC,UAAS,IAAKC,cAAc,MAAA;AAClC,YAAMC,OAAOR,SAASS,QAAQC;AAC9B,aAAO;QACLC,cAAcH,MAAMI,WAAW;QAC/BC,YAAY;UACVL,QACEM,qBAAqB;YACnBhB;YACAU,MAAMO,kBAAkBP,MAAM;cAAC;aAAU;UAC3C,CAAA;UACFQ,sBAAsB;YACpBC,iBAAiB;YACjBC,aAAa;YACbC,cAAc;YACdC,WAAW;YACXC,aAAapB,EAAE,sBAAA;UACjB,CAAA;UACAqB,sBAAsB;YACpBlB;UACF,CAAA;;UAGA,IAAImB,gBAAgBhC,oBAAoBiC,mBAAmBC,wBAAAA,CAAAA;UAE3DC,OAAOC,UAAAA;MACX;IACF,GAAG;MAACvB;MAAWJ,SAASS,QAAQC;KAAO;AAEvC,WAAO,sBAAA,cAACkB,OAAAA;MAAIC,KAAKvB;MAAWwB,WAAWC,GAAG,0BAA0BhC,UAAAA;;;;;AACtE;AAKO,IAAM0B,2BAA2BO,eAAeC,OAAO;EAC5D;;IAEEC,KAAKvC,KAAKwC;IACVC,OAAO;EACT;EACA;IACEF,KAAKvC,KAAK0C;IACVD,OAAO;EACT;EACA;IACEF,KAAKvC,KAAK2C;IACVF,OAAO;EACT;EACA;IACEF,KAAKvC,KAAK4C;IACVH,OAAO;EACT;CACD;",
6
+ "names": ["HighlightStyle", "LanguageSupport", "syntaxHighlighting", "styleTags", "tags", "handlebarsLanguage", "React", "createDocAccessor", "useThemeContext", "useTranslation", "createBasicExtensions", "createDataExtensions", "createThemeExtensions", "useTextEditor", "mx", "isNotFalsy", "handlebarsLanguage", "configure", "props", "styleTags", "tags", "lineComment", "TemplateEditor", "id", "classNames", "template", "t", "useTranslation", "meta", "themeMode", "useThemeContext", "parentRef", "useTextEditor", "text", "source", "target", "initialValue", "content", "extensions", "createDataExtensions", "createDocAccessor", "createBasicExtensions", "bracketMatching", "lineNumbers", "lineWrapping", "monospace", "placeholder", "createThemeExtensions", "LanguageSupport", "syntaxHighlighting", "handlebarsHighlightStyle", "filter", "isNotFalsy", "div", "ref", "className", "mx", "HighlightStyle", "define", "tag", "tagName", "class", "variableName", "keyword", "comment"]
7
+ }
@@ -0,0 +1,11 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ var __defProp = Object.defineProperty;
3
+ var __export = (target, all) => {
4
+ for (var name in all)
5
+ __defProp(target, name, { get: all[name], enumerable: true });
6
+ };
7
+
8
+ export {
9
+ __export
10
+ };
11
+ //# sourceMappingURL=chunk-HSLMI22Q.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
@@ -0,0 +1,245 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ LLM_PROVIDERS
4
+ } from "./chunk-F7RXCX5Y.mjs";
5
+ import {
6
+ meta
7
+ } from "./chunk-KOC6ESG7.mjs";
8
+
9
+ // src/components/AssistantSettings/AssistantSettings.tsx
10
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
11
+ import React from "react";
12
+ import { DEFAULT_EDGE_MODELS, DEFAULT_OLLAMA_MODELS } from "@dxos/ai";
13
+ import { Input, Select, useTranslation } from "@dxos/react-ui";
14
+ import { DeprecatedFormContainer, DeprecatedFormInput } from "@dxos/react-ui-form";
15
+ var DEFAULT_VALUE = "__default";
16
+ var LLM_PROVIDER_LABELS = {
17
+ edge: "DXOS",
18
+ ollama: "Ollama",
19
+ lmstudio: "LM Studio"
20
+ };
21
+ var AssistantSettings = ({ settings }) => {
22
+ var _effect = _useSignals();
23
+ try {
24
+ const { t } = useTranslation(meta.id);
25
+ return /* @__PURE__ */ React.createElement(DeprecatedFormContainer, null, /* @__PURE__ */ React.createElement(DeprecatedFormInput, {
26
+ label: t("settings custom prompts label")
27
+ }, /* @__PURE__ */ React.createElement(Input.Switch, {
28
+ checked: !!settings.customPrompts,
29
+ onCheckedChange: (checked) => settings.customPrompts = checked
30
+ })), /* @__PURE__ */ React.createElement(DeprecatedFormInput, {
31
+ label: t("settings llm provider label")
32
+ }, /* @__PURE__ */ React.createElement(Select.Root, {
33
+ value: settings.llmProvider ?? "edge",
34
+ onValueChange: (value) => {
35
+ settings.llmProvider = value === DEFAULT_VALUE ? void 0 : value;
36
+ }
37
+ }, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
38
+ placeholder: t("settings llm provider label")
39
+ }), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, /* @__PURE__ */ React.createElement(Select.Option, {
40
+ value: DEFAULT_VALUE
41
+ }, t("settings default label")), LLM_PROVIDERS.map((model) => /* @__PURE__ */ React.createElement(Select.Option, {
42
+ key: model,
43
+ value: model
44
+ }, LLM_PROVIDER_LABELS[model]))))))), /* @__PURE__ */ React.createElement(DeprecatedFormInput, {
45
+ label: t("settings edge llm model label")
46
+ }, /* @__PURE__ */ React.createElement(Select.Root, {
47
+ value: settings.edgeModel ?? DEFAULT_VALUE,
48
+ onValueChange: (value) => {
49
+ settings.edgeModel = value === DEFAULT_VALUE ? void 0 : value;
50
+ }
51
+ }, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
52
+ placeholder: t("settings default llm model label")
53
+ }), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, /* @__PURE__ */ React.createElement(Select.Option, {
54
+ value: DEFAULT_VALUE
55
+ }, t("settings default label")), DEFAULT_EDGE_MODELS.map((model) => /* @__PURE__ */ React.createElement(Select.Option, {
56
+ key: model,
57
+ value: model
58
+ }, model))))))), /* @__PURE__ */ React.createElement(DeprecatedFormInput, {
59
+ label: t("settings ollama llm model label")
60
+ }, /* @__PURE__ */ React.createElement(Select.Root, {
61
+ value: settings.ollamaModel ?? DEFAULT_VALUE,
62
+ onValueChange: (value) => {
63
+ settings.ollamaModel = value === DEFAULT_VALUE ? void 0 : value;
64
+ }
65
+ }, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
66
+ placeholder: t("settings default llm model label")
67
+ }), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, /* @__PURE__ */ React.createElement(Select.Option, {
68
+ value: DEFAULT_VALUE
69
+ }, t("settings default label")), DEFAULT_OLLAMA_MODELS.map((model) => /* @__PURE__ */ React.createElement(Select.Option, {
70
+ key: model,
71
+ value: model
72
+ }, model))))))));
73
+ } finally {
74
+ _effect.f();
75
+ }
76
+ };
77
+
78
+ // src/components/PromptSettings.tsx
79
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
80
+ import React2 from "react";
81
+ import { Toolbar, useTranslation as useTranslation2 } from "@dxos/react-ui";
82
+ var PromptSettings = ({ template }) => {
83
+ var _effect = _useSignals2();
84
+ try {
85
+ const { t } = useTranslation2(meta.id);
86
+ return /* @__PURE__ */ React2.createElement("div", {
87
+ className: "flex flex-col gap-4"
88
+ }, /* @__PURE__ */ React2.createElement("h2", null, t("prompt rules label")), /* @__PURE__ */ React2.createElement(Toolbar.Root, null));
89
+ } finally {
90
+ _effect.f();
91
+ }
92
+ };
93
+
94
+ // src/components/Timeline/Timeline.tsx
95
+ import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
96
+ import React3, { Fragment, useMemo } from "react";
97
+ import { mx } from "@dxos/react-ui-theme";
98
+ import { trim } from "@dxos/util";
99
+ var Timeline = ({ classNames, branches, commits }) => {
100
+ var _effect = _useSignals3();
101
+ try {
102
+ const spans = useMemo(() => {
103
+ const spans2 = /* @__PURE__ */ new Map();
104
+ branches.forEach((branch) => {
105
+ spans2.set(branch.name, {
106
+ start: -1,
107
+ end: -1
108
+ });
109
+ });
110
+ commits.forEach((commit, index) => {
111
+ const span = spans2.get(commit.branch);
112
+ if (span) {
113
+ if (span.start === -1) {
114
+ const parentIndex = commit.parent ? commits.findIndex((c) => c.id === commit.parent) : 0;
115
+ span.start = parentIndex;
116
+ span.parent = commit.parent ? branches.findIndex((branch) => branch.name === commits[parentIndex].branch) : void 0;
117
+ }
118
+ span.end = index;
119
+ }
120
+ });
121
+ return spans2;
122
+ }, [
123
+ commits,
124
+ branches
125
+ ]);
126
+ return /* @__PURE__ */ React3.createElement("div", {
127
+ className: mx("flex flex-col w-full overflow-hidden", classNames)
128
+ }, commits.map((commit, index) => {
129
+ return /* @__PURE__ */ React3.createElement("div", {
130
+ key: commit.id,
131
+ className: "group flex items-center gap-2 overflow-hidden hover:bg-hoverSurface",
132
+ style: {
133
+ height: `${lineHeight}px`
134
+ }
135
+ }, /* @__PURE__ */ React3.createElement("svg", {
136
+ width: branches.length * columnWidth,
137
+ height: lineHeight,
138
+ className: "shrink-0"
139
+ }, branches.map((branch, j) => {
140
+ const span = spans.get(branch.name);
141
+ const color = colors[j % colors.length];
142
+ if (!span) {
143
+ return null;
144
+ }
145
+ return /* @__PURE__ */ React3.createElement(Fragment, {
146
+ key: j
147
+ }, index !== 0 && span.start !== -1 && span.start < index && span.end >= index && /* @__PURE__ */ React3.createElement("line", {
148
+ x1: j * columnWidth + columnWidth / 2,
149
+ y1: 0,
150
+ x2: j * columnWidth + columnWidth / 2,
151
+ y2: lineHeight / 2,
152
+ className: mx("stroke-2", color.stroke)
153
+ }), span.end !== -1 && (span.start < index || span.start === 0) && index < span.end && /* @__PURE__ */ React3.createElement("line", {
154
+ x1: j * columnWidth + columnWidth / 2,
155
+ y1: lineHeight / 2,
156
+ x2: j * columnWidth + columnWidth / 2,
157
+ y2: lineHeight,
158
+ className: mx("stroke-2", color.stroke)
159
+ }), span.start === index && span.parent !== void 0 && span.parent !== -1 && /* @__PURE__ */ React3.createElement("path", {
160
+ d: trim`
161
+ M ${0.5 + span.parent * columnWidth + columnWidth / 2} ${lineHeight / 2}
162
+ L ${j * columnWidth + columnWidth / 4} ${lineHeight / 2}
163
+ A ${lineHeight / 4} ${lineHeight / 4} 0 0 1 ${j * columnWidth + columnWidth / 2} ${lineHeight * 3 / 4}
164
+ L ${j * columnWidth + columnWidth / 2} ${lineHeight}
165
+ `,
166
+ className: mx("stroke-2", color.stroke),
167
+ fill: "none"
168
+ }), branch.name === commit.branch && /* @__PURE__ */ React3.createElement("circle", {
169
+ cx: j * columnWidth + columnWidth / 2,
170
+ cy: lineHeight / 2,
171
+ r: nodeRadius,
172
+ className: mx("stroke-2 fill-red-500", color.stroke, color.hover)
173
+ }));
174
+ }), branches.map((branch, j) => {
175
+ const color = colors[j % colors.length];
176
+ return branch.name === commit.branch && /* @__PURE__ */ React3.createElement("circle", {
177
+ key: j,
178
+ cx: j * columnWidth + columnWidth / 2,
179
+ cy: lineHeight / 2,
180
+ r: nodeRadius,
181
+ className: mx("stroke-2", color.stroke, color.hover)
182
+ });
183
+ })), /* @__PURE__ */ React3.createElement("div", {
184
+ className: "text-sm truncate cursor-pointer text-subdued group-hover:text-baseText"
185
+ }, commit.message));
186
+ }));
187
+ } finally {
188
+ _effect.f();
189
+ }
190
+ };
191
+ var lineHeight = 24;
192
+ var columnWidth = 24;
193
+ var nodeRadius = 6;
194
+ var colors = [
195
+ {
196
+ stroke: "stroke-orange-500",
197
+ hover: "group-hover:fill-orange-500"
198
+ },
199
+ {
200
+ stroke: "stroke-sky-500",
201
+ hover: "group-hover:fill-sky-500"
202
+ },
203
+ {
204
+ stroke: "stroke-green-500",
205
+ hover: "group-hover:fill-green-500"
206
+ },
207
+ {
208
+ stroke: "stroke-fuchsia-500",
209
+ hover: "group-hover:fill-fuchsia-500"
210
+ },
211
+ {
212
+ stroke: "stroke-cyan-500",
213
+ hover: "group-hover:fill-cyan-500"
214
+ },
215
+ {
216
+ stroke: "stroke-emerald-500",
217
+ hover: "group-hover:fill-emerald-500"
218
+ },
219
+ {
220
+ stroke: "stroke-violet-500",
221
+ hover: "group-hover:fill-violet-500"
222
+ },
223
+ {
224
+ stroke: "stroke-teal-500",
225
+ hover: "group-hover:fill-teal-500"
226
+ }
227
+ ];
228
+
229
+ // src/components/index.ts
230
+ import { lazy } from "react";
231
+ var BlueprintContainer = lazy(() => import("./BlueprintContainer-VH4EE4CM.mjs"));
232
+ var ChatContainer = lazy(() => import("./ChatContainer-D5FABDNE.mjs"));
233
+ var ChatDialog = lazy(() => import("./ChatDialog-NKWVXHJP.mjs"));
234
+ var SequenceContainer = lazy(() => import("./SequenceContainer-EQ5NP2PG.mjs"));
235
+
236
+ export {
237
+ AssistantSettings,
238
+ PromptSettings,
239
+ Timeline,
240
+ BlueprintContainer,
241
+ ChatContainer,
242
+ ChatDialog,
243
+ SequenceContainer
244
+ };
245
+ //# sourceMappingURL=chunk-RD755HN3.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/AssistantSettings/AssistantSettings.tsx", "../../../src/components/PromptSettings.tsx", "../../../src/components/Timeline/Timeline.tsx", "../../../src/components/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { DEFAULT_EDGE_MODELS, DEFAULT_OLLAMA_MODELS } from '@dxos/ai';\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { DeprecatedFormContainer, DeprecatedFormInput } from '@dxos/react-ui-form';\n\nimport { meta } from '../../meta';\nimport { type Assistant, LLM_PROVIDERS } from '../../types';\n\n// TODO(burdon): Factor out default Selector.\nconst DEFAULT_VALUE = '__default';\n\nconst LLM_PROVIDER_LABELS = {\n edge: 'DXOS',\n ollama: 'Ollama',\n lmstudio: 'LM Studio',\n} as const;\n\nexport const AssistantSettings = ({ settings }: { settings: Assistant.Settings }) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <DeprecatedFormContainer>\n <DeprecatedFormInput label={t('settings custom prompts label')}>\n <Input.Switch\n checked={!!settings.customPrompts}\n onCheckedChange={(checked) => (settings.customPrompts = checked)}\n />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings llm provider label')}>\n <Select.Root\n value={settings.llmProvider ?? 'edge'}\n onValueChange={(value) => {\n settings.llmProvider = value === DEFAULT_VALUE ? undefined : (value as any);\n }}\n >\n <Select.TriggerButton placeholder={t('settings llm provider label')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n <Select.Option value={DEFAULT_VALUE}>{t('settings default label')}</Select.Option>\n {LLM_PROVIDERS.map((model) => (\n <Select.Option key={model} value={model}>\n {LLM_PROVIDER_LABELS[model]}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings edge llm model label')}>\n <Select.Root\n value={settings.edgeModel ?? DEFAULT_VALUE}\n onValueChange={(value) => {\n settings.edgeModel = value === DEFAULT_VALUE ? undefined : value;\n }}\n >\n <Select.TriggerButton placeholder={t('settings default llm model label')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n <Select.Option value={DEFAULT_VALUE}>{t('settings default label')}</Select.Option>\n {DEFAULT_EDGE_MODELS.map((model) => (\n <Select.Option key={model} value={model}>\n {model}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings ollama llm model label')}>\n <Select.Root\n value={settings.ollamaModel ?? DEFAULT_VALUE}\n onValueChange={(value) => {\n settings.ollamaModel = value === DEFAULT_VALUE ? undefined : value;\n }}\n >\n <Select.TriggerButton placeholder={t('settings default llm model label')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n <Select.Option value={DEFAULT_VALUE}>{t('settings default label')}</Select.Option>\n {DEFAULT_OLLAMA_MODELS.map((model) => (\n <Select.Option key={model} value={model}>\n {model}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n </DeprecatedFormContainer>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type Template } from '@dxos/blueprints';\nimport { Toolbar, useTranslation } from '@dxos/react-ui';\n\nimport { meta } from '../meta';\n\nexport const PromptSettings = ({ template }: { template: Template.Template }) => {\n const { t } = useTranslation(meta.id);\n\n // const handleKindChange = useCallback(\n // (value: string) => {\n // const kind = Match.type<string>().pipe(\n // Match.withReturnType<Schema.Schema.Type<typeof Template.Template>>(),\n // Match.when('always', () => ({ include: 'always' })),\n // Match.when('schema-matching', () => ({ include: 'schema-matching', typename: '' })),\n // Match.when('automatically', () => ({ include: 'automatically', description: '' })),\n // Match.orElse(() => ({ include: 'manual' })),\n // )(value);\n //\n // template.kind = kind;\n // },\n // [template],\n // );\n\n // const handleTypenameChange = useCallback(\n // debounce((event: ChangeEvent<HTMLInputElement>) => {\n // if (template.kind.include === 'schema-matching') {\n // template.kind.typename = event.target.value;\n // }\n // }, 300),\n // [template.kind.include],\n // );\n\n // const handleDescriptionChange = useCallback(\n // debounce((event: ChangeEvent<HTMLInputElement>) => {\n // if (template.kind.include === 'automatically') {\n // template.kind.description = event.target.value;\n // }\n // }, 300),\n // [template.kind.include],\n // );\n\n return (\n <div className='flex flex-col gap-4'>\n <h2>{t('prompt rules label')}</h2>\n <Toolbar.Root>\n {/* <Select.Root value={template.kind.include} onValueChange={handleKindChange}>\n <Toolbar.Button asChild>\n <Select.TriggerButton />\n </Toolbar.Button>\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {Template.Kinds.map((kind) => (\n <Select.Option key={kind} value={kind}>\n {kind}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root> */}\n {/* {template.kind.include === 'schema-matching' && (\n <Input.Root>\n <Input.TextInput\n placeholder={t('typename placeholder')}\n defaultValue={template.kind.typename}\n onChange={handleTypenameChange}\n />\n </Input.Root>\n )} */}\n {/* {template.kind.include === 'automatically' && (\n <Input.Root>\n <Input.TextInput\n placeholder={t('description placeholder')}\n defaultValue={template.kind.description}\n onChange={handleDescriptionChange}\n />\n </Input.Root>\n )} */}\n </Toolbar.Root>\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { Fragment, useMemo } from 'react';\n\nimport { type ThemedClassName } from '@dxos/react-ui';\nimport { mx } from '@dxos/react-ui-theme';\nimport { trim } from '@dxos/util';\n\nexport type Commit = {\n id: string;\n parent?: string;\n branch: string;\n message: string;\n timestamp?: Date;\n tags?: string[];\n};\n\nexport type Branch = {\n name: string;\n};\n\nexport type Span = {\n start: number;\n end: number;\n parent?: number;\n};\n\nexport type TimelineProps = ThemedClassName<{ branches: Branch[]; commits: Commit[] }>;\n\n// TODO(burdon): Reuse in toolCall messages.\n// TODO(burdon): Key up/down; selected.\nexport const Timeline = ({ classNames, branches, commits }: TimelineProps) => {\n const spans = useMemo(() => {\n const spans = new Map<string, Span>();\n branches.forEach((branch) => {\n spans.set(branch.name, { start: -1, end: -1 });\n });\n\n commits.forEach((commit, index) => {\n const span = spans.get(commit.branch);\n if (span) {\n if (span.start === -1) {\n const parentIndex = commit.parent ? commits.findIndex((c) => c.id === commit.parent) : 0;\n span.start = parentIndex;\n span.parent = commit.parent\n ? branches.findIndex((branch) => branch.name === commits[parentIndex].branch)\n : undefined;\n }\n span.end = index;\n }\n });\n\n return spans;\n }, [commits, branches]);\n\n return (\n <div className={mx('flex flex-col w-full overflow-hidden', classNames)}>\n {commits.map((commit, index) => {\n return (\n <div\n key={commit.id}\n className='group flex items-center gap-2 overflow-hidden hover:bg-hoverSurface'\n style={{ height: `${lineHeight}px` }}\n >\n <svg width={branches.length * columnWidth} height={lineHeight} className='shrink-0'>\n {branches.map((branch, j) => {\n const span = spans.get(branch.name);\n const color = colors[j % colors.length];\n if (!span) {\n return null;\n }\n\n return (\n <Fragment key={j}>\n {/* Upper */}\n {index !== 0 && span.start !== -1 && span.start < index && span.end >= index && (\n <line\n x1={j * columnWidth + columnWidth / 2}\n y1={0}\n x2={j * columnWidth + columnWidth / 2}\n y2={lineHeight / 2}\n className={mx('stroke-2', color.stroke)}\n />\n )}\n {/* Lower */}\n {span.end !== -1 && (span.start < index || span.start === 0) && index < span.end && (\n <line\n x1={j * columnWidth + columnWidth / 2}\n y1={lineHeight / 2}\n x2={j * columnWidth + columnWidth / 2}\n y2={lineHeight}\n className={mx('stroke-2', color.stroke)}\n />\n )}\n {/* Arc to parent */}\n {span.start === index && span.parent !== undefined && span.parent !== -1 && (\n <path\n d={trim`\n M ${0.5 + span.parent * columnWidth + columnWidth / 2} ${lineHeight / 2} \n L ${j * columnWidth + columnWidth / 4} ${lineHeight / 2} \n A ${lineHeight / 4} ${lineHeight / 4} 0 0 1 ${j * columnWidth + columnWidth / 2} ${(lineHeight * 3) / 4} \n L ${j * columnWidth + columnWidth / 2} ${lineHeight}\n `}\n className={mx('stroke-2', color.stroke)}\n fill='none'\n />\n )}\n {branch.name === commit.branch && (\n <circle\n cx={j * columnWidth + columnWidth / 2}\n cy={lineHeight / 2}\n r={nodeRadius}\n className={mx('stroke-2 fill-red-500', color.stroke, color.hover)}\n />\n )}\n </Fragment>\n );\n })}\n {branches.map((branch, j) => {\n const color = colors[j % colors.length];\n return (\n branch.name === commit.branch && (\n <circle\n key={j}\n cx={j * columnWidth + columnWidth / 2}\n cy={lineHeight / 2}\n r={nodeRadius}\n className={mx('stroke-2', color.stroke, color.hover)}\n />\n )\n );\n })}\n </svg>\n <div className='text-sm truncate cursor-pointer text-subdued group-hover:text-baseText'>\n {commit.message}\n </div>\n </div>\n );\n })}\n </div>\n );\n};\n\nconst lineHeight = 24;\nconst columnWidth = 24;\nconst nodeRadius = 6;\n\nconst colors = [\n { stroke: 'stroke-orange-500', hover: 'group-hover:fill-orange-500' },\n { stroke: 'stroke-sky-500', hover: 'group-hover:fill-sky-500' },\n { stroke: 'stroke-green-500', hover: 'group-hover:fill-green-500' },\n { stroke: 'stroke-fuchsia-500', hover: 'group-hover:fill-fuchsia-500' },\n { stroke: 'stroke-cyan-500', hover: 'group-hover:fill-cyan-500' },\n { stroke: 'stroke-emerald-500', hover: 'group-hover:fill-emerald-500' },\n { stroke: 'stroke-violet-500', hover: 'group-hover:fill-violet-500' },\n { stroke: 'stroke-teal-500', hover: 'group-hover:fill-teal-500' },\n];\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './AssistantSettings';\nexport * from './Chat';\nexport * from './PromptSettings';\nexport * from './TemplateEditor';\nexport * from './Timeline';\nexport * from './Toolbox';\n\nexport const BlueprintContainer = lazy(() => import('./BlueprintContainer'));\nexport const ChatContainer = lazy(() => import('./ChatContainer'));\nexport const ChatDialog = lazy(() => import('./ChatDialog'));\nexport const SequenceContainer = lazy(() => import('./SequenceContainer'));\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "DEFAULT_EDGE_MODELS", "DEFAULT_OLLAMA_MODELS", "Input", "Select", "useTranslation", "DeprecatedFormContainer", "DeprecatedFormInput", "DEFAULT_VALUE", "LLM_PROVIDER_LABELS", "edge", "ollama", "lmstudio", "AssistantSettings", "settings", "t", "useTranslation", "meta", "id", "DeprecatedFormContainer", "DeprecatedFormInput", "label", "Input", "Switch", "checked", "customPrompts", "onCheckedChange", "Select", "Root", "value", "llmProvider", "onValueChange", "undefined", "TriggerButton", "placeholder", "Portal", "Content", "Viewport", "Option", "LLM_PROVIDERS", "map", "model", "key", "edgeModel", "DEFAULT_EDGE_MODELS", "ollamaModel", "DEFAULT_OLLAMA_MODELS", "React", "Toolbar", "useTranslation", "PromptSettings", "template", "t", "useTranslation", "meta", "id", "React", "div", "className", "h2", "Toolbar", "Root", "React", "Fragment", "useMemo", "mx", "trim", "Timeline", "classNames", "branches", "commits", "spans", "useMemo", "Map", "forEach", "branch", "set", "name", "start", "end", "commit", "index", "span", "get", "parentIndex", "parent", "findIndex", "c", "id", "undefined", "React", "div", "className", "mx", "map", "key", "style", "height", "lineHeight", "svg", "width", "length", "columnWidth", "j", "color", "colors", "Fragment", "line", "x1", "y1", "x2", "y2", "stroke", "path", "d", "trim", "fill", "circle", "cx", "cy", "r", "nodeRadius", "hover", "message", "lazy", "BlueprintContainer", "lazy", "ChatContainer", "ChatDialog", "SequenceContainer"]
7
+ }
@@ -6,11 +6,12 @@ import {
6
6
  // src/capabilities/capabilities.ts
7
7
  import { defineCapability } from "@dxos/app-framework";
8
8
  (function(AssistantCapabilities2) {
9
- AssistantCapabilities2.AiClient = defineCapability(`${meta.id}/capability/ai-client`);
9
+ AssistantCapabilities2.AiServiceLayer = defineCapability(`${meta.id}/capability/ai-service-factory`);
10
+ AssistantCapabilities2.AiModelResolver = defineCapability(`${meta.id}/capability/ai-model-resolver`);
10
11
  })(AssistantCapabilities || (AssistantCapabilities = {}));
11
12
  var AssistantCapabilities;
12
13
 
13
14
  export {
14
15
  AssistantCapabilities
15
16
  };
16
- //# sourceMappingURL=chunk-E6V2RUQ2.mjs.map
17
+ //# sourceMappingURL=chunk-X6AANUHZ.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/capabilities.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Layer } from 'effect';\n\nimport { type AiService, type AiServiceRouter } from '@dxos/ai';\nimport { defineCapability } from '@dxos/app-framework';\n\nimport { meta } from '../meta';\n\nexport namespace AssistantCapabilities {\n export type AiServiceLayer = Layer.Layer<AiService.AiService>;\n export const AiServiceLayer = defineCapability<AiServiceLayer>(`${meta.id}/capability/ai-service-factory`);\n\n /**\n * Plugins can contribute them to provide model resolvers.\n */\n export const AiModelResolver = defineCapability<Layer.Layer<AiServiceRouter.AiModelResolver>>(\n `${meta.id}/capability/ai-model-resolver`,\n );\n}\n"],
5
+ "mappings": ";;;;;;AAOA,SAASA,wBAAwB;UAIhBC,wBAAAA;yBAEFC,iBAAiBC,iBAAiC,GAAGC,KAAKC,EAAE,gCAAgC;yBAK5FC,kBAAkBH,iBAC7B,GAAGC,KAAKC,EAAE,+BAA+B;AAE7C,GAViBJ,0BAAAA,wBAAAA,CAAAA,EAAAA;;",
6
+ "names": ["defineCapability", "AssistantCapabilities", "AiServiceLayer", "defineCapability", "meta", "id", "AiModelResolver"]
7
+ }
@@ -0,0 +1,25 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ AssistantCapabilities
4
+ } from "./chunk-X6AANUHZ.mjs";
5
+ import "./chunk-KOC6ESG7.mjs";
6
+ import "./chunk-HSLMI22Q.mjs";
7
+
8
+ // src/capabilities/edge-model-resolver.ts
9
+ import { AnthropicClient } from "@effect/ai-anthropic";
10
+ import { FetchHttpClient } from "@effect/platform";
11
+ import { Layer } from "effect";
12
+ import { AiServiceRouter } from "@dxos/ai";
13
+ import { contributes } from "@dxos/app-framework";
14
+ var edge_model_resolver_default = () => {
15
+ return [
16
+ contributes(AssistantCapabilities.AiModelResolver, AiServiceRouter.AnthropicResolver.pipe(Layer.provide(AnthropicClient.layer({
17
+ // TODO(dmaretskyi): Read endpoint from config/settings.
18
+ apiUrl: "https://ai-service.dxos.workers.dev/provider/anthropic"
19
+ })), Layer.provide(FetchHttpClient.layer)))
20
+ ];
21
+ };
22
+ export {
23
+ edge_model_resolver_default as default
24
+ };
25
+ //# sourceMappingURL=edge-model-resolver-UDDR2IA6.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/edge-model-resolver.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { AnthropicClient } from '@effect/ai-anthropic';\nimport { FetchHttpClient } from '@effect/platform';\nimport { Layer } from 'effect';\n\nimport { AiServiceRouter } from '@dxos/ai';\nimport { contributes } from '@dxos/app-framework';\n\nimport { AssistantCapabilities } from './capabilities';\n\nexport default () => {\n return [\n contributes(\n AssistantCapabilities.AiModelResolver,\n AiServiceRouter.AnthropicResolver.pipe(\n Layer.provide(\n AnthropicClient.layer({\n // TODO(dmaretskyi): Read endpoint from config/settings.\n apiUrl: 'https://ai-service.dxos.workers.dev/provider/anthropic',\n }),\n ),\n Layer.provide(FetchHttpClient.layer),\n ),\n ),\n ];\n};\n"],
5
+ "mappings": ";;;;;;;;AAIA,SAASA,uBAAuB;AAChC,SAASC,uBAAuB;AAChC,SAASC,aAAa;AAEtB,SAASC,uBAAuB;AAChC,SAASC,mBAAmB;AAI5B,IAAA,8BAAe,MAAA;AACb,SAAO;IACLC,YACEC,sBAAsBC,iBACtBC,gBAAgBC,kBAAkBC,KAChCC,MAAMC,QACJC,gBAAgBC,MAAM;;MAEpBC,QAAQ;IACV,CAAA,CAAA,GAEFJ,MAAMC,QAAQI,gBAAgBF,KAAK,CAAA,CAAA;;AAI3C;",
6
+ "names": ["AnthropicClient", "FetchHttpClient", "Layer", "AiServiceRouter", "contributes", "contributes", "AssistantCapabilities", "AiModelResolver", "AiServiceRouter", "AnthropicResolver", "pipe", "Layer", "provide", "AnthropicClient", "layer", "apiUrl", "FetchHttpClient"]
7
+ }