@dxos/plugin-assistant 0.8.1-main.ba2dec9 → 0.8.1-staging.31c3ee1

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 (236) hide show
  1. package/dist/lib/browser/{AssistantDialog-AMON6O2T.mjs → AssistantDialog-YSHMAHW5.mjs} +15 -14
  2. package/dist/lib/browser/AssistantDialog-YSHMAHW5.mjs.map +7 -0
  3. package/dist/lib/browser/{ChatContainer-SPZK5ZHX.mjs → ChatContainer-V5GP7DYF.mjs} +11 -11
  4. package/dist/lib/browser/ChatContainer-V5GP7DYF.mjs.map +7 -0
  5. package/dist/lib/browser/TemplateContainer-K4EJNGIL.mjs +78 -0
  6. package/dist/lib/browser/TemplateContainer-K4EJNGIL.mjs.map +7 -0
  7. package/dist/lib/browser/ai-client-CDZLSNXE.mjs +35 -0
  8. package/dist/lib/browser/ai-client-CDZLSNXE.mjs.map +7 -0
  9. package/dist/lib/browser/app-graph-builder-MF5EVDWW.mjs +209 -0
  10. package/dist/lib/browser/app-graph-builder-MF5EVDWW.mjs.map +7 -0
  11. package/dist/lib/browser/{chunk-NV7SVHMV.mjs → chunk-3HCI5FIL.mjs} +2 -2
  12. package/dist/lib/browser/{chunk-NV7SVHMV.mjs.map → chunk-3HCI5FIL.mjs.map} +2 -2
  13. package/dist/lib/browser/{chunk-HI564NSX.mjs → chunk-FMB7RGMP.mjs} +379 -247
  14. package/dist/lib/browser/chunk-FMB7RGMP.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-IAMR2FAE.mjs +183 -0
  16. package/dist/lib/browser/chunk-IAMR2FAE.mjs.map +7 -0
  17. package/dist/lib/browser/{chunk-FR7IEJ7N.mjs → chunk-KYMKVE6M.mjs} +37 -15
  18. package/dist/lib/browser/chunk-KYMKVE6M.mjs.map +7 -0
  19. package/dist/lib/browser/{chunk-EUMPBC4T.mjs → chunk-NFUHCW2J.mjs} +3 -3
  20. package/dist/lib/browser/{chunk-NTLTGYYS.mjs → chunk-TXJWGWJ7.mjs} +3 -3
  21. package/dist/lib/browser/chunk-TXJWGWJ7.mjs.map +7 -0
  22. package/dist/lib/browser/index.mjs +37 -53
  23. package/dist/lib/browser/index.mjs.map +3 -3
  24. package/dist/lib/browser/{intent-resolver-FQRN6747.mjs → intent-resolver-WJGLKKVO.mjs} +8 -6
  25. package/dist/lib/browser/{intent-resolver-FQRN6747.mjs.map → intent-resolver-WJGLKKVO.mjs.map} +3 -3
  26. package/dist/lib/browser/meta.json +1 -1
  27. package/dist/lib/browser/{react-surface-GLNUJX7O.mjs → react-surface-57VRDOQT.mjs} +36 -15
  28. package/dist/lib/browser/react-surface-57VRDOQT.mjs.map +7 -0
  29. package/dist/lib/browser/{settings-VVQUGG56.mjs → settings-U6UFQX32.mjs} +4 -4
  30. package/dist/lib/browser/types/index.mjs +6 -2
  31. package/dist/lib/node/{AssistantDialog-DS7OCVMV.cjs → AssistantDialog-YI2BSGSX.cjs} +18 -17
  32. package/dist/lib/node/AssistantDialog-YI2BSGSX.cjs.map +7 -0
  33. package/dist/lib/node/{ChatContainer-7MNRJL6Q.cjs → ChatContainer-ZJ5JXF6A.cjs} +15 -15
  34. package/dist/lib/node/ChatContainer-ZJ5JXF6A.cjs.map +7 -0
  35. package/dist/lib/node/TemplateContainer-XWFYJB4T.cjs +104 -0
  36. package/dist/lib/node/TemplateContainer-XWFYJB4T.cjs.map +7 -0
  37. package/dist/lib/node/{ai-client-RBDOGK6W.cjs → ai-client-URCCYU6B.cjs} +19 -19
  38. package/dist/lib/node/ai-client-URCCYU6B.cjs.map +7 -0
  39. package/dist/lib/node/app-graph-builder-N5ZUUI2Z.cjs +220 -0
  40. package/dist/lib/node/app-graph-builder-N5ZUUI2Z.cjs.map +7 -0
  41. package/dist/lib/node/{chunk-34WE2FD2.cjs → chunk-APRU3QWK.cjs} +32 -9
  42. package/dist/lib/node/chunk-APRU3QWK.cjs.map +7 -0
  43. package/dist/lib/node/{chunk-3WXG6WA6.cjs → chunk-GBUNQ257.cjs} +6 -6
  44. package/dist/lib/node/chunk-GBUNQ257.cjs.map +7 -0
  45. package/dist/lib/node/{chunk-GNPXCHFT.cjs → chunk-Q5XWEMHB.cjs} +4 -4
  46. package/dist/lib/node/{chunk-GNPXCHFT.cjs.map → chunk-Q5XWEMHB.cjs.map} +2 -2
  47. package/dist/lib/node/{chunk-3HNLL6MY.cjs → chunk-RPBKMP2E.cjs} +350 -222
  48. package/dist/lib/node/chunk-RPBKMP2E.cjs.map +7 -0
  49. package/dist/lib/node/{chunk-NV4TQQSU.cjs → chunk-XI2ARIEO.cjs} +6 -6
  50. package/dist/lib/node/{chunk-PYTGHFKZ.cjs → chunk-ZKOC4ZFY.cjs} +40 -18
  51. package/dist/lib/node/chunk-ZKOC4ZFY.cjs.map +7 -0
  52. package/dist/lib/node/index.cjs +78 -94
  53. package/dist/lib/node/index.cjs.map +3 -3
  54. package/dist/lib/node/{intent-resolver-Z37RNNMC.cjs → intent-resolver-R3OSTIMH.cjs} +14 -12
  55. package/dist/lib/node/intent-resolver-R3OSTIMH.cjs.map +7 -0
  56. package/dist/lib/node/meta.json +1 -1
  57. package/dist/lib/node/{react-surface-PYGRBZY7.cjs → react-surface-NUQTM6MS.cjs} +47 -26
  58. package/dist/lib/node/react-surface-NUQTM6MS.cjs.map +7 -0
  59. package/dist/lib/node/{settings-TJHHVI6B.cjs → settings-TXGRCYAL.cjs} +8 -8
  60. package/dist/lib/node/types/index.cjs +15 -11
  61. package/dist/lib/node/types/index.cjs.map +2 -2
  62. package/dist/lib/node-esm/{AssistantDialog-TSVUYKUL.mjs → AssistantDialog-U2FQX5TD.mjs} +15 -14
  63. package/dist/lib/node-esm/AssistantDialog-U2FQX5TD.mjs.map +7 -0
  64. package/dist/lib/node-esm/{ChatContainer-H4X734PB.mjs → ChatContainer-QW3OOXTT.mjs} +11 -11
  65. package/dist/lib/node-esm/ChatContainer-QW3OOXTT.mjs.map +7 -0
  66. package/dist/lib/node-esm/TemplateContainer-EUM2X65J.mjs +79 -0
  67. package/dist/lib/node-esm/TemplateContainer-EUM2X65J.mjs.map +7 -0
  68. package/dist/lib/node-esm/ai-client-WMHS5EGV.mjs +36 -0
  69. package/dist/lib/node-esm/ai-client-WMHS5EGV.mjs.map +7 -0
  70. package/dist/lib/node-esm/app-graph-builder-DWBNIMHM.mjs +210 -0
  71. package/dist/lib/node-esm/app-graph-builder-DWBNIMHM.mjs.map +7 -0
  72. package/dist/lib/node-esm/{chunk-ICQN3TDS.mjs → chunk-6JK5HEUQ.mjs} +3 -3
  73. package/dist/lib/node-esm/chunk-6JK5HEUQ.mjs.map +7 -0
  74. package/dist/lib/node-esm/{chunk-7SV6X6XU.mjs → chunk-ECRK6TUQ.mjs} +2 -2
  75. package/dist/lib/node-esm/{chunk-7SV6X6XU.mjs.map → chunk-ECRK6TUQ.mjs.map} +2 -2
  76. package/dist/lib/node-esm/{chunk-JRP4BQT4.mjs → chunk-GBBXIW5F.mjs} +37 -15
  77. package/dist/lib/node-esm/chunk-GBBXIW5F.mjs.map +7 -0
  78. package/dist/lib/node-esm/{chunk-E44GXXNE.mjs → chunk-MVDAY3CZ.mjs} +379 -247
  79. package/dist/lib/node-esm/chunk-MVDAY3CZ.mjs.map +7 -0
  80. package/dist/lib/node-esm/chunk-MXK2EANZ.mjs +184 -0
  81. package/dist/lib/node-esm/chunk-MXK2EANZ.mjs.map +7 -0
  82. package/dist/lib/node-esm/{chunk-LBQGJE5T.mjs → chunk-PBZA7XJR.mjs} +3 -3
  83. package/dist/lib/node-esm/index.mjs +37 -53
  84. package/dist/lib/node-esm/index.mjs.map +3 -3
  85. package/dist/lib/node-esm/{intent-resolver-LOTXWV4J.mjs → intent-resolver-H32TL4X6.mjs} +8 -6
  86. package/dist/lib/node-esm/{intent-resolver-LOTXWV4J.mjs.map → intent-resolver-H32TL4X6.mjs.map} +3 -3
  87. package/dist/lib/node-esm/meta.json +1 -1
  88. package/dist/lib/node-esm/{react-surface-PEQD6IJS.mjs → react-surface-JBVZF6CP.mjs} +36 -15
  89. package/dist/lib/node-esm/react-surface-JBVZF6CP.mjs.map +7 -0
  90. package/dist/lib/node-esm/{settings-BVWR244C.mjs → settings-DZU5PNXM.mjs} +4 -4
  91. package/dist/lib/node-esm/types/index.mjs +6 -2
  92. package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
  93. package/dist/types/src/capabilities/ai-client.d.ts +2 -1
  94. package/dist/types/src/capabilities/ai-client.d.ts.map +1 -1
  95. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  96. package/dist/types/src/capabilities/capabilities.d.ts +2 -1
  97. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  98. package/dist/types/src/capabilities/index.d.ts +1 -1
  99. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  100. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  101. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  102. package/dist/types/src/components/AmbientDialog/AmbientDialog.d.ts +4 -3
  103. package/dist/types/src/components/AmbientDialog/AmbientDialog.d.ts.map +1 -1
  104. package/dist/types/src/components/AmbientDialog/AmbientDialog.stories.d.ts.map +1 -1
  105. package/dist/types/src/components/AssistantDialog.d.ts.map +1 -1
  106. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
  107. package/dist/types/src/components/ChatContainer.d.ts +4 -2
  108. package/dist/types/src/components/ChatContainer.d.ts.map +1 -1
  109. package/dist/types/src/components/Prompt/Prompt.d.ts +3 -0
  110. package/dist/types/src/components/Prompt/Prompt.d.ts.map +1 -1
  111. package/dist/types/src/components/Prompt/Prompt.stories.d.ts +1 -0
  112. package/dist/types/src/components/Prompt/Prompt.stories.d.ts.map +1 -1
  113. package/dist/types/src/components/Prompt/PromptBar.d.ts +2 -2
  114. package/dist/types/src/components/Prompt/PromptBar.d.ts.map +1 -1
  115. package/dist/types/src/components/Prompt/references.d.ts +30 -0
  116. package/dist/types/src/components/Prompt/references.d.ts.map +1 -0
  117. package/dist/types/src/components/TemplateContainer.d.ts.map +1 -1
  118. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +3 -3
  119. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
  120. package/dist/types/src/components/Thread/Thread.d.ts +11 -1
  121. package/dist/types/src/components/Thread/Thread.d.ts.map +1 -1
  122. package/dist/types/src/components/Thread/ThreadContainer.d.ts +3 -0
  123. package/dist/types/src/components/Thread/ThreadContainer.d.ts.map +1 -1
  124. package/dist/types/src/components/Thread/ThreadContainer.stories.d.ts +3 -3
  125. package/dist/types/src/components/Thread/ThreadContainer.stories.d.ts.map +1 -1
  126. package/dist/types/src/components/Thread/ThreadMessage.d.ts.map +1 -1
  127. package/dist/types/src/components/index.d.ts +3 -2
  128. package/dist/types/src/components/index.d.ts.map +1 -1
  129. package/dist/types/src/hooks/index.d.ts +1 -0
  130. package/dist/types/src/hooks/index.d.ts.map +1 -1
  131. package/dist/types/src/hooks/processor.d.ts +7 -15
  132. package/dist/types/src/hooks/processor.d.ts.map +1 -1
  133. package/dist/types/src/hooks/useChatProcessor.d.ts +11 -2
  134. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
  135. package/dist/types/src/hooks/useContextProvider.d.ts +17 -0
  136. package/dist/types/src/hooks/useContextProvider.d.ts.map +1 -0
  137. package/dist/types/src/hooks/useMessageQueue.d.ts +3 -3
  138. package/dist/types/src/hooks/useMessageQueue.d.ts.map +1 -1
  139. package/dist/types/src/meta.d.ts +2 -8
  140. package/dist/types/src/meta.d.ts.map +1 -1
  141. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  142. package/dist/types/src/translations.d.ts +26 -12
  143. package/dist/types/src/translations.d.ts.map +1 -1
  144. package/dist/types/src/types/chat.d.ts +4 -6
  145. package/dist/types/src/types/chat.d.ts.map +1 -1
  146. package/dist/types/src/types/template.d.ts +36 -0
  147. package/dist/types/src/types/template.d.ts.map +1 -1
  148. package/dist/types/src/types/types.d.ts +3 -1
  149. package/dist/types/src/types/types.d.ts.map +1 -1
  150. package/package.json +58 -55
  151. package/src/AssistantPlugin.tsx +19 -23
  152. package/src/capabilities/ai-client.ts +23 -7
  153. package/src/capabilities/app-graph-builder.ts +100 -5
  154. package/src/capabilities/capabilities.ts +3 -1
  155. package/src/capabilities/intent-resolver.ts +4 -3
  156. package/src/capabilities/react-surface.tsx +27 -9
  157. package/src/components/AmbientDialog/AmbientDialog.stories.tsx +3 -1
  158. package/src/components/AmbientDialog/AmbientDialog.tsx +11 -11
  159. package/src/components/AssistantDialog.tsx +8 -2
  160. package/src/components/AssistantSettings/AssistantSettings.tsx +39 -5
  161. package/src/components/ChatContainer.tsx +18 -4
  162. package/src/components/Prompt/Prompt.stories.tsx +34 -0
  163. package/src/components/Prompt/Prompt.tsx +28 -18
  164. package/src/components/Prompt/PromptBar.tsx +5 -3
  165. package/src/components/Prompt/references.ts +180 -0
  166. package/src/components/TemplateContainer.tsx +79 -4
  167. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +5 -5
  168. package/src/components/TemplateEditor/TemplateForm.stories.tsx +3 -3
  169. package/src/components/Thread/Thread.stories.tsx +3 -3
  170. package/src/components/Thread/Thread.tsx +21 -0
  171. package/src/components/Thread/ThreadContainer.stories.tsx +9 -14
  172. package/src/components/Thread/ThreadContainer.tsx +10 -4
  173. package/src/components/Thread/ThreadMessage.tsx +17 -9
  174. package/src/components/Toolbox/Toolbox.stories.tsx +2 -2
  175. package/src/components/index.ts +3 -0
  176. package/src/hooks/index.ts +1 -0
  177. package/src/hooks/processor.ts +57 -116
  178. package/src/hooks/useChatProcessor.tsx +35 -19
  179. package/src/hooks/useContextProvider.ts +55 -0
  180. package/src/hooks/useMessageQueue.ts +4 -6
  181. package/src/meta.ts +2 -2
  182. package/src/testing/test-functions.ts +2 -2
  183. package/src/translations.ts +11 -5
  184. package/src/types/chat.ts +2 -3
  185. package/src/types/template.ts +22 -0
  186. package/src/types/types.ts +3 -1
  187. package/dist/lib/browser/AssistantDialog-AMON6O2T.mjs.map +0 -7
  188. package/dist/lib/browser/ChatContainer-SPZK5ZHX.mjs.map +0 -7
  189. package/dist/lib/browser/TemplateContainer-B7MQNUPY.mjs +0 -23
  190. package/dist/lib/browser/TemplateContainer-B7MQNUPY.mjs.map +0 -7
  191. package/dist/lib/browser/ai-client-PORKRZXM.mjs +0 -33
  192. package/dist/lib/browser/ai-client-PORKRZXM.mjs.map +0 -7
  193. package/dist/lib/browser/app-graph-builder-36SKR7CX.mjs +0 -110
  194. package/dist/lib/browser/app-graph-builder-36SKR7CX.mjs.map +0 -7
  195. package/dist/lib/browser/chunk-FPXC3LKK.mjs +0 -162
  196. package/dist/lib/browser/chunk-FPXC3LKK.mjs.map +0 -7
  197. package/dist/lib/browser/chunk-FR7IEJ7N.mjs.map +0 -7
  198. package/dist/lib/browser/chunk-HI564NSX.mjs.map +0 -7
  199. package/dist/lib/browser/chunk-NTLTGYYS.mjs.map +0 -7
  200. package/dist/lib/browser/react-surface-GLNUJX7O.mjs.map +0 -7
  201. package/dist/lib/node/AssistantDialog-DS7OCVMV.cjs.map +0 -7
  202. package/dist/lib/node/ChatContainer-7MNRJL6Q.cjs.map +0 -7
  203. package/dist/lib/node/TemplateContainer-R4BZZP3E.cjs +0 -53
  204. package/dist/lib/node/TemplateContainer-R4BZZP3E.cjs.map +0 -7
  205. package/dist/lib/node/ai-client-RBDOGK6W.cjs.map +0 -7
  206. package/dist/lib/node/app-graph-builder-V5JKKIY5.cjs +0 -122
  207. package/dist/lib/node/app-graph-builder-V5JKKIY5.cjs.map +0 -7
  208. package/dist/lib/node/chunk-34WE2FD2.cjs.map +0 -7
  209. package/dist/lib/node/chunk-3HNLL6MY.cjs.map +0 -7
  210. package/dist/lib/node/chunk-3WXG6WA6.cjs.map +0 -7
  211. package/dist/lib/node/chunk-PYTGHFKZ.cjs.map +0 -7
  212. package/dist/lib/node/intent-resolver-Z37RNNMC.cjs.map +0 -7
  213. package/dist/lib/node/react-surface-PYGRBZY7.cjs.map +0 -7
  214. package/dist/lib/node-esm/AssistantDialog-TSVUYKUL.mjs.map +0 -7
  215. package/dist/lib/node-esm/ChatContainer-H4X734PB.mjs.map +0 -7
  216. package/dist/lib/node-esm/TemplateContainer-WSHTZBB5.mjs +0 -24
  217. package/dist/lib/node-esm/TemplateContainer-WSHTZBB5.mjs.map +0 -7
  218. package/dist/lib/node-esm/ai-client-OTZVBDUH.mjs +0 -34
  219. package/dist/lib/node-esm/ai-client-OTZVBDUH.mjs.map +0 -7
  220. package/dist/lib/node-esm/app-graph-builder-DCAP6QAV.mjs +0 -111
  221. package/dist/lib/node-esm/app-graph-builder-DCAP6QAV.mjs.map +0 -7
  222. package/dist/lib/node-esm/chunk-E44GXXNE.mjs.map +0 -7
  223. package/dist/lib/node-esm/chunk-ICQN3TDS.mjs.map +0 -7
  224. package/dist/lib/node-esm/chunk-JRP4BQT4.mjs.map +0 -7
  225. package/dist/lib/node-esm/chunk-LELXJPGJ.mjs +0 -163
  226. package/dist/lib/node-esm/chunk-LELXJPGJ.mjs.map +0 -7
  227. package/dist/lib/node-esm/react-surface-PEQD6IJS.mjs.map +0 -7
  228. package/dist/types/src/hooks/email.d.ts +0 -4
  229. package/dist/types/src/hooks/email.d.ts.map +0 -1
  230. package/src/hooks/email.ts +0 -49
  231. /package/dist/lib/browser/{chunk-EUMPBC4T.mjs.map → chunk-NFUHCW2J.mjs.map} +0 -0
  232. /package/dist/lib/browser/{settings-VVQUGG56.mjs.map → settings-U6UFQX32.mjs.map} +0 -0
  233. /package/dist/lib/node/{chunk-NV4TQQSU.cjs.map → chunk-XI2ARIEO.cjs.map} +0 -0
  234. /package/dist/lib/node/{settings-TJHHVI6B.cjs.map → settings-TXGRCYAL.cjs.map} +0 -0
  235. /package/dist/lib/node-esm/{chunk-LBQGJE5T.mjs.map → chunk-PBZA7XJR.mjs.map} +0 -0
  236. /package/dist/lib/node-esm/{settings-BVWR244C.mjs.map → settings-DZU5PNXM.mjs.map} +0 -0
