@dxos/plugin-automation 0.7.5-labs.c0e040f → 0.7.5-labs.d199c0f

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 (320) hide show
  1. package/dist/lib/browser/AutomationPanel-ITYXSN5Z.mjs +132 -0
  2. package/dist/lib/browser/AutomationPanel-ITYXSN5Z.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-R4JH4TLE.mjs → chunk-OFDNNRLE.mjs} +3 -8
  4. package/dist/lib/browser/chunk-OFDNNRLE.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-U7QLNY2S.mjs +8 -0
  6. package/dist/lib/browser/chunk-U7QLNY2S.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-WY2C7JY4.mjs +119 -0
  8. package/dist/lib/browser/chunk-WY2C7JY4.mjs.map +7 -0
  9. package/dist/lib/browser/complementary-panel-4CPOJL4Y.mjs +56 -0
  10. package/dist/lib/browser/complementary-panel-4CPOJL4Y.mjs.map +7 -0
  11. package/dist/lib/browser/index.mjs +21 -377
  12. package/dist/lib/browser/index.mjs.map +4 -4
  13. package/dist/lib/browser/meta.json +1 -1
  14. package/dist/lib/browser/react-surface-SAPMN4PF.mjs +27 -0
  15. package/dist/lib/browser/react-surface-SAPMN4PF.mjs.map +7 -0
  16. package/dist/lib/node/{chunk-QXIHYOMF.cjs → AutomationPanel-X33HHDMQ.cjs} +19 -132
  17. package/dist/lib/node/AutomationPanel-X33HHDMQ.cjs.map +7 -0
  18. package/dist/lib/node/chunk-7Q5SNGCL.cjs +148 -0
  19. package/dist/lib/node/chunk-7Q5SNGCL.cjs.map +7 -0
  20. package/dist/lib/node/chunk-CB5OB6JH.cjs +40 -0
  21. package/dist/lib/node/chunk-CB5OB6JH.cjs.map +7 -0
  22. package/dist/lib/node/{chunk-EQYHOTGG.cjs → chunk-ORMEYEBE.cjs} +6 -12
  23. package/dist/lib/node/chunk-ORMEYEBE.cjs.map +7 -0
  24. package/dist/lib/node/complementary-panel-ZYJJ42ZU.cjs +72 -0
  25. package/dist/lib/node/complementary-panel-ZYJJ42ZU.cjs.map +7 -0
  26. package/dist/lib/node/index.cjs +36 -378
  27. package/dist/lib/node/index.cjs.map +4 -4
  28. package/dist/lib/node/meta.json +1 -1
  29. package/dist/lib/node/{react-surface-JT6SVCPK.cjs → react-surface-2WRVAPGR.cjs} +9 -34
  30. package/dist/lib/node/react-surface-2WRVAPGR.cjs.map +7 -0
  31. package/dist/lib/node-esm/AutomationPanel-HY3GB4BT.mjs +133 -0
  32. package/dist/lib/node-esm/AutomationPanel-HY3GB4BT.mjs.map +7 -0
  33. package/dist/lib/node-esm/{chunk-EMVA6QUT.mjs → chunk-6MUUH67V.mjs} +3 -8
  34. package/dist/lib/node-esm/chunk-6MUUH67V.mjs.map +7 -0
  35. package/dist/lib/node-esm/chunk-R3P2WPBQ.mjs +10 -0
  36. package/dist/lib/node-esm/chunk-R3P2WPBQ.mjs.map +7 -0
  37. package/dist/lib/node-esm/chunk-UDD2VA6G.mjs +120 -0
  38. package/dist/lib/node-esm/chunk-UDD2VA6G.mjs.map +7 -0
  39. package/dist/lib/node-esm/complementary-panel-S42RIIAY.mjs +57 -0
  40. package/dist/lib/node-esm/complementary-panel-S42RIIAY.mjs.map +7 -0
  41. package/dist/lib/node-esm/index.mjs +21 -377
  42. package/dist/lib/node-esm/index.mjs.map +4 -4
  43. package/dist/lib/node-esm/meta.json +1 -1
  44. package/dist/lib/node-esm/react-surface-QWLPOYXO.mjs +28 -0
  45. package/dist/lib/node-esm/react-surface-QWLPOYXO.mjs.map +7 -0
  46. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  47. package/dist/types/src/capabilities/{ai-client.d.ts → complementary-panel.d.ts} +2 -3
  48. package/dist/types/src/capabilities/complementary-panel.d.ts.map +1 -0
  49. package/dist/types/src/capabilities/index.d.ts +1 -180
  50. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  51. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  52. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -2
  53. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  54. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  55. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -2
  56. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  57. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  58. package/dist/types/src/components/index.d.ts +1 -12
  59. package/dist/types/src/components/index.d.ts.map +1 -1
  60. package/dist/types/src/index.d.ts +1 -3
  61. package/dist/types/src/index.d.ts.map +1 -1
  62. package/dist/types/src/meta.d.ts +0 -2
  63. package/dist/types/src/meta.d.ts.map +1 -1
  64. package/dist/types/src/testing/index.d.ts +0 -1
  65. package/dist/types/src/testing/index.d.ts.map +1 -1
  66. package/dist/types/src/testing/test-functions.d.ts +0 -2
  67. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  68. package/dist/types/src/translations.d.ts +1 -94
  69. package/dist/types/src/translations.d.ts.map +1 -1
  70. package/package.json +23 -74
  71. package/src/AutomationPlugin.tsx +9 -64
  72. package/src/capabilities/complementary-panel.ts +56 -0
  73. package/src/capabilities/index.ts +1 -5
  74. package/src/capabilities/react-surface.tsx +3 -23
  75. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +1 -2
  76. package/src/components/AutomationPanel/AutomationPanel.tsx +56 -49
  77. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +1 -2
  78. package/src/components/index.ts +0 -8
  79. package/src/index.ts +2 -3
  80. package/src/meta.ts +1 -4
  81. package/src/testing/index.ts +0 -1
  82. package/src/testing/test-functions.ts +0 -7
  83. package/src/translations.ts +1 -29
  84. package/dist/lib/browser/AutomationPanel-VW2XIUPU.mjs +0 -8
  85. package/dist/lib/browser/AutomationPanel-VW2XIUPU.mjs.map +0 -7
  86. package/dist/lib/browser/ChatContainer-OLRZNGWK.mjs +0 -12
  87. package/dist/lib/browser/ChatContainer-OLRZNGWK.mjs.map +0 -7
  88. package/dist/lib/browser/ai-client-5CNY6JBF.mjs +0 -22
  89. package/dist/lib/browser/ai-client-5CNY6JBF.mjs.map +0 -7
  90. package/dist/lib/browser/app-graph-builder-6H7MDCXE.mjs +0 -197
  91. package/dist/lib/browser/app-graph-builder-6H7MDCXE.mjs.map +0 -7
  92. package/dist/lib/browser/chunk-2H2EUYXL.mjs +0 -15
  93. package/dist/lib/browser/chunk-2H2EUYXL.mjs.map +0 -7
  94. package/dist/lib/browser/chunk-ITG6CBKL.mjs +0 -1602
  95. package/dist/lib/browser/chunk-ITG6CBKL.mjs.map +0 -7
  96. package/dist/lib/browser/chunk-MRBC5J4T.mjs +0 -518
  97. package/dist/lib/browser/chunk-MRBC5J4T.mjs.map +0 -7
  98. package/dist/lib/browser/chunk-NQFZ6XRX.mjs +0 -243
  99. package/dist/lib/browser/chunk-NQFZ6XRX.mjs.map +0 -7
  100. package/dist/lib/browser/chunk-Q4IMHYGH.mjs +0 -150
  101. package/dist/lib/browser/chunk-Q4IMHYGH.mjs.map +0 -7
  102. package/dist/lib/browser/chunk-R4JH4TLE.mjs.map +0 -7
  103. package/dist/lib/browser/intent-resolver-BWAXKT27.mjs +0 -29
  104. package/dist/lib/browser/intent-resolver-BWAXKT27.mjs.map +0 -7
  105. package/dist/lib/browser/react-surface-O6SHIBCA.mjs +0 -58
  106. package/dist/lib/browser/react-surface-O6SHIBCA.mjs.map +0 -7
  107. package/dist/lib/browser/types/index.mjs +0 -24
  108. package/dist/lib/browser/types/index.mjs.map +0 -7
  109. package/dist/lib/node/AutomationPanel-G6EDDYWW.cjs +0 -26
  110. package/dist/lib/node/AutomationPanel-G6EDDYWW.cjs.map +0 -7
  111. package/dist/lib/node/ChatContainer-GRZDJIG5.cjs +0 -33
  112. package/dist/lib/node/ChatContainer-GRZDJIG5.cjs.map +0 -7
  113. package/dist/lib/node/ai-client-FKLPDELV.cjs +0 -38
  114. package/dist/lib/node/ai-client-FKLPDELV.cjs.map +0 -7
  115. package/dist/lib/node/app-graph-builder-7JMJLZIE.cjs +0 -212
  116. package/dist/lib/node/app-graph-builder-7JMJLZIE.cjs.map +0 -7
  117. package/dist/lib/node/chunk-CFBERLTN.cjs +0 -1586
  118. package/dist/lib/node/chunk-CFBERLTN.cjs.map +0 -7
  119. package/dist/lib/node/chunk-EQYHOTGG.cjs.map +0 -7
  120. package/dist/lib/node/chunk-FQUY77HT.cjs +0 -527
  121. package/dist/lib/node/chunk-FQUY77HT.cjs.map +0 -7
  122. package/dist/lib/node/chunk-GB7245FH.cjs +0 -173
  123. package/dist/lib/node/chunk-GB7245FH.cjs.map +0 -7
  124. package/dist/lib/node/chunk-QXIHYOMF.cjs.map +0 -7
  125. package/dist/lib/node/chunk-U5Z7LFWB.cjs +0 -34
  126. package/dist/lib/node/chunk-U5Z7LFWB.cjs.map +0 -7
  127. package/dist/lib/node/intent-resolver-C6OKFVEW.cjs +0 -44
  128. package/dist/lib/node/intent-resolver-C6OKFVEW.cjs.map +0 -7
  129. package/dist/lib/node/react-surface-JT6SVCPK.cjs.map +0 -7
  130. package/dist/lib/node/types/index.cjs +0 -46
  131. package/dist/lib/node/types/index.cjs.map +0 -7
  132. package/dist/lib/node-esm/AutomationPanel-V3IWQAMO.mjs +0 -9
  133. package/dist/lib/node-esm/AutomationPanel-V3IWQAMO.mjs.map +0 -7
  134. package/dist/lib/node-esm/ChatContainer-ORVWQPJO.mjs +0 -13
  135. package/dist/lib/node-esm/ChatContainer-ORVWQPJO.mjs.map +0 -7
  136. package/dist/lib/node-esm/ai-client-XGNA6SJ5.mjs +0 -23
  137. package/dist/lib/node-esm/ai-client-XGNA6SJ5.mjs.map +0 -7
  138. package/dist/lib/node-esm/app-graph-builder-C6NUQGCU.mjs +0 -198
  139. package/dist/lib/node-esm/app-graph-builder-C6NUQGCU.mjs.map +0 -7
  140. package/dist/lib/node-esm/chunk-2OKJZ4ZW.mjs +0 -519
  141. package/dist/lib/node-esm/chunk-2OKJZ4ZW.mjs.map +0 -7
  142. package/dist/lib/node-esm/chunk-6HLBYDUI.mjs +0 -244
  143. package/dist/lib/node-esm/chunk-6HLBYDUI.mjs.map +0 -7
  144. package/dist/lib/node-esm/chunk-7VPT3OO3.mjs +0 -1603
  145. package/dist/lib/node-esm/chunk-7VPT3OO3.mjs.map +0 -7
  146. package/dist/lib/node-esm/chunk-DNCXRGAF.mjs +0 -151
  147. package/dist/lib/node-esm/chunk-DNCXRGAF.mjs.map +0 -7
  148. package/dist/lib/node-esm/chunk-EMVA6QUT.mjs.map +0 -7
  149. package/dist/lib/node-esm/chunk-IJRTDSKN.mjs +0 -16
  150. package/dist/lib/node-esm/chunk-IJRTDSKN.mjs.map +0 -7
  151. package/dist/lib/node-esm/intent-resolver-DCP4ZDBA.mjs +0 -30
  152. package/dist/lib/node-esm/intent-resolver-DCP4ZDBA.mjs.map +0 -7
  153. package/dist/lib/node-esm/react-surface-DSVM33SA.mjs +0 -59
  154. package/dist/lib/node-esm/react-surface-DSVM33SA.mjs.map +0 -7
  155. package/dist/lib/node-esm/types/index.mjs +0 -25
  156. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  157. package/dist/types/src/artifacts.stories.d.ts +0 -16
  158. package/dist/types/src/artifacts.stories.d.ts.map +0 -1
  159. package/dist/types/src/capabilities/ai-client.d.ts.map +0 -1
  160. package/dist/types/src/capabilities/app-graph-builder.d.ts +0 -181
  161. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +0 -1
  162. package/dist/types/src/capabilities/capabilities.d.ts +0 -5
  163. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  164. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  165. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  166. package/dist/types/src/components/AmbientChatDialog/AmbientChatDialog.d.ts +0 -3
  167. package/dist/types/src/components/AmbientChatDialog/AmbientChatDialog.d.ts.map +0 -1
  168. package/dist/types/src/components/AmbientChatDialog/AmbientChatDialog.stories.d.ts +0 -8
  169. package/dist/types/src/components/AmbientChatDialog/AmbientChatDialog.stories.d.ts.map +0 -1
  170. package/dist/types/src/components/AmbientChatDialog/index.d.ts +0 -2
  171. package/dist/types/src/components/AmbientChatDialog/index.d.ts.map +0 -1
  172. package/dist/types/src/components/Box/StatusLine.d.ts +0 -11
  173. package/dist/types/src/components/Box/StatusLine.d.ts.map +0 -1
  174. package/dist/types/src/components/Box/StatusLine.stories.d.ts +0 -9
  175. package/dist/types/src/components/Box/StatusLine.stories.d.ts.map +0 -1
  176. package/dist/types/src/components/Box/Tabbed.d.ts +0 -15
  177. package/dist/types/src/components/Box/Tabbed.d.ts.map +0 -1
  178. package/dist/types/src/components/Box/Tabbed.stories.d.ts +0 -8
  179. package/dist/types/src/components/Box/Tabbed.stories.d.ts.map +0 -1
  180. package/dist/types/src/components/Box/ToggleContainer.d.ts +0 -13
  181. package/dist/types/src/components/Box/ToggleContainer.d.ts.map +0 -1
  182. package/dist/types/src/components/Box/ToggleContainer.stories.d.ts +0 -9
  183. package/dist/types/src/components/Box/ToggleContainer.stories.d.ts.map +0 -1
  184. package/dist/types/src/components/Box/index.d.ts +0 -4
  185. package/dist/types/src/components/Box/index.d.ts.map +0 -1
  186. package/dist/types/src/components/ChatContainer/ChatContainer.d.ts +0 -7
  187. package/dist/types/src/components/ChatContainer/ChatContainer.d.ts.map +0 -1
  188. package/dist/types/src/components/ChatContainer/index.d.ts +0 -4
  189. package/dist/types/src/components/ChatContainer/index.d.ts.map +0 -1
  190. package/dist/types/src/components/MarkdownViewer/MarkdownViewer.d.ts +0 -14
  191. package/dist/types/src/components/MarkdownViewer/MarkdownViewer.d.ts.map +0 -1
  192. package/dist/types/src/components/MarkdownViewer/MarkdownViewer.stories.d.ts +0 -8
  193. package/dist/types/src/components/MarkdownViewer/MarkdownViewer.stories.d.ts.map +0 -1
  194. package/dist/types/src/components/MarkdownViewer/index.d.ts +0 -2
  195. package/dist/types/src/components/MarkdownViewer/index.d.ts.map +0 -1
  196. package/dist/types/src/components/Prompt/Prompt.d.ts +0 -7
  197. package/dist/types/src/components/Prompt/Prompt.d.ts.map +0 -1
  198. package/dist/types/src/components/Prompt/Prompt.stories.d.ts +0 -8
  199. package/dist/types/src/components/Prompt/Prompt.stories.d.ts.map +0 -1
  200. package/dist/types/src/components/Prompt/index.d.ts +0 -2
  201. package/dist/types/src/components/Prompt/index.d.ts.map +0 -1
  202. package/dist/types/src/components/Prompt/prompt-autocomplete.d.ts +0 -20
  203. package/dist/types/src/components/Prompt/prompt-autocomplete.d.ts.map +0 -1
  204. package/dist/types/src/components/PromptEditor/PromptEditor.d.ts +0 -10
  205. package/dist/types/src/components/PromptEditor/PromptEditor.d.ts.map +0 -1
  206. package/dist/types/src/components/PromptEditor/PromptEditor.stories.d.ts +0 -6
  207. package/dist/types/src/components/PromptEditor/PromptEditor.stories.d.ts.map +0 -1
  208. package/dist/types/src/components/PromptEditor/index.d.ts +0 -2
  209. package/dist/types/src/components/PromptEditor/index.d.ts.map +0 -1
  210. package/dist/types/src/components/PromptEditor/prompt-extension.d.ts +0 -4
  211. package/dist/types/src/components/PromptEditor/prompt-extension.d.ts.map +0 -1
  212. package/dist/types/src/components/PromptEditor/types.d.ts +0 -18
  213. package/dist/types/src/components/PromptEditor/types.d.ts.map +0 -1
  214. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.d.ts +0 -6
  215. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.d.ts.map +0 -1
  216. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.stories.d.ts +0 -8
  217. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.stories.d.ts.map +0 -1
  218. package/dist/types/src/components/ServiceRegistry/index.d.ts +0 -2
  219. package/dist/types/src/components/ServiceRegistry/index.d.ts.map +0 -1
  220. package/dist/types/src/components/Thread/Thread.d.ts +0 -11
  221. package/dist/types/src/components/Thread/Thread.d.ts.map +0 -1
  222. package/dist/types/src/components/Thread/Thread.stories.d.ts +0 -11
  223. package/dist/types/src/components/Thread/Thread.stories.d.ts.map +0 -1
  224. package/dist/types/src/components/Thread/ThreadMessage.d.ts +0 -12
  225. package/dist/types/src/components/Thread/ThreadMessage.d.ts.map +0 -1
  226. package/dist/types/src/components/Thread/index.d.ts +0 -2
  227. package/dist/types/src/components/Thread/index.d.ts.map +0 -1
  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/dist/types/src/hooks/index.d.ts +0 -6
  231. package/dist/types/src/hooks/index.d.ts.map +0 -1
  232. package/dist/types/src/hooks/invocation-handler.d.ts +0 -5
  233. package/dist/types/src/hooks/invocation-handler.d.ts.map +0 -1
  234. package/dist/types/src/hooks/processor.d.ts +0 -70
  235. package/dist/types/src/hooks/processor.d.ts.map +0 -1
  236. package/dist/types/src/hooks/processor.test.d.ts +0 -2
  237. package/dist/types/src/hooks/processor.test.d.ts.map +0 -1
  238. package/dist/types/src/hooks/useChatProcessor.d.ts +0 -7
  239. package/dist/types/src/hooks/useChatProcessor.d.ts.map +0 -1
  240. package/dist/types/src/hooks/useLocalTriggerManager.d.ts +0 -3
  241. package/dist/types/src/hooks/useLocalTriggerManager.d.ts.map +0 -1
  242. package/dist/types/src/hooks/useMessageQueue.d.ts +0 -41
  243. package/dist/types/src/hooks/useMessageQueue.d.ts.map +0 -1
  244. package/dist/types/src/hooks/useServices.d.ts +0 -7
  245. package/dist/types/src/hooks/useServices.d.ts.map +0 -1
  246. package/dist/types/src/presets.d.ts +0 -9
  247. package/dist/types/src/presets.d.ts.map +0 -1
  248. package/dist/types/src/testing/test-services.d.ts +0 -5
  249. package/dist/types/src/testing/test-services.d.ts.map +0 -1
  250. package/dist/types/src/tools/function.d.ts +0 -5
  251. package/dist/types/src/tools/function.d.ts.map +0 -1
  252. package/dist/types/src/tools/index.d.ts +0 -3
  253. package/dist/types/src/tools/index.d.ts.map +0 -1
  254. package/dist/types/src/tools/openapi.d.ts +0 -10
  255. package/dist/types/src/tools/openapi.d.ts.map +0 -1
  256. package/dist/types/src/tools/openapi.test.d.ts +0 -2
  257. package/dist/types/src/tools/openapi.test.d.ts.map +0 -1
  258. package/dist/types/src/types/index.d.ts +0 -4
  259. package/dist/types/src/types/index.d.ts.map +0 -1
  260. package/dist/types/src/types/registry.d.ts +0 -10
  261. package/dist/types/src/types/registry.d.ts.map +0 -1
  262. package/dist/types/src/types/schema.d.ts +0 -221
  263. package/dist/types/src/types/schema.d.ts.map +0 -1
  264. package/dist/types/src/types/types.d.ts +0 -18
  265. package/dist/types/src/types/types.d.ts.map +0 -1
  266. package/src/artifacts.stories.tsx +0 -241
  267. package/src/capabilities/ai-client.ts +0 -19
  268. package/src/capabilities/app-graph-builder.ts +0 -187
  269. package/src/capabilities/capabilities.ts +0 -12
  270. package/src/capabilities/intent-resolver.ts +0 -27
  271. package/src/components/AmbientChatDialog/AmbientChatDialog.stories.tsx +0 -44
  272. package/src/components/AmbientChatDialog/AmbientChatDialog.tsx +0 -63
  273. package/src/components/AmbientChatDialog/index.ts +0 -5
  274. package/src/components/Box/StatusLine.stories.tsx +0 -52
  275. package/src/components/Box/StatusLine.tsx +0 -76
  276. package/src/components/Box/Tabbed.stories.tsx +0 -51
  277. package/src/components/Box/Tabbed.tsx +0 -89
  278. package/src/components/Box/ToggleContainer.stories.tsx +0 -110
  279. package/src/components/Box/ToggleContainer.tsx +0 -108
  280. package/src/components/Box/index.ts +0 -7
  281. package/src/components/ChatContainer/ChatContainer.tsx +0 -52
  282. package/src/components/ChatContainer/index.ts +0 -8
  283. package/src/components/MarkdownViewer/MarkdownViewer.stories.tsx +0 -56
  284. package/src/components/MarkdownViewer/MarkdownViewer.tsx +0 -79
  285. package/src/components/MarkdownViewer/index.ts +0 -5
  286. package/src/components/Prompt/Prompt.stories.tsx +0 -50
  287. package/src/components/Prompt/Prompt.tsx +0 -39
  288. package/src/components/Prompt/index.ts +0 -5
  289. package/src/components/Prompt/prompt-autocomplete.ts +0 -200
  290. package/src/components/PromptEditor/PromptEditor.stories.tsx +0 -64
  291. package/src/components/PromptEditor/PromptEditor.tsx +0 -222
  292. package/src/components/PromptEditor/index.ts +0 -5
  293. package/src/components/PromptEditor/prompt-extension.ts +0 -43
  294. package/src/components/PromptEditor/types.tsx +0 -28
  295. package/src/components/ServiceRegistry/ServiceRegistry.stories.tsx +0 -49
  296. package/src/components/ServiceRegistry/ServiceRegistry.tsx +0 -76
  297. package/src/components/ServiceRegistry/index.ts +0 -5
  298. package/src/components/Thread/Thread.stories.tsx +0 -197
  299. package/src/components/Thread/Thread.tsx +0 -156
  300. package/src/components/Thread/ThreadMessage.tsx +0 -225
  301. package/src/components/Thread/index.ts +0 -5
  302. package/src/hooks/email.ts +0 -49
  303. package/src/hooks/index.ts +0 -10
  304. package/src/hooks/invocation-handler.ts +0 -109
  305. package/src/hooks/processor.test.ts +0 -15
  306. package/src/hooks/processor.ts +0 -210
  307. package/src/hooks/useChatProcessor.tsx +0 -86
  308. package/src/hooks/useLocalTriggerManager.ts +0 -82
  309. package/src/hooks/useMessageQueue.ts +0 -23
  310. package/src/hooks/useServices.ts +0 -28
  311. package/src/presets.ts +0 -248
  312. package/src/testing/test-services.ts +0 -131
  313. package/src/tools/function.ts +0 -47
  314. package/src/tools/index.ts +0 -6
  315. package/src/tools/openapi.test.ts +0 -224
  316. package/src/tools/openapi.ts +0 -331
  317. package/src/types/index.ts +0 -7
  318. package/src/types/registry.ts +0 -26
  319. package/src/types/schema.ts +0 -132
  320. package/src/types/types.ts +0 -21
