@dxos/plugin-automation 0.8.4-main.dedc0f3 → 0.8.4-main.ead640a

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 (177) hide show
  1. package/dist/lib/browser/AutomationPanel-3PHA5FTJ.mjs +11 -0
  2. package/dist/lib/browser/AutomationSettings-OQERZHTG.mjs +69 -0
  3. package/dist/lib/browser/AutomationSettings-OQERZHTG.mjs.map +7 -0
  4. package/dist/lib/browser/{FunctionsContainer-U4HASI4P.mjs → FunctionsContainer-V3OM6BFC.mjs} +7 -7
  5. package/dist/lib/browser/FunctionsContainer-V3OM6BFC.mjs.map +7 -0
  6. package/dist/lib/browser/{FunctionsPanel-I443Y6KB.mjs → FunctionsPanel-PTFCCUTB.mjs} +3 -3
  7. package/dist/lib/browser/{app-graph-builder-4OFKIRAI.mjs → app-graph-builder-DV5HMFX4.mjs} +10 -9
  8. package/dist/lib/browser/app-graph-builder-DV5HMFX4.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-2AOFK5FW.mjs +14 -0
  10. package/dist/lib/browser/chunk-2AOFK5FW.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-5ARH77PV.mjs +15 -0
  12. package/dist/lib/browser/chunk-5ARH77PV.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-Z5DT4MHW.mjs → chunk-DK7R2HNC.mjs} +20 -7
  14. package/dist/lib/browser/chunk-DK7R2HNC.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-MVPRI3DB.mjs +53 -0
  16. package/dist/lib/browser/chunk-MVPRI3DB.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-QACR4BJ7.mjs +14 -0
  18. package/dist/lib/browser/chunk-QACR4BJ7.mjs.map +7 -0
  19. package/dist/lib/browser/{chunk-S4SM663I.mjs → chunk-SUKAEYF3.mjs} +55 -18
  20. package/dist/lib/browser/chunk-SUKAEYF3.mjs.map +7 -0
  21. package/dist/lib/browser/{chunk-HN7OHFCB.mjs → chunk-VGBZKM3O.mjs} +3 -3
  22. package/dist/lib/browser/chunk-VGBZKM3O.mjs.map +7 -0
  23. package/dist/lib/browser/{chunk-4TWQV33E.mjs → chunk-VL3KSDVL.mjs} +57 -17
  24. package/dist/lib/browser/chunk-VL3KSDVL.mjs.map +7 -0
  25. package/dist/lib/browser/{chunk-GW5U2DGT.mjs → chunk-WWURMV25.mjs} +2 -4
  26. package/dist/lib/browser/chunk-WWURMV25.mjs.map +7 -0
  27. package/dist/lib/browser/compute-runtime-YJREH6WP.mjs +160 -0
  28. package/dist/lib/browser/compute-runtime-YJREH6WP.mjs.map +7 -0
  29. package/dist/lib/browser/hooks/index.mjs +12 -0
  30. package/dist/lib/browser/index.mjs +35 -14
  31. package/dist/lib/browser/index.mjs.map +4 -4
  32. package/dist/lib/browser/{intent-resolver-4PSYSQQG.mjs → intent-resolver-D2OHKQRR.mjs} +5 -5
  33. package/dist/lib/browser/{intent-resolver-4PSYSQQG.mjs.map → intent-resolver-D2OHKQRR.mjs.map} +1 -1
  34. package/dist/lib/browser/meta.json +1 -1
  35. package/dist/lib/browser/{react-surface-M52XGLXY.mjs → react-surface-POLPITTD.mjs} +18 -19
  36. package/dist/lib/browser/react-surface-POLPITTD.mjs.map +7 -0
  37. package/dist/lib/browser/types/index.mjs +2 -2
  38. package/dist/lib/node-esm/{AutomationPanel-MKOLA2FE.mjs → AutomationPanel-EETYIR35.mjs} +4 -4
  39. package/dist/lib/node-esm/AutomationSettings-MCB7HK3O.mjs +70 -0
  40. package/dist/lib/node-esm/AutomationSettings-MCB7HK3O.mjs.map +7 -0
  41. package/dist/lib/node-esm/{FunctionsContainer-VZIVURH6.mjs → FunctionsContainer-UGODP6YP.mjs} +7 -7
  42. package/dist/lib/node-esm/FunctionsContainer-UGODP6YP.mjs.map +7 -0
  43. package/dist/lib/node-esm/{FunctionsPanel-ELINCXPW.mjs → FunctionsPanel-JQFBRVOC.mjs} +3 -3
  44. package/dist/lib/node-esm/FunctionsPanel-JQFBRVOC.mjs.map +7 -0
  45. package/dist/lib/node-esm/{app-graph-builder-555IHYOB.mjs → app-graph-builder-TR2WXPX2.mjs} +10 -9
  46. package/dist/lib/node-esm/app-graph-builder-TR2WXPX2.mjs.map +7 -0
  47. package/dist/lib/node-esm/{chunk-NK5N3QKD.mjs → chunk-5MQJPJR2.mjs} +2 -4
  48. package/dist/lib/node-esm/chunk-5MQJPJR2.mjs.map +7 -0
  49. package/dist/lib/node-esm/{chunk-AONUBWBE.mjs → chunk-AKHETVIQ.mjs} +57 -17
  50. package/dist/lib/node-esm/chunk-AKHETVIQ.mjs.map +7 -0
  51. package/dist/lib/node-esm/{chunk-OEZNHUL2.mjs → chunk-CJUI6AKX.mjs} +3 -3
  52. package/dist/lib/node-esm/chunk-CJUI6AKX.mjs.map +7 -0
  53. package/dist/lib/node-esm/{chunk-CX2AILIS.mjs → chunk-G72KHW5A.mjs} +20 -7
  54. package/dist/lib/node-esm/chunk-G72KHW5A.mjs.map +7 -0
  55. package/dist/lib/node-esm/{chunk-ZOJVKPCA.mjs → chunk-J3XEBEIE.mjs} +55 -18
  56. package/dist/lib/node-esm/chunk-J3XEBEIE.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-LB7UQ4SK.mjs +16 -0
  58. package/dist/lib/node-esm/chunk-LB7UQ4SK.mjs.map +7 -0
  59. package/dist/lib/node-esm/chunk-QCA543ZR.mjs +54 -0
  60. package/dist/lib/node-esm/chunk-QCA543ZR.mjs.map +7 -0
  61. package/dist/lib/node-esm/chunk-TXFXIA34.mjs +16 -0
  62. package/dist/lib/node-esm/chunk-TXFXIA34.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-WHCSOUNN.mjs +16 -0
  64. package/dist/lib/node-esm/chunk-WHCSOUNN.mjs.map +7 -0
  65. package/dist/lib/node-esm/compute-runtime-CMEPAYND.mjs +161 -0
  66. package/dist/lib/node-esm/compute-runtime-CMEPAYND.mjs.map +7 -0
  67. package/dist/lib/node-esm/hooks/index.mjs +13 -0
  68. package/dist/lib/node-esm/hooks/index.mjs.map +7 -0
  69. package/dist/lib/node-esm/index.mjs +35 -14
  70. package/dist/lib/node-esm/index.mjs.map +4 -4
  71. package/dist/lib/node-esm/{intent-resolver-6ZGBUILG.mjs → intent-resolver-2LGBVXT5.mjs} +5 -5
  72. package/dist/lib/node-esm/{intent-resolver-6ZGBUILG.mjs.map → intent-resolver-2LGBVXT5.mjs.map} +1 -1
  73. package/dist/lib/node-esm/meta.json +1 -1
  74. package/dist/lib/node-esm/{react-surface-Y6AOXM75.mjs → react-surface-5ULTTXAZ.mjs} +18 -19
  75. package/dist/lib/node-esm/react-surface-5ULTTXAZ.mjs.map +7 -0
  76. package/dist/lib/node-esm/types/index.mjs +2 -2
  77. package/dist/types/src/AutomationPlugin.d.ts +1 -1
  78. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  79. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  80. package/dist/types/src/capabilities/capabilities.d.ts +19 -0
  81. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -0
  82. package/dist/types/src/capabilities/compute-runtime.d.ts +5 -0
  83. package/dist/types/src/capabilities/compute-runtime.d.ts.map +1 -0
  84. package/dist/types/src/capabilities/index.d.ts +2 -0
  85. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  86. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  87. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  88. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts +3 -1
  89. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  90. package/dist/types/src/components/AutomationSettings.d.ts +5 -0
  91. package/dist/types/src/components/AutomationSettings.d.ts.map +1 -0
  92. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
  93. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +1 -1
  94. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +1 -1
  95. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +4 -2
  96. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  97. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts +7 -4
  98. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  99. package/dist/types/src/components/TriggerSettings.d.ts +6 -0
  100. package/dist/types/src/components/TriggerSettings.d.ts.map +1 -0
  101. package/dist/types/src/components/index.d.ts +1 -1
  102. package/dist/types/src/components/index.d.ts.map +1 -1
  103. package/dist/types/src/events.d.ts +4 -0
  104. package/dist/types/src/events.d.ts.map +1 -0
  105. package/dist/types/src/hooks/index.d.ts +3 -0
  106. package/dist/types/src/hooks/index.d.ts.map +1 -0
  107. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts +8 -0
  108. package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts.map +1 -0
  109. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts +11 -0
  110. package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts.map +1 -0
  111. package/dist/types/src/index.d.ts +2 -0
  112. package/dist/types/src/index.d.ts.map +1 -1
  113. package/dist/types/src/meta.d.ts +0 -1
  114. package/dist/types/src/meta.d.ts.map +1 -1
  115. package/dist/types/src/translations.d.ts +3 -0
  116. package/dist/types/src/translations.d.ts.map +1 -1
  117. package/dist/types/src/types/schema.d.ts +1 -1
  118. package/dist/types/src/types/schema.d.ts.map +1 -1
  119. package/dist/types/tsconfig.tsbuildinfo +1 -1
  120. package/package.json +58 -37
  121. package/src/AutomationPlugin.tsx +35 -29
  122. package/src/capabilities/app-graph-builder.ts +8 -7
  123. package/src/capabilities/capabilities.ts +48 -0
  124. package/src/capabilities/compute-runtime.ts +138 -0
  125. package/src/capabilities/index.ts +3 -0
  126. package/src/capabilities/react-surface.tsx +13 -14
  127. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +3 -6
  128. package/src/components/AutomationPanel/AutomationPanel.tsx +78 -15
  129. package/src/components/{AutomationContainer.tsx → AutomationSettings.tsx} +8 -6
  130. package/src/components/FunctionsContainer.tsx +4 -4
  131. package/src/components/FunctionsPanel/FunctionsPanel.tsx +16 -4
  132. package/src/components/TriggerEditor/FunctionInputEditor.tsx +8 -2
  133. package/src/components/TriggerEditor/SpecSelector.tsx +10 -4
  134. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +57 -18
  135. package/src/components/TriggerEditor/TriggerEditor.tsx +35 -9
  136. package/src/components/TriggerSettings.tsx +25 -0
  137. package/src/components/index.ts +1 -1
  138. package/src/events.ts +11 -0
  139. package/src/hooks/index.ts +6 -0
  140. package/src/hooks/useComputeRuntimeCallback.ts +30 -0
  141. package/src/hooks/useTriggerRuntimeControls.ts +52 -0
  142. package/src/index.ts +2 -0
  143. package/src/meta.ts +1 -3
  144. package/src/testing/test-functions.ts +1 -1
  145. package/src/translations.ts +5 -0
  146. package/src/types/schema.ts +1 -1
  147. package/dist/lib/browser/AutomationContainer-BRV5AJZ3.mjs +0 -35
  148. package/dist/lib/browser/AutomationContainer-BRV5AJZ3.mjs.map +0 -7
  149. package/dist/lib/browser/AutomationPanel-N5HFJJXW.mjs +0 -11
  150. package/dist/lib/browser/FunctionsContainer-U4HASI4P.mjs.map +0 -7
  151. package/dist/lib/browser/app-graph-builder-4OFKIRAI.mjs.map +0 -7
  152. package/dist/lib/browser/chunk-4TWQV33E.mjs.map +0 -7
  153. package/dist/lib/browser/chunk-EIY2EUWC.mjs +0 -14
  154. package/dist/lib/browser/chunk-EIY2EUWC.mjs.map +0 -7
  155. package/dist/lib/browser/chunk-GW5U2DGT.mjs.map +0 -7
  156. package/dist/lib/browser/chunk-HN7OHFCB.mjs.map +0 -7
  157. package/dist/lib/browser/chunk-S4SM663I.mjs.map +0 -7
  158. package/dist/lib/browser/chunk-Z5DT4MHW.mjs.map +0 -7
  159. package/dist/lib/browser/react-surface-M52XGLXY.mjs.map +0 -7
  160. package/dist/lib/node-esm/AutomationContainer-FYRDTERM.mjs +0 -36
  161. package/dist/lib/node-esm/AutomationContainer-FYRDTERM.mjs.map +0 -7
  162. package/dist/lib/node-esm/FunctionsContainer-VZIVURH6.mjs.map +0 -7
  163. package/dist/lib/node-esm/app-graph-builder-555IHYOB.mjs.map +0 -7
  164. package/dist/lib/node-esm/chunk-AONUBWBE.mjs.map +0 -7
  165. package/dist/lib/node-esm/chunk-CICQ73ZT.mjs +0 -16
  166. package/dist/lib/node-esm/chunk-CICQ73ZT.mjs.map +0 -7
  167. package/dist/lib/node-esm/chunk-CX2AILIS.mjs.map +0 -7
  168. package/dist/lib/node-esm/chunk-NK5N3QKD.mjs.map +0 -7
  169. package/dist/lib/node-esm/chunk-OEZNHUL2.mjs.map +0 -7
  170. package/dist/lib/node-esm/chunk-ZOJVKPCA.mjs.map +0 -7
  171. package/dist/lib/node-esm/react-surface-Y6AOXM75.mjs.map +0 -7
  172. package/dist/types/src/components/AutomationContainer.d.ts +0 -5
  173. package/dist/types/src/components/AutomationContainer.d.ts.map +0 -1
  174. /package/dist/lib/browser/{AutomationPanel-N5HFJJXW.mjs.map → AutomationPanel-3PHA5FTJ.mjs.map} +0 -0
  175. /package/dist/lib/browser/{FunctionsPanel-I443Y6KB.mjs.map → FunctionsPanel-PTFCCUTB.mjs.map} +0 -0
  176. /package/dist/lib/{node-esm/AutomationPanel-MKOLA2FE.mjs.map → browser/hooks/index.mjs.map} +0 -0
  177. /package/dist/lib/node-esm/{FunctionsPanel-ELINCXPW.mjs.map → AutomationPanel-EETYIR35.mjs.map} +0 -0