@@ -16,21 +16,21 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var settings_TJHHVI6B_exports = {};
20
- __export(settings_TJHHVI6B_exports, {
19
+ var settings_TXGRCYAL_exports = {};
20
+ __export(settings_TXGRCYAL_exports, {
21
21
  default: () => settings_default
22
22
  });
23
- module.exports = __toCommonJS(settings_TJHHVI6B_exports);
24
- var import_chunk_34WE2FD2 = require("./chunk-34WE2FD2.cjs");
25
- var import_chunk_GNPXCHFT = require("./chunk-GNPXCHFT.cjs");
23
+ module.exports = __toCommonJS(settings_TXGRCYAL_exports);
24
+ var import_chunk_APRU3QWK = require("./chunk-APRU3QWK.cjs");
25
+ var import_chunk_Q5XWEMHB = require("./chunk-Q5XWEMHB.cjs");
26
26
  var import_app_framework = require("@dxos/app-framework");
27
27
  var import_live_object = require("@dxos/live-object");
28
28
  var settings_default = () => {
29
29
  const settings = (0, import_live_object.create)({});
30
30
  return (0, import_app_framework.contributes)(import_app_framework.Capabilities.Settings, {
31
- schema: import_chunk_34WE2FD2.AssistantSettingsSchema,
32
- prefix: import_chunk_GNPXCHFT.ASSISTANT_PLUGIN,
31
+ schema: import_chunk_APRU3QWK.AssistantSettingsSchema,
32
+ prefix: import_chunk_Q5XWEMHB.ASSISTANT_PLUGIN,
33
33
  value: settings
34
34
  });
35
35
  };
36
- //# sourceMappingURL=settings-TJHHVI6B.cjs.map
36
+ //# sourceMappingURL=settings-TXGRCYAL.cjs.map
@@ -18,19 +18,21 @@ var __copyProps = (to, from, except, desc) => {
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
19
  var types_exports = {};
20
20
  __export(types_exports, {
21
- AIChatType: () => import_chunk_34WE2FD2.AIChatType,
22
- ApiAuthorization: () => import_chunk_34WE2FD2.ApiAuthorization,
23
- AssistantAction: () => import_chunk_34WE2FD2.AssistantAction,
24
- AssistantSettingsSchema: () => import_chunk_34WE2FD2.AssistantSettingsSchema,
25
- ServiceType: () => import_chunk_34WE2FD2.ServiceType,
26
- TemplateInputSchema: () => import_chunk_34WE2FD2.TemplateInputSchema,
27
- TemplateInputType: () => import_chunk_34WE2FD2.TemplateInputType,
28
- TemplateType: () => import_chunk_34WE2FD2.TemplateType,
29
- categoryIcons: () => import_chunk_34WE2FD2.categoryIcons
21
+ AIChatType: () => import_chunk_APRU3QWK.AIChatType,
22
+ ApiAuthorization: () => import_chunk_APRU3QWK.ApiAuthorization,
23
+ AssistantAction: () => import_chunk_APRU3QWK.AssistantAction,
24
+ AssistantSettingsSchema: () => import_chunk_APRU3QWK.AssistantSettingsSchema,
25
+ ServiceType: () => import_chunk_APRU3QWK.ServiceType,
26
+ TemplateInputSchema: () => import_chunk_APRU3QWK.TemplateInputSchema,
27
+ TemplateInputType: () => import_chunk_APRU3QWK.TemplateInputType,
28
+ TemplateKindSchema: () => import_chunk_APRU3QWK.TemplateKindSchema,
29
+ TemplateKinds: () => import_chunk_APRU3QWK.TemplateKinds,
30
+ TemplateType: () => import_chunk_APRU3QWK.TemplateType,
31
+ categoryIcons: () => import_chunk_APRU3QWK.categoryIcons
30
32
  });
31
33
  module.exports = __toCommonJS(types_exports);
32
- var import_chunk_34WE2FD2 = require("../chunk-34WE2FD2.cjs");
33
- var import_chunk_GNPXCHFT = require("../chunk-GNPXCHFT.cjs");
34
+ var import_chunk_APRU3QWK = require("../chunk-APRU3QWK.cjs");
35
+ var import_chunk_Q5XWEMHB = require("../chunk-Q5XWEMHB.cjs");
34
36
  // Annotate the CommonJS export names for ESM import in node:
35
37
  0 && (module.exports = {
36
38
  AIChatType,
@@ -40,6 +42,8 @@ var import_chunk_GNPXCHFT = require("../chunk-GNPXCHFT.cjs");
40
42
  ServiceType,
41
43
  TemplateInputSchema,
42
44
  TemplateInputType,
45
+ TemplateKindSchema,
46
+ TemplateKinds,
43
47
  TemplateType,
44
48
  categoryIcons
45
49
  });
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["index.cjs"],
4
- "sourcesContent": ["import {\n AIChatType,\n ApiAuthorization,\n AssistantAction,\n AssistantSettingsSchema,\n ServiceType,\n TemplateInputSchema,\n TemplateInputType,\n TemplateType,\n categoryIcons\n} from \"../chunk-34WE2FD2.cjs\";\nimport \"../chunk-GNPXCHFT.cjs\";\nexport {\n AIChatType,\n ApiAuthorization,\n AssistantAction,\n AssistantSettingsSchema,\n ServiceType,\n TemplateInputSchema,\n TemplateInputType,\n TemplateType,\n categoryIcons\n};\n//# sourceMappingURL=index.cjs.map\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAUO;AACP,4BAAO;",
4
+ "sourcesContent": ["import {\n AIChatType,\n ApiAuthorization,\n AssistantAction,\n AssistantSettingsSchema,\n ServiceType,\n TemplateInputSchema,\n TemplateInputType,\n TemplateKindSchema,\n TemplateKinds,\n TemplateType,\n categoryIcons\n} from \"../chunk-APRU3QWK.cjs\";\nimport \"../chunk-Q5XWEMHB.cjs\";\nexport {\n AIChatType,\n ApiAuthorization,\n AssistantAction,\n AssistantSettingsSchema,\n ServiceType,\n TemplateInputSchema,\n TemplateInputType,\n TemplateKindSchema,\n TemplateKinds,\n TemplateType,\n categoryIcons\n};\n//# sourceMappingURL=index.cjs.map\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAYO;AACP,4BAAO;",
6
6
  "names": []
7
7
  }
@@ -1,34 +1,34 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  ThreadContainer
4
- } from "./chunk-E44GXXNE.mjs";
5
- import "./chunk-ICQN3TDS.mjs";
6
- import "./chunk-LELXJPGJ.mjs";
4
+ } from "./chunk-MVDAY3CZ.mjs";
5
+ import "./chunk-6JK5HEUQ.mjs";
6
+ import "./chunk-MXK2EANZ.mjs";
7
7
  import {
8
8
  ASSISTANT_PLUGIN
9
- } from "./chunk-7SV6X6XU.mjs";
9
+ } from "./chunk-ECRK6TUQ.mjs";
10
10
 
11
- // packages/plugins/experimental/plugin-assistant/src/components/AssistantDialog.tsx
11
+ // packages/plugins/plugin-assistant/src/components/AssistantDialog.tsx
12
12
  import React2, { useState as useState2 } from "react";
13
13
  import { useCapability, Capabilities, useCapabilities } from "@dxos/app-framework";
14
14
  import { TranscriptionCapabilities } from "@dxos/plugin-transcription";
15
15
  import { useTranslation } from "@dxos/react-ui";
16
16
 
17
- // packages/plugins/experimental/plugin-assistant/src/components/AmbientDialog/AmbientDialog.tsx
17
+ // packages/plugins/plugin-assistant/src/components/AmbientDialog/AmbientDialog.tsx
18
18
  import React, { useCallback, useEffect, useState } from "react";
19
19
  import { Dialog, Icon, IconButton } from "@dxos/react-ui";
20
20
  import { resizeAttributes, ResizeHandle, sizeStyle } from "@dxos/react-ui-dnd";
21
21
  import { mx } from "@dxos/react-ui-theme";
22
22
  var preventDefault = (event) => event.preventDefault();
23
23
  var minSize = 5;
24
- var AmbientDialog = ({ children, open: _open, title, onOpenChange }) => {
24
+ var AmbientDialog = ({ children, open: controlledOpen, title, onOpenChange }) => {
25
25
  const [resizeKey, setReizeKey] = useState(0);
26
26
  const [size, setSize] = useState("min-content");
27
- const [open, setOpen] = useState(_open);
27
+ const [open, setOpen] = useState(controlledOpen);
28
28
  useEffect(() => {
29
- setOpen(_open);
29
+ setOpen(controlledOpen);
30
30
  }, [
31
- _open
31
+ controlledOpen
32
32
  ]);
33
33
  useEffect(() => {
34
34
  setSize(open ? "min-content" : minSize);
@@ -52,7 +52,7 @@ var AmbientDialog = ({ children, open: _open, title, onOpenChange }) => {
52
52
  ...resizeAttributes,
53
53
  style: {
54
54
  ...sizeStyle(size, "vertical", true),
55
- maxBlockSize: "calc(100dvh - env(safe-area-inset-bottom) - env(safe-area-inset-top) - 8rem)"
55
+ maxBlockSize: "calc(100dvh - env(safe-area-inset-bottom) - env(safe-area-inset-top) - 9rem)"
56
56
  },
57
57
  onInteractOutside: preventDefault
58
58
  }, /* @__PURE__ */ React.createElement(ResizeHandle, {
@@ -92,10 +92,10 @@ var DialogHeader = ({ open, title, onToggle }) => {
92
92
  })));
93
93
  };
94
94
 
95
- // packages/plugins/experimental/plugin-assistant/src/components/AssistantDialog.tsx
95
+ // packages/plugins/plugin-assistant/src/components/AssistantDialog.tsx
96
96
  var AssistantDialog = ({ chat }) => {
97
97
  const { t } = useTranslation(ASSISTANT_PLUGIN);
98
- const transcription = useCapabilities(TranscriptionCapabilities.Transcription).length > 0;
98
+ const transcription = useCapabilities(TranscriptionCapabilities.Transcriber).length > 0;
99
99
  const settings = useCapability(Capabilities.SettingsStore).getStore(ASSISTANT_PLUGIN)?.value;
100
100
  const [open, setOpen] = useState2(false);
101
101
  return /* @__PURE__ */ React2.createElement(AmbientDialog, {
@@ -106,6 +106,7 @@ var AssistantDialog = ({ chat }) => {
106
106
  chat,
107
107
  onOpenChange: setOpen,
108
108
  settings,
109
+ part: "dialog",
109
110
  transcription
110
111
  }));
111
112
  };
@@ -114,4 +115,4 @@ export {
114
115
  AssistantDialog,
115
116
  AssistantDialog_default as default
116
117
  };
117
- //# sourceMappingURL=AssistantDialog-TSVUYKUL.mjs.map
118
+ //# sourceMappingURL=AssistantDialog-U2FQX5TD.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/AssistantDialog.tsx", "../../../src/components/AmbientDialog/AmbientDialog.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { type FC, useState } from 'react';\n\nimport { useCapability, Capabilities, useCapabilities } from '@dxos/app-framework';\nimport { TranscriptionCapabilities } from '@dxos/plugin-transcription';\nimport { useTranslation } from '@dxos/react-ui';\n\nimport { AmbientDialog } from './AmbientDialog';\nimport { ThreadContainer } from './Thread';\nimport { ASSISTANT_PLUGIN } from '../meta';\nimport { type AssistantSettingsProps, type AIChatType } from '../types';\n\nexport const AssistantDialog: FC<{ chat?: AIChatType }> = ({ chat }) => {\n const { t } = useTranslation(ASSISTANT_PLUGIN);\n const transcription = useCapabilities(TranscriptionCapabilities.Transcriber).length > 0;\n const settings = useCapability(Capabilities.SettingsStore).getStore<AssistantSettingsProps>(ASSISTANT_PLUGIN)?.value;\n\n // TODO(burdon): Refocus when open.\n const [open, setOpen] = useState(false);\n\n return (\n <AmbientDialog open={open} onOpenChange={setOpen} title={t('assistant dialog title')}>\n <ThreadContainer\n chat={chat}\n onOpenChange={setOpen}\n settings={settings}\n part={'dialog'}\n transcription={transcription}\n />\n </AmbientDialog>\n );\n};\n\nexport default AssistantDialog;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { type PropsWithChildren, useCallback, useEffect, useState } from 'react';\n\nimport { Dialog, Icon, IconButton } from '@dxos/react-ui';\nimport { resizeAttributes, ResizeHandle, type Size, sizeStyle } from '@dxos/react-ui-dnd';\nimport { mx } from '@dxos/react-ui-theme';\n\nconst preventDefault = (event: Event) => event.preventDefault();\n\nconst minSize = 5;\n\nexport type AmbientDialogProps = PropsWithChildren<{\n open?: boolean;\n title?: string;\n onOpenChange?: (open: boolean) => void;\n}>;\n\nexport const AmbientDialog = ({ children, open: controlledOpen, title, onOpenChange }: AmbientDialogProps) => {\n const [resizeKey, setReizeKey] = useState(0);\n const [size, setSize] = useState<Size>('min-content');\n const [open, setOpen] = useState(controlledOpen);\n\n // Update controlled value.\n useEffect(() => {\n setOpen(controlledOpen);\n }, [controlledOpen]);\n\n // Update size and key.\n useEffect(() => {\n setSize(open ? 'min-content' : minSize);\n setReizeKey((key) => key + 1);\n }, [open]);\n\n // TODO(burdon): Animate open/close.\n // NOTE: We set the min size to 5rem (80px), and the header and prompt bar to 40px (i.e., the rail-size) each.\n // The dialog has no vertical padding and has box-content so that when closed it collapses to the size of the header and prompt bar.\n const handleToggle = useCallback(() => {\n setOpen((open) => {\n onOpenChange?.(!open);\n return !open;\n });\n }, []);\n\n return (\n <div role='none' className='dx-dialog__overlay bg-transparent pointer-events-none' data-block-align='end'>\n <Dialog.Content\n classNames='relative box-content py-0 px-2 md:is-[35rem] md:max-is-none overflow-hidden pointer-events-auto transition-[block-size] ease-in-out duration-0 [&:not([data-dx-resizing=\"true\"])]:duration-200'\n inOverlayLayout\n {...resizeAttributes}\n style={{\n ...sizeStyle(size, 'vertical', true),\n maxBlockSize: 'calc(100dvh - env(safe-area-inset-bottom) - env(safe-area-inset-top) - 9rem)',\n }}\n onInteractOutside={preventDefault}\n >\n <ResizeHandle\n key={resizeKey}\n side='block-start'\n defaultSize='min-content'\n minSize={minSize}\n fallbackSize={minSize}\n iconPosition='center'\n onSizeChange={setSize}\n />\n\n <DialogHeader open={open} title={title} onToggle={handleToggle} />\n\n {children}\n </Dialog.Content>\n </div>\n );\n};\n\n/**\n * Matches same layout grid as PromptBar.\n */\nconst DialogHeader = ({ open, title, onToggle }: { open?: boolean; title?: string; onToggle: () => void }) => {\n return (\n <div className='flex shrink-0 w-full grid grid-cols-[var(--rail-action)_1fr_var(--rail-action)] items-center overflow-hidden'>\n <div className='flex w-[--rail-action] h-[--rail-action] items-center justify-center'>\n <Dialog.Close>\n <Icon icon='ph--x--regular' />\n </Dialog.Close>\n </div>\n <div className='grow'>\n <Dialog.Title classNames='flex justify-center text-xs text-subdued'>{title}</Dialog.Title>\n </div>\n <div className='flex w-[--rail-action] h-[--rail-action] items-center justify-center'>\n <IconButton\n variant='ghost'\n icon={'ph--caret-up--regular'}\n classNames={mx('[&>svg]:transition [&>svg]:duration-200', open && '[&>svg]:rotate-180')}\n iconOnly\n label='Shrink'\n onClick={onToggle}\n />\n </div>\n </div>\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;;;AAIA,OAAOA,UAAkBC,YAAAA,iBAAgB;AAEzC,SAASC,eAAeC,cAAcC,uBAAuB;AAC7D,SAASC,iCAAiC;AAC1C,SAASC,sBAAsB;;;ACJ/B,OAAOC,SAAiCC,aAAaC,WAAWC,gBAAgB;AAEhF,SAASC,QAAQC,MAAMC,kBAAkB;AACzC,SAASC,kBAAkBC,cAAyBC,iBAAiB;AACrE,SAASC,UAAU;AAEnB,IAAMC,iBAAiB,CAACC,UAAiBA,MAAMD,eAAc;AAE7D,IAAME,UAAU;AAQT,IAAMC,gBAAgB,CAAC,EAAEC,UAAUC,MAAMC,gBAAgBC,OAAOC,aAAY,MAAsB;AACvG,QAAM,CAACC,WAAWC,WAAAA,IAAeC,SAAS,CAAA;AAC1C,QAAM,CAACC,MAAMC,OAAAA,IAAWF,SAAe,aAAA;AACvC,QAAM,CAACN,MAAMS,OAAAA,IAAWH,SAASL,cAAAA;AAGjCS,YAAU,MAAA;AACRD,YAAQR,cAAAA;EACV,GAAG;IAACA;GAAe;AAGnBS,YAAU,MAAA;AACRF,YAAQR,OAAO,gBAAgBH,OAAAA;AAC/BQ,gBAAY,CAACM,QAAQA,MAAM,CAAA;EAC7B,GAAG;IAACX;GAAK;AAKT,QAAMY,eAAeC,YAAY,MAAA;AAC/BJ,YAAQ,CAACT,UAAAA;AACPG,qBAAe,CAACH,KAAAA;AAChB,aAAO,CAACA;IACV,CAAA;EACF,GAAG,CAAA,CAAE;AAEL,SACE,sBAAA,cAACc,OAAAA;IAAIC,MAAK;IAAOC,WAAU;IAAwDC,oBAAiB;KAClG,sBAAA,cAACC,OAAOC,SAAO;IACbC,YAAW;IACXC,iBAAAA;IACC,GAAGC;IACJC,OAAO;MACL,GAAGC,UAAUjB,MAAM,YAAY,IAAA;MAC/BkB,cAAc;IAChB;IACAC,mBAAmB/B;KAEnB,sBAAA,cAACgC,cAAAA;IACChB,KAAKP;IACLwB,MAAK;IACLC,aAAY;IACZhC;IACAiC,cAAcjC;IACdkC,cAAa;IACbC,cAAcxB;MAGhB,sBAAA,cAACyB,cAAAA;IAAajC;IAAYE;IAAcgC,UAAUtB;MAEjDb,QAAAA,CAAAA;AAIT;AAKA,IAAMkC,eAAe,CAAC,EAAEjC,MAAME,OAAOgC,SAAQ,MAA4D;AACvG,SACE,sBAAA,cAACpB,OAAAA;IAAIE,WAAU;KACb,sBAAA,cAACF,OAAAA;IAAIE,WAAU;KACb,sBAAA,cAACE,OAAOiB,OAAK,MACX,sBAAA,cAACC,MAAAA;IAAKC,MAAK;QAGf,sBAAA,cAACvB,OAAAA;IAAIE,WAAU;KACb,sBAAA,cAACE,OAAOoB,OAAK;IAAClB,YAAW;KAA4ClB,KAAAA,CAAAA,GAEvE,sBAAA,cAACY,OAAAA;IAAIE,WAAU;KACb,sBAAA,cAACuB,YAAAA;IACCC,SAAQ;IACRH,MAAM;IACNjB,YAAYqB,GAAG,2CAA2CzC,QAAQ,oBAAA;IAClE0C,UAAAA;IACAC,OAAM;IACNC,SAASV;;AAKnB;;;ADvFO,IAAMW,kBAA6C,CAAC,EAAEC,KAAI,MAAE;AACjE,QAAM,EAAEC,EAAC,IAAKC,eAAeC,gBAAAA;AAC7B,QAAMC,gBAAgBC,gBAAgBC,0BAA0BC,WAAW,EAAEC,SAAS;AACtF,QAAMC,WAAWC,cAAcC,aAAaC,aAAa,EAAEC,SAAiCV,gBAAAA,GAAmBW;AAG/G,QAAM,CAACC,MAAMC,OAAAA,IAAWC,UAAS,KAAA;AAEjC,SACE,gBAAAC,OAAA,cAACC,eAAAA;IAAcJ;IAAYK,cAAcJ;IAASK,OAAOpB,EAAE,wBAAA;KACzD,gBAAAiB,OAAA,cAACI,iBAAAA;IACCtB;IACAoB,cAAcJ;IACdP;IACAc,MAAM;IACNnB;;AAIR;AAEA,IAAA,0BAAeL;",
6
+ "names": ["React", "useState", "useCapability", "Capabilities", "useCapabilities", "TranscriptionCapabilities", "useTranslation", "React", "useCallback", "useEffect", "useState", "Dialog", "Icon", "IconButton", "resizeAttributes", "ResizeHandle", "sizeStyle", "mx", "preventDefault", "event", "minSize", "AmbientDialog", "children", "open", "controlledOpen", "title", "onOpenChange", "resizeKey", "setReizeKey", "useState", "size", "setSize", "setOpen", "useEffect", "key", "handleToggle", "useCallback", "div", "role", "className", "data-block-align", "Dialog", "Content", "classNames", "inOverlayLayout", "resizeAttributes", "style", "sizeStyle", "maxBlockSize", "onInteractOutside", "ResizeHandle", "side", "defaultSize", "fallbackSize", "iconPosition", "onSizeChange", "DialogHeader", "onToggle", "Close", "Icon", "icon", "Title", "IconButton", "variant", "mx", "iconOnly", "label", "onClick", "AssistantDialog", "chat", "t", "useTranslation", "ASSISTANT_PLUGIN", "transcription", "useCapabilities", "TranscriptionCapabilities", "Transcriber", "length", "settings", "useCapability", "Capabilities", "SettingsStore", "getStore", "value", "open", "setOpen", "useState", "React", "AmbientDialog", "onOpenChange", "title", "ThreadContainer", "part"]
7
+ }
@@ -1,29 +1,29 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  ThreadContainer
4
- } from "./chunk-E44GXXNE.mjs";
5
- import "./chunk-ICQN3TDS.mjs";
6
- import "./chunk-LELXJPGJ.mjs";
4
+ } from "./chunk-MVDAY3CZ.mjs";
5
+ import "./chunk-6JK5HEUQ.mjs";
6
+ import "./chunk-MXK2EANZ.mjs";
7
7
  import {
8
8
  ASSISTANT_PLUGIN
9
- } from "./chunk-7SV6X6XU.mjs";
9
+ } from "./chunk-ECRK6TUQ.mjs";
10
10
 
