@dxos/plugin-automation 0.8.2-main.fbd8ed0 → 0.8.2-staging.4d6ad0f

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 (120) hide show
  1. package/dist/lib/browser/AutomationContainer-HQK7FTN6.mjs +40 -0
  2. package/dist/lib/{node-esm/AutomationContainer-OP43F4PD.mjs.map → browser/AutomationContainer-HQK7FTN6.mjs.map} +1 -1
  3. package/dist/lib/browser/AutomationPanel-GU37N5LO.mjs +11 -0
  4. package/dist/lib/browser/FunctionsContainer-B7RDWVMX.mjs +39 -0
  5. package/dist/lib/{node-esm/FunctionsContainer-5TVRDIX5.mjs.map → browser/FunctionsContainer-B7RDWVMX.mjs.map} +1 -1
  6. package/dist/lib/browser/{FunctionsPanel-NSI3P53X.mjs → FunctionsPanel-LCCPDIT6.mjs} +3 -3
  7. package/dist/lib/browser/{app-graph-builder-2OGPEVBA.mjs → app-graph-builder-BYECL42X.mjs} +4 -3
  8. package/dist/lib/browser/{app-graph-builder-2OGPEVBA.mjs.map → app-graph-builder-BYECL42X.mjs.map} +3 -3
  9. package/dist/lib/browser/{chunk-ADYCSC6Y.mjs → chunk-4E2KPMLB.mjs} +3 -3
  10. package/dist/lib/{node-esm/chunk-EEA6CZ6B.mjs.map → browser/chunk-4E2KPMLB.mjs.map} +1 -1
  11. package/dist/lib/browser/chunk-4QTXMPBC.mjs +229 -0
  12. package/dist/lib/browser/chunk-4QTXMPBC.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-D2ESAYQD.mjs +149 -0
  14. package/dist/lib/browser/chunk-D2ESAYQD.mjs.map +7 -0
  15. package/dist/lib/browser/{chunk-SGT76SL2.mjs → chunk-ELQ2FX5G.mjs} +5 -5
  16. package/dist/lib/browser/{chunk-WKKQV4PC.mjs → chunk-IHAKPP5A.mjs} +2 -2
  17. package/dist/lib/browser/{chunk-WKKQV4PC.mjs.map → chunk-IHAKPP5A.mjs.map} +1 -1
  18. package/dist/lib/browser/chunk-ZTRYR6RJ.mjs +94 -0
  19. package/dist/lib/{node-esm/chunk-AD4C4IK2.mjs.map → browser/chunk-ZTRYR6RJ.mjs.map} +1 -1
  20. package/dist/lib/browser/index.mjs +6 -6
  21. package/dist/lib/browser/{intent-resolver-X3H6ZSP4.mjs → intent-resolver-ZRBBYZUX.mjs} +3 -3
  22. package/dist/lib/browser/meta.json +1 -1
  23. package/dist/lib/browser/{react-surface-MOXIHBMS.mjs → react-surface-VKO6PA2P.mjs} +4 -4
  24. package/dist/lib/browser/types.mjs +2 -2
  25. package/dist/lib/node/{AutomationContainer-FIFH4P5T.cjs → AutomationContainer-5J7LJK7L.cjs} +26 -20
  26. package/dist/lib/node/{AutomationContainer-FIFH4P5T.cjs.map → AutomationContainer-5J7LJK7L.cjs.map} +1 -1
  27. package/dist/lib/node/{AutomationPanel-HTNEWBGB.cjs → AutomationPanel-NPDBUQ7D.cjs} +9 -9
  28. package/dist/lib/node/{AutomationPanel-HTNEWBGB.cjs.map → AutomationPanel-NPDBUQ7D.cjs.map} +2 -2
  29. package/dist/lib/node/{FunctionsContainer-LF2F6CPE.cjs → FunctionsContainer-LNLDZUZ6.cjs} +25 -19
  30. package/dist/lib/node/{FunctionsContainer-LF2F6CPE.cjs.map → FunctionsContainer-LNLDZUZ6.cjs.map} +1 -1
  31. package/dist/lib/node/{FunctionsPanel-6HOAIMQ3.cjs → FunctionsPanel-7AOXIQMA.cjs} +8 -8
  32. package/dist/lib/node/FunctionsPanel-7AOXIQMA.cjs.map +7 -0
  33. package/dist/lib/node/{app-graph-builder-3XGDVWHR.cjs → app-graph-builder-DUKR2BRB.cjs} +17 -16
  34. package/dist/lib/node/{app-graph-builder-3XGDVWHR.cjs.map → app-graph-builder-DUKR2BRB.cjs.map} +3 -3
  35. package/dist/lib/node/{chunk-7GXNXMSM.cjs → chunk-3EF7MLFX.cjs} +5 -5
  36. package/dist/lib/node/{chunk-7GXNXMSM.cjs.map → chunk-3EF7MLFX.cjs.map} +1 -1
  37. package/dist/lib/node/chunk-4O627QZU.cjs +175 -0
  38. package/dist/lib/node/chunk-4O627QZU.cjs.map +7 -0
  39. package/dist/lib/node/{chunk-SV2CB3FT.cjs → chunk-DOLMQUQ5.cjs} +8 -8
  40. package/dist/lib/node/{chunk-GDCG2BML.cjs → chunk-GIIVTK4O.cjs} +7 -7
  41. package/dist/lib/node/{chunk-GDCG2BML.cjs.map → chunk-GIIVTK4O.cjs.map} +1 -1
  42. package/dist/lib/node/chunk-O42NQYQT.cjs +252 -0
  43. package/dist/lib/node/chunk-O42NQYQT.cjs.map +7 -0
  44. package/dist/lib/node/chunk-WXQAVUBJ.cjs +122 -0
  45. package/dist/lib/node/{chunk-CBHWMYKF.cjs.map → chunk-WXQAVUBJ.cjs.map} +1 -1
  46. package/dist/lib/node/index.cjs +20 -20
  47. package/dist/lib/node/{intent-resolver-Q7WJ4PZZ.cjs → intent-resolver-JC4Q4TYU.cjs} +7 -7
  48. package/dist/lib/node/meta.json +1 -1
  49. package/dist/lib/node/{react-surface-43VHU36V.cjs → react-surface-HB3MYTCK.cjs} +15 -15
  50. package/dist/lib/node/types.cjs +3 -3
  51. package/dist/lib/node/types.cjs.map +1 -1
  52. package/dist/lib/node-esm/AutomationContainer-OJGH76X2.mjs +41 -0
  53. package/dist/lib/{browser/AutomationContainer-DA6IW7O2.mjs.map → node-esm/AutomationContainer-OJGH76X2.mjs.map} +1 -1
  54. package/dist/lib/node-esm/{AutomationPanel-ZQKRBWP2.mjs → AutomationPanel-HIWEJUWL.mjs} +4 -4
  55. package/dist/lib/node-esm/FunctionsContainer-PPR6XNNR.mjs +40 -0
  56. package/dist/lib/{browser/FunctionsContainer-MPBMMOMS.mjs.map → node-esm/FunctionsContainer-PPR6XNNR.mjs.map} +1 -1
  57. package/dist/lib/node-esm/{FunctionsPanel-NMEW26KL.mjs → FunctionsPanel-SBXKWTHR.mjs} +3 -3
  58. package/dist/lib/node-esm/{app-graph-builder-UR2E5CQY.mjs → app-graph-builder-UAXHKKGW.mjs} +4 -3
  59. package/dist/lib/node-esm/{app-graph-builder-UR2E5CQY.mjs.map → app-graph-builder-UAXHKKGW.mjs.map} +3 -3
  60. package/dist/lib/node-esm/chunk-5IAHBEHR.mjs +95 -0
  61. package/dist/lib/{browser/chunk-TRC3J2I6.mjs.map → node-esm/chunk-5IAHBEHR.mjs.map} +1 -1
  62. package/dist/lib/node-esm/{chunk-EEA6CZ6B.mjs → chunk-6JOJ2NN4.mjs} +3 -3
  63. package/dist/lib/{browser/chunk-ADYCSC6Y.mjs.map → node-esm/chunk-6JOJ2NN4.mjs.map} +1 -1
  64. package/dist/lib/node-esm/chunk-D5HK4XLC.mjs +230 -0
  65. package/dist/lib/node-esm/chunk-D5HK4XLC.mjs.map +7 -0
  66. package/dist/lib/node-esm/{chunk-DZ44LGYT.mjs → chunk-HCCLRNMJ.mjs} +2 -2
  67. package/dist/lib/node-esm/{chunk-DZ44LGYT.mjs.map → chunk-HCCLRNMJ.mjs.map} +1 -1
  68. package/dist/lib/node-esm/chunk-P2FKMPRE.mjs +150 -0
  69. package/dist/lib/node-esm/chunk-P2FKMPRE.mjs.map +7 -0
  70. package/dist/lib/node-esm/{chunk-CUPEMOYK.mjs → chunk-Z7VAQDEE.mjs} +5 -5
  71. package/dist/lib/node-esm/index.mjs +6 -6
  72. package/dist/lib/node-esm/{intent-resolver-HEUGQ6SL.mjs → intent-resolver-KRCXJEDR.mjs} +3 -3
  73. package/dist/lib/node-esm/meta.json +1 -1
  74. package/dist/lib/node-esm/{react-surface-TER7JEF6.mjs → react-surface-TRKCIZAB.mjs} +4 -4
  75. package/dist/lib/node-esm/types.mjs +2 -2
  76. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  77. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  78. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  79. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  80. package/package.json +27 -26
  81. package/src/capabilities/app-graph-builder.ts +1 -0
  82. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +3 -2
  83. package/src/components/AutomationPanel/AutomationPanel.tsx +14 -10
  84. package/src/components/TriggerEditor/TriggerEditor.tsx +29 -27
  85. package/src/meta.ts +1 -1
  86. package/src/testing/test-functions.ts +5 -5
  87. package/dist/lib/browser/AutomationContainer-DA6IW7O2.mjs +0 -34
  88. package/dist/lib/browser/AutomationPanel-R42D3LDD.mjs +0 -11
  89. package/dist/lib/browser/FunctionsContainer-MPBMMOMS.mjs +0 -33
  90. package/dist/lib/browser/chunk-2QF27UJ2.mjs +0 -140
  91. package/dist/lib/browser/chunk-2QF27UJ2.mjs.map +0 -7
  92. package/dist/lib/browser/chunk-BNQNURZN.mjs +0 -211
  93. package/dist/lib/browser/chunk-BNQNURZN.mjs.map +0 -7
  94. package/dist/lib/browser/chunk-TRC3J2I6.mjs +0 -88
  95. package/dist/lib/node/FunctionsPanel-6HOAIMQ3.cjs.map +0 -7
  96. package/dist/lib/node/chunk-CBHWMYKF.cjs +0 -116
  97. package/dist/lib/node/chunk-S3Z4AP77.cjs +0 -234
  98. package/dist/lib/node/chunk-S3Z4AP77.cjs.map +0 -7
  99. package/dist/lib/node/chunk-TI3WBQIB.cjs +0 -166
  100. package/dist/lib/node/chunk-TI3WBQIB.cjs.map +0 -7
  101. package/dist/lib/node-esm/AutomationContainer-OP43F4PD.mjs +0 -35
  102. package/dist/lib/node-esm/FunctionsContainer-5TVRDIX5.mjs +0 -34
  103. package/dist/lib/node-esm/chunk-AD4C4IK2.mjs +0 -89
  104. package/dist/lib/node-esm/chunk-DIUPZXCQ.mjs +0 -141
  105. package/dist/lib/node-esm/chunk-DIUPZXCQ.mjs.map +0 -7
  106. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs +0 -212
  107. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs.map +0 -7
  108. /package/dist/lib/browser/{AutomationPanel-R42D3LDD.mjs.map → AutomationPanel-GU37N5LO.mjs.map} +0 -0
  109. /package/dist/lib/browser/{FunctionsPanel-NSI3P53X.mjs.map → FunctionsPanel-LCCPDIT6.mjs.map} +0 -0
  110. /package/dist/lib/browser/{chunk-SGT76SL2.mjs.map → chunk-ELQ2FX5G.mjs.map} +0 -0
  111. /package/dist/lib/browser/{intent-resolver-X3H6ZSP4.mjs.map → intent-resolver-ZRBBYZUX.mjs.map} +0 -0
  112. /package/dist/lib/browser/{react-surface-MOXIHBMS.mjs.map → react-surface-VKO6PA2P.mjs.map} +0 -0
  113. /package/dist/lib/node/{chunk-SV2CB3FT.cjs.map → chunk-DOLMQUQ5.cjs.map} +0 -0
  114. /package/dist/lib/node/{intent-resolver-Q7WJ4PZZ.cjs.map → intent-resolver-JC4Q4TYU.cjs.map} +0 -0
  115. /package/dist/lib/node/{react-surface-43VHU36V.cjs.map → react-surface-HB3MYTCK.cjs.map} +0 -0
  116. /package/dist/lib/node-esm/{AutomationPanel-ZQKRBWP2.mjs.map → AutomationPanel-HIWEJUWL.mjs.map} +0 -0
  117. /package/dist/lib/node-esm/{FunctionsPanel-NMEW26KL.mjs.map → FunctionsPanel-SBXKWTHR.mjs.map} +0 -0
  118. /package/dist/lib/node-esm/{chunk-CUPEMOYK.mjs.map → chunk-Z7VAQDEE.mjs.map} +0 -0
  119. /package/dist/lib/node-esm/{intent-resolver-HEUGQ6SL.mjs.map → intent-resolver-KRCXJEDR.mjs.map} +0 -0
  120. /package/dist/lib/node-esm/{react-surface-TER7JEF6.mjs.map → react-surface-TRKCIZAB.mjs.map} +0 -0
