@dxos/plugin-automation 0.8.4-main.ae835ea → 0.8.4-main.bc2380dfbc

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 (339) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/neutral/AutomationPanel-T5O4DNQF.mjs +11 -0
  4. package/dist/lib/neutral/AutomationPlugin.mjs +10 -0
  5. package/dist/lib/neutral/AutomationPlugin.node.mjs +1112 -0
  6. package/dist/lib/neutral/AutomationPlugin.node.mjs.map +7 -0
  7. package/dist/lib/neutral/AutomationPlugin.workerd.mjs +23 -0
  8. package/dist/lib/neutral/AutomationPlugin.workerd.mjs.map +7 -0
  9. package/dist/lib/neutral/AutomationSettings-UVS5STCS.mjs +31 -0
  10. package/dist/lib/neutral/AutomationSettings-UVS5STCS.mjs.map +7 -0
  11. package/dist/lib/neutral/FunctionsContainer-CDCM65U4.mjs +38 -0
  12. package/dist/lib/neutral/FunctionsContainer-CDCM65U4.mjs.map +7 -0
  13. package/dist/lib/neutral/FunctionsPanel-SVRKRUXZ.mjs +97 -0
  14. package/dist/lib/neutral/FunctionsPanel-SVRKRUXZ.mjs.map +7 -0
  15. package/dist/lib/neutral/FunctionsRegistry-7ITCFJCW.mjs +95 -0
  16. package/dist/lib/neutral/FunctionsRegistry-7ITCFJCW.mjs.map +7 -0
  17. package/dist/lib/neutral/TriggerSettings-XCHIZPOR.mjs +9 -0
  18. package/dist/lib/neutral/app-graph-builder-GDCGRYEP.mjs +75 -0
  19. package/dist/lib/neutral/app-graph-builder-GDCGRYEP.mjs.map +7 -0
  20. package/dist/lib/neutral/capabilities/index.mjs +15 -0
  21. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  22. package/dist/lib/neutral/capabilities/node.mjs +13 -0
  23. package/dist/lib/neutral/capabilities/node.mjs.map +7 -0
  24. package/dist/lib/neutral/chunk-2JP77CMN.mjs +42 -0
  25. package/dist/lib/neutral/chunk-2JP77CMN.mjs.map +7 -0
  26. package/dist/lib/neutral/chunk-2UYFDJO6.mjs +12 -0
  27. package/dist/lib/neutral/chunk-2UYFDJO6.mjs.map +7 -0
  28. package/dist/lib/{browser/chunk-LZQFZO3B.mjs → neutral/chunk-ATECY555.mjs} +7 -4
  29. package/dist/lib/neutral/chunk-ATECY555.mjs.map +7 -0
  30. package/dist/lib/neutral/chunk-CNFKEN7S.mjs +37 -0
  31. package/dist/lib/neutral/chunk-CNFKEN7S.mjs.map +7 -0
  32. package/dist/lib/neutral/chunk-DSCOLDT5.mjs +93 -0
  33. package/dist/lib/neutral/chunk-DSCOLDT5.mjs.map +7 -0
  34. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  35. package/dist/lib/neutral/chunk-JKVVCWSL.mjs +307 -0
  36. package/dist/lib/neutral/chunk-JKVVCWSL.mjs.map +7 -0
  37. package/dist/lib/neutral/chunk-K3C5ZTZA.mjs +285 -0
  38. package/dist/lib/neutral/chunk-K3C5ZTZA.mjs.map +7 -0
  39. package/dist/lib/neutral/chunk-M3TIHFXN.mjs +8 -0
  40. package/dist/lib/neutral/chunk-M3TIHFXN.mjs.map +7 -0
  41. package/dist/lib/neutral/components/index.mjs +16 -0
  42. package/dist/lib/neutral/compute-runtime-D7MPZJ4R.mjs +222 -0
  43. package/dist/lib/neutral/compute-runtime-D7MPZJ4R.mjs.map +7 -0
  44. package/dist/lib/neutral/containers/index.mjs +13 -0
  45. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  46. package/dist/lib/neutral/create-trigger-from-template-7K3OYOHQ.mjs +68 -0
  47. package/dist/lib/neutral/create-trigger-from-template-7K3OYOHQ.mjs.map +7 -0
  48. package/dist/lib/neutral/hooks/index.mjs +129 -0
  49. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  50. package/dist/lib/neutral/index.mjs +20 -0
  51. package/dist/lib/neutral/meta.json +1 -0
  52. package/dist/lib/neutral/meta.mjs +8 -0
  53. package/dist/lib/neutral/operation-handler-YXGYH5W5.mjs +13 -0
  54. package/dist/lib/neutral/operation-handler-YXGYH5W5.mjs.map +7 -0
  55. package/dist/lib/neutral/operations/index.mjs +8 -0
  56. package/dist/lib/neutral/plugin.mjs +16 -0
  57. package/dist/lib/neutral/plugin.mjs.map +7 -0
  58. package/dist/lib/neutral/react-surface-3OGMAMKV.mjs +57 -0
  59. package/dist/lib/neutral/react-surface-3OGMAMKV.mjs.map +7 -0
  60. package/dist/lib/neutral/testing.mjs +8 -0
  61. package/dist/lib/neutral/testing.mjs.map +7 -0
  62. package/dist/lib/neutral/translations.mjs +47 -0
  63. package/dist/lib/neutral/translations.mjs.map +7 -0
  64. package/dist/lib/neutral/types/index.mjs +16 -0
  65. package/dist/lib/neutral/types/index.mjs.map +7 -0
  66. package/dist/types/src/AutomationPlugin.d.ts +3 -1
  67. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  68. package/dist/types/src/AutomationPlugin.node.d.ts +4 -0
  69. package/dist/types/src/AutomationPlugin.node.d.ts.map +1 -0
  70. package/dist/types/src/AutomationPlugin.test.d.ts +2 -0
  71. package/dist/types/src/AutomationPlugin.test.d.ts.map +1 -0
  72. package/dist/types/src/AutomationPlugin.workerd.d.ts +4 -0
  73. package/dist/types/src/AutomationPlugin.workerd.d.ts.map +1 -0
  74. package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
  75. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  76. package/dist/types/src/capabilities/compute-runtime.d.ts +12 -3
  77. package/dist/types/src/capabilities/compute-runtime.d.ts.map +1 -1
  78. package/dist/types/src/capabilities/index.d.ts +6 -5
  79. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  80. package/dist/types/src/capabilities/node.d.ts +6 -0
  81. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  82. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  83. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  84. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  85. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  86. package/dist/types/src/commands/index.d.ts +2 -0
  87. package/dist/types/src/commands/index.d.ts.map +1 -0
  88. package/dist/types/src/commands/trigger/create/index.d.ts +25 -0
  89. package/dist/types/src/commands/trigger/create/index.d.ts.map +1 -0
  90. package/dist/types/src/commands/trigger/create/queue.d.ts +13 -0
  91. package/dist/types/src/commands/trigger/create/queue.d.ts.map +1 -0
  92. package/dist/types/src/commands/trigger/create/subscription.d.ts +15 -0
  93. package/dist/types/src/commands/trigger/create/subscription.d.ts.map +1 -0
  94. package/dist/types/src/commands/trigger/create/timer.d.ts +13 -0
  95. package/dist/types/src/commands/trigger/create/timer.d.ts.map +1 -0
  96. package/dist/types/src/commands/trigger/index.d.ts +57 -0
  97. package/dist/types/src/commands/trigger/index.d.ts.map +1 -0
  98. package/dist/types/src/commands/trigger/list.d.ts +7 -0
  99. package/dist/types/src/commands/trigger/list.d.ts.map +1 -0
  100. package/dist/types/src/commands/trigger/options.d.ts +11 -0
  101. package/dist/types/src/commands/trigger/options.d.ts.map +1 -0
  102. package/dist/types/src/commands/trigger/remove.d.ts +8 -0
  103. package/dist/types/src/commands/trigger/remove.d.ts.map +1 -0
  104. package/dist/types/src/commands/trigger/update/index.d.ts +28 -0
  105. package/dist/types/src/commands/trigger/update/index.d.ts.map +1 -0
  106. package/dist/types/src/commands/trigger/update/queue.d.ts +12 -0
  107. package/dist/types/src/commands/trigger/update/queue.d.ts.map +1 -0
  108. package/dist/types/src/commands/trigger/update/subscription.d.ts +13 -0
  109. package/dist/types/src/commands/trigger/update/subscription.d.ts.map +1 -0
  110. package/dist/types/src/commands/trigger/update/timer.d.ts +11 -0
  111. package/dist/types/src/commands/trigger/update/timer.d.ts.map +1 -0
  112. package/dist/types/src/commands/trigger/util.d.ts +46 -0
  113. package/dist/types/src/commands/trigger/util.d.ts.map +1 -0
  114. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +5 -6
  115. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  116. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts +32 -28
  117. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  118. package/dist/types/src/components/AutomationPanel/index.d.ts.map +1 -1
  119. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
  120. package/dist/types/src/components/FunctionsPanel/index.d.ts.map +1 -1
  121. package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts +8 -0
  122. package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts.map +1 -0
  123. package/dist/types/src/components/FunctionsRegistry/index.d.ts +4 -0
  124. package/dist/types/src/components/FunctionsRegistry/index.d.ts.map +1 -0
  125. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +12 -9
  126. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +1 -1
  127. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts +6 -3
  128. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +1 -1
  129. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +8 -7
  130. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  131. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts +104 -30
  132. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  133. package/dist/types/src/components/index.d.ts +3 -4
  134. package/dist/types/src/components/index.d.ts.map +1 -1
  135. package/dist/types/src/containers/AutomationSettings/AutomationSettings.d.ts +6 -0
  136. package/dist/types/src/containers/AutomationSettings/AutomationSettings.d.ts.map +1 -0
  137. package/dist/types/src/containers/AutomationSettings/index.d.ts +2 -0
  138. package/dist/types/src/containers/AutomationSettings/index.d.ts.map +1 -0
  139. package/dist/types/src/containers/FunctionsContainer/FunctionsContainer.d.ts +4 -0
  140. package/dist/types/src/containers/FunctionsContainer/FunctionsContainer.d.ts.map +1 -0
  141. package/dist/types/src/containers/FunctionsContainer/index.d.ts +2 -0
  142. package/dist/types/src/containers/FunctionsContainer/index.d.ts.map +1 -0
  143. package/dist/types/src/containers/TriggerSettings/TriggerSettings.d.ts.map +1 -0
  144. package/dist/types/src/containers/TriggerSettings/index.d.ts +3 -0
  145. package/dist/types/src/containers/TriggerSettings/index.d.ts.map +1 -0
  146. package/dist/types/src/containers/index.d.ts +5 -0
  147. package/dist/types/src/containers/index.d.ts.map +1 -0
  148. package/dist/types/src/hooks/index.d.ts +2 -0
  149. package/dist/types/src/hooks/index.d.ts.map +1 -1
  150. package/dist/types/src/hooks/useComputeRuntime.d.ts +8 -0
  151. package/dist/types/src/hooks/useComputeRuntime.d.ts.map +1 -0
  152. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts +5 -4
  153. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts.map +1 -1
  154. package/dist/types/src/hooks/useComputeRuntimeService.d.ts +17 -0
  155. package/dist/types/src/hooks/useComputeRuntimeService.d.ts.map +1 -0
  156. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts +5 -4
  157. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts.map +1 -1
  158. package/dist/types/src/index.d.ts +1 -5
  159. package/dist/types/src/index.d.ts.map +1 -1
  160. package/dist/types/src/meta.d.ts +2 -2
  161. package/dist/types/src/meta.d.ts.map +1 -1
  162. package/dist/types/src/operations/create-trigger-from-template.d.ts +5 -0
  163. package/dist/types/src/operations/create-trigger-from-template.d.ts.map +1 -0
  164. package/dist/types/src/operations/index.d.ts +3 -0
  165. package/dist/types/src/operations/index.d.ts.map +1 -0
  166. package/dist/types/src/plugin.d.ts +4 -0
  167. package/dist/types/src/plugin.d.ts.map +1 -0
  168. package/dist/types/src/testing/test-functions.d.ts +204 -3
  169. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  170. package/dist/types/src/testing.d.ts +2 -0
  171. package/dist/types/src/testing.d.ts.map +1 -0
  172. package/dist/types/src/translations.d.ts +32 -29
  173. package/dist/types/src/translations.d.ts.map +1 -1
  174. package/dist/types/src/types/AutomationCapabilities.d.ts +22 -0
  175. package/dist/types/src/types/AutomationCapabilities.d.ts.map +1 -0
  176. package/dist/types/src/types/AutomationEvents.d.ts +3 -0
  177. package/dist/types/src/types/AutomationEvents.d.ts.map +1 -0
  178. package/dist/types/src/types/AutomationOperation.d.ts +19 -0
  179. package/dist/types/src/types/AutomationOperation.d.ts.map +1 -0
  180. package/dist/types/src/types/index.d.ts +3 -0
  181. package/dist/types/src/types/index.d.ts.map +1 -1
  182. package/dist/types/src/types/schema.d.ts +11 -3
  183. package/dist/types/src/types/schema.d.ts.map +1 -1
  184. package/dist/types/tsconfig.tsbuildinfo +1 -1
  185. package/package.json +142 -68
  186. package/src/AutomationPlugin.node.ts +29 -0
  187. package/src/AutomationPlugin.test.ts +27 -0
  188. package/src/AutomationPlugin.tsx +20 -37
  189. package/src/AutomationPlugin.workerd.ts +18 -0
  190. package/src/capabilities/app-graph-builder.ts +59 -80
  191. package/src/capabilities/compute-runtime.ts +266 -78
  192. package/src/capabilities/index.ts +9 -7
  193. package/src/capabilities/node.ts +13 -0
  194. package/src/capabilities/operation-handler.ts +16 -0
  195. package/src/capabilities/react-surface.tsx +49 -45
  196. package/src/commands/index.ts +5 -0
  197. package/src/commands/trigger/create/index.ts +14 -0
  198. package/src/commands/trigger/create/queue.ts +86 -0
  199. package/src/commands/trigger/create/subscription.ts +125 -0
  200. package/src/commands/trigger/create/timer.ts +90 -0
  201. package/src/commands/trigger/index.ts +16 -0
  202. package/src/commands/trigger/list.ts +70 -0
  203. package/src/commands/trigger/options.ts +59 -0
  204. package/src/commands/trigger/remove.ts +44 -0
  205. package/src/commands/trigger/update/index.ts +14 -0
  206. package/src/commands/trigger/update/queue.ts +194 -0
  207. package/src/commands/trigger/update/subscription.ts +278 -0
  208. package/src/commands/trigger/update/timer.ts +193 -0
  209. package/src/commands/trigger/util.ts +412 -0
  210. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +14 -7
  211. package/src/components/AutomationPanel/AutomationPanel.tsx +229 -85
  212. package/src/components/FunctionsPanel/FunctionsPanel.tsx +42 -34
  213. package/src/components/FunctionsRegistry/FunctionsRegistry.tsx +119 -0
  214. package/src/components/FunctionsRegistry/index.ts +8 -0
  215. package/src/components/TriggerEditor/FunctionInputEditor.tsx +34 -33
  216. package/src/components/TriggerEditor/SpecSelector.tsx +25 -19
  217. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +90 -38
  218. package/src/components/TriggerEditor/TriggerEditor.tsx +89 -48
  219. package/src/components/index.ts +1 -2
  220. package/src/containers/AutomationSettings/AutomationSettings.tsx +31 -0
  221. package/src/containers/AutomationSettings/index.ts +5 -0
  222. package/src/containers/FunctionsContainer/FunctionsContainer.tsx +33 -0
  223. package/src/containers/FunctionsContainer/index.ts +5 -0
  224. package/src/containers/TriggerSettings/TriggerSettings.tsx +48 -0
  225. package/src/containers/TriggerSettings/index.ts +6 -0
  226. package/src/containers/index.ts +9 -0
  227. package/src/hooks/index.ts +3 -0
  228. package/src/hooks/useComputeRuntime.ts +30 -0
  229. package/src/hooks/useComputeRuntimeCallback.ts +11 -12
  230. package/src/hooks/useComputeRuntimeService.ts +64 -0
  231. package/src/hooks/useTriggerRuntimeControls.ts +32 -14
  232. package/src/index.ts +1 -6
  233. package/src/meta.ts +5 -4
  234. package/src/operations/create-trigger-from-template.ts +71 -0
  235. package/src/operations/index.ts +7 -0
  236. package/src/plugin.ts +11 -0
  237. package/src/testing/test-functions.ts +12 -9
  238. package/src/testing.ts +7 -0
  239. package/src/translations.ts +39 -34
  240. package/src/types/AutomationCapabilities.ts +48 -0
  241. package/src/types/AutomationEvents.ts +11 -0
  242. package/src/types/AutomationOperation.ts +30 -0
  243. package/src/types/index.ts +4 -0
  244. package/src/types/schema.ts +5 -5
  245. package/dist/lib/browser/AutomationPanel-LBXJDM6Z.mjs +0 -11
  246. package/dist/lib/browser/AutomationSettings-IIEI5D2K.mjs +0 -68
  247. package/dist/lib/browser/AutomationSettings-IIEI5D2K.mjs.map +0 -7
  248. package/dist/lib/browser/FunctionsContainer-IZTCGNJZ.mjs +0 -36
  249. package/dist/lib/browser/FunctionsContainer-IZTCGNJZ.mjs.map +0 -7
  250. package/dist/lib/browser/FunctionsPanel-HFCK3JRB.mjs +0 -10
  251. package/dist/lib/browser/app-graph-builder-7VKA2GS3.mjs +0 -81
  252. package/dist/lib/browser/app-graph-builder-7VKA2GS3.mjs.map +0 -7
  253. package/dist/lib/browser/chunk-CVYJM6OO.mjs +0 -66
  254. package/dist/lib/browser/chunk-CVYJM6OO.mjs.map +0 -7
  255. package/dist/lib/browser/chunk-FHSN7G4H.mjs +0 -107
  256. package/dist/lib/browser/chunk-FHSN7G4H.mjs.map +0 -7
  257. package/dist/lib/browser/chunk-GCGHLQM2.mjs +0 -15
  258. package/dist/lib/browser/chunk-GCGHLQM2.mjs.map +0 -7
  259. package/dist/lib/browser/chunk-JW7XSPYW.mjs +0 -267
  260. package/dist/lib/browser/chunk-JW7XSPYW.mjs.map +0 -7
  261. package/dist/lib/browser/chunk-K5YNWESC.mjs +0 -183
  262. package/dist/lib/browser/chunk-K5YNWESC.mjs.map +0 -7
  263. package/dist/lib/browser/chunk-LZQFZO3B.mjs.map +0 -7
  264. package/dist/lib/browser/chunk-XXZNGORC.mjs +0 -14
  265. package/dist/lib/browser/chunk-XXZNGORC.mjs.map +0 -7
  266. package/dist/lib/browser/chunk-YBPJCY3F.mjs +0 -38
  267. package/dist/lib/browser/chunk-YBPJCY3F.mjs.map +0 -7
  268. package/dist/lib/browser/compute-runtime-PFYRMGN2.mjs +0 -114
  269. package/dist/lib/browser/compute-runtime-PFYRMGN2.mjs.map +0 -7
  270. package/dist/lib/browser/hooks/index.mjs +0 -11
  271. package/dist/lib/browser/index.mjs +0 -126
  272. package/dist/lib/browser/index.mjs.map +0 -7
  273. package/dist/lib/browser/intent-resolver-5HR7M7T6.mjs +0 -77
  274. package/dist/lib/browser/intent-resolver-5HR7M7T6.mjs.map +0 -7
  275. package/dist/lib/browser/meta.json +0 -1
  276. package/dist/lib/browser/react-surface-WPMY3EX2.mjs +0 -63
  277. package/dist/lib/browser/react-surface-WPMY3EX2.mjs.map +0 -7
  278. package/dist/lib/browser/types/index.mjs +0 -8
  279. package/dist/lib/node-esm/AutomationPanel-NVEIUIZP.mjs +0 -12
  280. package/dist/lib/node-esm/AutomationSettings-VIIEPI2P.mjs +0 -69
  281. package/dist/lib/node-esm/AutomationSettings-VIIEPI2P.mjs.map +0 -7
  282. package/dist/lib/node-esm/FunctionsContainer-KKRCIXGB.mjs +0 -37
  283. package/dist/lib/node-esm/FunctionsContainer-KKRCIXGB.mjs.map +0 -7
  284. package/dist/lib/node-esm/FunctionsPanel-74ELGR7P.mjs +0 -11
  285. package/dist/lib/node-esm/app-graph-builder-RTOFJNFV.mjs +0 -82
  286. package/dist/lib/node-esm/app-graph-builder-RTOFJNFV.mjs.map +0 -7
  287. package/dist/lib/node-esm/chunk-3BJ6BR3E.mjs +0 -67
  288. package/dist/lib/node-esm/chunk-3BJ6BR3E.mjs.map +0 -7
  289. package/dist/lib/node-esm/chunk-CEVIVRTY.mjs +0 -19
  290. package/dist/lib/node-esm/chunk-CEVIVRTY.mjs.map +0 -7
  291. package/dist/lib/node-esm/chunk-ECJKIUBO.mjs +0 -39
  292. package/dist/lib/node-esm/chunk-ECJKIUBO.mjs.map +0 -7
  293. package/dist/lib/node-esm/chunk-JOCKHLFT.mjs +0 -108
  294. package/dist/lib/node-esm/chunk-JOCKHLFT.mjs.map +0 -7
  295. package/dist/lib/node-esm/chunk-MRYKW5TM.mjs +0 -16
  296. package/dist/lib/node-esm/chunk-MRYKW5TM.mjs.map +0 -7
  297. package/dist/lib/node-esm/chunk-U5Q2NI7H.mjs +0 -16
  298. package/dist/lib/node-esm/chunk-U5Q2NI7H.mjs.map +0 -7
  299. package/dist/lib/node-esm/chunk-W76WUTZY.mjs +0 -268
  300. package/dist/lib/node-esm/chunk-W76WUTZY.mjs.map +0 -7
  301. package/dist/lib/node-esm/chunk-Y7PJXFCJ.mjs +0 -184
  302. package/dist/lib/node-esm/chunk-Y7PJXFCJ.mjs.map +0 -7
  303. package/dist/lib/node-esm/compute-runtime-IXCSD3W7.mjs +0 -115
  304. package/dist/lib/node-esm/compute-runtime-IXCSD3W7.mjs.map +0 -7
  305. package/dist/lib/node-esm/hooks/index.mjs +0 -12
  306. package/dist/lib/node-esm/index.mjs +0 -127
  307. package/dist/lib/node-esm/index.mjs.map +0 -7
  308. package/dist/lib/node-esm/intent-resolver-KDRYB5BC.mjs +0 -78
  309. package/dist/lib/node-esm/intent-resolver-KDRYB5BC.mjs.map +0 -7
  310. package/dist/lib/node-esm/meta.json +0 -1
  311. package/dist/lib/node-esm/react-surface-Y2BBJV2I.mjs +0 -64
  312. package/dist/lib/node-esm/react-surface-Y2BBJV2I.mjs.map +0 -7
  313. package/dist/lib/node-esm/types/index.mjs +0 -9
  314. package/dist/types/src/capabilities/capabilities.d.ts +0 -19
  315. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  316. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  317. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  318. package/dist/types/src/components/AutomationSettings.d.ts +0 -5
  319. package/dist/types/src/components/AutomationSettings.d.ts.map +0 -1
  320. package/dist/types/src/components/FunctionsContainer.d.ts +0 -7
  321. package/dist/types/src/components/FunctionsContainer.d.ts.map +0 -1
  322. package/dist/types/src/components/TriggerSettings.d.ts.map +0 -1
  323. package/dist/types/src/events.d.ts +0 -4
  324. package/dist/types/src/events.d.ts.map +0 -1
  325. package/src/capabilities/capabilities.ts +0 -48
  326. package/src/capabilities/intent-resolver.ts +0 -72
  327. package/src/components/AutomationSettings.tsx +0 -30
  328. package/src/components/FunctionsContainer.tsx +0 -29
  329. package/src/components/TriggerSettings.tsx +0 -25
  330. package/src/events.ts +0 -11
  331. /package/dist/lib/{browser/AutomationPanel-LBXJDM6Z.mjs.map → neutral/AutomationPanel-T5O4DNQF.mjs.map} +0 -0
  332. /package/dist/lib/{browser/FunctionsPanel-HFCK3JRB.mjs.map → neutral/AutomationPlugin.mjs.map} +0 -0
  333. /package/dist/lib/{browser/hooks/index.mjs.map → neutral/TriggerSettings-XCHIZPOR.mjs.map} +0 -0
  334. /package/dist/lib/{browser/types/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
  335. /package/dist/lib/{node-esm/hooks → neutral/components}/index.mjs.map +0 -0
  336. /package/dist/lib/{node-esm/types → neutral}/index.mjs.map +0 -0
  337. /package/dist/lib/{node-esm/AutomationPanel-NVEIUIZP.mjs.map → neutral/meta.mjs.map} +0 -0
  338. /package/dist/lib/{node-esm/FunctionsPanel-74ELGR7P.mjs.map → neutral/operations/index.mjs.map} +0 -0
  339. /package/dist/types/src/{components → containers/TriggerSettings}/TriggerSettings.d.ts +0 -0
@@ -0,0 +1,8 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { FunctionsRegistry } from './FunctionsRegistry';
6
+
7
+ export { FunctionsRegistry };
8
+ export default FunctionsRegistry;
@@ -2,29 +2,26 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
+ import type * as SchemaAST from 'effect/SchemaAST';
5
6
  import React, { useCallback, useMemo } from 'react';
6
7
 
7
- import { Ref, Type } from '@dxos/echo';
8
+ import { type Operation } from '@dxos/compute';
9
+ import { type Database, JsonSchema, Obj, Ref } from '@dxos/echo';
8
10
  import { type JsonPath } from '@dxos/echo/internal';
9
- import { type Function } from '@dxos/functions';
10
- import { useOnTransition } from '@dxos/react-ui';
11
- import { Form, type FormInputStateProps, type QueryRefOptions, useFormValues } from '@dxos/react-ui-form';
11
+ import { useOnTransition, useTranslation } from '@dxos/react-ui';
12
+ import { Form, type FormFieldStateProps, type FormRootProps, useFormValues } from '@dxos/react-ui-form';
13
+
14
+ import { meta } from '#meta';
12
15
 
13
16
  export type FunctionInputEditorProps = {
14
- functions: Function.Function[];
15
- onQueryRefOptions: QueryRefOptions;
16
- } & FormInputStateProps;
17
+ type: SchemaAST.AST;
18
+ functions: Operation.PersistentOperation[];
19
+ db?: Database.Database;
20
+ } & FormFieldStateProps;
17
21
 
