@dxos/plugin-assistant 0.8.4-main.ae835ea → 0.8.4-main.bc674ce

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 (515) hide show
  1. package/dist/lib/browser/BlueprintArticle-WP3G5GLG.mjs +31 -0
  2. package/dist/lib/browser/BlueprintArticle-WP3G5GLG.mjs.map +7 -0
  3. package/dist/lib/browser/ChatCompanion-ECQYUQ2B.mjs +153 -0
  4. package/dist/lib/browser/ChatCompanion-ECQYUQ2B.mjs.map +7 -0
  5. package/dist/lib/browser/ChatContainer-QCCOFBUX.mjs +73 -0
  6. package/dist/lib/browser/ChatContainer-QCCOFBUX.mjs.map +7 -0
  7. package/dist/lib/browser/ChatDialog-SMK4RSZU.mjs +85 -0
  8. package/dist/lib/browser/ChatDialog-SMK4RSZU.mjs.map +7 -0
  9. package/dist/lib/browser/PromptArticle-K362ZPAE.mjs +53 -0
  10. package/dist/lib/browser/PromptArticle-K362ZPAE.mjs.map +7 -0
  11. package/dist/lib/browser/ai-service-5GUDOEWF.mjs +21 -0
  12. package/dist/lib/browser/ai-service-5GUDOEWF.mjs.map +7 -0
  13. package/dist/lib/browser/app-graph-builder-DSNH2OMY.mjs +212 -0
  14. package/dist/lib/browser/app-graph-builder-DSNH2OMY.mjs.map +7 -0
  15. package/dist/lib/browser/blueprint-definition-DGHH7MUU.mjs +14 -0
  16. package/dist/lib/browser/blueprints/index.mjs +12 -0
  17. package/dist/lib/browser/chunk-3JYPE2MM.mjs +1832 -0
  18. package/dist/lib/browser/chunk-3JYPE2MM.mjs.map +7 -0
  19. package/dist/lib/browser/chunk-DKQMSMBN.mjs +326 -0
  20. package/dist/lib/browser/chunk-DKQMSMBN.mjs.map +7 -0
  21. package/dist/lib/browser/{chunk-WBG5PTSX.mjs → chunk-EXVT7D4B.mjs} +1 -1
  22. package/dist/lib/browser/chunk-EXVT7D4B.mjs.map +7 -0
  23. package/dist/lib/browser/{chunk-L5OA5OGS.mjs → chunk-ML3QCFKA.mjs} +40 -37
  24. package/dist/lib/browser/chunk-ML3QCFKA.mjs.map +7 -0
  25. package/dist/lib/browser/chunk-MRJVYGLU.mjs +208 -0
  26. package/dist/lib/browser/chunk-MRJVYGLU.mjs.map +7 -0
  27. package/dist/lib/browser/chunk-V772AMZM.mjs +250 -0
  28. package/dist/lib/browser/chunk-V772AMZM.mjs.map +7 -0
  29. package/dist/lib/browser/chunk-WGQTU6UJ.mjs +41 -0
  30. package/dist/lib/browser/chunk-WGQTU6UJ.mjs.map +7 -0
  31. package/dist/lib/browser/edge-model-resolver-26BOY6HY.mjs +20 -0
  32. package/dist/lib/browser/edge-model-resolver-26BOY6HY.mjs.map +7 -0
  33. package/dist/lib/browser/index.mjs +201 -214
  34. package/dist/lib/browser/index.mjs.map +4 -4
  35. package/dist/lib/browser/local-model-resolver-ZFIM6GGV.mjs +19 -0
  36. package/dist/lib/browser/local-model-resolver-ZFIM6GGV.mjs.map +7 -0
  37. package/dist/lib/browser/meta.json +1 -1
  38. package/dist/lib/browser/operation-resolver-7XJLBRQY.mjs +132 -0
  39. package/dist/lib/browser/operation-resolver-7XJLBRQY.mjs.map +7 -0
  40. package/dist/lib/browser/react-surface-NCITRSJJ.mjs +109 -0
  41. package/dist/lib/browser/react-surface-NCITRSJJ.mjs.map +7 -0
  42. package/dist/lib/browser/repair-6QGAKOVM.mjs +54 -0
  43. package/dist/lib/browser/repair-6QGAKOVM.mjs.map +7 -0
  44. package/dist/lib/browser/settings-4ZDLUMYE.mjs +32 -0
  45. package/dist/lib/browser/settings-4ZDLUMYE.mjs.map +7 -0
  46. package/dist/lib/browser/state-AN6336ZX.mjs +26 -0
  47. package/dist/lib/browser/state-AN6336ZX.mjs.map +7 -0
  48. package/dist/lib/browser/toolkit-7AVTEPMA.mjs +18 -0
  49. package/dist/lib/browser/toolkit-7AVTEPMA.mjs.map +7 -0
  50. package/dist/lib/browser/types/index.mjs +8 -4
  51. package/dist/lib/node-esm/BlueprintArticle-WZ76E2C4.mjs +32 -0
  52. package/dist/lib/node-esm/BlueprintArticle-WZ76E2C4.mjs.map +7 -0
  53. package/dist/lib/node-esm/ChatCompanion-Q4FUZ2MW.mjs +154 -0
  54. package/dist/lib/node-esm/ChatCompanion-Q4FUZ2MW.mjs.map +7 -0
  55. package/dist/lib/node-esm/ChatContainer-AKI33HIB.mjs +74 -0
  56. package/dist/lib/node-esm/ChatContainer-AKI33HIB.mjs.map +7 -0
  57. package/dist/lib/node-esm/ChatDialog-AP45PVZR.mjs +86 -0
  58. package/dist/lib/node-esm/ChatDialog-AP45PVZR.mjs.map +7 -0
  59. package/dist/lib/node-esm/PromptArticle-D4HAIIC6.mjs +54 -0
  60. package/dist/lib/node-esm/PromptArticle-D4HAIIC6.mjs.map +7 -0
  61. package/dist/lib/node-esm/ai-service-PXKKCFIF.mjs +22 -0
  62. package/dist/lib/node-esm/ai-service-PXKKCFIF.mjs.map +7 -0
  63. package/dist/lib/node-esm/app-graph-builder-TJCUEXW5.mjs +213 -0
  64. package/dist/lib/node-esm/app-graph-builder-TJCUEXW5.mjs.map +7 -0
  65. package/dist/lib/node-esm/{blueprint-definition-CFCUD2VC.mjs → blueprint-definition-SEMDEIYG.mjs} +6 -5
  66. package/dist/lib/node-esm/blueprint-definition-SEMDEIYG.mjs.map +7 -0
  67. package/dist/lib/node-esm/blueprints/index.mjs +13 -0
  68. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  69. package/dist/lib/node-esm/chunk-355W5B27.mjs +251 -0
  70. package/dist/lib/node-esm/chunk-355W5B27.mjs.map +7 -0
  71. package/dist/lib/node-esm/chunk-75PHXBN3.mjs +327 -0
  72. package/dist/lib/node-esm/chunk-75PHXBN3.mjs.map +7 -0
  73. package/dist/lib/node-esm/chunk-DCA5QWQT.mjs +209 -0
  74. package/dist/lib/node-esm/chunk-DCA5QWQT.mjs.map +7 -0
  75. package/dist/lib/node-esm/chunk-MSBPC4RJ.mjs +42 -0
  76. package/dist/lib/node-esm/chunk-MSBPC4RJ.mjs.map +7 -0
  77. package/dist/lib/node-esm/{chunk-WE6KTH72.mjs → chunk-POWB2BPC.mjs} +1 -1
  78. package/dist/lib/node-esm/chunk-POWB2BPC.mjs.map +7 -0
  79. package/dist/lib/node-esm/chunk-XI5T3MJC.mjs +1833 -0
  80. package/dist/lib/node-esm/chunk-XI5T3MJC.mjs.map +7 -0
  81. package/dist/lib/node-esm/{chunk-7ZYOYW7F.mjs → chunk-ZRIPP7YF.mjs} +40 -37
  82. package/dist/lib/node-esm/chunk-ZRIPP7YF.mjs.map +7 -0
  83. package/dist/lib/node-esm/{edge-model-resolver-2ARXDOYS.mjs → edge-model-resolver-G5KMODPO.mjs} +9 -7
  84. package/dist/lib/node-esm/edge-model-resolver-G5KMODPO.mjs.map +7 -0
  85. package/dist/lib/node-esm/index.mjs +201 -214
  86. package/dist/lib/node-esm/index.mjs.map +4 -4
  87. package/dist/lib/node-esm/local-model-resolver-KDZLYI7Y.mjs +20 -0
  88. package/dist/lib/node-esm/local-model-resolver-KDZLYI7Y.mjs.map +7 -0
  89. package/dist/lib/node-esm/meta.json +1 -1
  90. package/dist/lib/node-esm/operation-resolver-SX4WMNA7.mjs +133 -0
  91. package/dist/lib/node-esm/operation-resolver-SX4WMNA7.mjs.map +7 -0
  92. package/dist/lib/node-esm/react-surface-ST6V7LPE.mjs +110 -0
  93. package/dist/lib/node-esm/react-surface-ST6V7LPE.mjs.map +7 -0
  94. package/dist/lib/node-esm/repair-QJ7CQDKU.mjs +55 -0
  95. package/dist/lib/node-esm/repair-QJ7CQDKU.mjs.map +7 -0
  96. package/dist/lib/node-esm/settings-CQEOHR3R.mjs +33 -0
  97. package/dist/lib/node-esm/settings-CQEOHR3R.mjs.map +7 -0
  98. package/dist/lib/node-esm/state-HDON4REW.mjs +27 -0
  99. package/dist/lib/node-esm/state-HDON4REW.mjs.map +7 -0
  100. package/dist/lib/node-esm/toolkit-OWGCEKOO.mjs +19 -0
  101. package/dist/lib/node-esm/toolkit-OWGCEKOO.mjs.map +7 -0
  102. package/dist/lib/node-esm/types/index.mjs +8 -4
  103. package/dist/types/src/AssistantPlugin.d.ts +2 -1
  104. package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
  105. package/dist/types/src/blueprints/assistant-blueprint.d.ts +209 -0
  106. package/dist/types/src/blueprints/assistant-blueprint.d.ts.map +1 -0
  107. package/dist/types/src/blueprints/index.d.ts +7 -0
  108. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  109. package/dist/types/src/capabilities/ai-service/ai-service.d.ts +5 -0
  110. package/dist/types/src/capabilities/ai-service/ai-service.d.ts.map +1 -0
  111. package/dist/types/src/capabilities/ai-service/index.d.ts +3 -0
  112. package/dist/types/src/capabilities/ai-service/index.d.ts.map +1 -0
  113. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +6 -0
  114. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +1 -0
  115. package/dist/types/src/capabilities/app-graph-builder/index.d.ts +3 -0
  116. package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +1 -0
  117. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +21 -0
  118. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +1 -0
  119. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +4 -0
  120. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +1 -0
  121. package/dist/types/src/capabilities/edge-model-resolver/edge-model-resolver.d.ts +6 -0
  122. package/dist/types/src/capabilities/edge-model-resolver/edge-model-resolver.d.ts.map +1 -0
  123. package/dist/types/src/capabilities/edge-model-resolver/index.d.ts +3 -0
  124. package/dist/types/src/capabilities/edge-model-resolver/index.d.ts.map +1 -0
  125. package/dist/types/src/capabilities/index.d.ts +10 -11
  126. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  127. package/dist/types/src/capabilities/local-model-resolver/index.d.ts +3 -0
  128. package/dist/types/src/capabilities/local-model-resolver/index.d.ts.map +1 -0
  129. package/dist/types/src/capabilities/local-model-resolver/local-model-resolver.d.ts +12 -0
  130. package/dist/types/src/capabilities/local-model-resolver/local-model-resolver.d.ts.map +1 -0
  131. package/dist/types/src/capabilities/operation-resolver/index.d.ts +3 -0
  132. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +1 -0
  133. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +5 -0
  134. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -0
  135. package/dist/types/src/capabilities/react-surface/index.d.ts +3 -0
  136. package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -0
  137. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +5 -0
  138. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -0
  139. package/dist/types/src/capabilities/repair/index.d.ts +3 -0
  140. package/dist/types/src/capabilities/repair/index.d.ts.map +1 -0
  141. package/dist/types/src/capabilities/repair/repair.d.ts +6 -0
  142. package/dist/types/src/capabilities/repair/repair.d.ts.map +1 -0
  143. package/dist/types/src/capabilities/settings/index.d.ts +15 -0
  144. package/dist/types/src/capabilities/settings/index.d.ts.map +1 -0
  145. package/dist/types/src/capabilities/settings/settings.d.ts +17 -0
  146. package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -0
  147. package/dist/types/src/capabilities/state/index.d.ts +11 -0
  148. package/dist/types/src/capabilities/state/index.d.ts.map +1 -0
  149. package/dist/types/src/capabilities/state/state.d.ts +13 -0
  150. package/dist/types/src/capabilities/state/state.d.ts.map +1 -0
  151. package/dist/types/src/capabilities/toolkit/index.d.ts +3 -0
  152. package/dist/types/src/capabilities/toolkit/index.d.ts.map +1 -0
  153. package/dist/types/src/capabilities/toolkit/toolkit.d.ts +5 -0
  154. package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +1 -0
  155. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +4 -2
  156. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
  157. package/dist/types/src/components/BlueprintArticle.d.ts +7 -0
  158. package/dist/types/src/components/BlueprintArticle.d.ts.map +1 -0
  159. package/dist/types/src/components/Chat/Chat.d.ts +21 -12
  160. package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
  161. package/dist/types/src/components/Chat/events.d.ts +5 -1
  162. package/dist/types/src/components/Chat/events.d.ts.map +1 -1
  163. package/dist/types/src/components/ChatCompanion.d.ts +2 -2
  164. package/dist/types/src/components/ChatCompanion.d.ts.map +1 -1
  165. package/dist/types/src/components/ChatContainer.d.ts +13 -5
  166. package/dist/types/src/components/ChatContainer.d.ts.map +1 -1
  167. package/dist/types/src/components/ChatDialog.d.ts.map +1 -1
  168. package/dist/types/src/components/ChatProgress/ChatProgress.d.ts.map +1 -1
  169. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts.map +1 -1
  170. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts +3 -3
  171. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
  172. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +3 -3
  173. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
  174. package/dist/types/src/components/ChatThread/ChatThread.d.ts +7 -10
  175. package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
  176. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +128 -73
  177. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
  178. package/dist/types/src/components/ChatThread/registry.d.ts +1 -1
  179. package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -1
  180. package/dist/types/src/components/ChatThread/sync.d.ts +12 -6
  181. package/dist/types/src/components/ChatThread/sync.d.ts.map +1 -1
  182. package/dist/types/src/components/PromptArticle.d.ts +7 -0
  183. package/dist/types/src/components/PromptArticle.d.ts.map +1 -0
  184. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
  185. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +112 -60
  186. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
  187. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +11 -1
  188. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
  189. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +113 -61
  190. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
  191. package/dist/types/src/components/TemplateEditor/extensions/handlebars-extension.d.ts.map +1 -0
  192. package/dist/types/src/components/TemplateEditor/extensions/index.d.ts +3 -0
  193. package/dist/types/src/components/TemplateEditor/extensions/index.d.ts.map +1 -0
  194. package/dist/types/src/components/TemplateEditor/extensions/xml-extension.d.ts +8 -0
  195. package/dist/types/src/components/TemplateEditor/extensions/xml-extension.d.ts.map +1 -0
  196. package/dist/types/src/components/ToolBlock/ToolBlock.d.ts +10 -8
  197. package/dist/types/src/components/ToolBlock/ToolBlock.d.ts.map +1 -1
  198. package/dist/types/src/components/Toolbox/Toolbox.d.ts +4 -5
  199. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
  200. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +112 -60
  201. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
  202. package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts +12 -0
  203. package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts.map +1 -0
  204. package/dist/types/src/components/Typewriter/Typewriter.d.ts +11 -0
  205. package/dist/types/src/components/Typewriter/Typewriter.d.ts.map +1 -0
  206. package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts +7 -0
  207. package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts.map +1 -0
  208. package/dist/types/src/components/Typewriter/assistant-extension.d.ts +5 -0
  209. package/dist/types/src/components/Typewriter/assistant-extension.d.ts.map +1 -0
  210. package/dist/types/src/components/Typewriter/index.d.ts +2 -0
  211. package/dist/types/src/components/Typewriter/index.d.ts.map +1 -0
  212. package/dist/types/src/components/index.d.ts +10 -5
  213. package/dist/types/src/components/index.d.ts.map +1 -1
  214. package/dist/types/src/functions/index.d.ts +1 -1
  215. package/dist/types/src/functions/index.d.ts.map +1 -1
  216. package/dist/types/src/functions/object-list.d.ts +2 -2
  217. package/dist/types/src/functions/object-list.d.ts.map +1 -1
  218. package/dist/types/src/functions/object-load.d.ts +1 -1
  219. package/dist/types/src/functions/object-load.d.ts.map +1 -1
  220. package/dist/types/src/functions/object-search.d.ts +10 -0
  221. package/dist/types/src/functions/object-search.d.ts.map +1 -0
  222. package/dist/types/src/hooks/index.d.ts +2 -1
  223. package/dist/types/src/hooks/index.d.ts.map +1 -1
  224. package/dist/types/src/hooks/useBlueprintRegistry.d.ts +5 -5
  225. package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -1
  226. package/dist/types/src/hooks/useChatProcessor.d.ts +3 -1
  227. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
  228. package/dist/types/src/hooks/useChatServices.d.ts +3 -3
  229. package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
  230. package/dist/types/src/hooks/useChatToolbarActions.d.ts +8 -0
  231. package/dist/types/src/hooks/useChatToolbarActions.d.ts.map +1 -0
  232. package/dist/types/src/hooks/useContextBinder.d.ts +2 -2
  233. package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -1
  234. package/dist/types/src/hooks/useContextObjects.d.ts +7 -7
  235. package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -1
  236. package/dist/types/src/hooks/useFilteredTypes.d.ts +3 -0
  237. package/dist/types/src/hooks/useFilteredTypes.d.ts.map +1 -0
  238. package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -1
  239. package/dist/types/src/index.d.ts +0 -1
  240. package/dist/types/src/index.d.ts.map +1 -1
  241. package/dist/types/src/meta.d.ts +2 -2
  242. package/dist/types/src/meta.d.ts.map +1 -1
  243. package/dist/types/src/processor/processor.d.ts +17 -16
  244. package/dist/types/src/processor/processor.d.ts.map +1 -1
  245. package/dist/types/src/processor/update-name.d.ts.map +1 -1
  246. package/dist/types/src/queue-logger.d.ts.map +1 -1
  247. package/dist/types/src/testing/test-generator.d.ts +5 -4
  248. package/dist/types/src/testing/test-generator.d.ts.map +1 -1
  249. package/dist/types/src/testing/test-services.d.ts.map +1 -1
  250. package/dist/types/src/translations.d.ts +243 -26
  251. package/dist/types/src/translations.d.ts.map +1 -1
  252. package/dist/types/src/types/Assistant.d.ts +16 -22
  253. package/dist/types/src/types/Assistant.d.ts.map +1 -1
  254. package/dist/types/src/types/AssistantAction.d.ts +88 -112
  255. package/dist/types/src/types/AssistantAction.d.ts.map +1 -1
  256. package/dist/types/src/types/capabilities.d.ts +33 -0
  257. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  258. package/dist/types/src/types/events.d.ts +5 -0
  259. package/dist/types/src/types/events.d.ts.map +1 -0
  260. package/dist/types/src/types/index.d.ts +3 -1
  261. package/dist/types/src/types/index.d.ts.map +1 -1
  262. package/dist/types/src/types/service.d.ts +10 -212
  263. package/dist/types/src/types/service.d.ts.map +1 -1
  264. package/dist/types/tsconfig.tsbuildinfo +1 -1
  265. package/package.json +113 -90
  266. package/src/AssistantPlugin.tsx +70 -105
  267. package/src/blueprints/assistant-blueprint.ts +62 -0
  268. package/src/blueprints/index.ts +12 -0
  269. package/src/capabilities/ai-service/ai-service.ts +29 -0
  270. package/src/capabilities/ai-service/index.ts +7 -0
  271. package/src/capabilities/app-graph-builder/app-graph-builder.ts +180 -0
  272. package/src/capabilities/app-graph-builder/index.ts +7 -0
  273. package/src/capabilities/blueprint-definition/blueprint-definition.ts +60 -0
  274. package/src/capabilities/blueprint-definition/index.ts +8 -0
  275. package/src/capabilities/edge-model-resolver/edge-model-resolver.ts +32 -0
  276. package/src/capabilities/edge-model-resolver/index.ts +7 -0
  277. package/src/capabilities/index.ts +10 -14
  278. package/src/capabilities/local-model-resolver/index.ts +7 -0
  279. package/src/capabilities/local-model-resolver/local-model-resolver.ts +37 -0
  280. package/src/capabilities/operation-resolver/index.ts +7 -0
  281. package/src/capabilities/operation-resolver/operation-resolver.ts +110 -0
  282. package/src/capabilities/react-surface/index.ts +7 -0
  283. package/src/capabilities/react-surface/react-surface.tsx +95 -0
  284. package/src/capabilities/repair/index.ts +7 -0
  285. package/src/capabilities/repair/repair.ts +63 -0
  286. package/src/capabilities/settings/index.ts +7 -0
  287. package/src/capabilities/settings/settings.ts +30 -0
  288. package/src/capabilities/state/index.ts +7 -0
  289. package/src/capabilities/state/state.ts +27 -0
  290. package/src/capabilities/toolkit/index.ts +7 -0
  291. package/src/capabilities/toolkit/toolkit.ts +26 -0
  292. package/src/components/AssistantSettings/AssistantSettings.tsx +13 -5
  293. package/src/components/BlueprintArticle.tsx +29 -0
  294. package/src/components/Chat/Chat.tsx +160 -125
  295. package/src/components/Chat/events.ts +7 -1
  296. package/src/components/ChatCompanion.tsx +132 -105
  297. package/src/components/ChatContainer.tsx +40 -30
  298. package/src/components/ChatDialog.tsx +13 -7
  299. package/src/components/ChatProgress/ChatProgress.tsx +4 -17
  300. package/src/components/ChatPrompt/ChatActions.tsx +3 -5
  301. package/src/components/ChatPrompt/ChatOptions.tsx +93 -80
  302. package/src/components/ChatPrompt/ChatReferences.tsx +7 -8
  303. package/src/components/ChatPrompt/ChatStatusIndicator.tsx +1 -1
  304. package/src/components/ChatThread/ChatThread.stories.tsx +57 -36
  305. package/src/components/ChatThread/ChatThread.tsx +26 -36
  306. package/src/components/ChatThread/Link.tsx +3 -3
  307. package/src/components/ChatThread/registry.tsx +25 -35
  308. package/src/components/ChatThread/sync.test.ts +33 -17
  309. package/src/components/ChatThread/sync.ts +53 -12
  310. package/src/components/ChatThread/testing/thread.md +37 -0
  311. package/src/components/PromptArticle.tsx +50 -0
  312. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +12 -4
  313. package/src/components/TemplateEditor/TemplateEditor.tsx +14 -10
  314. package/src/components/TemplateEditor/TemplateForm.stories.tsx +15 -7
  315. package/src/components/TemplateEditor/TemplateForm.tsx +76 -29
  316. package/src/components/TemplateEditor/extensions/handlebars-extension.ts +274 -0
  317. package/src/components/TemplateEditor/extensions/index.ts +6 -0
  318. package/src/components/TemplateEditor/extensions/xml-extension.ts +64 -0
  319. package/src/components/ToolBlock/ToolBlock.tsx +36 -45
  320. package/src/components/Toolbox/Toolbox.stories.tsx +9 -10
  321. package/src/components/Toolbox/Toolbox.tsx +16 -17
  322. package/src/components/Typewriter/AssistantToolbar.tsx +161 -0
  323. package/src/components/Typewriter/Typewriter.stories.tsx +83 -0
  324. package/src/components/Typewriter/Typewriter.tsx +54 -0
  325. package/src/components/Typewriter/assistant-extension.tsx +144 -0
  326. package/src/components/Typewriter/index.ts +5 -0
  327. package/src/components/index.ts +2 -3
  328. package/src/functions/index.ts +1 -1
  329. package/src/functions/object-list.ts +4 -3
  330. package/src/functions/object-load.ts +7 -5
  331. package/src/functions/object-search.ts +46 -0
  332. package/src/hooks/index.ts +2 -1
  333. package/src/hooks/useBlueprintRegistry.ts +31 -20
  334. package/src/hooks/useChatProcessor.ts +15 -12
  335. package/src/hooks/useChatServices.ts +13 -14
  336. package/src/hooks/useChatToolbarActions.ts +121 -0
  337. package/src/hooks/useContextBinder.ts +9 -7
  338. package/src/hooks/useContextObjects.ts +13 -25
  339. package/src/hooks/useFilteredTypes.ts +37 -0
  340. package/src/hooks/useReferencesProvider.ts +7 -6
  341. package/src/index.ts +0 -1
  342. package/src/meta.ts +2 -2
  343. package/src/processor/presets.ts +1 -1
  344. package/src/processor/processor.test.ts +8 -17
  345. package/src/processor/processor.ts +41 -43
  346. package/src/processor/update-name.ts +4 -2
  347. package/src/queue-logger.ts +8 -9
  348. package/src/testing/test-generator.ts +14 -13
  349. package/src/testing/test-services.ts +8 -6
  350. package/src/translations.ts +27 -16
  351. package/src/types/Assistant.ts +9 -10
  352. package/src/types/AssistantAction.ts +59 -54
  353. package/src/types/capabilities.ts +27 -0
  354. package/src/types/events.ts +11 -0
  355. package/src/types/index.ts +3 -1
  356. package/src/types/service.ts +10 -7
  357. package/dist/lib/browser/BlueprintContainer-GMSYKGSO.mjs +0 -36
  358. package/dist/lib/browser/BlueprintContainer-GMSYKGSO.mjs.map +0 -7
  359. package/dist/lib/browser/ChatCompanion-M3FDKTQM.mjs +0 -151
  360. package/dist/lib/browser/ChatCompanion-M3FDKTQM.mjs.map +0 -7
  361. package/dist/lib/browser/ChatContainer-KAH7XITI.mjs +0 -74
  362. package/dist/lib/browser/ChatContainer-KAH7XITI.mjs.map +0 -7
  363. package/dist/lib/browser/ChatDialog-ZWRGABW6.mjs +0 -87
  364. package/dist/lib/browser/ChatDialog-ZWRGABW6.mjs.map +0 -7
  365. package/dist/lib/browser/ai-service-ERTZBTP3.mjs +0 -19
  366. package/dist/lib/browser/ai-service-ERTZBTP3.mjs.map +0 -7
  367. package/dist/lib/browser/app-graph-builder-R5T7BJPC.mjs +0 -183
  368. package/dist/lib/browser/app-graph-builder-R5T7BJPC.mjs.map +0 -7
  369. package/dist/lib/browser/blueprint-definition-AGTDXTXO.mjs +0 -13
  370. package/dist/lib/browser/chunk-357IHWQL.mjs +0 -1519
  371. package/dist/lib/browser/chunk-357IHWQL.mjs.map +0 -7
  372. package/dist/lib/browser/chunk-A2NVNXPL.mjs +0 -170
  373. package/dist/lib/browser/chunk-A2NVNXPL.mjs.map +0 -7
  374. package/dist/lib/browser/chunk-CQW6UPJM.mjs +0 -199
  375. package/dist/lib/browser/chunk-CQW6UPJM.mjs.map +0 -7
  376. package/dist/lib/browser/chunk-GNI6HL6G.mjs +0 -219
  377. package/dist/lib/browser/chunk-GNI6HL6G.mjs.map +0 -7
  378. package/dist/lib/browser/chunk-GXHZTOWJ.mjs +0 -378
  379. package/dist/lib/browser/chunk-GXHZTOWJ.mjs.map +0 -7
  380. package/dist/lib/browser/chunk-L5OA5OGS.mjs.map +0 -7
  381. package/dist/lib/browser/chunk-MEN5WTLA.mjs +0 -182
  382. package/dist/lib/browser/chunk-MEN5WTLA.mjs.map +0 -7
  383. package/dist/lib/browser/chunk-PUG24BEC.mjs +0 -277
  384. package/dist/lib/browser/chunk-PUG24BEC.mjs.map +0 -7
  385. package/dist/lib/browser/chunk-SJJV3HEX.mjs +0 -16
  386. package/dist/lib/browser/chunk-SJJV3HEX.mjs.map +0 -7
  387. package/dist/lib/browser/chunk-WBG5PTSX.mjs.map +0 -7
  388. package/dist/lib/browser/edge-model-resolver-O6OFYIO2.mjs +0 -18
  389. package/dist/lib/browser/edge-model-resolver-O6OFYIO2.mjs.map +0 -7
  390. package/dist/lib/browser/intent-resolver-3C5TABOX.mjs +0 -136
  391. package/dist/lib/browser/intent-resolver-3C5TABOX.mjs.map +0 -7
  392. package/dist/lib/browser/local-model-resolver-GO6ZEMLL.mjs +0 -17
  393. package/dist/lib/browser/local-model-resolver-GO6ZEMLL.mjs.map +0 -7
  394. package/dist/lib/browser/react-surface-EYKA5IFU.mjs +0 -90
  395. package/dist/lib/browser/react-surface-EYKA5IFU.mjs.map +0 -7
  396. package/dist/lib/browser/settings-VMVBYZLN.mjs +0 -23
  397. package/dist/lib/browser/settings-VMVBYZLN.mjs.map +0 -7
  398. package/dist/lib/browser/state-CFREPBB6.mjs +0 -21
  399. package/dist/lib/browser/state-CFREPBB6.mjs.map +0 -7
  400. package/dist/lib/browser/toolkit-F3NQ7TSI.mjs +0 -21
  401. package/dist/lib/browser/toolkit-F3NQ7TSI.mjs.map +0 -7
  402. package/dist/lib/node-esm/BlueprintContainer-6GBLMK4Z.mjs +0 -37
  403. package/dist/lib/node-esm/BlueprintContainer-6GBLMK4Z.mjs.map +0 -7
  404. package/dist/lib/node-esm/ChatCompanion-OV426GCP.mjs +0 -152
  405. package/dist/lib/node-esm/ChatCompanion-OV426GCP.mjs.map +0 -7
  406. package/dist/lib/node-esm/ChatContainer-UKY7NHFY.mjs +0 -75
  407. package/dist/lib/node-esm/ChatContainer-UKY7NHFY.mjs.map +0 -7
  408. package/dist/lib/node-esm/ChatDialog-2BDQIEXH.mjs +0 -88
  409. package/dist/lib/node-esm/ChatDialog-2BDQIEXH.mjs.map +0 -7
  410. package/dist/lib/node-esm/ai-service-MUYLV3NT.mjs +0 -20
  411. package/dist/lib/node-esm/ai-service-MUYLV3NT.mjs.map +0 -7
  412. package/dist/lib/node-esm/app-graph-builder-I52RYVWH.mjs +0 -184
  413. package/dist/lib/node-esm/app-graph-builder-I52RYVWH.mjs.map +0 -7
  414. package/dist/lib/node-esm/chunk-2CAETDW2.mjs +0 -183
  415. package/dist/lib/node-esm/chunk-2CAETDW2.mjs.map +0 -7
  416. package/dist/lib/node-esm/chunk-4J5FYNNM.mjs +0 -171
  417. package/dist/lib/node-esm/chunk-4J5FYNNM.mjs.map +0 -7
  418. package/dist/lib/node-esm/chunk-5ARE4R2I.mjs +0 -220
  419. package/dist/lib/node-esm/chunk-5ARE4R2I.mjs.map +0 -7
  420. package/dist/lib/node-esm/chunk-7ZYOYW7F.mjs.map +0 -7
  421. package/dist/lib/node-esm/chunk-HJPIYMWD.mjs +0 -1520
  422. package/dist/lib/node-esm/chunk-HJPIYMWD.mjs.map +0 -7
  423. package/dist/lib/node-esm/chunk-O36P4LN5.mjs +0 -200
  424. package/dist/lib/node-esm/chunk-O36P4LN5.mjs.map +0 -7
  425. package/dist/lib/node-esm/chunk-WE6KTH72.mjs.map +0 -7
  426. package/dist/lib/node-esm/chunk-XM4BVQQR.mjs +0 -278
  427. package/dist/lib/node-esm/chunk-XM4BVQQR.mjs.map +0 -7
  428. package/dist/lib/node-esm/chunk-XQBL2SBL.mjs +0 -17
  429. package/dist/lib/node-esm/chunk-XQBL2SBL.mjs.map +0 -7
  430. package/dist/lib/node-esm/chunk-YIO5MEPR.mjs +0 -380
  431. package/dist/lib/node-esm/chunk-YIO5MEPR.mjs.map +0 -7
  432. package/dist/lib/node-esm/edge-model-resolver-2ARXDOYS.mjs.map +0 -7
  433. package/dist/lib/node-esm/intent-resolver-HQ27YALS.mjs +0 -137
  434. package/dist/lib/node-esm/intent-resolver-HQ27YALS.mjs.map +0 -7
  435. package/dist/lib/node-esm/local-model-resolver-WOQ2D2R2.mjs +0 -18
  436. package/dist/lib/node-esm/local-model-resolver-WOQ2D2R2.mjs.map +0 -7
  437. package/dist/lib/node-esm/react-surface-UOC3CBPH.mjs +0 -91
  438. package/dist/lib/node-esm/react-surface-UOC3CBPH.mjs.map +0 -7
  439. package/dist/lib/node-esm/settings-7AUVNDM2.mjs +0 -24
  440. package/dist/lib/node-esm/settings-7AUVNDM2.mjs.map +0 -7
  441. package/dist/lib/node-esm/state-XXND44OW.mjs +0 -22
  442. package/dist/lib/node-esm/state-XXND44OW.mjs.map +0 -7
  443. package/dist/lib/node-esm/toolkit-7CH5UNSQ.mjs +0 -22
  444. package/dist/lib/node-esm/toolkit-7CH5UNSQ.mjs.map +0 -7
  445. package/dist/types/src/capabilities/ai-service.d.ts +0 -4
  446. package/dist/types/src/capabilities/ai-service.d.ts.map +0 -1
  447. package/dist/types/src/capabilities/app-graph-builder.d.ts +0 -4
  448. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +0 -1
  449. package/dist/types/src/capabilities/blueprint-definition.d.ts +0 -7
  450. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +0 -1
  451. package/dist/types/src/capabilities/capabilities.d.ts +0 -11
  452. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  453. package/dist/types/src/capabilities/edge-model-resolver.d.ts +0 -4
  454. package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +0 -1
  455. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  456. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  457. package/dist/types/src/capabilities/local-model-resolver.d.ts +0 -10
  458. package/dist/types/src/capabilities/local-model-resolver.d.ts.map +0 -1
  459. package/dist/types/src/capabilities/react-surface.d.ts +0 -4
  460. package/dist/types/src/capabilities/react-surface.d.ts.map +0 -1
  461. package/dist/types/src/capabilities/settings.d.ts +0 -4
  462. package/dist/types/src/capabilities/settings.d.ts.map +0 -1
  463. package/dist/types/src/capabilities/state.d.ts +0 -4
  464. package/dist/types/src/capabilities/state.d.ts.map +0 -1
  465. package/dist/types/src/capabilities/toolkit.d.ts +0 -4
  466. package/dist/types/src/capabilities/toolkit.d.ts.map +0 -1
  467. package/dist/types/src/components/BlueprintContainer.d.ts +0 -8
  468. package/dist/types/src/components/BlueprintContainer.d.ts.map +0 -1
  469. package/dist/types/src/components/ChatThread/reducers.d.ts +0 -40
  470. package/dist/types/src/components/ChatThread/reducers.d.ts.map +0 -1
  471. package/dist/types/src/components/ChatToolbar/ChatToolbar.d.ts +0 -6
  472. package/dist/types/src/components/ChatToolbar/ChatToolbar.d.ts.map +0 -1
  473. package/dist/types/src/components/ChatToolbar/index.d.ts +0 -2
  474. package/dist/types/src/components/ChatToolbar/index.d.ts.map +0 -1
  475. package/dist/types/src/components/ChatToolbar/useChatToolbarActions.d.ts +0 -9
  476. package/dist/types/src/components/ChatToolbar/useChatToolbarActions.d.ts.map +0 -1
  477. package/dist/types/src/components/TemplateEditor/handlebars-extension.d.ts.map +0 -1
  478. package/dist/types/src/events.d.ts +0 -4
  479. package/dist/types/src/events.d.ts.map +0 -1
  480. package/dist/types/src/functions/analysis.d.ts +0 -5
  481. package/dist/types/src/functions/analysis.d.ts.map +0 -1
  482. package/dist/types/src/hooks/useItemTypes.d.ts +0 -4
  483. package/dist/types/src/hooks/useItemTypes.d.ts.map +0 -1
  484. package/dist/types/src/toolkits/AssistantToolkit.d.ts +0 -21
  485. package/dist/types/src/toolkits/AssistantToolkit.d.ts.map +0 -1
  486. package/dist/types/src/toolkits/SystemToolkit.d.ts +0 -69
  487. package/dist/types/src/toolkits/SystemToolkit.d.ts.map +0 -1
  488. package/dist/types/src/toolkits/index.d.ts +0 -3
  489. package/dist/types/src/toolkits/index.d.ts.map +0 -1
  490. package/src/capabilities/ai-service.ts +0 -27
  491. package/src/capabilities/app-graph-builder.ts +0 -194
  492. package/src/capabilities/blueprint-definition.ts +0 -66
  493. package/src/capabilities/capabilities.ts +0 -18
  494. package/src/capabilities/edge-model-resolver.ts +0 -25
  495. package/src/capabilities/intent-resolver.ts +0 -121
  496. package/src/capabilities/local-model-resolver.ts +0 -30
  497. package/src/capabilities/react-surface.tsx +0 -71
  498. package/src/capabilities/settings.ts +0 -19
  499. package/src/capabilities/state.ts +0 -20
  500. package/src/capabilities/toolkit.ts +0 -19
  501. package/src/components/BlueprintContainer.tsx +0 -30
  502. package/src/components/ChatThread/reducers.ts +0 -151
  503. package/src/components/ChatToolbar/ChatToolbar.tsx +0 -23
  504. package/src/components/ChatToolbar/index.ts +0 -5
  505. package/src/components/ChatToolbar/useChatToolbarActions.ts +0 -126
  506. package/src/components/TemplateEditor/handlebars-extension.ts +0 -166
  507. package/src/events.ts +0 -11
  508. package/src/functions/analysis.ts +0 -22
  509. package/src/hooks/useItemTypes.ts +0 -37
  510. package/src/toolkits/AssistantToolkit.ts +0 -55
  511. package/src/toolkits/SystemToolkit.ts +0 -292
  512. package/src/toolkits/index.ts +0 -6
  513. /package/dist/lib/browser/{blueprint-definition-AGTDXTXO.mjs.map → blueprint-definition-DGHH7MUU.mjs.map} +0 -0
  514. /package/dist/lib/{node-esm/blueprint-definition-CFCUD2VC.mjs.map → browser/blueprints/index.mjs.map} +0 -0
  515. /package/dist/types/src/components/TemplateEditor/{handlebars-extension.d.ts → extensions/handlebars-extension.d.ts} +0 -0