@@ -0,0 +1,40 @@
1
+ import {
2
+ AutomationPanel
3
+ } from "./chunk-D2ESAYQD.mjs";
4
+ import "./chunk-4QTXMPBC.mjs";
5
+ import {
6
+ AUTOMATION_PLUGIN
7
+ } from "./chunk-IHAKPP5A.mjs";
8
+
9
+ // packages/plugins/plugin-automation/src/components/AutomationContainer.tsx
10
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
11
+ import React from "react";
12
+ import { useTranslation } from "@dxos/react-ui";
13
+ import { ControlSection, ControlPage } from "@dxos/react-ui-form";
14
+ import { StackItem } from "@dxos/react-ui-stack";
15
+ var AutomationContainer = ({ space }) => {
16
+ var _effect = _useSignals();
17
+ try {
18
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
19
+ return /* @__PURE__ */ React.createElement(StackItem.Content, {
20
+ classNames: "block overflow-y-auto"
21
+ }, /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
22
+ title: t("automation verbose label", {
23
+ ns: AUTOMATION_PLUGIN
24
+ }),
25
+ description: t("automation description", {
26
+ ns: AUTOMATION_PLUGIN
27
+ })
28
+ }, /* @__PURE__ */ React.createElement(AutomationPanel, {
29
+ space
30
+ }))));
31
+ } finally {
32
+ _effect.f();
33
+ }
34
+ };
35
+ var AutomationContainer_default = AutomationContainer;
36
+ export {
37
+ AutomationContainer,
38
+ AutomationContainer_default as default
39
+ };
40
+ //# sourceMappingURL=AutomationContainer-HQK7FTN6.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/components/AutomationContainer.tsx"],
4
4
  "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type Space } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { ControlSection, ControlPage } from '@dxos/react-ui-form';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { AutomationPanel } from './AutomationPanel';\nimport { AUTOMATION_PLUGIN } from '../meta';\n\nexport const AutomationContainer = ({ space }: { space: Space }) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n return (\n <StackItem.Content classNames='block overflow-y-auto'>\n <ControlPage>\n <ControlSection\n title={t('automation verbose label', { ns: AUTOMATION_PLUGIN })}\n description={t('automation description', { ns: AUTOMATION_PLUGIN })}\n >\n <AutomationPanel space={space} />\n </ControlSection>\n </ControlPage>\n </StackItem.Content>\n );\n};\n\nexport default AutomationContainer;\n"],
