@dxos/plugin-assistant 0.8.4-main.c4373fc → 0.8.4-main.c85a9c8dae

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 (681) hide show
  1. package/dist/lib/browser/AssistantSettings-2LFAG5OQ.mjs +93 -0
  2. package/dist/lib/browser/AssistantSettings-2LFAG5OQ.mjs.map +7 -0
  3. package/dist/lib/browser/BlueprintArticle-CCS25MNW.mjs +36 -0
  4. package/dist/lib/browser/BlueprintArticle-CCS25MNW.mjs.map +7 -0
  5. package/dist/lib/browser/ChatCompanion-UGD4V34A.mjs +202 -0
  6. package/dist/lib/browser/ChatCompanion-UGD4V34A.mjs.map +7 -0
  7. package/dist/lib/browser/ChatContainer-ZGRSZ5EU.mjs +12 -0
  8. package/dist/lib/browser/ChatDialog-AET7GVIB.mjs +85 -0
  9. package/dist/lib/browser/ChatDialog-AET7GVIB.mjs.map +7 -0
  10. package/dist/lib/browser/ProjectArticle-QDBTIFNE.mjs +91 -0
  11. package/dist/lib/browser/ProjectArticle-QDBTIFNE.mjs.map +7 -0
  12. package/dist/lib/browser/ProjectSettings-R6RRARLO.mjs +194 -0
  13. package/dist/lib/browser/ProjectSettings-R6RRARLO.mjs.map +7 -0
  14. package/dist/lib/browser/PromptArticle-USQO4WX6.mjs +71 -0
  15. package/dist/lib/browser/PromptArticle-USQO4WX6.mjs.map +7 -0
  16. package/dist/lib/browser/TriggerStatus-65X3EUSN.mjs +122 -0
  17. package/dist/lib/browser/TriggerStatus-65X3EUSN.mjs.map +7 -0
  18. package/dist/lib/browser/ai-service-CY2BYPH6.mjs +22 -0
  19. package/dist/lib/browser/ai-service-CY2BYPH6.mjs.map +7 -0
  20. package/dist/lib/browser/app-graph-builder-SFYYUKTT.mjs +234 -0
  21. package/dist/lib/browser/app-graph-builder-SFYYUKTT.mjs.map +7 -0
  22. package/dist/lib/browser/blueprint-definition-RB5RHZZM.mjs +34 -0
  23. package/dist/lib/browser/blueprint-definition-RB5RHZZM.mjs.map +7 -0
  24. package/dist/lib/browser/blueprints/index.mjs +8 -0
  25. package/dist/lib/browser/chunk-7DXYAXLZ.mjs +230 -0
  26. package/dist/lib/browser/chunk-7DXYAXLZ.mjs.map +7 -0
  27. package/dist/lib/browser/chunk-EXVT7D4B.mjs +23 -0
  28. package/dist/lib/browser/chunk-EXVT7D4B.mjs.map +7 -0
  29. package/dist/lib/browser/chunk-JYY5AD65.mjs +286 -0
  30. package/dist/lib/browser/chunk-JYY5AD65.mjs.map +7 -0
  31. package/dist/lib/browser/chunk-LEXIQDXZ.mjs +26 -0
  32. package/dist/lib/browser/chunk-LEXIQDXZ.mjs.map +7 -0
  33. package/dist/lib/browser/chunk-RU4G5NY4.mjs +69 -0
  34. package/dist/lib/browser/chunk-RU4G5NY4.mjs.map +7 -0
  35. package/dist/lib/browser/chunk-UUA6GNGG.mjs +2125 -0
  36. package/dist/lib/browser/chunk-UUA6GNGG.mjs.map +7 -0
  37. package/dist/lib/browser/edge-model-resolver-YTMFQEN5.mjs +21 -0
  38. package/dist/lib/browser/edge-model-resolver-YTMFQEN5.mjs.map +7 -0
  39. package/dist/lib/browser/index.mjs +271 -226
  40. package/dist/lib/browser/index.mjs.map +4 -4
  41. package/dist/lib/browser/local-model-resolver-CGRQH37T.mjs +20 -0
  42. package/dist/lib/browser/local-model-resolver-CGRQH37T.mjs.map +7 -0
  43. package/dist/lib/browser/meta.json +1 -1
  44. package/dist/lib/browser/operation-resolver-ELXDQZEG.mjs +136 -0
  45. package/dist/lib/browser/operation-resolver-ELXDQZEG.mjs.map +7 -0
  46. package/dist/lib/browser/react-surface-KYQSZO2I.mjs +144 -0
  47. package/dist/lib/browser/react-surface-KYQSZO2I.mjs.map +7 -0
  48. package/dist/lib/browser/repair-ZFZWZALX.mjs +52 -0
  49. package/dist/lib/browser/repair-ZFZWZALX.mjs.map +7 -0
  50. package/dist/lib/browser/settings-YREVQAZ5.mjs +33 -0
  51. package/dist/lib/browser/settings-YREVQAZ5.mjs.map +7 -0
  52. package/dist/lib/browser/state-MPG42ZO4.mjs +26 -0
  53. package/dist/lib/browser/state-MPG42ZO4.mjs.map +7 -0
  54. package/dist/lib/browser/toolkit-XRSBBB3L.mjs +16 -0
  55. package/dist/lib/browser/toolkit-XRSBBB3L.mjs.map +7 -0
  56. package/dist/lib/browser/types/index.mjs +8 -4
  57. package/dist/lib/node-esm/AssistantSettings-QWFEMJG7.mjs +94 -0
  58. package/dist/lib/node-esm/AssistantSettings-QWFEMJG7.mjs.map +7 -0
  59. package/dist/lib/node-esm/BlueprintArticle-SNEN6LOY.mjs +37 -0
  60. package/dist/lib/node-esm/BlueprintArticle-SNEN6LOY.mjs.map +7 -0
  61. package/dist/lib/node-esm/ChatCompanion-NP4R5BFE.mjs +203 -0
  62. package/dist/lib/node-esm/ChatCompanion-NP4R5BFE.mjs.map +7 -0
  63. package/dist/lib/node-esm/ChatContainer-IFHDIFJH.mjs +13 -0
  64. package/dist/lib/node-esm/ChatContainer-IFHDIFJH.mjs.map +7 -0
  65. package/dist/lib/node-esm/ChatDialog-UZNQBTKZ.mjs +86 -0
  66. package/dist/lib/node-esm/ChatDialog-UZNQBTKZ.mjs.map +7 -0
  67. package/dist/lib/node-esm/ProjectArticle-BCIBESJN.mjs +92 -0
  68. package/dist/lib/node-esm/ProjectArticle-BCIBESJN.mjs.map +7 -0
  69. package/dist/lib/node-esm/ProjectSettings-Q5QY6BYS.mjs +195 -0
  70. package/dist/lib/node-esm/ProjectSettings-Q5QY6BYS.mjs.map +7 -0
  71. package/dist/lib/node-esm/PromptArticle-PGMJMQK7.mjs +72 -0
  72. package/dist/lib/node-esm/PromptArticle-PGMJMQK7.mjs.map +7 -0
  73. package/dist/lib/node-esm/TriggerStatus-UR5S7PXJ.mjs +123 -0
  74. package/dist/lib/node-esm/TriggerStatus-UR5S7PXJ.mjs.map +7 -0
  75. package/dist/lib/node-esm/ai-service-ZI3A6RVG.mjs +23 -0
  76. package/dist/lib/node-esm/ai-service-ZI3A6RVG.mjs.map +7 -0
  77. package/dist/lib/node-esm/app-graph-builder-E25JXI34.mjs +235 -0
  78. package/dist/lib/node-esm/app-graph-builder-E25JXI34.mjs.map +7 -0
  79. package/dist/lib/node-esm/blueprint-definition-L7XKRYIW.mjs +35 -0
  80. package/dist/lib/node-esm/blueprint-definition-L7XKRYIW.mjs.map +7 -0
  81. package/dist/lib/node-esm/blueprints/index.mjs +9 -0
  82. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  83. package/dist/lib/node-esm/chunk-3QBVFAYO.mjs +28 -0
  84. package/dist/lib/node-esm/chunk-3QBVFAYO.mjs.map +7 -0
  85. package/dist/lib/node-esm/chunk-6NCLKQCL.mjs +70 -0
  86. package/dist/lib/node-esm/chunk-6NCLKQCL.mjs.map +7 -0
  87. package/dist/lib/node-esm/chunk-GZ4ERNT2.mjs +2126 -0
  88. package/dist/lib/node-esm/chunk-GZ4ERNT2.mjs.map +7 -0
  89. package/dist/lib/node-esm/chunk-JMBYVUD6.mjs +288 -0
  90. package/dist/lib/node-esm/chunk-JMBYVUD6.mjs.map +7 -0
  91. package/dist/lib/node-esm/chunk-MWYYLALM.mjs +231 -0
  92. package/dist/lib/node-esm/chunk-MWYYLALM.mjs.map +7 -0
  93. package/dist/lib/node-esm/{chunk-73ABYRYX.mjs → chunk-POWB2BPC.mjs} +7 -2
  94. package/dist/lib/node-esm/chunk-POWB2BPC.mjs.map +7 -0
  95. package/dist/lib/node-esm/edge-model-resolver-CMJ3KNLQ.mjs +22 -0
  96. package/dist/lib/node-esm/edge-model-resolver-CMJ3KNLQ.mjs.map +7 -0
  97. package/dist/lib/node-esm/index.mjs +271 -226
  98. package/dist/lib/node-esm/index.mjs.map +4 -4
  99. package/dist/lib/node-esm/local-model-resolver-FFDAKOXN.mjs +21 -0
  100. package/dist/lib/node-esm/local-model-resolver-FFDAKOXN.mjs.map +7 -0
  101. package/dist/lib/node-esm/meta.json +1 -1
  102. package/dist/lib/node-esm/operation-resolver-Q5GNP2GH.mjs +137 -0
  103. package/dist/lib/node-esm/operation-resolver-Q5GNP2GH.mjs.map +7 -0
  104. package/dist/lib/node-esm/react-surface-JJRGVGKD.mjs +145 -0
  105. package/dist/lib/node-esm/react-surface-JJRGVGKD.mjs.map +7 -0
  106. package/dist/lib/node-esm/repair-LXFVOK4B.mjs +53 -0
  107. package/dist/lib/node-esm/repair-LXFVOK4B.mjs.map +7 -0
  108. package/dist/lib/node-esm/settings-N452OW6Y.mjs +34 -0
  109. package/dist/lib/node-esm/settings-N452OW6Y.mjs.map +7 -0
  110. package/dist/lib/node-esm/state-WHZFKIEL.mjs +27 -0
  111. package/dist/lib/node-esm/state-WHZFKIEL.mjs.map +7 -0
  112. package/dist/lib/node-esm/toolkit-5IWGLUF4.mjs +17 -0
  113. package/dist/lib/node-esm/toolkit-5IWGLUF4.mjs.map +7 -0
  114. package/dist/lib/node-esm/types/index.mjs +8 -4
  115. package/dist/types/src/AssistantPlugin.d.ts +2 -1
  116. package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
  117. package/dist/types/src/blueprints/assistant/blueprint.d.ts +4 -0
  118. package/dist/types/src/blueprints/assistant/blueprint.d.ts.map +1 -0
  119. package/dist/types/src/blueprints/assistant/blueprint.test.d.ts +2 -0
  120. package/dist/types/src/blueprints/assistant/blueprint.test.d.ts.map +1 -0
  121. package/dist/types/src/blueprints/assistant/index.d.ts +2 -0
  122. package/dist/types/src/blueprints/assistant/index.d.ts.map +1 -0
  123. package/dist/types/src/blueprints/index.d.ts +2 -0
  124. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  125. package/dist/types/src/capabilities/ai-service/ai-service.d.ts +6 -0
  126. package/dist/types/src/capabilities/ai-service/ai-service.d.ts.map +1 -0
  127. package/dist/types/src/capabilities/ai-service/index.d.ts +3 -0
  128. package/dist/types/src/capabilities/ai-service/index.d.ts.map +1 -0
  129. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +6 -0
  130. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +1 -0
  131. package/dist/types/src/capabilities/app-graph-builder/index.d.ts +3 -0
  132. package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +1 -0
  133. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +6 -0
  134. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +1 -0
  135. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +3 -0
  136. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +1 -0
  137. package/dist/types/src/capabilities/edge-model-resolver/edge-model-resolver.d.ts +7 -0
  138. package/dist/types/src/capabilities/edge-model-resolver/edge-model-resolver.d.ts.map +1 -0
  139. package/dist/types/src/capabilities/edge-model-resolver/index.d.ts +3 -0
  140. package/dist/types/src/capabilities/edge-model-resolver/index.d.ts.map +1 -0
  141. package/dist/types/src/capabilities/index.d.ts +10 -11
  142. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  143. package/dist/types/src/capabilities/local-model-resolver/index.d.ts +3 -0
  144. package/dist/types/src/capabilities/local-model-resolver/index.d.ts.map +1 -0
  145. package/dist/types/src/capabilities/local-model-resolver/local-model-resolver.d.ts +13 -0
  146. package/dist/types/src/capabilities/local-model-resolver/local-model-resolver.d.ts.map +1 -0
  147. package/dist/types/src/capabilities/operation-resolver/index.d.ts +3 -0
  148. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +1 -0
  149. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +5 -0
  150. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -0
  151. package/dist/types/src/capabilities/react-surface/index.d.ts +3 -0
  152. package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -0
  153. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +5 -0
  154. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -0
  155. package/dist/types/src/capabilities/repair/index.d.ts +3 -0
  156. package/dist/types/src/capabilities/repair/index.d.ts.map +1 -0
  157. package/dist/types/src/capabilities/repair/repair.d.ts +6 -0
  158. package/dist/types/src/capabilities/repair/repair.d.ts.map +1 -0
  159. package/dist/types/src/capabilities/settings/index.d.ts +15 -0
  160. package/dist/types/src/capabilities/settings/index.d.ts.map +1 -0
  161. package/dist/types/src/capabilities/settings/settings.d.ts +18 -0
  162. package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -0
  163. package/dist/types/src/capabilities/state/index.d.ts +11 -0
  164. package/dist/types/src/capabilities/state/index.d.ts.map +1 -0
  165. package/dist/types/src/capabilities/state/state.d.ts +13 -0
  166. package/dist/types/src/capabilities/state/state.d.ts.map +1 -0
  167. package/dist/types/src/capabilities/toolkit/index.d.ts +3 -0
  168. package/dist/types/src/capabilities/toolkit/index.d.ts.map +1 -0
  169. package/dist/types/src/capabilities/toolkit/toolkit.d.ts +6 -0
  170. package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +1 -0
  171. package/dist/types/src/components/Chat/Chat.d.ts +28 -14
  172. package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
  173. package/dist/types/src/components/Chat/events.d.ts +5 -1
  174. package/dist/types/src/components/Chat/events.d.ts.map +1 -1
  175. package/dist/types/src/components/ChatProgress/ChatProgress.d.ts +2 -2
  176. package/dist/types/src/components/ChatProgress/ChatProgress.d.ts.map +1 -1
  177. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts.map +1 -1
  178. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts +3 -3
  179. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
  180. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +3 -3
  181. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
  182. package/dist/types/src/components/ChatThread/ChatThread.d.ts +7 -8
  183. package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
  184. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +250 -76
  185. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
  186. package/dist/types/src/components/ChatThread/registry.d.ts +1 -1
  187. package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -1
  188. package/dist/types/src/components/ChatThread/sync.d.ts +12 -6
  189. package/dist/types/src/components/ChatThread/sync.d.ts.map +1 -1
  190. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +2 -1
  191. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
  192. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +234 -65
  193. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
  194. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +11 -1
  195. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
  196. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +235 -66
  197. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
  198. package/dist/types/src/components/TemplateEditor/extensions/handlebars-extension.d.ts.map +1 -0
  199. package/dist/types/src/components/TemplateEditor/extensions/index.d.ts +3 -0
  200. package/dist/types/src/components/TemplateEditor/extensions/index.d.ts.map +1 -0
  201. package/dist/types/src/components/TemplateEditor/extensions/xml-extension.d.ts +8 -0
  202. package/dist/types/src/components/TemplateEditor/extensions/xml-extension.d.ts.map +1 -0
  203. package/dist/types/src/components/ToolBlock/ToolBlock.d.ts +10 -8
  204. package/dist/types/src/components/ToolBlock/ToolBlock.d.ts.map +1 -1
  205. package/dist/types/src/components/Toolbox/Toolbox.d.ts +6 -7
  206. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
  207. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +234 -64
  208. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
  209. package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts +12 -0
  210. package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts.map +1 -0
  211. package/dist/types/src/components/Typewriter/Typewriter.d.ts +11 -0
  212. package/dist/types/src/components/Typewriter/Typewriter.d.ts.map +1 -0
  213. package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts +7 -0
  214. package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts.map +1 -0
  215. package/dist/types/src/components/Typewriter/assistant-extension.d.ts +5 -0
  216. package/dist/types/src/components/Typewriter/assistant-extension.d.ts.map +1 -0
  217. package/dist/types/src/components/Typewriter/index.d.ts +2 -0
  218. package/dist/types/src/components/Typewriter/index.d.ts.map +1 -0
  219. package/dist/types/src/components/index.d.ts +0 -11
  220. package/dist/types/src/components/index.d.ts.map +1 -1
  221. package/dist/types/src/containers/AssistantSettings/AssistantSettings.d.ts +8 -0
  222. package/dist/types/src/containers/AssistantSettings/AssistantSettings.d.ts.map +1 -0
  223. package/dist/types/src/containers/AssistantSettings/index.d.ts +3 -0
  224. package/dist/types/src/containers/AssistantSettings/index.d.ts.map +1 -0
  225. package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts +6 -0
  226. package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts.map +1 -0
  227. package/dist/types/src/containers/BlueprintArticle/index.d.ts +3 -0
  228. package/dist/types/src/containers/BlueprintArticle/index.d.ts.map +1 -0
  229. package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts +12 -0
  230. package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts.map +1 -0
  231. package/dist/types/src/containers/ChatCompanion/index.d.ts +3 -0
  232. package/dist/types/src/containers/ChatCompanion/index.d.ts.map +1 -0
  233. package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts +18 -0
  234. package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts.map +1 -0
  235. package/dist/types/src/containers/ChatContainer/index.d.ts +3 -0
  236. package/dist/types/src/containers/ChatContainer/index.d.ts.map +1 -0
  237. package/dist/types/src/{components → containers/ChatDialog}/ChatDialog.d.ts +2 -3
  238. package/dist/types/src/containers/ChatDialog/ChatDialog.d.ts.map +1 -0
  239. package/dist/types/src/containers/ChatDialog/index.d.ts +3 -0
  240. package/dist/types/src/containers/ChatDialog/index.d.ts.map +1 -0
  241. package/dist/types/src/containers/Project/ProjectArticle.d.ts +7 -0
  242. package/dist/types/src/containers/Project/ProjectArticle.d.ts.map +1 -0
  243. package/dist/types/src/containers/Project/ProjectSettings.d.ts +6 -0
  244. package/dist/types/src/containers/Project/ProjectSettings.d.ts.map +1 -0
  245. package/dist/types/src/containers/Project/index.d.ts +7 -0
  246. package/dist/types/src/containers/Project/index.d.ts.map +1 -0
  247. package/dist/types/src/containers/Project/triggers.d.ts +6 -0
  248. package/dist/types/src/containers/Project/triggers.d.ts.map +1 -0
  249. package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts +6 -0
  250. package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts.map +1 -0
  251. package/dist/types/src/containers/PromptArticle/index.d.ts +3 -0
  252. package/dist/types/src/containers/PromptArticle/index.d.ts.map +1 -0
  253. package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts +4 -0
  254. package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts.map +1 -0
  255. package/dist/types/src/containers/TriggerStatus/index.d.ts +3 -0
  256. package/dist/types/src/containers/TriggerStatus/index.d.ts.map +1 -0
  257. package/dist/types/src/containers/index.d.ts +10 -0
  258. package/dist/types/src/containers/index.d.ts.map +1 -0
  259. package/dist/types/src/hooks/index.d.ts +2 -1
  260. package/dist/types/src/hooks/index.d.ts.map +1 -1
  261. package/dist/types/src/hooks/useBlueprintRegistry.d.ts +5 -5
  262. package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -1
  263. package/dist/types/src/hooks/useChatProcessor.d.ts +5 -2
  264. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
  265. package/dist/types/src/hooks/useChatServices.d.ts +5 -5
  266. package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
  267. package/dist/types/src/hooks/useChatToolbarActions.d.ts +8 -0
  268. package/dist/types/src/hooks/useChatToolbarActions.d.ts.map +1 -0
  269. package/dist/types/src/hooks/useContextBinder.d.ts +2 -2
  270. package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -1
  271. package/dist/types/src/hooks/useContextObjects.d.ts +7 -7
  272. package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -1
  273. package/dist/types/src/hooks/useFilteredTypes.d.ts +3 -0
  274. package/dist/types/src/hooks/useFilteredTypes.d.ts.map +1 -0
  275. package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -1
  276. package/dist/types/src/index.d.ts +3 -1
  277. package/dist/types/src/index.d.ts.map +1 -1
  278. package/dist/types/src/meta.d.ts +2 -2
  279. package/dist/types/src/meta.d.ts.map +1 -1
  280. package/dist/types/src/processor/index.d.ts +1 -0
  281. package/dist/types/src/processor/index.d.ts.map +1 -1
  282. package/dist/types/src/processor/processor.d.ts +24 -19
  283. package/dist/types/src/processor/processor.d.ts.map +1 -1
  284. package/dist/types/src/processor/update-name.d.ts +10 -0
  285. package/dist/types/src/processor/update-name.d.ts.map +1 -0
  286. package/dist/types/src/queue-logger.d.ts.map +1 -1
  287. package/dist/types/src/testing/index.d.ts +0 -2
  288. package/dist/types/src/testing/index.d.ts.map +1 -1
  289. package/dist/types/src/testing/test-generator.d.ts +5 -4
  290. package/dist/types/src/testing/test-generator.d.ts.map +1 -1
  291. package/dist/types/src/testing/test-services.d.ts +2 -2
  292. package/dist/types/src/testing/test-services.d.ts.map +1 -1
  293. package/dist/types/src/translations.d.ts +359 -27
  294. package/dist/types/src/translations.d.ts.map +1 -1
  295. package/dist/types/src/types/Assistant.d.ts +7 -29
  296. package/dist/types/src/types/Assistant.d.ts.map +1 -1
  297. package/dist/types/src/types/AssistantAction.d.ts +86 -100
  298. package/dist/types/src/types/AssistantAction.d.ts.map +1 -1
  299. package/dist/types/src/types/capabilities.d.ts +33 -0
  300. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  301. package/dist/types/src/types/events.d.ts +5 -0
  302. package/dist/types/src/types/events.d.ts.map +1 -0
  303. package/dist/types/src/types/index.d.ts +4 -1
  304. package/dist/types/src/types/index.d.ts.map +1 -1
  305. package/dist/types/src/types/service.d.ts +13 -215
  306. package/dist/types/src/types/service.d.ts.map +1 -1
  307. package/dist/types/tsconfig.tsbuildinfo +1 -1
  308. package/package.json +120 -112
  309. package/src/AssistantPlugin.tsx +117 -112
  310. package/src/blueprints/assistant/blueprint.conversations.json +1 -0
  311. package/src/blueprints/assistant/blueprint.test.ts +48 -0
  312. package/src/blueprints/assistant/blueprint.ts +27 -0
  313. package/src/blueprints/assistant/index.ts +5 -0
  314. package/src/{components/Toolbar → blueprints}/index.ts +1 -1
  315. package/src/capabilities/ai-service/ai-service.ts +30 -0
  316. package/src/capabilities/ai-service/index.ts +7 -0
  317. package/src/capabilities/app-graph-builder/app-graph-builder.ts +198 -0
  318. package/src/capabilities/app-graph-builder/index.ts +7 -0
  319. package/src/capabilities/blueprint-definition/blueprint-definition.ts +48 -0
  320. package/src/capabilities/blueprint-definition/index.ts +7 -0
  321. package/src/capabilities/edge-model-resolver/edge-model-resolver.ts +33 -0
  322. package/src/capabilities/edge-model-resolver/index.ts +7 -0
  323. package/src/capabilities/index.ts +10 -14
  324. package/src/capabilities/local-model-resolver/index.ts +7 -0
  325. package/src/capabilities/local-model-resolver/local-model-resolver.ts +38 -0
  326. package/src/capabilities/operation-resolver/index.ts +7 -0
  327. package/src/capabilities/operation-resolver/operation-resolver.ts +121 -0
  328. package/src/capabilities/react-surface/index.ts +7 -0
  329. package/src/capabilities/react-surface/react-surface.tsx +121 -0
  330. package/src/capabilities/repair/index.ts +7 -0
  331. package/src/capabilities/repair/repair.ts +69 -0
  332. package/src/capabilities/settings/index.ts +7 -0
  333. package/src/capabilities/settings/settings.ts +31 -0
  334. package/src/capabilities/state/index.ts +7 -0
  335. package/src/capabilities/state/state.ts +27 -0
  336. package/src/capabilities/toolkit/index.ts +7 -0
  337. package/src/capabilities/toolkit/toolkit.ts +15 -0
  338. package/src/components/Chat/Chat.tsx +229 -153
  339. package/src/components/Chat/events.ts +7 -1
  340. package/src/components/ChatProgress/ChatProgress.tsx +6 -20
  341. package/src/components/ChatPrompt/ChatActions.tsx +12 -6
  342. package/src/components/ChatPrompt/ChatOptions.tsx +119 -86
  343. package/src/components/ChatPrompt/ChatReferences.tsx +19 -10
  344. package/src/components/ChatPrompt/ChatStatusIndicator.tsx +1 -1
  345. package/src/components/ChatThread/ChatThread.stories.tsx +59 -38
  346. package/src/components/ChatThread/ChatThread.tsx +40 -37
  347. package/src/components/ChatThread/Link.tsx +4 -4
  348. package/src/components/ChatThread/registry.tsx +72 -49
  349. package/src/components/ChatThread/sync.test.ts +35 -17
  350. package/src/components/ChatThread/sync.ts +61 -14
  351. package/src/components/ChatThread/testing/thread.md +37 -0
  352. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +17 -7
  353. package/src/components/TemplateEditor/TemplateEditor.tsx +25 -13
  354. package/src/components/TemplateEditor/TemplateForm.stories.tsx +17 -9
  355. package/src/components/TemplateEditor/TemplateForm.tsx +80 -34
  356. package/src/components/TemplateEditor/extensions/handlebars-extension.ts +274 -0
  357. package/src/components/TemplateEditor/extensions/index.ts +6 -0
  358. package/src/components/TemplateEditor/extensions/xml-extension.ts +64 -0
  359. package/src/components/ToolBlock/ToolBlock.tsx +39 -48
  360. package/src/components/Toolbox/Toolbox.stories.tsx +11 -12
  361. package/src/components/Toolbox/Toolbox.tsx +52 -54
  362. package/src/components/Typewriter/AssistantToolbar.tsx +161 -0
  363. package/src/components/Typewriter/Typewriter.stories.tsx +86 -0
  364. package/src/components/Typewriter/Typewriter.tsx +54 -0
  365. package/src/components/Typewriter/assistant-extension.tsx +142 -0
  366. package/src/components/Typewriter/index.ts +5 -0
  367. package/src/components/index.ts +0 -12
  368. package/src/{components → containers}/AssistantSettings/AssistantSettings.tsx +28 -20
  369. package/src/containers/AssistantSettings/index.ts +7 -0
  370. package/src/containers/BlueprintArticle/BlueprintArticle.tsx +30 -0
  371. package/src/containers/BlueprintArticle/index.ts +7 -0
  372. package/src/containers/ChatCompanion/ChatCompanion.tsx +225 -0
  373. package/src/containers/ChatCompanion/index.ts +7 -0
  374. package/src/containers/ChatContainer/ChatContainer.tsx +69 -0
  375. package/src/containers/ChatContainer/index.ts +7 -0
  376. package/src/{components → containers/ChatDialog}/ChatDialog.tsx +18 -14
  377. package/src/containers/ChatDialog/index.ts +7 -0
  378. package/src/containers/Project/ProjectArticle.tsx +117 -0
  379. package/src/containers/Project/ProjectSettings.tsx +118 -0
  380. package/src/containers/Project/index.ts +16 -0
  381. package/src/containers/Project/triggers.ts +131 -0
  382. package/src/containers/PromptArticle/PromptArticle.tsx +59 -0
  383. package/src/containers/PromptArticle/index.ts +7 -0
  384. package/src/containers/TriggerStatus/TriggerStatus.tsx +150 -0
  385. package/src/containers/TriggerStatus/index.ts +7 -0
  386. package/src/containers/index.ts +15 -0
  387. package/src/hooks/index.ts +2 -1
  388. package/src/hooks/useBlueprintRegistry.ts +35 -21
  389. package/src/hooks/useChatProcessor.ts +26 -14
  390. package/src/hooks/useChatServices.ts +16 -18
  391. package/src/hooks/useChatToolbarActions.ts +122 -0
  392. package/src/hooks/useContextBinder.ts +21 -7
  393. package/src/hooks/useContextObjects.ts +13 -25
  394. package/src/hooks/useFilteredTypes.ts +37 -0
  395. package/src/hooks/useReferencesProvider.ts +5 -8
  396. package/src/index.ts +3 -1
  397. package/src/meta.ts +8 -3
  398. package/src/processor/index.ts +1 -0
  399. package/src/processor/presets.ts +1 -1
  400. package/src/processor/processor.test.ts +19 -27
  401. package/src/processor/processor.ts +83 -90
  402. package/src/processor/update-name.ts +58 -0
  403. package/src/queue-logger.ts +8 -9
  404. package/src/testing/index.ts +0 -2
  405. package/src/testing/test-generator.ts +14 -13
  406. package/src/testing/test-sequence.ts +3 -3
  407. package/src/testing/test-services.ts +10 -14
  408. package/src/translations.ts +52 -19
  409. package/src/types/Assistant.ts +4 -37
  410. package/src/types/AssistantAction.ts +67 -53
  411. package/src/types/capabilities.ts +27 -0
  412. package/src/types/events.ts +11 -0
  413. package/src/types/index.ts +6 -1
  414. package/src/types/service.ts +26 -15
  415. package/dist/lib/browser/BlueprintContainer-TO35YXHT.mjs +0 -29
  416. package/dist/lib/browser/BlueprintContainer-TO35YXHT.mjs.map +0 -7
  417. package/dist/lib/browser/ChatCompanion-ZIKNUUSU.mjs +0 -127
  418. package/dist/lib/browser/ChatCompanion-ZIKNUUSU.mjs.map +0 -7
  419. package/dist/lib/browser/ChatContainer-MA5BVDGH.mjs +0 -73
  420. package/dist/lib/browser/ChatContainer-MA5BVDGH.mjs.map +0 -7
  421. package/dist/lib/browser/ChatDialog-7OXLIWZI.mjs +0 -86
  422. package/dist/lib/browser/ChatDialog-7OXLIWZI.mjs.map +0 -7
  423. package/dist/lib/browser/SequenceContainer-2FEWMQGW.mjs +0 -150
  424. package/dist/lib/browser/SequenceContainer-2FEWMQGW.mjs.map +0 -7
  425. package/dist/lib/browser/ai-service-ERTZBTP3.mjs +0 -19
  426. package/dist/lib/browser/ai-service-ERTZBTP3.mjs.map +0 -7
  427. package/dist/lib/browser/app-graph-builder-VKFRYY2N.mjs +0 -154
  428. package/dist/lib/browser/app-graph-builder-VKFRYY2N.mjs.map +0 -7
  429. package/dist/lib/browser/blueprint-definition-NSJARW5U.mjs +0 -12
  430. package/dist/lib/browser/chunk-2CE2KPKZ.mjs +0 -175
  431. package/dist/lib/browser/chunk-2CE2KPKZ.mjs.map +0 -7
  432. package/dist/lib/browser/chunk-43I2LR6O.mjs +0 -216
  433. package/dist/lib/browser/chunk-43I2LR6O.mjs.map +0 -7
  434. package/dist/lib/browser/chunk-5EGXHCAZ.mjs +0 -16
  435. package/dist/lib/browser/chunk-5EGXHCAZ.mjs.map +0 -7
  436. package/dist/lib/browser/chunk-5RICKAMN.mjs +0 -18
  437. package/dist/lib/browser/chunk-5RICKAMN.mjs.map +0 -7
  438. package/dist/lib/browser/chunk-B2RCJXEO.mjs +0 -202
  439. package/dist/lib/browser/chunk-B2RCJXEO.mjs.map +0 -7
  440. package/dist/lib/browser/chunk-BRJMNZOS.mjs +0 -169
  441. package/dist/lib/browser/chunk-BRJMNZOS.mjs.map +0 -7
  442. package/dist/lib/browser/chunk-P5P7QXBS.mjs +0 -296
  443. package/dist/lib/browser/chunk-P5P7QXBS.mjs.map +0 -7
  444. package/dist/lib/browser/chunk-UDH4MR7H.mjs +0 -1744
  445. package/dist/lib/browser/chunk-UDH4MR7H.mjs.map +0 -7
  446. package/dist/lib/browser/edge-model-resolver-O6OFYIO2.mjs +0 -18
  447. package/dist/lib/browser/edge-model-resolver-O6OFYIO2.mjs.map +0 -7
  448. package/dist/lib/browser/intent-resolver-5LB25ZRN.mjs +0 -112
  449. package/dist/lib/browser/intent-resolver-5LB25ZRN.mjs.map +0 -7
  450. package/dist/lib/browser/local-model-resolver-GO6ZEMLL.mjs +0 -17
  451. package/dist/lib/browser/local-model-resolver-GO6ZEMLL.mjs.map +0 -7
  452. package/dist/lib/browser/react-surface-WQZXU624.mjs +0 -107
  453. package/dist/lib/browser/react-surface-WQZXU624.mjs.map +0 -7
  454. package/dist/lib/browser/settings-4B2NA4CE.mjs +0 -23
  455. package/dist/lib/browser/settings-4B2NA4CE.mjs.map +0 -7
  456. package/dist/lib/browser/state-LXTS54DI.mjs +0 -21
  457. package/dist/lib/browser/state-LXTS54DI.mjs.map +0 -7
  458. package/dist/lib/browser/toolkit-NQ2GXCF5.mjs +0 -199
  459. package/dist/lib/browser/toolkit-NQ2GXCF5.mjs.map +0 -7
  460. package/dist/lib/node-esm/BlueprintContainer-J664LTU3.mjs +0 -30
  461. package/dist/lib/node-esm/BlueprintContainer-J664LTU3.mjs.map +0 -7
  462. package/dist/lib/node-esm/ChatCompanion-YDXJIVCF.mjs +0 -128
  463. package/dist/lib/node-esm/ChatCompanion-YDXJIVCF.mjs.map +0 -7
  464. package/dist/lib/node-esm/ChatContainer-WLTOQLHH.mjs +0 -74
  465. package/dist/lib/node-esm/ChatContainer-WLTOQLHH.mjs.map +0 -7
  466. package/dist/lib/node-esm/ChatDialog-ADKF62SY.mjs +0 -87
  467. package/dist/lib/node-esm/ChatDialog-ADKF62SY.mjs.map +0 -7
  468. package/dist/lib/node-esm/SequenceContainer-PGGJUQ46.mjs +0 -151
  469. package/dist/lib/node-esm/SequenceContainer-PGGJUQ46.mjs.map +0 -7
  470. package/dist/lib/node-esm/ai-service-MUYLV3NT.mjs +0 -20
  471. package/dist/lib/node-esm/ai-service-MUYLV3NT.mjs.map +0 -7
  472. package/dist/lib/node-esm/app-graph-builder-K6AYO4YM.mjs +0 -155
  473. package/dist/lib/node-esm/app-graph-builder-K6AYO4YM.mjs.map +0 -7
  474. package/dist/lib/node-esm/blueprint-definition-WD2IVMAI.mjs +0 -13
  475. package/dist/lib/node-esm/chunk-73ABYRYX.mjs.map +0 -7
  476. package/dist/lib/node-esm/chunk-DBDKOC3I.mjs +0 -203
  477. package/dist/lib/node-esm/chunk-DBDKOC3I.mjs.map +0 -7
  478. package/dist/lib/node-esm/chunk-DSE2IILK.mjs +0 -217
  479. package/dist/lib/node-esm/chunk-DSE2IILK.mjs.map +0 -7
  480. package/dist/lib/node-esm/chunk-I7BZMIAG.mjs +0 -170
  481. package/dist/lib/node-esm/chunk-I7BZMIAG.mjs.map +0 -7
  482. package/dist/lib/node-esm/chunk-TBQOICXZ.mjs +0 -297
  483. package/dist/lib/node-esm/chunk-TBQOICXZ.mjs.map +0 -7
  484. package/dist/lib/node-esm/chunk-U2NYUS2N.mjs +0 -177
  485. package/dist/lib/node-esm/chunk-U2NYUS2N.mjs.map +0 -7
  486. package/dist/lib/node-esm/chunk-UPPSDTOJ.mjs +0 -1745
  487. package/dist/lib/node-esm/chunk-UPPSDTOJ.mjs.map +0 -7
  488. package/dist/lib/node-esm/chunk-XQGWSZ4T.mjs +0 -17
  489. package/dist/lib/node-esm/chunk-XQGWSZ4T.mjs.map +0 -7
  490. package/dist/lib/node-esm/edge-model-resolver-2ARXDOYS.mjs +0 -19
  491. package/dist/lib/node-esm/edge-model-resolver-2ARXDOYS.mjs.map +0 -7
  492. package/dist/lib/node-esm/intent-resolver-I64MNI4C.mjs +0 -113
  493. package/dist/lib/node-esm/intent-resolver-I64MNI4C.mjs.map +0 -7
  494. package/dist/lib/node-esm/local-model-resolver-WOQ2D2R2.mjs +0 -18
  495. package/dist/lib/node-esm/local-model-resolver-WOQ2D2R2.mjs.map +0 -7
  496. package/dist/lib/node-esm/react-surface-TVVVRIR3.mjs +0 -108
  497. package/dist/lib/node-esm/react-surface-TVVVRIR3.mjs.map +0 -7
  498. package/dist/lib/node-esm/settings-7Y3CRASE.mjs +0 -24
  499. package/dist/lib/node-esm/settings-7Y3CRASE.mjs.map +0 -7
  500. package/dist/lib/node-esm/state-BO6GUFLB.mjs +0 -22
  501. package/dist/lib/node-esm/state-BO6GUFLB.mjs.map +0 -7
  502. package/dist/lib/node-esm/toolkit-V57PRJNG.mjs +0 -200
  503. package/dist/lib/node-esm/toolkit-V57PRJNG.mjs.map +0 -7
  504. package/dist/types/src/capabilities/ai-service.d.ts +0 -4
  505. package/dist/types/src/capabilities/ai-service.d.ts.map +0 -1
  506. package/dist/types/src/capabilities/app-graph-builder.d.ts +0 -4
  507. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +0 -1
  508. package/dist/types/src/capabilities/blueprint-definition.d.ts +0 -7
  509. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +0 -1
  510. package/dist/types/src/capabilities/capabilities.d.ts +0 -11
  511. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  512. package/dist/types/src/capabilities/edge-model-resolver.d.ts +0 -4
  513. package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +0 -1
  514. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  515. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  516. package/dist/types/src/capabilities/local-model-resolver.d.ts +0 -10
  517. package/dist/types/src/capabilities/local-model-resolver.d.ts.map +0 -1
  518. package/dist/types/src/capabilities/react-surface.d.ts +0 -4
  519. package/dist/types/src/capabilities/react-surface.d.ts.map +0 -1
  520. package/dist/types/src/capabilities/settings.d.ts +0 -4
  521. package/dist/types/src/capabilities/settings.d.ts.map +0 -1
  522. package/dist/types/src/capabilities/state.d.ts +0 -4
  523. package/dist/types/src/capabilities/state.d.ts.map +0 -1
  524. package/dist/types/src/capabilities/toolkit.d.ts +0 -4
  525. package/dist/types/src/capabilities/toolkit.d.ts.map +0 -1
  526. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +0 -6
  527. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +0 -1
  528. package/dist/types/src/components/AssistantSettings/index.d.ts +0 -2
  529. package/dist/types/src/components/AssistantSettings/index.d.ts.map +0 -1
  530. package/dist/types/src/components/BlueprintContainer.d.ts +0 -8
  531. package/dist/types/src/components/BlueprintContainer.d.ts.map +0 -1
  532. package/dist/types/src/components/ChatCompanion.d.ts +0 -13
  533. package/dist/types/src/components/ChatCompanion.d.ts.map +0 -1
  534. package/dist/types/src/components/ChatContainer.d.ts +0 -11
  535. package/dist/types/src/components/ChatContainer.d.ts.map +0 -1
  536. package/dist/types/src/components/ChatDialog.d.ts.map +0 -1
  537. package/dist/types/src/components/ChatThread/reducers.d.ts +0 -40
  538. package/dist/types/src/components/ChatThread/reducers.d.ts.map +0 -1
  539. package/dist/types/src/components/PromptSettings.d.ts +0 -6
  540. package/dist/types/src/components/PromptSettings.d.ts.map +0 -1
  541. package/dist/types/src/components/SequenceContainer.d.ts +0 -8
  542. package/dist/types/src/components/SequenceContainer.d.ts.map +0 -1
  543. package/dist/types/src/components/SequenceEditor/SequenceEditor.d.ts +0 -13
  544. package/dist/types/src/components/SequenceEditor/SequenceEditor.d.ts.map +0 -1
  545. package/dist/types/src/components/SequenceEditor/SequenceEditor.stories.d.ts +0 -269
  546. package/dist/types/src/components/SequenceEditor/SequenceEditor.stories.d.ts.map +0 -1
  547. package/dist/types/src/components/SequenceEditor/index.d.ts +0 -2
  548. package/dist/types/src/components/SequenceEditor/index.d.ts.map +0 -1
  549. package/dist/types/src/components/TemplateEditor/handlebars-extension.d.ts.map +0 -1
  550. package/dist/types/src/components/Toolbar/Toolbar.d.ts +0 -5
  551. package/dist/types/src/components/Toolbar/Toolbar.d.ts.map +0 -1
  552. package/dist/types/src/components/Toolbar/index.d.ts +0 -2
  553. package/dist/types/src/components/Toolbar/index.d.ts.map +0 -1
  554. package/dist/types/src/components/Toolbar/useChatToolbarActions.d.ts +0 -11
  555. package/dist/types/src/components/Toolbar/useChatToolbarActions.d.ts.map +0 -1
  556. package/dist/types/src/events.d.ts +0 -4
  557. package/dist/types/src/events.d.ts.map +0 -1
  558. package/dist/types/src/functions/analysis.d.ts +0 -5
  559. package/dist/types/src/functions/analysis.d.ts.map +0 -1
  560. package/dist/types/src/functions/index.d.ts +0 -4
  561. package/dist/types/src/functions/index.d.ts.map +0 -1
  562. package/dist/types/src/functions/list.d.ts +0 -10
  563. package/dist/types/src/functions/list.d.ts.map +0 -1
  564. package/dist/types/src/functions/load.d.ts +0 -8
  565. package/dist/types/src/functions/load.d.ts.map +0 -1
  566. package/dist/types/src/hooks/useItemTypes.d.ts +0 -4
  567. package/dist/types/src/hooks/useItemTypes.d.ts.map +0 -1
  568. package/dist/types/src/stories/Chat.stories.d.ts +0 -32
  569. package/dist/types/src/stories/Chat.stories.d.ts.map +0 -1
  570. package/dist/types/src/stories/QueryEditor.stories.d.ts +0 -7
  571. package/dist/types/src/stories/QueryEditor.stories.d.ts.map +0 -1
  572. package/dist/types/src/stories/components/BlueprintContainer.d.ts +0 -4
  573. package/dist/types/src/stories/components/BlueprintContainer.d.ts.map +0 -1
  574. package/dist/types/src/stories/components/ChatContainer.d.ts +0 -4
  575. package/dist/types/src/stories/components/ChatContainer.d.ts.map +0 -1
  576. package/dist/types/src/stories/components/ChessContainer.d.ts +0 -4
  577. package/dist/types/src/stories/components/ChessContainer.d.ts.map +0 -1
  578. package/dist/types/src/stories/components/CommentsContainer.d.ts +0 -4
  579. package/dist/types/src/stories/components/CommentsContainer.d.ts.map +0 -1
  580. package/dist/types/src/stories/components/DebugCard.d.ts +0 -8
  581. package/dist/types/src/stories/components/DebugCard.d.ts.map +0 -1
  582. package/dist/types/src/stories/components/ExecutionGraphContainer.d.ts +0 -7
  583. package/dist/types/src/stories/components/ExecutionGraphContainer.d.ts.map +0 -1
  584. package/dist/types/src/stories/components/GraphContainer.d.ts +0 -6
  585. package/dist/types/src/stories/components/GraphContainer.d.ts.map +0 -1
  586. package/dist/types/src/stories/components/InvocationsContainer.d.ts +0 -4
  587. package/dist/types/src/stories/components/InvocationsContainer.d.ts.map +0 -1
  588. package/dist/types/src/stories/components/MessageContainer.d.ts +0 -4
  589. package/dist/types/src/stories/components/MessageContainer.d.ts.map +0 -1
  590. package/dist/types/src/stories/components/ProjectContainer.d.ts +0 -4
  591. package/dist/types/src/stories/components/ProjectContainer.d.ts.map +0 -1
  592. package/dist/types/src/stories/components/PromptContainer.d.ts +0 -6
  593. package/dist/types/src/stories/components/PromptContainer.d.ts.map +0 -1
  594. package/dist/types/src/stories/components/ResearchInputStack.d.ts +0 -4
  595. package/dist/types/src/stories/components/ResearchInputStack.d.ts.map +0 -1
  596. package/dist/types/src/stories/components/ResearchOutputStack.d.ts +0 -4
  597. package/dist/types/src/stories/components/ResearchOutputStack.d.ts.map +0 -1
  598. package/dist/types/src/stories/components/ScriptContainer.d.ts +0 -4
  599. package/dist/types/src/stories/components/ScriptContainer.d.ts.map +0 -1
  600. package/dist/types/src/stories/components/TasksContainer.d.ts +0 -4
  601. package/dist/types/src/stories/components/TasksContainer.d.ts.map +0 -1
  602. package/dist/types/src/stories/components/TokenManagerContainer.d.ts +0 -3
  603. package/dist/types/src/stories/components/TokenManagerContainer.d.ts.map +0 -1
  604. package/dist/types/src/stories/components/TriggersContainer.d.ts +0 -3
  605. package/dist/types/src/stories/components/TriggersContainer.d.ts.map +0 -1
  606. package/dist/types/src/stories/components/index.d.ts +0 -18
  607. package/dist/types/src/stories/components/index.d.ts.map +0 -1
  608. package/dist/types/src/stories/components/types.d.ts +0 -7
  609. package/dist/types/src/stories/components/types.d.ts.map +0 -1
  610. package/dist/types/src/stories/testing/data.d.ts +0 -9
  611. package/dist/types/src/stories/testing/data.d.ts.map +0 -1
  612. package/dist/types/src/stories/testing/index.d.ts +0 -3
  613. package/dist/types/src/stories/testing/index.d.ts.map +0 -1
  614. package/dist/types/src/stories/testing/schema.d.ts +0 -7
  615. package/dist/types/src/stories/testing/schema.d.ts.map +0 -1
  616. package/dist/types/src/stories/testing/testing.d.ts +0 -51
  617. package/dist/types/src/stories/testing/testing.d.ts.map +0 -1
  618. package/dist/types/src/testing/test-data.d.ts +0 -14
  619. package/dist/types/src/testing/test-data.d.ts.map +0 -1
  620. package/dist/types/src/testing/test-functions.d.ts +0 -6
  621. package/dist/types/src/testing/test-functions.d.ts.map +0 -1
  622. package/src/capabilities/ai-service.ts +0 -27
  623. package/src/capabilities/app-graph-builder.ts +0 -163
  624. package/src/capabilities/blueprint-definition.ts +0 -64
  625. package/src/capabilities/capabilities.ts +0 -18
  626. package/src/capabilities/edge-model-resolver.ts +0 -25
  627. package/src/capabilities/intent-resolver.ts +0 -94
  628. package/src/capabilities/local-model-resolver.ts +0 -30
  629. package/src/capabilities/react-surface.tsx +0 -91
  630. package/src/capabilities/settings.ts +0 -19
  631. package/src/capabilities/state.ts +0 -20
  632. package/src/capabilities/toolkit.ts +0 -168
  633. package/src/components/AssistantSettings/index.ts +0 -5
  634. package/src/components/BlueprintContainer.tsx +0 -24
  635. package/src/components/ChatCompanion.tsx +0 -114
  636. package/src/components/ChatContainer.tsx +0 -51
  637. package/src/components/ChatThread/reducers.ts +0 -151
  638. package/src/components/PromptSettings.tsx +0 -90
  639. package/src/components/SequenceContainer.tsx +0 -131
  640. package/src/components/SequenceEditor/SequenceEditor.stories.tsx +0 -35
  641. package/src/components/SequenceEditor/SequenceEditor.tsx +0 -50
  642. package/src/components/SequenceEditor/index.ts +0 -5
  643. package/src/components/TemplateEditor/handlebars-extension.ts +0 -165
  644. package/src/components/Toolbar/Toolbar.tsx +0 -21
  645. package/src/components/Toolbar/useChatToolbarActions.ts +0 -126
  646. package/src/events.ts +0 -11
  647. package/src/functions/analysis.ts +0 -22
  648. package/src/functions/index.ts +0 -7
  649. package/src/functions/list.ts +0 -48
  650. package/src/functions/load.ts +0 -46
  651. package/src/hooks/useItemTypes.ts +0 -37
  652. package/src/stories/Chat.stories.tsx +0 -882
  653. package/src/stories/QueryEditor.stories.tsx +0 -114
  654. package/src/stories/components/BlueprintContainer.tsx +0 -34
  655. package/src/stories/components/ChatContainer.tsx +0 -74
  656. package/src/stories/components/ChessContainer.tsx +0 -17
  657. package/src/stories/components/CommentsContainer.tsx +0 -25
  658. package/src/stories/components/DebugCard.tsx +0 -61
  659. package/src/stories/components/ExecutionGraphContainer.tsx +0 -30
  660. package/src/stories/components/GraphContainer.tsx +0 -106
  661. package/src/stories/components/InvocationsContainer.tsx +0 -17
  662. package/src/stories/components/MessageContainer.tsx +0 -22
  663. package/src/stories/components/ProjectContainer.tsx +0 -17
  664. package/src/stories/components/PromptContainer.tsx +0 -52
  665. package/src/stories/components/ResearchInputStack.tsx +0 -30
  666. package/src/stories/components/ResearchOutputStack.tsx +0 -29
  667. package/src/stories/components/ScriptContainer.tsx +0 -28
  668. package/src/stories/components/TasksContainer.tsx +0 -47
  669. package/src/stories/components/TokenManagerContainer.tsx +0 -14
  670. package/src/stories/components/TriggersContainer.tsx +0 -12
  671. package/src/stories/components/index.ts +0 -22
  672. package/src/stories/components/types.ts +0 -11
  673. package/src/stories/testing/data.ts +0 -135
  674. package/src/stories/testing/index.ts +0 -6
  675. package/src/stories/testing/schema.ts +0 -17
  676. package/src/stories/testing/testing.tsx +0 -291
  677. package/src/testing/test-data.ts +0 -248
  678. package/src/testing/test-functions.ts +0 -16
  679. /package/dist/lib/browser/{blueprint-definition-NSJARW5U.mjs.map → ChatContainer-ZGRSZ5EU.mjs.map} +0 -0
  680. /package/dist/lib/{node-esm/blueprint-definition-WD2IVMAI.mjs.map → browser/blueprints/index.mjs.map} +0 -0
  681. /package/dist/types/src/components/TemplateEditor/{handlebars-extension.d.ts → extensions/handlebars-extension.d.ts} +0 -0
