@dxos/plugin-automation 0.8.2-main.f081794 → 0.8.2-main.fbd8ed0

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 (144) hide show
  1. package/dist/lib/browser/{AutomationContainer-KEQ5RNIW.mjs → AutomationContainer-DA6IW7O2.mjs} +3 -3
  2. package/dist/lib/browser/{AutomationPanel-G3OB6ELR.mjs → AutomationPanel-R42D3LDD.mjs} +3 -3
  3. package/dist/lib/browser/{FunctionsContainer-STXBW4CX.mjs → FunctionsContainer-MPBMMOMS.mjs} +2 -2
  4. package/dist/lib/browser/{FunctionsPanel-JJPLIAJW.mjs → FunctionsPanel-NSI3P53X.mjs} +2 -2
  5. package/dist/lib/browser/{app-graph-builder-ND64CHOM.mjs → app-graph-builder-2OGPEVBA.mjs} +13 -15
  6. package/dist/lib/browser/app-graph-builder-2OGPEVBA.mjs.map +7 -0
  7. package/dist/lib/browser/{chunk-NGG4ICAQ.mjs → chunk-2QF27UJ2.mjs} +12 -12
  8. package/dist/lib/browser/chunk-2QF27UJ2.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-ADYCSC6Y.mjs +39 -0
  10. package/dist/lib/browser/chunk-ADYCSC6Y.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-BNQNURZN.mjs +211 -0
  12. package/dist/lib/browser/chunk-BNQNURZN.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-QJPKWYTL.mjs → chunk-SGT76SL2.mjs} +5 -5
  14. package/dist/lib/browser/{chunk-65VL4EYS.mjs → chunk-TRC3J2I6.mjs} +6 -6
  15. package/dist/lib/browser/chunk-TRC3J2I6.mjs.map +7 -0
  16. package/dist/lib/browser/index.mjs +6 -6
  17. package/dist/lib/browser/index.mjs.map +1 -1
  18. package/dist/lib/browser/{intent-resolver-3J647TIZ.mjs → intent-resolver-X3H6ZSP4.mjs} +22 -16
  19. package/dist/lib/browser/intent-resolver-X3H6ZSP4.mjs.map +7 -0
  20. package/dist/lib/browser/meta.json +1 -1
  21. package/dist/lib/browser/{react-surface-L22QIANU.mjs → react-surface-MOXIHBMS.mjs} +4 -4
  22. package/dist/lib/browser/{react-surface-L22QIANU.mjs.map → react-surface-MOXIHBMS.mjs.map} +1 -1
  23. package/dist/lib/browser/types.mjs +1 -1
  24. package/dist/lib/node/{AutomationContainer-E5I76FPP.cjs → AutomationContainer-FIFH4P5T.cjs} +7 -7
  25. package/dist/lib/node/{AutomationPanel-YLXAFJDP.cjs → AutomationPanel-HTNEWBGB.cjs} +8 -8
  26. package/dist/lib/node/{AutomationPanel-YLXAFJDP.cjs.map → AutomationPanel-HTNEWBGB.cjs.map} +2 -2
  27. package/dist/lib/node/{FunctionsContainer-3HCURMEB.cjs → FunctionsContainer-LF2F6CPE.cjs} +6 -6
  28. package/dist/lib/node/{FunctionsPanel-SYIZHPGU.cjs → FunctionsPanel-6HOAIMQ3.cjs} +7 -7
  29. package/dist/lib/node/{FunctionsPanel-SYIZHPGU.cjs.map → FunctionsPanel-6HOAIMQ3.cjs.map} +2 -2
  30. package/dist/lib/node/{app-graph-builder-TVFR6RXO.cjs → app-graph-builder-3XGDVWHR.cjs} +16 -18
  31. package/dist/lib/node/app-graph-builder-3XGDVWHR.cjs.map +7 -0
  32. package/dist/lib/node/{chunk-BSK5SHTR.cjs → chunk-CBHWMYKF.cjs} +9 -9
  33. package/dist/lib/node/chunk-CBHWMYKF.cjs.map +7 -0
  34. package/dist/lib/node/{chunk-PSIJDHAX.cjs → chunk-GDCG2BML.cjs} +19 -19
  35. package/dist/lib/node/chunk-GDCG2BML.cjs.map +7 -0
  36. package/dist/lib/node/chunk-S3Z4AP77.cjs +234 -0
  37. package/dist/lib/node/chunk-S3Z4AP77.cjs.map +7 -0
  38. package/dist/lib/node/{chunk-L5TWLPGA.cjs → chunk-SV2CB3FT.cjs} +8 -8
  39. package/dist/lib/node/{chunk-SRXHHBDE.cjs → chunk-TI3WBQIB.cjs} +18 -18
  40. package/dist/lib/node/chunk-TI3WBQIB.cjs.map +7 -0
  41. package/dist/lib/node/index.cjs +13 -13
  42. package/dist/lib/node/index.cjs.map +2 -2
  43. package/dist/lib/node/{intent-resolver-4YYZ2MMZ.cjs → intent-resolver-Q7WJ4PZZ.cjs} +28 -22
  44. package/dist/lib/node/intent-resolver-Q7WJ4PZZ.cjs.map +7 -0
  45. package/dist/lib/node/meta.json +1 -1
  46. package/dist/lib/node/{react-surface-PCZCHIET.cjs → react-surface-43VHU36V.cjs} +11 -11
  47. package/dist/lib/node/react-surface-43VHU36V.cjs.map +7 -0
  48. package/dist/lib/node/types.cjs +2 -2
  49. package/dist/lib/node/types.cjs.map +1 -1
  50. package/dist/lib/node-esm/{AutomationContainer-22PUFPSE.mjs → AutomationContainer-OP43F4PD.mjs} +3 -3
  51. package/dist/lib/node-esm/{AutomationPanel-6UXIAJVS.mjs → AutomationPanel-ZQKRBWP2.mjs} +3 -3
  52. package/dist/lib/node-esm/{FunctionsContainer-XG5WVAN3.mjs → FunctionsContainer-5TVRDIX5.mjs} +2 -2
  53. package/dist/lib/node-esm/{FunctionsPanel-J3QGUESH.mjs → FunctionsPanel-NMEW26KL.mjs} +2 -2
  54. package/dist/lib/node-esm/{app-graph-builder-NYLOXWVV.mjs → app-graph-builder-UR2E5CQY.mjs} +13 -15
  55. package/dist/lib/node-esm/app-graph-builder-UR2E5CQY.mjs.map +7 -0
  56. package/dist/lib/node-esm/{chunk-4UPGANGV.mjs → chunk-AD4C4IK2.mjs} +6 -6
  57. package/dist/lib/node-esm/chunk-AD4C4IK2.mjs.map +7 -0
  58. package/dist/lib/node-esm/{chunk-TMMB5ETD.mjs → chunk-CUPEMOYK.mjs} +5 -5
  59. package/dist/lib/node-esm/{chunk-HMYAQLGF.mjs → chunk-DIUPZXCQ.mjs} +12 -12
  60. package/dist/lib/node-esm/chunk-DIUPZXCQ.mjs.map +7 -0
  61. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs +212 -0
  62. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs.map +7 -0
  63. package/dist/lib/node-esm/{chunk-YYBCQXB2.mjs → chunk-EEA6CZ6B.mjs} +16 -16
  64. package/dist/lib/node-esm/chunk-EEA6CZ6B.mjs.map +7 -0
  65. package/dist/lib/node-esm/index.mjs +6 -6
  66. package/dist/lib/node-esm/index.mjs.map +1 -1
  67. package/dist/lib/node-esm/{intent-resolver-WXIXG5UY.mjs → intent-resolver-HEUGQ6SL.mjs} +22 -16
  68. package/dist/lib/node-esm/intent-resolver-HEUGQ6SL.mjs.map +7 -0
  69. package/dist/lib/node-esm/meta.json +1 -1
  70. package/dist/lib/node-esm/{react-surface-VSO4NWC6.mjs → react-surface-TER7JEF6.mjs} +4 -4
  71. package/dist/lib/node-esm/{react-surface-VSO4NWC6.mjs.map → react-surface-TER7JEF6.mjs.map} +1 -1
  72. package/dist/lib/node-esm/types.mjs +1 -1
  73. package/dist/types/src/capabilities/app-graph-builder.d.ts +2 -179
  74. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  75. package/dist/types/src/capabilities/index.d.ts +2 -178
  76. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  77. package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
  78. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  79. package/dist/types/src/components/AutomationContainer.d.ts.map +1 -1
  80. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -1
  81. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  82. package/dist/types/src/components/FunctionsContainer.d.ts.map +1 -1
  83. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
  84. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +12 -0
  85. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +1 -0
  86. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts +5 -0
  87. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +1 -0
  88. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -1
  89. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  90. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  91. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  92. package/dist/types/src/types.d.ts +15 -15
  93. package/dist/types/src/types.d.ts.map +1 -1
  94. package/dist/types/tsconfig.tsbuildinfo +1 -1
  95. package/package.json +31 -24
  96. package/src/AutomationPlugin.tsx +1 -1
  97. package/src/capabilities/app-graph-builder.ts +64 -41
  98. package/src/capabilities/intent-resolver.ts +25 -14
  99. package/src/capabilities/react-surface.tsx +1 -1
  100. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +2 -2
  101. package/src/components/AutomationPanel/AutomationPanel.tsx +11 -10
  102. package/src/components/FunctionsPanel/FunctionsPanel.tsx +5 -5
  103. package/src/components/TriggerEditor/FunctionInputEditor.tsx +77 -0
  104. package/src/components/TriggerEditor/SpecSelector.tsx +59 -0
  105. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +17 -8
  106. package/src/components/TriggerEditor/TriggerEditor.tsx +53 -93
  107. package/src/testing/test-functions.ts +23 -9
  108. package/src/types.ts +11 -10
  109. package/dist/lib/browser/app-graph-builder-ND64CHOM.mjs.map +0 -7
  110. package/dist/lib/browser/chunk-65VL4EYS.mjs.map +0 -7
  111. package/dist/lib/browser/chunk-FALBBJNO.mjs +0 -138
  112. package/dist/lib/browser/chunk-FALBBJNO.mjs.map +0 -7
  113. package/dist/lib/browser/chunk-FCLWFVFX.mjs +0 -39
  114. package/dist/lib/browser/chunk-FCLWFVFX.mjs.map +0 -7
  115. package/dist/lib/browser/chunk-NGG4ICAQ.mjs.map +0 -7
  116. package/dist/lib/browser/intent-resolver-3J647TIZ.mjs.map +0 -7
  117. package/dist/lib/node/app-graph-builder-TVFR6RXO.cjs.map +0 -7
  118. package/dist/lib/node/chunk-BSK5SHTR.cjs.map +0 -7
  119. package/dist/lib/node/chunk-FTEDH5Q6.cjs +0 -167
  120. package/dist/lib/node/chunk-FTEDH5Q6.cjs.map +0 -7
  121. package/dist/lib/node/chunk-PSIJDHAX.cjs.map +0 -7
  122. package/dist/lib/node/chunk-SRXHHBDE.cjs.map +0 -7
  123. package/dist/lib/node/intent-resolver-4YYZ2MMZ.cjs.map +0 -7
  124. package/dist/lib/node/react-surface-PCZCHIET.cjs.map +0 -7
  125. package/dist/lib/node-esm/app-graph-builder-NYLOXWVV.mjs.map +0 -7
  126. package/dist/lib/node-esm/chunk-4UPGANGV.mjs.map +0 -7
  127. package/dist/lib/node-esm/chunk-HMYAQLGF.mjs.map +0 -7
  128. package/dist/lib/node-esm/chunk-M4QXMIIB.mjs +0 -139
  129. package/dist/lib/node-esm/chunk-M4QXMIIB.mjs.map +0 -7
  130. package/dist/lib/node-esm/chunk-YYBCQXB2.mjs.map +0 -7
  131. package/dist/lib/node-esm/intent-resolver-WXIXG5UY.mjs.map +0 -7
  132. /package/dist/lib/browser/{AutomationContainer-KEQ5RNIW.mjs.map → AutomationContainer-DA6IW7O2.mjs.map} +0 -0
  133. /package/dist/lib/browser/{AutomationPanel-G3OB6ELR.mjs.map → AutomationPanel-R42D3LDD.mjs.map} +0 -0
  134. /package/dist/lib/browser/{FunctionsContainer-STXBW4CX.mjs.map → FunctionsContainer-MPBMMOMS.mjs.map} +0 -0
  135. /package/dist/lib/browser/{FunctionsPanel-JJPLIAJW.mjs.map → FunctionsPanel-NSI3P53X.mjs.map} +0 -0
  136. /package/dist/lib/browser/{chunk-QJPKWYTL.mjs.map → chunk-SGT76SL2.mjs.map} +0 -0
  137. /package/dist/lib/node/{AutomationContainer-E5I76FPP.cjs.map → AutomationContainer-FIFH4P5T.cjs.map} +0 -0
  138. /package/dist/lib/node/{FunctionsContainer-3HCURMEB.cjs.map → FunctionsContainer-LF2F6CPE.cjs.map} +0 -0
  139. /package/dist/lib/node/{chunk-L5TWLPGA.cjs.map → chunk-SV2CB3FT.cjs.map} +0 -0
  140. /package/dist/lib/node-esm/{AutomationContainer-22PUFPSE.mjs.map → AutomationContainer-OP43F4PD.mjs.map} +0 -0
  141. /package/dist/lib/node-esm/{AutomationPanel-6UXIAJVS.mjs.map → AutomationPanel-ZQKRBWP2.mjs.map} +0 -0
  142. /package/dist/lib/node-esm/{FunctionsContainer-XG5WVAN3.mjs.map → FunctionsContainer-5TVRDIX5.mjs.map} +0 -0
  143. /package/dist/lib/node-esm/{FunctionsPanel-J3QGUESH.mjs.map → FunctionsPanel-NMEW26KL.mjs.map} +0 -0
  144. /package/dist/lib/node-esm/{chunk-TMMB5ETD.mjs.map → chunk-CUPEMOYK.mjs.map} +0 -0
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  AutomationPanel
3
- } from "./chunk-NGG4ICAQ.mjs";
4
- import "./chunk-FALBBJNO.mjs";
3
+ } from "./chunk-2QF27UJ2.mjs";
4
+ import "./chunk-BNQNURZN.mjs";
5
5
  import {
6
6
  AUTOMATION_PLUGIN
7
7
  } from "./chunk-WKKQV4PC.mjs";