@@ -1,21 +1,22 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  meta
4
- } from "./chunk-NK5N3QKD.mjs";
4
+ } from "./chunk-5MQJPJR2.mjs";
5
5
 
6
6
  // src/capabilities/app-graph-builder.ts
7
7
  import { Rx } from "@effect-rx/rx-react";
8
- import { Option, pipe } from "effect";
8
+ import * as Function from "effect/Function";
9
+ import * as Option from "effect/Option";
9
10
  import { Capabilities, contributes } from "@dxos/app-framework";
10
11
  import { Obj } from "@dxos/echo";
11
12
  import { ScriptType } from "@dxos/functions";
12
13
  import { ATTENDABLE_PATH_SEPARATOR, PLANK_COMPANION_TYPE } from "@dxos/plugin-deck/types";
13
14
  import { createExtension } from "@dxos/plugin-graph";
14
- import { SPACE_PLUGIN } from "@dxos/plugin-space";
15
- var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
15
+ import { meta as spaceMeta } from "@dxos/plugin-space";
16
+ var app_graph_builder_default = ((context) => contributes(Capabilities.AppGraphBuilder, [
16
17
  createExtension({
17
18
  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
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.type === `${spaceMeta.id}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
19
20
  {
20
21
  id: `automation-${node2.id}`,
21
22
  type: `${meta.id}/space-settings-automation`,
@@ -34,7 +35,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
34
35
  }),
35
36
  createExtension({
36
37
  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
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.type === `${spaceMeta.id}/settings` ? Option.some(node2) : Option.none()), Option.map((node2) => [
38
39
  {
39
40
  id: `functions-${node2.id}`,
40
41
  type: `${meta.id}/space-settings-functions`,
@@ -53,7 +54,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
53
54
  }),
54
55
  createExtension({
55
56
  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
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => Obj.instanceOf(ScriptType, node2.data) ? Option.some(node2) : Option.none()), Option.map((node2) => [
57
58
  {
58
59
  id: [
59
60
  node2.id,
@@ -74,8 +75,8 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
74
75
  }
75
76
  ]), Option.getOrElse(() => [])))
76
77
  })
77
- ]);
78
+ ]));
78
79
  export {
79
80
  app_graph_builder_default as default
80
81
  };
81
- //# sourceMappingURL=app-graph-builder-555IHYOB.mjs.map
82
+ //# sourceMappingURL=app-graph-builder-TR2WXPX2.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 * as Function from 'effect/Function';\nimport * as Option from 'effect/Option';\n\nimport { Capabilities, type PluginContext, contributes } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { ScriptType } from '@dxos/functions';\nimport { ATTENDABLE_PATH_SEPARATOR, PLANK_COMPANION_TYPE } from '@dxos/plugin-deck/types';\nimport { createExtension } from '@dxos/plugin-graph';\nimport { meta as spaceMeta } 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 Function.pipe(\n get(node),\n Option.flatMap((node) => (node.type === `${spaceMeta.id}/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 Function.pipe(\n get(node),\n Option.flatMap((node) => (node.type === `${spaceMeta.id}/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 Function.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,YAAYC,cAAc;AAC1B,YAAYC,YAAY;AAExB,SAASC,cAAkCC,mBAAmB;AAC9D,SAASC,WAAW;AACpB,SAASC,kBAAkB;AAC3B,SAASC,2BAA2BC,4BAA4B;AAChE,SAASC,uBAAuB;AAChC,SAASC,QAAQC,iBAAiB;AAIlC,IAAA,6BAAe,CAACC,YACdC,YAAYC,aAAaC,iBAAiB;EACxCC,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACEC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUA,MAAKM,SAAS,GAAGC,UAAUV,EAAE,cAAqBW,YAAKR,KAAAA,IAAeS,YAAI,CAAA,GAC7FC,WAAI,CAACV,UAAS;MACnB;QACEH,IAAI,cAAcG,MAAKH,EAAE;QACzBS,MAAM,GAAGR,KAAKD,EAAE;QAChBc,MAAM,GAAGb,KAAKD,EAAE;QAChBe,YAAY;UACVC,OAAO;YAAC;YAA0B;cAAEC,IAAIhB,KAAKD;YAAG;;UAChDkB,MAAM;QACR;MACF;KACD,GACMC,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACApB,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACEC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUA,MAAKM,SAAS,GAAGC,UAAUV,EAAE,cAAqBW,YAAKR,KAAAA,IAAeS,YAAI,CAAA,GAC7FC,WAAI,CAACV,UAAS;MACnB;QACEH,IAAI,aAAaG,MAAKH,EAAE;QACxBS,MAAM,GAAGR,KAAKD,EAAE;QAChBc,MAAM,GAAGb,KAAKD,EAAE;QAChBe,YAAY;UACVC,OAAO;YAAC;YAAyB;cAAEC,IAAIhB,KAAKD;YAAG;;UAC/CkB,MAAM;QACR;MACF;KACD,GACMC,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACApB,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,WAAW,CAACC,SACVC,GAAGC,KAAK,CAACC,QACEC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUiB,IAAIC,WAAWC,YAAYnB,MAAKW,IAAI,IAAWH,YAAKR,KAAAA,IAAeS,YAAI,CAAA,GAC1FC,WAAI,CAACV,UAAS;MACnB;QACEH,IAAI;UAACG,MAAKH;UAAI;UAAcuB,KAAKC,yBAAAA;QACjCf,MAAMgB;QACNX,MAAM;QACNC,YAAY;UACVC,OAAO;YAAC;YAA2B;cAAEC,IAAIhB,KAAKD;YAAG;;UACjDkB,MAAM;UACNQ,aAAa;QACf;MACF;KACD,GACMP,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;CACD;",
6
+ "names": ["Rx", "Function", "Option", "Capabilities", "contributes", "Obj", "ScriptType", "ATTENDABLE_PATH_SEPARATOR", "PLANK_COMPANION_TYPE", "createExtension", "meta", "spaceMeta", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "connector", "node", "Rx", "make", "get", "pipe", "flatMap", "type", "spaceMeta", "some", "none", "map", "data", "properties", "label", "ns", "icon", "getOrElse", "Obj", "instanceOf", "ScriptType", "join", "ATTENDABLE_PATH_SEPARATOR", "PLANK_COMPANION_TYPE", "disposition"]
7
+ }
@@ -1,9 +1,8 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
 
3
3
  // src/meta.ts
4
- var AUTOMATION_PLUGIN = "dxos.org/plugin/automation";
5
4
  var meta = {
6
- id: AUTOMATION_PLUGIN,
5
+ id: "dxos.org/plugin/automation",
7
6
  name: "Automation",
8
7
  description: "The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.",
9
8
  icon: "ph--robot--regular",
@@ -11,7 +10,6 @@ var meta = {
11
10
  };
12
11
 
13
12
  export {
14
- AUTOMATION_PLUGIN,
15
13
  meta
16
14
  };
17
- //# sourceMappingURL=chunk-NK5N3QKD.mjs.map
15
+ //# sourceMappingURL=chunk-5MQJPJR2.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/meta.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/automation',\n name: 'Automation',\n description:\n 'The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.',\n icon: 'ph--robot--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-automation',\n};\n"],
5
+ "mappings": ";;;AAMO,IAAMA,OAAmB;EAC9BC,IAAI;EACJC,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;AACV;",
6
+ "names": ["meta", "id", "name", "description", "icon", "source"]
7
+ }
@@ -1,32 +1,51 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  TriggerEditor
4
- } from "./chunk-ZOJVKPCA.mjs";
4
+ } from "./chunk-J3XEBEIE.mjs";
5
5
  import {
6
- AUTOMATION_PLUGIN
7
- } from "./chunk-NK5N3QKD.mjs";
6
+ meta
7
+ } from "./chunk-5MQJPJR2.mjs";
8
8
 
9
9
  // src/components/AutomationPanel/AutomationPanel.tsx
10
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";
11
+ import * as Array from "effect/Array";
12
+ import * as Function from "effect/Function";
13
+ import * as Match from "effect/Match";
14
+ import * as Schema from "effect/Schema";
15
+ import React, { useMemo, useState } from "react";
16
+ import { Filter, Obj, Tag } from "@dxos/echo";
14
17
  import { FunctionTrigger, FunctionType, ScriptType } from "@dxos/functions";
18
+ import { useTypeOptions } from "@dxos/plugin-space";
15
19
  import { useClient } from "@dxos/react-client";
16
20
  import { getSpace, useQuery } from "@dxos/react-client/echo";
17
21
  import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
18
22
  import { ControlItem, controlItemClasses } from "@dxos/react-ui-form";
19
23
  import { List } from "@dxos/react-ui-list";
20
24
  import { ghostHover, mx } from "@dxos/react-ui-theme";
25
+ import { DataType } from "@dxos/schema";
21
26
  var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
22
27
  var AutomationPanel = ({ classNames, space, object, initialTrigger, onDone }) => {
23
28
  var _effect = _useSignals();
24
29
  try {
25
- const { t } = useTranslation(AUTOMATION_PLUGIN);
30
+ const { t } = useTranslation(meta.id);
26
31
  const client = useClient();
27
- const triggers = useQuery(space, Filter.type(FunctionTrigger));
28
32
  const functions = useQuery(space, Filter.type(FunctionType));
29
- const scripts = useQuery(space, Filter.type(ScriptType));
33
+ const triggers = useQuery(space, Filter.type(FunctionTrigger));
34
+ const filteredTriggers = useMemo(() => {
35
+ return object ? triggers.filter(triggerMatch(object)) : triggers;
36
+ }, [
37
+ object,
38
+ triggers
39
+ ]);
40
+ const tags = useQuery(space, Filter.type(Tag.Tag));
41
+ const types = useTypeOptions({
42
+ space,
43
+ annotation: [
44
+ "dynamic",
45
+ "limited-static",
46
+ "object-form"
47
+ ]
48
+ });
30
49
  const [trigger, setTrigger] = useState(initialTrigger);
31
50
  const [selected, setSelected] = useState();
32
51
  const handleSelect = (trigger2) => {
@@ -62,20 +81,23 @@ var AutomationPanel = ({ classNames, space, object, initialTrigger, onDone }) =>
62
81
  }, /* @__PURE__ */ React.createElement(TriggerEditor, {
63
82
  space,
64
83
  trigger,
84
+ readonlySpec: Boolean(object),
85
+ tags,
86
+ types,
65
87
  onSave: handleSave,
66
88
  onCancel: handleCancel
67
89
  }));
68
90
  }
69
91
  return /* @__PURE__ */ React.createElement("div", {
70
92
  className: mx(controlItemClasses, classNames)
71
- }, triggers.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
72
- items: triggers,
93
+ }, filteredTriggers.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
94
+ items: filteredTriggers,
73
95
  isItem: Schema.is(FunctionTrigger),
74
96
  getId: (field) => field.id
75
- }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
97
+ }, ({ items: filteredTriggers2 }) => /* @__PURE__ */ React.createElement("div", {
76
98
  role: "list",
77
99
  className: "flex flex-col w-full"
78
- }, triggers2?.map((trigger2) => {
100
+ }, filteredTriggers2?.map((trigger2) => {
79
101
  const copyAction = getCopyAction(client, trigger2);
80
102
  return /* @__PURE__ */ React.createElement(List.Item, {
81
103
  key: trigger2.id,
@@ -89,13 +111,13 @@ var AutomationPanel = ({ classNames, space, object, initialTrigger, onDone }) =>
89
111
  }, /* @__PURE__ */ React.createElement(List.ItemTitle, {
90
112
  classNames: "px-1 cursor-pointer w-0 shrink truncate",
91
113
  onClick: () => handleSelect(trigger2)
92
- }, getFunctionName(scripts, functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
114
+ }, getFunctionName(functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
93
115
  label: t(copyAction.translationKey),
94
116
  value: copyAction.contentProvider()
95
117
  })), /* @__PURE__ */ React.createElement(List.ItemDeleteButton, {
96
118
  onClick: () => handleDelete(trigger2)
97
119
  }));
98
- }))), triggers.length > 0 && /* @__PURE__ */ React.createElement(Separator, {
120
+ }))), filteredTriggers.length > 0 && /* @__PURE__ */ React.createElement(Separator, {
99
121
  classNames: "mlb-4"
100
122
  }), /* @__PURE__ */ React.createElement(IconButton, {
101
123
  icon: "ph--plus--regular",
@@ -128,11 +150,29 @@ var getWebhookUrl = (client, trigger) => {
128
150
  edgeUrl.protocol = isSecure ? "https" : "http";
129
151
  return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
130
152
  };
131
- var getFunctionName = (scripts, functions, trigger) => {
153
+ var getFunctionName = (functions, trigger) => {
132
154
  const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
133
155
  const functionObject = functions.find((fn) => fn === trigger.function?.target);
134
156
  return functionObject?.name ?? shortId;
135
157
  };
158
+ var scriptMatch = (script) => (trigger) => {
159
+ const fn = trigger.function?.target;
160
+ if (!Obj.instanceOf(FunctionType, fn)) {
161
+ return false;
162
+ }
163
+ return fn.source?.target === script;
164
+ };
165
+ var projectMatch = (project) => {
166
+ const viewQueries = Function.pipe(project.collections, Array.map((collection) => collection.target), Array.filter(Schema.is(DataType.View)), Array.map((view) => Obj.getSnapshot(view).query.ast), Array.map((ast) => JSON.stringify(ast)));
167
+ return (trigger) => {
168
+ const spec = Obj.getSnapshot(trigger).spec;
169
+ if (spec?.kind !== "subscription") {
170
+ return false;
171
+ }
172
+ return viewQueries.some((query) => JSON.stringify(spec.query) === query);
173
+ };
174
+ };
175
+ var triggerMatch = Match.type().pipe(Match.withReturnType(), Match.when((obj) => Obj.instanceOf(ScriptType, obj), (obj) => scriptMatch(obj)), Match.when((obj) => Obj.instanceOf(DataType.Project, obj), (obj) => projectMatch(obj)), Match.orElse((_obj) => () => true));
136
176
 
137
177
  // src/components/AutomationPanel/index.ts
138
178
  var AutomationPanel_default = AutomationPanel;
@@ -141,4 +181,4 @@ export {
141
181
  AutomationPanel,
142
182
  AutomationPanel_default
143
183
  };
144
- //# sourceMappingURL=chunk-AONUBWBE.mjs.map
184
+ //# sourceMappingURL=chunk-AKHETVIQ.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 * as Array from 'effect/Array';\nimport * as Function from 'effect/Function';\nimport * as Match from 'effect/Match';\nimport * as Schema from 'effect/Schema';\nimport React, { useMemo, useState } from 'react';\n\nimport { Filter, Obj, Tag } from '@dxos/echo';\nimport { FunctionTrigger, FunctionType, ScriptType } from '@dxos/functions';\nimport { useTypeOptions } from '@dxos/plugin-space';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { type Space, getSpace, useQuery } from '@dxos/react-client/echo';\nimport { Clipboard, IconButton, Input, Separator, type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { ControlItem, controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\nimport { DataType } from '@dxos/schema';\n\nimport { meta } from '../../meta';\nimport { TriggerEditor, type TriggerEditorProps } from '../TriggerEditor';\n\nconst grid = 'grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]';\n\nexport type AutomationPanelProps = ThemedClassName<{\n space: Space;\n object?: Obj.Any;\n initialTrigger?: FunctionTrigger;\n onDone?: () => void;\n}>;\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ classNames, space, object, initialTrigger, onDone }: AutomationPanelProps) => {\n const { t } = useTranslation(meta.id);\n const client = useClient();\n const functions = useQuery(space, Filter.type(FunctionType));\n const triggers = useQuery(space, Filter.type(FunctionTrigger));\n const filteredTriggers = useMemo(() => {\n return object ? triggers.filter(triggerMatch(object)) : triggers;\n }, [object, triggers]);\n const tags = useQuery(space, Filter.type(Tag.Tag));\n const types = useTypeOptions({ space, annotation: ['dynamic', 'limited-static', 'object-form'] });\n\n const [trigger, setTrigger] = useState<FunctionTrigger | undefined>(initialTrigger);\n const [selected, setSelected] = useState<FunctionTrigger>();\n\n const handleSelect = (trigger: FunctionTrigger) => {\n setTrigger(trigger);\n setSelected(trigger);\n };\n\n const handleAdd = () => {\n setTrigger(Obj.make(FunctionTrigger, {}));\n setSelected(undefined);\n };\n\n const handleDelete = (trigger: FunctionTrigger) => {\n space.db.remove(trigger);\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleSave: TriggerEditorProps['onSave'] = (trigger) => {\n if (selected) {\n Object.assign(selected, trigger);\n } else {\n space.db.add(Obj.make(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n onDone?.();\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n onDone?.();\n };\n\n if (trigger) {\n return (\n <ControlItem title={t('trigger editor title')}>\n <TriggerEditor\n space={space}\n trigger={trigger}\n readonlySpec={Boolean(object)}\n tags={tags}\n types={types}\n onSave={handleSave}\n onCancel={handleCancel}\n />\n </ControlItem>\n );\n }\n\n return (\n <div className={mx(controlItemClasses, classNames)}>\n {filteredTriggers.length > 0 && (\n <List.Root<FunctionTrigger>\n items={filteredTriggers}\n isItem={Schema.is(FunctionTrigger)}\n getId={(field) => field.id}\n >\n {({ items: filteredTriggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {filteredTriggers?.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(functions, trigger) ?? '∅'}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose copy action */}\n {copyAction && (\n <Clipboard.IconButton\n label={t(copyAction.translationKey)}\n value={copyAction.contentProvider()}\n />\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n )}\n {filteredTriggers.length > 0 && <Separator classNames='mlb-4' />}\n <IconButton icon='ph--plus--regular' label={t('new trigger label')} onClick={handleAdd} />\n </div>\n );\n};\n\nconst getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.kind === 'email') {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.kind === 'webhook') {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (functions: FunctionType[], trigger: FunctionTrigger) => {\n // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}…`;\n const functionObject = functions.find((fn) => fn === trigger.function?.target);\n return functionObject?.name ?? shortId;\n};\n\nconst scriptMatch = (script: ScriptType) => (trigger: FunctionTrigger) => {\n const fn = trigger.function?.target;\n if (!Obj.instanceOf(FunctionType, fn)) {\n return false;\n }\n\n return fn.source?.target === script;\n};\n\nconst projectMatch = (project: DataType.Project) => {\n const viewQueries = Function.pipe(\n project.collections,\n Array.map((collection) => collection.target),\n Array.filter(Schema.is(DataType.View)),\n Array.map((view) => Obj.getSnapshot(view).query.ast),\n Array.map((ast) => JSON.stringify(ast)),\n );\n\n return (trigger: FunctionTrigger) => {\n const spec = Obj.getSnapshot(trigger).spec;\n if (spec?.kind !== 'subscription') {\n return false;\n }\n\n // TODO(wittjosiah): Implement better way of comparing query ASTs.\n return viewQueries.some((query) => JSON.stringify(spec.query) === query);\n };\n};\n\nconst triggerMatch = Match.type<Obj.Any>().pipe(\n Match.withReturnType<(trigger: FunctionTrigger) => boolean>(),\n Match.when(\n (obj) => Obj.instanceOf(ScriptType, obj),\n (obj) => scriptMatch(obj),\n ),\n Match.when(\n (obj) => Obj.instanceOf(DataType.Project, obj),\n (obj) => projectMatch(obj),\n ),\n Match.orElse((_obj) => () => true),\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": ["Array", "Function", "Match", "Schema", "React", "useMemo", "useState", "Filter", "Obj", "Tag", "FunctionTrigger", "FunctionType", "ScriptType", "useTypeOptions", "useClient", "getSpace", "useQuery", "Clipboard", "IconButton", "Input", "Separator", "useTranslation", "ControlItem", "controlItemClasses", "List", "ghostHover", "mx", "DataType", "grid", "AutomationPanel", "classNames", "space", "object", "initialTrigger", "onDone", "t", "useTranslation", "meta", "id", "client", "useClient", "functions", "useQuery", "Filter", "type", "FunctionType", "triggers", "FunctionTrigger", "filteredTriggers", "useMemo", "filter", "triggerMatch", "tags", "Tag", "types", "useTypeOptions", "annotation", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "handleAdd", "Obj", "make", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "ControlItem", "title", "TriggerEditor", "readonlySpec", "Boolean", "onSave", "onCancel", "div", "className", "mx", "controlItemClasses", "length", "List", "Root", "items", "isItem", "is", "getId", "field", "role", "map", "copyAction", "getCopyAction", "Item", "key", "item", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Clipboard", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "Separator", "icon", "spec", "kind", "getSpace", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "values", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "dxn", "slice", "functionObject", "find", "fn", "target", "name", "scriptMatch", "script", "instanceOf", "source", "projectMatch", "project", "viewQueries", "pipe", "collections", "collection", "DataType", "View", "view", "getSnapshot", "query", "ast", "JSON", "stringify", "some", "withReturnType", "when", "obj", "ScriptType", "Project", "orElse", "_obj", "AutomationPanel"]
7
+ }
@@ -1,10 +1,10 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  meta
4
- } from "./chunk-NK5N3QKD.mjs";
4
+ } from "./chunk-5MQJPJR2.mjs";
5
5
 
6
6
  // src/types/schema.ts
7
- import { Schema } from "effect";
7
+ import * as Schema from "effect/Schema";
8
8
  import { SpaceSchema } from "@dxos/react-client/echo";
9
9
  var TriggerTemplate = Schema.Union(Schema.Struct({
10
10
  type: Schema.Literal("timer"),
@@ -36,4 +36,4 @@ var AutomationAction;
36
36
  export {
37
37
  AutomationAction
38
38
  };
39
- //# sourceMappingURL=chunk-OEZNHUL2.mjs.map
39
+ //# sourceMappingURL=chunk-CJUI6AKX.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/types/schema.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\n\nimport { SpaceSchema } from '@dxos/react-client/echo';\n\nimport { meta } 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 export class CreateTriggerFromTemplate extends Schema.TaggedClass<CreateTriggerFromTemplate>()(\n `${meta.id}/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,YAAYA,YAAY;AAExB,SAASC,mBAAmB;AAI5B,IAAMC,kBAAyBC,aACtBC,cAAO;EAAEC,MAAaC,eAAQ,OAAA;EAAUC,MAAaC;AAAO,CAAA,GAC5DJ,cAAO;EAAEC,MAAaC,eAAQ,OAAA;EAAUG,UAAiBC;AAAI,CAAA,CAAA;UAGrDC,mBAAAA;EACR,MAAMC,kCAAyCC,mBAAW,EAC/D,GAAGC,KAAKC,EAAE,wCACV;IACEC,OAAcZ,cAAO;MACnBa,OAAOC;MACPC,UAAUjB;MACVkB,SAAgBC,gBAAgBC,cAAO;;MAEvCC,YAAmBF,gBAAgBb,aAAM;MACzCQ,OAAcK,gBAAgBG,cAAO;QAAEC,KAAYjB;QAAQkB,OAAchB;MAAI,CAAA,CAAA;IAC/E,CAAA;IACAiB,QAAeC;EACjB,CAAA,EAAA;EACC;oBAbUhB,4BAAAA;AAcf,GAfiBD,qBAAAA,mBAAAA,CAAAA,EAAAA;;",
6
+ "names": ["Schema", "SpaceSchema", "TriggerTemplate", "Union", "Struct", "type", "Literal", "cron", "String", "queueDXN", "Any", "AutomationAction", "CreateTriggerFromTemplate", "TaggedClass", "meta", "id", "input", "space", "SpaceSchema", "template", "enabled", "optional", "Boolean", "scriptName", "Record", "key", "value", "output", "Void"]
7
+ }
@@ -1,16 +1,17 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
- AUTOMATION_PLUGIN
4
- } from "./chunk-NK5N3QKD.mjs";
3
+ meta
4
+ } from "./chunk-5MQJPJR2.mjs";
5
5
 
6
6
  // src/components/FunctionsPanel/FunctionsPanel.tsx
7
7
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
8
- import { Schema } from "effect";
8
+ import * as Schema from "effect/Schema";
9
9
  import React, { useCallback, useMemo } from "react";
10
10
  import { LayoutAction, createIntent, useIntentDispatcher } from "@dxos/app-framework";
11
11
  import { FunctionType, ScriptType } from "@dxos/functions";
12
+ import { SpaceAction } from "@dxos/plugin-space/types";
12
13
  import { Filter, fullyQualifiedId, useQuery } from "@dxos/react-client/echo";
13
- import { Button, useTranslation } from "@dxos/react-ui";
14
+ import { Button, IconButton, useTranslation } from "@dxos/react-ui";
14
15
  import { controlItemClasses } from "@dxos/react-ui-form";
15
16
  import { List } from "@dxos/react-ui-list";
16
17
  import { ghostHover, mx } from "@dxos/react-ui-theme";
@@ -18,7 +19,7 @@ var grid = "grid grid-cols-[1fr_auto] min-bs-[2.5rem]";
18
19
  var FunctionsPanel = ({ space }) => {
19
20
  var _effect = _useSignals();
20
21
  try {
21
- const { t } = useTranslation(AUTOMATION_PLUGIN);
22
+ const { t } = useTranslation(meta.id);
22
23
  const functions = useQuery(space, Filter.type(FunctionType));
23
24
  const scripts = useQuery(space, Filter.type(ScriptType));
24
25
  const { dispatchPromise: dispatch } = useIntentDispatcher();
@@ -55,6 +56,13 @@ var FunctionsPanel = ({ space }) => {
55
56
  functionToScriptMap,
56
57
  dispatch
57
58
  ]);
59
+ const handleDelete = useCallback((func) => dispatch(createIntent(SpaceAction.RemoveObjects, {
60
+ objects: [
61
+ func
62
+ ]
63
+ })), [
64
+ dispatch
65
+ ]);
58
66
  return /* @__PURE__ */ React.createElement("div", {
59
67
  role: "none",
60
68
  className: mx(controlItemClasses)
@@ -77,7 +85,12 @@ var FunctionsPanel = ({ space }) => {
77
85
  className: "text-xs text-description truncate"
78
86
  }, getScriptName(func))), functionToScriptMap[func.id] && /* @__PURE__ */ React.createElement(Button, {
79
87
  onClick: () => handleGoToScript(func)
80
- }, t("go to function source button label")))))), functions.length === 0 && /* @__PURE__ */ React.createElement("div", {
88
+ }, t("go to function source button label")), /* @__PURE__ */ React.createElement(IconButton, {
89
+ iconOnly: true,
90
+ icon: "ph--trash--regular",
91
+ label: t("delete function button label"),
92
+ onClick: () => handleDelete(func)
93
+ }))))), functions.length === 0 && /* @__PURE__ */ React.createElement("div", {
81
94
  className: "text-center plb-4 text-gray-500"
82
95
  }, t("no functions found")));
