@dxos/plugin-automation 0.8.4-main.a4bbb77 → 0.8.4-main.abd8ff62ef

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 (287) hide show
  1. package/dist/lib/browser/chunk-CHUTFU3D.mjs +54 -0
  2. package/dist/lib/browser/chunk-CHUTFU3D.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  4. package/dist/lib/browser/chunk-RE64VLSV.mjs +44 -0
  5. package/dist/lib/browser/chunk-RE64VLSV.mjs.map +7 -0
  6. package/dist/lib/browser/create-trigger-from-template-JLBSJRVB.mjs +70 -0
  7. package/dist/lib/browser/create-trigger-from-template-JLBSJRVB.mjs.map +7 -0
  8. package/dist/lib/browser/hooks/index.mjs +123 -6
  9. package/dist/lib/browser/hooks/index.mjs.map +4 -4
  10. package/dist/lib/browser/index.mjs +17 -102
  11. package/dist/lib/browser/index.mjs.map +4 -4
  12. package/dist/lib/browser/meta.json +1 -1
  13. package/dist/lib/browser/operations/index.mjs +14 -0
  14. package/dist/lib/browser/operations/index.mjs.map +7 -0
  15. package/dist/lib/browser/translations.mjs +47 -0
  16. package/dist/lib/browser/translations.mjs.map +7 -0
  17. package/dist/lib/browser/types/index.mjs +10 -4
  18. package/dist/lib/node-esm/chunk-HHIHREME.mjs +45 -0
  19. package/dist/lib/node-esm/chunk-HHIHREME.mjs.map +7 -0
  20. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  21. package/dist/lib/node-esm/chunk-NWQMBY32.mjs +56 -0
  22. package/dist/lib/node-esm/chunk-NWQMBY32.mjs.map +7 -0
  23. package/dist/lib/node-esm/create-trigger-from-template-FUQ3LUIF.mjs +71 -0
  24. package/dist/lib/node-esm/create-trigger-from-template-FUQ3LUIF.mjs.map +7 -0
  25. package/dist/lib/node-esm/hooks/index.mjs +123 -6
  26. package/dist/lib/node-esm/hooks/index.mjs.map +4 -4
  27. package/dist/lib/node-esm/index.mjs +17 -102
  28. package/dist/lib/node-esm/index.mjs.map +4 -4
  29. package/dist/lib/node-esm/meta.json +1 -1
  30. package/dist/lib/node-esm/operations/index.mjs +15 -0
  31. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  32. package/dist/lib/node-esm/translations.mjs +48 -0
  33. package/dist/lib/node-esm/translations.mjs.map +7 -0
  34. package/dist/lib/node-esm/types/index.mjs +10 -4
  35. package/dist/types/src/AutomationPlugin.d.ts +3 -1
  36. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  37. package/dist/types/src/AutomationPlugin.node.d.ts +4 -0
  38. package/dist/types/src/AutomationPlugin.node.d.ts.map +1 -0
  39. package/dist/types/src/AutomationPlugin.test.d.ts +2 -0
  40. package/dist/types/src/AutomationPlugin.test.d.ts.map +1 -0
  41. package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
  42. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  43. package/dist/types/src/capabilities/compute-runtime.d.ts +12 -3
  44. package/dist/types/src/capabilities/compute-runtime.d.ts.map +1 -1
  45. package/dist/types/src/capabilities/index.d.ts +6 -5
  46. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  47. package/dist/types/src/capabilities/node.d.ts +6 -0
  48. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  49. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  50. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  51. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  52. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  53. package/dist/types/src/commands/index.d.ts +2 -0
  54. package/dist/types/src/commands/index.d.ts.map +1 -0
  55. package/dist/types/src/commands/trigger/create/index.d.ts +25 -0
  56. package/dist/types/src/commands/trigger/create/index.d.ts.map +1 -0
  57. package/dist/types/src/commands/trigger/create/queue.d.ts +13 -0
  58. package/dist/types/src/commands/trigger/create/queue.d.ts.map +1 -0
  59. package/dist/types/src/commands/trigger/create/subscription.d.ts +15 -0
  60. package/dist/types/src/commands/trigger/create/subscription.d.ts.map +1 -0
  61. package/dist/types/src/commands/trigger/create/timer.d.ts +13 -0
  62. package/dist/types/src/commands/trigger/create/timer.d.ts.map +1 -0
  63. package/dist/types/src/commands/trigger/index.d.ts +57 -0
  64. package/dist/types/src/commands/trigger/index.d.ts.map +1 -0
  65. package/dist/types/src/commands/trigger/list.d.ts +7 -0
  66. package/dist/types/src/commands/trigger/list.d.ts.map +1 -0
  67. package/dist/types/src/commands/trigger/options.d.ts +11 -0
  68. package/dist/types/src/commands/trigger/options.d.ts.map +1 -0
  69. package/dist/types/src/commands/trigger/remove.d.ts +8 -0
  70. package/dist/types/src/commands/trigger/remove.d.ts.map +1 -0
  71. package/dist/types/src/commands/trigger/update/index.d.ts +28 -0
  72. package/dist/types/src/commands/trigger/update/index.d.ts.map +1 -0
  73. package/dist/types/src/commands/trigger/update/queue.d.ts +12 -0
  74. package/dist/types/src/commands/trigger/update/queue.d.ts.map +1 -0
  75. package/dist/types/src/commands/trigger/update/subscription.d.ts +13 -0
  76. package/dist/types/src/commands/trigger/update/subscription.d.ts.map +1 -0
  77. package/dist/types/src/commands/trigger/update/timer.d.ts +11 -0
  78. package/dist/types/src/commands/trigger/update/timer.d.ts.map +1 -0
  79. package/dist/types/src/commands/trigger/util.d.ts +46 -0
  80. package/dist/types/src/commands/trigger/util.d.ts.map +1 -0
  81. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +6 -7
  82. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  83. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts +32 -27
  84. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  85. package/dist/types/src/components/AutomationPanel/index.d.ts.map +1 -1
  86. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
  87. package/dist/types/src/components/FunctionsPanel/index.d.ts.map +1 -1
  88. package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts +8 -0
  89. package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts.map +1 -0
  90. package/dist/types/src/components/FunctionsRegistry/index.d.ts +4 -0
  91. package/dist/types/src/components/FunctionsRegistry/index.d.ts.map +1 -0
  92. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +12 -9
  93. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +1 -1
  94. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts +6 -3
  95. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +1 -1
  96. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +11 -8
  97. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  98. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts +106 -30
  99. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  100. package/dist/types/src/components/index.d.ts +3 -4
  101. package/dist/types/src/components/index.d.ts.map +1 -1
  102. package/dist/types/src/containers/AutomationSettings/AutomationSettings.d.ts +6 -0
  103. package/dist/types/src/containers/AutomationSettings/AutomationSettings.d.ts.map +1 -0
  104. package/dist/types/src/containers/AutomationSettings/index.d.ts +2 -0
  105. package/dist/types/src/containers/AutomationSettings/index.d.ts.map +1 -0
  106. package/dist/types/src/containers/FunctionsContainer/FunctionsContainer.d.ts +4 -0
  107. package/dist/types/src/containers/FunctionsContainer/FunctionsContainer.d.ts.map +1 -0
  108. package/dist/types/src/containers/FunctionsContainer/index.d.ts +2 -0
  109. package/dist/types/src/containers/FunctionsContainer/index.d.ts.map +1 -0
  110. package/dist/types/src/containers/TriggerSettings/TriggerSettings.d.ts.map +1 -0
  111. package/dist/types/src/containers/TriggerSettings/index.d.ts +3 -0
  112. package/dist/types/src/containers/TriggerSettings/index.d.ts.map +1 -0
  113. package/dist/types/src/containers/index.d.ts +5 -0
  114. package/dist/types/src/containers/index.d.ts.map +1 -0
  115. package/dist/types/src/hooks/index.d.ts +2 -0
  116. package/dist/types/src/hooks/index.d.ts.map +1 -1
  117. package/dist/types/src/hooks/useComputeRuntime.d.ts +8 -0
  118. package/dist/types/src/hooks/useComputeRuntime.d.ts.map +1 -0
  119. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts +5 -4
  120. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts.map +1 -1
  121. package/dist/types/src/hooks/useComputeRuntimeService.d.ts +17 -0
  122. package/dist/types/src/hooks/useComputeRuntimeService.d.ts.map +1 -0
  123. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts +6 -5
  124. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts.map +1 -1
  125. package/dist/types/src/index.d.ts +3 -4
  126. package/dist/types/src/index.d.ts.map +1 -1
  127. package/dist/types/src/meta.d.ts +2 -2
  128. package/dist/types/src/meta.d.ts.map +1 -1
  129. package/dist/types/src/operations/create-trigger-from-template.d.ts +5 -0
  130. package/dist/types/src/operations/create-trigger-from-template.d.ts.map +1 -0
  131. package/dist/types/src/operations/definitions.d.ts +19 -0
  132. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  133. package/dist/types/src/operations/index.d.ts +4 -0
  134. package/dist/types/src/operations/index.d.ts.map +1 -0
  135. package/dist/types/src/testing/test-functions.d.ts +204 -3
  136. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  137. package/dist/types/src/translations.d.ts +32 -28
  138. package/dist/types/src/translations.d.ts.map +1 -1
  139. package/dist/types/src/types/capabilities.d.ts +24 -0
  140. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  141. package/dist/types/src/types/events.d.ts +5 -0
  142. package/dist/types/src/types/events.d.ts.map +1 -0
  143. package/dist/types/src/types/index.d.ts +2 -0
  144. package/dist/types/src/types/index.d.ts.map +1 -1
  145. package/dist/types/src/types/schema.d.ts +12 -4
  146. package/dist/types/src/types/schema.d.ts.map +1 -1
  147. package/dist/types/tsconfig.tsbuildinfo +1 -1
  148. package/package.json +99 -56
  149. package/src/AutomationPlugin.node.ts +29 -0
  150. package/src/AutomationPlugin.test.ts +27 -0
  151. package/src/AutomationPlugin.tsx +20 -35
  152. package/src/capabilities/app-graph-builder.ts +59 -79
  153. package/src/capabilities/compute-runtime.ts +272 -83
  154. package/src/capabilities/index.ts +9 -7
  155. package/src/capabilities/node.ts +13 -0
  156. package/src/capabilities/operation-handler.ts +16 -0
  157. package/src/capabilities/react-surface.tsx +49 -46
  158. package/src/commands/index.ts +5 -0
  159. package/src/commands/trigger/create/index.ts +14 -0
  160. package/src/commands/trigger/create/queue.ts +86 -0
  161. package/src/commands/trigger/create/subscription.ts +125 -0
  162. package/src/commands/trigger/create/timer.ts +90 -0
  163. package/src/commands/trigger/index.ts +16 -0
  164. package/src/commands/trigger/list.ts +70 -0
  165. package/src/commands/trigger/options.ts +59 -0
  166. package/src/commands/trigger/remove.ts +45 -0
  167. package/src/commands/trigger/update/index.ts +14 -0
  168. package/src/commands/trigger/update/queue.ts +194 -0
  169. package/src/commands/trigger/update/subscription.ts +278 -0
  170. package/src/commands/trigger/update/timer.ts +193 -0
  171. package/src/commands/trigger/util.ts +410 -0
  172. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +7 -7
  173. package/src/components/AutomationPanel/AutomationPanel.tsx +249 -81
  174. package/src/components/FunctionsPanel/FunctionsPanel.tsx +50 -31
  175. package/src/components/FunctionsRegistry/FunctionsRegistry.tsx +114 -0
  176. package/src/components/FunctionsRegistry/index.ts +8 -0
  177. package/src/components/TriggerEditor/FunctionInputEditor.tsx +42 -35
  178. package/src/components/TriggerEditor/SpecSelector.tsx +28 -16
  179. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +116 -29
  180. package/src/components/TriggerEditor/TriggerEditor.tsx +109 -42
  181. package/src/components/index.ts +1 -2
  182. package/src/containers/AutomationSettings/AutomationSettings.tsx +31 -0
  183. package/src/containers/AutomationSettings/index.ts +5 -0
  184. package/src/containers/FunctionsContainer/FunctionsContainer.tsx +33 -0
  185. package/src/containers/FunctionsContainer/index.ts +5 -0
  186. package/src/containers/TriggerSettings/TriggerSettings.tsx +48 -0
  187. package/src/containers/TriggerSettings/index.ts +6 -0
  188. package/src/containers/index.ts +9 -0
  189. package/src/hooks/index.ts +3 -0
  190. package/src/hooks/useComputeRuntime.ts +30 -0
  191. package/src/hooks/useComputeRuntimeCallback.ts +11 -9
  192. package/src/hooks/useComputeRuntimeService.ts +64 -0
  193. package/src/hooks/useTriggerRuntimeControls.ts +34 -16
  194. package/src/index.ts +5 -4
  195. package/src/meta.ts +9 -6
  196. package/src/operations/create-trigger-from-template.ts +71 -0
  197. package/src/operations/definitions.ts +28 -0
  198. package/src/operations/index.ts +9 -0
  199. package/src/testing/test-functions.ts +10 -7
  200. package/src/translations.ts +39 -33
  201. package/src/types/capabilities.ts +47 -0
  202. package/src/types/events.ts +11 -0
  203. package/src/types/index.ts +2 -0
  204. package/src/types/schema.ts +6 -6
  205. package/dist/lib/browser/AutomationPanel-4QA5G3ZY.mjs +0 -11
  206. package/dist/lib/browser/AutomationSettings-6XLG2PCK.mjs +0 -69
  207. package/dist/lib/browser/AutomationSettings-6XLG2PCK.mjs.map +0 -7
  208. package/dist/lib/browser/FunctionsContainer-BQ6VBDIG.mjs +0 -36
  209. package/dist/lib/browser/FunctionsContainer-BQ6VBDIG.mjs.map +0 -7
  210. package/dist/lib/browser/FunctionsPanel-QBTOFFNU.mjs +0 -10
  211. package/dist/lib/browser/app-graph-builder-6TP6ZNYG.mjs +0 -80
  212. package/dist/lib/browser/app-graph-builder-6TP6ZNYG.mjs.map +0 -7
  213. package/dist/lib/browser/chunk-BDJPBZGC.mjs +0 -14
  214. package/dist/lib/browser/chunk-BDJPBZGC.mjs.map +0 -7
  215. package/dist/lib/browser/chunk-EAQL33PI.mjs +0 -94
  216. package/dist/lib/browser/chunk-EAQL33PI.mjs.map +0 -7
  217. package/dist/lib/browser/chunk-F4K5EMWL.mjs +0 -38
  218. package/dist/lib/browser/chunk-F4K5EMWL.mjs.map +0 -7
  219. package/dist/lib/browser/chunk-IN2YC7NY.mjs +0 -230
  220. package/dist/lib/browser/chunk-IN2YC7NY.mjs.map +0 -7
  221. package/dist/lib/browser/chunk-LNMCGQC2.mjs +0 -143
  222. package/dist/lib/browser/chunk-LNMCGQC2.mjs.map +0 -7
  223. package/dist/lib/browser/chunk-M2WQCY2T.mjs +0 -53
  224. package/dist/lib/browser/chunk-M2WQCY2T.mjs.map +0 -7
  225. package/dist/lib/browser/chunk-U66KBK53.mjs +0 -14
  226. package/dist/lib/browser/chunk-U66KBK53.mjs.map +0 -7
  227. package/dist/lib/browser/chunk-WWURMV25.mjs +0 -13
  228. package/dist/lib/browser/chunk-WWURMV25.mjs.map +0 -7
  229. package/dist/lib/browser/chunk-ZTXBAXUT.mjs +0 -15
  230. package/dist/lib/browser/chunk-ZTXBAXUT.mjs.map +0 -7
  231. package/dist/lib/browser/compute-runtime-OFQPXD5I.mjs +0 -158
  232. package/dist/lib/browser/compute-runtime-OFQPXD5I.mjs.map +0 -7
  233. package/dist/lib/browser/intent-resolver-JXVWRAAH.mjs +0 -77
  234. package/dist/lib/browser/intent-resolver-JXVWRAAH.mjs.map +0 -7
  235. package/dist/lib/browser/react-surface-NG3MJCDH.mjs +0 -64
  236. package/dist/lib/browser/react-surface-NG3MJCDH.mjs.map +0 -7
  237. package/dist/lib/node-esm/AutomationPanel-WMVR3IST.mjs +0 -12
  238. package/dist/lib/node-esm/AutomationPanel-WMVR3IST.mjs.map +0 -7
  239. package/dist/lib/node-esm/AutomationSettings-4IW7RGMN.mjs +0 -70
  240. package/dist/lib/node-esm/AutomationSettings-4IW7RGMN.mjs.map +0 -7
  241. package/dist/lib/node-esm/FunctionsContainer-LHUUOLA5.mjs +0 -37
  242. package/dist/lib/node-esm/FunctionsContainer-LHUUOLA5.mjs.map +0 -7
  243. package/dist/lib/node-esm/FunctionsPanel-SHTQIMDV.mjs +0 -11
  244. package/dist/lib/node-esm/FunctionsPanel-SHTQIMDV.mjs.map +0 -7
  245. package/dist/lib/node-esm/app-graph-builder-3A2NIPR5.mjs +0 -81
  246. package/dist/lib/node-esm/app-graph-builder-3A2NIPR5.mjs.map +0 -7
  247. package/dist/lib/node-esm/chunk-2L2X4JMP.mjs +0 -16
  248. package/dist/lib/node-esm/chunk-2L2X4JMP.mjs.map +0 -7
  249. package/dist/lib/node-esm/chunk-5MQJPJR2.mjs +0 -15
  250. package/dist/lib/node-esm/chunk-5MQJPJR2.mjs.map +0 -7
  251. package/dist/lib/node-esm/chunk-B6O6UBS7.mjs +0 -16
  252. package/dist/lib/node-esm/chunk-B6O6UBS7.mjs.map +0 -7
  253. package/dist/lib/node-esm/chunk-CEWZ2CDM.mjs +0 -39
  254. package/dist/lib/node-esm/chunk-CEWZ2CDM.mjs.map +0 -7
  255. package/dist/lib/node-esm/chunk-DSEZPWSO.mjs +0 -54
  256. package/dist/lib/node-esm/chunk-DSEZPWSO.mjs.map +0 -7
  257. package/dist/lib/node-esm/chunk-MN5S5J4O.mjs +0 -144
  258. package/dist/lib/node-esm/chunk-MN5S5J4O.mjs.map +0 -7
  259. package/dist/lib/node-esm/chunk-N7NES6SZ.mjs +0 -231
  260. package/dist/lib/node-esm/chunk-N7NES6SZ.mjs.map +0 -7
  261. package/dist/lib/node-esm/chunk-PBULJE4B.mjs +0 -95
  262. package/dist/lib/node-esm/chunk-PBULJE4B.mjs.map +0 -7
  263. package/dist/lib/node-esm/chunk-UTZIMYCX.mjs +0 -16
  264. package/dist/lib/node-esm/chunk-UTZIMYCX.mjs.map +0 -7
  265. package/dist/lib/node-esm/compute-runtime-W5UJNSQY.mjs +0 -159
  266. package/dist/lib/node-esm/compute-runtime-W5UJNSQY.mjs.map +0 -7
  267. package/dist/lib/node-esm/intent-resolver-ROEBZXSS.mjs +0 -78
  268. package/dist/lib/node-esm/intent-resolver-ROEBZXSS.mjs.map +0 -7
  269. package/dist/lib/node-esm/react-surface-A4KTYX6Z.mjs +0 -65
  270. package/dist/lib/node-esm/react-surface-A4KTYX6Z.mjs.map +0 -7
  271. package/dist/types/src/capabilities/capabilities.d.ts +0 -18
  272. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  273. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  274. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  275. package/dist/types/src/components/AutomationSettings.d.ts +0 -5
  276. package/dist/types/src/components/AutomationSettings.d.ts.map +0 -1
  277. package/dist/types/src/components/FunctionsContainer.d.ts +0 -7
  278. package/dist/types/src/components/FunctionsContainer.d.ts.map +0 -1
  279. package/dist/types/src/components/TriggerSettings.d.ts.map +0 -1
  280. package/src/capabilities/capabilities.ts +0 -47
  281. package/src/capabilities/intent-resolver.ts +0 -72
  282. package/src/components/AutomationSettings.tsx +0 -30
  283. package/src/components/FunctionsContainer.tsx +0 -29
  284. package/src/components/TriggerSettings.tsx +0 -25
  285. /package/dist/lib/browser/{AutomationPanel-4QA5G3ZY.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  286. /package/dist/lib/{browser/FunctionsPanel-QBTOFFNU.mjs.map → node-esm/chunk-HSLMI22Q.mjs.map} +0 -0
  287. /package/dist/types/src/{components → containers/TriggerSettings}/TriggerSettings.d.ts +0 -0
@@ -1,230 +0,0 @@
1
- import {
2
- meta
3
- } from "./chunk-WWURMV25.mjs";
4
-
5
- // src/components/TriggerEditor/TriggerEditor.tsx
6
- import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
7
- import React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react";
8
- import { ComputeGraph } from "@dxos/conductor";
9
- import { Type as Type2 } from "@dxos/echo";
10
- import { FunctionTrigger, FunctionType, ScriptType } from "@dxos/functions";
11
- import { Filter, Ref as Ref2, useQuery } from "@dxos/react-client/echo";
12
- import { Form as Form2, SelectInput as SelectInput2, useRefQueryLookupHandler } from "@dxos/react-ui-form";
13
-
14
- // src/components/TriggerEditor/FunctionInputEditor.tsx
15
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
16
- import React, { useCallback, useMemo } from "react";
17
- import { Ref, Type } from "@dxos/echo";
18
- import { useOnTransition } from "@dxos/react-ui";
19
- import { Form, useFormValues } from "@dxos/react-ui-form";
20
- var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
21
- var _effect = _useSignals();
22
- try {
23
- const selectedFunctionValue = useFormValues([
24
- "function"
25
- ]);
26
- const selectedFunctionId = useMemo(() => {
27
- if (Ref.isRef(selectedFunctionValue)) {
28
- return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
29
- }
30
- }, [
31
- selectedFunctionValue
32
- ]);
33
- const selectedFunction = useMemo(() => functions.find((fn) => fn.id === selectedFunctionId), [
34
- functions,
35
- selectedFunctionId
36
- ]);
37
- useOnTransition(
38
- // Clear function parameter input when the function changes.
39
- selectedFunctionValue,
40
- (prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
41
- (currValue) => currValue !== void 0,
42
- () => onValueChange("object", {})
43
- );
44
- const inputSchema = useMemo(() => selectedFunction?.inputSchema, [
45
- selectedFunction
46
- ]);
47
- const effectSchema = useMemo(() => inputSchema ? Type.toEffectSchema(inputSchema) : void 0, [
48
- inputSchema
49
- ]);
50
- const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
51
- const values = useMemo(() => getValue() ?? {}, [
52
- getValue
53
- ]);
54
- const handleValuesChanged = useCallback((values2) => {
55
- onValueChange("object", values2);
56
- }, [
57
- onValueChange
58
- ]);
59
- if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
60
- return null;
61
- }
62
- return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("h3", {
63
- className: "text-md"
64
- }, "Function parameters"), /* @__PURE__ */ React.createElement(Form, {
65
- schema: effectSchema,
66
- values,
67
- onValuesChanged: handleValuesChanged,
68
- onQueryRefOptions,
69
- outerSpacing: false
70
- }));
71
- } finally {
72
- _effect.f();
73
- }
74
- };
75
-
76
- // src/components/TriggerEditor/SpecSelector.tsx
77
- import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
78
- import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
79
- import { TriggerKinds } from "@dxos/functions";
80
- import { useTranslation } from "@dxos/react-ui";
81
- import { SelectInput, useInputProps } from "@dxos/react-ui-form";
82
- var SpecSelector = (props) => {
83
- var _effect = _useSignals2();
84
- try {
85
- const { t } = useTranslation(meta.id);
86
- const specProps = useInputProps([
87
- "spec"
88
- ]);
89
- const handleTypeChange = useCallback2((_type, value) => {
90
- const getDefaultTriggerSpec = (kind) => {
91
- switch (kind) {
92
- case "timer":
93
- return {
94
- kind: "timer",
95
- cron: ""
96
- };
97
- case "subscription":
98
- return {
99
- kind: "subscription",
100
- filter: {}
101
- };
102
- case "queue":
103
- return {
104
- kind: "queue",
105
- queue: ""
106
- };
107
- case "email":
108
- return {
109
- kind: "email"
110
- };
111
- case "webhook":
112
- return {
113
- kind: "webhook"
114
- };
115
- default:
116
- return void 0;
117
- }
118
- };
119
- const defaultSpec = getDefaultTriggerSpec(value);
120
- if (!defaultSpec) {
121
- return;
122
- }
123
- specProps.onValueChange("object", defaultSpec);
124
- }, [
125
- specProps
126
- ]);
127
- const options = useMemo2(() => TriggerKinds.map((kind) => ({
128
- value: kind,
129
- label: t(`trigger type ${kind}`)
130
- })), [
131
- t
132
- ]);
133
- return /* @__PURE__ */ React2.createElement(SelectInput, {
134
- ...props,
135
- options,
136
- onValueChange: handleTypeChange
137
- });
138
- } finally {
139
- _effect.f();
140
- }
141
- };
142
-
143
- // src/components/TriggerEditor/TriggerEditor.tsx
144
- var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
145
- var _effect = _useSignals3();
146
- try {
147
- const handleSave = (values) => {
148
- onSave?.(values);
149
- };
150
- const handleRefQueryLookup = useRefQueryLookupHandler({
151
- space
152
- });
153
- const Custom = useCustomInputs(space, handleRefQueryLookup);
154
- return /* @__PURE__ */ React3.createElement(Form2, {
155
- outerSpacing: false,
156
- Custom,
157
- schema: FunctionTrigger,
158
- values: trigger,
159
- onSave: handleSave,
160
- onCancel,
161
- onQueryRefOptions: handleRefQueryLookup
162
- });
163
- } finally {
164
- _effect.f();
165
- }
166
- };
167
- var useCustomInputs = (space, onQueryRefOptions) => {
168
- const functions = useQuery(space, Filter.type(FunctionType));
169
- const workflows = useQuery(space, Filter.type(ComputeGraph));
170
- const scripts = useQuery(space, Filter.type(ScriptType));
171
- return useMemo3(() => ({
172
- // Function selector.
173
- ["function"]: (props) => {
174
- const getValue = useCallback3(() => {
175
- const formValue = props.getValue();
176
- if (Ref2.isRef(formValue)) {
177
- return formValue.dxn.toString();
178
- }
179
- return void 0;
180
- }, [
181
- props
182
- ]);
183
- const handleOnValueChange = useCallback3((_type, dxnString) => {
184
- const dxn = Type2.DXN.parse(dxnString);
185
- if (dxn) {
186
- const ref = Ref2.fromDXN(dxn);
187
- props.onValueChange("object", ref);
188
- }
189
- }, [
190
- props.onValueChange
191
- ]);
192
- return /* @__PURE__ */ React3.createElement(SelectInput2, {
193
- ...props,
194
- getValue,
195
- onValueChange: handleOnValueChange,
196
- options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
197
- });
198
- },
199
- // Spec selector.
200
- ["spec.kind"]: SpecSelector,
201
- // Function input editor.
202
- ["input"]: (props) => /* @__PURE__ */ React3.createElement(FunctionInputEditor, {
203
- ...props,
204
- functions,
205
- onQueryRefOptions
206
- })
207
- }), [
208
- workflows,
209
- scripts,
210
- functions
211
- ]);
212
- };
213
- var getWorkflowOptions = (graphs) => {
214
- return graphs.map((graph) => ({
215
- label: `compute-${graph.id}`,
216
- value: `dxn:echo:@:${graph.id}`
217
- }));
218
- };
219
- var getFunctionOptions = (scripts, functions) => {
220
- const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
221
- return functions.map((fn) => ({
222
- label: getLabel(fn),
223
- value: `dxn:echo:@:${fn.id}`
224
- }));
225
- };
226
-
227
- export {
228
- TriggerEditor
229
- };
230
- //# sourceMappingURL=chunk-IN2YC7NY.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx", "../../../src/components/TriggerEditor/FunctionInputEditor.tsx", "../../../src/components/TriggerEditor/SpecSelector.tsx"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { ComputeGraph } from '@dxos/conductor';\nimport { Type } from '@dxos/echo';\nimport { FunctionTrigger, FunctionType, ScriptType } from '@dxos/functions';\nimport { Filter, Ref, type Space, useQuery } from '@dxos/react-client/echo';\nimport { type CustomInputMap, Form, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { FunctionInputEditor, type FunctionInputEditorProps } from './FunctionInputEditor';\nimport { SpecSelector } from './SpecSelector';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTrigger;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const handleSave = (values: FunctionTrigger) => {\n onSave?.(values);\n };\n\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n const Custom = useCustomInputs(space, handleRefQueryLookup);\n\n return (\n <Form\n outerSpacing={false}\n Custom={Custom}\n schema={FunctionTrigger}\n values={trigger}\n onSave={handleSave}\n onCancel={onCancel}\n onQueryRefOptions={handleRefQueryLookup}\n />\n );\n};\n\nconst useCustomInputs = (space: Space, onQueryRefOptions: FunctionInputEditorProps['onQueryRefOptions']) => {\n const functions = useQuery(space, Filter.type(FunctionType));\n const workflows = useQuery(space, Filter.type(ComputeGraph));\n const scripts = useQuery(space, Filter.type(ScriptType));\n\n return useMemo(\n (): CustomInputMap => ({\n // Function selector.\n ['function' satisfies keyof FunctionTrigger]: (props) => {\n const getValue = useCallback(() => {\n const formValue = props.getValue();\n if (Ref.isRef(formValue)) {\n return formValue.dxn.toString() as string;\n }\n return undefined;\n }, [props]);\n\n const handleOnValueChange = useCallback(\n (_type: any, dxnString: string) => {\n const dxn = Type.DXN.parse(dxnString);\n if (dxn) {\n const ref = Ref.fromDXN(dxn);\n props.onValueChange('object', ref);\n }\n },\n [props.onValueChange],\n );\n\n return (\n <SelectInput\n {...props}\n getValue={getValue as any}\n onValueChange={handleOnValueChange}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n );\n },\n\n // Spec selector.\n ['spec.kind' as const]: SpecSelector,\n\n // Function input editor.\n ['input' as const]: (props) => (\n <FunctionInputEditor {...props} functions={functions} onQueryRefOptions={onQueryRefOptions} />\n ),\n }),\n [workflows, scripts, functions],\n );\n};\n\nconst getWorkflowOptions = (graphs: ComputeGraph[]) => {\n return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));\n};\n\nconst getFunctionOptions = (scripts: ScriptType[], functions: FunctionType[]) => {\n const getLabel = (fn: FunctionType) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:echo:@:${fn.id}` }));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Ref, Type } from '@dxos/echo';\nimport { type JsonPath } from '@dxos/echo-schema';\nimport { type FunctionType } from '@dxos/functions';\nimport { useOnTransition } from '@dxos/react-ui';\nimport { Form, type FormInputStateProps, type QueryRefOptions, useFormValues } from '@dxos/react-ui-form';\n\nexport type FunctionInputEditorProps = {\n functions: FunctionType[];\n onQueryRefOptions: QueryRefOptions;\n} & FormInputStateProps;\n\n/**\n * Editor component for function input parameters.\n */\nexport const FunctionInputEditor = ({\n functions,\n getValue,\n onValueChange,\n onQueryRefOptions,\n}: FunctionInputEditorProps) => {\n const selectedFunctionValue = useFormValues(['function' as JsonPath]);\n const selectedFunctionId = useMemo(() => {\n if (Ref.isRef(selectedFunctionValue)) {\n return selectedFunctionValue.dxn.toString().split('dxn:echo:@:').at(1);\n }\n }, [selectedFunctionValue]);\n\n const selectedFunction = useMemo(\n () => functions.find((fn) => fn.id === selectedFunctionId),\n [functions, selectedFunctionId],\n );\n\n useOnTransition(\n // Clear function parameter input when the function changes.\n selectedFunctionValue,\n (prevValue) => prevValue !== undefined && prevValue !== selectedFunctionValue,\n (currValue) => currValue !== undefined,\n () => onValueChange('object', {}),\n );\n\n const inputSchema = useMemo(() => selectedFunction?.inputSchema, [selectedFunction]);\n const effectSchema = useMemo(() => (inputSchema ? Type.toEffectSchema(inputSchema) : undefined), [inputSchema]);\n const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;\n\n const values = useMemo(() => getValue() ?? {}, [getValue]);\n\n const handleValuesChanged = useCallback(\n (values: any) => {\n onValueChange('object', values);\n },\n [onValueChange],\n );\n\n if (selectedFunction === undefined || effectSchema === undefined || propertyCount === 0) {\n return null;\n }\n\n return (\n <>\n <h3 className='text-md'>Function parameters</h3>\n {/* TODO(ZaymonFC): Try using <FormFields /> internal component for this nesting.\n This would allow errors to flow up to the root context. */}\n <Form\n schema={effectSchema}\n values={values}\n onValuesChanged={handleValuesChanged}\n onQueryRefOptions={onQueryRefOptions}\n outerSpacing={false}\n />\n </>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { type FunctionTrigger, TriggerKinds, type TriggerType } from '@dxos/functions';\nimport { useTranslation } from '@dxos/react-ui';\nimport { type InputProps, SelectInput, useInputProps } from '@dxos/react-ui-form';\n\nimport { meta } from '../../meta';\n\nexport type SpecSelectorProps = InputProps;\n\nexport const SpecSelector = (props: SpecSelectorProps) => {\n const { t } = useTranslation(meta.id);\n const specProps = useInputProps(['spec' satisfies keyof FunctionTrigger]);\n\n const handleTypeChange = useCallback(\n (_type: any, value: string): TriggerType | undefined => {\n const getDefaultTriggerSpec = (kind: string) => {\n switch (kind) {\n case 'timer':\n return { kind: 'timer', cron: '' };\n case 'subscription':\n return { kind: 'subscription', filter: {} };\n case 'queue':\n return { kind: 'queue', queue: '' };\n case 'email':\n return { kind: 'email' };\n case 'webhook':\n return { kind: 'webhook' };\n default:\n return undefined;\n }\n };\n\n const defaultSpec = getDefaultTriggerSpec(value);\n if (!defaultSpec) {\n return;\n }\n\n // Update the entire spec object, not just the `spec.kind`.\n specProps.onValueChange('object', defaultSpec);\n },\n [specProps],\n );\n\n const options = useMemo(\n () =>\n TriggerKinds.map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n })),\n [t],\n );\n\n return <SelectInput {...props} options={options} onValueChange={handleTypeChange} />;\n};\n"],
5
- "mappings": "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",
6
- "names": ["React", "useCallback", "useMemo", "ComputeGraph", "Type", "FunctionTrigger", "FunctionType", "ScriptType", "Filter", "Ref", "useQuery", "Form", "SelectInput", "useRefQueryLookupHandler", "React", "useCallback", "useMemo", "Ref", "Type", "useOnTransition", "Form", "useFormValues", "FunctionInputEditor", "functions", "getValue", "onValueChange", "onQueryRefOptions", "selectedFunctionValue", "useFormValues", "selectedFunctionId", "useMemo", "Ref", "isRef", "dxn", "toString", "split", "at", "selectedFunction", "find", "fn", "id", "useOnTransition", "prevValue", "undefined", "currValue", "inputSchema", "effectSchema", "Type", "toEffectSchema", "propertyCount", "properties", "Object", "keys", "length", "values", "handleValuesChanged", "useCallback", "h3", "className", "Form", "schema", "onValuesChanged", "outerSpacing", "React", "useCallback", "useMemo", "TriggerKinds", "useTranslation", "SelectInput", "useInputProps", "SpecSelector", "props", "t", "useTranslation", "meta", "id", "specProps", "useInputProps", "handleTypeChange", "useCallback", "_type", "value", "getDefaultTriggerSpec", "kind", "cron", "filter", "queue", "undefined", "defaultSpec", "onValueChange", "options", "useMemo", "TriggerKinds", "map", "label", "React", "SelectInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "handleSave", "values", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "useCustomInputs", "React", "Form", "outerSpacing", "schema", "FunctionTrigger", "onQueryRefOptions", "functions", "useQuery", "Filter", "type", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "useMemo", "props", "getValue", "useCallback", "formValue", "Ref", "isRef", "dxn", "toString", "undefined", "handleOnValueChange", "_type", "dxnString", "Type", "DXN", "parse", "ref", "fromDXN", "onValueChange", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "SpecSelector", "FunctionInputEditor", "graphs", "map", "graph", "label", "id", "value", "getLabel", "fn", "find", "s", "source", "target", "name"]
7
- }
@@ -1,143 +0,0 @@
1
- import {
2
- TriggerEditor
3
- } from "./chunk-IN2YC7NY.mjs";
4
- import {
5
- meta
6
- } from "./chunk-WWURMV25.mjs";
7
-
8
- // src/components/AutomationPanel/AutomationPanel.tsx
9
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
10
- import { Schema } from "effect";
11
- import React, { useState } from "react";
12
- import { Filter, Obj } from "@dxos/echo";
13
- import { FunctionTrigger, FunctionType, ScriptType } from "@dxos/functions";
14
- import { useClient } from "@dxos/react-client";
15
- import { getSpace, useQuery } from "@dxos/react-client/echo";
16
- import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
17
- import { ControlItem, controlItemClasses } from "@dxos/react-ui-form";
18
- import { List } from "@dxos/react-ui-list";
19
- import { ghostHover, mx } from "@dxos/react-ui-theme";
20
- var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
21
- var AutomationPanel = ({ classNames, space, object, initialTrigger, onDone }) => {
22
- var _effect = _useSignals();
23
- try {
24
- const { t } = useTranslation(meta.id);
25
- const client = useClient();
26
- const triggers = useQuery(space, Filter.type(FunctionTrigger));
27
- const functions = useQuery(space, Filter.type(FunctionType));
28
- const scripts = useQuery(space, Filter.type(ScriptType));
29
- const [trigger, setTrigger] = useState(initialTrigger);
30
- const [selected, setSelected] = useState();
31
- const handleSelect = (trigger2) => {
32
- setTrigger(trigger2);
33
- setSelected(trigger2);
34
- };
35
- const handleAdd = () => {
36
- setTrigger(Obj.make(FunctionTrigger, {}));
37
- setSelected(void 0);
38
- };
39
- const handleDelete = (trigger2) => {
40
- space.db.remove(trigger2);
41
- setTrigger(void 0);
42
- setSelected(void 0);
43
- };
44
- const handleSave = (trigger2) => {
45
- if (selected) {
46
- Object.assign(selected, trigger2);
47
- } else {
48
- space.db.add(Obj.make(FunctionTrigger, trigger2));
49
- }
50
- setTrigger(void 0);
51
- setSelected(void 0);
52
- onDone?.();
53
- };
54
- const handleCancel = () => {
55
- setTrigger(void 0);
56
- onDone?.();
57
- };
58
- if (trigger) {
59
- return /* @__PURE__ */ React.createElement(ControlItem, {
60
- title: t("trigger editor title")
61
- }, /* @__PURE__ */ React.createElement(TriggerEditor, {
62
- space,
63
- trigger,
64
- onSave: handleSave,
65
- onCancel: handleCancel
66
- }));
67
- }
68
- return /* @__PURE__ */ React.createElement("div", {
69
- className: mx(controlItemClasses, classNames)
70
- }, triggers.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
71
- items: triggers,
72
- isItem: Schema.is(FunctionTrigger),
73
- getId: (field) => field.id
74
- }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
75
- role: "list",
76
- className: "flex flex-col w-full"
77
- }, triggers2?.map((trigger2) => {
78
- const copyAction = getCopyAction(client, trigger2);
79
- return /* @__PURE__ */ React.createElement(List.Item, {
80
- key: trigger2.id,
81
- item: trigger2,
82
- classNames: mx(grid, ghostHover, "items-center", "px-2")
83
- }, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.Switch, {
84
- checked: trigger2.enabled,
85
- onCheckedChange: (checked) => trigger2.enabled = checked
86
- })), /* @__PURE__ */ React.createElement("div", {
87
- className: "flex"
88
- }, /* @__PURE__ */ React.createElement(List.ItemTitle, {
89
- classNames: "px-1 cursor-pointer w-0 shrink truncate",
90
- onClick: () => handleSelect(trigger2)
91
- }, getFunctionName(scripts, functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
92
- label: t(copyAction.translationKey),
93
- value: copyAction.contentProvider()
94
- })), /* @__PURE__ */ React.createElement(List.ItemDeleteButton, {
95
- onClick: () => handleDelete(trigger2)
96
- }));
97
- }))), triggers.length > 0 && /* @__PURE__ */ React.createElement(Separator, {
98
- classNames: "mlb-4"
99
- }), /* @__PURE__ */ React.createElement(IconButton, {
100
- icon: "ph--plus--regular",
101
- label: t("new trigger label"),
102
- onClick: handleAdd
103
- }));
104
- } finally {
105
- _effect.f();
106
- }
107
- };
108
- var getCopyAction = (client, trigger) => {
109
- if (trigger?.spec?.kind === "email") {
110
- return {
111
- translationKey: "trigger copy email",
112
- contentProvider: () => `${getSpace(trigger).id}@dxos.network`
113
- };
114
- }
115
- if (trigger?.spec?.kind === "webhook") {
116
- return {
117
- translationKey: "trigger copy url",
118
- contentProvider: () => getWebhookUrl(client, trigger)
119
- };
120
- }
121
- return void 0;
122
- };
123
- var getWebhookUrl = (client, trigger) => {
124
- const spaceId = getSpace(trigger).id;
125
- const edgeUrl = new URL(client.config.values.runtime.services.edge.url);
126
- const isSecure = edgeUrl.protocol.startsWith("https") || edgeUrl.protocol.startsWith("wss");
127
- edgeUrl.protocol = isSecure ? "https" : "http";
128
- return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
129
- };
130
- var getFunctionName = (scripts, functions, trigger) => {
131
- const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
132
- const functionObject = functions.find((fn) => fn === trigger.function?.target);
133
- return functionObject?.name ?? shortId;
134
- };
135
-
136
- // src/components/AutomationPanel/index.ts
137
- var AutomationPanel_default = AutomationPanel;
138
-
139
- export {
140
- AutomationPanel,
141
- AutomationPanel_default
142
- };
143
- //# sourceMappingURL=chunk-LNMCGQC2.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/AutomationPanel/index.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport React, { useState } from 'react';\n\nimport { Filter, Obj } from '@dxos/echo';\nimport { FunctionTrigger, FunctionType, ScriptType } from '@dxos/functions';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { type Space, getSpace, useQuery } from '@dxos/react-client/echo';\nimport { Clipboard, IconButton, Input, Separator, type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { ControlItem, controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\n\nimport { meta } from '../../meta';\nimport { TriggerEditor, type TriggerEditorProps } from '../TriggerEditor';\n\nconst grid = 'grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]';\n\nexport type AutomationPanelProps = ThemedClassName<{\n space: Space;\n object?: Obj.Any;\n initialTrigger?: FunctionTrigger;\n onDone?: () => void;\n}>;\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ classNames, space, object, initialTrigger, onDone }: AutomationPanelProps) => {\n const { t } = useTranslation(meta.id);\n const client = useClient();\n const triggers = useQuery(space, Filter.type(FunctionTrigger));\n const functions = useQuery(space, Filter.type(FunctionType));\n const scripts = useQuery(space, Filter.type(ScriptType));\n\n const [trigger, setTrigger] = useState<FunctionTrigger | undefined>(initialTrigger);\n const [selected, setSelected] = useState<FunctionTrigger>();\n\n const handleSelect = (trigger: FunctionTrigger) => {\n setTrigger(trigger);\n setSelected(trigger);\n };\n\n const handleAdd = () => {\n setTrigger(Obj.make(FunctionTrigger, {}));\n setSelected(undefined);\n };\n\n const handleDelete = (trigger: FunctionTrigger) => {\n space.db.remove(trigger);\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleSave: TriggerEditorProps['onSave'] = (trigger) => {\n if (selected) {\n Object.assign(selected, trigger);\n } else {\n space.db.add(Obj.make(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n onDone?.();\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n onDone?.();\n };\n\n if (trigger) {\n return (\n <ControlItem title={t('trigger editor title')}>\n <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />\n </ControlItem>\n );\n }\n\n return (\n <div className={mx(controlItemClasses, classNames)}>\n {triggers.length > 0 && (\n <List.Root<FunctionTrigger> items={triggers} isItem={Schema.is(FunctionTrigger)} getId={(field) => field.id}>\n {({ items: triggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {triggers?.map((trigger) => {\n const copyAction = getCopyAction(client, trigger);\n return (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center', 'px-2')}\n >\n <Input.Root>\n <Input.Switch\n checked={trigger.enabled}\n onCheckedChange={(checked) => (trigger.enabled = checked)}\n />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle\n classNames='px-1 cursor-pointer w-0 shrink truncate'\n onClick={() => handleSelect(trigger)}\n >\n {getFunctionName(scripts, functions, trigger) ?? '∅'}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose copy action */}\n {copyAction && (\n <Clipboard.IconButton\n label={t(copyAction.translationKey)}\n value={copyAction.contentProvider()}\n />\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n )}\n {triggers.length > 0 && <Separator classNames='mlb-4' />}\n <IconButton icon='ph--plus--regular' label={t('new trigger label')} onClick={handleAdd} />\n </div>\n );\n};\n\nconst getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.kind === 'email') {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.kind === 'webhook') {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTrigger) => {\n // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}…`;\n const functionObject = functions.find((fn) => fn === trigger.function?.target);\n return functionObject?.name ?? shortId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AutomationPanel } from './AutomationPanel';\n\nexport * from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
5
- "mappings": "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",
6
- "names": ["Schema", "React", "useState", "Filter", "Obj", "FunctionTrigger", "FunctionType", "ScriptType", "useClient", "getSpace", "useQuery", "Clipboard", "IconButton", "Input", "Separator", "useTranslation", "ControlItem", "controlItemClasses", "List", "ghostHover", "mx", "grid", "AutomationPanel", "classNames", "space", "object", "initialTrigger", "onDone", "t", "useTranslation", "meta", "id", "client", "useClient", "triggers", "useQuery", "Filter", "type", "FunctionTrigger", "functions", "FunctionType", "scripts", "ScriptType", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "handleAdd", "Obj", "make", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "ControlItem", "title", "TriggerEditor", "onSave", "onCancel", "div", "className", "mx", "controlItemClasses", "length", "List", "Root", "items", "isItem", "Schema", "is", "getId", "field", "role", "map", "copyAction", "getCopyAction", "Item", "key", "item", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Clipboard", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "Separator", "icon", "spec", "kind", "getSpace", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "values", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "dxn", "slice", "functionObject", "find", "fn", "target", "name", "AutomationPanel"]
7
- }
@@ -1,53 +0,0 @@
1
- import {
2
- AutomationCapabilities
3
- } from "./chunk-ZTXBAXUT.mjs";
4
-
5
- // src/hooks/useComputeRuntimeCallback.ts
6
- import { useCallback } from "react";
7
- import { useCapability } from "@dxos/app-framework";
8
- var useComputeRuntimeCallback = (space, fn, deps) => {
9
- const computeRuntime = useCapability(AutomationCapabilities.ComputeRuntime);
10
- const runtime = space !== void 0 ? computeRuntime.getRuntime(space.id) : void 0;
11
- return useCallback(() => {
12
- if (!runtime) {
13
- throw new TypeError("Space not provided to useComputeRuntimeCallback");
14
- }
15
- return runtime.runPromise(fn());
16
- }, [
17
- runtime,
18
- ...deps ?? []
19
- ]);
20
- };
21
-
22
- // src/hooks/useTriggerRuntimeControls.ts
23
- import { Effect } from "effect";
24
- import { Filter } from "@dxos/echo";
25
- import { FunctionTrigger, TriggerDispatcher } from "@dxos/functions";
26
- import { useQuery } from "@dxos/react-client/echo";
27
- import { useAsyncState } from "@dxos/react-ui";
28
- var useTriggerRuntimeControls = (space) => {
29
- const triggers = useQuery(space, Filter.type(FunctionTrigger));
30
- const [isRunningState, setIsRunningState] = useAsyncState(useComputeRuntimeCallback(space, () => TriggerDispatcher.pipe(Effect.map((t) => t.running))));
31
- const start = useComputeRuntimeCallback(space, Effect.fnUntraced(function* () {
32
- const dispatcher = yield* TriggerDispatcher;
33
- yield* dispatcher.start();
34
- setIsRunningState(true);
35
- }));
36
- const stop = useComputeRuntimeCallback(space, Effect.fnUntraced(function* () {
37
- const dispatcher = yield* TriggerDispatcher;
38
- yield* dispatcher.stop();
39
- setIsRunningState(false);
40
- }));
41
- return {
42
- triggers,
43
- isRunning: isRunningState ?? false,
44
- start: () => void start(),
45
- stop: () => void stop()
46
- };
47
- };
48
-
49
- export {
50
- useComputeRuntimeCallback,
51
- useTriggerRuntimeControls
52
- };
53
- //# sourceMappingURL=chunk-M2WQCY2T.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/hooks/useComputeRuntimeCallback.ts", "../../../src/hooks/useTriggerRuntimeControls.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport type { Effect } from 'effect';\nimport { useCallback } from 'react';\n\nimport { useCapability } from '@dxos/app-framework';\nimport type { Space } from '@dxos/react-client/echo';\n\nimport { AutomationCapabilities } from '../capabilities';\n\n/**\n * Create an effectful function that has access to compute services\n */\nexport const useComputeRuntimeCallback = <T>(\n space: Space | undefined,\n fn: () => Effect.Effect<T, any, AutomationCapabilities.ComputeServices>,\n deps?: React.DependencyList,\n): (() => Promise<T>) => {\n const computeRuntime = useCapability(AutomationCapabilities.ComputeRuntime);\n const runtime = space !== undefined ? computeRuntime.getRuntime(space.id) : undefined;\n\n return useCallback(() => {\n if (!runtime) {\n throw new TypeError('Space not provided to useComputeRuntimeCallback');\n }\n return runtime.runPromise(fn());\n }, [runtime, ...(deps ?? [])]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Effect } from 'effect';\n\nimport { Filter } from '@dxos/echo';\nimport { FunctionTrigger, TriggerDispatcher } from '@dxos/functions';\nimport { type Space, useQuery } from '@dxos/react-client/echo';\nimport { useAsyncState } from '@dxos/react-ui';\n\nimport { useComputeRuntimeCallback } from './useComputeRuntimeCallback';\n\ninterface TriggerRuntimeControls {\n triggers: FunctionTrigger[];\n isRunning: boolean;\n start: () => void;\n stop: () => void;\n}\n\nexport const useTriggerRuntimeControls = (space: Space | undefined): TriggerRuntimeControls => {\n const triggers = useQuery(space, Filter.type(FunctionTrigger));\n\n const [isRunningState, setIsRunningState] = useAsyncState(\n useComputeRuntimeCallback(space, () => TriggerDispatcher.pipe(Effect.map((t) => t.running))),\n );\n\n const start = useComputeRuntimeCallback(\n space,\n Effect.fnUntraced(function* () {\n const dispatcher = yield* TriggerDispatcher;\n yield* dispatcher.start();\n setIsRunningState(true);\n }),\n );\n\n const stop = useComputeRuntimeCallback(\n space,\n Effect.fnUntraced(function* () {\n const dispatcher = yield* TriggerDispatcher;\n yield* dispatcher.stop();\n setIsRunningState(false);\n }),\n );\n\n return {\n triggers,\n isRunning: isRunningState ?? false,\n start: () => void start(),\n stop: () => void stop(),\n };\n};\n"],
5
- "mappings": ";;;;;AAKA,SAASA,mBAAmB;AAE5B,SAASC,qBAAqB;AAQvB,IAAMC,4BAA4B,CACvCC,OACAC,IACAC,SAAAA;AAEA,QAAMC,iBAAiBC,cAAcC,uBAAuBC,cAAc;AAC1E,QAAMC,UAAUP,UAAUQ,SAAYL,eAAeM,WAAWT,MAAMU,EAAE,IAAIF;AAE5E,SAAOG,YAAY,MAAA;AACjB,QAAI,CAACJ,SAAS;AACZ,YAAM,IAAIK,UAAU,iDAAA;IACtB;AACA,WAAOL,QAAQM,WAAWZ,GAAAA,CAAAA;EAC5B,GAAG;IAACM;OAAaL,QAAQ,CAAA;GAAI;AAC/B;;;ACzBA,SAASY,cAAc;AAEvB,SAASC,cAAc;AACvB,SAASC,iBAAiBC,yBAAyB;AACnD,SAAqBC,gBAAgB;AACrC,SAASC,qBAAqB;AAWvB,IAAMC,4BAA4B,CAACC,UAAAA;AACxC,QAAMC,WAAWC,SAASF,OAAOG,OAAOC,KAAKC,eAAAA,CAAAA;AAE7C,QAAM,CAACC,gBAAgBC,iBAAAA,IAAqBC,cAC1CC,0BAA0BT,OAAO,MAAMU,kBAAkBC,KAAKC,OAAOC,IAAI,CAACC,MAAMA,EAAEC,OAAO,CAAA,CAAA,CAAA;AAG3F,QAAMC,QAAQP,0BACZT,OACAY,OAAOK,WAAW,aAAA;AAChB,UAAMC,aAAa,OAAOR;AAC1B,WAAOQ,WAAWF,MAAK;AACvBT,sBAAkB,IAAA;EACpB,CAAA,CAAA;AAGF,QAAMY,OAAOV,0BACXT,OACAY,OAAOK,WAAW,aAAA;AAChB,UAAMC,aAAa,OAAOR;AAC1B,WAAOQ,WAAWC,KAAI;AACtBZ,sBAAkB,KAAA;EACpB,CAAA,CAAA;AAGF,SAAO;IACLN;IACAmB,WAAWd,kBAAkB;IAC7BU,OAAO,MAAM,KAAKA,MAAAA;IAClBG,MAAM,MAAM,KAAKA,KAAAA;EACnB;AACF;",
6
- "names": ["useCallback", "useCapability", "useComputeRuntimeCallback", "space", "fn", "deps", "computeRuntime", "useCapability", "AutomationCapabilities", "ComputeRuntime", "runtime", "undefined", "getRuntime", "id", "useCallback", "TypeError", "runPromise", "Effect", "Filter", "FunctionTrigger", "TriggerDispatcher", "useQuery", "useAsyncState", "useTriggerRuntimeControls", "space", "triggers", "useQuery", "Filter", "type", "FunctionTrigger", "isRunningState", "setIsRunningState", "useAsyncState", "useComputeRuntimeCallback", "TriggerDispatcher", "pipe", "Effect", "map", "t", "running", "start", "fnUntraced", "dispatcher", "stop", "isRunning"]
7
- }
@@ -1,14 +0,0 @@
1
- // src/components/index.ts
2
- import { lazy } from "react";
3
- var AutomationPanel = lazy(() => import("./AutomationPanel-4QA5G3ZY.mjs"));
4
- var AutomationSettings = lazy(() => import("./AutomationSettings-6XLG2PCK.mjs"));
5
- var FunctionsContainer = lazy(() => import("./FunctionsContainer-BQ6VBDIG.mjs"));
6
- var FunctionsPanel = lazy(() => import("./FunctionsPanel-QBTOFFNU.mjs"));
7
-
8
- export {
9
- AutomationPanel,
10
- AutomationSettings,
11
- FunctionsContainer,
12
- FunctionsPanel
13
- };
14
- //# sourceMappingURL=chunk-U66KBK53.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/index.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './TriggerEditor';\n\nexport const AutomationPanel = lazy(() => import('./AutomationPanel'));\nexport const AutomationSettings = lazy(() => import('./AutomationSettings'));\nexport const FunctionsContainer = lazy(() => import('./FunctionsContainer'));\nexport const FunctionsPanel = lazy(() => import('./FunctionsPanel'));\n"],
5
- "mappings": ";AAIA,SAASA,YAAY;AAId,IAAMC,kBAAkBC,KAAK,MAAM,OAAO,gCAAA,CAAA;AAC1C,IAAMC,qBAAqBD,KAAK,MAAM,OAAO,mCAAA,CAAA;AAC7C,IAAME,qBAAqBF,KAAK,MAAM,OAAO,mCAAA,CAAA;AAC7C,IAAMG,iBAAiBH,KAAK,MAAM,OAAO,+BAAA,CAAA;",
6
- "names": ["lazy", "AutomationPanel", "lazy", "AutomationSettings", "FunctionsContainer", "FunctionsPanel"]
7
- }
@@ -1,13 +0,0 @@
1
- // src/meta.ts
2
- var meta = {
3
- id: "dxos.org/plugin/automation",
4
- name: "Automation",
5
- description: "The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.",
6
- icon: "ph--robot--regular",
7
- source: "https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-automation"
8
- };
9
-
10
- export {
11
- meta
12
- };
13
- //# sourceMappingURL=chunk-WWURMV25.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/meta.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/automation',\n name: 'Automation',\n description:\n 'The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.',\n icon: 'ph--robot--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-automation',\n};\n"],
5
- "mappings": ";AAMO,IAAMA,OAAmB;EAC9BC,IAAI;EACJC,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;AACV;",
6
- "names": ["meta", "id", "name", "description", "icon", "source"]
7
- }
@@ -1,15 +0,0 @@
1
- import {
2
- meta
3
- } from "./chunk-WWURMV25.mjs";
4
-
5
- // src/capabilities/capabilities.ts
6
- import { defineCapability } from "@dxos/app-framework";
7
- (function(AutomationCapabilities2) {
8
- AutomationCapabilities2.ComputeRuntime = defineCapability(`${meta.id}/capability/compute-runtime`);
9
- })(AutomationCapabilities || (AutomationCapabilities = {}));
10
- var AutomationCapabilities;
11
-
12
- export {
13
- AutomationCapabilities
14
- };
15
- //# sourceMappingURL=chunk-ZTXBAXUT.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/capabilities.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type ManagedRuntime } from 'effect';\n\nimport { type AiService, type ToolExecutionService, type ToolResolverService } from '@dxos/ai';\nimport { defineCapability } from '@dxos/app-framework';\nimport type {\n CredentialsService,\n DatabaseService,\n FunctionInvocationService,\n InvocationTracer,\n QueueService,\n TriggerDispatcher,\n TriggerStateStore,\n} from '@dxos/functions';\nimport type { SpaceId } from '@dxos/keys';\n\nimport { meta } from '../meta';\n\nexport namespace AutomationCapabilities {\n /**\n * Service stack for executing agents, functions, and triggers.\n */\n export type ComputeServices =\n | TriggerDispatcher\n | AiService.AiService\n | DatabaseService\n | QueueService\n | CredentialsService\n | FunctionInvocationService\n | InvocationTracer\n | TriggerStateStore\n // TODO(dmaretskyi): Those should be provided at AI-chat call site.\n | ToolResolverService\n | ToolExecutionService;\n\n export interface ComputeRuntimeProvider {\n getRuntime(spaceId: SpaceId): ManagedRuntime.ManagedRuntime<ComputeServices, never>;\n }\n\n /**\n * Runtime for executing agents, functions, and triggers.\n */\n export const ComputeRuntime = defineCapability<ComputeRuntimeProvider>(`${meta.id}/capability/compute-runtime`);\n}\n"],
5
- "mappings": ";;;;;AAOA,SAASA,wBAAwB;UAchBC,yBAAAA;0BAwBFC,iBAAiBC,iBAAyC,GAAGC,KAAKC,EAAE,6BAA6B;AAChH,GAzBiBJ,2BAAAA,yBAAAA,CAAAA,EAAAA;;",
6
- "names": ["defineCapability", "AutomationCapabilities", "ComputeRuntime", "defineCapability", "meta", "id"]
7
- }