@@ -31,4 +31,4 @@ export {
31
31
  AutomationContainer,
32
32
  AutomationContainer_default as default
33
33
  };
34
- //# sourceMappingURL=AutomationContainer-KEQ5RNIW.mjs.map
34
+ //# sourceMappingURL=AutomationContainer-DA6IW7O2.mjs.map
@@ -1,11 +1,11 @@
1
1
  import {
2
2
  AutomationPanel,
3
3
  AutomationPanel_default
4
- } from "./chunk-NGG4ICAQ.mjs";
5
- import "./chunk-FALBBJNO.mjs";
4
+ } from "./chunk-2QF27UJ2.mjs";
5
+ import "./chunk-BNQNURZN.mjs";
6
6
  import "./chunk-WKKQV4PC.mjs";
7
7
  export {
8
8
  AutomationPanel,
9
9
  AutomationPanel_default as default
10
10
  };
11
- //# sourceMappingURL=AutomationPanel-G3OB6ELR.mjs.map
11
+ //# sourceMappingURL=AutomationPanel-R42D3LDD.mjs.map
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  FunctionsPanel
3
- } from "./chunk-65VL4EYS.mjs";
3
+ } from "./chunk-TRC3J2I6.mjs";
4
4
  import {
5
5
  AUTOMATION_PLUGIN
6
6
  } from "./chunk-WKKQV4PC.mjs";