83
96
  } finally {
@@ -92,4 +105,4 @@ export {
92
105
  FunctionsPanel,
93
106
  FunctionsPanel_default
94
107
  };
95
- //# sourceMappingURL=chunk-CX2AILIS.mjs.map
108
+ //# sourceMappingURL=chunk-G72KHW5A.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/FunctionsPanel/FunctionsPanel.tsx", "../../../src/components/FunctionsPanel/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\nimport React, { useCallback, useMemo } from 'react';\n\nimport { LayoutAction, createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { FunctionType, ScriptType } from '@dxos/functions';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { Filter, type Space, fullyQualifiedId, useQuery } from '@dxos/react-client/echo';\nimport { Button, IconButton, useTranslation } from '@dxos/react-ui';\nimport { controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\n\nimport { meta } from '../../meta';\n\nconst grid = 'grid grid-cols-[1fr_auto] min-bs-[2.5rem]';\n\nexport type FunctionsPanelProps = {\n space: Space;\n};\n\nexport const FunctionsPanel = ({ space }: FunctionsPanelProps) => {\n const { t } = useTranslation(meta.id);\n const functions = useQuery(space, Filter.type(FunctionType));\n const scripts = useQuery(space, Filter.type(ScriptType));\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n\n const functionToScriptMap = useMemo(\n () =>\n functions.reduce(\n (map, func) => {\n const scriptId = func.source?.target?.id;\n if (scriptId) {\n const script = scripts.find((s) => s.id === scriptId);\n if (script) {\n map[func.id] = script;\n }\n }\n return map;\n },\n {} as Record<string, ScriptType>,\n ),\n [functions, scripts],\n );\n\n const getScriptName = useCallback(\n (func: FunctionType) => {\n const script = functionToScriptMap[func.id];\n return script?.name;\n },\n [functionToScriptMap],\n );\n\n const handleGoToScript = useCallback(\n (func: FunctionType) => {\n const script = functionToScriptMap[func.id];\n if (script) {\n void dispatch(createIntent(LayoutAction.Open, { part: 'main', subject: [fullyQualifiedId(script)] }));\n }\n },\n [functionToScriptMap, dispatch],\n );\n\n const handleDelete = useCallback(\n (func: FunctionType) => dispatch(createIntent(SpaceAction.RemoveObjects, { objects: [func] })),\n [dispatch],\n );\n\n return (\n <div role='none' className={mx(controlItemClasses)}>\n {functions.length > 0 && (\n <List.Root<FunctionType> items={functions} isItem={Schema.is(FunctionType)} getId={(func) => func.id}>\n {({ items }) => (\n <div role='list' className='flex flex-col w-full'>\n {items?.map((func) => (\n <List.Item<FunctionType>\n key={func.id}\n item={func}\n classNames={mx(grid, ghostHover, 'items-center', 'pli-2', 'min-bs-[3rem]')}\n >\n <div className='flex flex-col truncate'>\n <List.ItemTitle classNames='truncate'>{func.name}</List.ItemTitle>\n {getScriptName(func) && (\n <div className='text-xs text-description truncate'>{getScriptName(func)}</div>\n )}\n </div>\n {functionToScriptMap[func.id] && (\n <Button onClick={() => handleGoToScript(func)}>{t('go to function source button label')}</Button>\n )}\n <IconButton\n iconOnly\n icon='ph--trash--regular'\n label={t('delete function button label')}\n onClick={() => handleDelete(func)}\n />\n </List.Item>\n ))}\n </div>\n )}\n </List.Root>\n )}\n\n {functions.length === 0 && <div className='text-center plb-4 text-gray-500'>{t('no functions found')}</div>}\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { FunctionsPanel } from './FunctionsPanel';\n\nexport * from './FunctionsPanel';\nexport default FunctionsPanel;\n"],
5
+ "mappings": ";;;;;;;AAIA,YAAYA,YAAY;AACxB,OAAOC,SAASC,aAAaC,eAAe;AAE5C,SAASC,cAAcC,cAAcC,2BAA2B;AAChE,SAASC,cAAcC,kBAAkB;AACzC,SAASC,mBAAmB;AAC5B,SAASC,QAAoBC,kBAAkBC,gBAAgB;AAC/D,SAASC,QAAQC,YAAYC,sBAAsB;AACnD,SAASC,0BAA0B;AACnC,SAASC,YAAY;AACrB,SAASC,YAAYC,UAAU;AAI/B,IAAMC,OAAO;AAMN,IAAMC,iBAAiB,CAAC,EAAEC,MAAK,MAAuB;;;AAC3D,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AACpC,UAAMC,YAAYC,SAASN,OAAOO,OAAOC,KAAKC,YAAAA,CAAAA;AAC9C,UAAMC,UAAUJ,SAASN,OAAOO,OAAOC,KAAKG,UAAAA,CAAAA;AAC5C,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AAEtC,UAAMC,sBAAsBC,QAC1B,MACEX,UAAUY,OACR,CAACC,KAAKC,SAAAA;AACJ,YAAMC,WAAWD,KAAKE,QAAQC,QAAQlB;AACtC,UAAIgB,UAAU;AACZ,cAAMG,SAASb,QAAQc,KAAK,CAACC,MAAMA,EAAErB,OAAOgB,QAAAA;AAC5C,YAAIG,QAAQ;AACVL,cAAIC,KAAKf,EAAE,IAAImB;QACjB;MACF;AACA,aAAOL;IACT,GACA,CAAC,CAAA,GAEL;MAACb;MAAWK;KAAQ;AAGtB,UAAMgB,gBAAgBC,YACpB,CAACR,SAAAA;AACC,YAAMI,SAASR,oBAAoBI,KAAKf,EAAE;AAC1C,aAAOmB,QAAQK;IACjB,GACA;MAACb;KAAoB;AAGvB,UAAMc,mBAAmBF,YACvB,CAACR,SAAAA;AACC,YAAMI,SAASR,oBAAoBI,KAAKf,EAAE;AAC1C,UAAImB,QAAQ;AACV,aAAKV,SAASiB,aAAaC,aAAaC,MAAM;UAAEC,MAAM;UAAQC,SAAS;YAACC,iBAAiBZ,MAAAA;;QAAS,CAAA,CAAA;MACpG;IACF,GACA;MAACR;MAAqBF;KAAS;AAGjC,UAAMuB,eAAeT,YACnB,CAACR,SAAuBN,SAASiB,aAAaO,YAAYC,eAAe;MAAEC,SAAS;QAACpB;;IAAM,CAAA,CAAA,GAC3F;MAACN;KAAS;AAGZ,WACE,sBAAA,cAAC2B,OAAAA;MAAIC,MAAK;MAAOC,WAAWC,GAAGC,kBAAAA;OAC5BvC,UAAUwC,SAAS,KAClB,sBAAA,cAACC,KAAKC,MAAI;MAAeC,OAAO3C;MAAW4C,QAAeC,UAAGzC,YAAAA;MAAe0C,OAAO,CAAChC,SAASA,KAAKf;OAC/F,CAAC,EAAE4C,MAAK,MACP,sBAAA,cAACR,OAAAA;MAAIC,MAAK;MAAOC,WAAU;OACxBM,OAAO9B,IAAI,CAACC,SACX,sBAAA,cAAC2B,KAAKM,MAAI;MACRC,KAAKlC,KAAKf;MACVkD,MAAMnC;MACNoC,YAAYZ,GAAG7C,MAAM0D,YAAY,gBAAgB,SAAS,eAAA;OAE1D,sBAAA,cAAChB,OAAAA;MAAIE,WAAU;OACb,sBAAA,cAACI,KAAKW,WAAS;MAACF,YAAW;OAAYpC,KAAKS,IAAI,GAC/CF,cAAcP,IAAAA,KACb,sBAAA,cAACqB,OAAAA;MAAIE,WAAU;OAAqChB,cAAcP,IAAAA,CAAAA,CAAAA,GAGrEJ,oBAAoBI,KAAKf,EAAE,KAC1B,sBAAA,cAACsD,QAAAA;MAAOC,SAAS,MAAM9B,iBAAiBV,IAAAA;OAAQlB,EAAE,oCAAA,CAAA,GAEpD,sBAAA,cAAC2D,YAAAA;MACCC,UAAAA;MACAC,MAAK;MACLC,OAAO9D,EAAE,8BAAA;MACT0D,SAAS,MAAMvB,aAAajB,IAAAA;YASzCd,UAAUwC,WAAW,KAAK,sBAAA,cAACL,OAAAA;MAAIE,WAAU;OAAmCzC,EAAE,oBAAA,CAAA,CAAA;;;;AAGrF;;;ACrGA,IAAA,yBAAe+D;",
6
+ "names": ["Schema", "React", "useCallback", "useMemo", "LayoutAction", "createIntent", "useIntentDispatcher", "FunctionType", "ScriptType", "SpaceAction", "Filter", "fullyQualifiedId", "useQuery", "Button", "IconButton", "useTranslation", "controlItemClasses", "List", "ghostHover", "mx", "grid", "FunctionsPanel", "space", "t", "useTranslation", "meta", "id", "functions", "useQuery", "Filter", "type", "FunctionType", "scripts", "ScriptType", "dispatchPromise", "dispatch", "useIntentDispatcher", "functionToScriptMap", "useMemo", "reduce", "map", "func", "scriptId", "source", "target", "script", "find", "s", "getScriptName", "useCallback", "name", "handleGoToScript", "createIntent", "LayoutAction", "Open", "part", "subject", "fullyQualifiedId", "handleDelete", "SpaceAction", "RemoveObjects", "objects", "div", "role", "className", "mx", "controlItemClasses", "length", "List", "Root", "items", "isItem", "is", "getId", "Item", "key", "item", "classNames", "ghostHover", "ItemTitle", "Button", "onClick", "IconButton", "iconOnly", "icon", "label", "FunctionsPanel"]
7
+ }
@@ -1,7 +1,7 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
- AUTOMATION_PLUGIN
4
- } from "./chunk-NK5N3QKD.mjs";
3
+ meta
4
+ } from "./chunk-5MQJPJR2.mjs";
5
5
 