5
- "mappings": ";;;;;;;;;;AAIA,OAAOA,WAAW;AAGlB,SAASC,sBAAsB;AAC/B,SAASC,gBAAgBC,mBAAmB;AAC5C,SAASC,iBAAiB;AAKnB,IAAMC,sBAAsB,CAAC,EAAEC,MAAK,MAAoB;AAC7D,QAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,SACE,sBAAA,cAACC,UAAUC,SAAO;IAACC,YAAW;KAC5B,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;IACCC,OAAOR,EAAE,4BAA4B;MAAES,IAAIP;IAAkB,CAAA;IAC7DQ,aAAaV,EAAE,0BAA0B;MAAES,IAAIP;IAAkB,CAAA;KAEjE,sBAAA,cAACS,iBAAAA;IAAgBZ;;AAK3B;AAEA,IAAA,8BAAeD;",
5
+ "mappings": ";;;;;;;;;;AAIA,OAAOA,WAAW;AAGlB,SAASC,sBAAsB;AAC/B,SAASC,gBAAgBC,mBAAmB;AAC5C,SAASC,iBAAiB;AAKnB,IAAMC,sBAAsB,CAAC,EAAEC,MAAK,MAAoB;;;AAC7D,UAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,WACE,sBAAA,cAACC,UAAUC,SAAO;MAACC,YAAW;OAC5B,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;MACCC,OAAOR,EAAE,4BAA4B;QAAES,IAAIP;MAAkB,CAAA;MAC7DQ,aAAaV,EAAE,0BAA0B;QAAES,IAAIP;MAAkB,CAAA;OAEjE,sBAAA,cAACS,iBAAAA;MAAgBZ;;;;;AAK3B;AAEA,IAAA,8BAAeD;",
6
6
  "names": ["React", "useTranslation", "ControlSection", "ControlPage", "StackItem", "AutomationContainer", "space", "t", "useTranslation", "AUTOMATION_PLUGIN", "StackItem", "Content", "classNames", "ControlPage", "ControlSection", "title", "ns", "description", "AutomationPanel"]