@@ -30,4 +30,4 @@ export {
30
30
  FunctionsContainer,
31
31
  FunctionsContainer_default as default
32
32
  };
33
- //# sourceMappingURL=FunctionsContainer-STXBW4CX.mjs.map
33
+ //# sourceMappingURL=FunctionsContainer-MPBMMOMS.mjs.map
@@ -1,10 +1,10 @@
1
1
  import {
2
2
  FunctionsPanel,
3
3
  FunctionsPanel_default
4
- } from "./chunk-65VL4EYS.mjs";
4
+ } from "./chunk-TRC3J2I6.mjs";
5
5
  import "./chunk-WKKQV4PC.mjs";
6
6
  export {
7
7
  FunctionsPanel,
8
8
  FunctionsPanel_default as default
9
9
  };
10
- //# sourceMappingURL=FunctionsPanel-JJPLIAJW.mjs.map
10
+ //# sourceMappingURL=FunctionsPanel-NSI3P53X.mjs.map
@@ -3,20 +3,20 @@ import {
3
3
  } from "./chunk-WKKQV4PC.mjs";
4
4
 
5
5
  // packages/plugins/plugin-automation/src/capabilities/app-graph-builder.ts
6
+ import { Rx } from "@effect-rx/rx-react";
7
+ import { Option, pipe } from "effect";
6
8
  import { Capabilities, contributes } from "@dxos/app-framework";
7
9
  import { isInstanceOf } from "@dxos/echo-schema";
8
10
  import { ScriptType } from "@dxos/functions";