6
6
  // src/components/TriggerEditor/TriggerEditor.tsx
7
7
  import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
@@ -9,8 +9,10 @@ import React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react"
9
9
  import { ComputeGraph } from "@dxos/conductor";
10
10
  import { Type as Type2 } from "@dxos/echo";
11
11
  import { FunctionTrigger, FunctionType, 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";
12
+ import { Filter as Filter2, Ref as Ref2, useQuery } from "@dxos/react-client/echo";
13
+ import { Input } from "@dxos/react-ui";
14
+ import { QueryForm } from "@dxos/react-ui-components";
15
+ import { Form as Form2, InputHeader, SelectInput as SelectInput2, useRefQueryLookupHandler } from "@dxos/react-ui-form";
14
16
 
15
17
  // src/components/TriggerEditor/FunctionInputEditor.tsx
16
18
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
@@ -38,7 +40,12 @@ var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptio
38
40
  useOnTransition(
39
41
  // Clear function parameter input when the function changes.
40
42
  selectedFunctionValue,
41
- (prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
43
+ (prevValue) => {
44
+ if (!Ref.isRef(prevValue) || !Ref.isRef(selectedFunctionValue)) {
45
+ return false;
46
+ }
47
+ return prevValue.dxn.toString() !== selectedFunctionValue.dxn.toString();
48
+ },
42
49
  (currValue) => currValue !== void 0,
43
50
  () => onValueChange("object", {})
44
51
  );
@@ -77,13 +84,14 @@ var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptio
77
84
  // src/components/TriggerEditor/SpecSelector.tsx
78
85
  import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
79
86
  import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
87
+ import { Filter, Query } from "@dxos/echo";
80
88
  import { TriggerKinds } from "@dxos/functions";
81
89
  import { useTranslation } from "@dxos/react-ui";
82
90
  import { SelectInput, useInputProps } from "@dxos/react-ui-form";
83
91
  var SpecSelector = (props) => {
84
92
  var _effect = _useSignals2();
85
93
  try {
86
- const { t } = useTranslation(AUTOMATION_PLUGIN);
94
+ const { t } = useTranslation(meta.id);
87
95
  const specProps = useInputProps([
88
96
  "spec"
89
97
  ]);
@@ -98,12 +106,14 @@ var SpecSelector = (props) => {
98
106
  case "subscription":
99
107
  return {
100
108
  kind: "subscription",
101
- filter: {}
109
+ query: {
110
+ ast: Query.select(Filter.nothing()).ast
111
+ }
102
112
  };
103
113
  case "queue":
104
114
  return {
105
115
  kind: "queue",
106
- queue: ""
116
+ queue: "dxn:"
107
117
  };
108
118
  case "email":
109
119
  return {
@@ -142,16 +152,22 @@ var SpecSelector = (props) => {
142
152
  };
143
153
 
144
154
  // src/components/TriggerEditor/TriggerEditor.tsx
145
- var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
155
+ var TriggerEditor = ({ space, trigger, readonlySpec, types, tags, onSave, onCancel }) => {
146
156
  var _effect = _useSignals3();
147
157
  try {
148
- const handleSave = (values) => {
158
+ const handleSave = ({ id: _, ...values }) => {
149
159
  onSave?.(values);
150
160
  };
151
161
  const handleRefQueryLookup = useRefQueryLookupHandler({
152
162
  space
153
163
  });
154
- const Custom = useCustomInputs(space, handleRefQueryLookup);
164
+ const Custom = useCustomInputs({
165
+ space,
166
+ readonlySpec,
167
+ types,
168
+ tags,
169
+ onQueryRefOptions: handleRefQueryLookup
170
+ });
155
171
  return /* @__PURE__ */ React3.createElement(Form2, {
156
172
  outerSpacing: false,
157
173
  Custom,
@@ -165,10 +181,10 @@ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
165
181
  _effect.f();
166
182
  }
167
183
  };
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));
184
+ var useCustomInputs = ({ space, readonlySpec, types, tags, onQueryRefOptions }) => {
185
+ const functions = useQuery(space, Filter2.type(FunctionType));
186
+ const workflows = useQuery(space, Filter2.type(ComputeGraph));
187
+ const scripts = useQuery(space, Filter2.type(ScriptType));
172
188
  return useMemo3(() => ({
173
189
  // Function selector.
174
190
  ["function"]: (props) => {
@@ -198,7 +214,27 @@ var useCustomInputs = (space, onQueryRefOptions) => {
198
214
  });
199
215
  },
200
216
  // Spec selector.
201
- ["spec.kind"]: SpecSelector,
217
+ ["spec.kind"]: (props) => /* @__PURE__ */ React3.createElement(SpecSelector, {
218
+ ...props,
219
+ readonly: readonlySpec ? "disabled-input" : false
220
+ }),
221
+ // TODO(wittjosiah): Copied from ViewEditor.
222
+ // Query input editor.
223
+ ["spec.query"]: (props) => {
224
+ const handleChange = useCallback3((query) => props.onValueChange("object", {
225
+ ast: query.ast
226
+ }), [
227
+ props.onValueChange
228
+ ]);
229
+ return /* @__PURE__ */ React3.createElement(Input.Root, null, /* @__PURE__ */ React3.createElement(InputHeader, {
230
+ label: props.label
231
+ }), /* @__PURE__ */ React3.createElement(QueryForm, {
232
+ initialQuery: props.getValue().ast,
233
+ types,
234
+ tags,
235
+ onChange: handleChange
236
+ }));
237
+ },
202
238
  // Function input editor.
203
239
  ["input"]: (props) => /* @__PURE__ */ React3.createElement(FunctionInputEditor, {
204
240
  ...props,
@@ -208,7 +244,8 @@ var useCustomInputs = (space, onQueryRefOptions) => {
208
244
  }), [
209
245
  workflows,
210
246
  scripts,
211
- functions
247
+ functions,
248
+ readonlySpec
212
249
  ]);
213
250
  };
214
251
  var getWorkflowOptions = (graphs) => {
@@ -228,4 +265,4 @@ var getFunctionOptions = (scripts, functions) => {
228
265
  export {
229
266
  TriggerEditor
230
267
  };
231
- //# sourceMappingURL=chunk-ZOJVKPCA.mjs.map
268
+ //# sourceMappingURL=chunk-J3XEBEIE.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 { type Query, Type } from '@dxos/echo';\nimport { FunctionTrigger, FunctionType, ScriptType } from '@dxos/functions';\nimport { Filter, Ref, type Space, useQuery } from '@dxos/react-client/echo';\nimport { Input } from '@dxos/react-ui';\nimport { QueryForm, type QueryFormProps } from '@dxos/react-ui-components';\nimport { type CustomInputMap, Form, InputHeader, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { FunctionInputEditor, type FunctionInputEditorProps } from './FunctionInputEditor';\nimport { SpecSelector } from './SpecSelector';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTrigger;\n // TODO(wittjosiah): This needs to apply to whole spec but currently only applies to spec.kind & spec.query.\n readonlySpec?: boolean;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n} & Pick<QueryFormProps, 'types' | 'tags'>;\n\nexport const TriggerEditor = ({ space, trigger, readonlySpec, types, tags, onSave, onCancel }: TriggerEditorProps) => {\n const handleSave = ({ id: _, ...values }: FunctionTrigger) => {\n onSave?.(values);\n };\n\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n const Custom = useCustomInputs({ space, readonlySpec, types, tags, onQueryRefOptions: handleRefQueryLookup });\n\n return (\n <Form\n outerSpacing={false}\n Custom={Custom}\n schema={FunctionTrigger}\n values={trigger}\n onSave={handleSave}\n onCancel={onCancel}\n onQueryRefOptions={handleRefQueryLookup}\n />\n );\n};\n\ntype UseCustomInputsProps = {\n space: Space;\n readonlySpec?: boolean;\n onQueryRefOptions: FunctionInputEditorProps['onQueryRefOptions'];\n} & Pick<QueryFormProps, 'types' | 'tags'>;\n\nconst useCustomInputs = ({ space, readonlySpec, types, tags, onQueryRefOptions }: UseCustomInputsProps) => {\n const functions = useQuery(space, Filter.type(FunctionType));\n const workflows = useQuery(space, Filter.type(ComputeGraph));\n const scripts = useQuery(space, Filter.type(ScriptType));\n\n return useMemo(\n (): CustomInputMap => ({\n // Function selector.\n ['function' satisfies keyof FunctionTrigger]: (props) => {\n const getValue = useCallback(() => {\n const formValue = props.getValue();\n if (Ref.isRef(formValue)) {\n return formValue.dxn.toString() as string;\n }\n return undefined;\n }, [props]);\n\n const handleOnValueChange = useCallback(\n (_type: any, dxnString: string) => {\n const dxn = Type.DXN.parse(dxnString);\n if (dxn) {\n const ref = Ref.fromDXN(dxn);\n props.onValueChange('object', ref);\n }\n },\n [props.onValueChange],\n );\n\n return (\n <SelectInput\n {...props}\n getValue={getValue as any}\n onValueChange={handleOnValueChange}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n );\n },\n\n // Spec selector.\n ['spec.kind' as const]: (props) => <SpecSelector {...props} readonly={readonlySpec ? 'disabled-input' : false} />,\n\n // TODO(wittjosiah): Copied from ViewEditor.\n // Query input editor.\n ['spec.query' as const]: (props) => {\n const handleChange = useCallback(\n (query: Query.Any) => props.onValueChange('object', { ast: query.ast }),\n [props.onValueChange],\n );\n\n return (\n <Input.Root>\n <InputHeader label={props.label} />\n <QueryForm initialQuery={(props.getValue() as any).ast} types={types} tags={tags} onChange={handleChange} />\n </Input.Root>\n );\n },\n\n // Function input editor.\n ['input' as const]: (props) => (\n <FunctionInputEditor {...props} functions={functions} onQueryRefOptions={onQueryRefOptions} />\n ),\n }),\n [workflows, scripts, functions, readonlySpec],\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/internal';\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) => {\n if (!Ref.isRef(prevValue) || !Ref.isRef(selectedFunctionValue)) {\n return false;\n }\n\n return prevValue.dxn.toString() !== selectedFunctionValue.dxn.toString();\n },\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 { Filter, Query } from '@dxos/echo';\nimport { type FunctionTrigger, TriggerKinds, type TriggerType } from '@dxos/functions';\nimport { useTranslation } from '@dxos/react-ui';\nimport { type InputProps, SelectInput, useInputProps } from '@dxos/react-ui-form';\n\nimport { meta } from '../../meta';\n\nexport type SpecSelectorProps = InputProps;\n\nexport const SpecSelector = (props: SpecSelectorProps) => {\n const { t } = useTranslation(meta.id);\n const specProps = useInputProps(['spec' satisfies keyof FunctionTrigger]);\n\n const handleTypeChange = useCallback(\n (_type: any, value: string): TriggerType | undefined => {\n const getDefaultTriggerSpec = (kind: string) => {\n switch (kind) {\n case 'timer':\n return { kind: 'timer', cron: '' };\n case 'subscription':\n return {\n kind: 'subscription',\n query: {\n ast: Query.select(Filter.nothing()).ast,\n },\n };\n case 'queue':\n return { kind: 'queue', queue: 'dxn:' };\n case 'email':\n return { kind: 'email' };\n case 'webhook':\n return { kind: 'webhook' };\n default:\n return undefined;\n }\n };\n\n const defaultSpec = getDefaultTriggerSpec(value);\n if (!defaultSpec) {\n return;\n }\n\n // Update the entire spec object, not just the `spec.kind`.\n specProps.onValueChange('object', defaultSpec);\n },\n [specProps],\n );\n\n const options = useMemo(\n () =>\n TriggerKinds.map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n })),\n [t],\n );\n\n return <SelectInput {...props} options={options} onValueChange={handleTypeChange} />;\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useCallback", "useMemo", "ComputeGraph", "Type", "FunctionTrigger", "FunctionType", "ScriptType", "Filter", "Ref", "useQuery", "Input", "QueryForm", "Form", "InputHeader", "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", "currValue", "undefined", "inputSchema", "effectSchema", "Type", "toEffectSchema", "propertyCount", "properties", "Object", "keys", "length", "values", "handleValuesChanged", "useCallback", "h3", "className", "Form", "schema", "onValuesChanged", "outerSpacing", "React", "useCallback", "useMemo", "Filter", "Query", "TriggerKinds", "useTranslation", "SelectInput", "useInputProps", "SpecSelector", "props", "t", "useTranslation", "meta", "id", "specProps", "useInputProps", "handleTypeChange", "useCallback", "_type", "value", "getDefaultTriggerSpec", "kind", "cron", "query", "ast", "Query", "select", "Filter", "nothing", "queue", "undefined", "defaultSpec", "onValueChange", "options", "useMemo", "TriggerKinds", "map", "label", "React", "SelectInput", "TriggerEditor", "space", "trigger", "readonlySpec", "types", "tags", "onSave", "onCancel", "handleSave", "id", "_", "values", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "useCustomInputs", "onQueryRefOptions", "React", "Form", "outerSpacing", "schema", "FunctionTrigger", "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", "readonly", "handleChange", "query", "ast", "Input", "Root", "InputHeader", "label", "QueryForm", "initialQuery", "onChange", "FunctionInputEditor", "graphs", "map", "graph", "value", "getLabel", "fn", "find", "s", "source", "target", "name"]
7
+ }