7
7
  }
@@ -0,0 +1,11 @@
1
+ import {
2
+ AutomationPanel,
3
+ AutomationPanel_default
4
+ } from "./chunk-D2ESAYQD.mjs";
5
+ import "./chunk-4QTXMPBC.mjs";
6
+ import "./chunk-IHAKPP5A.mjs";
7
+ export {
8
+ AutomationPanel,
9
+ AutomationPanel_default as default
10
+ };
11
+ //# sourceMappingURL=AutomationPanel-GU37N5LO.mjs.map
@@ -0,0 +1,39 @@
1
+ import {
2
+ FunctionsPanel
3
+ } from "./chunk-ZTRYR6RJ.mjs";
4
+ import {
5
+ AUTOMATION_PLUGIN
6
+ } from "./chunk-IHAKPP5A.mjs";
7
+
8
+ // packages/plugins/plugin-automation/src/components/FunctionsContainer.tsx
9
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
10
+ import React from "react";
11
+ import { useTranslation } from "@dxos/react-ui";
12
+ import { ControlPage, ControlSection } from "@dxos/react-ui-form";
13
+ import { StackItem } from "@dxos/react-ui-stack";
14
+ var FunctionsContainer = ({ space }) => {
15
+ var _effect = _useSignals();
16
+ try {
17
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
18
+ return /* @__PURE__ */ React.createElement(StackItem.Content, {
19
+ classNames: "block overflow-y-auto"
20
+ }, /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
21
+ title: t("functions verbose label", {
22
+ ns: AUTOMATION_PLUGIN
23
+ }),
24
+ description: t("functions description", {
25
+ ns: AUTOMATION_PLUGIN
26
+ })
27
+ }, /* @__PURE__ */ React.createElement(FunctionsPanel, {
28
+ space
29
+ }))));
30
+ } finally {
31
+ _effect.f();
32
+ }
33
+ };
34
+ var FunctionsContainer_default = FunctionsContainer;
35
+ export {
36
+ FunctionsContainer,
37
+ FunctionsContainer_default as default
38
+ };
39
+ //# sourceMappingURL=FunctionsContainer-B7RDWVMX.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/components/FunctionsContainer.tsx"],
4
4
  "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type Space } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { ControlPage, ControlSection } from '@dxos/react-ui-form';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { FunctionsPanel } from './FunctionsPanel';\nimport { AUTOMATION_PLUGIN } from '../meta';\n\nexport const FunctionsContainer = ({ space }: { space: Space }) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n return (\n <StackItem.Content classNames='block overflow-y-auto'>\n <ControlPage>\n <ControlSection\n title={t('functions verbose label', { ns: AUTOMATION_PLUGIN })}\n description={t('functions description', { ns: AUTOMATION_PLUGIN })}\n >\n <FunctionsPanel space={space} />\n </ControlSection>\n </ControlPage>\n </StackItem.Content>\n );\n};\n\nexport default FunctionsContainer;\n"],
