@dxos/plugin-automation 0.8.4-main.f9ba587 → 0.8.4-main.fcc0d83b33

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 (275) hide show
  1. package/dist/lib/browser/chunk-3JLJBF5C.mjs +54 -0
  2. package/dist/lib/browser/chunk-3JLJBF5C.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  4. package/dist/lib/browser/chunk-SZIGF7TB.mjs +44 -0
  5. package/dist/lib/browser/chunk-SZIGF7TB.mjs.map +7 -0
  6. package/dist/lib/browser/cli/index.mjs +1107 -0
  7. package/dist/lib/browser/cli/index.mjs.map +7 -0
  8. package/dist/lib/browser/create-trigger-from-template-RSZIPHIG.mjs +71 -0
  9. package/dist/lib/browser/create-trigger-from-template-RSZIPHIG.mjs.map +7 -0
  10. package/dist/lib/browser/hooks/index.mjs +129 -0
  11. package/dist/lib/browser/hooks/index.mjs.map +7 -0
  12. package/dist/lib/browser/index.mjs +44 -94
  13. package/dist/lib/browser/index.mjs.map +4 -4
  14. package/dist/lib/browser/meta.json +1 -1
  15. package/dist/lib/browser/operations/index.mjs +14 -0
  16. package/dist/lib/browser/operations/index.mjs.map +7 -0
  17. package/dist/lib/browser/translations.mjs +47 -0
  18. package/dist/lib/browser/translations.mjs.map +7 -0
  19. package/dist/lib/browser/types/index.mjs +14 -0
  20. package/dist/lib/node-esm/chunk-7I6EPBJI.mjs +56 -0
  21. package/dist/lib/node-esm/chunk-7I6EPBJI.mjs.map +7 -0
  22. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  23. package/dist/lib/node-esm/chunk-TR5BMZG5.mjs +45 -0
  24. package/dist/lib/node-esm/chunk-TR5BMZG5.mjs.map +7 -0
  25. package/dist/lib/node-esm/cli/index.mjs +1108 -0
  26. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  27. package/dist/lib/node-esm/create-trigger-from-template-GE76I6FE.mjs +72 -0
  28. package/dist/lib/node-esm/create-trigger-from-template-GE76I6FE.mjs.map +7 -0
  29. package/dist/lib/node-esm/hooks/index.mjs +130 -0
  30. package/dist/lib/node-esm/hooks/index.mjs.map +7 -0
  31. package/dist/lib/node-esm/index.mjs +44 -94
  32. package/dist/lib/node-esm/index.mjs.map +4 -4
  33. package/dist/lib/node-esm/meta.json +1 -1
  34. package/dist/lib/node-esm/operations/index.mjs +15 -0
  35. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  36. package/dist/lib/node-esm/translations.mjs +48 -0
  37. package/dist/lib/node-esm/translations.mjs.map +7 -0
  38. package/dist/lib/node-esm/types/index.mjs +15 -0
  39. package/dist/types/src/AutomationPlugin.d.ts +2 -1
  40. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  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 +14 -0
  44. package/dist/types/src/capabilities/compute-runtime.d.ts.map +1 -0
  45. package/dist/types/src/capabilities/index.d.ts +6 -3
  46. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  47. package/dist/types/src/capabilities/node.d.ts +3 -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/cli/commands/index.d.ts +2 -0
  54. package/dist/types/src/cli/commands/index.d.ts.map +1 -0
  55. package/dist/types/src/cli/commands/trigger/create/index.d.ts +25 -0
  56. package/dist/types/src/cli/commands/trigger/create/index.d.ts.map +1 -0
  57. package/dist/types/src/cli/commands/trigger/create/queue.d.ts +13 -0
  58. package/dist/types/src/cli/commands/trigger/create/queue.d.ts.map +1 -0
  59. package/dist/types/src/cli/commands/trigger/create/subscription.d.ts +15 -0
  60. package/dist/types/src/cli/commands/trigger/create/subscription.d.ts.map +1 -0
  61. package/dist/types/src/cli/commands/trigger/create/timer.d.ts +13 -0
  62. package/dist/types/src/cli/commands/trigger/create/timer.d.ts.map +1 -0
  63. package/dist/types/src/cli/commands/trigger/index.d.ts +57 -0
  64. package/dist/types/src/cli/commands/trigger/index.d.ts.map +1 -0
  65. package/dist/types/src/cli/commands/trigger/list.d.ts +7 -0
  66. package/dist/types/src/cli/commands/trigger/list.d.ts.map +1 -0
  67. package/dist/types/src/cli/commands/trigger/options.d.ts +11 -0
  68. package/dist/types/src/cli/commands/trigger/options.d.ts.map +1 -0
  69. package/dist/types/src/cli/commands/trigger/remove.d.ts +8 -0
  70. package/dist/types/src/cli/commands/trigger/remove.d.ts.map +1 -0
  71. package/dist/types/src/cli/commands/trigger/update/index.d.ts +28 -0
  72. package/dist/types/src/cli/commands/trigger/update/index.d.ts.map +1 -0
  73. package/dist/types/src/cli/commands/trigger/update/queue.d.ts +12 -0
  74. package/dist/types/src/cli/commands/trigger/update/queue.d.ts.map +1 -0
  75. package/dist/types/src/cli/commands/trigger/update/subscription.d.ts +13 -0
  76. package/dist/types/src/cli/commands/trigger/update/subscription.d.ts.map +1 -0
  77. package/dist/types/src/cli/commands/trigger/update/timer.d.ts +11 -0
  78. package/dist/types/src/cli/commands/trigger/update/timer.d.ts.map +1 -0
  79. package/dist/types/src/cli/commands/trigger/util.d.ts +46 -0
  80. package/dist/types/src/cli/commands/trigger/util.d.ts.map +1 -0
  81. package/dist/types/src/cli/index.d.ts +2 -0
  82. package/dist/types/src/cli/index.d.ts.map +1 -0
  83. package/dist/types/src/cli/plugin.d.ts +3 -0
  84. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  85. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +3 -3
  86. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  87. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts +50 -4
  88. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  89. package/dist/types/src/components/AutomationPanel/index.d.ts.map +1 -1
  90. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
  91. package/dist/types/src/components/FunctionsPanel/index.d.ts.map +1 -1
  92. package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts +8 -0
  93. package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts.map +1 -0
  94. package/dist/types/src/components/FunctionsRegistry/index.d.ts +4 -0
  95. package/dist/types/src/components/FunctionsRegistry/index.d.ts.map +1 -0
  96. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +12 -9
  97. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +1 -1
  98. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts +6 -3
  99. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +1 -1
  100. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +11 -8
  101. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  102. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts +121 -4
  103. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  104. package/dist/types/src/components/index.d.ts +2 -3
  105. package/dist/types/src/components/index.d.ts.map +1 -1
  106. package/dist/types/src/containers/AutomationSettings/AutomationSettings.d.ts +6 -0
  107. package/dist/types/src/containers/AutomationSettings/AutomationSettings.d.ts.map +1 -0
  108. package/dist/types/src/containers/AutomationSettings/index.d.ts +2 -0
  109. package/dist/types/src/containers/AutomationSettings/index.d.ts.map +1 -0
  110. package/dist/types/src/containers/FunctionsContainer/FunctionsContainer.d.ts +4 -0
  111. package/dist/types/src/containers/FunctionsContainer/FunctionsContainer.d.ts.map +1 -0
  112. package/dist/types/src/containers/FunctionsContainer/index.d.ts +2 -0
  113. package/dist/types/src/containers/FunctionsContainer/index.d.ts.map +1 -0
  114. package/dist/types/src/containers/TriggerSettings/TriggerSettings.d.ts +6 -0
  115. package/dist/types/src/containers/TriggerSettings/TriggerSettings.d.ts.map +1 -0
  116. package/dist/types/src/containers/TriggerSettings/index.d.ts +3 -0
  117. package/dist/types/src/containers/TriggerSettings/index.d.ts.map +1 -0
  118. package/dist/types/src/containers/index.d.ts +5 -0
  119. package/dist/types/src/containers/index.d.ts.map +1 -0
  120. package/dist/types/src/hooks/index.d.ts +5 -0
  121. package/dist/types/src/hooks/index.d.ts.map +1 -0
  122. package/dist/types/src/hooks/useComputeRuntime.d.ts +8 -0
  123. package/dist/types/src/hooks/useComputeRuntime.d.ts.map +1 -0
  124. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts +9 -0
  125. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts.map +1 -0
  126. package/dist/types/src/hooks/useComputeRuntimeService.d.ts +17 -0
  127. package/dist/types/src/hooks/useComputeRuntimeService.d.ts.map +1 -0
  128. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts +12 -0
  129. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts.map +1 -0
  130. package/dist/types/src/index.d.ts +2 -3
  131. package/dist/types/src/index.d.ts.map +1 -1
  132. package/dist/types/src/meta.d.ts +2 -3
  133. package/dist/types/src/meta.d.ts.map +1 -1
  134. package/dist/types/src/operations/create-trigger-from-template.d.ts +5 -0
  135. package/dist/types/src/operations/create-trigger-from-template.d.ts.map +1 -0
  136. package/dist/types/src/operations/definitions.d.ts +19 -0
  137. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  138. package/dist/types/src/operations/index.d.ts +4 -0
  139. package/dist/types/src/operations/index.d.ts.map +1 -0
  140. package/dist/types/src/testing/test-functions.d.ts +204 -3
  141. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  142. package/dist/types/src/translations.d.ts +32 -26
  143. package/dist/types/src/translations.d.ts.map +1 -1
  144. package/dist/types/src/types/capabilities.d.ts +25 -0
  145. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  146. package/dist/types/src/types/events.d.ts +5 -0
  147. package/dist/types/src/types/events.d.ts.map +1 -0
  148. package/dist/types/src/types/index.d.ts +4 -0
  149. package/dist/types/src/types/index.d.ts.map +1 -0
  150. package/dist/types/src/{types.d.ts → types/schema.d.ts} +13 -5
  151. package/dist/types/src/types/schema.d.ts.map +1 -0
  152. package/dist/types/tsconfig.tsbuildinfo +1 -1
  153. package/package.json +110 -46
  154. package/src/AutomationPlugin.tsx +22 -34
  155. package/src/capabilities/app-graph-builder.ts +56 -79
  156. package/src/capabilities/compute-runtime.ts +320 -0
  157. package/src/capabilities/index.ts +9 -4
  158. package/src/capabilities/node.ts +7 -0
  159. package/src/capabilities/operation-handler.ts +16 -0
  160. package/src/capabilities/react-surface.tsx +49 -46
  161. package/src/cli/commands/index.ts +5 -0
  162. package/src/cli/commands/trigger/create/index.ts +14 -0
  163. package/src/cli/commands/trigger/create/queue.ts +87 -0
  164. package/src/cli/commands/trigger/create/subscription.ts +126 -0
  165. package/src/cli/commands/trigger/create/timer.ts +91 -0
  166. package/src/cli/commands/trigger/index.ts +16 -0
  167. package/src/cli/commands/trigger/list.ts +70 -0
  168. package/src/cli/commands/trigger/options.ts +59 -0
  169. package/src/cli/commands/trigger/remove.ts +45 -0
  170. package/src/cli/commands/trigger/update/index.ts +14 -0
  171. package/src/cli/commands/trigger/update/queue.ts +195 -0
  172. package/src/cli/commands/trigger/update/subscription.ts +279 -0
  173. package/src/cli/commands/trigger/update/timer.ts +194 -0
  174. package/src/cli/commands/trigger/util.ts +411 -0
  175. package/src/cli/index.ts +5 -0
  176. package/src/cli/plugin.ts +23 -0
  177. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +18 -17
  178. package/src/components/AutomationPanel/AutomationPanel.tsx +250 -94
  179. package/src/components/FunctionsPanel/FunctionsPanel.tsx +52 -32
  180. package/src/components/FunctionsRegistry/FunctionsRegistry.tsx +114 -0
  181. package/src/components/FunctionsRegistry/index.ts +8 -0
  182. package/src/components/TriggerEditor/FunctionInputEditor.tsx +42 -35
  183. package/src/components/TriggerEditor/SpecSelector.tsx +34 -22
  184. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +129 -40
  185. package/src/components/TriggerEditor/TriggerEditor.tsx +110 -48
  186. package/src/components/index.ts +1 -2
  187. package/src/containers/AutomationSettings/AutomationSettings.tsx +31 -0
  188. package/src/containers/AutomationSettings/index.ts +5 -0
  189. package/src/containers/FunctionsContainer/FunctionsContainer.tsx +33 -0
  190. package/src/containers/FunctionsContainer/index.ts +5 -0
  191. package/src/containers/TriggerSettings/TriggerSettings.tsx +48 -0
  192. package/src/containers/TriggerSettings/index.ts +6 -0
  193. package/src/containers/index.ts +9 -0
  194. package/src/hooks/index.ts +9 -0
  195. package/src/hooks/useComputeRuntime.ts +30 -0
  196. package/src/hooks/useComputeRuntimeCallback.ts +32 -0
  197. package/src/hooks/useComputeRuntimeService.ts +64 -0
  198. package/src/hooks/useTriggerRuntimeControls.ts +70 -0
  199. package/src/index.ts +2 -4
  200. package/src/meta.ts +9 -8
  201. package/src/operations/create-trigger-from-template.ts +72 -0
  202. package/src/operations/definitions.ts +28 -0
  203. package/src/operations/index.ts +9 -0
  204. package/src/testing/test-functions.ts +10 -7
  205. package/src/translations.ts +39 -29
  206. package/src/types/capabilities.ts +48 -0
  207. package/src/types/events.ts +11 -0
  208. package/src/types/index.ts +7 -0
  209. package/src/{types.ts → types/schema.ts} +6 -8
  210. package/dist/lib/browser/AutomationContainer-VZNV2ZQF.mjs +0 -38
  211. package/dist/lib/browser/AutomationContainer-VZNV2ZQF.mjs.map +0 -7
  212. package/dist/lib/browser/AutomationPanel-ZWA6GOFY.mjs +0 -11
  213. package/dist/lib/browser/FunctionsContainer-IOB333TX.mjs +0 -39
  214. package/dist/lib/browser/FunctionsContainer-IOB333TX.mjs.map +0 -7
  215. package/dist/lib/browser/FunctionsPanel-56ZKRVM5.mjs +0 -10
  216. package/dist/lib/browser/app-graph-builder-ZTAUTFI4.mjs +0 -80
  217. package/dist/lib/browser/app-graph-builder-ZTAUTFI4.mjs.map +0 -7
  218. package/dist/lib/browser/chunk-ECSTS2UI.mjs +0 -14
  219. package/dist/lib/browser/chunk-ECSTS2UI.mjs.map +0 -7
  220. package/dist/lib/browser/chunk-ERTIGJYE.mjs +0 -147
  221. package/dist/lib/browser/chunk-ERTIGJYE.mjs.map +0 -7
  222. package/dist/lib/browser/chunk-FSJZXTS2.mjs +0 -230
  223. package/dist/lib/browser/chunk-FSJZXTS2.mjs.map +0 -7
  224. package/dist/lib/browser/chunk-GW5U2DGT.mjs +0 -15
  225. package/dist/lib/browser/chunk-GW5U2DGT.mjs.map +0 -7
  226. package/dist/lib/browser/chunk-LYJVTIVD.mjs +0 -94
  227. package/dist/lib/browser/chunk-LYJVTIVD.mjs.map +0 -7
  228. package/dist/lib/browser/chunk-S2LE7SYB.mjs +0 -39
  229. package/dist/lib/browser/chunk-S2LE7SYB.mjs.map +0 -7
  230. package/dist/lib/browser/intent-resolver-YLRSMLH4.mjs +0 -76
  231. package/dist/lib/browser/intent-resolver-YLRSMLH4.mjs.map +0 -7
  232. package/dist/lib/browser/react-surface-4DFSM7OX.mjs +0 -64
  233. package/dist/lib/browser/react-surface-4DFSM7OX.mjs.map +0 -7
  234. package/dist/lib/browser/types.mjs +0 -8
  235. package/dist/lib/node-esm/AutomationContainer-WMIH3F4V.mjs +0 -39
  236. package/dist/lib/node-esm/AutomationContainer-WMIH3F4V.mjs.map +0 -7
  237. package/dist/lib/node-esm/AutomationPanel-YYUMSK2W.mjs +0 -12
  238. package/dist/lib/node-esm/FunctionsContainer-DJWB6WFH.mjs +0 -40
  239. package/dist/lib/node-esm/FunctionsContainer-DJWB6WFH.mjs.map +0 -7
  240. package/dist/lib/node-esm/FunctionsPanel-KGIOZSPZ.mjs +0 -11
  241. package/dist/lib/node-esm/FunctionsPanel-KGIOZSPZ.mjs.map +0 -7
  242. package/dist/lib/node-esm/app-graph-builder-3FP63ZSG.mjs +0 -81
  243. package/dist/lib/node-esm/app-graph-builder-3FP63ZSG.mjs.map +0 -7
  244. package/dist/lib/node-esm/chunk-AZH66CED.mjs +0 -231
  245. package/dist/lib/node-esm/chunk-AZH66CED.mjs.map +0 -7
  246. package/dist/lib/node-esm/chunk-HIMYPGHF.mjs +0 -148
  247. package/dist/lib/node-esm/chunk-HIMYPGHF.mjs.map +0 -7
  248. package/dist/lib/node-esm/chunk-NK5N3QKD.mjs +0 -17
  249. package/dist/lib/node-esm/chunk-NK5N3QKD.mjs.map +0 -7
  250. package/dist/lib/node-esm/chunk-SGZPTJ47.mjs +0 -16
  251. package/dist/lib/node-esm/chunk-SGZPTJ47.mjs.map +0 -7
  252. package/dist/lib/node-esm/chunk-UKATFY3R.mjs +0 -40
  253. package/dist/lib/node-esm/chunk-UKATFY3R.mjs.map +0 -7
  254. package/dist/lib/node-esm/chunk-ZGPUV5VS.mjs +0 -95
  255. package/dist/lib/node-esm/chunk-ZGPUV5VS.mjs.map +0 -7
  256. package/dist/lib/node-esm/intent-resolver-LU7EYWEO.mjs +0 -77
  257. package/dist/lib/node-esm/intent-resolver-LU7EYWEO.mjs.map +0 -7
  258. package/dist/lib/node-esm/react-surface-3PNW7NDW.mjs +0 -65
  259. package/dist/lib/node-esm/react-surface-3PNW7NDW.mjs.map +0 -7
  260. package/dist/lib/node-esm/types.mjs +0 -9
  261. package/dist/lib/node-esm/types.mjs.map +0 -7
  262. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  263. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  264. package/dist/types/src/components/AutomationContainer.d.ts +0 -5
  265. package/dist/types/src/components/AutomationContainer.d.ts.map +0 -1
  266. package/dist/types/src/components/FunctionsContainer.d.ts +0 -7
  267. package/dist/types/src/components/FunctionsContainer.d.ts.map +0 -1
  268. package/dist/types/src/types.d.ts.map +0 -1
  269. package/src/capabilities/intent-resolver.ts +0 -72
  270. package/src/components/AutomationContainer.tsx +0 -30
  271. package/src/components/FunctionsContainer.tsx +0 -31
  272. /package/dist/lib/browser/{AutomationPanel-ZWA6GOFY.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  273. /package/dist/lib/browser/{FunctionsPanel-56ZKRVM5.mjs.map → types/index.mjs.map} +0 -0
  274. /package/dist/lib/{browser/types.mjs.map → node-esm/chunk-HSLMI22Q.mjs.map} +0 -0
  275. /package/dist/lib/node-esm/{AutomationPanel-YYUMSK2W.mjs.map → types/index.mjs.map} +0 -0
@@ -1,39 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- AutomationPanel
4
- } from "./chunk-HIMYPGHF.mjs";
5
- import "./chunk-AZH66CED.mjs";
6
- import {
7
- AUTOMATION_PLUGIN
8
- } from "./chunk-NK5N3QKD.mjs";
9
-
10
- // src/components/AutomationContainer.tsx
11
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
12
- import React from "react";
13
- import { useTranslation } from "@dxos/react-ui";
14
- import { ControlSection, ControlPage } from "@dxos/react-ui-form";
15
- import { StackItem } from "@dxos/react-ui-stack";
16
- var AutomationContainer = (props) => {
17
- var _effect = _useSignals();
18
- try {
19
- const { t } = useTranslation(AUTOMATION_PLUGIN);
20
- return /* @__PURE__ */ React.createElement(StackItem.Content, {
21
- classNames: "block overflow-y-auto"
22
- }, /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
23
- title: t("automation verbose label", {
24
- ns: AUTOMATION_PLUGIN
25
- }),
26
- description: t("automation description", {
27
- ns: AUTOMATION_PLUGIN
28
- })
29
- }, /* @__PURE__ */ React.createElement(AutomationPanel, props))));
30
- } finally {
31
- _effect.f();
32
- }
33
- };
34
- var AutomationContainer_default = AutomationContainer;
35
- export {
36
- AutomationContainer,
37
- AutomationContainer_default as default
38
- };
39
- //# sourceMappingURL=AutomationContainer-WMIH3F4V.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/AutomationContainer.tsx"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { useTranslation } from '@dxos/react-ui';\nimport { ControlSection, ControlPage } from '@dxos/react-ui-form';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { AutomationPanel, type AutomationPanelProps } from './AutomationPanel';\nimport { AUTOMATION_PLUGIN } from '../meta';\n\nexport const AutomationContainer = (props: AutomationPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n return (\n <StackItem.Content classNames='block overflow-y-auto'>\n <ControlPage>\n <ControlSection\n title={t('automation verbose label', { ns: AUTOMATION_PLUGIN })}\n description={t('automation description', { ns: AUTOMATION_PLUGIN })}\n >\n <AutomationPanel {...props} />\n </ControlSection>\n </ControlPage>\n </StackItem.Content>\n );\n};\n\nexport default AutomationContainer;\n"],
5
- "mappings": ";;;;;;;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,sBAAsB;AAC/B,SAASC,gBAAgBC,mBAAmB;AAC5C,SAASC,iBAAiB;AAKnB,IAAMC,sBAAsB,CAACC,UAAAA;;;AAClC,UAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,WACE,sBAAA,cAACC,UAAUC,SAAO;MAACC,YAAW;OAC5B,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;MACCC,OAAOR,EAAE,4BAA4B;QAAES,IAAIP;MAAkB,CAAA;MAC7DQ,aAAaV,EAAE,0BAA0B;QAAES,IAAIP;MAAkB,CAAA;OAEjE,sBAAA,cAACS,iBAAoBZ,KAAAA,CAAAA,CAAAA,CAAAA;;;;AAK/B;AAEA,IAAA,8BAAeD;",
6
- "names": ["React", "useTranslation", "ControlSection", "ControlPage", "StackItem", "AutomationContainer", "props", "t", "useTranslation", "AUTOMATION_PLUGIN", "StackItem", "Content", "classNames", "ControlPage", "ControlSection", "title", "ns", "description", "AutomationPanel"]
7
- }
@@ -1,12 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- AutomationPanel,
4
- AutomationPanel_default
5
- } from "./chunk-HIMYPGHF.mjs";
6
- import "./chunk-AZH66CED.mjs";
7
- import "./chunk-NK5N3QKD.mjs";
8
- export {
9
- AutomationPanel,
10
- AutomationPanel_default as default
11
- };
12
- //# sourceMappingURL=AutomationPanel-YYUMSK2W.mjs.map
@@ -1,40 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- FunctionsPanel
4
- } from "./chunk-ZGPUV5VS.mjs";
5
- import {
6
- AUTOMATION_PLUGIN
7
- } from "./chunk-NK5N3QKD.mjs";
8
-
9
- // src/components/FunctionsContainer.tsx
10
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
11
- import React from "react";
12
- import { useTranslation } from "@dxos/react-ui";
13
- import { ControlPage, ControlSection } from "@dxos/react-ui-form";
14
- import { StackItem } from "@dxos/react-ui-stack";
15
- var FunctionsContainer = ({ space }) => {
16
- var _effect = _useSignals();
17
- try {
18
- const { t } = useTranslation(AUTOMATION_PLUGIN);
19
- return /* @__PURE__ */ React.createElement(StackItem.Content, {
20
- classNames: "block overflow-y-auto"
21
- }, /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
22
- title: t("functions verbose label", {
23
- ns: AUTOMATION_PLUGIN
24
- }),
25
- description: t("functions description", {
26
- ns: AUTOMATION_PLUGIN
27
- })
28
- }, /* @__PURE__ */ React.createElement(FunctionsPanel, {
29
- space
30
- }))));
31
- } finally {
32
- _effect.f();
33
- }
34
- };
35
- var FunctionsContainer_default = FunctionsContainer;
36
- export {
37
- FunctionsContainer,
38
- FunctionsContainer_default as default
39
- };
40
- //# sourceMappingURL=FunctionsContainer-DJWB6WFH.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/FunctionsContainer.tsx"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type Space } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { ControlPage, ControlSection } from '@dxos/react-ui-form';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { FunctionsPanel } from './FunctionsPanel';\nimport { AUTOMATION_PLUGIN } from '../meta';\n\nexport const FunctionsContainer = ({ space }: { space: Space }) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n return (\n <StackItem.Content classNames='block overflow-y-auto'>\n <ControlPage>\n <ControlSection\n title={t('functions verbose label', { ns: AUTOMATION_PLUGIN })}\n description={t('functions description', { ns: AUTOMATION_PLUGIN })}\n >\n <FunctionsPanel space={space} />\n </ControlSection>\n </ControlPage>\n </StackItem.Content>\n );\n};\n\nexport default FunctionsContainer;\n"],
5
- "mappings": ";;;;;;;;;;AAIA,OAAOA,WAAW;AAGlB,SAASC,sBAAsB;AAC/B,SAASC,aAAaC,sBAAsB;AAC5C,SAASC,iBAAiB;AAKnB,IAAMC,qBAAqB,CAAC,EAAEC,MAAK,MAAoB;;;AAC5D,UAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,WACE,sBAAA,cAACC,UAAUC,SAAO;MAACC,YAAW;OAC5B,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;MACCC,OAAOR,EAAE,2BAA2B;QAAES,IAAIP;MAAkB,CAAA;MAC5DQ,aAAaV,EAAE,yBAAyB;QAAES,IAAIP;MAAkB,CAAA;OAEhE,sBAAA,cAACS,gBAAAA;MAAeZ;;;;;AAK1B;AAEA,IAAA,6BAAeD;",
6
- "names": ["React", "useTranslation", "ControlPage", "ControlSection", "StackItem", "FunctionsContainer", "space", "t", "useTranslation", "AUTOMATION_PLUGIN", "StackItem", "Content", "classNames", "ControlPage", "ControlSection", "title", "ns", "description", "FunctionsPanel"]
7
- }
@@ -1,11 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- FunctionsPanel,
4
- FunctionsPanel_default
5
- } from "./chunk-ZGPUV5VS.mjs";
6
- import "./chunk-NK5N3QKD.mjs";
7
- export {
8
- FunctionsPanel,
9
- FunctionsPanel_default as default
10
- };
11
- //# sourceMappingURL=FunctionsPanel-KGIOZSPZ.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": [],
4
- "sourcesContent": [],
5
- "mappings": "",
6
- "names": []
7
- }
@@ -1,81 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- meta
4
- } from "./chunk-NK5N3QKD.mjs";
5
-
6
- // src/capabilities/app-graph-builder.ts
7
- import { Rx } from "@effect-rx/rx-react";
8
- import { Option, pipe } from "effect";
9
- import { Capabilities, contributes } from "@dxos/app-framework";
10
- import { Obj } from "@dxos/echo";
11
- import { ScriptType } from "@dxos/functions";
12
- import { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from "@dxos/plugin-deck/types";
13
- import { createExtension } from "@dxos/plugin-graph";
14
- import { SPACE_PLUGIN } from "@dxos/plugin-space";
15
- var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
16
- createExtension({
17
- id: `${meta.id}/space-settings-automation`,
18
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === `${SPACE_PLUGIN}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
19
- {
20
- id: `automation-${node2.id}`,
21
- type: `${meta.id}/space-settings-automation`,
22
- data: `${meta.id}/space-settings-automation`,
23
- properties: {
24
- label: [
25
- "automation panel label",
26
- {
27
- ns: meta.id
28
- }
29
- ],
30
- icon: "ph--lightning--regular"
31
- }
32
- }
33
- ]), Option.getOrElse(() => [])))
34
- }),
35
- createExtension({
36
- id: `${meta.id}/space-settings-functions`,
37
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === `${SPACE_PLUGIN}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
38
- {
39
- id: `functions-${node2.id}`,
40
- type: `${meta.id}/space-settings-functions`,
41
- data: `${meta.id}/space-settings-functions`,
42
- properties: {
43
- label: [
44
- "functions panel label",
45
- {
46
- ns: meta.id
47
- }
48
- ],
49
- icon: "ph--function--regular"
50
- }
51
- }
52
- ]), Option.getOrElse(() => [])))
53
- }),
54
- createExtension({
55
- id: `${meta.id}/script-companion`,
56
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(ScriptType, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
57
- {
58
- id: [
59
- node2.id,
60
- "automation"
61
- ].join(ATTENDABLE_PATH_SEPARATOR),
62
- type: PLANK_COMPANION_TYPE,
63
- data: "automation",
64
- properties: {
65
- label: [
66
- "script automation label",
67
- {
68
- ns: meta.id
69
- }
70
- ],
71
- icon: "ph--lightning--regular",
72
- disposition: "hidden"
73
- }
74
- }
75
- ]), Option.getOrElse(() => [])))
76
- })
77
- ]);
78
- export {
79
- app_graph_builder_default as default
80
- };
81
- //# sourceMappingURL=app-graph-builder-3FP63ZSG.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/app-graph-builder.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Rx } from '@effect-rx/rx-react';\nimport { Option, pipe } from 'effect';\n\nimport { Capabilities, contributes, type PluginContext } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { ScriptType } from '@dxos/functions';\nimport { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from '@dxos/plugin-deck/types';\nimport { createExtension } from '@dxos/plugin-graph';\nimport { SPACE_PLUGIN } from '@dxos/plugin-space';\n\nimport { meta } from '../meta';\n\nexport default (context: PluginContext) =>\n contributes(Capabilities.AppGraphBuilder, [\n createExtension({\n id: `${meta.id}/space-settings-automation`,\n connector: (node) =>\n Rx.make((get) =>\n pipe(\n get(node),\n Option.flatMap((node) => (node.type === `${SPACE_PLUGIN}/settings` ? Option.some(node) : Option.none())),\n Option.map((node) => [\n {\n id: `automation-${node.id}`,\n type: `${meta.id}/space-settings-automation`,\n data: `${meta.id}/space-settings-automation`,\n properties: {\n label: ['automation panel label', { ns: meta.id }],\n icon: 'ph--lightning--regular',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n createExtension({\n id: `${meta.id}/space-settings-functions`,\n connector: (node) =>\n Rx.make((get) =>\n pipe(\n get(node),\n Option.flatMap((node) => (node.type === `${SPACE_PLUGIN}/settings` ? Option.some(node) : Option.none())),\n Option.map((node) => [\n {\n id: `functions-${node.id}`,\n type: `${meta.id}/space-settings-functions`,\n data: `${meta.id}/space-settings-functions`,\n properties: {\n label: ['functions panel label', { ns: meta.id }],\n icon: 'ph--function--regular',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n createExtension({\n id: `${meta.id}/script-companion`,\n connector: (node) =>\n Rx.make((get) =>\n pipe(\n get(node),\n Option.flatMap((node) => (Obj.instanceOf(ScriptType, node.data) ? Option.some(node) : Option.none())),\n Option.map((node) => [\n {\n id: [node.id, 'automation'].join(ATTENDABLE_PATH_SEPARATOR),\n type: PLANK_COMPANION_TYPE,\n data: 'automation',\n properties: {\n label: ['script automation label', { ns: meta.id }],\n icon: 'ph--lightning--regular',\n disposition: 'hidden',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n ]);\n"],
5
- "mappings": ";;;;;;AAIA,SAASA,UAAU;AACnB,SAASC,QAAQC,YAAY;AAE7B,SAASC,cAAcC,mBAAuC;AAC9D,SAASC,WAAW;AACpB,SAASC,kBAAkB;AAC3B,SAASC,sBAAsBC,iCAAiC;AAChE,SAASC,uBAAuB;AAChC,SAASC,oBAAoB;AAI7B,IAAA,4BAAe,CAACC,YACdC,YAAYC,aAAaC,iBAAiB;EACxCC,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUA,MAAKO,SAAS,GAAGC,YAAAA,cAA0BH,OAAOI,KAAKT,KAAAA,IAAQK,OAAOK,KAAI,CAAA,GACpGL,OAAOM,IAAI,CAACX,UAAS;MACnB;QACEH,IAAI,cAAcG,MAAKH,EAAE;QACzBU,MAAM,GAAGT,KAAKD,EAAE;QAChBe,MAAM,GAAGd,KAAKD,EAAE;QAChBgB,YAAY;UACVC,OAAO;YAAC;YAA0B;cAAEC,IAAIjB,KAAKD;YAAG;;UAChDmB,MAAM;QACR;MACF;KACD,GACDX,OAAOY,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACArB,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUA,MAAKO,SAAS,GAAGC,YAAAA,cAA0BH,OAAOI,KAAKT,KAAAA,IAAQK,OAAOK,KAAI,CAAA,GACpGL,OAAOM,IAAI,CAACX,UAAS;MACnB;QACEH,IAAI,aAAaG,MAAKH,EAAE;QACxBU,MAAM,GAAGT,KAAKD,EAAE;QAChBe,MAAM,GAAGd,KAAKD,EAAE;QAChBgB,YAAY;UACVC,OAAO;YAAC;YAAyB;cAAEC,IAAIjB,KAAKD;YAAG;;UAC/CmB,MAAM;QACR;MACF;KACD,GACDX,OAAOY,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACArB,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUkB,IAAIC,WAAWC,YAAYpB,MAAKY,IAAI,IAAIP,OAAOI,KAAKT,KAAAA,IAAQK,OAAOK,KAAI,CAAA,GACjGL,OAAOM,IAAI,CAACX,UAAS;MACnB;QACEH,IAAI;UAACG,MAAKH;UAAI;UAAcwB,KAAKC,yBAAAA;QACjCf,MAAMgB;QACNX,MAAM;QACNC,YAAY;UACVC,OAAO;YAAC;YAA2B;cAAEC,IAAIjB,KAAKD;YAAG;;UACjDmB,MAAM;UACNQ,aAAa;QACf;MACF;KACD,GACDnB,OAAOY,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;CACD;",
6
- "names": ["Rx", "Option", "pipe", "Capabilities", "contributes", "Obj", "ScriptType", "PLANK_COMPANION_TYPE", "ATTENDABLE_PATH_SEPARATOR", "createExtension", "SPACE_PLUGIN", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "connector", "node", "Rx", "make", "get", "pipe", "Option", "flatMap", "type", "SPACE_PLUGIN", "some", "none", "map", "data", "properties", "label", "ns", "icon", "getOrElse", "Obj", "instanceOf", "ScriptType", "join", "ATTENDABLE_PATH_SEPARATOR", "PLANK_COMPANION_TYPE", "disposition"]
7
- }
@@ -1,231 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- AUTOMATION_PLUGIN
4
- } from "./chunk-NK5N3QKD.mjs";
5
-
6
- // src/components/TriggerEditor/TriggerEditor.tsx
7
- import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
8
- import React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react";
9
- import { ComputeGraph } from "@dxos/conductor";
10
- import { Type as Type2 } from "@dxos/echo";
11
- import { FunctionType, FunctionTriggerSchema, ScriptType } from "@dxos/functions";
12
- import { Filter, Ref as Ref2, useQuery } from "@dxos/react-client/echo";
13
- import { Form as Form2, SelectInput as SelectInput2, useRefQueryLookupHandler } from "@dxos/react-ui-form";
14
-
15
- // src/components/TriggerEditor/FunctionInputEditor.tsx
16
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
17
- import React, { useCallback, useMemo } from "react";
18
- import { Ref, Type } from "@dxos/echo";
19
- import { useOnTransition } from "@dxos/react-ui";
20
- import { Form, useFormValues } from "@dxos/react-ui-form";
21
- var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
22
- var _effect = _useSignals();
23
- try {
24
- const selectedFunctionValue = useFormValues([
25
- "function"
26
- ]);
27
- const selectedFunctionId = useMemo(() => {
28
- if (Ref.isRef(selectedFunctionValue)) {
29
- return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
30
- }
31
- }, [
32
- selectedFunctionValue
33
- ]);
34
- const selectedFunction = useMemo(() => functions.find((fn) => fn.id === selectedFunctionId), [
35
- functions,
36
- selectedFunctionId
37
- ]);
38
- useOnTransition(
39
- // Clear function parameter input when the function changes.
40
- selectedFunctionValue,
41
- (prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
42
- (currValue) => currValue !== void 0,
43
- () => onValueChange("object", {})
44
- );
45
- const inputSchema = useMemo(() => selectedFunction?.inputSchema, [
46
- selectedFunction
47
- ]);
48
- const effectSchema = useMemo(() => inputSchema ? Type.toEffectSchema(inputSchema) : void 0, [
49
- inputSchema
50
- ]);
51
- const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
52
- const values = useMemo(() => getValue() ?? {}, [
53
- getValue
54
- ]);
55
- const handleValuesChanged = useCallback((values2) => {
56
- onValueChange("object", values2);
57
- }, [
58
- onValueChange
59
- ]);
60
- if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
61
- return null;
62
- }
63
- return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("h3", {
64
- className: "text-md"
65
- }, "Function parameters"), /* @__PURE__ */ React.createElement(Form, {
66
- schema: effectSchema,
67
- values,
68
- onValuesChanged: handleValuesChanged,
69
- onQueryRefOptions,
70
- outerSpacing: false
71
- }));
72
- } finally {
73
- _effect.f();
74
- }
75
- };
76
-
77
- // src/components/TriggerEditor/SpecSelector.tsx
78
- import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
79
- import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
80
- import { TriggerKind } from "@dxos/functions";
81
- import { useTranslation } from "@dxos/react-ui";
82
- import { SelectInput, useInputProps } from "@dxos/react-ui-form";
83
- var SpecSelector = (props) => {
84
- var _effect = _useSignals2();
85
- try {
86
- const { t } = useTranslation(AUTOMATION_PLUGIN);
87
- const specProps = useInputProps([
88
- "spec"
89
- ]);
90
- const handleTypeChange = useCallback2((_type, value) => {
91
- const getDefaultTriggerSpec = (kind) => {
92
- switch (kind) {
93
- case TriggerKind.Timer:
94
- return {
95
- kind: TriggerKind.Timer,
96
- cron: ""
97
- };
98
- case TriggerKind.Subscription:
99
- return {
100
- kind: TriggerKind.Subscription,
101
- filter: {}
102
- };
103
- case TriggerKind.Queue:
104
- return {
105
- kind: TriggerKind.Queue,
106
- queue: ""
107
- };
108
- case TriggerKind.Email:
109
- return {
110
- kind: TriggerKind.Email
111
- };
112
- case TriggerKind.Webhook:
113
- return {
114
- kind: TriggerKind.Webhook
115
- };
116
- default:
117
- return void 0;
118
- }
119
- };
120
- const defaultSpec = getDefaultTriggerSpec(value);
121
- if (!defaultSpec) {
122
- return;
123
- }
124
- specProps.onValueChange("object", defaultSpec);
125
- }, [
126
- specProps
127
- ]);
128
- const options = useMemo2(() => Object.values(TriggerKind).map((kind) => ({
129
- value: kind,
130
- label: t(`trigger type ${kind}`)
131
- })), [
132
- t
133
- ]);
134
- return /* @__PURE__ */ React2.createElement(SelectInput, {
135
- ...props,
136
- options,
137
- onValueChange: handleTypeChange
138
- });
139
- } finally {
140
- _effect.f();
141
- }
142
- };
143
-
144
- // src/components/TriggerEditor/TriggerEditor.tsx
145
- var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
146
- var _effect = _useSignals3();
147
- try {
148
- const handleSave = (values) => {
149
- onSave?.(values);
150
- };
151
- const handleRefQueryLookup = useRefQueryLookupHandler({
152
- space
153
- });
154
- const Custom = useCustomInputs(space, handleRefQueryLookup);
155
- return /* @__PURE__ */ React3.createElement(Form2, {
156
- outerSpacing: false,
157
- Custom,
158
- schema: FunctionTriggerSchema,
159
- values: trigger,
160
- onSave: handleSave,
161
- onCancel,
162
- onQueryRefOptions: handleRefQueryLookup
163
- });
164
- } finally {
165
- _effect.f();
166
- }
167
- };
168
- var useCustomInputs = (space, onQueryRefOptions) => {
169
- const functions = useQuery(space, Filter.type(FunctionType));
170
- const workflows = useQuery(space, Filter.type(ComputeGraph));
171
- const scripts = useQuery(space, Filter.type(ScriptType));
172
- return useMemo3(() => ({
173
- // Function selector.
174
- ["function"]: (props) => {
175
- const getValue = useCallback3(() => {
176
- const formValue = props.getValue();
177
- if (Ref2.isRef(formValue)) {
178
- return formValue.dxn.toString();
179
- }
180
- return void 0;
181
- }, [
182
- props
183
- ]);
184
- const handleOnValueChange = useCallback3((_type, dxnString) => {
185
- const dxn = Type2.DXN.parse(dxnString);
186
- if (dxn) {
187
- const ref = Ref2.fromDXN(dxn);
188
- props.onValueChange("object", ref);
189
- }
190
- }, [
191
- props.onValueChange
192
- ]);
193
- return /* @__PURE__ */ React3.createElement(SelectInput2, {
194
- ...props,
195
- getValue,
196
- onValueChange: handleOnValueChange,
197
- options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
198
- });
199
- },
200
- // Spec selector.
201
- ["spec.kind"]: SpecSelector,
202
- // Function input editor.
203
- ["input"]: (props) => /* @__PURE__ */ React3.createElement(FunctionInputEditor, {
204
- ...props,
205
- functions,
206
- onQueryRefOptions
207
- })
208
- }), [
209
- workflows,
210
- scripts,
211
- functions
212
- ]);
213
- };
214
- var getWorkflowOptions = (graphs) => {
215
- return graphs.map((graph) => ({
216
- label: `compute-${graph.id}`,
217
- value: `dxn:echo:@:${graph.id}`
218
- }));
219
- };
220
- var getFunctionOptions = (scripts, functions) => {
221
- const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
222
- return functions.map((fn) => ({
223
- label: getLabel(fn),
224
- value: `dxn:echo:@:${fn.id}`
225
- }));
226
- };
227
-
228
- export {
229
- TriggerEditor
230
- };
231
- //# sourceMappingURL=chunk-AZH66CED.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 {\n FunctionType,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n type FunctionTrigger,\n ScriptType,\n} from '@dxos/functions';\nimport { Filter, Ref, useQuery, type Space } 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: FunctionTriggerType;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const handleSave = (values: FunctionTriggerType) => {\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={FunctionTriggerSchema}\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 FunctionTriggerType]: (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 FunctionTriggerType, TriggerKind, type TriggerType } from '@dxos/functions';\nimport { useTranslation } from '@dxos/react-ui';\nimport { SelectInput, type InputProps, useInputProps } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type SpecSelectorProps = InputProps;\n\nexport const SpecSelector = (props: SpecSelectorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const specProps = useInputProps(['spec' satisfies keyof FunctionTriggerType]);\n\n const handleTypeChange = useCallback(\n (_type: any, value: string): TriggerType | undefined => {\n const getDefaultTriggerSpec = (kind: string) => {\n switch (kind) {\n case TriggerKind.Timer:\n return { kind: TriggerKind.Timer, cron: '' };\n case TriggerKind.Subscription:\n return { kind: TriggerKind.Subscription, filter: {} };\n case TriggerKind.Queue:\n return { kind: TriggerKind.Queue, queue: '' };\n case TriggerKind.Email:\n return { kind: TriggerKind.Email };\n case TriggerKind.Webhook:\n return { kind: TriggerKind.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 Object.values(TriggerKind).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", "FunctionType", "FunctionTriggerSchema", "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", "TriggerKind", "useTranslation", "SelectInput", "useInputProps", "SpecSelector", "props", "t", "useTranslation", "AUTOMATION_PLUGIN", "specProps", "useInputProps", "handleTypeChange", "useCallback", "_type", "value", "getDefaultTriggerSpec", "kind", "TriggerKind", "Timer", "cron", "Subscription", "filter", "Queue", "queue", "Email", "Webhook", "undefined", "defaultSpec", "onValueChange", "options", "useMemo", "Object", "values", "map", "label", "React", "SelectInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "handleSave", "values", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "useCustomInputs", "React", "Form", "outerSpacing", "schema", "FunctionTriggerSchema", "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,148 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- TriggerEditor
4
- } from "./chunk-AZH66CED.mjs";
5
- import {
6
- AUTOMATION_PLUGIN
7
- } from "./chunk-NK5N3QKD.mjs";
8
-
9
- // src/components/AutomationPanel/AutomationPanel.tsx
10
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
11
- import { Schema } from "effect";
12
- import React, { useState } from "react";
13
- import { Filter, Obj } from "@dxos/echo";
14
- import { FunctionType, FunctionTrigger, FunctionTriggerSchema, ScriptType, TriggerKind } from "@dxos/functions";
15
- import { useClient } from "@dxos/react-client";
16
- import { useQuery, getSpace } from "@dxos/react-client/echo";
17
- import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
18
- import { ControlItem, controlItemClasses } from "@dxos/react-ui-form";
19
- import { List } from "@dxos/react-ui-list";
20
- import { ghostHover, mx } from "@dxos/react-ui-theme";
21
- var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
22
- var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
23
- var _effect = _useSignals();
24
- try {
25
- const { t } = useTranslation(AUTOMATION_PLUGIN);
26
- const client = useClient();
27
- const triggers = useQuery(space, Filter.type(FunctionTrigger));
28
- const functions = useQuery(space, Filter.type(FunctionType));
29
- const scripts = useQuery(space, Filter.type(ScriptType));
30
- const [trigger, setTrigger] = useState(initialTrigger);
31
- const [selected, setSelected] = useState();
32
- const handleSelect = (trigger2) => {
33
- const { id: _, ...values } = trigger2;
34
- setTrigger(values);
35
- setSelected(trigger2);
36
- };
37
- const handleAdd = () => {
38
- setTrigger(Obj.make(FunctionTriggerSchema, {}));
39
- setSelected(void 0);
40
- };
41
- const handleDelete = (trigger2) => {
42
- space.db.remove(trigger2);
43
- setTrigger(void 0);
44
- setSelected(void 0);
45
- };
46
- const handleSave = (trigger2) => {
47
- if (selected) {
48
- Object.assign(selected, trigger2);
49
- } else {
50
- space.db.add(Obj.make(FunctionTrigger, trigger2));
51
- }
52
- setTrigger(void 0);
53
- setSelected(void 0);
54
- onDone?.();
55
- };
56
- const handleCancel = () => {
57
- setTrigger(void 0);
58
- onDone?.();
59
- };
60
- if (trigger) {
61
- return /* @__PURE__ */ React.createElement(ControlItem, {
62
- title: t("trigger editor title")
63
- }, /* @__PURE__ */ React.createElement(TriggerEditor, {
64
- space,
65
- trigger,
66
- onSave: handleSave,
67
- onCancel: handleCancel
68
- }));
69
- }
70
- return /* @__PURE__ */ React.createElement("div", {
71
- className: controlItemClasses
72
- }, triggers.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
73
- items: triggers,
74
- isItem: Schema.is(FunctionTrigger),
75
- getId: (field) => field.id
76
- }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
77
- role: "list",
78
- className: "flex flex-col w-full"
79
- }, triggers2?.map((trigger2) => {
80
- const copyAction = getCopyAction(client, trigger2);
81
- return /* @__PURE__ */ React.createElement(List.Item, {
82
- key: trigger2.id,
83
- item: trigger2,
84
- classNames: mx(grid, ghostHover, "items-center", "px-2")
85
- }, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.Switch, {
86
- checked: trigger2.enabled,
87
- onCheckedChange: (checked) => trigger2.enabled = checked
88
- })), /* @__PURE__ */ React.createElement("div", {
89
- className: "flex"
90
- }, /* @__PURE__ */ React.createElement(List.ItemTitle, {
91
- classNames: "px-1 cursor-pointer w-0 shrink truncate",
92
- onClick: () => handleSelect(trigger2)
93
- }, getFunctionName(scripts, functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
94
- label: t(copyAction.translationKey),
95
- value: copyAction.contentProvider()
96
- })), /* @__PURE__ */ React.createElement(List.ItemDeleteButton, {
97
- onClick: () => handleDelete(trigger2)
98
- }));
99
- }))), triggers.length > 0 && /* @__PURE__ */ React.createElement(Separator, {
100
- classNames: "mlb-4"
101
- }), /* @__PURE__ */ React.createElement(IconButton, {
102
- icon: "ph--plus--regular",
103
- label: t("new trigger label"),
104
- onClick: handleAdd
105
- }));
106
- } finally {
107
- _effect.f();
108
- }
109
- };
110
- var getCopyAction = (client, trigger) => {
111
- if (trigger?.spec?.kind === TriggerKind.Email) {
112
- return {
113
- translationKey: "trigger copy email",
114
- contentProvider: () => `${getSpace(trigger).id}@dxos.network`
115
- };
116
- }
117
- if (trigger?.spec?.kind === TriggerKind.Webhook) {
118
- return {
119
- translationKey: "trigger copy url",
120
- contentProvider: () => getWebhookUrl(client, trigger)
121
- };
122
- }
123
- return void 0;
124
- };
125
- var getWebhookUrl = (client, trigger) => {
126
- const spaceId = getSpace(trigger).id;
127
- const edgeUrl = new URL(client.config.values.runtime.services.edge.url);
128
- const isSecure = edgeUrl.protocol.startsWith("https") || edgeUrl.protocol.startsWith("wss");
129
- edgeUrl.protocol = isSecure ? "https" : "http";
130
- return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
131
- };
132
- var getFunctionName = (scripts, functions, trigger) => {
133
- const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
134
- const functionObject = functions.find((fn) => fn === trigger.function?.target);
135
- if (!functionObject) {
136
- return shortId;
137
- }
138
- return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;
139
- };
140
-
141
- // src/components/AutomationPanel/index.ts
142
- var AutomationPanel_default = AutomationPanel;
143
-
144
- export {
145
- AutomationPanel,
146
- AutomationPanel_default
147
- };
148
- //# sourceMappingURL=chunk-HIMYPGHF.mjs.map