11
- // packages/plugins/experimental/plugin-assistant/src/components/ChatContainer.tsx
11
+ // packages/plugins/plugin-assistant/src/components/ChatContainer.tsx
12
12
  import React from "react";
13
13
  import { Capabilities, useCapabilities, useCapability } from "@dxos/app-framework";
14
14
  import { TranscriptionCapabilities } from "@dxos/plugin-transcription";
15
15
  import { StackItem } from "@dxos/react-ui-stack";
16
- var ChatContainer = ({ chat, role }) => {
17
- const transcription = useCapabilities(TranscriptionCapabilities.Transcription).length > 0;
16
+ var ChatContainer = ({ role, chat, associatedArtifact }) => {
17
+ const transcription = useCapabilities(TranscriptionCapabilities.Transcriber).length > 0;
18
18
  const settings = useCapability(Capabilities.SettingsStore).getStore(ASSISTANT_PLUGIN)?.value;
19
19
  return /* @__PURE__ */ React.createElement(StackItem.Content, {
20
- toolbar: false,
21
20
  role,
22
- classNames: "mli-auto w-full max-w-[50rem]"
21
+ classNames: "container-max-width"
23
22
  }, /* @__PURE__ */ React.createElement(ThreadContainer, {
24
23
  chat,
25
24
  settings,
26
- transcription
25
+ transcription,
26
+ associatedArtifact
27
27
  }));
28
28
  };
29
29
  var ChatContainer_default = ChatContainer;
@@ -31,4 +31,4 @@ export {
31
31
  ChatContainer,
32
32
  ChatContainer_default as default
33
33
  };
34
- //# sourceMappingURL=ChatContainer-H4X734PB.mjs.map
34
+ //# sourceMappingURL=ChatContainer-QW3OOXTT.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/ChatContainer.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, useCapabilities, useCapability } from '@dxos/app-framework';\nimport { type AssociatedArtifact } from '@dxos/artifact';\nimport { TranscriptionCapabilities } from '@dxos/plugin-transcription';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { ThreadContainer } from './Thread';\nimport { ASSISTANT_PLUGIN } from '../meta';\nimport { type AssistantSettingsProps, type AIChatType } from '../types';\n\n// TODO(burdon): Attention.\nexport const ChatContainer = ({\n role,\n chat,\n associatedArtifact,\n}: {\n role: string;\n chat: AIChatType;\n associatedArtifact?: AssociatedArtifact;\n}) => {\n const transcription = useCapabilities(TranscriptionCapabilities.Transcriber).length > 0;\n const settings = useCapability(Capabilities.SettingsStore).getStore<AssistantSettingsProps>(ASSISTANT_PLUGIN)?.value;\n\n return (\n <StackItem.Content role={role} classNames='container-max-width'>\n <ThreadContainer\n chat={chat}\n settings={settings}\n transcription={transcription}\n associatedArtifact={associatedArtifact}\n />\n </StackItem.Content>\n );\n};\n\nexport default ChatContainer;\n"],
5
+ "mappings": ";;;;;;;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,cAAcC,iBAAiBC,qBAAqB;AAE7D,SAASC,iCAAiC;AAC1C,SAASC,iBAAiB;AAOnB,IAAMC,gBAAgB,CAAC,EAC5BC,MACAC,MACAC,mBAAkB,MAKnB;AACC,QAAMC,gBAAgBC,gBAAgBC,0BAA0BC,WAAW,EAAEC,SAAS;AACtF,QAAMC,WAAWC,cAAcC,aAAaC,aAAa,EAAEC,SAAiCC,gBAAAA,GAAmBC;AAE/G,SACE,sBAAA,cAACC,UAAUC,SAAO;IAAChB;IAAYiB,YAAW;KACxC,sBAAA,cAACC,iBAAAA;IACCjB;IACAO;IACAL;IACAD;;AAIR;AAEA,IAAA,wBAAeH;",
6
+ "names": ["React", "Capabilities", "useCapabilities", "useCapability", "TranscriptionCapabilities", "StackItem", "ChatContainer", "role", "chat", "associatedArtifact", "transcription", "useCapabilities", "TranscriptionCapabilities", "Transcriber", "length", "settings", "useCapability", "Capabilities", "SettingsStore", "getStore", "ASSISTANT_PLUGIN", "value", "StackItem", "Content", "classNames", "ThreadContainer"]
7
+ }
@@ -0,0 +1,79 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ TemplateEditor
4
+ } from "./chunk-PBZA7XJR.mjs";
5
+ import {
6
+ TemplateKinds
7
+ } from "./chunk-MXK2EANZ.mjs";
8
+ import {
9
+ ASSISTANT_PLUGIN
10
+ } from "./chunk-ECRK6TUQ.mjs";
11
+
12
+ // packages/plugins/plugin-assistant/src/components/TemplateContainer.tsx
13
+ import { Match } from "effect";
14
+ import React, { useCallback } from "react";
15
+ import { debounce } from "@dxos/async";
16
+ import { Input, Select, Toolbar, useTranslation } from "@dxos/react-ui";
17
+ import { StackItem } from "@dxos/react-ui-stack";
18
+ var TemplateContainer = ({ template, role }) => {
19
+ const { t } = useTranslation(ASSISTANT_PLUGIN);
20
+ const handleKindChange = useCallback((value) => {
21
+ const kind = Match.type().pipe(Match.withReturnType(), Match.when("always", () => ({
22
+ include: "always"
23
+ })), Match.when("schema-matching", () => ({
24
+ include: "schema-matching",
25
+ typename: ""
26
+ })), Match.when("automatically", () => ({
27
+ include: "automatically",
28
+ description: ""
29
+ })), Match.orElse(() => ({
30
+ include: "manual"
31
+ })))(value);
32
+ template.kind = kind;
33
+ }, [
34
+ template
35
+ ]);
36
+ const handleTypenameChange = useCallback(debounce((event) => {
37
+ if (template.kind.include === "schema-matching") {
38
+ template.kind.typename = event.target.value;
39
+ }
40
+ }, 300), [
41
+ template.kind.include
42
+ ]);
43
+ const handleDescriptionChange = useCallback(debounce((event) => {
44
+ if (template.kind.include === "automatically") {
45
+ template.kind.description = event.target.value;
46
+ }
47
+ }, 300), [
48
+ template.kind.include
49
+ ]);
50
+ return /* @__PURE__ */ React.createElement(StackItem.Content, {
51
+ role,
52
+ toolbar: true,
53
+ classNames: "container-max-width"
54
+ }, /* @__PURE__ */ React.createElement(Toolbar.Root, null, /* @__PURE__ */ React.createElement(Select.Root, {
55
+ value: template.kind.include,
56
+ onValueChange: handleKindChange
57
+ }, /* @__PURE__ */ React.createElement(Toolbar.Button, {
58
+ asChild: true
59
+ }, /* @__PURE__ */ React.createElement(Select.TriggerButton, null)), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, TemplateKinds.map((kind) => /* @__PURE__ */ React.createElement(Select.Option, {
60
+ key: kind,
61
+ value: kind
62
+ }, kind)))))), template.kind.include === "schema-matching" && /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.TextInput, {
63
+ placeholder: t("typename placeholder"),
64
+ defaultValue: template.kind.typename,
65
+ onChange: handleTypenameChange
66
+ })), template.kind.include === "automatically" && /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.TextInput, {
67
+ placeholder: t("description placeholder"),
68
+ defaultValue: template.kind.description,
69
+ onChange: handleDescriptionChange
70
+ }))), /* @__PURE__ */ React.createElement(TemplateEditor, {
71
+ template
72
+ }));
73
+ };
74
+ var TemplateContainer_default = TemplateContainer;
75
+ export {
76
+ TemplateContainer,
77
+ TemplateContainer_default as default
78
+ };
79
+ //# sourceMappingURL=TemplateContainer-EUM2X65J.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/TemplateContainer.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Match, type Schema as S } from 'effect';\nimport React, { type ChangeEvent, useCallback } from 'react';\n\nimport { debounce } from '@dxos/async';\nimport { Input, Select, Toolbar, useTranslation } from '@dxos/react-ui';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { TemplateEditor } from './TemplateEditor';\nimport { ASSISTANT_PLUGIN } from '../meta';\nimport { TemplateKinds, type TemplateKindSchema, type TemplateType } from '../types';\n\nexport const TemplateContainer = ({ template, role }: { template: TemplateType; role: string }) => {\n const { t } = useTranslation(ASSISTANT_PLUGIN);\n\n const handleKindChange = useCallback(\n (value: string) => {\n const kind = Match.type<string>().pipe(\n Match.withReturnType<S.Schema.Type<typeof TemplateKindSchema>>(),\n Match.when('always', () => ({ include: 'always' })),\n Match.when('schema-matching', () => ({ include: 'schema-matching', typename: '' })),\n Match.when('automatically', () => ({ include: 'automatically', description: '' })),\n Match.orElse(() => ({ include: 'manual' })),\n )(value);\n\n template.kind = kind;\n },\n [template],\n );\n\n const handleTypenameChange = useCallback(\n debounce((event: ChangeEvent<HTMLInputElement>) => {\n if (template.kind.include === 'schema-matching') {\n template.kind.typename = event.target.value;\n }\n }, 300),\n [template.kind.include],\n );\n\n const handleDescriptionChange = useCallback(\n debounce((event: ChangeEvent<HTMLInputElement>) => {\n if (template.kind.include === 'automatically') {\n template.kind.description = event.target.value;\n }\n }, 300),\n [template.kind.include],\n );\n\n return (\n <StackItem.Content role={role} toolbar classNames='container-max-width'>\n {/* TODO(wittjosiah): Move this toolbar into c11y sidebar. */}\n <Toolbar.Root>\n <Select.Root value={template.kind.include} onValueChange={handleKindChange}>\n <Toolbar.Button asChild>\n <Select.TriggerButton />\n </Toolbar.Button>\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {TemplateKinds.map((kind) => (\n <Select.Option key={kind} value={kind}>\n {kind}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n {template.kind.include === 'schema-matching' && (\n <Input.Root>\n <Input.TextInput\n placeholder={t('typename placeholder')}\n defaultValue={template.kind.typename}\n onChange={handleTypenameChange}\n />\n </Input.Root>\n )}\n {template.kind.include === 'automatically' && (\n <Input.Root>\n <Input.TextInput\n placeholder={t('description placeholder')}\n defaultValue={template.kind.description}\n onChange={handleDescriptionChange}\n />\n </Input.Root>\n )}\n </Toolbar.Root>\n <TemplateEditor template={template} />\n </StackItem.Content>\n );\n};\n\nexport default TemplateContainer;\n"],
5
+ "mappings": ";;;;;;;;;;;;AAIA,SAASA,aAA+B;AACxC,OAAOC,SAA2BC,mBAAmB;AAErD,SAASC,gBAAgB;AACzB,SAASC,OAAOC,QAAQC,SAASC,sBAAsB;AACvD,SAASC,iBAAiB;AAMnB,IAAMC,oBAAoB,CAAC,EAAEC,UAAUC,KAAI,MAA4C;AAC5F,QAAM,EAAEC,EAAC,IAAKC,eAAeC,gBAAAA;AAE7B,QAAMC,mBAAmBC,YACvB,CAACC,UAAAA;AACC,UAAMC,OAAOC,MAAMC,KAAI,EAAWC,KAChCF,MAAMG,eAAc,GACpBH,MAAMI,KAAK,UAAU,OAAO;MAAEC,SAAS;IAAS,EAAA,GAChDL,MAAMI,KAAK,mBAAmB,OAAO;MAAEC,SAAS;MAAmBC,UAAU;IAAG,EAAA,GAChFN,MAAMI,KAAK,iBAAiB,OAAO;MAAEC,SAAS;MAAiBE,aAAa;IAAG,EAAA,GAC/EP,MAAMQ,OAAO,OAAO;MAAEH,SAAS;IAAS,EAAA,CAAA,EACxCP,KAAAA;AAEFP,aAASQ,OAAOA;EAClB,GACA;IAACR;GAAS;AAGZ,QAAMkB,uBAAuBZ,YAC3Ba,SAAS,CAACC,UAAAA;AACR,QAAIpB,SAASQ,KAAKM,YAAY,mBAAmB;AAC/Cd,eAASQ,KAAKO,WAAWK,MAAMC,OAAOd;IACxC;EACF,GAAG,GAAA,GACH;IAACP,SAASQ,KAAKM;GAAQ;AAGzB,QAAMQ,0BAA0BhB,YAC9Ba,SAAS,CAACC,UAAAA;AACR,QAAIpB,SAASQ,KAAKM,YAAY,iBAAiB;AAC7Cd,eAASQ,KAAKQ,cAAcI,MAAMC,OAAOd;IAC3C;EACF,GAAG,GAAA,GACH;IAACP,SAASQ,KAAKM;GAAQ;AAGzB,SACE,sBAAA,cAACS,UAAUC,SAAO;IAACvB;IAAYwB,SAAAA;IAAQC,YAAW;KAEhD,sBAAA,cAACC,QAAQC,MAAI,MACX,sBAAA,cAACC,OAAOD,MAAI;IAACrB,OAAOP,SAASQ,KAAKM;IAASgB,eAAezB;KACxD,sBAAA,cAACsB,QAAQI,QAAM;IAACC,SAAAA;KACd,sBAAA,cAACH,OAAOI,eAAa,IAAA,CAAA,GAEvB,sBAAA,cAACJ,OAAOK,QAAM,MACZ,sBAAA,cAACL,OAAOL,SAAO,MACb,sBAAA,cAACK,OAAOM,UAAQ,MACbC,cAAcC,IAAI,CAAC7B,SAClB,sBAAA,cAACqB,OAAOS,QAAM;IAACC,KAAK/B;IAAMD,OAAOC;KAC9BA,IAAAA,CAAAA,CAAAA,CAAAA,CAAAA,CAAAA,GAOZR,SAASQ,KAAKM,YAAY,qBACzB,sBAAA,cAAC0B,MAAMZ,MAAI,MACT,sBAAA,cAACY,MAAMC,WAAS;IACdC,aAAaxC,EAAE,sBAAA;IACfyC,cAAc3C,SAASQ,KAAKO;IAC5B6B,UAAU1B;OAIflB,SAASQ,KAAKM,YAAY,mBACzB,sBAAA,cAAC0B,MAAMZ,MAAI,MACT,sBAAA,cAACY,MAAMC,WAAS;IACdC,aAAaxC,EAAE,yBAAA;IACfyC,cAAc3C,SAASQ,KAAKQ;IAC5B4B,UAAUtB;QAKlB,sBAAA,cAACuB,gBAAAA;IAAe7C;;AAGtB;AAEA,IAAA,4BAAeD;",
6
+ "names": ["Match", "React", "useCallback", "debounce", "Input", "Select", "Toolbar", "useTranslation", "StackItem", "TemplateContainer", "template", "role", "t", "useTranslation", "ASSISTANT_PLUGIN", "handleKindChange", "useCallback", "value", "kind", "Match", "type", "pipe", "withReturnType", "when", "include", "typename", "description", "orElse", "handleTypenameChange", "debounce", "event", "target", "handleDescriptionChange", "StackItem", "Content", "toolbar", "classNames", "Toolbar", "Root", "Select", "onValueChange", "Button", "asChild", "TriggerButton", "Portal", "Viewport", "TemplateKinds", "map", "Option", "key", "Input", "TextInput", "placeholder", "defaultValue", "onChange", "TemplateEditor"]
7
+ }
@@ -0,0 +1,36 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ AssistantCapabilities
4
+ } from "./chunk-6JK5HEUQ.mjs";
5
+ import {
6
+ ASSISTANT_PLUGIN
7
+ } from "./chunk-ECRK6TUQ.mjs";
8
+
9
+ // packages/plugins/plugin-assistant/src/capabilities/ai-client.ts
10
+ import { effect, signal } from "@preact/signals-core";
11
+ import { Capabilities, contributes } from "@dxos/app-framework";
12
+ import { AIServiceEdgeClient, OllamaClient } from "@dxos/assistant";
13
+ import { ClientCapabilities } from "@dxos/plugin-client";
14
+ var DEFAULT_AI_SERVICE_URL = "http://localhost:8788";
15
+ var ai_client_default = (context) => {
16
+ const client = context.requestCapability(ClientCapabilities.Client);
17
+ const endpoint = client.config.values.runtime?.services?.ai?.server ?? DEFAULT_AI_SERVICE_URL;
18
+ const ai = signal(new AIServiceEdgeClient({
19
+ endpoint
20
+ }));
21
+ const unsubscribe = effect(() => {
22
+ const settings = context.requestCapability(Capabilities.SettingsStore).getStore(ASSISTANT_PLUGIN)?.value;
23
+ if (settings?.llmProvider === "ollama") {
24
+ ai.value = new OllamaClient();
25
+ } else {
26
+ ai.value = new AIServiceEdgeClient({
27
+ endpoint
28
+ });
29
+ }
30
+ });
31
+ return contributes(AssistantCapabilities.AiClient, ai, () => unsubscribe());
32
+ };
33
+ export {
34
+ ai_client_default as default
35
+ };
36
+ //# sourceMappingURL=ai-client-WMHS5EGV.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/ai-client.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { effect, signal } from '@preact/signals-core';\n\nimport { Capabilities, contributes, type PluginsContext } from '@dxos/app-framework';\nimport { type AIServiceClient, AIServiceEdgeClient, OllamaClient } from '@dxos/assistant';\nimport { ClientCapabilities } from '@dxos/plugin-client';\n\nimport { AssistantCapabilities } from './capabilities';\nimport { ASSISTANT_PLUGIN } from '../meta';\nimport { type AssistantSettingsProps } from '../types';\n\n// TODO(wittjosiah): Factor out.\nconst DEFAULT_AI_SERVICE_URL = 'http://localhost:8788';\n\nexport default (context: PluginsContext) => {\n const client = context.requestCapability(ClientCapabilities.Client);\n const endpoint = client.config.values.runtime?.services?.ai?.server ?? DEFAULT_AI_SERVICE_URL;\n\n const ai = signal<AIServiceClient>(new AIServiceEdgeClient({ endpoint }));\n\n const unsubscribe = effect(() => {\n // TODO(burdon): Could be undefined.\n const settings = context\n .requestCapability(Capabilities.SettingsStore)\n .getStore<AssistantSettingsProps>(ASSISTANT_PLUGIN)?.value;\n\n if (settings?.llmProvider === 'ollama') {\n ai.value = new OllamaClient();\n } else {\n ai.value = new AIServiceEdgeClient({ endpoint });\n }\n });\n\n return contributes(AssistantCapabilities.AiClient, ai, () => unsubscribe());\n};\n"],
5
+ "mappings": ";;;;;;;;;AAIA,SAASA,QAAQC,cAAc;AAE/B,SAASC,cAAcC,mBAAwC;AAC/D,SAA+BC,qBAAqBC,oBAAoB;AACxE,SAASC,0BAA0B;AAOnC,IAAMC,yBAAyB;AAE/B,IAAA,oBAAe,CAACC,YAAAA;AACd,QAAMC,SAASD,QAAQE,kBAAkBC,mBAAmBC,MAAM;AAClE,QAAMC,WAAWJ,OAAOK,OAAOC,OAAOC,SAASC,UAAUC,IAAIC,UAAUZ;AAEvE,QAAMW,KAAKE,OAAwB,IAAIC,oBAAoB;IAAER;EAAS,CAAA,CAAA;AAEtE,QAAMS,cAAcC,OAAO,MAAA;AAEzB,UAAMC,WAAWhB,QACdE,kBAAkBe,aAAaC,aAAa,EAC5CC,SAAiCC,gBAAAA,GAAmBC;AAEvD,QAAIL,UAAUM,gBAAgB,UAAU;AACtCZ,SAAGW,QAAQ,IAAIE,aAAAA;IACjB,OAAO;AACLb,SAAGW,QAAQ,IAAIR,oBAAoB;QAAER;MAAS,CAAA;IAChD;EACF,CAAA;AAEA,SAAOmB,YAAYC,sBAAsBC,UAAUhB,IAAI,MAAMI,YAAAA,CAAAA;AAC/D;",
6
+ "names": ["effect", "signal", "Capabilities", "contributes", "AIServiceEdgeClient", "OllamaClient", "ClientCapabilities", "DEFAULT_AI_SERVICE_URL", "context", "client", "requestCapability", "ClientCapabilities", "Client", "endpoint", "config", "values", "runtime", "services", "ai", "server", "signal", "AIServiceEdgeClient", "unsubscribe", "effect", "settings", "Capabilities", "SettingsStore", "getStore", "ASSISTANT_PLUGIN", "value", "llmProvider", "OllamaClient", "contributes", "AssistantCapabilities", "AiClient"]
7
+ }
@@ -0,0 +1,210 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ AIChatType,
4
+ AssistantAction,
5
+ TemplateType
6
+ } from "./chunk-MXK2EANZ.mjs";
7
+ import {
8
+ ASSISTANT_DIALOG,
9
+ ASSISTANT_PLUGIN
10
+ } from "./chunk-ECRK6TUQ.mjs";
11
+
12
+ // packages/plugins/plugin-assistant/src/capabilities/app-graph-builder.ts
13
+ import { Capabilities, contributes, createIntent, LayoutAction } from "@dxos/app-framework";
14
+ import { invariant } from "@dxos/invariant";
15
+ import { ClientCapabilities } from "@dxos/plugin-client";
16
+ import { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR, DECK_COMPANION_TYPE } from "@dxos/plugin-deck/types";
17
+ import { createExtension, ROOT_ID } from "@dxos/plugin-graph";
18
+ import { memoizeQuery } from "@dxos/plugin-space";
19
+ import { SpaceAction } from "@dxos/plugin-space/types";
20
+ import { Filter, fullyQualifiedId, getSpace, isSpace, isReactiveObject, parseId } from "@dxos/react-client/echo";
21
+ var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-assistant/src/capabilities/app-graph-builder.ts";
22
+ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
23
+ createExtension({
24
+ id: `${ASSISTANT_PLUGIN}/assistant`,
25
+ filter: (node) => node.id === ROOT_ID,
26
+ actions: () => [
27
+ {
28
+ id: `${LayoutAction.UpdateDialog._tag}/assistant/open`,
29
+ data: async () => {
30
+ const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
31
+ const client = context.requestCapability(ClientCapabilities.Client);
32
+ const layout = context.requestCapability(Capabilities.Layout);
33
+ const { graph } = context.requestCapability(Capabilities.AppGraph);
34
+ let chat;
35
+ if (layout.active.length > 0) {
36
+ const node = graph.findNode(layout.active[0]);
37
+ if (node) {
38
+ const space = getSpace(node.data);
39
+ if (space) {
40
+ chat = await getOrCreateChat(dispatch, space);
41
+ }
42
+ }
43
+ } else {
44
+ const space = client.spaces.default;
45
+ chat = await getOrCreateChat(dispatch, space);
46
+ }
47
+ if (!chat) {
48
+ return;
49
+ }
50
+ await dispatch(createIntent(LayoutAction.UpdateDialog, {
51
+ part: "dialog",
52
+ subject: ASSISTANT_DIALOG,
53
+ options: {
54
+ state: true,
55
+ blockAlign: "end",
56
+ props: {
57
+ chat
58
+ }
59
+ }
60
+ }));
61
+ },
62
+ properties: {
63
+ label: [
64
+ "open assistant label",
65
+ {
66
+ ns: ASSISTANT_PLUGIN
67
+ }
68
+ ],
69
+ icon: "ph--star-four--regular",
70
+ disposition: "pin-end",
71
+ position: "hoist",
72
+ keyBinding: {
73
+ macos: "shift+meta+k",
74
+ windows: "shift+ctrl+k"
75
+ }
76
+ }
77
+ }
78
+ ]
79
+ }),
80
+ createExtension({
81
+ id: `${ASSISTANT_PLUGIN}/service-registry`,
82
+ filter: (node) => node.id === "root",
83
+ connector: ({ node }) => {
84
+ const layout = context.requestCapability(Capabilities.Layout);
85
+ const client = context.requestCapability(ClientCapabilities.Client);
86
+ const { spaceId } = parseId(layout.workspace);
87
+ const space = spaceId ? client.spaces.get(spaceId) : null;
88
+ return [
89
+ {
90
+ id: [
91
+ node.id,
92
+ "service-registry"
93
+ ].join(ATTENDABLE_PATH_SEPARATOR),
94
+ type: DECK_COMPANION_TYPE,
95
+ data: space,
96
+ properties: {
97
+ label: [
98
+ "service registry label",
99
+ {
100
+ ns: ASSISTANT_PLUGIN
101
+ }
102
+ ],
103
+ icon: "ph--plugs--regular",
104
+ disposition: "hidden"
105
+ }
106
+ }
107
+ ];
108
+ }
109
+ }),
110
+ createExtension({
111
+ id: `${ASSISTANT_PLUGIN}/object-chat-companion`,
112
+ filter: (node) => isReactiveObject(node.data) && node.data.assistantChatQueue && node.data.type !== AIChatType.typename,
113
+ connector: ({ node }) => [
114
+ {
115
+ id: [
116
+ node.id,
117
+ "assistant-chat"
118
+ ].join(ATTENDABLE_PATH_SEPARATOR),
119
+ type: PLANK_COMPANION_TYPE,
120
+ data: "assistant-chat",
121
+ properties: {
122
+ label: [
123
+ "assistant chat label",
124
+ {
125
+ ns: ASSISTANT_PLUGIN
126
+ }
127
+ ],
128
+ icon: "ph--star-four--regular",
129
+ position: "hoist"
130
+ }
131
+ }
132
+ ]
133
+ }),
134
+ createExtension({
135
+ id: `${ASSISTANT_PLUGIN}/root`,
136
+ filter: (node) => isSpace(node.data),
137
+ connector: ({ node }) => {
138
+ const templates = memoizeQuery(node.data, Filter.schema(TemplateType));
139
+ return templates.length > 0 ? [
140
+ {
141
+ id: `${ASSISTANT_PLUGIN}/templates`,
142
+ type: `${ASSISTANT_PLUGIN}/templates`,
143
+ data: null,
144
+ properties: {
145
+ label: [
146
+ "templates label",
147
+ {
148
+ ns: ASSISTANT_PLUGIN
149
+ }
150
+ ],
151
+ icon: "ph--file-code--regular",
152
+ space: node.data
153
+ }
154
+ }
155
+ ] : [];
156
+ }
157
+ }),
158
+ createExtension({
159
+ id: `${ASSISTANT_PLUGIN}/templates`,
160
+ filter: (node) => node.id === `${ASSISTANT_PLUGIN}/templates`,
161
+ connector: ({ node }) => {
162
+ const templates = memoizeQuery(node.properties.space, Filter.schema(TemplateType));
163
+ return templates.toSorted((a, b) => {
164
+ const nameA = a.name ?? "";
165
+ const nameB = b.name ?? "";
166
+ return nameA.localeCompare(nameB);
167
+ }).map((template) => ({
168
+ id: fullyQualifiedId(template),
169
+ type: `${ASSISTANT_PLUGIN}/template`,
170
+ data: template,
171
+ properties: {
172
+ label: template.name ?? [
173
+ "template title placeholder",
174
+ {
175
+ ns: ASSISTANT_PLUGIN
176
+ }
177
+ ],
178
+ icon: "ph--file-code--regular"
179
+ }
180
+ }));
181
+ }
182
+ })
183
+ ]);
184
+ var getOrCreateChat = async (dispatch, space) => {
185
+ const { objects } = await space.db.query(Filter.schema(AIChatType)).run();
186
+ if (objects.length > 0) {
187
+ return objects[objects.length - 1];
188
+ }
189
+ const { data } = await dispatch(createIntent(AssistantAction.CreateChat, {
190
+ spaceId: space.id
191
+ }));
192
+ invariant(data?.object instanceof AIChatType, void 0, {
193
+ F: __dxlog_file,
194
+ L: 192,
195
+ S: void 0,
196
+ A: [
197
+ "data?.object instanceof AIChatType",
198
+ ""
199
+ ]
200
+ });
201
+ await dispatch(createIntent(SpaceAction.AddObject, {
202
+ target: space,
203
+ object: data.object
204
+ }));
205
+ return data.object;
206
+ };
207
+ export {
208
+ app_graph_builder_default as default
209
+ };
210
+ //# sourceMappingURL=app-graph-builder-DWBNIMHM.mjs.map