5
- "mappings": ";;;;;;;;;AAIA,OAAOA,WAAW;AAGlB,SAASC,sBAAsB;AAC/B,SAASC,aAAaC,sBAAsB;AAC5C,SAASC,iBAAiB;AAKnB,IAAMC,qBAAqB,CAAC,EAAEC,MAAK,MAAoB;AAC5D,QAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,SACE,sBAAA,cAACC,UAAUC,SAAO;IAACC,YAAW;KAC5B,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;IACCC,OAAOR,EAAE,2BAA2B;MAAES,IAAIP;IAAkB,CAAA;IAC5DQ,aAAaV,EAAE,yBAAyB;MAAES,IAAIP;IAAkB,CAAA;KAEhE,sBAAA,cAACS,gBAAAA;IAAeZ;;AAK1B;AAEA,IAAA,6BAAeD;",
5
+ "mappings": ";;;;;;;;;AAIA,OAAOA,WAAW;AAGlB,SAASC,sBAAsB;AAC/B,SAASC,aAAaC,sBAAsB;AAC5C,SAASC,iBAAiB;AAKnB,IAAMC,qBAAqB,CAAC,EAAEC,MAAK,MAAoB;;;AAC5D,UAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,WACE,sBAAA,cAACC,UAAUC,SAAO;MAACC,YAAW;OAC5B,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;MACCC,OAAOR,EAAE,2BAA2B;QAAES,IAAIP;MAAkB,CAAA;MAC5DQ,aAAaV,EAAE,yBAAyB;QAAES,IAAIP;MAAkB,CAAA;OAEhE,sBAAA,cAACS,gBAAAA;MAAeZ;;;;;AAK1B;AAEA,IAAA,6BAAeD;",
6
6
  "names": ["React", "useTranslation", "ControlPage", "ControlSection", "StackItem", "FunctionsContainer", "space", "t", "useTranslation", "AUTOMATION_PLUGIN", "StackItem", "Content", "classNames", "ControlPage", "ControlSection", "title", "ns", "description", "FunctionsPanel"]
7
7
  }
@@ -1,10 +1,10 @@
1
1
  import {
2
2
  FunctionsPanel,
3
3
  FunctionsPanel_default
4
- } from "./chunk-TRC3J2I6.mjs";
5
- import "./chunk-WKKQV4PC.mjs";
4
+ } from "./chunk-ZTRYR6RJ.mjs";
5
+ import "./chunk-IHAKPP5A.mjs";
6
6
  export {
7
7
  FunctionsPanel,
8
8
  FunctionsPanel_default as default
9
9
  };
10
- //# sourceMappingURL=FunctionsPanel-NSI3P53X.mjs.map
10
+ //# sourceMappingURL=FunctionsPanel-LCCPDIT6.mjs.map
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  meta
3
- } from "./chunk-WKKQV4PC.mjs";
3
+ } from "./chunk-IHAKPP5A.mjs";
4
4
 
5
5
  // packages/plugins/plugin-automation/src/capabilities/app-graph-builder.ts
6
6
  import { Rx } from "@effect-rx/rx-react";
@@ -67,7 +67,8 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
67
67
  ns: meta.id
68
68
  }
69
69
  ],
70
- icon: "ph--lightning--regular"
70
+ icon: "ph--lightning--regular",
71
+ disposition: "hidden"
71
72
  }
72
73
  }
73
74
  ]), Option.getOrElse(() => [])))
@@ -76,4 +77,4 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
76
77
  export {
77
78
  app_graph_builder_default as default
78
79
  };
79
- //# sourceMappingURL=app-graph-builder-2OGPEVBA.mjs.map
80
+ //# sourceMappingURL=app-graph-builder-BYECL42X.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
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"]
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 disposition: 'hidden',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n ]);\n"],
5
+ "mappings": ";;;;;AAIA,SAASA,UAAU;AACnB,SAASC,QAAQC,YAAY;AAE7B,SAASC,cAAcC,mBAAuC;AAC9D,SAASC,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;UACNO,aAAa;QACf;MACF;KACD,GACDlB,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", "disposition"]
7
7
  }
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  AUTOMATION_PLUGIN
3
- } from "./chunk-WKKQV4PC.mjs";
3
+ } from "./chunk-IHAKPP5A.mjs";
4
4
 
5
5
  // packages/plugins/plugin-automation/src/types.ts
6
6
  import { Schema } from "effect";
@@ -12,7 +12,6 @@ var TriggerTemplate = Schema.Union(Schema.Struct({
12
12
  type: Schema.Literal("queue"),
13
13
  queueDXN: Schema.Any
14
14
  }));
15
- var AutomationAction;
16
15
  (function(AutomationAction2) {
17
16
  const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;
18
17
  class CreateTriggerFromTemplate extends Schema.TaggedClass()(`${AUTOMATION_ACTION}/create-trigger-from-template`, {
@@ -32,8 +31,9 @@ var AutomationAction;
32
31
  }
33
32
  AutomationAction2.CreateTriggerFromTemplate = CreateTriggerFromTemplate;
34
33
  })(AutomationAction || (AutomationAction = {}));
34
+ var AutomationAction;
35
35
 
36
36
  export {
37
37
  AutomationAction
38
38
  };
39
- //# sourceMappingURL=chunk-ADYCSC6Y.mjs.map
39
+ //# sourceMappingURL=chunk-4E2KPMLB.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/types.ts"],
4
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;",
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
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
7
  }