@@ -1,76 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { useEffect, useRef, useState } from 'react';
6
-
7
- import { type ThemedClassName } from '@dxos/react-ui';
8
- import { mx } from '@dxos/react-ui-theme';
9
-
10
- const emptyLines: string[] = [];
11
-
12
- export type StatusLineProps = ThemedClassName<{
13
- line?: number;
14
- lines?: string[];
15
- transition?: number;
16
- advance?: number;
17
- autoAdvance?: boolean;
18
- }>;
19
-
20
- export const StatusLine = ({
21
- classNames,
22
- line = -1,
23
- lines = emptyLines,
24
- transition = 300,
25
- advance = 1_000,
26
- autoAdvance,
27
- }: StatusLineProps) => {
28
- const containerRef = useRef<HTMLDivElement>(null);
29
- const [currentLine, setCurrentLine] = useState(line);
30
- useEffect(() => {
31
- setCurrentLine(line);
32
- }, [line]);
33
-
34
- useEffect(() => {
35
- if (!autoAdvance) {
36
- return;
37
- }
38
-
39
- const next = () => {
40
- setCurrentLine((prev) => {
41
- if (prev >= lines.length - 1) {
42
- clearInterval(interval);
43
- return prev;
44
- }
45
-
46
- return prev + 1;
47
- });
48
- };
49
-
50
- next();
51
- const interval = setInterval(next, advance);
52
-
53
- return () => clearInterval(interval);
54
- }, [lines.length, autoAdvance, advance]);
55
-
56
- useEffect(() => {
57
- if (containerRef.current) {
58
- containerRef.current.style.transition = `transform ${transition}ms ease-in-out`;
59
- containerRef.current.style.transform = `translateY(-${currentLine * 24}px)`;
60
- }
61
- }, [currentLine]);
62
-
63
- return (
64
- <div className={mx('relative h-[24px] overflow-hidden', classNames)}>
65
- <div ref={containerRef} className='h-[24px]'>
66
- <div className='flex flex-col'>
67
- {lines.map((line, i) => (
68
- <div key={i} className={mx('flex h-[24px] items-center')}>
69
- <span className='truncate'>{line}</span>
70
- </div>
71
- ))}
72
- </div>
73
- </div>
74
- </div>
75
- );
76
- };
@@ -1,51 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { type StoryObj, type Meta } from '@storybook/react';
8
- import React, { useState } from 'react';
9
-
10
- import { faker } from '@dxos/random';
11
- import { withLayout, withTheme, withSignals } from '@dxos/storybook-utils';
12
-
13
- import { Tabs } from './Tabbed';
14
- import { ToggleContainer } from './ToggleContainer';
15
-
16
- const content = Array.from({ length: 4 }, (_, i) => ({
17
- title: faker.lorem.paragraph(),
18
- content: faker.lorem.paragraphs(3),
19
- }));
20
-
21
- const meta: Meta<typeof Tabs> = {
22
- title: 'plugins/plugin-automation/Tabbed',
23
- component: Tabs,
24
- decorators: [withSignals, withTheme, withLayout({ fullscreen: true, classNames: 'justify-center' })],
25
- };
26
-
27
- export default meta;
28
-
29
- type Story = StoryObj<typeof Tabs>;
30
-
31
- export const Default: Story = {
32
- render: () => {
33
- const [selected, setSelected] = useState(0);
34
- return (
35
- <div className='flex flex-col w-[500px] p-4 bg-attention'>
36
- <ToggleContainer
37
- open
38
- title={content[selected].title}
39
- classNames='p-1 rounded-lg bg-baseSurface border border-neutral-500'
40
- >
41
- <div className='flex w-full overflow-hidden'>
42
- <Tabs length={content.length} selected={selected} onSelect={setSelected} />
43
- <div className='flex-1 pis-2 pie-2 overflow-y-auto'>
44
- <div>{content[selected].content}</div>
45
- </div>
46
- </div>
47
- </ToggleContainer>
48
- </div>
49
- );
50
- },
51
- };
@@ -1,89 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { forwardRef } from 'react';
6
-
7
- import { Icon, type ThemedClassName } from '@dxos/react-ui';
8
- import { mx } from '@dxos/react-ui-theme';
9
-
10
- const numbers = [
11
- { regular: 'ph--number-circle-zero--thin', active: 'ph--number-circle-zero--duotone' },
12
- { regular: 'ph--number-circle-one--thin', active: 'ph--number-circle-one--duotone' },
13
- { regular: 'ph--number-circle-two--thin', active: 'ph--number-circle-two--duotone' },
14
- { regular: 'ph--number-circle-three--thin', active: 'ph--number-circle-three--duotone' },
15
- { regular: 'ph--number-circle-four--thin', active: 'ph--number-circle-four--duotone' },
16
- { regular: 'ph--number-circle-five--thin', active: 'ph--number-circle-five--duotone' },
17
- { regular: 'ph--number-circle-six--thin', active: 'ph--number-circle-six--duotone' },
18
- { regular: 'ph--number-circle-seven--thin', active: 'ph--number-circle-seven--duotone' },
19
- { regular: 'ph--number-circle-eight--thin', active: 'ph--number-circle-eight--duotone' },
20
- { regular: 'ph--number-circle-nine--thin', active: 'ph--number-circle-nine--duotone' },
21
- ];
22
-
23
- export type TabsProps = ThemedClassName<{
24
- length: number;
25
- selected?: number;
26
- onSelect?: (index: number) => void;
27
- }>;
28
-
29
- export const Tabs = forwardRef<HTMLDivElement, TabsProps>(
30
- ({ classNames, length, selected = 0, onSelect }, forwardedRef) => {
31
- return (
32
- <div
33
- ref={forwardedRef}
34
- className={mx('flex flex-col overflow-hidden outline-none', classNames)}
35
- tabIndex={-1}
36
- onKeyDown={(ev) => {
37
- // TODO(burdon): Focus when open Toggle.
38
- switch (ev.key) {
39
- case 'ArrowDown':
40
- case 'ArrowRight': {
41
- ev.preventDefault();
42
- ev.stopPropagation();
43
- if (selected < length - 1) {
44
- onSelect?.(selected + 1);
45
- }
46
- break;
47
- }
48
- case 'ArrowUp':
49
- case 'ArrowLeft': {
50
- ev.preventDefault();
51
- ev.stopPropagation();
52
- if (selected > 0) {
53
- onSelect?.(selected - 1);
54
- }
55
- break;
56
- }
57
-
58
- case 'Enter': {
59
- ev.preventDefault();
60
- ev.stopPropagation();
61
- onSelect?.(selected);
62
- break;
63
- }
64
- }
65
- }}
66
- >
67
- {Array.from({ length }).map((_, i) => {
68
- const icon = numbers[i + 1];
69
- return (
70
- <div
71
- key={i}
72
- className={mx(
73
- 'relative flex w-[24px] h-[28px] justify-center cursor-pointer text-subdued',
74
- selected === i && '!text-cyan-550 !dark:text-cyan-300',
75
- )}
76
- >
77
- {i < length - 1 && <div className='absolute left-[11.5px] top-[21px] w-[1px] h-[10px] bg-neutral-400' />}
78
- <Icon
79
- icon={selected === i ? icon.regular : icon.regular}
80
- classNames='z-10 !p-0 !w-[24px] !h-[24px] outline-none'
81
- onClick={() => onSelect?.(i)}
82
- />
83
- </div>
84
- );
85
- })}
86
- </div>
87
- );
88
- },
89
- );
@@ -1,110 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { computed, type ReadonlySignal, signal } from '@preact/signals-core';
8
- import { type StoryObj, type Meta } from '@storybook/react';
9
- import React, { useEffect, useMemo, useState } from 'react';
10
-
11
- import { faker } from '@dxos/random';
12
- import { Icon, Input, Toolbar } from '@dxos/react-ui';
13
- import { mx } from '@dxos/react-ui-theme';
14
- import { withLayout, withTheme, withSignals } from '@dxos/storybook-utils';
15
-
16
- import { ToggleContainer, type ToggleContainerProps } from './ToggleContainer';
17
- import { MarkdownViewer } from '../MarkdownViewer';
18
-
19
- class Generator {
20
- private readonly _current = signal<string>(faker.lorem.sentence(5));
21
- private readonly _lines = signal<string[]>([]);
22
- private _running: NodeJS.Timeout | undefined;
23
-
24
- readonly count = computed(() => this._lines.value.length);
25
- readonly text: ReadonlySignal<string[]> = computed(() => [...this._lines.value, this._current.value]);
26
-
27
- start() {
28
- this.stop();
29
- this._running = setInterval(() => {
30
- if (this._current.value.length > 0) {
31
- this._current.value += ' ';
32
- }
33
- this._current.value += faker.lorem.words(Math.ceil(Math.random() * 2));
34
- if (Math.random() > 0.95) {
35
- this._lines.value = [...this._lines.value, this._current.value + '.'];
36
- this._current.value = '';
37
- }
38
- }, 100);
39
- }
40
-
41
- stop() {
42
- if (this._running) {
43
- clearInterval(this._running);
44
- this._running = undefined;
45
- }
46
- }
47
- }
48
-
49
- const Render = ({ shrinkX, ...props }: ToggleContainerProps) => {
50
- const generator = useMemo(() => new Generator(), []);
51
- const [running, setRunning] = useState(false);
52
- useEffect(() => {
53
- if (running) {
54
- generator.start();
55
- } else {
56
- generator.stop();
57
- }
58
- }, [running]);
59
-
60
- return (
61
- <div className='flex flex-col w-[500px]'>
62
- <Toolbar.Root classNames='p-4'>
63
- <Input.Root>
64
- <Input.Switch checked={running} onCheckedChange={(checked) => setRunning(checked)} />
65
- </Input.Root>
66
- <div className='grow' />
67
- <div>{generator.count.value}</div>
68
- </Toolbar.Root>
69
- <div className='flex p-4'>
70
- <div className={mx('border border-border rounded-md p-2', !shrinkX && 'w-full')}>
71
- <ToggleContainer
72
- {...props}
73
- shrinkX={shrinkX}
74
- icon={
75
- running ? (
76
- <Icon icon={'ph--circle-notch--regular'} classNames='text-subdued ml-2 animate-spin' size={4} />
77
- ) : undefined
78
- }
79
- >
80
- <MarkdownViewer classNames='text-sm' content={generator.text.value.join('\n\n')} />
81
- </ToggleContainer>
82
- </div>
83
- </div>
84
- </div>
85
- );
86
- };
87
-
88
- const meta: Meta<typeof ToggleContainer> = {
89
- title: 'plugins/plugin-automation/ToggleContainer',
90
- component: ToggleContainer,
91
- render: Render,
92
- decorators: [withSignals, withTheme, withLayout({ fullscreen: true, classNames: 'justify-center bg-baseSurface' })],
93
- };
94
-
95
- export default meta;
96
-
97
- type Story = StoryObj<typeof ToggleContainer>;
98
-
99
- export const Default: Story = {
100
- args: {
101
- title: 'Markdown',
102
- },
103
- };
104
-
105
- export const Shrink: Story = {
106
- args: {
107
- title: 'Markdown',
108
- shrinkX: true,
109
- },
110
- };
@@ -1,108 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { type JSX, type PropsWithChildren, useEffect, useState } from 'react';
6
-
7
- import { Icon, useControlledState, type ThemedClassName } from '@dxos/react-ui';
8
- import { mx } from '@dxos/react-ui-theme';
9
-
10
- export type ToggleContainerProps = ThemedClassName<
11
- PropsWithChildren<{
12
- title?: string | JSX.Element;
13
- icon?: JSX.Element;
14
- open?: boolean;
15
- duration?: number;
16
- /** Should shrink the width when closed. */
17
- shrinkX?: boolean;
18
- onChangeOpen?: (open: boolean) => void;
19
- }>
20
- >;
21
-
22
- export const ToggleContainer = ({
23
- classNames,
24
- title,
25
- icon,
26
- open: _open,
27
- duration = 400,
28
- shrinkX = false,
29
- children,
30
- onChangeOpen,
31
- }: ToggleContainerProps) => {
32
- const [open, setOpen] = useControlledState(_open);
33
- const [expandX, setExpandX] = useState(shrinkX ? open : true);
34
- const [expandY, setExpandY] = useState(open);
35
-
36
- useEffect(() => {
37
- let t: NodeJS.Timeout;
38
- if (open) {
39
- if (shrinkX) {
40
- setExpandX(true);
41
- }
42
- t = setTimeout(
43
- () => {
44
- setExpandY(true);
45
- },
46
- shrinkX ? duration : 0,
47
- );
48
- } else {
49
- setExpandY(false);
50
- if (shrinkX) {
51
- t = setTimeout(() => {
52
- setExpandX(false);
53
- }, duration);
54
- }
55
- }
56
-
57
- return () => clearTimeout(t);
58
- }, [open]);
59
-
60
- const handleToggle = () => {
61
- if (onChangeOpen) {
62
- onChangeOpen(!open);
63
- } else {
64
- setOpen((open) => !open);
65
- }
66
- };
67
-
68
- return (
69
- <div className={mx('overflow-hidden', classNames)}>
70
- {title && (
71
- <div
72
- className='flex gap-1 py-1 items-center text-sm text-subdued cursor-pointer select-none'
73
- onClick={handleToggle}
74
- >
75
- <div className='flex w-[24px] h-[24px] items-center justify-center'>
76
- <Icon
77
- size={4}
78
- icon={'ph--caret-right--regular'}
79
- style={{ transitionDuration: `${shrinkX ? duration * 2 : duration}ms` }}
80
- classNames={['transition transition-transform ease-in-out', open ? 'rotate-90' : 'transform-none']}
81
- />
82
- </div>
83
- <div className='flex-1 pis-1 pie-1 truncate'>{title}</div>
84
- {icon}
85
- </div>
86
- )}
87
- <div
88
- style={{ transitionDuration: `${duration}ms` }}
89
- className={mx(
90
- 'grid transition-[grid-template-columns] ease-in-out',
91
- expandX ? 'grid-cols-[1fr]' : 'grid-cols-[0fr]',
92
- )}
93
- >
94
- <div className='overflow-hidden'>
95
- <div
96
- style={{ transitionDuration: `${duration}ms` }}
97
- className={mx(
98
- 'grid transition-[grid-template-rows] ease-in-out',
99
- expandY ? 'grid-rows-[1fr]' : 'grid-rows-[0fr]',
100
- )}
101
- >
102
- <div className={mx('flex overflow-hidden transition-opacity')}>{children}</div>
103
- </div>
104
- </div>
105
- </div>
106
- </div>
107
- );
108
- };
@@ -1,7 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- export * from './StatusLine';
6
- export * from './Tabbed';
7
- export * from './ToggleContainer';
@@ -1,52 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { useCallback } from 'react';
6
-
7
- import { invariant } from '@dxos/invariant';
8
- import { StackItem } from '@dxos/react-ui-stack';
9
-
10
- import { useChatProcessor, useMessageQueue } from '../../hooks';
11
- import { type AIChatType } from '../../types';
12
- import { Thread } from '../Thread';
13
-
14
- export const ChatContainer = ({ chat, role }: { chat: AIChatType; role: string }) => {
15
- const processor = useChatProcessor(chat);
16
- const messageQueue = useMessageQueue(chat);
17
- const messages = [...(messageQueue?.items ?? []), ...processor.messages.value];
18
-
19
- const handleSubmit = useCallback(
20
- async (text: string) => {
21
- if (processor.streaming.value) {
22
- await processor.cancel();
23
- }
24
-
25
- invariant(messageQueue);
26
- await processor.request(text, {
27
- history: messageQueue.items,
28
- onComplete: (messages) => messageQueue.append(messages),
29
- });
30
- },
31
- [processor, messageQueue],
32
- );
33
-
34
- const handleStop = useCallback(() => {
35
- if (processor.streaming.value) {
36
- void processor.cancel();
37
- }
38
- }, [processor]);
39
-
40
- return (
41
- <StackItem.Content toolbar={false} role={role}>
42
- <Thread
43
- messages={messages}
44
- streaming={processor.streaming.value}
45
- collapse={true}
46
- onSubmit={handleSubmit}
47
- onSuggest={handleSubmit}
48
- onStop={handleStop}
49
- />
50
- </StackItem.Content>
51
- );
52
- };
@@ -1,8 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { ChatContainer } from './ChatContainer';
6
-
7
- export * from './ChatContainer';
8
- export default ChatContainer;
@@ -1,56 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { type StoryObj, type Meta } from '@storybook/react';
8
-
9
- import { faker } from '@dxos/random';
10
- import { withLayout, withTheme } from '@dxos/storybook-utils';
11
-
12
- import { MarkdownViewer } from './MarkdownViewer';
13
-
14
- faker.seed(0);
15
-
16
- const meta: Meta<typeof MarkdownViewer> = {
17
- title: 'plugins/plugin-automation/MarkdownViewer',
18
- component: MarkdownViewer,
19
- decorators: [withTheme, withLayout({ fullscreen: true, classNames: 'justify-center' })],
20
- };
21
-
22
- export default meta;
23
-
24
- type Story = StoryObj<typeof MarkdownViewer>;
25
-
26
- const content = `
27
- # Hello, world!
28
-
29
- ${faker.lorem.paragraphs(1)}
30
-
31
- Here's a JSON block:
32
-
33
- ~~~json
34
- {
35
- "hello": "world"
36
- }
37
- ~~~
38
-
39
- And some code:
40
-
41
- ~~~ts
42
- const App = () => {
43
- const title = 'Hello, world!';
44
- return <div>{title}</div>;
45
- };
46
- ~~~
47
-
48
- ${faker.lorem.paragraphs(1)}
49
- `;
50
-
51
- export const Default: Story = {
52
- args: {
53
- classNames: 'w-[500px] border border-border rounded-md p-4',
54
- content,
55
- },
56
- };
@@ -1,79 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { type FC } from 'react';
6
- import ReactMarkdown from 'react-markdown';
7
-
8
- import { type ThemedClassName } from '@dxos/react-ui';
9
- import { SyntaxHighlighter } from '@dxos/react-ui-syntax-highlighter';
10
- import { mx } from '@dxos/react-ui-theme';
11
- import { omit } from '@dxos/util';
12
-
13
- type MarkdownViewerProps = ThemedClassName<{
14
- content?: string;
15
- }>;
16
-
17
- /**
18
- * Transform text into react elements.
19
- *
20
- * https://github.com/remarkjs/react-markdown
21
- * markdown -> remark -> [mdast -> remark plugins] -> [hast -> rehype plugins] -> components -> react elements.
22
- */
23
- // TODO(burdon): Styles.
24
- // TODO(burdon): Factor out (react-ui-syntax-highlighter).
25
- export const MarkdownViewer: FC<MarkdownViewerProps> = ({ classNames, content = '' }) => {
26
- return (
27
- <div className={mx('space-y-2', classNames)}>
28
- <ReactMarkdown
29
- components={{
30
- a: ({ node, children, href, ...props }) => (
31
- <a
32
- href={href}
33
- className='text-primary-500 hover:text-primary-500'
34
- target='_blank'
35
- rel='noopener noreferrer'
36
- {...props}
37
- >
38
- {children}
39
- </a>
40
- ),
41
- ol: ({ node, children, ...props }) => (
42
- <ol className='leading-tight list-decimal pl-6' {...omit(props, ['ordered'])}>
43
- {children}
44
- </ol>
45
- ),
46
- ul: ({ node, children, ...props }) => (
47
- <ul className='leading-tight list-disc pl-6' {...omit(props, ['ordered'])}>
48
- {children}
49
- </ul>
50
- ),
51
- li: ({ node, children, ...props }) => (
52
- <li className='' {...omit(props, ['ordered'])}>
53
- {children}
54
- </li>
55
- ),
56
- blockquote: ({ node, children, ...props }) => (
57
- <blockquote className='border-l-4 border-primary-500 pl-4 my-4 text-primary-500' {...props}>
58
- {children}
59
- </blockquote>
60
- ),
61
- code: ({ children, className }) => {
62
- const [_, language] = /language-(\w+)/.exec(className || '') || [];
63
- return (
64
- <SyntaxHighlighter PreTag='div' language={language} className='p-0'>
65
- {children}
66
- </SyntaxHighlighter>
67
- );
68
- },
69
- }}
70
- >
71
- {content}
72
- </ReactMarkdown>
73
- </div>
74
- );
75
- };
76
-
77
- // const Cursor = () => {
78
- // return <span className='animate-[pulse_1s_steps(1)_infinite] text-primary-500'>▊</span>;
79
- // };
@@ -1,5 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- export * from './MarkdownViewer';
@@ -1,50 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { type StoryObj, type Meta } from '@storybook/react';
8
-
9
- import { withTheme } from '@dxos/storybook-utils';
10
-
11
- import { Prompt } from './Prompt';
12
-
13
- const meta: Meta<typeof Prompt> = {
14
- title: 'plugins/plugin-automation/Prompt',
15
- component: Prompt,
16
- decorators: [withTheme],
17
- parameters: {
18
- layout: 'centered',
19
- },
20
- };
21
-
22
- export default meta;
23
-
24
- type Story = StoryObj<typeof Prompt>;
25
-
26
- export const Default: Story = {
27
- args: {
28
- classNames: 'w-96 p-4 rounded outline outline-gray-200',
29
- autoFocus: true,
30
- onEnter: (text) => {
31
- console.log('onEnter', text);
32
- },
33
- onSuggest: (text) => {
34
- const trimmed = text.trim().toLowerCase();
35
- if (trimmed.length < 2) {
36
- return [];
37
- }
38
-
39
- const suggestions = [
40
- 'Create a CRM',
41
- 'Create a new project',
42
- 'Find flights to Tokyo',
43
- "Let's play chess",
44
- 'Show me Paris on a map',
45
- ];
46
-
47
- return suggestions.filter((s) => s.toLowerCase().startsWith(text));
48
- },
49
- },
50
- };