@@ -0,0 +1,2126 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ AiChatProcessor,
4
+ AiServicePresets
5
+ } from "./chunk-JMBYVUD6.mjs";
6
+ import {
7
+ AssistantOperation,
8
+ ServiceType
9
+ } from "./chunk-MWYYLALM.mjs";
10
+ import {
11
+ meta
12
+ } from "./chunk-POWB2BPC.mjs";
13
+
14
+ // src/hooks/useBlueprintRegistry.ts
15
+ import { useCallback, useEffect, useMemo, useState } from "react";
16
+ import { useCapabilities } from "@dxos/app-framework/ui";
17
+ import { AppCapabilities } from "@dxos/app-toolkit";
18
+ import { Blueprint } from "@dxos/blueprints";
19
+ import { Filter, Obj, Ref } from "@dxos/echo";
20
+ import { useQuery } from "@dxos/react-client/echo";
21
+ import { distinctBy } from "@dxos/util";
22
+ var useBlueprintRegistry = () => {
23
+ const blueprintDefinitions = useCapabilities(AppCapabilities.BlueprintDefinition);
24
+ return useMemo(() => new Blueprint.Registry(blueprintDefinitions.map((blueprint) => blueprint.make())), [
25
+ blueprintDefinitions
26
+ ]);
27
+ };
28
+ var useBlueprints = ({ blueprintRegistry, db }) => {
29
+ const staticBlueprints = useMemo(() => blueprintRegistry?.query() ?? [], [
30
+ blueprintRegistry
31
+ ]);
32
+ const spaceBlueprints = useQuery(db, Filter.type(Blueprint.Blueprint));
33
+ return useMemo(() => {
34
+ const blueprints = distinctBy([
35
+ ...staticBlueprints,
36
+ ...spaceBlueprints
37
+ ], (b) => b.key);
38
+ blueprints.sort(({ name: a }, { name: b }) => a.localeCompare(b));
39
+ return blueprints;
40
+ }, [
41
+ staticBlueprints,
42
+ spaceBlueprints
43
+ ]);
44
+ };
45
+ var useActiveBlueprints = ({ context }) => {
46
+ const [active, setActive] = useState(/* @__PURE__ */ new Map());
47
+ useEffect(() => {
48
+ if (!context) {
49
+ setActive(/* @__PURE__ */ new Map());
50
+ return;
51
+ }
52
+ const updateActive = () => {
53
+ const blueprints = context.getBlueprints();
54
+ setActive(new Map(blueprints.map((blueprint) => [
55
+ blueprint.key,
56
+ blueprint
57
+ ])));
58
+ };
59
+ updateActive();
60
+ return context.subscribeBlueprints(updateActive);
61
+ }, [
62
+ context
63
+ ]);
64
+ return active;
65
+ };
66
+ var useBlueprintHandlers = ({ db, context, blueprintRegistry }) => {
67
+ const onUpdateBlueprint = useCallback(async (key, checked) => {
68
+ if (!context || !blueprintRegistry) {
69
+ return;
70
+ }
71
+ const objects = await db.query(Filter.type(Blueprint.Blueprint)).run();
72
+ let storedBlueprint = objects.find((blueprint) => blueprint.key === key);
73
+ if (checked) {
74
+ if (!storedBlueprint) {
75
+ const blueprint = blueprintRegistry.getByKey(key);
76
+ if (!blueprint) {
77
+ return;
78
+ }
79
+ storedBlueprint = db.add(Obj.clone(blueprint));
80
+ }
81
+ await context.bind({
82
+ blueprints: [
83
+ Ref.make(storedBlueprint)
84
+ ]
85
+ });
86
+ } else if (storedBlueprint) {
87
+ await context.unbind({
88
+ blueprints: [
89
+ Ref.make(storedBlueprint)
90
+ ]
91
+ });
92
+ }
93
+ }, [
94
+ db,
95
+ context,
96
+ blueprintRegistry
97
+ ]);
98
+ return {
99
+ onUpdateBlueprint
100
+ };
101
+ };
102
+
103
+ // src/hooks/useChatProcessor.ts
104
+ import { RegistryContext } from "@effect-atom/atom-react";
105
+ import { useContext, useMemo as useMemo2, useState as useState2 } from "react";
106
+ import { AiConversation } from "@dxos/assistant";
107
+ import { log } from "@dxos/log";
108
+ import { useAsyncEffect } from "@dxos/react-ui";
109
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/hooks/useChatProcessor.ts";
110
+ var useChatProcessor = ({ space, chat, preset, services, blueprintRegistry, settings }) => {
111
+ const observableRegistry = useContext(RegistryContext);
112
+ const [conversation, setConversation] = useState2();
113
+ useAsyncEffect(async () => {
114
+ if (!space || !chat) {
115
+ return;
116
+ }
117
+ const queue = space.queues.get(chat.queue.dxn);
118
+ const conversation2 = new AiConversation({
119
+ queue,
120
+ registry: observableRegistry
121
+ });
122
+ await conversation2.open();
123
+ setConversation(conversation2);
124
+ return () => {
125
+ void conversation2.close();
126
+ setConversation(void 0);
127
+ };
128
+ }, [
129
+ space,
130
+ chat?.queue.dxn.toString()
131
+ ]);
132
+ const processor = useMemo2(() => {
133
+ if (!services || !conversation) {
134
+ return void 0;
135
+ }
136
+ log("creating processor", {
137
+ preset,
138
+ model: preset?.model,
139
+ settings
140
+ }, {
141
+ F: __dxlog_file,
142
+ L: 69,
143
+ S: void 0,
144
+ C: (f, a) => f(...a)
145
+ });
146
+ return new AiChatProcessor(conversation, services, {
147
+ observableRegistry,
148
+ blueprintRegistry,
149
+ model: preset?.model
150
+ });
151
+ }, [
152
+ services,
153
+ conversation,
154
+ blueprintRegistry,
155
+ preset
156
+ ]);
157
+ return processor;
158
+ };
159
+
160
+ // src/hooks/useChatServices.ts
161
+ import * as Effect from "effect/Effect";
162
+ import { useMemo as useMemo3 } from "react";
163
+ import { useCapability } from "@dxos/app-framework/ui";
164
+ import { TracingService } from "@dxos/functions";
165
+ import { TracingServiceExt } from "@dxos/functions-runtime";
166
+ import { AutomationCapabilities } from "@dxos/plugin-automation";
167
+ import { useClient } from "@dxos/react-client";
168
+ var useChatServices = ({ id, chat }) => {
169
+ const client = useClient();
170
+ id ??= client.spaces.default.id;
171
+ const runtimeResolver = useCapability(AutomationCapabilities.ComputeRuntime);
172
+ return useMemo3(() => {
173
+ const runtime2 = runtimeResolver.getRuntime(id);
174
+ return () => runtime2.runPromise(Effect.runtime().pipe(Effect.provide(chat?.traceQueue?.target ? TracingServiceExt.layerQueue(chat.traceQueue?.target) : TracingService.layerNoop)));
175
+ }, [
176
+ id,
177
+ chat?.traceQueue?.target
178
+ ]);
179
+ };
180
+
181
+ // src/hooks/useChatToolbarActions.ts
182
+ import { Atom } from "@effect-atom/atom-react";
183
+ import * as Effect2 from "effect/Effect";
184
+ import { useMemo as useMemo10 } from "react";
185
+ import { useOperationInvoker } from "@dxos/app-framework/ui";
186
+ import { Chat as Chat2 } from "@dxos/assistant-toolkit";
187
+ import { Filter as Filter6, Obj as Obj6, Query } from "@dxos/echo";
188
+ import { runAndForwardErrors } from "@dxos/effect";
189
+ import { invariant } from "@dxos/invariant";
190
+ import { useQuery as useQuery5 } from "@dxos/react-client/echo";
191
+ import { MenuBuilder, useMenuActions } from "@dxos/react-ui-menu";
192
+
193
+ // src/components/Chat/Chat.tsx
194
+ import { Prec } from "@codemirror/state";
195
+ import { keymap } from "@codemirror/view";
196
+ import { useAtomValue } from "@effect-atom/atom-react";
197
+ import { createContext } from "@radix-ui/react-context";
198
+ import * as Array2 from "effect/Array";
199
+ import * as Option4 from "effect/Option";
200
+ import React9, { useCallback as useCallback7, useEffect as useEffect7, useMemo as useMemo9, useRef as useRef3, useState as useState12 } from "react";
201
+ import { Event } from "@dxos/async";
202
+ import { Filter as Filter4, Obj as Obj5 } from "@dxos/echo";
203
+ import { useVoiceInput } from "@dxos/plugin-transcription";
204
+ import { useQuery as useQuery3 } from "@dxos/react-client/echo";
205
+ import { useIdentity } from "@dxos/react-client/halo";
206
+ import { Input, useDynamicRef, useTranslation as useTranslation5 } from "@dxos/react-ui";
207
+ import { ChatEditor } from "@dxos/react-ui-chat";
208
+ import { Menu } from "@dxos/react-ui-menu";
209
+ import { Message } from "@dxos/types";
210
+ import { mx as mx6 } from "@dxos/ui-theme";
211
+ import { isTruthy } from "@dxos/util";
212
+
213
+ // src/hooks/useContextBinder.ts
214
+ import { RegistryContext as RegistryContext2 } from "@effect-atom/atom-react";
215
+ import { useContext as useContext2, useState as useState3 } from "react";
216
+ import { AiContextBinder } from "@dxos/assistant";
217
+ import { useAsyncEffect as useAsyncEffect2 } from "@dxos/react-ui";
218
+ var useContextBinder = (queue) => {
219
+ const registry = useContext2(RegistryContext2);
220
+ const [binder, setBinder] = useState3();
221
+ useAsyncEffect2(async () => {
222
+ if (!queue) {
223
+ return;
224
+ }
225
+ const binder2 = new AiContextBinder({
226
+ queue,
227
+ registry
228
+ });
229
+ await binder2.open();
230
+ setBinder(binder2);
231
+ return () => {
232
+ void binder2.close();
233
+ };
234
+ }, [
235
+ queue
236
+ ]);
237
+ return binder;
238
+ };
239
+
240
+ // src/hooks/useContextObjects.ts
241
+ import { useCallback as useCallback2 } from "react";
242
+ import { Ref as Ref2 } from "@dxos/echo";
243
+ var useContextObjects = ({ db, context }) => {
244
+ const handleUpdateObject = useCallback2(async (dxn, checked) => {
245
+ if (!db || !context) {
246
+ return;
247
+ }
248
+ const ref = Ref2.fromDXN(dxn);
249
+ await ref.load();
250
+ if (checked) {
251
+ await context.bind({
252
+ objects: [
253
+ ref
254
+ ]
255
+ });
256
+ } else {
257
+ await context.unbind({
258
+ objects: [
259
+ ref
260
+ ]
261
+ });
262
+ }
263
+ }, [
264
+ db,
265
+ context
266
+ ]);
267
+ return {
268
+ objects: context?.getObjects() ?? [],
269
+ onUpdateObject: handleUpdateObject
270
+ };
271
+ };
272
+
273
+ // src/hooks/useFilteredTypes.ts
274
+ import * as Option from "effect/Option";
275
+ import { useEffect as useEffect2, useState as useState4 } from "react";
276
+ import { EntityKind, SystemTypeAnnotation, getTypeAnnotation } from "@dxos/echo/internal";
277
+ var useFilteredTypes = (db) => {
278
+ const [types, setTypes] = useState4([]);
279
+ useEffect2(() => {
280
+ if (!db) {
281
+ return;
282
+ }
283
+ return db.schemaRegistry.query({
284
+ location: [
285
+ "database",
286
+ "runtime"
287
+ ]
288
+ }).subscribe((query) => {
289
+ const types2 = Array.from(new Set(query.results.filter((schema) => getTypeAnnotation(schema)?.kind !== EntityKind.Relation).filter((schema) => SystemTypeAnnotation.get(schema).pipe(Option.getOrElse(() => false)))));
290
+ setTypes(types2);
291
+ }, {
292
+ fire: true
293
+ });
294
+ }, [
295
+ db
296
+ ]);
297
+ return types;
298
+ };
299
+
300
+ // src/hooks/useFlush.ts
301
+ import { useCallback as useCallback3, useRef, useState as useState5 } from "react";
302
+ var useFlush = (space) => {
303
+ const [state, setState] = useState5("idle");
304
+ const resetTimer = useRef(null);
305
+ const handleFlush = useCallback3(() => {
306
+ if (!space) {
307
+ return;
308
+ }
309
+ queueMicrotask(async () => {
310
+ if (resetTimer.current) {
311
+ clearTimeout(resetTimer.current);
312
+ }
313
+ setState("flushing");
314
+ await space.db.flush();
315
+ setState("flushed");
316
+ resetTimer.current = setTimeout(() => {
317
+ setState("idle");
318
+ resetTimer.current = null;
319
+ }, 1e3);
320
+ });
321
+ }, [
322
+ space
323
+ ]);
324
+ return {
325
+ state,
326
+ handleFlush
327
+ };
328
+ };
329
+
330
+ // src/hooks/useOnline.ts
331
+ import { useState as useState6 } from "react";
332
+ var useOnline = () => {
333
+ const [online, setOnline] = useState6(true);
334
+ return [
335
+ online,
336
+ setOnline
337
+ ];
338
+ };
339
+
340
+ // src/hooks/usePresets.ts
341
+ import { useCallback as useCallback4, useEffect as useEffect3, useMemo as useMemo4, useState as useState7 } from "react";
342
+ var usePresets = (online) => {
343
+ const [preset, setPreset] = useState7();
344
+ const presets = useMemo4(() => AiServicePresets.filter((preset2) => online === (preset2.provider === "dxos-remote")), [
345
+ online
346
+ ]);
347
+ const presetOptions = useMemo4(() => presets.map(({ id, model, label }) => ({
348
+ id,
349
+ label: label ?? model
350
+ })), [
351
+ presets
352
+ ]);
353
+ useEffect3(() => {
354
+ setPreset(presets[0]);
355
+ }, [
356
+ presets
357
+ ]);
358
+ const handlePresetChange = useCallback4((id) => {
359
+ const preset2 = presets.find((preset3) => preset3.id === id);
360
+ if (preset2) {
361
+ setPreset(preset2);
362
+ }
363
+ }, [
364
+ presets
365
+ ]);
366
+ return {
367
+ preset,
368
+ presets: presetOptions,
369
+ onPresetChange: handlePresetChange
370
+ };
371
+ };
372
+
373
+ // src/hooks/useReferencesProvider.ts
374
+ import { useMemo as useMemo5 } from "react";
375
+ import { Filter as Filter2, Obj as Obj2 } from "@dxos/echo";
376
+ var useReferencesProvider = (space) => {
377
+ return useMemo5(() => {
378
+ if (!space) {
379
+ return void 0;
380
+ }
381
+ return {
382
+ getReferences: async ({ query }) => {
383
+ const objects = await space.db.query(Filter2.everything()).run();
384
+ return objects.filter((object) => stringMatch(query, Obj2.getLabel(object) ?? "")).filter((object) => !!Obj2.getDXN(object)).map((object) => ({
385
+ uri: Obj2.getDXN(object).toString(),
386
+ label: Obj2.getLabel(object) ?? ""
387
+ }));
388
+ },
389
+ resolveReference: async ({ uri }) => {
390
+ const object = await space.db.query(Filter2.id(uri)).first();
391
+ return {
392
+ uri,
393
+ label: Obj2.getLabel(object) ?? ""
394
+ };
395
+ }
396
+ };
397
+ }, [
398
+ space
399
+ ]);
400
+ };
401
+ var stringMatch = (query, label) => label.toLowerCase().startsWith(query.toLowerCase());
402
+
403
+ // src/components/ChatPrompt/ChatActions.tsx
404
+ import React from "react";
405
+ import { IconButton, useTranslation } from "@dxos/react-ui";
406
+ import { mx } from "@dxos/ui-theme";
407
+ var ChatActions = ({ classNames, children, microphone, recording, processing, onEvent }) => {
408
+ const { t } = useTranslation(meta.id);
409
+ return /* @__PURE__ */ React.createElement("div", {
410
+ className: mx("flex items-center me-1", classNames)
411
+ }, children, /* @__PURE__ */ React.createElement(IconButton, {
412
+ disabled: !processing,
413
+ variant: "ghost",
414
+ icon: "ph--x--regular",
415
+ iconOnly: true,
416
+ label: t("cancel processing button"),
417
+ onClick: () => onEvent?.({
418
+ type: "cancel"
419
+ })
420
+ }), microphone && /* @__PURE__ */ React.createElement(IconButton, {
421
+ disabled: !processing,
422
+ classNames: mx(recording && "bg-primary-500"),
423
+ variant: "ghost",
424
+ icon: "ph--microphone--regular",
425
+ iconOnly: true,
426
+ noTooltip: true,
427
+ label: t("microphone button"),
428
+ onMouseDown: () => onEvent?.({
429
+ type: "record-start"
430
+ }),
431
+ onMouseUp: () => onEvent?.({
432
+ type: "record-stop"
433
+ }),
434
+ onTouchStart: () => onEvent?.({
435
+ type: "record-start"
436
+ }),
437
+ onTouchEnd: () => onEvent?.({
438
+ type: "record-stop"
439
+ })
440
+ }), /* @__PURE__ */ React.createElement(IconButton, {
441
+ variant: "ghost",
442
+ icon: "ph--wrench--regular",
443
+ iconOnly: true,
444
+ label: t("debug button"),
445
+ onClick: () => onEvent?.({
446
+ type: "toggle-debug"
447
+ })
448
+ }));
449
+ };
450
+
451
+ // src/components/ChatPrompt/ChatOptions.tsx
452
+ import * as Option2 from "effect/Option";
453
+ import React2, { useMemo as useMemo6, useState as useState8 } from "react";
454
+ import { Filter as Filter3, Obj as Obj3, Type } from "@dxos/echo";
455
+ import { Annotation } from "@dxos/echo";
456
+ import { useQuery as useQuery2 } from "@dxos/react-client/echo";
457
+ import { IconButton as IconButton2, Popover, Select, useTranslation as useTranslation2 } from "@dxos/react-ui";
458
+ import { Listbox, SearchList, useSearchListResults } from "@dxos/react-ui-searchlist";
459
+ import { Tabs } from "@dxos/react-ui-tabs";
460
+ import { getStyles, mx as mx2 } from "@dxos/ui-theme";
461
+ var panelClassNames = "w-[calc(100dvw-.5rem)] sm:w-max md:w-72 max-w-text-content";
462
+ var ChatOptions = ({ db, context, blueprintRegistry, presets, preset, onPresetChange }) => {
463
+ const { t } = useTranslation2(meta.id);
464
+ return /* @__PURE__ */ React2.createElement("div", {
465
+ role: "none",
466
+ className: "flex p-2"
467
+ }, /* @__PURE__ */ React2.createElement(Popover.Root, null, /* @__PURE__ */ React2.createElement(Popover.Trigger, {
468
+ asChild: true
469
+ }, /* @__PURE__ */ React2.createElement(IconButton2, {
470
+ variant: "ghost",
471
+ icon: "ph--plus--regular",
472
+ iconOnly: true,
473
+ label: t("context objects button")
474
+ })), /* @__PURE__ */ React2.createElement(Popover.Portal, null, /* @__PURE__ */ React2.createElement(Popover.Content, {
475
+ side: "top",
476
+ classNames: panelClassNames
477
+ }, /* @__PURE__ */ React2.createElement(Popover.Viewport, null, /* @__PURE__ */ React2.createElement(ObjectsPanel, {
478
+ db,
479
+ context
480
+ })), /* @__PURE__ */ React2.createElement(Popover.Arrow, null)))), /* @__PURE__ */ React2.createElement(Popover.Root, null, /* @__PURE__ */ React2.createElement(Popover.Trigger, {
481
+ asChild: true
482
+ }, /* @__PURE__ */ React2.createElement(IconButton2, {
483
+ variant: "ghost",
484
+ icon: "ph--sliders-horizontal--regular",
485
+ iconOnly: true,
486
+ label: t("context settings button")
487
+ })), /* @__PURE__ */ React2.createElement(Popover.Portal, null, /* @__PURE__ */ React2.createElement(Popover.Content, {
488
+ side: "top",
489
+ classNames: panelClassNames
490
+ }, /* @__PURE__ */ React2.createElement(Popover.Viewport, null, /* @__PURE__ */ React2.createElement(Tabs.Root, {
491
+ orientation: "horizontal",
492
+ defaultValue: "blueprints",
493
+ defaultActivePart: "list",
494
+ tabIndex: -1
495
+ }, /* @__PURE__ */ React2.createElement(Tabs.Viewport, {
496
+ classNames: mx2("max-h-(--radix-popover-content-available-height) grid grid-rows-[1fr_min-content]", '[&_[cmdk-root]]:contents [&_[role="tabpanel"]]:grid [&_[role="tabpanel"]]:grid-rows-[1fr_min-content]', '[&_[role="listbox"]]:min-h-0 [&_[role="listbox"]]:overflow-y-auto', '[&_[role="tabpanel"]]:min-h-0 [&_[role="tabpanel"]]:px-form-chrome [&_[role="tabpanel"][data-state="active"]]:order-first [&_[role="tabpanel"][data-state="inactive"]]:hidden')
497
+ }, /* @__PURE__ */ React2.createElement(Tabs.Tabpanel, {
498
+ value: "blueprints",
499
+ tabIndex: -1,
500
+ classNames: "dx-focus-ring-inset"
501
+ }, /* @__PURE__ */ React2.createElement(BlueprintsPanel, {
502
+ blueprintRegistry,
503
+ db,
504
+ context
505
+ })), /* @__PURE__ */ React2.createElement(Tabs.Tabpanel, {
506
+ value: "model",
507
+ tabIndex: -1,
508
+ classNames: "dx-focus-ring-inset px-0!"
509
+ }, /* @__PURE__ */ React2.createElement(ModelsPanel, {
510
+ presets,
511
+ preset,
512
+ onPresetChange
513
+ })), /* @__PURE__ */ React2.createElement(Tabs.Tablist, {
514
+ classNames: "sm:overflow-x-hidden justify-center p-form-chrome border-y border-subdued-separator order-last"
515
+ }, /* @__PURE__ */ React2.createElement(Tabs.IconTab, {
516
+ value: "blueprints",
517
+ icon: "ph--blueprint--regular",
518
+ label: t("blueprints in context title")
519
+ }), /* @__PURE__ */ React2.createElement(Tabs.IconTab, {
520
+ value: "model",
521
+ label: t("chat model title"),
522
+ icon: "ph--cpu--regular"
523
+ }))))), /* @__PURE__ */ React2.createElement(Popover.Arrow, null)))));
524
+ };
525
+ var BlueprintsPanel = ({ blueprintRegistry, db, context }) => {
526
+ const { t } = useTranslation2(meta.id);
527
+ const blueprints = useBlueprints({
528
+ blueprintRegistry,
529
+ db
530
+ });
531
+ const activeBlueprints = useActiveBlueprints({
532
+ context
533
+ });
534
+ const { onUpdateBlueprint } = useBlueprintHandlers({
535
+ db,
536
+ context,
537
+ blueprintRegistry
538
+ });
539
+ const { results, handleSearch } = useSearchListResults({
540
+ items: blueprints,
541
+ extract: (blueprint) => blueprint.name
542
+ });
543
+ return /* @__PURE__ */ React2.createElement(SearchList.Root, {
544
+ onSearch: handleSearch
545
+ }, /* @__PURE__ */ React2.createElement(SearchList.Content, {
546
+ classNames: "py-form-chrome"
547
+ }, /* @__PURE__ */ React2.createElement(SearchList.Viewport, null, results.map((blueprint) => {
548
+ const isActive = activeBlueprints.has(blueprint.key);
549
+ return /* @__PURE__ */ React2.createElement(SearchList.Item, {
550
+ classNames: "flex items-center overflow-hidden",
551
+ key: blueprint.key,
552
+ value: blueprint.key,
553
+ label: blueprint.name,
554
+ checked: isActive,
555
+ onSelect: () => onUpdateBlueprint?.(blueprint.key, !isActive)
556
+ });
557
+ }))), /* @__PURE__ */ React2.createElement(SearchList.Input, {
558
+ placeholder: t("search placeholder"),
559
+ classNames: "mb-form-chrome",
560
+ autoFocus: true
561
+ }));
562
+ };
563
+ var ModelsPanel = ({ presets, preset, onPresetChange }) => {
564
+ return /* @__PURE__ */ React2.createElement(Listbox.Root, {
565
+ value: preset,
566
+ onValueChange: onPresetChange,
567
+ autoFocus: true
568
+ }, presets?.map(({ id, label }) => {
569
+ return /* @__PURE__ */ React2.createElement(Listbox.Option, {
570
+ key: id,
571
+ value: id
572
+ }, /* @__PURE__ */ React2.createElement(Listbox.OptionLabel, null, label), /* @__PURE__ */ React2.createElement(Listbox.OptionIndicator, null));
573
+ }));
574
+ };
575
+ var ANY = "__any__";
576
+ var ObjectsPanel = ({ db, context }) => {
577
+ const { t } = useTranslation2(meta.id);
578
+ const types = useFilteredTypes(db);
579
+ const typenames = useMemo6(() => {
580
+ const typenames2 = types.map((type) => {
581
+ const typename2 = Type.getTypename(type);
582
+ return {
583
+ typename: typename2,
584
+ label: t("typename label", {
585
+ ns: typename2,
586
+ defaultValue: typename2
587
+ })
588
+ };
589
+ });
590
+ typenames2.sort((a, b) => a.label.localeCompare(b.label));
591
+ return typenames2;
592
+ }, [
593
+ types
594
+ ]);
595
+ const [typename, setTypename] = useState8(ANY);
596
+ const anyFilter = useMemo6(() => Filter3.or(...typenames.map(({ typename: typename2 }) => Filter3.typename(typename2))), [
597
+ typenames
598
+ ]);
599
+ const objects = useQuery2(db, typename === ANY ? anyFilter : Filter3.typename(typename));
600
+ const { objects: contextObjects, onUpdateObject } = useContextObjects({
601
+ db,
602
+ context
603
+ });
604
+ const { results, handleSearch } = useSearchListResults({
605
+ items: objects,
606
+ extract: (object) => Obj3.getLabel(object) ?? Obj3.getTypename(object) ?? object.id
607
+ });
608
+ return /* @__PURE__ */ React2.createElement(SearchList.Root, {
609
+ onSearch: handleSearch
610
+ }, /* @__PURE__ */ React2.createElement(SearchList.Content, {
611
+ classNames: "p-form-chrome [&:has([cmdk-list-sizer]:empty)]:py-0"
612
+ }, /* @__PURE__ */ React2.createElement(SearchList.Viewport, null, results.length ? results.map((object) => {
613
+ const isActive = contextObjects.findIndex((obj) => obj.id === object.id) !== -1;
614
+ const { icon, hue } = Option2.fromNullable(Obj3.getSchema(object)).pipe(Option2.flatMap(Annotation.IconAnnotation.get), Option2.getOrElse(() => ({
615
+ icon: DEFAULT_OBJECT_ICON,
616
+ hue: void 0
617
+ })));
618
+ const styles = hue ? getStyles(hue) : void 0;
619
+ return /* @__PURE__ */ React2.createElement(SearchList.Item, {
620
+ classNames: "flex items-center overflow-hidden",
621
+ key: object.id,
622
+ value: object.id,
623
+ icon,
624
+ iconClassNames: styles?.surfaceText,
625
+ label: Obj3.getLabel(object) ?? Obj3.getTypename(object) ?? object.id,
626
+ checked: isActive,
627
+ onSelect: () => onUpdateObject?.(Obj3.getDXN(object), !isActive)
628
+ });
629
+ }) : /* @__PURE__ */ React2.createElement(SearchList.Item, {
630
+ value: "__empty__",
631
+ label: t("no results")
632
+ }))), /* @__PURE__ */ React2.createElement("div", {
633
+ role: "none",
634
+ className: "grid grid-cols-[min-content_1fr] gap-2 px-form-chrome mb-form-chrome"
635
+ }, /* @__PURE__ */ React2.createElement(Select.Root, {
636
+ value: typename === ANY ? void 0 : typename,
637
+ onValueChange: setTypename
638
+ }, /* @__PURE__ */ React2.createElement(Select.TriggerButton, {
639
+ density: "fine",
640
+ placeholder: t("type filter placeholder")
641
+ }), /* @__PURE__ */ React2.createElement(Select.Portal, null, /* @__PURE__ */ React2.createElement(Select.Content, null, /* @__PURE__ */ React2.createElement(Select.ScrollUpButton, null), /* @__PURE__ */ React2.createElement(Select.Viewport, null, /* @__PURE__ */ React2.createElement(Select.Option, {
642
+ value: ANY
643
+ }, t("any type filter label")), typenames.map(({ typename: typename2, label }) => /* @__PURE__ */ React2.createElement(Select.Option, {
644
+ key: typename2,
645
+ value: typename2
646
+ }, label))), /* @__PURE__ */ React2.createElement(Select.ScrollDownButton, null), /* @__PURE__ */ React2.createElement(Select.Arrow, null)))), /* @__PURE__ */ React2.createElement(SearchList.Input, {
647
+ placeholder: t("search placeholder"),
648
+ classNames: "mb-0",
649
+ autoFocus: true
650
+ })));
651
+ };
652
+ var DEFAULT_OBJECT_ICON = "ph--cube--regular";
653
+
654
+ // src/components/ChatPrompt/ChatPresets.tsx
655
+ import React3 from "react";
656
+ import { Select as Select2 } from "@dxos/react-ui";
657
+
658
+ // src/components/ChatPrompt/ChatReferences.tsx
659
+ import * as Option3 from "effect/Option";
660
+ import React4 from "react";
661
+ import { Annotation as Annotation2, Obj as Obj4 } from "@dxos/echo";
662
+ import { Icon, IconButton as IconButton3, toLocalizedString, useTranslation as useTranslation3 } from "@dxos/react-ui";
663
+ import { getStyles as getStyles2, mx as mx3 } from "@dxos/ui-theme";
664
+ var ChatReferences = ({ classNames, context, db }) => {
665
+ const { t } = useTranslation3(meta.id);
666
+ const { objects, onUpdateObject } = useContextObjects({
667
+ db,
668
+ context
669
+ });
670
+ return /* @__PURE__ */ React4.createElement("ul", {
671
+ className: mx3("flex", classNames)
672
+ }, objects.map((obj) => {
673
+ const dxn = Obj4.getDXN(obj);
674
+ const typename = Obj4.getTypename(obj);
675
+ const label = Obj4.getLabel(obj) ?? (typename ? [
676
+ "object name placeholder",
677
+ {
678
+ ns: typename
679
+ }
680
+ ] : obj.id);
681
+ const { icon, hue } = Option3.fromNullable(Obj4.getSchema(obj)).pipe(Option3.flatMap(Annotation2.IconAnnotation.get), Option3.getOrElse(() => ({
682
+ icon: DEFAULT_OBJECT_ICON2,
683
+ hue: void 0
684
+ })));
685
+ const styles = hue ? getStyles2(hue) : void 0;
686
+ return /* @__PURE__ */ React4.createElement("li", {
687
+ key: dxn.toString(),
688
+ className: "dx-tag py-0 ps-2 flex items-center gap-1",
689
+ "data-hue": "neutral"
690
+ }, /* @__PURE__ */ React4.createElement(Icon, {
691
+ icon,
692
+ size: 4,
693
+ classNames: styles?.surfaceText
694
+ }), toLocalizedString(label, t), /* @__PURE__ */ React4.createElement(IconButton3, {
695
+ icon: "ph--x--bold",
696
+ iconOnly: true,
697
+ variant: "ghost",
698
+ label: t("remove object in context label"),
699
+ classNames: "p-0 hover:bg-transparent",
700
+ size: 3,
701
+ onClick: () => onUpdateObject?.(dxn, false)
702
+ }));
703
+ }));
704
+ };
705
+ var DEFAULT_OBJECT_ICON2 = "ph--cube--regular";
706
+
707
+ // src/components/ChatPrompt/ChatStatusIndicator.tsx
708
+ import React5, { useEffect as useEffect4, useState as useState9 } from "react";
709
+ import { Tooltip, useTimeout } from "@dxos/react-ui";
710
+ import { Spinner } from "@dxos/react-ui-sfx";
711
+ import { mx as mx4 } from "@dxos/ui-theme";
712
+ var period = 3e3;
713
+ var ChatStatusIndicator = ({ classNames, preset, processing, error, ...props }) => {
714
+ const [init, setInit] = useState9(false);
715
+ useEffect4(() => setInit(false), [
716
+ preset
717
+ ]);
718
+ useTimeout(async () => {
719
+ setInit(true);
720
+ }, period / 2, [
721
+ preset
722
+ ]);
723
+ return /* @__PURE__ */ React5.createElement("div", {
724
+ role: "none",
725
+ className: mx4("relative flex", classNames)
726
+ }, /* @__PURE__ */ React5.createElement(Spinner, {
727
+ duration: period,
728
+ state: !init ? "flash" : error ? "error" : processing ? "spin" : "pulse",
729
+ ...props
730
+ }), error && /* @__PURE__ */ React5.createElement(Tooltip.Trigger, {
731
+ asChild: true,
732
+ content: error.message
733
+ }, /* @__PURE__ */ React5.createElement("div", {
734
+ className: "absolute inset-0"
735
+ })));
736
+ };
737
+
738
+ // src/components/ChatThread/ChatThread.tsx
739
+ import React8, { forwardRef, useCallback as useCallback6, useEffect as useEffect6, useMemo as useMemo8, useState as useState11 } from "react";
740
+ import { PublicKey } from "@dxos/keys";
741
+ import { useForwardedRef } from "@dxos/react-ui";
742
+ import { MarkdownStream } from "@dxos/react-ui-components";
743
+ import { mx as mx5 } from "@dxos/ui-theme";
744
+ import { keyToFallback } from "@dxos/util";
745
+
746
+ // src/components/ChatThread/registry.tsx
747
+ import React7 from "react";
748
+ import { log as log2 } from "@dxos/log";
749
+ import { ToggleContainer as ToggleContainer2 } from "@dxos/react-ui-components";
750
+ import { PromptWidget, ReasoningWidget, ReferenceWidget, SelectWidget, SuggestionWidget, SummaryWidget } from "@dxos/react-ui-components";
751
+ import { Json as Json2 } from "@dxos/react-ui-syntax-highlighter";
752
+ import { ContentBlock } from "@dxos/types";
753
+ import { getXmlTextChild } from "@dxos/ui-editor";
754
+
755
+ // src/components/ToolBlock/ToolBlock.tsx
756
+ import React6, { useCallback as useCallback5, useEffect as useEffect5, useMemo as useMemo7, useRef as useRef2, useState as useState10 } from "react";
757
+ import { useTranslation as useTranslation4 } from "@dxos/react-ui";
758
+ import { NumericTabs, TextCrawl, ToggleContainer } from "@dxos/react-ui-components";
759
+ import { Json } from "@dxos/react-ui-syntax-highlighter";
760
+ import { isNonNullable, safeParseJson } from "@dxos/util";
761
+ var ToolBlock = ({ view, blocks = [] }) => {
762
+ const { t } = useTranslation4(meta.id);
763
+ const items = useMemo7(() => {
764
+ let lastToolCall;
765
+ const tools = [];
766
+ return blocks.filter((block) => block._tag === "toolCall" || block._tag === "toolResult" || block._tag === "stats").map((block) => {
767
+ switch (block._tag) {
768
+ case "toolCall": {
769
+ if (block.pending && lastToolCall?.block.toolCallId === block.toolCallId) {
770
+ return null;
771
+ }
772
+ const tool = tools.find((tool2) => tool2.name === block.name);
773
+ lastToolCall = {
774
+ tool,
775
+ block
776
+ };
777
+ return {
778
+ title: tool?.description ?? [
779
+ t("tool call label"),
780
+ tool?.name
781
+ ].join(" "),
782
+ content: {
783
+ ...block,
784
+ input: safeParseJson(block.input)
785
+ }
786
+ };
787
+ }
788
+ case "toolResult": {
789
+ if (block.error) {
790
+ return {
791
+ title: t("tool error label"),
792
+ content: block
793
+ };
794
+ }
795
+ const title = lastToolCall?.tool?.description ?? [
796
+ t("tool result label"),
797
+ lastToolCall?.tool?.name
798
+ ].join(" ");
799
+ lastToolCall = void 0;
800
+ return {
801
+ title,
802
+ content: {
803
+ ...block,
804
+ result: safeParseJson(block.result)
805
+ }
806
+ };
807
+ }
808
+ case "stats": {
809
+ if (!lastToolCall) {
810
+ return null;
811
+ }
812
+ return {
813
+ title: t("stats label"),
814
+ content: block
815
+ };
816
+ }
817
+ }
818
+ }).filter(isNonNullable);
819
+ }, [
820
+ blocks
821
+ ]);
822
+ const handleChangeOpen = useCallback5(() => {
823
+ setTimeout(() => {
824
+ view?.requestMeasure();
825
+ }, 1e3);
826
+ }, [
827
+ view
828
+ ]);
829
+ if (!items.length) {
830
+ return null;
831
+ }
832
+ return /* @__PURE__ */ React6.createElement(ToolContainer, {
833
+ items,
834
+ onChangeOpen: handleChangeOpen
835
+ });
836
+ };
837
+ ToolBlock.displayName = "ToolBlock";
838
+ var ToolContainer = ({ items, onChangeOpen }) => {
839
+ const tabsRef = useRef2(null);
840
+ const [selected, setSelected] = useState10(0);
841
+ const [open, setOpen] = useState10(false);
842
+ useEffect5(() => {
843
+ onChangeOpen?.(open);
844
+ if (open) {
845
+ tabsRef.current?.focus();
846
+ }
847
+ }, [
848
+ open,
849
+ onChangeOpen
850
+ ]);
851
+ const handleSelect = useCallback5((index) => {
852
+ setSelected(index);
853
+ }, []);
854
+ return /* @__PURE__ */ React6.createElement(ToggleContainer.Root, {
855
+ classNames: "mt-2 w-full rounded-xs",
856
+ open,
857
+ onChangeOpen: setOpen
858
+ }, /* @__PURE__ */ React6.createElement(ToggleContainer.Header, {
859
+ classNames: "text-sm text-placeholder"
860
+ }, /* @__PURE__ */ React6.createElement(TextCrawl, {
861
+ key: "status-roll",
862
+ lines: items.map((item) => item.title),
863
+ autoAdvance: true,
864
+ greedy: true
865
+ })), /* @__PURE__ */ React6.createElement(ToggleContainer.Content, {
866
+ classNames: "grid grid-cols-[32px_1fr]"
867
+ }, /* @__PURE__ */ React6.createElement(NumericTabs, {
868
+ ref: tabsRef,
869
+ classNames: "p-1",
870
+ length: items.length,
871
+ selected,
872
+ onSelect: handleSelect
873
+ }), /* @__PURE__ */ React6.createElement(Json, {
874
+ data: items[selected]?.content,
875
+ classNames: "p-1 text-xs bg-transparent",
876
+ replacer: {
877
+ maxDepth: 3,
878
+ maxArrayLen: 10,
879
+ maxStringLen: 128
880
+ }
881
+ })));
882
+ };
883
+
884
+ // src/components/ChatThread/registry.tsx
885
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/components/ChatThread/registry.tsx";
886
+ var Fallback = ({ _tag, ...props }) => {
887
+ return /* @__PURE__ */ React7.createElement(ToggleContainer2.Root, {
888
+ classNames: "rounded-xs"
889
+ }, /* @__PURE__ */ React7.createElement(ToggleContainer2.Header, {
890
+ classNames: "bg-group-surface"
891
+ }, _tag), /* @__PURE__ */ React7.createElement(ToggleContainer2.Content, {
892
+ classNames: "bg-modal-surface"
893
+ }, /* @__PURE__ */ React7.createElement(Json2, {
894
+ classNames: "p-2! text-sm",
895
+ data: props
896
+ })));
897
+ };
898
+ var Summary = ({ text }) => {
899
+ return /* @__PURE__ */ React7.createElement(ToggleContainer2.Root, {
900
+ classNames: "rounded-sm"
901
+ }, /* @__PURE__ */ React7.createElement(ToggleContainer2.Header, {
902
+ classNames: "bg-group-surface"
903
+ }, "Conversation summarized"), /* @__PURE__ */ React7.createElement(ToggleContainer2.Content, {
904
+ classNames: "bg-modal-surface"
905
+ }, text));
906
+ };
907
+ var componentRegistry = {
908
+ //
909
+ // Widgets
910
+ //
911
+ prompt: {
912
+ block: true,
913
+ factory: ({ children }) => {
914
+ const text = getXmlTextChild(children);
915
+ return text ? new PromptWidget(text) : null;
916
+ }
917
+ },
918
+ reasoning: {
919
+ block: true,
920
+ factory: ({ children }) => {
921
+ const text = getXmlTextChild(children);
922
+ return text ? new ReasoningWidget(text) : null;
923
+ }
924
+ },
925
+ reference: {
926
+ block: false,
927
+ factory: ({ children, ref }) => {
928
+ const text = getXmlTextChild(children);
929
+ return text && ref ? new ReferenceWidget(text, ref) : null;
930
+ }
931
+ },
932
+ select: {
933
+ block: true,
934
+ factory: ({ children }) => {
935
+ const options = children?.map((option) => option._tag === "option" && getXmlTextChild(option.children)).filter(Boolean);
936
+ return options?.length ? new SelectWidget(options) : null;
937
+ }
938
+ },
939
+ suggestion: {
940
+ block: true,
941
+ factory: ({ children }) => {
942
+ const text = getXmlTextChild(children);
943
+ return text ? new SuggestionWidget(text) : null;
944
+ }
945
+ },
946
+ stats: {
947
+ block: true,
948
+ factory: ({ children }) => {
949
+ const text = getXmlTextChild(children);
950
+ return text ? new SummaryWidget(text) : null;
951
+ }
952
+ },
953
+ //
954
+ // React
955
+ //
956
+ toolCall: {
957
+ block: true,
958
+ Component: ToolBlock
959
+ },
960
+ toolResult: {
961
+ block: true,
962
+ Component: Fallback
963
+ },
964
+ toolkit: {
965
+ block: true,
966
+ Component: Fallback
967
+ },
968
+ summary: {
969
+ block: true,
970
+ Component: Summary
971
+ },
972
+ //
973
+ // Fallback
974
+ //
975
+ json: {
976
+ block: true,
977
+ Component: Fallback
978
+ }
979
+ };
980
+ var blockToMarkdown = (context, message, block) => {
981
+ let str = blockToMarkdownImpl(context, message, block);
982
+ if (str && !block.pending) {
983
+ return str += "\n";
984
+ }
985
+ return str;
986
+ };
987
+ var blockToMarkdownImpl = (context, message, block) => {
988
+ log2("blockToMarkdown", {
989
+ block: JSON.stringify(block)
990
+ }, {
991
+ F: __dxlog_file2,
992
+ L: 146,
993
+ S: void 0,
994
+ C: (f, a) => f(...a)
995
+ });
996
+ switch (block._tag) {
997
+ case "text": {
998
+ if (message.sender.role === "user") {
999
+ return `<prompt>${block.text}</prompt>`;
1000
+ } else {
1001
+ const text = block.text.trim();
1002
+ if (text.length > 0) {
1003
+ return text;
1004
+ }
1005
+ }
1006
+ break;
1007
+ }
1008
+ case "reference": {
1009
+ const dxn = block.reference.dxn;
1010
+ return `<reference ref="${dxn.toString()}">${context.getObjectLabel(dxn)}</reference>`;
1011
+ }
1012
+ case "suggestion": {
1013
+ if (block.pending) {
1014
+ return;
1015
+ }
1016
+ return `<suggestion>${block.text}</suggestion>`;
1017
+ }
1018
+ case "select": {
1019
+ if (block.pending || block.options.length === 0) {
1020
+ return;
1021
+ }
1022
+ return `<select>${block.options.map((option) => `<option>${option}</option>`).join("")}</select>`;
1023
+ }
1024
+ case "toolCall": {
1025
+ context.updateWidget(block.toolCallId, {
1026
+ blocks: [
1027
+ block
1028
+ ]
1029
+ });
1030
+ return `<toolCall id="${block.toolCallId}" />`;
1031
+ }
1032
+ case "toolResult": {
1033
+ context.updateWidget(block.toolCallId, ({ blocks = [] } = {
1034
+ blocks: []
1035
+ }) => ({
1036
+ blocks: [
1037
+ ...blocks,
1038
+ block
1039
+ ]
1040
+ }));
1041
+ break;
1042
+ }
1043
+ case "stats": {
1044
+ return `<stats>${ContentBlock.createStatsMessage(block)}</stats>`;
1045
+ }
1046
+ case "reasoning": {
1047
+ const text = block.reasoningText ?? block.redactedText;
1048
+ if (!text) {
1049
+ return;
1050
+ }
1051
+ return `<reasoning>${text.replace(/\n/g, " ").trim()}</reasoning>`;
1052
+ }
1053
+ case "summary": {
1054
+ return `<summary>${block.content}</summary>`;
1055
+ }
1056
+ default: {
1057
+ return `<json id="${message.id}">
1058
+ ${JSON.stringify(block)}
1059
+ </json>`;
1060
+ }
1061
+ }
1062
+ };
1063
+
1064
+ // src/components/ChatThread/sync.ts
1065
+ import { log as log3 } from "@dxos/log";
1066
+ var __dxlog_file3 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/components/ChatThread/sync.ts";
1067
+ var MessageThreadContext = class {
1068
+ _widgetState;
1069
+ constructor(_widgetState) {
1070
+ this._widgetState = _widgetState;
1071
+ }
1072
+ updateWidget(id, value) {
1073
+ this._widgetState?.updateWidget(id, value);
1074
+ }
1075
+ // TODO(burdon): Resolve from hypergraph.
1076
+ getObjectLabel(_id) {
1077
+ return "Object";
1078
+ }
1079
+ };
1080
+ var MessageSyncer = class {
1081
+ _model;
1082
+ _blockRenderer;
1083
+ _initialMessageId;
1084
+ _currentMessageIndex = 0;
1085
+ _currentBlockIndex = 0;
1086
+ _currentBlockContent;
1087
+ _context;
1088
+ constructor(_model, _blockRenderer) {
1089
+ this._model = _model;
1090
+ this._blockRenderer = _blockRenderer;
1091
+ this._context = new MessageThreadContext(this._model);
1092
+ }
1093
+ get context() {
1094
+ return this._context;
1095
+ }
1096
+ reset() {
1097
+ log3("reset", void 0, {
1098
+ F: __dxlog_file3,
1099
+ L: 64,
1100
+ S: this,
1101
+ C: (f, a) => f(...a)
1102
+ });
1103
+ this._initialMessageId = void 0;
1104
+ this._currentMessageIndex = 0;
1105
+ this._currentBlockIndex = 0;
1106
+ this._currentBlockContent = void 0;
1107
+ void this._model.reset("");
1108
+ }
1109
+ /**
1110
+ * Syncs messages with the editor.
1111
+ */
1112
+ append(messages, flush = false) {
1113
+ messages = messages.map((message) => ({
1114
+ ...message,
1115
+ blocks: message.blocks.filter((block) => !block.pending || block._tag === "text")
1116
+ }));
1117
+ if (this._initialMessageId !== messages[0]?.id) {
1118
+ this.reset();
1119
+ this._initialMessageId = messages[0]?.id;
1120
+ }
1121
+ if (flush && this._model.view?.state.doc.length === 0) {
1122
+ const buffer = [];
1123
+ this.process(messages, (content2) => {
1124
+ buffer.push(content2);
1125
+ });
1126
+ const content = buffer.join("");
1127
+ this._model.view?.dispatch({
1128
+ changes: [
1129
+ {
1130
+ from: 0,
1131
+ to: this._model.view?.state.doc.length ?? 0,
1132
+ insert: content
1133
+ }
1134
+ ],
1135
+ selection: {
1136
+ anchor: content.length
1137
+ }
1138
+ });
1139
+ return true;
1140
+ } else {
1141
+ this.process(messages, (content) => {
1142
+ void this._model.append(content);
1143
+ });
1144
+ return false;
1145
+ }
1146
+ }
1147
+ process(messages, append) {
1148
+ let i = this._currentMessageIndex;
1149
+ for (const message of messages.slice(this._currentMessageIndex)) {
1150
+ if (i > this._currentMessageIndex) {
1151
+ this._currentBlockIndex = 0;
1152
+ }
1153
+ this._currentMessageIndex = i;
1154
+ let j = this._currentBlockIndex;
1155
+ for (const block of message.blocks.slice(this._currentBlockIndex)) {
1156
+ this._currentBlockIndex = j;
1157
+ const currentBlockContent = this._blockRenderer(this._context, message, block);
1158
+ if (currentBlockContent) {
1159
+ let content = "";
1160
+ if (this._currentBlockContent && currentBlockContent.startsWith(this._currentBlockContent)) {
1161
+ content = currentBlockContent.slice(this._currentBlockContent.length);
1162
+ } else {
1163
+ content = currentBlockContent;
1164
+ }
1165
+ this._currentBlockContent = currentBlockContent;
1166
+ append(content);
1167
+ }
1168
+ if (block.pending) {
1169
+ return;
1170
+ } else {
1171
+ this._currentBlockContent = void 0;
1172
+ this._currentBlockIndex++;
1173
+ }
1174
+ j++;
1175
+ }
1176
+ i++;
1177
+ }
1178
+ }
1179
+ };
1180
+
1181
+ // src/components/ChatThread/ChatThread.tsx
1182
+ var ChatThread = /* @__PURE__ */ forwardRef(({ classNames, identity, messages = [], error, cursor = false, fadeIn = true, debug = false, onEvent }, forwardedRef) => {
1183
+ const controllerRef = useForwardedRef(forwardedRef);
1184
+ const [controller, setController] = useState11(null);
1185
+ const refCallback = useCallback6((node) => {
1186
+ controllerRef.current = node;
1187
+ setController(node);
1188
+ }, [
1189
+ controllerRef
1190
+ ]);
1191
+ const userHue = useMemo8(() => identity?.profile?.data?.hue || keyToFallback(identity?.identityKey ?? PublicKey.random()).hue, [
1192
+ identity
1193
+ ]);
1194
+ useEffect6(() => {
1195
+ controller?.scrollToBottom();
1196
+ }, [
1197
+ controller,
1198
+ error
1199
+ ]);
1200
+ const syncer = useMemo8(() => controller && new MessageSyncer(controller, blockToMarkdown), [
1201
+ controller
1202
+ ]);
1203
+ useEffect6(() => {
1204
+ const reset = syncer?.append(messages, true);
1205
+ if (reset) {
1206
+ controller?.scrollToBottom("instant");
1207
+ }
1208
+ }, [
1209
+ syncer,
1210
+ messages
1211
+ ]);
1212
+ const handleEvent = useCallback6(({ type, value }) => {
1213
+ switch (type) {
1214
+ case "submit": {
1215
+ value && onEvent?.({
1216
+ type,
1217
+ text: value
1218
+ });
1219
+ break;
1220
+ }
1221
+ }
1222
+ }, [
1223
+ onEvent
1224
+ ]);
1225
+ return /* @__PURE__ */ React8.createElement("div", {
1226
+ role: "none",
1227
+ className: mx5("flex h-full w-full justify-center overflow-hidden", classNames),
1228
+ style: {
1229
+ "--user-fill": `var(--color-${userHue}-fill)`
1230
+ }
1231
+ }, /* @__PURE__ */ React8.createElement(MarkdownStream, {
1232
+ ref: refCallback,
1233
+ registry: componentRegistry,
1234
+ cursor,
1235
+ fadeIn,
1236
+ debug,
1237
+ onEvent: handleEvent
1238
+ }));
1239
+ });
1240
+
1241
+ // src/components/Chat/Chat.tsx
1242
+ var [ChatContextProvider, useChatContext] = createContext("Chat");
1243
+ var ChatRoot = ({ children, chat, processor, onEvent, ...props }) => {
1244
+ const [debug, setDebug] = useState12(false);
1245
+ const pending = useAtomValue(processor.messages);
1246
+ const streaming = useAtomValue(processor.streaming);
1247
+ const lastPrompt = useRef3(void 0);
1248
+ const storedMessages = useQuery3(chat?.queue?.target, Filter4.type(Message.Message));
1249
+ const messages = useMemo9(() => {
1250
+ return Array2.dedupeWith([
1251
+ ...storedMessages,
1252
+ ...pending
1253
+ ], ({ id: a }, { id: b }) => a === b);
1254
+ }, [
1255
+ storedMessages,
1256
+ pending
1257
+ ]);
1258
+ const event = useMemo9(() => new Event(), []);
1259
+ useEffect7(() => {
1260
+ return event.on((ev) => {
1261
+ switch (ev.type) {
1262
+ case "toggle-debug": {
1263
+ setDebug((debug2) => !debug2);
1264
+ queueMicrotask(async () => {
1265
+ const objects = processor.context.getObjects();
1266
+ const blueprints = processor.context.getBlueprints();
1267
+ const tools = await processor.getTools();
1268
+ const system = await processor.getSystemPrompt();
1269
+ console.log("Chat processor state:", {
1270
+ objects,
1271
+ blueprints
1272
+ });
1273
+ console.log(`
1274
+ ==== System Prompt ====
1275
+ ${system}
1276
+ ==== Tools ====
1277
+ ${Object.values(tools).map((tool) => JSON.stringify(tool, null, 2)).join("\n")}
1278
+ `);
1279
+ });
1280
+ break;
1281
+ }
1282
+ case "submit": {
1283
+ const text = ev.text.trim();
1284
+ if (!streaming && text.length) {
1285
+ lastPrompt.current = ev.text;
1286
+ void processor.request({
1287
+ message: text
1288
+ });
1289
+ }
1290
+ break;
1291
+ }
1292
+ case "retry": {
1293
+ if (!streaming) {
1294
+ void processor.retry();
1295
+ }
1296
+ break;
1297
+ }
1298
+ case "cancel": {
1299
+ if (streaming) {
1300
+ void processor.cancel();
1301
+ if (lastPrompt.current) {
1302
+ event.emit({
1303
+ type: "update-prompt",
1304
+ text: lastPrompt.current
1305
+ });
1306
+ }
1307
+ }
1308
+ break;
1309
+ }
1310
+ }
1311
+ onEvent?.(ev);
1312
+ });
1313
+ }, [
1314
+ event,
1315
+ processor,
1316
+ streaming,
1317
+ onEvent
1318
+ ]);
1319
+ const db = props.db ?? (chat && Obj5.getDatabase(chat));
1320
+ return /* @__PURE__ */ React9.createElement(ChatContextProvider, {
1321
+ debug,
1322
+ event,
1323
+ db,
1324
+ chat,
1325
+ messages,
1326
+ processor,
1327
+ ...props
1328
+ }, children);
1329
+ };
1330
+ ChatRoot.displayName = "Chat.Root";
1331
+ var CHAT_VIEWPORT_NAME = "Chat.Viewport";
1332
+ var ChatViewport = ({ classNames, children, ...props }) => {
1333
+ return /* @__PURE__ */ React9.createElement("div", {
1334
+ role: "none",
1335
+ ...props,
1336
+ className: mx6("flex flex-col h-full w-full", classNames)
1337
+ }, children);
1338
+ };
1339
+ ChatViewport.displayName = CHAT_VIEWPORT_NAME;
1340
+ var CHAT_THREAD_NAME = "Chat.Thread";
1341
+ var ChatThread2 = (props) => {
1342
+ const { debug, event, messages, processor } = useChatContext(CHAT_THREAD_NAME);
1343
+ const identity = useIdentity();
1344
+ const error = useAtomValue(processor.error).pipe(Option4.getOrUndefined);
1345
+ const controllerRef = useRef3(null);
1346
+ useEffect7(() => {
1347
+ return event.on((event2) => {
1348
+ switch (event2.type) {
1349
+ case "submit":
1350
+ case "scroll-to-bottom":
1351
+ controllerRef.current?.scrollToBottom();
1352
+ break;
1353
+ case "nav-previous":
1354
+ controllerRef.current?.navigatePrevious();
1355
+ break;
1356
+ case "nav-next":
1357
+ controllerRef.current?.navigateNext();
1358
+ break;
1359
+ }
1360
+ });
1361
+ }, [
1362
+ event
1363
+ ]);
1364
+ const handleEvent = useCallback7((ev) => {
1365
+ event.emit(ev);
1366
+ }, [
1367
+ event
1368
+ ]);
1369
+ if (!identity) {
1370
+ return null;
1371
+ }
1372
+ return /* @__PURE__ */ React9.createElement(ChatThread, {
1373
+ ...props,
1374
+ identity,
1375
+ messages,
1376
+ error,
1377
+ debug,
1378
+ onEvent: handleEvent,
1379
+ ref: controllerRef
1380
+ });
1381
+ };
1382
+ ChatThread2.displayName = CHAT_THREAD_NAME;
1383
+ var CHAT_PROMPT_NAME = "Chat.Prompt";
1384
+ var ChatPrompt = ({ classNames, outline, settings = true, placeholder, expandable, online, presets, preset, onPresetChange, onOnlineChange }) => {
1385
+ const { t } = useTranslation5(meta.id);
1386
+ const { db, processor, event } = useChatContext(CHAT_PROMPT_NAME);
1387
+ const error = useAtomValue(processor.error).pipe(Option4.getOrUndefined);
1388
+ const streaming = useAtomValue(processor.streaming);
1389
+ const active = useAtomValue(processor.active);
1390
+ const activeRef = useDynamicRef(active);
1391
+ const editorRef = useRef3(null);
1392
+ const [recordingState, setRecordingState] = useState12(false);
1393
+ useEffect7(() => {
1394
+ return event.on((event2) => {
1395
+ switch (event2.type) {
1396
+ case "update-prompt":
1397
+ if (!editorRef.current?.getText()?.length) {
1398
+ editorRef.current?.setText(event2.text);
1399
+ editorRef.current?.focus();
1400
+ }
1401
+ break;
1402
+ case "record-start":
1403
+ setRecordingState(true);
1404
+ break;
1405
+ case "record-stop":
1406
+ setRecordingState(false);
1407
+ break;
1408
+ }
1409
+ });
1410
+ }, [
1411
+ event
1412
+ ]);
1413
+ const { recording } = useVoiceInput({
1414
+ active: recordingState,
1415
+ onUpdate: (text) => {
1416
+ editorRef.current?.setText(text);
1417
+ editorRef.current?.focus();
1418
+ }
1419
+ });
1420
+ const extensions = useMemo9(() => {
1421
+ return [
1422
+ Prec.highest(keymap.of([
1423
+ {
1424
+ key: "Mod-d",
1425
+ preventDefault: true,
1426
+ run: () => {
1427
+ event.emit({
1428
+ type: "toggle-debug"
1429
+ });
1430
+ return true;
1431
+ }
1432
+ },
1433
+ {
1434
+ key: "Mod-ArrowUp",
1435
+ preventDefault: true,
1436
+ run: () => {
1437
+ event.emit({
1438
+ type: "nav-previous"
1439
+ });
1440
+ return true;
1441
+ },
1442
+ shift: () => {
1443
+ event.emit({
1444
+ type: "thread-open"
1445
+ });
1446
+ return true;
1447
+ }
1448
+ },
1449
+ {
1450
+ key: "Mod-ArrowDown",
1451
+ preventDefault: true,
1452
+ run: () => {
1453
+ event.emit({
1454
+ type: "nav-next"
1455
+ });
1456
+ return true;
1457
+ },
1458
+ shift: () => {
1459
+ event.emit({
1460
+ type: "thread-close"
1461
+ });
1462
+ return true;
1463
+ }
1464
+ }
1465
+ ]))
1466
+ ].filter(isTruthy);
1467
+ }, [
1468
+ event,
1469
+ expandable
1470
+ ]);
1471
+ const handleSubmit = useCallback7((text) => {
1472
+ if (!activeRef.current) {
1473
+ event.emit({
1474
+ type: "submit",
1475
+ text
1476
+ });
1477
+ return true;
1478
+ }
1479
+ }, [
1480
+ event
1481
+ ]);
1482
+ const handleEvent = useCallback7((ev) => {
1483
+ event.emit(ev);
1484
+ }, [
1485
+ event
1486
+ ]);
1487
+ return /* @__PURE__ */ React9.createElement("div", {
1488
+ role: "group",
1489
+ className: mx6("flex flex-col w-full dx-density-fine", outline && "bg-group-surface border border-subdued-separator transition transition-border [&:has(.cm-content:focus)]:border-separator rounded-sm", classNames)
1490
+ }, /* @__PURE__ */ React9.createElement("div", {
1491
+ role: "none",
1492
+ className: "flex p-2 gap-2"
1493
+ }, /* @__PURE__ */ React9.createElement(ChatStatusIndicator, {
1494
+ classNames: "p-1",
1495
+ preset,
1496
+ error,
1497
+ processing: streaming
1498
+ }), /* @__PURE__ */ React9.createElement(ChatEditor, {
1499
+ ref: editorRef,
1500
+ autoFocus: true,
1501
+ lineWrapping: true,
1502
+ classNames: "col-span-2 pt-0.5",
1503
+ placeholder: placeholder ?? t("prompt placeholder"),
1504
+ extensions,
1505
+ onSubmit: handleSubmit
1506
+ })), db && settings && /* @__PURE__ */ React9.createElement("div", {
1507
+ role: "none",
1508
+ className: "flex items-center overflow-hidden"
1509
+ }, /* @__PURE__ */ React9.createElement(ChatOptions, {
1510
+ db,
1511
+ blueprintRegistry: processor.blueprintRegistry,
1512
+ context: processor.context,
1513
+ preset,
1514
+ presets,
1515
+ onPresetChange
1516
+ }), /* @__PURE__ */ React9.createElement("div", {
1517
+ role: "none",
1518
+ className: "flex grow overflow-x-auto scrollbar-none"
1519
+ }, /* @__PURE__ */ React9.createElement(ChatReferences, {
1520
+ db,
1521
+ context: processor.context
1522
+ })), /* @__PURE__ */ React9.createElement(ChatActions, {
1523
+ classNames: "col-span-2",
1524
+ microphone: true,
1525
+ recording,
1526
+ processing: streaming,
1527
+ onEvent: handleEvent
1528
+ }, online !== void 0 && /* @__PURE__ */ React9.createElement(Input.Root, null, /* @__PURE__ */ React9.createElement(Input.Label, {
1529
+ srOnly: true
1530
+ }, t("online switch label")), /* @__PURE__ */ React9.createElement(Input.Switch, {
1531
+ classNames: "mx-2",
1532
+ checked: online,
1533
+ onCheckedChange: onOnlineChange
1534
+ })))));
1535
+ };
1536
+ ChatPrompt.displayName = CHAT_PROMPT_NAME;
1537
+ var CHAT_TOOLBAR_NAME = "Chat.Toolbar";
1538
+ var ChatToolbar = ({ classNames, companionTo, ...props }) => {
1539
+ const { chat } = useChatContext(CHAT_TOOLBAR_NAME);
1540
+ const menu = useChatToolbarActions({
1541
+ chat,
1542
+ companionTo
1543
+ });
1544
+ return /* @__PURE__ */ React9.createElement(Menu.Root, {
1545
+ ...props,
1546
+ ...menu,
1547
+ attendableId: companionTo ? Obj5.getDXN(companionTo).toString() : chat ? Obj5.getDXN(chat).toString() : ""
1548
+ }, /* @__PURE__ */ React9.createElement(Menu.Toolbar, {
1549
+ classNames,
1550
+ textBlockWidth: true
1551
+ }));
1552
+ };
1553
+ ChatToolbar.displayName = CHAT_TOOLBAR_NAME;
1554
+ var Chat = {
1555
+ Root: ChatRoot,
1556
+ Viewport: ChatViewport,
1557
+ Thread: ChatThread2,
1558
+ Prompt: ChatPrompt,
1559
+ Toolbar: ChatToolbar
1560
+ };
1561
+
1562
+ // src/components/TemplateEditor/TemplateEditor.tsx
1563
+ import { defaultHighlightStyle, syntaxHighlighting } from "@codemirror/language";
1564
+ import React10 from "react";
1565
+ import { createDocAccessor } from "@dxos/echo-db";
1566
+ import { useThemeContext, useTranslation as useTranslation6 } from "@dxos/react-ui";
1567
+ import { useTextEditor } from "@dxos/react-ui-editor";
1568
+ import { createBasicExtensions, createDataExtensions, createMarkdownExtensions, createThemeExtensions, decorateMarkdown } from "@dxos/ui-editor";
1569
+ import { mx as mx8 } from "@dxos/ui-theme";
1570
+ import { isNonNullable as isNonNullable2 } from "@dxos/util";
1571
+
1572
+ // src/components/TemplateEditor/extensions/handlebars-extension.ts
1573
+ import { autocompletion, completionKeymap } from "@codemirror/autocomplete";
1574
+ import { RangeSetBuilder } from "@codemirror/state";
1575
+ import { Decoration, ViewPlugin, WidgetType, keymap as keymap2 } from "@codemirror/view";
1576
+ import { Domino, mx as mx7 } from "@dxos/ui";
1577
+ var handlebars = (_ = {}) => {
1578
+ return [
1579
+ handlebarsHighlightPlugin,
1580
+ autocompletion({
1581
+ activateOnTyping: true,
1582
+ aboveCursor: true,
1583
+ closeOnBlur: true,
1584
+ override: [
1585
+ handlebarsCompletions
1586
+ ]
1587
+ }),
1588
+ keymap2.of(completionKeymap)
1589
+ ];
1590
+ };
1591
+ var regex = {
1592
+ // {{! comment }}
1593
+ comment: /\{\{!\s*[^}]*\}\}/g,
1594
+ // {{var}}
1595
+ brackets: /\{\{[^}]*\}\}/g,
1596
+ // {{#command}} {{/command}}
1597
+ command: /\{\{[#/]([^}]+)\}\}/g,
1598
+ // {{var}}
1599
+ var: /\{\{(?!\s*!)(\w[^}]*)\}\}/g,
1600
+ // @dxn:queue:data:xxx
1601
+ dxn: /@?dxn:[\w@:]+/g,
1602
+ // dxos.org/type/xxx
1603
+ url: /[\w.-]+\.[\w.-]+\/[\w/]+/g
1604
+ };
1605
+ var tagPadding = "mx-0.5 px-1 rounded-xs";
1606
+ var handlebarsHighlightPlugin = ViewPlugin.fromClass(class {
1607
+ decorations;
1608
+ constructor(view) {
1609
+ this.decorations = this.buildDecorations(view);
1610
+ }
1611
+ update(update) {
1612
+ if (update.docChanged || update.viewportChanged || update.selectionSet) {
1613
+ this.decorations = this.buildDecorations(update.view);
1614
+ }
1615
+ }
1616
+ // NOTE: Decorations may clash with other extensions (e.g., markdown).
1617
+ buildDecorations(view) {
1618
+ const selection = view.state.selection.main;
1619
+ const decorations = [];
1620
+ for (const { from, to } of view.visibleRanges) {
1621
+ const text = view.state.doc.sliceString(from, to);
1622
+ {
1623
+ let match;
1624
+ while ((match = regex.dxn.exec(text)) !== null) {
1625
+ const start = from + match.index;
1626
+ const end = start + match[0].length;
1627
+ const overlaps = selection.to > start && selection.from <= end;
1628
+ if (!overlaps) {
1629
+ decorations.push({
1630
+ from: start,
1631
+ to: end,
1632
+ decoration: Decoration.widget({
1633
+ widget: new DXNWidget(match[0])
1634
+ })
1635
+ });
1636
+ }
1637
+ }
1638
+ }
1639
+ {
1640
+ let match;
1641
+ while ((match = regex.url.exec(text)) !== null) {
1642
+ const start = from + match.index;
1643
+ const end = start + match[0].length;
1644
+ decorations.push({
1645
+ from: start,
1646
+ to: end,
1647
+ decoration: Decoration.mark({
1648
+ class: mx7("dx-tag--blue", tagPadding)
1649
+ })
1650
+ });
1651
+ }
1652
+ }
1653
+ {
1654
+ let match;
1655
+ while ((match = regex.brackets.exec(text)) !== null) {
1656
+ const start = from + match.index;
1657
+ const end = start + match[0].length;
1658
+ decorations.push({
1659
+ from: start,
1660
+ to: end,
1661
+ decoration: Decoration.mark({
1662
+ class: "text-subdued"
1663
+ })
1664
+ });
1665
+ }
1666
+ }
1667
+ {
1668
+ let match;
1669
+ while ((match = regex.command.exec(text)) !== null) {
1670
+ const start = from + match.index + 2;
1671
+ let end = start + match[0].length - 4;
1672
+ const text2 = view.state.doc.sliceString(start, end);
1673
+ const parts = text2.split(/\s+/);
1674
+ if (parts.length > 1) {
1675
+ const idx = start + parts[0].length;
1676
+ decorations.push({
1677
+ from: idx,
1678
+ to: end,
1679
+ decoration: Decoration.mark({
1680
+ class: "text-green-text"
1681
+ })
1682
+ });
1683
+ end = idx;
1684
+ }
1685
+ decorations.push({
1686
+ from: start,
1687
+ to: end,
1688
+ decoration: Decoration.mark({
1689
+ class: "text-blue-text"
1690
+ })
1691
+ });
1692
+ }
1693
+ }
1694
+ {
1695
+ let match;
1696
+ while ((match = regex.var.exec(text)) !== null) {
1697
+ const start = from + match.index + 2;
1698
+ const end = start + match[0].length - 4;
1699
+ decorations.push({
1700
+ from: start,
1701
+ to: end,
1702
+ decoration: Decoration.mark({
1703
+ class: "text-green-text"
1704
+ })
1705
+ });
1706
+ }
1707
+ }
1708
+ }
1709
+ decorations.sort((a, b) => a.from - b.from || a.to - b.to);
1710
+ const builder = new RangeSetBuilder();
1711
+ for (const { from, to, decoration } of decorations) {
1712
+ builder.add(from, to, decoration);
1713
+ }
1714
+ return builder.finish();
1715
+ }
1716
+ }, {
1717
+ decorations: (v) => v.decorations
1718
+ });
1719
+ var DXNWidget = class extends WidgetType {
1720
+ _identifier;
1721
+ constructor(_identifier) {
1722
+ super(), this._identifier = _identifier;
1723
+ }
1724
+ ignoreEvent() {
1725
+ return false;
1726
+ }
1727
+ eq(other) {
1728
+ return this._identifier === other._identifier;
1729
+ }
1730
+ toDOM() {
1731
+ const text = this._identifier.split(":").map((part) => {
1732
+ const len = 16;
1733
+ const plen = 4;
1734
+ if (part.length > len) {
1735
+ return `[${part.slice(0, plen)}\u2026${part.slice(-plen)}]`;
1736
+ }
1737
+ return part;
1738
+ }).join(":");
1739
+ return Domino.of("span").classNames(mx7("font-mono dx-tag--blue", tagPadding)).text(text).root;
1740
+ }
1741
+ };
1742
+ var variables = [
1743
+ "this"
1744
+ ];
1745
+ var commands = [
1746
+ "this",
1747
+ "each",
1748
+ "if",
1749
+ "unless",
1750
+ "with"
1751
+ ];
1752
+ function handlebarsCompletions(context) {
1753
+ const match = context.matchBefore(/\{\{[^}]*/);
1754
+ if (!match || match.from === match.to) {
1755
+ return null;
1756
+ }
1757
+ let type = "variable";
1758
+ let text = match.text.slice(2);
1759
+ let from = match.from + 2;
1760
+ let matches = [];
1761
+ if (text.startsWith("#") || text.startsWith("/")) {
1762
+ const idx = text.lastIndexOf(" ");
1763
+ if (idx !== -1) {
1764
+ type = "variable";
1765
+ matches = variables;
1766
+ text = text.slice(idx + 1);
1767
+ from += idx + 1;
1768
+ } else {
1769
+ type = "command";
1770
+ text = text.slice(1);
1771
+ matches = commands;
1772
+ from += 1;
1773
+ }
1774
+ } else {
1775
+ type = "variable";
1776
+ matches = variables;
1777
+ }
1778
+ const options = matches.filter((name) => name.startsWith(text)).map((name) => ({
1779
+ type,
1780
+ label: name
1781
+ }));
1782
+ return {
1783
+ from,
1784
+ options
1785
+ };
1786
+ }
1787
+
1788
+ // src/components/TemplateEditor/extensions/xml-extension.ts
1789
+ import { syntaxTree } from "@codemirror/language";
1790
+ import { RangeSetBuilder as RangeSetBuilder2 } from "@codemirror/state";
1791
+ import { Decoration as Decoration2, ViewPlugin as ViewPlugin2 } from "@codemirror/view";
1792
+ var xmlDecorator = (_ = {}) => {
1793
+ return [
1794
+ xmlDecoratorPlugin
1795
+ ];
1796
+ };
1797
+ var xmlDecoratorPlugin = ViewPlugin2.fromClass(class {
1798
+ decorations;
1799
+ constructor(view) {
1800
+ this.decorations = this.buildDecorations(view);
1801
+ }
1802
+ update(update) {
1803
+ if (update.docChanged || update.viewportChanged) {
1804
+ this.decorations = this.buildDecorations(update.view);
1805
+ }
1806
+ }
1807
+ buildDecorations(view) {
1808
+ const builder = new RangeSetBuilder2();
1809
+ for (const { from, to } of view.visibleRanges) {
1810
+ syntaxTree(view.state).iterate({
1811
+ from,
1812
+ to,
1813
+ enter: (node) => {
1814
+ if (node.name === "HTMLTag" || node.name === "OpenTag" || node.name === "CloseTag" || node.name === "SelfClosingTag" || node.name === "Element") {
1815
+ builder.add(node.from, node.to, Decoration2.mark({
1816
+ class: "font-mono text-subdued"
1817
+ }));
1818
+ }
1819
+ }
1820
+ });
1821
+ }
1822
+ return builder.finish();
1823
+ }
1824
+ }, {
1825
+ decorations: (v) => v.decorations
1826
+ });
1827
+
1828
+ // src/components/TemplateEditor/TemplateEditor.tsx
1829
+ var TemplateEditor = ({ id, classNames, template, lineNumbers = true }) => {
1830
+ const { t } = useTranslation6(meta.id);
1831
+ const { themeMode } = useThemeContext();
1832
+ const { parentRef } = useTextEditor(() => {
1833
+ const text = template.source?.target;
1834
+ if (!text) {
1835
+ return {};
1836
+ }
1837
+ return {
1838
+ initialValue: text.content ?? "",
1839
+ extensions: [
1840
+ createDataExtensions({
1841
+ id,
1842
+ text: createDocAccessor(text, [
1843
+ "content"
1844
+ ])
1845
+ }),
1846
+ createBasicExtensions({
1847
+ bracketMatching: false,
1848
+ lineNumbers,
1849
+ lineWrapping: true,
1850
+ placeholder: t("template placeholder")
1851
+ }),
1852
+ createThemeExtensions({
1853
+ themeMode,
1854
+ slots: {
1855
+ content: {
1856
+ className: "!pe-4"
1857
+ }
1858
+ }
1859
+ }),
1860
+ createMarkdownExtensions(),
1861
+ decorateMarkdown(),
1862
+ handlebars(),
1863
+ // xml(),
1864
+ // NOTE: Since we're using markdown only HTML nodes are parsed.
1865
+ xmlDecorator(),
1866
+ syntaxHighlighting(defaultHighlightStyle)
1867
+ ].filter(isNonNullable2)
1868
+ };
1869
+ }, [
1870
+ themeMode,
1871
+ template.source?.target,
1872
+ lineNumbers
1873
+ ]);
1874
+ return /* @__PURE__ */ React10.createElement("div", {
1875
+ ref: parentRef,
1876
+ className: mx8("h-full overflow-hidden", classNames)
1877
+ });
1878
+ };
1879
+
1880
+ // src/components/Toolbox/Toolbox.tsx
1881
+ import React11, { Fragment, useEffect as useEffect8, useState as useState13 } from "react";
1882
+ import { Function } from "@dxos/functions";
1883
+ import { log as log4 } from "@dxos/log";
1884
+ import { Filter as Filter5, useQuery as useQuery4 } from "@dxos/react-client/echo";
1885
+ import { ScrollArea } from "@dxos/react-ui";
1886
+ import { mx as mx9 } from "@dxos/ui-theme";
1887
+ var __dxlog_file4 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/components/Toolbox/Toolbox.tsx";
1888
+ var Toolbox = ({ classNames, functions, services, blueprints, activeBlueprints }) => {
1889
+ return /* @__PURE__ */ React11.createElement(ScrollArea.Root, {
1890
+ thin: true,
1891
+ orientation: "vertical"
1892
+ }, /* @__PURE__ */ React11.createElement(ScrollArea.Viewport, {
1893
+ classNames
1894
+ }, blueprints && blueprints.length > 0 && /* @__PURE__ */ React11.createElement(Section, {
1895
+ title: "Blueprints",
1896
+ items: blueprints.map(({ name, description, tools }) => ({
1897
+ name,
1898
+ description,
1899
+ subitems: tools.map((toolId) => ({
1900
+ name: `\u2219 ${safeToolId(toolId)}`
1901
+ }))
1902
+ }))
1903
+ }), activeBlueprints && activeBlueprints.length > 0 && /* @__PURE__ */ React11.createElement(Section, {
1904
+ title: "Blueprints",
1905
+ items: activeBlueprints.map(({ target }) => ({
1906
+ name: target?.name ?? "",
1907
+ description: target?.description ?? "",
1908
+ subitems: target?.tools.map((toolId) => ({
1909
+ name: `\u2219 ${safeToolId(toolId)}`
1910
+ }))
1911
+ }))
1912
+ }), services && services.length > 0 && /* @__PURE__ */ React11.createElement(Section, {
1913
+ title: "Services",
1914
+ items: services.map(({ service: { serviceId, name, description } }) => ({
1915
+ name: name ?? serviceId,
1916
+ description
1917
+ }))
1918
+ }), functions && functions.length > 0 && /* @__PURE__ */ React11.createElement(Section, {
1919
+ title: "Functions",
1920
+ items: functions.map(({ name, description }) => ({
1921
+ name,
1922
+ description
1923
+ }))
1924
+ })));
1925
+ };
1926
+ var Section = ({ title, items, striped }) => {
1927
+ const stripeClassNames = "odd:bg-neutral-50 dark:odd:bg-neutral-800";
1928
+ const gridClassNames = "grid grid-cols-[8rem_1fr]";
1929
+ const subGridClassNames = mx9("col-span-full grid grid-cols-subgrid text-xs px-2", striped && stripeClassNames);
1930
+ return /* @__PURE__ */ React11.createElement("div", null, /* @__PURE__ */ React11.createElement("h1", {
1931
+ className: "px-2 text-sm"
1932
+ }, title), /* @__PURE__ */ React11.createElement("div", {
1933
+ className: gridClassNames
1934
+ }, items.map(({ name, description, subitems }, i) => /* @__PURE__ */ React11.createElement(Fragment, {
1935
+ key: i
1936
+ }, name && /* @__PURE__ */ React11.createElement("div", {
1937
+ className: subGridClassNames
1938
+ }, /* @__PURE__ */ React11.createElement("div", {
1939
+ className: "truncate text-primary-500"
1940
+ }, name), /* @__PURE__ */ React11.createElement("div", {
1941
+ className: "line-clamp-2"
1942
+ }, description)), subitems?.map(({ name: name2, description: description2 }, i2) => /* @__PURE__ */ React11.createElement("div", {
1943
+ key: i2,
1944
+ className: mx9(subGridClassNames, striped && stripeClassNames)
1945
+ }, /* @__PURE__ */ React11.createElement("div", {
1946
+ className: "truncate"
1947
+ }, name2), /* @__PURE__ */ React11.createElement("div", {
1948
+ className: "line-clamp-3 text-subdued"
1949
+ }, description2)))))));
1950
+ };
1951
+ var ToolboxContainer = ({ classNames, db, processor }) => {
1952
+ const services = useQuery4(db, Filter5.type(ServiceType));
1953
+ const [serviceTools, setServiceTools] = useState13([]);
1954
+ useEffect8(() => {
1955
+ log4("creating service tools...", {
1956
+ services: services.length
1957
+ }, {
1958
+ F: __dxlog_file4,
1959
+ L: 115,
1960
+ S: void 0,
1961
+ C: (f, a) => f(...a)
1962
+ });
1963
+ queueMicrotask(async () => {
1964
+ });
1965
+ }, [
1966
+ services
1967
+ ]);
1968
+ const functions = useQuery4(db, Filter5.type(Function.Function));
1969
+ return /* @__PURE__ */ React11.createElement(Toolbox, {
1970
+ classNames,
1971
+ blueprints: processor?.context.getBlueprints(),
1972
+ services: serviceTools,
1973
+ functions
1974
+ });
1975
+ };
1976
+ var safeToolId = (name) => {
1977
+ return name.split("_").pop();
1978
+ };
1979
+
1980
+ // src/hooks/useChatToolbarActions.ts
1981
+ var __dxlog_file5 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/hooks/useChatToolbarActions.ts";
1982
+ var useChatToolbarActions = ({ chat, companionTo }) => {
1983
+ const { invoke } = useOperationInvoker();
1984
+ const { db } = useChatContext("useChatToolbarActions");
1985
+ const query = companionTo ? Query.select(Filter6.id(companionTo.id)).targetOf(Chat2.CompanionTo).source() : Query.select(Filter6.nothing());
1986
+ const chats = useQuery5(db, query);
1987
+ return useMenuActions(useMemo10(() => {
1988
+ return Atom.make(() => {
1989
+ const builder = MenuBuilder.make().root({
1990
+ label: [
1991
+ "chat toolbar title",
1992
+ {
1993
+ ns: meta.id
1994
+ }
1995
+ ]
1996
+ }).action("new", {
1997
+ label: [
1998
+ "new thread button",
1999
+ {
2000
+ ns: meta.id
2001
+ }
2002
+ ],
2003
+ icon: "ph--plus--regular",
2004
+ type: "new",
2005
+ disabled: !companionTo
2006
+ }, () => {
2007
+ invariant(companionTo, void 0, {
2008
+ F: __dxlog_file5,
2009
+ L: 53,
2010
+ S: void 0,
2011
+ A: [
2012
+ "companionTo",
2013
+ ""
2014
+ ]
2015
+ });
2016
+ return invoke(AssistantOperation.SetCurrentChat, {
2017
+ companionTo,
2018
+ chat: void 0
2019
+ }).pipe(runAndForwardErrors);
2020
+ }).action("rename", {
2021
+ label: [
2022
+ "rename thread button",
2023
+ {
2024
+ ns: meta.id
2025
+ }
2026
+ ],
2027
+ icon: "ph--magic-wand--regular",
2028
+ type: "rename",
2029
+ disabled: !chat
2030
+ }, () => Effect2.gen(function* () {
2031
+ invariant(chat, void 0, {
2032
+ F: __dxlog_file5,
2033
+ L: 70,
2034
+ S: this,
2035
+ A: [
2036
+ "chat",
2037
+ ""
2038
+ ]
2039
+ });
2040
+ yield* invoke(AssistantOperation.UpdateChatName, {
2041
+ chat
2042
+ });
2043
+ }).pipe(runAndForwardErrors)).action("branch", {
2044
+ label: [
2045
+ "button branch thread",
2046
+ {
2047
+ ns: meta.id
2048
+ }
2049
+ ],
2050
+ icon: "ph--git-branch--regular",
2051
+ type: "branch",
2052
+ disabled: true
2053
+ }, () => {
2054
+ });
2055
+ if (chats.length > 0) {
2056
+ builder.group("chats", {
2057
+ label: [
2058
+ "chat history label",
2059
+ {
2060
+ ns: meta.id
2061
+ }
2062
+ ],
2063
+ icon: "ph--clock-counter-clockwise--regular",
2064
+ selectCardinality: "single",
2065
+ variant: "dropdownMenu"
2066
+ }, (builder2) => {
2067
+ chats.toSorted((a, b) => a.id.localeCompare(b.id)).forEach((chat2) => {
2068
+ builder2.action(chat2.id, {
2069
+ label: Obj6.getLabel(chat2) ?? [
2070
+ "object name placeholder",
2071
+ {
2072
+ ns: Chat2.Chat.typename
2073
+ }
2074
+ ]
2075
+ }, () => Effect2.gen(function* () {
2076
+ invariant(companionTo, void 0, {
2077
+ F: __dxlog_file5,
2078
+ L: 106,
2079
+ S: this,
2080
+ A: [
2081
+ "companionTo",
2082
+ ""
2083
+ ]
2084
+ });
2085
+ yield* invoke(AssistantOperation.SetCurrentChat, {
2086
+ companionTo,
2087
+ chat: chat2
2088
+ });
2089
+ }).pipe(runAndForwardErrors));
2090
+ });
2091
+ });
2092
+ }
2093
+ return builder.build();
2094
+ });
2095
+ }, [
2096
+ chats.length,
2097
+ db?.spaceId,
2098
+ companionTo?.id,
2099
+ chat?.id,
2100
+ invoke
2101
+ ]));
2102
+ };
2103
+
2104
+ export {
2105
+ useBlueprintRegistry,
2106
+ useBlueprints,
2107
+ useActiveBlueprints,
2108
+ useBlueprintHandlers,
2109
+ useChatProcessor,
2110
+ useChatServices,
2111
+ useChatToolbarActions,
2112
+ useContextBinder,
2113
+ useContextObjects,
2114
+ useFilteredTypes,
2115
+ useFlush,
2116
+ useOnline,
2117
+ usePresets,
2118
+ useReferencesProvider,
2119
+ ChatContextProvider,
2120
+ useChatContext,
2121
+ Chat,
2122
+ TemplateEditor,
2123
+ Toolbox,
2124
+ ToolboxContainer
2125
+ };
2126
+ //# sourceMappingURL=chunk-GZ4ERNT2.mjs.map