@@ -6,19 +6,25 @@ import React, { type JSX, useMemo, useState } from 'react';
6
6
 
7
7
  import { type AiContextBinder } from '@dxos/assistant';
8
8
  import { type Blueprint } from '@dxos/blueprints';
9
- import { Filter, Obj, Type } from '@dxos/echo';
10
- import { type Space, useQuery } from '@dxos/react-client/echo';
11
- import { Icon, IconButton, Popover, Select, useTranslation } from '@dxos/react-ui';
12
- import { Listbox, SearchList } from '@dxos/react-ui-searchlist';
9
+ import { type Database, Filter, Obj, Type } from '@dxos/echo';
10
+ import { useQuery } from '@dxos/react-client/echo';
11
+ import { IconButton, Popover, Select, useTranslation } from '@dxos/react-ui';
12
+ import { Listbox, SearchList, useSearchListResults } from '@dxos/react-ui-searchlist';
13
13
  import { Tabs } from '@dxos/react-ui-tabs';
14
14
 
15
- import { useActiveBlueprints, useBlueprintHandlers, useBlueprints, useContextObjects, useItemTypes } from '../../hooks';
15
+ import {
16
+ useActiveBlueprints,
17
+ useBlueprintHandlers,
18
+ useBlueprints,
19
+ useContextObjects,
20
+ useFilteredTypes,
21
+ } from '../../hooks';
16
22
  import { meta } from '../../meta';