@@ -0,0 +1,229 @@
1
+ import {
2
+ AUTOMATION_PLUGIN
3
+ } from "./chunk-IHAKPP5A.mjs";
4
+
5
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
6
+ import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
7
+ import React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react";
8
+ import { ComputeGraph } from "@dxos/conductor";
9
+ import { Type } from "@dxos/echo";
10
+ import { FunctionType, FunctionTriggerSchema, ScriptType } from "@dxos/functions";
11
+ import { Filter, Ref, useQuery } from "@dxos/react-client/echo";
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 { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
16
+ import React, { useCallback, useMemo } from "react";
17
+ import { RefImpl, toEffectSchema } from "@dxos/echo-schema";
18
+ import { useOnTransition } from "@dxos/react-ui";
19
+ import { Form, useFormValues } from "@dxos/react-ui-form";
20
+ var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
21
+ var _effect = _useSignals();
22
+ try {
23
+ const selectedFunctionValue = useFormValues([
24
+ "function"
25
+ ]);
26
+ const selectedFunctionId = useMemo(() => {
27
+ if (selectedFunctionValue instanceof RefImpl) {
28
+ return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
29
+ }
30
+ }, [
31
+ selectedFunctionValue
32
+ ]);
33
+ const selectedFunction = useMemo(() => functions.find((f) => f.id === selectedFunctionId), [
34
+ functions,
35
+ selectedFunctionId
36
+ ]);
37
+ useOnTransition(
38
+ // Clear function parameter input when the function changes.
39
+ selectedFunctionValue,
40
+ (prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
41
+ (currValue) => currValue !== void 0,
42
+ () => onValueChange("object", {})
43
+ );
44
+ const inputSchema = useMemo(() => selectedFunction?.inputSchema, [
45
+ selectedFunction
46
+ ]);
47
+ const effectSchema = useMemo(() => inputSchema ? toEffectSchema(inputSchema) : void 0, [
48
+ inputSchema
49
+ ]);
50
+ const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
51
+ const values = useMemo(() => getValue() ?? {}, [
52
+ getValue
53
+ ]);
54
+ const handleValuesChanged = useCallback((values2) => {
55
+ onValueChange("object", values2);
56
+ }, [
57
+ onValueChange
58
+ ]);
59
+ if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
60
+ return null;
61
+ }
62
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("h3", {
63
+ className: "text-md"
64
+ }, "Function parameters"), /* @__PURE__ */ React.createElement(Form, {
65
+ schema: effectSchema,
66
+ values,
67
+ classNames: "p-0",
68
+ onValuesChanged: handleValuesChanged,
69
+ onQueryRefOptions
70
+ }));
71
+ } finally {
72
+ _effect.f();
73
+ }
74
+ };
75
+
76
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/SpecSelector.tsx
77
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
78
+ import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
79
+ import { TriggerKind } from "@dxos/functions";
80
+ import { useTranslation } from "@dxos/react-ui";
81
+ import { SelectInput, useInputProps } from "@dxos/react-ui-form";
82
+ var SpecSelector = (props) => {
83
+ var _effect = _useSignals2();
84
+ try {
85
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
86
+ const specProps = useInputProps([
87
+ "spec"
88
+ ]);
89
+ const handleTypeChange = useCallback2((_type, value) => {
90
+ const getDefaultTriggerSpec = (kind) => {
91
+ switch (kind) {
92
+ case TriggerKind.Timer:
93
+ return {
94
+ kind: TriggerKind.Timer,
95
+ cron: ""
96
+ };
97
+ case TriggerKind.Subscription:
98
+ return {
99
+ kind: TriggerKind.Subscription,
100
+ filter: {}
101
+ };
102
+ case TriggerKind.Queue:
103
+ return {
104
+ kind: TriggerKind.Queue,
105
+ queue: ""
106
+ };
107
+ case TriggerKind.Email:
108
+ return {
109
+ kind: TriggerKind.Email
110
+ };
111
+ case TriggerKind.Webhook:
112
+ return {
113
+ kind: TriggerKind.Webhook
114
+ };
115
+ default:
116
+ return void 0;
117
+ }
118
+ };
119
+ const defaultSpec = getDefaultTriggerSpec(value);
120
+ if (!defaultSpec) {
121
+ return;
122
+ }
123
+ specProps.onValueChange("object", defaultSpec);
124
+ }, [
125
+ specProps
126
+ ]);
127
+ const options = useMemo2(() => Object.values(TriggerKind).map((kind) => ({
128
+ value: kind,
129
+ label: t(`trigger type ${kind}`)
130
+ })), [
131
+ t
132
+ ]);
133
+ return /* @__PURE__ */ React2.createElement(SelectInput, {
134
+ ...props,
135
+ options,
136
+ onValueChange: handleTypeChange
137
+ });
138
+ } finally {
139
+ _effect.f();
140
+ }
141
+ };
142
+
143
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
144
+ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
145
+ var _effect = _useSignals3();
146
+ try {
147
+ const handleSave = (values) => {
148
+ onSave?.(values);
149
+ };
150
+ const handleRefQueryLookup = useRefQueryLookupHandler({
151
+ space
152
+ });
153
+ const Custom = useCustomInputs(space, handleRefQueryLookup);
154
+ return /* @__PURE__ */ React3.createElement(Form2, {
155
+ Custom,
156
+ schema: FunctionTriggerSchema,
157
+ values: trigger,
158
+ onSave: handleSave,
159
+ onCancel,
160
+ onQueryRefOptions: handleRefQueryLookup
161
+ });
162
+ } finally {
163
+ _effect.f();
164
+ }
165
+ };
166
+ var useCustomInputs = (space, onQueryRefOptions) => {
167
+ const functions = useQuery(space, Filter.type(FunctionType));
168
+ const workflows = useQuery(space, Filter.type(ComputeGraph));
169
+ const scripts = useQuery(space, Filter.type(ScriptType));
170
+ return useMemo3(() => ({
171
+ // Function selector.
172
+ ["function"]: (props) => {
173
+ const getValue = useCallback3(() => {
174
+ const formValue = props.getValue();
175
+ if (Ref.isRef(formValue)) {
176
+ return formValue.dxn.toString();
177
+ }
178
+ return void 0;
179
+ }, [
180
+ props
181
+ ]);
182
+ const handleOnValueChange = useCallback3((_type, dxnString) => {
183
+ const dxn = Type.DXN.parse(dxnString);
184
+ if (dxn) {
185
+ const ref = Ref.fromDXN(dxn);
186
+ props.onValueChange("object", ref);
187
+ }
188
+ }, [
189
+ props.onValueChange
190
+ ]);
191
+ return /* @__PURE__ */ React3.createElement(SelectInput2, {
192
+ ...props,
193
+ getValue,
194
+ onValueChange: handleOnValueChange,
195
+ options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
196
+ });
197
+ },
198
+ // Spec selector.
199
+ ["spec.kind"]: SpecSelector,
200
+ // Function input editor.
201
+ ["input"]: (props) => /* @__PURE__ */ React3.createElement(FunctionInputEditor, {
202
+ ...props,
203
+ functions,
204
+ onQueryRefOptions
205
+ })
206
+ }), [
207
+ workflows,
208
+ scripts,
209
+ functions
210
+ ]);
211
+ };
212
+ var getWorkflowOptions = (graphs) => {
213
+ return graphs.map((graph) => ({
214
+ label: `compute-${graph.id}`,
215
+ value: `dxn:echo:@:${graph.id}`
216
+ }));
217
+ };
218
+ var getFunctionOptions = (scripts, functions) => {
219
+ const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
220
+ return functions.map((fn) => ({
221
+ label: getLabel(fn),
222
+ value: `dxn:echo:@:${fn.id}`
223
+ }));
224
+ };
225
+
226
+ export {
227
+ TriggerEditor
228
+ };
229
+ //# sourceMappingURL=chunk-4QTXMPBC.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 } from '@dxos/echo';\nimport {\n FunctionType,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n type FunctionTrigger,\n ScriptType,\n} from '@dxos/functions';\nimport { Filter, Ref, useQuery, type Space } from '@dxos/react-client/echo';\nimport { type CustomInputMap, Form, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { FunctionInputEditor, type FunctionInputEditorProps } from './FunctionInputEditor';\nimport { SpecSelector } from './SpecSelector';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const handleSave = (values: FunctionTriggerType) => {\n onSave?.(values);\n };\n\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n const Custom = useCustomInputs(space, handleRefQueryLookup);\n\n return (\n <Form\n Custom={Custom}\n schema={FunctionTriggerSchema}\n values={trigger}\n onSave={handleSave}\n onCancel={onCancel}\n onQueryRefOptions={handleRefQueryLookup}\n />\n );\n};\n\nconst useCustomInputs = (space: Space, onQueryRefOptions: FunctionInputEditorProps['onQueryRefOptions']) => {\n const functions = useQuery(space, Filter.type(FunctionType));\n const workflows = useQuery(space, Filter.type(ComputeGraph));\n const scripts = useQuery(space, Filter.type(ScriptType));\n\n return useMemo(\n (): CustomInputMap => ({\n // Function selector.\n ['function' satisfies keyof FunctionTriggerType]: (props) => {\n const getValue = useCallback(() => {\n const formValue = props.getValue();\n if (Ref.isRef(formValue)) {\n return formValue.dxn.toString() as string;\n }\n return undefined;\n }, [props]);\n\n const handleOnValueChange = useCallback(\n (_type: any, dxnString: string) => {\n const dxn = Type.DXN.parse(dxnString);\n if (dxn) {\n const ref = Ref.fromDXN(dxn);\n props.onValueChange('object', ref);\n }\n },\n [props.onValueChange],\n );\n\n return (\n <SelectInput\n {...props}\n getValue={getValue as any}\n onValueChange={handleOnValueChange}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n );\n },\n\n // Spec selector.\n ['spec.kind' as const]: SpecSelector,\n\n // Function input editor.\n ['input' as const]: (props) => (\n <FunctionInputEditor {...props} functions={functions} onQueryRefOptions={onQueryRefOptions} />\n ),\n }),\n [workflows, scripts, functions],\n );\n};\n\nconst getWorkflowOptions = (graphs: ComputeGraph[]) => {\n return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));\n};\n\nconst getFunctionOptions = (scripts: ScriptType[], functions: FunctionType[]) => {\n const getLabel = (fn: FunctionType) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:echo:@:${fn.id}` }));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { 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", "Type", "FunctionType", "FunctionTriggerSchema", "ScriptType", "Filter", "Ref", "useQuery", "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", "handleSave", "values", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "useCustomInputs", "React", "Form", "schema", "FunctionTriggerSchema", "onQueryRefOptions", "functions", "useQuery", "Filter", "type", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "useMemo", "props", "getValue", "useCallback", "formValue", "Ref", "isRef", "dxn", "toString", "undefined", "handleOnValueChange", "_type", "dxnString", "Type", "DXN", "parse", "ref", "fromDXN", "onValueChange", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "SpecSelector", "FunctionInputEditor", "graphs", "map", "graph", "label", "id", "value", "getLabel", "fn", "find", "s", "source", "target", "name"]
7
+ }
@@ -0,0 +1,149 @@
1
+ import {
2
+ TriggerEditor
3
+ } from "./chunk-4QTXMPBC.mjs";
4
+ import {
5
+ AUTOMATION_PLUGIN
6
+ } from "./chunk-IHAKPP5A.mjs";
7
+
8
+ // packages/plugins/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
9
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
10
+ import { Schema } from "effect";
11
+ import React, { useState } from "react";
12
+ import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions";
13
+ import { useClient } from "@dxos/react-client";
14
+ import { live, Filter, useQuery, getSpace } from "@dxos/react-client/echo";
15
+ import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
16
+ import { ControlItem, controlItemClasses } from "@dxos/react-ui-form";
17
+ import { List } from "@dxos/react-ui-list";
18
+ import { ghostHover, mx } from "@dxos/react-ui-theme";
19
+ var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
20
+ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
21
+ var _effect = _useSignals();
22
+ try {
23
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
24
+ const client = useClient();
25
+ const triggers = useQuery(space, Filter.type(FunctionTrigger));
26
+ const functions = useQuery(space, Filter.type(FunctionType));
27
+ const scripts = useQuery(space, Filter.type(ScriptType));
28
+ const [trigger, setTrigger] = useState(initialTrigger);
29
+ const [selected, setSelected] = useState();
30
+ const handleSelect = (trigger2) => {
31
+ const { id: _, ...values } = trigger2;
32
+ setTrigger(values);
33
+ setSelected(trigger2);
34
+ };
35
+ const handleAdd = () => {
36
+ setTrigger(live(FunctionTriggerSchema, {}));
37
+ setSelected(void 0);
38
+ };
39
+ const handleDelete = (trigger2) => {
40
+ space.db.remove(trigger2);
41
+ setTrigger(void 0);
42
+ setSelected(void 0);
43
+ };
44
+ const handleSave = (trigger2) => {
45
+ if (selected) {
46
+ Object.assign(selected, trigger2);
47
+ } else {
48
+ space.db.add(live(FunctionTrigger, trigger2));
49
+ }
50
+ setTrigger(void 0);
51
+ setSelected(void 0);
52
+ onDone?.();
53
+ };
54
+ const handleCancel = () => {
55
+ setTrigger(void 0);
56
+ onDone?.();
57
+ };
58
+ if (trigger) {
59
+ return /* @__PURE__ */ React.createElement(ControlItem, {
60
+ title: t("trigger editor title")
61
+ }, /* @__PURE__ */ React.createElement(TriggerEditor, {
62
+ space,
63
+ trigger,
64
+ onSave: handleSave,
65
+ onCancel: handleCancel
66
+ }));
67
+ }
68
+ return /* @__PURE__ */ React.createElement("div", {
69
+ className: "flex flex-col w-full"
70
+ }, /* @__PURE__ */ React.createElement("div", {
71
+ role: "none",
72
+ className: controlItemClasses
73
+ }, triggers.length > 0 && /* @__PURE__ */ React.createElement(List.Root, {
74
+ items: triggers,
75
+ isItem: Schema.is(FunctionTrigger),
76
+ getId: (field) => field.id
77
+ }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
78
+ role: "list",
79
+ className: "flex flex-col w-full"
80
+ }, triggers2?.map((trigger2) => {
81
+ const copyAction = getCopyAction(client, trigger2);
82
+ return /* @__PURE__ */ React.createElement(List.Item, {
83
+ key: trigger2.id,
84
+ item: trigger2,
85
+ classNames: mx(grid, ghostHover, "items-center", "px-2")
86
+ }, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.Switch, {
87
+ checked: trigger2.enabled,
88
+ onCheckedChange: (checked) => trigger2.enabled = checked
89
+ })), /* @__PURE__ */ React.createElement("div", {
90
+ className: "flex"
91
+ }, /* @__PURE__ */ React.createElement(List.ItemTitle, {
92
+ classNames: "px-1 cursor-pointer w-0 shrink truncate",
93
+ onClick: () => handleSelect(trigger2)
94
+ }, getFunctionName(scripts, functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React.createElement(Clipboard.IconButton, {
95
+ label: t(copyAction.translationKey),
96
+ value: copyAction.contentProvider()
97
+ })), /* @__PURE__ */ React.createElement(List.ItemDeleteButton, {
98
+ onClick: () => handleDelete(trigger2)
99
+ }));
100
+ }))), triggers.length > 0 && /* @__PURE__ */ React.createElement(Separator, {
101
+ classNames: "mlb-4"
102
+ }), /* @__PURE__ */ React.createElement(IconButton, {
103
+ icon: "ph--plus--regular",
104
+ label: t("new trigger label"),
105
+ onClick: handleAdd
106
+ })));
107
+ } finally {
108
+ _effect.f();
109
+ }
110
+ };
111
+ var getCopyAction = (client, trigger) => {
112
+ if (trigger?.spec?.kind === TriggerKind.Email) {
113
+ return {
114
+ translationKey: "trigger copy email",
115
+ contentProvider: () => `${getSpace(trigger).id}@dxos.network`
116
+ };
117
+ }
118
+ if (trigger?.spec?.kind === TriggerKind.Webhook) {
119
+ return {
120
+ translationKey: "trigger copy url",
121
+ contentProvider: () => getWebhookUrl(client, trigger)
122
+ };
123
+ }
124
+ return void 0;
125
+ };
126
+ var getWebhookUrl = (client, trigger) => {
127
+ const spaceId = getSpace(trigger).id;
128
+ const edgeUrl = new URL(client.config.values.runtime.services.edge.url);
129
+ const isSecure = edgeUrl.protocol.startsWith("https") || edgeUrl.protocol.startsWith("wss");
130
+ edgeUrl.protocol = isSecure ? "https" : "http";
131
+ return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
132
+ };
133
+ var getFunctionName = (scripts, functions, trigger) => {
134
+ const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
135
+ const functionObject = functions.find((fn) => fn === trigger.function?.target);
136
+ if (!functionObject) {
137
+ return shortId;
138
+ }
139
+ return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;
140
+ };
141
+
142
+ // packages/plugins/plugin-automation/src/components/AutomationPanel/index.ts
143
+ var AutomationPanel_default = AutomationPanel;
144
+
145
+ export {
146
+ AutomationPanel,
147
+ AutomationPanel_default
148
+ };
149
+ //# sourceMappingURL=chunk-D2ESAYQD.mjs.map