18
- /**
19
- * Editor component for function input parameters.
20
- */
21
- export const FunctionInputEditor = ({
22
- functions,
23
- getValue,
24
- onValueChange,
25
- onQueryRefOptions,
26
- }: FunctionInputEditorProps) => {
27
- const selectedFunctionValue = useFormValues(['function' as JsonPath]);
22
+ export const FunctionInputEditor = ({ type, functions, db, getValue, onValueChange }: FunctionInputEditorProps) => {
23
+ const { t } = useTranslation(meta.id);
24
+ const selectedFunctionValue = useFormValues(FunctionInputEditor.displayName, ['function' as JsonPath]);
28
25
  const selectedFunctionId = useMemo(() => {
29
26
  if (Ref.isRef(selectedFunctionValue)) {
30
27
  return selectedFunctionValue.dxn.toString().split('dxn:echo:@:').at(1);
@@ -47,20 +44,22 @@ export const FunctionInputEditor = ({
47
44
  return prevValue.dxn.toString() !== selectedFunctionValue.dxn.toString();
48
45
  },
49
46
  (currValue) => currValue !== undefined,
50
- () => onValueChange('object', {}),
47
+ () => onValueChange(type, {}),
51
48
  );
52
49
 
53
50
  const inputSchema = useMemo(() => selectedFunction?.inputSchema, [selectedFunction]);
54
- const effectSchema = useMemo(() => (inputSchema ? Type.toEffectSchema(inputSchema) : undefined), [inputSchema]);
51
+ const effectSchema = useMemo(() => (inputSchema ? JsonSchema.toEffectSchema(inputSchema) : undefined), [inputSchema]);
55
52
  const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
53
+ const defaultValues = useMemo(() => {
54
+ const raw = getValue() ?? {};
55
+ return Obj.isObject(raw) ? { ...Obj.getSnapshot(raw) } : { ...raw };
56
+ }, [getValue]);
56
57
 
57
- const values = useMemo(() => getValue() ?? {}, [getValue]);
58
-
59
- const handleValuesChanged = useCallback(
60
- (values: any) => {
61
- onValueChange('object', values);
58
+ const handleValuesChanged = useCallback<NonNullable<FormRootProps['onValuesChanged']>>(
59
+ (values) => {
60
+ onValueChange(type, values);
62
61
  },
63
- [onValueChange],
62
+ [type, onValueChange],
64
63
  );
65
64
 
66
65
  if (selectedFunction === undefined || effectSchema === undefined || propertyCount === 0) {
@@ -69,16 +68,18 @@ export const FunctionInputEditor = ({
69
68
 
70
69
  return (
71
70
  <>
72
- <h3 className='text-md'>Function parameters</h3>
73
- {/* TODO(ZaymonFC): Try using <FormFields /> internal component for this nesting.
74
- This would allow errors to flow up to the root context. */}
75
- <Form
71
+ <Form.Label label={t('function-parameters.label')} asChild />
72
+ <Form.Root
73
+ key={selectedFunction.id}
76
74
  schema={effectSchema}
77
- values={values}
75
+ defaultValues={defaultValues}
76
+ db={db}
78
77
  onValuesChanged={handleValuesChanged}
79
- onQueryRefOptions={onQueryRefOptions}
80
- outerSpacing={false}
81
- />
78
+ >
79
+ <Form.FieldSet />
80
+ </Form.Root>
82
81
  </>
83
82
  );
84
83
  };
84
+
85
+ FunctionInputEditor.displayName = 'AutomationTrigger.FunctionInputEditor';
@@ -4,38 +4,33 @@
4
4
 
5
5
  import React, { useCallback, useMemo } from 'react';
6
6
 
7
+ import { Trigger } from '@dxos/compute';
7
8
  import { Filter, Query } from '@dxos/echo';
8
- import { Trigger } from '@dxos/functions';
9
9
  import { useTranslation } from '@dxos/react-ui';
10
- import { type InputProps, SelectInput, useInputProps } from '@dxos/react-ui-form';
10
+ import { type FormFieldComponentProps, SelectField, useFormFieldState } from '@dxos/react-ui-form';
11
11
 
12
- import { meta } from '../../meta';
12
+ import { meta } from '#meta';
13
13
 
14
- export type SpecSelectorProps = InputProps;
14
+ export type SpecSelectorProps = FormFieldComponentProps;
15
15
 
16
16
  export const SpecSelector = (props: SpecSelectorProps) => {
17
17
  const { t } = useTranslation(meta.id);
18
- const specProps = useInputProps(['spec' satisfies keyof Trigger.Trigger]);
18
+ const specProps = useFormFieldState(SpecSelector.displayName, ['spec' satisfies keyof Trigger.Trigger]);
19
19
 
20
20
  const handleTypeChange = useCallback(
21
21
  (_type: any, value: string): Trigger.Spec | undefined => {
22
22
  const getDefaultTriggerSpec = (kind: string) => {
23
23
  switch (kind) {
24
24
  case 'timer':
25
- return { kind: 'timer', cron: '' };
25
+ return Trigger.specTimer('');
26
26
  case 'subscription':
27
- return {
28
- kind: 'subscription',
29
- query: {
30
- ast: Query.select(Filter.nothing()).ast,
31
- },
32
- };
27
+ return Trigger.specSubscription(Query.select(Filter.nothing()));
33
28
  case 'queue':
34
- return { kind: 'queue', queue: 'dxn:' };
29
+ return Trigger.specQueue('dxn:queue:default');
35
30
  case 'email':
36
- return { kind: 'email' };
31
+ return Trigger.specEmail();
37
32
  case 'webhook':
38
- return { kind: 'webhook' };
33
+ return Trigger.specWebhook();
39
34
  default:
40
35
  return undefined;
41
36
  }
@@ -47,19 +42,30 @@ export const SpecSelector = (props: SpecSelectorProps) => {
47
42
  }
48
43
 
49
44
  // Update the entire spec object, not just the `spec.kind`.
50
- specProps.onValueChange('object', defaultSpec);
45
+ specProps.onValueChange(props.type, defaultSpec);
51
46
  },
52
- [specProps],
47
+ [props.type, specProps],
53
48
  );
54
49
 
50
+ const kindLabels: Record<string, string> = {
51
+ timer: t('trigger-type.timer.label'),
52
+ webhook: t('trigger-type.webhook.label'),
53
+ websocket: t('trigger-type.websocket.label'),
54
+ subscription: t('trigger-type.subscription.label'),
55
+ email: t('trigger-type.email.label'),
56
+ queue: t('trigger-type.queue.label'),
57
+ };
58
+
55
59
  const options = useMemo(
56
60
  () =>
57
61
  Trigger.Kinds.map((kind) => ({
58
62
  value: kind,
59
- label: t(`trigger type ${kind}`),
63
+ label: kindLabels[kind],
60
64
  })),
61
65
  [t],
62
66
  );
63
67
 
64
- return <SelectInput {...props} options={options} onValueChange={handleTypeChange} />;
68
+ return <SelectField {...props} options={options} onValueChange={handleTypeChange} />;
65
69
  };
70
+
71
+ SpecSelector.displayName = 'Form.SpecSelector';
@@ -4,47 +4,49 @@
4
4
 
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React, { useState } from 'react';
7
+ import { expect, userEvent, within } from 'storybook/test';
7
8
 
9
+ import { Operation, Trigger } from '@dxos/compute';
8
10
  import { Filter, Obj, Ref, Tag, Type } from '@dxos/echo';
9
- import { Function, Trigger } from '@dxos/functions';
10
11
  import { invariant } from '@dxos/invariant';
11
- import { faker } from '@dxos/random';
12
+ import { random } from '@dxos/random';
12
13
  import { useQuery } from '@dxos/react-client/echo';
13
- import { ContactType, useClientProvider, withClientProvider } from '@dxos/react-client/testing';
14
+ import { TestSchema, useClientStory, withClientProvider } from '@dxos/react-client/testing';
14
15
  import { useAsyncEffect } from '@dxos/react-ui';
16
+ import { translations as formTranslations } from '@dxos/react-ui-form/translations';
15
17
  import { withLayout, withTheme } from '@dxos/react-ui/testing';
16
- import { DataType } from '@dxos/schema';
18
+ import { Employer, Organization, Person, Pipeline } from '@dxos/types';
17
19
 
18
- import { functions } from '../../testing';
19
- import { translations } from '../../translations';
20
+ import { functions } from '#testing';
21
+ import { translations } from '#translations';
20
22
 
21
23
  import { TriggerEditor, type TriggerEditorProps } from './TriggerEditor';
22
24
 
23
25
  const types = [
24
26
  // TODO(burdon): Get label from annotation.
25
- { value: Type.getTypename(DataType.Organization), label: 'Organization' },
26
- { value: Type.getTypename(DataType.Person), label: 'Person' },
27
- { value: Type.getTypename(DataType.Project), label: 'Project' },
28
- { value: Type.getTypename(DataType.Employer), label: 'Employer' },
27
+ { value: Organization.Organization.typename, label: 'Organization' },
28
+ { value: Person.Person.typename, label: 'Person' },
29
+ { value: Type.getTypename(Pipeline.Pipeline), label: 'Project' },
30
+ { value: Employer.Employer.typename, label: 'Employer' },
29
31
  ];
30
32
 
31
33
  const DefaultStory = (props: Partial<TriggerEditorProps>) => {
32
- const { space } = useClientProvider();
34
+ const { space } = useClientStory();
33
35
  const [trigger, setTrigger] = useState<Trigger.Trigger>();
34
- const tags = useQuery(space, Filter.type(Tag.Tag));
36
+ const tags = useQuery(space?.db, Filter.type(Tag.Tag));
35
37
 
36
38
  useAsyncEffect(async () => {
37
39
  if (!space) {
38
40
  return;
39
41
  }
40
42
 
41
- const result = await space.db.query(Filter.type(Function.Function)).run();
42
- const fn = result.objects.find((fn) => fn.name === 'example.com/function/forex');
43
+ const functions = await space.db.query(Filter.type(Operation.PersistentOperation)).run();
44
+ const fn = functions.find((fn) => fn.name === 'com.example.function.forex');
43
45
  invariant(fn);
44
46
  const trigger = space.db.add(
45
47
  Trigger.make({
46
48
  function: Ref.make(fn),
47
- spec: { kind: 'webhook' },
49
+ spec: Trigger.specWebhook(),
48
50
  input: {
49
51
  from: 'USD',
50
52
  to: 'JPY',
@@ -59,42 +61,50 @@ const DefaultStory = (props: Partial<TriggerEditorProps>) => {
59
61
  }
60
62
 
61
63
  return (
62
- <div role='none' className='w-[32rem] bs-fit border border-separator rounded-sm'>
63
- <TriggerEditor
64
- space={space}
65
- trigger={trigger}
66
- types={types}
67
- tags={tags}
68
- onSave={(values) => console.log('on save', values)}
69
- {...props}
70
- />
71
- </div>
64
+ <TriggerEditor
65
+ db={space.db}
66
+ trigger={trigger}
67
+ types={types}
68
+ tags={tags}
69
+ onSave={(values) => console.log('on save', values)}
70
+ {...props}
71
+ />
72
72
  );
73
73
  };
74
74
 
75
75
  const meta = {
76
- title: 'plugins/plugin-automation/TriggerEditor',
76
+ title: 'plugins/plugin-automation/components/TriggerEditor',
77
77
  component: TriggerEditor as any,
78
78
  render: DefaultStory,
79
79
  decorators: [
80
- withTheme,
81
- withLayout({ container: 'column' }),
80
+ withTheme(),
81
+ withLayout({ layout: 'column' }),
82
82
  withClientProvider({
83
83
  createIdentity: true,
84
84
  createSpace: true,
85
- types: [Tag.Tag, Function.Function, Trigger.Trigger, ContactType],
85
+ types: [Tag.Tag, Operation.PersistentOperation, Trigger.Trigger, TestSchema.ContactType],
86
86
  onCreateSpace: ({ space }) => {
87
- space.db.add(Tag.make({ label: 'Important' }));
88
- space.db.add(Tag.make({ label: 'Investor' }));
89
- space.db.add(Tag.make({ label: 'New' }));
87
+ // Tags.
88
+ ['Important', 'Investor', 'New'].forEach((label) => {
89
+ space.db.add(Tag.make({ label }));
90
+ });
91
+
92
+ // Functions.
93
+ functions.forEach((fn) => {
94
+ const { key, version, ...data } = fn;
95
+ space.db.add(
96
+ Obj.make(Operation.PersistentOperation, {
97
+ [Obj.Meta]: { key, version: version ?? '0.1.0' },
98
+ ...data,
99
+ }),
100
+ );
101
+ });
90
102
 
91
- for (const fn of functions) {
92
- space.db.add(Function.make(fn));
93
- }
103
+ // Objects.
94
104
  Array.from({ length: 10 }).map(() => {
95
105
  return space.db.add(
96
- Obj.make(ContactType, {
97
- name: faker.person.fullName(),
106
+ Obj.make(TestSchema.ContactType, {
107
+ name: random.person.fullName(),
98
108
  identifiers: [],
99
109
  }),
100
110
  );
@@ -103,7 +113,8 @@ const meta = {
103
113
  }),
104
114
  ],
105
115
  parameters: {
106
- translations,
116
+ layout: 'fullscreen',
117
+ translations: [...formTranslations, ...translations],
107
118
  },
108
119
  } satisfies Meta<typeof DefaultStory>;
109
120
 
@@ -118,3 +129,44 @@ export const ReadonlySpec: Story = {
118
129
  readonlySpec: true,
119
130
  },
120
131
  };
132
+
133
+ export const Spec: Story = {
134
+ play: async ({ canvasElement }) => {
135
+ const canvas = within(canvasElement);
136
+ const webhookText = await canvas.findByText('Webhook', {}, { timeout: 10_000 });
137
+ const combobox = webhookText.closest('[role="combobox"]') as HTMLElement;
138
+ await expect(combobox).not.toBeDisabled();
139
+
140
+ // Helper to switch to a kind via keyboard.
141
+ // TODO(wittjosiah): Radix Select in popper mode doesn't close on click.
142
+ // Use keyboard navigation: open, type first letter to jump, Enter to select.
143
+ const selectKind = async (combobox: HTMLElement, firstLetter: string) => {
144
+ combobox.focus();
145
+ await userEvent.keyboard('{Enter}');
146
+ await userEvent.keyboard(firstLetter);
147
+ await userEvent.keyboard('{Enter}');
148
+ };
149
+
150
+ // Timer — should show "Cron" field.
151
+ await selectKind(combobox, 't');
152
+ await expect(canvas.findByLabelText('Cron')).resolves.toBeInTheDocument();
153
+
154
+ // Email — no extra fields; Cron should be gone.
155
+ await selectKind(combobox, 'e');
156
+ await expect(combobox).not.toBeDisabled();
157
+ await expect(canvas.queryByLabelText('Cron')).not.toBeInTheDocument();
158
+
159
+ // Webhook — should show "Method" field.
160
+ await selectKind(combobox, 'w');
161
+ await expect(canvas.findByLabelText('Method')).resolves.toBeInTheDocument();
162
+
163
+ // Subscription — should show query editor.
164
+ await selectKind(combobox, 's');
165
+ await expect(combobox).not.toBeDisabled();
166
+ await expect(canvas.queryByLabelText('Method')).not.toBeInTheDocument();
167
+
168
+ // Feed — should show DXN field (the queue address). DXN is a combobox, not an input, so use getByText.
169
+ await selectKind(combobox, 'f');
170
+ await expect(canvas.findByText('DXN')).resolves.toBeInTheDocument();
171
+ },
172
+ };
@@ -4,60 +4,87 @@
4
4
 
5
5
  import React, { useCallback, useMemo } from 'react';
6
6
 
7
+ import { Operation, Script, Trigger } from '@dxos/compute';
7
8
  import { ComputeGraph } from '@dxos/conductor';
8
- import { type Query, Type } from '@dxos/echo';
9
- import { Function, Script, Trigger } from '@dxos/functions';
10
- import { Filter, Ref, type Space, useQuery } from '@dxos/react-client/echo';
9
+ import { type Database, DXN, Entity, Feed, Filter, Obj, type Query, Ref } from '@dxos/echo';
10
+ import { useQuery } from '@dxos/react-client/echo';
11
11
  import { Input } from '@dxos/react-ui';
12
12
  import { QueryForm, type QueryFormProps } from '@dxos/react-ui-components';
13
- import { type CustomInputMap, Form, InputHeader, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';
14
-
15
- import { FunctionInputEditor, type FunctionInputEditorProps } from './FunctionInputEditor';
13
+ import {
14
+ type ExcludeId,
15
+ Form,
16
+ FormFieldLabel,
17
+ type FormFieldMap,
18
+ type FormRootProps,
19
+ SelectField,
20
+ omitId,
21
+ } from '@dxos/react-ui-form';
22
+
23
+ import { FunctionInputEditor } from './FunctionInputEditor';
16
24
  import { SpecSelector } from './SpecSelector';
17
25
 
26
+ type TriggerFormSchema = ExcludeId<typeof Trigger.Trigger>;
27
+
18
28
  export type TriggerEditorProps = {
19
- space: Space;
29
+ db: Database.Database;
20
30
  trigger: Trigger.Trigger;
21
31
  // TODO(wittjosiah): This needs to apply to whole spec but currently only applies to spec.kind & spec.query.
22
32
  readonlySpec?: boolean;
23
- onSave?: (trigger: Omit<Trigger.Trigger, 'id'>) => void;
24
- onCancel?: () => void;
25
- } & Pick<QueryFormProps, 'types' | 'tags'>;
26
-
27
- export const TriggerEditor = ({ space, trigger, readonlySpec, types, tags, onSave, onCancel }: TriggerEditorProps) => {
28
- const handleSave = ({ id: _, ...values }: Trigger.Trigger) => {
29
- onSave?.(values);
30
- };
33
+ } &
34
+ // prettier-ignore
35
+ Pick<QueryFormProps, 'types' | 'tags'> &
36
+ Pick<FormRootProps<TriggerFormSchema>, 'onSave' | 'onCancel'>;
37
+
38
+ export const TriggerEditor = ({ db, types, tags, readonlySpec, trigger, ...formProps }: TriggerEditorProps) => {
39
+ const fieldMap = useCustomInputs({ db, types, tags, readonlySpec });
40
+
41
+ const handleValuesChanged = useCallback(
42
+ (newValues: Partial<TriggerFormSchema>) => {
43
+ Obj.update(trigger, (trigger) => {
44
+ Object.assign(trigger, newValues);
45
+ });
46
+ },
47
+ [trigger],
48
+ );
31
49
 
32
- const handleRefQueryLookup = useRefQueryLookupHandler({ space });
33
- const Custom = useCustomInputs({ space, readonlySpec, types, tags, onQueryRefOptions: handleRefQueryLookup });
50
+ const triggerSchema = useMemo(() => omitId(Trigger.Trigger), []);
51
+ const defaultValues = useMemo(() => {
52
+ const { id: _, ...values } = trigger;
53
+ return values;
54
+ }, [trigger]);
34
55
 
35
56
  return (
36
- <Form
37
- outerSpacing={false}
38
- Custom={Custom}
39
- schema={Trigger.Trigger}
40
- values={trigger}
41
- onSave={handleSave}
42
- onCancel={onCancel}
43
- onQueryRefOptions={handleRefQueryLookup}
44
- />
57
+ <Form.Root<TriggerFormSchema>
58
+ {...formProps}
59
+ db={db}
60
+ schema={triggerSchema}
61
+ defaultValues={defaultValues}
62
+ fieldMap={fieldMap}
63
+ onValuesChanged={handleValuesChanged}
64
+ >
65
+ <Form.Viewport>
66
+ <Form.Content>
67
+ <Form.FieldSet />
68
+ <Form.Actions />
69
+ </Form.Content>
70
+ </Form.Viewport>
71
+ </Form.Root>
45
72
  );
46
73
  };
47
74
 
48
75
  type UseCustomInputsProps = {
49
- space: Space;
76
+ db: Database.Database;
50
77
  readonlySpec?: boolean;
51
- onQueryRefOptions: FunctionInputEditorProps['onQueryRefOptions'];
52
78
  } & Pick<QueryFormProps, 'types' | 'tags'>;
53
79
 
54
- const useCustomInputs = ({ space, readonlySpec, types, tags, onQueryRefOptions }: UseCustomInputsProps) => {
55
- const functions = useQuery(space, Filter.type(Function.Function));
56
- const workflows = useQuery(space, Filter.type(ComputeGraph));
57
- const scripts = useQuery(space, Filter.type(Script.Script));
80
+ const useCustomInputs = ({ db, readonlySpec, types, tags }: UseCustomInputsProps): FormFieldMap => {
81
+ const functions = useQuery(db, Filter.type(Operation.PersistentOperation));
82
+ const workflows = useQuery(db, Filter.type(ComputeGraph));
83
+ const scripts = useQuery(db, Filter.type(Script.Script));
84
+ const feeds = useQuery(db, Filter.type(Feed.Feed));
58
85
 
59
86
  return useMemo(
60
- (): CustomInputMap => ({
87
+ (): FormFieldMap => ({
61
88
  // Function selector.
62
89
  ['function' satisfies keyof Trigger.Trigger]: (props) => {
63
90
  const getValue = useCallback(() => {
@@ -70,17 +97,17 @@ const useCustomInputs = ({ space, readonlySpec, types, tags, onQueryRefOptions }
70
97
 
71
98
  const handleOnValueChange = useCallback(
72
99
  (_type: any, dxnString: string) => {
73
- const dxn = Type.DXN.parse(dxnString);
100
+ const dxn = DXN.parse(dxnString);
74
101
  if (dxn) {
75
102
  const ref = Ref.fromDXN(dxn);
76
- props.onValueChange('object', ref);
103
+ props.onValueChange(props.type, ref);
77
104
  }
78
105
  },
79
- [props.onValueChange],
106
+ [props.type, props.onValueChange],
80
107
  );
81
108
 
82
109
  return (
83
- <SelectInput
110
+ <SelectField
84
111
  {...props}
85
112
  getValue={getValue as any}
86
113
  onValueChange={handleOnValueChange}
@@ -90,30 +117,31 @@ const useCustomInputs = ({ space, readonlySpec, types, tags, onQueryRefOptions }
90
117
  },
91
118
 
92
119
  // Spec selector.
93
- ['spec.kind' as const]: (props) => <SpecSelector {...props} readonly={readonlySpec ? 'disabled-input' : false} />,
120
+ 'spec.kind': (props) => <SpecSelector {...props} readonly={readonlySpec} />,
121
+
122
+ // Queue feed selector with parent labels.
123
+ 'spec.queue': (props) => <SelectField {...props} options={getFeedQueueOptions(feeds)} />,
94
124
 
95
125
  // TODO(wittjosiah): Copied from ViewEditor.
96
126
  // Query input editor.
97
- ['spec.query' as const]: (props) => {
127
+ 'spec.query': (props) => {
98
128
  const handleChange = useCallback(
99
- (query: Query.Any) => props.onValueChange('object', { ast: query.ast }),
100
- [props.onValueChange],
129
+ (query: Query.Any) => props.onValueChange(props.type, { ast: query.ast }),
130
+ [props.type, props.onValueChange],
101
131
  );
102
132
 
103
133
  return (
104
134
  <Input.Root>
105
- <InputHeader label={props.label} />
135
+ <FormFieldLabel label={props.label} asChild />
106
136
  <QueryForm initialQuery={(props.getValue() as any).ast} types={types} tags={tags} onChange={handleChange} />
107
137
  </Input.Root>
108
138
  );
109
139
  },
110
140
 
111
141
  // Function input editor.
112
- ['input' as const]: (props) => (
113
- <FunctionInputEditor {...props} functions={functions} onQueryRefOptions={onQueryRefOptions} />
114
- ),
142
+ input: (props) => <FunctionInputEditor {...props} functions={functions} db={db} />,
115
143
  }),
116
- [workflows, scripts, functions, readonlySpec],
144
+ [workflows, scripts, functions, feeds, readonlySpec],
117
145
  );
118
146
  };
119
147
 
@@ -121,7 +149,20 @@ const getWorkflowOptions = (graphs: ComputeGraph[]) => {
121
149
  return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));
122
150
  };
123
151
 
124
- const getFunctionOptions = (scripts: Script.Script[], functions: Function.Function[]) => {
125
- const getLabel = (fn: Function.Function) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
152
+ const getFunctionOptions = (scripts: Script.Script[], functions: Operation.PersistentOperation[]) => {
153
+ const getLabel = (fn: Operation.PersistentOperation) =>
154
+ scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
126
155
  return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:echo:@:${fn.id}` }));
127
156
  };
157
+
158
+ const getFeedQueueOptions = (feeds: Feed.Feed[]) => {
159
+ return feeds.flatMap((feed) => {
160
+ const queueDXN = Feed.getQueueDxn(feed);
161
+ if (!queueDXN) {
162
+ return [];
163
+ }
164
+ const parent = Obj.getParent(feed);
165
+ const label = parent ? Entity.getLabel(parent) : Entity.getLabel(feed);
166
+ return [{ label: label ?? feed.id, value: queueDXN.toString() }];
167
+ });
168
+ };
@@ -7,6 +7,5 @@ import { lazy } from 'react';
7
7
  export * from './TriggerEditor';
8
8
 
9
9
  export const AutomationPanel = lazy(() => import('./AutomationPanel'));
10
- export const AutomationSettings = lazy(() => import('./AutomationSettings'));
11
- export const FunctionsContainer = lazy(() => import('./FunctionsContainer'));
12
10
  export const FunctionsPanel = lazy(() => import('./FunctionsPanel'));
11
+ export const FunctionsRegistry = lazy(() => import('./FunctionsRegistry'));
@@ -0,0 +1,31 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import React from 'react';
6
+
7
+ import { AppSurface } from '@dxos/app-toolkit/ui';
8
+ import { useTranslation } from '@dxos/react-ui';
9
+ import { Settings } from '@dxos/react-ui-form';
10
+
11
+ import { meta } from '#meta';
12
+
13
+ import { AutomationPanel, type AutomationPanelProps } from '../../components/AutomationPanel';
14
+ import { TriggersSettings } from '../TriggerSettings';
15
+
16
+ export type AutomationSettingsProps = AppSurface.SpaceArticleProps<Omit<AutomationPanelProps, 'space'>>;
17
+
18
+ export const AutomationSettings = (props: AutomationSettingsProps) => {
19
+ const { t } = useTranslation(meta.id);
20
+ return (
21
+ <Settings.Viewport>
22
+ <Settings.Section
23
+ title={t('automation-verbose.label', { ns: meta.id })}
24
+ description={t('automation.description', { ns: meta.id })}
25
+ >
26
+ <AutomationPanel {...props} />
27
+ <TriggersSettings space={props.space} />
28
+ </Settings.Section>
29
+ </Settings.Viewport>
30
+ );
31
+ };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export { AutomationSettings as default } from './AutomationSettings';