17
23
 
18
24
  const panelClassNames = 'is-[calc(100dvw-.5rem)] sm:is-max md:is-72 max-is-[--text-content]';
19
25
 
20
26
  export type ChatOptionsProps = {
21
- space: Space;
27
+ db: Database.Database;
22
28
  context: AiContextBinder;
23
29
  blueprintRegistry?: Blueprint.Registry;
24
30
  presets?: { id: string; label: string }[];
@@ -29,25 +35,20 @@ export type ChatOptionsProps = {
29
35
  /**
30
36
  * Manages the runtime context for the chat.
31
37
  */
32
- export const ChatOptions = ({
33
- space,
34
- context,
35
- blueprintRegistry,
36
- presets,
37
- preset,
38
- onPresetChange,
39
- }: ChatOptionsProps) => {
38
+ export const ChatOptions = ({ db, context, blueprintRegistry, presets, preset, onPresetChange }: ChatOptionsProps) => {
40
39
  const { t } = useTranslation(meta.id);
41
40
 
42
41
  return (
43
- <div role='none' className='flex gap-0.5'>
42
+ <div role='none' className='flex p-2'>
44
43
  <Popover.Root>
45
44
  <Popover.Trigger asChild>
46
- <IconButton variant='ghost' icon='ph--plus--regular' iconOnly size={5} label={t('button context objects')} />
45
+ <IconButton variant='ghost' icon='ph--plus--regular' iconOnly label={t('context objects button')} />
47
46
  </Popover.Trigger>
48
47
  <Popover.Portal>
49
48
  <Popover.Content side='top' classNames={panelClassNames}>
50
- <ObjectsPanel space={space} context={context} />
49
+ <Popover.Viewport>
50
+ <ObjectsPanel db={db} context={context} />
51
+ </Popover.Viewport>
51
52
  <Popover.Arrow />
52
53
  </Popover.Content>
53
54
  </Popover.Portal>
@@ -59,30 +60,31 @@ export const ChatOptions = ({
59
60
  variant='ghost'
60
61
  icon='ph--sliders-horizontal--regular'
61
62
  iconOnly
62
- size={5}
63
- label={t('button context settings')}
63
+ label={t('context settings button')}
64
64
  />
65
65
  </Popover.Trigger>
66
66
  <Popover.Portal>
67
67
  <Popover.Content side='top' classNames={panelClassNames}>
68
- <Tabs.Root orientation='horizontal' defaultValue='blueprints' defaultActivePart='list' tabIndex={-1}>
69
- <Tabs.Viewport classNames='max-bs-[--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-bs-0 [&_[role="listbox"]]:overflow-y-auto [&_[role="tabpanel"]]:min-bs-0 [&_[role="tabpanel"]]:pli-cardSpacingChrome [&_[role="tabpanel"][data-state="active"]]:order-first [&_[role="tabpanel"][data-state="inactive"]]:hidden'>
70
- <Tabs.Tabpanel value='blueprints' tabIndex={-1} classNames='dx-focus-ring-inset'>
71
- <BlueprintsPanel blueprintRegistry={blueprintRegistry} space={space} context={context} />
72
- </Tabs.Tabpanel>
73
- <Tabs.Tabpanel value='model' tabIndex={-1} classNames='dx-focus-ring-inset !pli-0'>
74
- <ModelsPanel presets={presets} preset={preset} onPresetChange={onPresetChange} />
75
- </Tabs.Tabpanel>
76
- <Tabs.Tablist classNames='sm:overflow-x-hidden justify-center p-[--dx-cardSpacingChrome] border-bs border-subduedSeparator order-last'>
77
- <Tabs.IconTab
78
- value='blueprints'
79
- icon='ph--blueprint--regular'
80
- label={t('blueprints in context title')}
81
- />
82
- <Tabs.IconTab value='model' label={t('chat model title')} icon='ph--cpu--regular' />
83
- </Tabs.Tablist>
84
- </Tabs.Viewport>
85
- </Tabs.Root>
68
+ <Popover.Viewport>
69
+ <Tabs.Root orientation='horizontal' defaultValue='blueprints' defaultActivePart='list' tabIndex={-1}>
70
+ <Tabs.Viewport classNames='max-bs-[--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-bs-0 [&_[role="listbox"]]:overflow-y-auto [&_[role="tabpanel"]]:min-bs-0 [&_[role="tabpanel"]]:pli-cardSpacingChrome [&_[role="tabpanel"][data-state="active"]]:order-first [&_[role="tabpanel"][data-state="inactive"]]:hidden'>
71
+ <Tabs.Tabpanel value='blueprints' tabIndex={-1} classNames='dx-focus-ring-inset'>
72
+ <BlueprintsPanel blueprintRegistry={blueprintRegistry} db={db} context={context} />
73
+ </Tabs.Tabpanel>
74
+ <Tabs.Tabpanel value='model' tabIndex={-1} classNames='dx-focus-ring-inset !pli-0'>
75
+ <ModelsPanel presets={presets} preset={preset} onPresetChange={onPresetChange} />
76
+ </Tabs.Tabpanel>
77
+ <Tabs.Tablist classNames='sm:overflow-x-hidden justify-center p-[--dx-cardSpacingChrome] border-bs border-subduedSeparator order-last'>
78
+ <Tabs.IconTab
79
+ value='blueprints'
80
+ icon='ph--blueprint--regular'
81
+ label={t('blueprints in context title')}
82
+ />
83
+ <Tabs.IconTab value='model' label={t('chat model title')} icon='ph--cpu--regular' />
84
+ </Tabs.Tablist>
85
+ </Tabs.Viewport>
86
+ </Tabs.Root>
87
+ </Popover.Viewport>
86
88
  <Popover.Arrow />
87
89
  </Popover.Content>
88
90
  </Popover.Portal>
@@ -93,32 +95,38 @@ export const ChatOptions = ({
93
95
 
94
96
  const BlueprintsPanel = ({
95
97
  blueprintRegistry,
96
- space,
98
+ db,
97
99
  context,
98
- }: Pick<ChatOptionsProps, 'blueprintRegistry' | 'space' | 'context'>) => {
100
+ }: Pick<ChatOptionsProps, 'blueprintRegistry' | 'db' | 'context'>) => {
99
101
  const { t } = useTranslation(meta.id);
100
102
 
101
- const blueprints = useBlueprints({ blueprintRegistry, space });
103
+ const blueprints = useBlueprints({ blueprintRegistry, db });
102
104
  const activeBlueprints = useActiveBlueprints({ context });
103
- const { onUpdateBlueprint } = useBlueprintHandlers({ space, context, blueprintRegistry });
105
+ const { onUpdateBlueprint } = useBlueprintHandlers({ db, context, blueprintRegistry });
106
+
107
+ const { results, handleSearch } = useSearchListResults({
108
+ items: blueprints,
109
+ extract: (blueprint) => blueprint.name,
110
+ });
104
111
 
105
112
  return (
106
- <SearchList.Root>
113
+ <SearchList.Root onSearch={handleSearch}>
107
114
  <SearchList.Content classNames='plb-cardSpacingChrome'>
108
- {blueprints.map((blueprint) => {
109
- const isActive = activeBlueprints.has(blueprint.key);
110
- return (
111
- <SearchList.Item
112
- classNames='flex items-center overflow-hidden'
113
- key={blueprint.key}
114
- value={blueprint.name}
115
- onSelect={() => onUpdateBlueprint?.(blueprint.key, !isActive)}
116
- >
117
- <div className='grow truncate'>{blueprint.name}</div>
118
- <Icon icon='ph--check--regular' classNames={[!isActive && 'invisible']} />
119
- </SearchList.Item>
120
- );
121
- })}
115
+ <SearchList.Viewport>
116
+ {results.map((blueprint) => {
117
+ const isActive = activeBlueprints.has(blueprint.key);
118
+ return (
119
+ <SearchList.Item
120
+ classNames='flex items-center overflow-hidden'
121
+ key={blueprint.key}
122
+ value={blueprint.key}
123
+ label={blueprint.name}
124
+ checked={isActive}
125
+ onSelect={() => onUpdateBlueprint?.(blueprint.key, !isActive)}
126
+ />
127
+ );
128
+ })}
129
+ </SearchList.Viewport>
122
130
  </SearchList.Content>
123
131
  <SearchList.Input placeholder={t('search placeholder')} classNames='mbe-cardSpacingChrome' autoFocus />
124
132
  </SearchList.Root>
@@ -146,11 +154,11 @@ const ModelsPanel = ({
146
154
 
147
155
  const ANY = '__any__';
148
156
 
149
- const ObjectsPanel = ({ space, context }: Pick<ChatOptionsProps, 'space' | 'context'>): JSX.Element => {
157
+ const ObjectsPanel = ({ db, context }: Pick<ChatOptionsProps, 'db' | 'context'>): JSX.Element => {
150
158
  const { t } = useTranslation(meta.id);
151
159
 
152
160
  // Item types sorted by label.
153
- const types = useItemTypes(space);
161
+ const types = useFilteredTypes(db);
154
162
  const typenames = useMemo(() => {
155
163
  const typenames = types.map((type) => {
156
164
  const typename = Type.getTypename(type);
@@ -172,31 +180,36 @@ const ObjectsPanel = ({ space, context }: Pick<ChatOptionsProps, 'space' | 'cont
172
180
  );
173
181
 
174
182
  // Context objects.
175
- const objects = useQuery(space, typename === ANY ? anyFilter : Filter.typename(typename));
176
- const { objects: contextObjects, onUpdateObject } = useContextObjects({ space, context });
183
+ const objects = useQuery(db, typename === ANY ? anyFilter : Filter.typename(typename));
184
+ const { objects: contextObjects, onUpdateObject } = useContextObjects({ db, context });
185
+
186
+ const { results, handleSearch } = useSearchListResults({
187
+ items: objects,
188
+ extract: (object) => Obj.getLabel(object) ?? Obj.getTypename(object) ?? object.id,
189
+ });
177
190
 
178
191
  return (
179
- <SearchList.Root>
192
+ <SearchList.Root onSearch={handleSearch}>
180
193
  <SearchList.Content classNames='p-cardSpacingChrome [&:has([cmdk-list-sizer]:empty)]:plb-0'>
181
- {objects.length ? (
182
- objects.map((object) => {
183
- const label = Obj.getLabel(object) ?? Obj.getTypename(object) ?? object.id;
184
- const isActive = contextObjects.findIndex((obj) => obj.id === object.id) !== -1;
185
- return (
186
- <SearchList.Item
187
- classNames='flex items-center overflow-hidden'
188
- key={object.id}
189
- value={object.id}
190
- onSelect={() => onUpdateObject?.(Obj.getDXN(object), !isActive)}
191
- >
192
- <div className='grow truncate'>{label}</div>
193
- <Icon icon='ph--check--regular' classNames={[!isActive && 'invisible']} />
194
- </SearchList.Item>
195
- );
196
- })
197
- ) : (
198
- <SearchList.Item>{t('no results')}</SearchList.Item>
199
- )}
194
+ <SearchList.Viewport>
195
+ {results.length ? (
196
+ results.map((object) => {
197
+ const isActive = contextObjects.findIndex((obj) => obj.id === object.id) !== -1;
198
+ return (
199
+ <SearchList.Item
200
+ classNames='flex items-center overflow-hidden'
201
+ key={object.id}
202
+ value={object.id}
203
+ label={Obj.getLabel(object) ?? Obj.getTypename(object) ?? object.id}
204
+ checked={isActive}
205
+ onSelect={() => onUpdateObject?.(Obj.getDXN(object), !isActive)}
206
+ />
207
+ );
208
+ })
209
+ ) : (
210
+ <SearchList.Item value='__empty__' label={t('no results')} />
211
+ )}
212
+ </SearchList.Viewport>
200
213
  </SearchList.Content>
201
214
 
202
215
  <div role='none' className='grid grid-cols-[min-content_1fr] gap-2 pli-cardSpacingChrome mbe-cardSpacingChrome'>
@@ -5,25 +5,24 @@
5
5
  import React from 'react';
6
6
 
7
7
  import { type AiContextBinder } from '@dxos/assistant';
8
- import { Obj } from '@dxos/echo';
9
- import { type Space } from '@dxos/react-client/echo';
8
+ import { type Database, Obj } from '@dxos/echo';
10
9
  import { IconButton, type Label, type ThemedClassName, toLocalizedString, useTranslation } from '@dxos/react-ui';
11
- import { mx } from '@dxos/react-ui-theme';
10
+ import { mx } from '@dxos/ui-theme';
12
11
 
13
12
  import { useContextObjects } from '../../hooks';
14
13
  import { meta } from '../../meta';
15
14
 
16
15
  export type ChatReferencesProps = ThemedClassName<{
17
16
  context: AiContextBinder;
18
- space: Space;
17
+ db: Database.Database;
19
18
  }>;
20
19
 
21
- export const ChatReferences = ({ classNames, context, space }: ChatReferencesProps) => {
20
+ export const ChatReferences = ({ classNames, context, db }: ChatReferencesProps) => {
22
21
  const { t } = useTranslation(meta.id);
23
- const { objects, onUpdateObject } = useContextObjects({ space, context });
22
+ const { objects, onUpdateObject } = useContextObjects({ db, context });
24
23
 
25
24
  return (
26
- <ul className={mx('flex flex-wrap', classNames)}>
25
+ <ul className={mx('flex', classNames)}>
27
26
  {objects.map((obj) => {
28
27
  const dxn = Obj.getDXN(obj);
29
28
  const typename = Obj.getTypename(obj);
@@ -32,12 +31,12 @@ export const ChatReferences = ({ classNames, context, space }: ChatReferencesPro
32
31
  <li key={dxn.toString()} className='dx-tag plb-0 pis-2 flex items-center' data-hue='neutral'>
33
32
  {toLocalizedString(label, t)}
34
33
  <IconButton
34
+ icon='ph--x--bold'
35
35
  iconOnly
36
36
  variant='ghost'
37
37
  label={t('remove object in context label')}
38
38
  classNames='p-0 hover:bg-transparent'
39
39
  size={3}
40
- icon='ph--x--bold'
41
40
  onClick={() => onUpdateObject?.(dxn, false)}
42
41
  />
43
42
  </li>
@@ -6,7 +6,7 @@ import React, { useEffect, useState } from 'react';
6
6
 
7
7
  import { type ThemedClassName, Tooltip, useTimeout } from '@dxos/react-ui';
8
8
  import { Spinner, type SpinnerProps } from '@dxos/react-ui-sfx';
9
- import { mx } from '@dxos/react-ui-theme';
9
+ import { mx } from '@dxos/ui-theme';
10
10
 
11
11
  const period = 3_000;
12
12
 
@@ -6,33 +6,40 @@ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import * as Effect from 'effect/Effect';
7
7
  import * as Fiber from 'effect/Fiber';
8
8
  import * as Layer from 'effect/Layer';
9
- import React, { useEffect, useMemo, useState } from 'react';
9
+ import React, { type CSSProperties, useEffect, useMemo, useState } from 'react';
10
10
 
11
- import { ContextQueueService, DatabaseService } from '@dxos/functions';
11
+ import { Database } from '@dxos/echo';
12
+ import { runAndForwardErrors } from '@dxos/effect';
13
+ import { ContextQueueService } from '@dxos/functions';
12
14
  import { faker } from '@dxos/random';
13
15
  import { useQueue, useSpace } from '@dxos/react-client/echo';
14
16
  import { withClientProvider } from '@dxos/react-client/testing';
15
17
  import { Popover } from '@dxos/react-ui';
16
- import { withTheme } from '@dxos/react-ui/testing';
17
- import { PreviewPopoverProvider, usePreviewPopover } from '@dxos/react-ui-editor/testing';
18
- import { Card } from '@dxos/react-ui-stack';
19
- import { DataType } from '@dxos/schema';
18
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
19
+ import { MarkdownStream } from '@dxos/react-ui-components';
20
+ import { EditorPreviewProvider, useEditorPreview } from '@dxos/react-ui-editor';
21
+ import { Card } from '@dxos/react-ui-mosaic';
22
+ import { render } from '@dxos/storybook-utils';
23
+ import { type Message, Organization, Person } from '@dxos/types';
20
24
 
21
25
  import { createMessageGenerator } from '../../testing';
22
26
  import { translations } from '../../translations';
23
27
 
24
- import { ChatThread, type ChatThreadController, type ChatThreadProps } from './ChatThread';
28
+ import { ChatThread, type ChatThreadProps } from './ChatThread';
29
+ import { componentRegistry } from './registry';
30
+ import TEXT from './testing/thread.md?raw';
25
31
 
26
32
  faker.seed(1);
27
33
 
28
- type MessageGenerator = Effect.Effect<void, never, DatabaseService | ContextQueueService>;
34
+ type MessageGenerator = Effect.Effect<void, never, Database.Service | ContextQueueService>;
29
35
 
30
- type StoryProps = ChatThreadProps & { generator?: MessageGenerator[]; delay?: number };
36
+ type StoryProps = { generator?: MessageGenerator[]; delay?: number; wait?: boolean } & ChatThreadProps;
31
37
 
32
- const DefaultStory = ({ generator = [], delay = 0, ...props }: StoryProps) => {
38
+ const DefaultStory = ({ generator = [], delay = 0, wait, ...props }: StoryProps) => {
33
39
  const space = useSpace();
34
40
  const queueDxn = useMemo(() => space?.queues.create().dxn, [space]);
35
- const queue = useQueue<DataType.Message>(queueDxn);
41
+ const queue = useQueue<Message.Message>(queueDxn);
42
+ const [done, setDone] = useState(false);
36
43
 
37
44
  // Generate messages.
38
45
  useEffect(() => {
@@ -48,46 +55,38 @@ const DefaultStory = ({ generator = [], delay = 0, ...props }: StoryProps) => {
48
55
  yield* Effect.sleep(delay);
49
56
  }
50
57
  }
51
- }).pipe(Effect.provide(Layer.mergeAll(DatabaseService.layer(space.db), ContextQueueService.layer(queue)))),
58
+ setDone(true);
59
+ }).pipe(Effect.provide(Layer.mergeAll(Database.Service.layer(space.db), ContextQueueService.layer(queue)))),
52
60
  );
53
61
 
54
62
  return () => {
55
- void Effect.runPromise(Fiber.interrupt(fiber));
63
+ void runAndForwardErrors(Fiber.interrupt(fiber));
56
64
  };
57
65
  }, [space, queue, generator]);
58
66
 
59
- // Set context.
60
- const [controller, setController] = useState<ChatThreadController | null>(null);
61
- useEffect(() => {
62
- // controller?.setContext({ timestamp: Date.now() });
63
- }, [controller]);
67
+ if (wait && !done) {
68
+ return null;
69
+ }
64
70
 
65
- // TODO(burdon): Elsewhere PreviewProvider is implemented via the plugin-preview.
66
71
  return (
67
- <PreviewPopoverProvider
68
- onLookup={async ({ label, ref }) => {
69
- return { label, text: ref };
70
- }}
71
- >
72
- <ChatThread {...props} messages={queue?.objects ?? []} ref={setController} />
72
+ <EditorPreviewProvider onLookup={async ({ label, ref }) => ({ label, text: ref })}>
73
+ <ChatThread {...props} messages={queue?.objects} />
73
74
  <PreviewCard />
74
- </PreviewPopoverProvider>
75
+ </EditorPreviewProvider>
75
76
  );
76
77
  };
77
78
 
78
- // TODO(burdon): Factor out.
79
- // TODO(burdon): Provide renderer for preview extension.
80
79
  const PreviewCard = () => {
81
- const { target } = usePreviewPopover('PreviewCard');
80
+ const { target } = useEditorPreview('PreviewCard');
82
81
 
83
82
  return (
84
83
  <Popover.Portal>
85
84
  <Popover.Content onOpenAutoFocus={(event) => event.preventDefault()}>
86
85
  <Popover.Viewport>
87
- <Card.SurfaceRoot role='card--popover'>
86
+ <Card.Root>
88
87
  <Card.Heading>{target?.label}</Card.Heading>
89
88
  {target && <Card.Text classNames='truncate line-clamp-3'>{target.text}</Card.Text>}
90
- </Card.SurfaceRoot>
89
+ </Card.Root>
91
90
  </Popover.Viewport>
92
91
  <Popover.Arrow />
93
92
  </Popover.Content>
@@ -98,32 +97,54 @@ const PreviewCard = () => {
98
97
  const meta = {
99
98
  title: 'plugins/plugin-assistant/ChatThread',
100
99
  component: ChatThread,
101
- render: DefaultStory,
100
+ render: render(DefaultStory),
102
101
  decorators: [
103
102
  withTheme,
104
- withClientProvider({ createIdentity: true, createSpace: true, types: [DataType.Organization, DataType.Person] }),
103
+ withLayout({ layout: 'column' }),
104
+ withClientProvider({
105
+ createIdentity: true,
106
+ createSpace: true,
107
+ types: [Organization.Organization, Person.Person],
108
+ }),
105
109
  ],
106
110
  parameters: {
107
111
  layout: 'fullscreen',
108
112
  translations,
109
113
  },
110
- } satisfies Meta<typeof ChatThread>;
114
+ } satisfies Meta<StoryProps>;
111
115
 
112
116
  export default meta;
113
117
 
114
- type Story = StoryObj<typeof meta>;
118
+ type Story = StoryObj<StoryProps>;
115
119
 
116
120
  export const Default: Story = {
117
121
  args: {
118
122
  generator: createMessageGenerator(),
123
+ wait: true,
119
124
  },
120
125
  };
121
126
 
122
127
  export const Delayed: Story = {
123
128
  args: {
124
129
  generator: createMessageGenerator(),
125
- delay: 3_000,
130
+ delay: 1_000,
126
131
  fadeIn: true,
127
132
  cursor: false,
128
133
  },
129
134
  };
135
+
136
+ export const Raw: Story = {
137
+ render: () => (
138
+ <div className='contents' style={{ '--user-fill': 'var(--dx-amberFill)' } as CSSProperties}>
139
+ <MarkdownStream content={TEXT} />
140
+ </div>
141
+ ),
142
+ };
143
+
144
+ export const Static: Story = {
145
+ render: () => (
146
+ <div className='contents' style={{ '--user-fill': 'var(--dx-amberFill)' } as CSSProperties}>
147
+ <MarkdownStream content={TEXT} registry={componentRegistry} />
148
+ </div>
149
+ ),
150
+ };
@@ -2,22 +2,14 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import React, {
6
- type CSSProperties,
7
- forwardRef,
8
- useCallback,
9
- useEffect,
10
- useImperativeHandle,
11
- useMemo,
12
- useState,
13
- } from 'react';
5
+ import React, { type CSSProperties, forwardRef, useCallback, useEffect, useMemo } from 'react';
14
6
 
15
7
  import { PublicKey } from '@dxos/keys';
16
8
  import { type Identity } from '@dxos/react-client/halo';
17
- import { type ThemedClassName } from '@dxos/react-ui';
9
+ import { type ThemedClassName, useForwardedRef } from '@dxos/react-ui';
18
10
  import { MarkdownStream, type MarkdownStreamController, type MarkdownStreamProps } from '@dxos/react-ui-components';
19
- import { mx } from '@dxos/react-ui-theme';
20
- import { type DataType } from '@dxos/schema';
11
+ import { type Message } from '@dxos/types';
12
+ import { mx } from '@dxos/ui-theme';
21
13
  import { keyToFallback } from '@dxos/util';
22
14
 
23
15
  import { type ChatEvent } from '../Chat';
@@ -25,30 +17,28 @@ import { type ChatEvent } from '../Chat';
25
17
  import { blockToMarkdown, componentRegistry } from './registry';
26
18
  import { MessageSyncer } from './sync';
27
19
 
28
- export type ChatThreadController = Pick<MarkdownStreamController, 'setContext' | 'scrollToBottom'>;
29
-
30
20
  export type ChatThreadProps = ThemedClassName<
31
21
  {
32
22
  identity?: Identity;
33
- messages?: DataType.Message[];
23
+ messages?: Message.Message[];
34
24
  error?: Error;
35
- overscroll?: number;
36
25
  onEvent?: (event: ChatEvent) => void;
37
- } & Pick<MarkdownStreamProps, 'cursor' | 'fadeIn' | 'overscroll'>
26
+ } & Pick<MarkdownStreamProps, 'cursor' | 'fadeIn' | 'debug'>
38
27
  >;
39
28
 
40
- export const ChatThread = forwardRef<ChatThreadController | null, ChatThreadProps>(
29
+ // TODO(burdon): Memo thread position.
30
+ export const ChatThread = forwardRef<MarkdownStreamController, ChatThreadProps>(
41
31
  (
42
- { classNames, identity, messages = [], error, cursor = false, fadeIn = true, overscroll, onEvent },
32
+ { classNames, identity, messages = [], error, cursor = false, fadeIn = true, debug = false, onEvent },
43
33
  forwardedRef,
44
34
  ) => {
45
- const userHue = useMemo(() => {
46
- return identity?.profile?.data?.hue || keyToFallback(identity?.identityKey ?? PublicKey.random()).hue;
47
- }, [identity]);
35
+ const controllerRef = useForwardedRef(forwardedRef);
36
+ const controller = controllerRef.current;
48
37
 
49
- // Expose controller.
50
- const [controller, setController] = useState<MarkdownStreamController | null>(null);
51
- useImperativeHandle(forwardedRef, () => (controller ? controller : (null as any)), [controller]);
38
+ const userHue = useMemo(
39
+ () => identity?.profile?.data?.hue || keyToFallback(identity?.identityKey ?? PublicKey.random()).hue,
40
+ [identity],
41
+ );
52
42
 
53
43
  // Show error.
54
44
  useEffect(() => {
@@ -58,19 +48,18 @@ export const ChatThread = forwardRef<ChatThreadController | null, ChatThreadProp
58
48
  // Update document.
59
49
  const syncer = useMemo(() => controller && new MessageSyncer(controller, blockToMarkdown), [controller]);
60
50
  useEffect(() => {
61
- syncer?.sync(messages);
51
+ const reset = syncer?.append(messages, true);
52
+ if (reset) {
53
+ controller?.scrollToBottom('instant');
54
+ }
62
55
  }, [syncer, messages]);
63
56
 
64
- // Event handler.
57
+ // Event adapter.
65
58
  const handleEvent = useCallback<NonNullable<MarkdownStreamProps['onEvent']>>(
66
- (ev) => {
67
- switch (ev.type) {
59
+ ({ type, value }) => {
60
+ switch (type) {
68
61
  case 'submit': {
69
- ev.value &&
70
- onEvent?.({
71
- type: 'submit',
72
- text: ev.value,
73
- });
62
+ value && onEvent?.({ type, text: value });
74
63
  break;
75
64
  }
76
65
  }
@@ -80,15 +69,16 @@ export const ChatThread = forwardRef<ChatThreadController | null, ChatThreadProp
80
69
 
81
70
  return (
82
71
  <div
72
+ role='none'
83
73
  className={mx('flex bs-full is-full justify-center overflow-hidden', classNames)}
84
74
  style={{ '--user-fill': `var(--dx-${userHue}Fill)` } as CSSProperties}
85
75
  >
86
76
  <MarkdownStream
87
- ref={setController}
77
+ ref={controllerRef}
88
78
  registry={componentRegistry}
89
79
  cursor={cursor}
90
80
  fadeIn={fadeIn}
91
- overscroll={overscroll}
81
+ debug={debug}
92
82
  onEvent={handleEvent}
93
83
  />
94
84
  </div>
@@ -5,7 +5,7 @@
5
5
  import React, { useMemo } from 'react';
6
6
 
7
7
  import { type Space } from '@dxos/client/echo';
8
- import { Obj } from '@dxos/echo';
8
+ import { Entity } from '@dxos/echo';
9
9
  import { type DXN } from '@dxos/keys';
10
10
  import { DxAnchor } from '@dxos/lit-ui/react';
11
11
 
@@ -15,9 +15,9 @@ export type ObjectLinkProps = {
15
15
  };
16
16
 
17
17
  export const ObjectLink = ({ space, dxn }: ObjectLinkProps) => {
18
- const ref = useMemo(() => space.db.ref(dxn), [space, dxn.toString()]);
18
+ const ref = useMemo(() => space.db.makeRef(dxn), [space, dxn.toString()]);
19
19
 
20
- const title = Obj.getLabel(ref.target) ?? ref.target?.id ?? ref.dxn.toString();
20
+ const title = (ref.target && Entity.getLabel(ref.target)) ?? ref.target?.id ?? ref.dxn.toString();
21
21
  return (
22
22
  <DxAnchor rootclassname='dx-tag--anchor' refid={dxn.toString()}>
23
23
  {title}