9
11
  import { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from "@dxos/plugin-deck/types";
10
12
  import { createExtension } from "@dxos/plugin-graph";
11
- import { SCRIPT_PLUGIN } from "@dxos/plugin-script/types";
12
13
  import { SPACE_PLUGIN } from "@dxos/plugin-space";
13
14
  var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
14
15
  createExtension({
15
16
  id: `${meta.id}/space-settings-automation`,
16
- filter: (node) => node.type === `${SPACE_PLUGIN}/settings`,
17
- connector: ({ node }) => [
17
+ connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.type === `${SPACE_PLUGIN}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
18
18
  {
19
- id: `automation-${node.id}`,
19
+ id: `automation-${node2.id}`,
20
20
  type: `${meta.id}/space-settings-automation`,
21
21
  data: `${meta.id}/space-settings-automation`,
22
22
  properties: {
@@ -29,14 +29,13 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
29
29
  icon: "ph--lightning--regular"
30
30
  }
31
31
  }
32
- ]
32
+ ]), Option.getOrElse(() => [])))
33
33
  }),
34
34
  createExtension({
35
35
  id: `${meta.id}/space-settings-functions`,
36
- filter: (node) => node.type === `${SPACE_PLUGIN}/settings`,
37
- connector: ({ node }) => [
36
+ 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
37
  {
39
- id: `functions-${node.id}`,
38
+ id: `functions-${node2.id}`,
40
39
  type: `${meta.id}/space-settings-functions`,
41
40
  data: `${meta.id}/space-settings-functions`,
42
41
  properties: {
@@ -49,15 +48,14 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
49
48
  icon: "ph--function--regular"
50
49
  }
51
50
  }
52
- ]
51
+ ]), Option.getOrElse(() => [])))
53
52
  }),
54
53
  createExtension({
55
- id: `${SCRIPT_PLUGIN}/script-companion`,
56
- filter: (node) => isInstanceOf(ScriptType, node.data),
57
- connector: ({ node }) => [
54
+ id: `${meta.id}/script-companion`,
55
+ connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => isInstanceOf(ScriptType, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
58
56
  {
59
57
  id: [
60
- node.id,
58
+ node2.id,
61
59
  "automation"
62
60
  ].join(ATTENDABLE_PATH_SEPARATOR),
63
61
  type: PLANK_COMPANION_TYPE,
@@ -72,10 +70,10 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
72
70
  icon: "ph--lightning--regular"
73
71
  }
74
72
  }
75
- ]
73
+ ]), Option.getOrElse(() => [])))
76
74
  })
77
75
  ]);
78
76
  export {
79
77
  app_graph_builder_default as default
80
78
  };
81
- //# sourceMappingURL=app-graph-builder-ND64CHOM.mjs.map
79
+ //# sourceMappingURL=app-graph-builder-2OGPEVBA.mjs.map
@@ -0,0 +1,7 @@
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 { isInstanceOf } from '@dxos/echo-schema';\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) => (isInstanceOf(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 },\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,oBAAoB;AAC7B,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,aAAaC,YAAYnB,MAAKY,IAAI,IAAIP,OAAOI,KAAKT,KAAAA,IAAQK,OAAOK,KAAI,CAAA,GAC/FL,OAAOM,IAAI,CAACX,UAAS;MACnB;QACEH,IAAI;UAACG,MAAKH;UAAI;UAAcuB,KAAKC,yBAAAA;QACjCd,MAAMe;QACNV,MAAM;QACNC,YAAY;UACVC,OAAO;YAAC;YAA2B;cAAEC,IAAIjB,KAAKD;YAAG;;UACjDmB,MAAM;QACR;MACF;KACD,GACDX,OAAOY,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;CACD;",
6
+ "names": ["Rx", "Option", "pipe", "Capabilities", "contributes", "isInstanceOf", "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", "isInstanceOf", "ScriptType", "join", "ATTENDABLE_PATH_SEPARATOR", "PLANK_COMPANION_TYPE"]
7
+ }
@@ -1,14 +1,14 @@
1
1
  import {
2
2
  TriggerEditor
3
- } from "./chunk-FALBBJNO.mjs";
3
+ } from "./chunk-BNQNURZN.mjs";
4
4
  import {
5
5
  AUTOMATION_PLUGIN
6
6
  } from "./chunk-WKKQV4PC.mjs";
7
7
 
8
8
  // packages/plugins/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
9
+ import { Schema } from "effect";
9
10
  import React, { useState } from "react";
10
- import { S } from "@dxos/echo-schema";
11
- import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions/types";
11
+ import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions";
12
12
  import { useClient } from "@dxos/react-client";
13
13
  import { live, Filter, useQuery, getSpace } from "@dxos/react-client/echo";
14
14
  import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
@@ -19,9 +19,9 @@ var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
19
19
  var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
20
20
  const { t } = useTranslation(AUTOMATION_PLUGIN);
21
21
  const client = useClient();
22
- const triggers = useQuery(space, Filter.schema(FunctionTrigger));
23
- const functions = useQuery(space, Filter.schema(FunctionType));
24
- const scripts = useQuery(space, Filter.schema(ScriptType));
22
+ const triggers = useQuery(space, Filter.type(FunctionTrigger));
23
+ const functions = useQuery(space, Filter.type(FunctionType));
24
+ const scripts = useQuery(space, Filter.type(ScriptType));
25
25
  const [trigger, setTrigger] = useState(initialTrigger);
26
26
  const [selected, setSelected] = useState();
27
27
  const handleSelect = (trigger2) => {
@@ -66,7 +66,7 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
66
66
  className: controlItemClasses
67
67
  }, /* @__PURE__ */ React.createElement(List.Root, {
68
68
  items: triggers,
69
- isItem: S.is(FunctionTrigger),
69
+ isItem: Schema.is(FunctionTrigger),
70
70
  getId: (field) => field.id
71
71
  }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
72
72
  role: "list",
@@ -100,13 +100,13 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
100
100
  })));
101
101
  };
102
102
  var getCopyAction = (client, trigger) => {
103
- if (trigger?.spec?.type === TriggerKind.Email) {
103
+ if (trigger?.spec?.kind === TriggerKind.Email) {
104
104
  return {
105
105
  translationKey: "trigger copy email",
106
106
  contentProvider: () => `${getSpace(trigger).id}@dxos.network`
107
107
  };
108
108
  }
109
- if (trigger?.spec?.type === TriggerKind.Webhook) {
109
+ if (trigger?.spec?.kind === TriggerKind.Webhook) {
110
110
  return {
111
111
  translationKey: "trigger copy url",
112
112
  contentProvider: () => getWebhookUrl(client, trigger)
@@ -122,8 +122,8 @@ var getWebhookUrl = (client, trigger) => {
122
122
  return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
123
123
  };
124
124
  var getFunctionName = (scripts, functions, trigger) => {
125
- const shortId = trigger.function && `${trigger.function?.slice(0, 16)}\u2026`;
126
- const functionObject = functions.find((fn) => `dxn:worker:${fn.name}` === trigger.function);
125
+ const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
126
+ const functionObject = functions.find((fn) => fn === trigger.function?.target);
127
127
  if (!functionObject) {
128
128
  return shortId;
129
129
  }
@@ -137,4 +137,4 @@ export {
137
137
  AutomationPanel,
138
138
  AutomationPanel_default
139
139
  };
140
- //# sourceMappingURL=chunk-NGG4ICAQ.mjs.map
140
+ //# sourceMappingURL=chunk-2QF27UJ2.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/AutomationPanel/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport React, { useState } from 'react';\n\nimport {\n FunctionType,\n FunctionTrigger,\n FunctionTriggerSchema,\n TriggerKind,\n type FunctionTriggerType,\n ScriptType,\n} from '@dxos/functions';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { live, Filter, useQuery, type Space, type Live, getSpace } from '@dxos/react-client/echo';\nimport { Clipboard, IconButton, Input, Separator, useTranslation } from '@dxos/react-ui';\nimport { ControlItem, controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\nimport { TriggerEditor, type TriggerEditorProps } from '../TriggerEditor';\n\nconst grid = 'grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]';\n\nexport type AutomationPanelProps = {\n space: Space;\n object?: Live<any>;\n initialTrigger?: FunctionTriggerType;\n onDone?: () => void;\n};\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ space, object, initialTrigger, onDone }: AutomationPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const client = useClient();\n const triggers = useQuery(space, Filter.type(FunctionTrigger));\n const functions = useQuery(space, Filter.type(FunctionType));\n const scripts = useQuery(space, Filter.type(ScriptType));\n\n const [trigger, setTrigger] = useState<FunctionTriggerType | undefined>(initialTrigger);\n const [selected, setSelected] = useState<FunctionTrigger>();\n\n const handleSelect = (trigger: FunctionTrigger) => {\n const { id: _, ...values } = trigger;\n setTrigger(values);\n setSelected(trigger);\n };\n\n const handleAdd = () => {\n setTrigger(live(FunctionTriggerSchema, {}));\n setSelected(undefined);\n };\n\n const handleDelete = (trigger: FunctionTrigger) => {\n space.db.remove(trigger);\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleSave: TriggerEditorProps['onSave'] = (trigger) => {\n if (selected) {\n Object.assign(selected, trigger);\n } else {\n space.db.add(live(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n onDone?.();\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n onDone?.();\n };\n\n return (\n <div className='flex flex-col w-full'>\n {trigger ? (\n <ControlItem title={t('trigger editor title')}>\n <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />\n </ControlItem>\n ) : (\n <div role='none' className={controlItemClasses}>\n <List.Root<FunctionTrigger> items={triggers} isItem={Schema.is(FunctionTrigger)} getId={(field) => field.id}>\n {({ items: triggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {triggers?.map((trigger) => {\n const copyAction = getCopyAction(client, trigger);\n return (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center', 'px-2')}\n >\n <Input.Root>\n <Input.Switch\n checked={trigger.enabled}\n onCheckedChange={(checked) => (trigger.enabled = checked)}\n />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle\n classNames='px-1 cursor-pointer w-0 shrink truncate'\n onClick={() => handleSelect(trigger)}\n >\n {getFunctionName(scripts, functions, trigger) ?? '∅'}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose copy action */}\n {copyAction && (\n <Clipboard.IconButton\n label={t(copyAction.translationKey)}\n value={copyAction.contentProvider()}\n />\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n {triggers.length > 0 && <Separator classNames='mlb-4' />}\n <IconButton icon='ph--plus--regular' label={t('new trigger label')} onClick={handleAdd} />\n </div>\n )}\n </div>\n );\n};\n\nconst getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.kind === TriggerKind.Email) {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.kind === TriggerKind.Webhook) {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTriggerType) => {\n // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}…`;\n const functionObject = functions.find((fn) => fn === trigger.function?.target);\n if (!functionObject) {\n return shortId;\n }\n\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AutomationPanel } from './AutomationPanel';\n\nexport * from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
5
+ "mappings": "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",
6
+ "names": ["Schema", "React", "useState", "FunctionType", "FunctionTrigger", "FunctionTriggerSchema", "TriggerKind", "ScriptType", "useClient", "live", "Filter", "useQuery", "getSpace", "Clipboard", "IconButton", "Input", "Separator", "useTranslation", "ControlItem", "controlItemClasses", "List", "ghostHover", "mx", "grid", "AutomationPanel", "space", "object", "initialTrigger", "onDone", "t", "useTranslation", "AUTOMATION_PLUGIN", "client", "useClient", "triggers", "useQuery", "Filter", "type", "FunctionTrigger", "functions", "FunctionType", "scripts", "ScriptType", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "id", "_", "values", "handleAdd", "live", "FunctionTriggerSchema", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "div", "className", "ControlItem", "title", "TriggerEditor", "onSave", "onCancel", "role", "controlItemClasses", "List", "Root", "items", "isItem", "Schema", "is", "getId", "field", "map", "copyAction", "getCopyAction", "Item", "key", "item", "classNames", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Clipboard", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "length", "Separator", "icon", "spec", "kind", "TriggerKind", "Email", "getSpace", "Webhook", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "dxn", "slice", "functionObject", "find", "fn", "target", "s", "source", "name", "AutomationPanel"]
7
+ }
@@ -0,0 +1,39 @@
1
+ import {
2
+ AUTOMATION_PLUGIN
3
+ } from "./chunk-WKKQV4PC.mjs";
4
+
5
+ // packages/plugins/plugin-automation/src/types.ts
6
+ import { Schema } from "effect";
7
+ import { SpaceSchema } from "@dxos/react-client/echo";
8
+ var TriggerTemplate = Schema.Union(Schema.Struct({
9
+ type: Schema.Literal("timer"),
10
+ cron: Schema.String
11
+ }), Schema.Struct({
12
+ type: Schema.Literal("queue"),
13
+ queueDXN: Schema.Any
14
+ }));
15
+ var AutomationAction;
16
+ (function(AutomationAction2) {
17
+ const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;
18
+ class CreateTriggerFromTemplate extends Schema.TaggedClass()(`${AUTOMATION_ACTION}/create-trigger-from-template`, {
19
+ input: Schema.Struct({
20
+ space: SpaceSchema,
21
+ template: TriggerTemplate,
22
+ enabled: Schema.optional(Schema.Boolean),
23
+ // TODO(wittjosiah): Improve how this lookup is done.
24
+ scriptName: Schema.optional(Schema.String),
25
+ input: Schema.optional(Schema.Record({
26
+ key: Schema.String,
27
+ value: Schema.Any
28
+ }))
29
+ }),
30
+ output: Schema.Void
31
+ }) {
32
+ }
33
+ AutomationAction2.CreateTriggerFromTemplate = CreateTriggerFromTemplate;
34
+ })(AutomationAction || (AutomationAction = {}));
35
+
36
+ export {
37
+ AutomationAction
38
+ };
39
+ //# sourceMappingURL=chunk-ADYCSC6Y.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/types.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { SpaceSchema } from '@dxos/react-client/echo';\n\nimport { AUTOMATION_PLUGIN } from './meta';\n\nconst TriggerTemplate = Schema.Union(\n Schema.Struct({ type: Schema.Literal('timer'), cron: Schema.String }),\n Schema.Struct({ type: Schema.Literal('queue'), queueDXN: Schema.Any }),\n);\n\nexport namespace AutomationAction {\n const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;\n\n export class CreateTriggerFromTemplate extends Schema.TaggedClass<CreateTriggerFromTemplate>()(\n `${AUTOMATION_ACTION}/create-trigger-from-template`,\n {\n input: Schema.Struct({\n space: SpaceSchema,\n template: TriggerTemplate,\n enabled: Schema.optional(Schema.Boolean),\n // TODO(wittjosiah): Improve how this lookup is done.\n scriptName: Schema.optional(Schema.String),\n input: Schema.optional(Schema.Record({ key: Schema.String, value: Schema.Any })),\n }),\n output: Schema.Void,\n },\n ) {}\n}\n"],
5
+ "mappings": ";;;;;AAIA,SAASA,cAAc;AAEvB,SAASC,mBAAmB;AAI5B,IAAMC,kBAAkBC,OAAOC,MAC7BD,OAAOE,OAAO;EAAEC,MAAMH,OAAOI,QAAQ,OAAA;EAAUC,MAAML,OAAOM;AAAO,CAAA,GACnEN,OAAOE,OAAO;EAAEC,MAAMH,OAAOI,QAAQ,OAAA;EAAUG,UAAUP,OAAOQ;AAAI,CAAA,CAAA;;UAGrDC,mBAAAA;AACf,QAAMC,oBAAoB,GAAGC,iBAAAA;EAEtB,MAAMC,kCAAkCZ,OAAOa,YAAW,EAC/D,GAAGH,iBAAAA,iCACH;IACEI,OAAOd,OAAOE,OAAO;MACnBa,OAAOC;MACPC,UAAUlB;MACVmB,SAASlB,OAAOmB,SAASnB,OAAOoB,OAAO;;MAEvCC,YAAYrB,OAAOmB,SAASnB,OAAOM,MAAM;MACzCQ,OAAOd,OAAOmB,SAASnB,OAAOsB,OAAO;QAAEC,KAAKvB,OAAOM;QAAQkB,OAAOxB,OAAOQ;MAAI,CAAA,CAAA;IAC/E,CAAA;IACAiB,QAAQzB,OAAO0B;EACjB,CAAA,EAAA;EACC;oBAbUd,4BAAAA;AAcf,GAjBiBH,qBAAAA,mBAAAA,CAAAA,EAAAA;",
6
+ "names": ["Schema", "SpaceSchema", "TriggerTemplate", "Schema", "Union", "Struct", "type", "Literal", "cron", "String", "queueDXN", "Any", "AutomationAction", "AUTOMATION_ACTION", "AUTOMATION_PLUGIN", "CreateTriggerFromTemplate", "TaggedClass", "input", "space", "SpaceSchema", "template", "enabled", "optional", "Boolean", "scriptName", "Record", "key", "value", "output", "Void"]
7
+ }
@@ -0,0 +1,211 @@
1
+ import {
2
+ AUTOMATION_PLUGIN
3
+ } from "./chunk-WKKQV4PC.mjs";
4
+
5
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
6
+ import React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react";
7
+ import { ComputeGraph } from "@dxos/conductor";
8
+ import { DXN } from "@dxos/echo";
9
+ import { FunctionType, FunctionTriggerSchema, ScriptType } from "@dxos/functions";
10
+ import { Filter, Ref, useQuery } from "@dxos/react-client/echo";
11
+ import { useTranslation as useTranslation2 } from "@dxos/react-ui";
12
+ import { Form as Form2, SelectInput as SelectInput2, useRefQueryLookupHandler } from "@dxos/react-ui-form";
13
+
14
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/FunctionInputEditor.tsx
15
+ import React, { useCallback, useMemo } from "react";
16
+ import { RefImpl, toEffectSchema } from "@dxos/echo-schema";
17
+ import { useOnTransition } from "@dxos/react-ui";
18
+ import { Form, useFormValues } from "@dxos/react-ui-form";
19
+ var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
20
+ const selectedFunctionValue = useFormValues([
21
+ "function"
22
+ ]);
23
+ const selectedFunctionId = useMemo(() => {
24
+ if (selectedFunctionValue instanceof RefImpl) {
25
+ return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
26
+ }
27
+ }, [
28
+ selectedFunctionValue
29
+ ]);
30
+ const selectedFunction = useMemo(() => functions.find((f) => f.id === selectedFunctionId), [
31
+ functions,
32
+ selectedFunctionId
33
+ ]);
34
+ useOnTransition(
35
+ // Clear function parameter input when the function changes.
36
+ selectedFunctionValue,
37
+ (prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
38
+ (currValue) => currValue !== void 0,
39
+ () => onValueChange("object", {})
40
+ );
41
+ const inputSchema = useMemo(() => selectedFunction?.inputSchema, [
42
+ selectedFunction
43
+ ]);
44
+ const effectSchema = useMemo(() => inputSchema ? toEffectSchema(inputSchema) : void 0, [
45
+ inputSchema
46
+ ]);
47
+ const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
48
+ const values = useMemo(() => getValue() ?? {}, [
49
+ getValue
50
+ ]);
51
+ const handleValuesChanged = useCallback((values2) => {
52
+ onValueChange("object", values2);
53
+ }, [
54
+ onValueChange
55
+ ]);
56
+ if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
57
+ return null;
58
+ }
59
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("h3", {
60
+ className: "text-md"
61
+ }, "Function parameters"), /* @__PURE__ */ React.createElement(Form, {
62
+ schema: effectSchema,
63
+ values,
64
+ classNames: "p-0",
65
+ onValuesChanged: handleValuesChanged,
66
+ onQueryRefOptions
67
+ }));
68
+ };
69
+
70
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/SpecSelector.tsx
71
+ import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
72
+ import { TriggerKind } from "@dxos/functions";
73
+ import { useTranslation } from "@dxos/react-ui";
74
+ import { SelectInput, useInputProps } from "@dxos/react-ui-form";
75
+ var SpecSelector = (props) => {
76
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
77
+ const specProps = useInputProps([
78
+ "spec"
79
+ ]);
80
+ const handleTypeChange = useCallback2((_type, value) => {
81
+ const getDefaultTriggerSpec = (kind) => {
82
+ switch (kind) {
83
+ case TriggerKind.Timer:
84
+ return {
85
+ kind: TriggerKind.Timer,
86
+ cron: ""
87
+ };
88
+ case TriggerKind.Subscription:
89
+ return {
90
+ kind: TriggerKind.Subscription,
91
+ filter: {}
92
+ };
93
+ case TriggerKind.Queue:
94
+ return {
95
+ kind: TriggerKind.Queue,
96
+ queue: ""
97
+ };
98
+ case TriggerKind.Email:
99
+ return {
100
+ kind: TriggerKind.Email
101
+ };
102
+ case TriggerKind.Webhook:
103
+ return {
104
+ kind: TriggerKind.Webhook
105
+ };
106
+ default:
107
+ return void 0;
108
+ }
109
+ };
110
+ const defaultSpec = getDefaultTriggerSpec(value);
111
+ if (!defaultSpec) {
112
+ return;
113
+ }
114
+ specProps.onValueChange("object", defaultSpec);
115
+ }, [
116
+ specProps
117
+ ]);
118
+ const options = useMemo2(() => Object.values(TriggerKind).map((kind) => ({
119
+ value: kind,
120
+ label: t(`trigger type ${kind}`)
121
+ })), [
122
+ t
123
+ ]);
124
+ return /* @__PURE__ */ React2.createElement(SelectInput, {
125
+ ...props,
126
+ options,
127
+ onValueChange: handleTypeChange
128
+ });
129
+ };
130
+
131
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
132
+ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
133
+ const { t } = useTranslation2(AUTOMATION_PLUGIN);
134
+ const functions = useQuery(space, Filter.type(FunctionType));
135
+ const workflows = useQuery(space, Filter.type(ComputeGraph));
136
+ const scripts = useQuery(space, Filter.type(ScriptType));
137
+ const handleSave = (values) => {
138
+ onSave?.(values);
139
+ };
140
+ const handleRefQueryLookup = useRefQueryLookupHandler({
141
+ space
142
+ });
143
+ const Custom = useMemo3(() => ({
144
+ ["function"]: (props) => {
145
+ const getValue = useCallback3(() => {
146
+ const formValue = props.getValue();
147
+ if (Ref.isRef(formValue)) {
148
+ return formValue.dxn.toString();
149
+ }
150
+ return void 0;
151
+ }, [
152
+ props
153
+ ]);
154
+ const handleOnValueChange = useCallback3((_type, dxnString) => {
155
+ const dxn = DXN.parse(dxnString);
156
+ if (dxn) {
157
+ const ref = Ref.fromDXN(dxn);
158
+ props.onValueChange("object", ref);
159
+ }
160
+ }, [
161
+ props.onValueChange
162
+ ]);
163
+ return /* @__PURE__ */ React3.createElement(SelectInput2, {
164
+ ...props,
165
+ getValue,
166
+ onValueChange: handleOnValueChange,
167
+ options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
168
+ });
169
+ },
170
+ ["spec.kind"]: SpecSelector,
171
+ ["input"]: (props) => /* @__PURE__ */ React3.createElement(FunctionInputEditor, {
172
+ ...props,
173
+ functions,
174
+ onQueryRefOptions: handleRefQueryLookup
175
+ })
176
+ }), [
177
+ workflows,
178
+ scripts,
179
+ functions,
180
+ t
181
+ ]);
182
+ return /* @__PURE__ */ React3.createElement("div", {
183
+ role: "none",
184
+ className: "bs-full is-full"
185
+ }, /* @__PURE__ */ React3.createElement(Form2, {
186
+ schema: FunctionTriggerSchema,
187
+ values: trigger,
188
+ onSave: handleSave,
189
+ onCancel,
190
+ Custom,
191
+ onQueryRefOptions: handleRefQueryLookup
192
+ }));
193
+ };
194
+ var getWorkflowOptions = (graphs) => {
195
+ return graphs.map((graph) => ({
196
+ label: `compute-${graph.id}`,
197
+ value: `dxn:echo:@:${graph.id}`
198
+ }));
199
+ };
200
+ var getFunctionOptions = (scripts, functions) => {
201
+ const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
202
+ return functions.map((fn) => ({
203
+ label: getLabel(fn),
204
+ value: `dxn:echo:@:${fn.id}`
205
+ }));
206
+ };
207
+
208
+ export {
209
+ TriggerEditor
210
+ };
211
+ //# sourceMappingURL=chunk-BNQNURZN.mjs.map
@@ -0,0 +1,7 @@
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 { DXN } 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 { useTranslation } from '@dxos/react-ui';\nimport { type CustomInputMap, Form, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { FunctionInputEditor } from './FunctionInputEditor';\nimport { SpecSelector } from './SpecSelector';\nimport { AUTOMATION_PLUGIN } from '../../meta';\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 { t } = useTranslation(AUTOMATION_PLUGIN);\n\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 const handleSave = (values: FunctionTriggerType) => {\n onSave?.(values);\n };\n\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n\n const Custom = useMemo(\n (): CustomInputMap => ({\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 = 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 ['spec.kind' as const]: SpecSelector,\n ['input' as const]: (props) => (\n <FunctionInputEditor {...props} functions={functions} onQueryRefOptions={handleRefQueryLookup} />\n ),\n }),\n [workflows, scripts, functions, t],\n );\n\n return (\n <div role='none' className='bs-full is-full'>\n <Form\n schema={FunctionTriggerSchema}\n values={trigger}\n onSave={handleSave}\n onCancel={onCancel}\n Custom={Custom}\n onQueryRefOptions={handleRefQueryLookup}\n />\n </div>\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 { type JsonPath, RefImpl, toEffectSchema } 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 (selectedFunctionValue instanceof RefImpl) {\n return selectedFunctionValue.dxn.toString().split('dxn:echo:@:').at(1);\n }\n }, [selectedFunctionValue]);\n\n const selectedFunction = useMemo(\n () => functions.find((f) => f.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 ? 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 classNames='p-0'\n onValuesChanged={handleValuesChanged}\n onQueryRefOptions={onQueryRefOptions}\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", "DXN", "FunctionType", "FunctionTriggerSchema", "ScriptType", "Filter", "Ref", "useQuery", "useTranslation", "Form", "SelectInput", "useRefQueryLookupHandler", "React", "useCallback", "useMemo", "RefImpl", "toEffectSchema", "useOnTransition", "Form", "useFormValues", "FunctionInputEditor", "functions", "getValue", "onValueChange", "onQueryRefOptions", "selectedFunctionValue", "useFormValues", "selectedFunctionId", "useMemo", "RefImpl", "dxn", "toString", "split", "at", "selectedFunction", "find", "f", "id", "useOnTransition", "prevValue", "undefined", "currValue", "inputSchema", "effectSchema", "toEffectSchema", "propertyCount", "properties", "Object", "keys", "length", "values", "handleValuesChanged", "useCallback", "h3", "className", "Form", "schema", "classNames", "onValuesChanged", "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", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "type", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "handleSave", "values", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "useMemo", "props", "getValue", "useCallback", "formValue", "Ref", "isRef", "dxn", "toString", "undefined", "handleOnValueChange", "_type", "dxnString", "DXN", "parse", "ref", "fromDXN", "onValueChange", "React", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "SpecSelector", "FunctionInputEditor", "onQueryRefOptions", "div", "role", "className", "Form", "schema", "FunctionTriggerSchema", "graphs", "map", "graph", "label", "id", "value", "getLabel", "fn", "find", "s", "source", "target", "name"]
7
+ }
@@ -1,9 +1,9 @@
1
1
  // packages/plugins/plugin-automation/src/components/index.ts
2
2
  import { lazy } from "react";
3
- var AutomationContainer = lazy(() => import("./AutomationContainer-KEQ5RNIW.mjs"));
4
- var AutomationPanel = lazy(() => import("./AutomationPanel-G3OB6ELR.mjs"));
5
- var FunctionsContainer = lazy(() => import("./FunctionsContainer-STXBW4CX.mjs"));
6
- var FunctionsPanel = lazy(() => import("./FunctionsPanel-JJPLIAJW.mjs"));
3
+ var AutomationContainer = lazy(() => import("./AutomationContainer-DA6IW7O2.mjs"));
4
+ var AutomationPanel = lazy(() => import("./AutomationPanel-R42D3LDD.mjs"));
5
+ var FunctionsContainer = lazy(() => import("./FunctionsContainer-MPBMMOMS.mjs"));
6
+ var FunctionsPanel = lazy(() => import("./FunctionsPanel-NSI3P53X.mjs"));
7
7
 
8
8
  export {
9
9
  AutomationContainer,
@@ -11,4 +11,4 @@ export {
11
11
  FunctionsContainer,
12
12
  FunctionsPanel
13
13
  };
14
- //# sourceMappingURL=chunk-QJPKWYTL.mjs.map
14
+ //# sourceMappingURL=chunk-SGT76SL2.mjs.map
@@ -3,10 +3,10 @@ import {
3
3
  } from "./chunk-WKKQV4PC.mjs";
4
4
 
5
5
  // packages/plugins/plugin-automation/src/components/FunctionsPanel/FunctionsPanel.tsx
6
+ import { Schema } from "effect";
6
7
  import React, { useCallback, useMemo } from "react";
7
8
  import { createIntent, LayoutAction, useIntentDispatcher } from "@dxos/app-framework";
8
- import { S } from "@dxos/echo-schema";
9
- import { FunctionType, ScriptType } from "@dxos/functions/types";
9
+ import { FunctionType, ScriptType } from "@dxos/functions";
10
10
  import { Filter, fullyQualifiedId, useQuery } from "@dxos/react-client/echo";
11
11
  import { Button, useTranslation } from "@dxos/react-ui";
12
12
  import { controlItemClasses } from "@dxos/react-ui-form";
@@ -15,8 +15,8 @@ import { ghostHover, mx } from "@dxos/react-ui-theme";
15
15
  var grid = "grid grid-cols-[1fr_auto] min-bs-[2.5rem]";
16
16
  var FunctionsPanel = ({ space }) => {
17
17
  const { t } = useTranslation(AUTOMATION_PLUGIN);
18
- const functions = useQuery(space, Filter.schema(FunctionType));
19
- const scripts = useQuery(space, Filter.schema(ScriptType));
18
+ const functions = useQuery(space, Filter.type(FunctionType));
19
+ const scripts = useQuery(space, Filter.type(ScriptType));
20
20
  const { dispatchPromise: dispatch } = useIntentDispatcher();
21
21
  const functionToScriptMap = useMemo(() => functions.reduce((map, func) => {
22
22
  const scriptId = func.source?.target?.id;
@@ -56,7 +56,7 @@ var FunctionsPanel = ({ space }) => {
56
56
  className: mx(controlItemClasses)
57
57
  }, /* @__PURE__ */ React.createElement(List.Root, {
58
58
  items: functions,
59
- isItem: S.is(FunctionType),
59
+ isItem: Schema.is(FunctionType),
60
60
  getId: (func) => func.id
61
61
  }, ({ items }) => /* @__PURE__ */ React.createElement("div", {
62
62
  role: "list",
@@ -85,4 +85,4 @@ export {
85
85
  FunctionsPanel,
86
86
  FunctionsPanel_default
87
87
  };
88
- //# sourceMappingURL=chunk-65VL4EYS.mjs.map
88
+ //# sourceMappingURL=chunk-TRC3J2I6.mjs.map