@dxos/plugin-automation 0.8.2-main.fbd8ed0 → 0.8.2-staging.7ac8446

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 (168) hide show
  1. package/dist/lib/browser/{chunk-2QF27UJ2.mjs → AutomationPanel-YAHFXQX6.mjs} +23 -24
  2. package/dist/lib/browser/AutomationPanel-YAHFXQX6.mjs.map +7 -0
  3. package/dist/lib/browser/app-graph-builder-K3BIQFWW.mjs +40 -0
  4. package/dist/lib/browser/app-graph-builder-K3BIQFWW.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-FALBBJNO.mjs +138 -0
  6. package/dist/lib/browser/chunk-FALBBJNO.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-MT3FZH4V.mjs +8 -0
  8. package/dist/lib/browser/chunk-MT3FZH4V.mjs.map +7 -0
  9. package/dist/lib/browser/index.mjs +19 -25
  10. package/dist/lib/browser/index.mjs.map +3 -3
  11. package/dist/lib/browser/meta.json +1 -1
  12. package/dist/lib/browser/react-surface-4QQSJR4A.mjs +42 -0
  13. package/dist/lib/browser/react-surface-4QQSJR4A.mjs.map +7 -0
  14. package/dist/lib/node/{chunk-TI3WBQIB.cjs → AutomationPanel-ZKAMIU6O.cjs} +26 -31
  15. package/dist/lib/node/AutomationPanel-ZKAMIU6O.cjs.map +7 -0
  16. package/dist/lib/node/app-graph-builder-HO4FPGZ5.cjs +56 -0
  17. package/dist/lib/node/app-graph-builder-HO4FPGZ5.cjs.map +7 -0
  18. package/dist/lib/node/{chunk-SV2CB3FT.cjs → chunk-AGJ6XTDN.cjs} +7 -16
  19. package/dist/lib/node/chunk-AGJ6XTDN.cjs.map +7 -0
  20. package/dist/lib/node/chunk-FTEDH5Q6.cjs +167 -0
  21. package/dist/lib/node/chunk-FTEDH5Q6.cjs.map +7 -0
  22. package/dist/lib/node/index.cjs +22 -28
  23. package/dist/lib/node/index.cjs.map +3 -3
  24. package/dist/lib/node/meta.json +1 -1
  25. package/dist/lib/node/{react-surface-43VHU36V.cjs → react-surface-52M54VWV.cjs} +15 -39
  26. package/dist/lib/node/react-surface-52M54VWV.cjs.map +7 -0
  27. package/dist/lib/node-esm/{chunk-DIUPZXCQ.mjs → AutomationPanel-XF7YPSKM.mjs} +23 -24
  28. package/dist/lib/node-esm/AutomationPanel-XF7YPSKM.mjs.map +7 -0
  29. package/dist/lib/node-esm/app-graph-builder-XCJR33VS.mjs +41 -0
  30. package/dist/lib/node-esm/app-graph-builder-XCJR33VS.mjs.map +7 -0
  31. package/dist/lib/node-esm/chunk-M4QXMIIB.mjs +139 -0
  32. package/dist/lib/node-esm/chunk-M4QXMIIB.mjs.map +7 -0
  33. package/dist/lib/node-esm/chunk-OA75PSGH.mjs +10 -0
  34. package/dist/lib/node-esm/chunk-OA75PSGH.mjs.map +7 -0
  35. package/dist/lib/node-esm/index.mjs +19 -25
  36. package/dist/lib/node-esm/index.mjs.map +3 -3
  37. package/dist/lib/node-esm/meta.json +1 -1
  38. package/dist/lib/node-esm/react-surface-MGKM3OO3.mjs +43 -0
  39. package/dist/lib/node-esm/react-surface-MGKM3OO3.mjs.map +7 -0
  40. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  41. package/dist/types/src/capabilities/app-graph-builder.d.ts +179 -2
  42. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  43. package/dist/types/src/capabilities/index.d.ts +177 -2
  44. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  45. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  46. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +3 -6
  47. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  48. package/dist/types/src/components/AutomationPanel/index.d.ts +0 -1
  49. package/dist/types/src/components/AutomationPanel/index.d.ts.map +1 -1
  50. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -1
  51. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  52. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  53. package/dist/types/src/components/index.d.ts +1 -8
  54. package/dist/types/src/components/index.d.ts.map +1 -1
  55. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  56. package/dist/types/src/translations.d.ts +0 -8
  57. package/dist/types/src/translations.d.ts.map +1 -1
  58. package/dist/types/tsconfig.tsbuildinfo +1 -1
  59. package/package.json +24 -36
  60. package/src/AutomationPlugin.tsx +10 -5
  61. package/src/capabilities/app-graph-builder.ts +17 -71
  62. package/src/capabilities/index.ts +0 -1
  63. package/src/capabilities/react-surface.tsx +8 -32
  64. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +5 -5
  65. package/src/components/AutomationPanel/AutomationPanel.tsx +72 -72
  66. package/src/components/AutomationPanel/index.ts +0 -2
  67. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +10 -19
  68. package/src/components/TriggerEditor/TriggerEditor.tsx +93 -53
  69. package/src/components/index.ts +0 -3
  70. package/src/testing/test-functions.ts +9 -23
  71. package/src/translations.ts +1 -10
  72. package/dist/lib/browser/AutomationContainer-DA6IW7O2.mjs +0 -34
  73. package/dist/lib/browser/AutomationContainer-DA6IW7O2.mjs.map +0 -7
  74. package/dist/lib/browser/AutomationPanel-R42D3LDD.mjs +0 -11
  75. package/dist/lib/browser/AutomationPanel-R42D3LDD.mjs.map +0 -7
  76. package/dist/lib/browser/FunctionsContainer-MPBMMOMS.mjs +0 -33
  77. package/dist/lib/browser/FunctionsContainer-MPBMMOMS.mjs.map +0 -7
  78. package/dist/lib/browser/FunctionsPanel-NSI3P53X.mjs +0 -10
  79. package/dist/lib/browser/FunctionsPanel-NSI3P53X.mjs.map +0 -7
  80. package/dist/lib/browser/app-graph-builder-2OGPEVBA.mjs +0 -79
  81. package/dist/lib/browser/app-graph-builder-2OGPEVBA.mjs.map +0 -7
  82. package/dist/lib/browser/chunk-2QF27UJ2.mjs.map +0 -7
  83. package/dist/lib/browser/chunk-ADYCSC6Y.mjs +0 -39
  84. package/dist/lib/browser/chunk-ADYCSC6Y.mjs.map +0 -7
  85. package/dist/lib/browser/chunk-BNQNURZN.mjs +0 -211
  86. package/dist/lib/browser/chunk-BNQNURZN.mjs.map +0 -7
  87. package/dist/lib/browser/chunk-SGT76SL2.mjs +0 -14
  88. package/dist/lib/browser/chunk-SGT76SL2.mjs.map +0 -7
  89. package/dist/lib/browser/chunk-TRC3J2I6.mjs +0 -88
  90. package/dist/lib/browser/chunk-TRC3J2I6.mjs.map +0 -7
  91. package/dist/lib/browser/intent-resolver-X3H6ZSP4.mjs +0 -77
  92. package/dist/lib/browser/intent-resolver-X3H6ZSP4.mjs.map +0 -7
  93. package/dist/lib/browser/react-surface-MOXIHBMS.mjs +0 -68
  94. package/dist/lib/browser/react-surface-MOXIHBMS.mjs.map +0 -7
  95. package/dist/lib/browser/types.mjs +0 -8
  96. package/dist/lib/browser/types.mjs.map +0 -7
  97. package/dist/lib/node/AutomationContainer-FIFH4P5T.cjs +0 -62
  98. package/dist/lib/node/AutomationContainer-FIFH4P5T.cjs.map +0 -7
  99. package/dist/lib/node/AutomationPanel-HTNEWBGB.cjs +0 -32
  100. package/dist/lib/node/AutomationPanel-HTNEWBGB.cjs.map +0 -7
  101. package/dist/lib/node/FunctionsContainer-LF2F6CPE.cjs +0 -61
  102. package/dist/lib/node/FunctionsContainer-LF2F6CPE.cjs.map +0 -7
  103. package/dist/lib/node/FunctionsPanel-6HOAIMQ3.cjs +0 -31
  104. package/dist/lib/node/FunctionsPanel-6HOAIMQ3.cjs.map +0 -7
  105. package/dist/lib/node/app-graph-builder-3XGDVWHR.cjs +0 -95
  106. package/dist/lib/node/app-graph-builder-3XGDVWHR.cjs.map +0 -7
  107. package/dist/lib/node/chunk-CBHWMYKF.cjs +0 -116
  108. package/dist/lib/node/chunk-CBHWMYKF.cjs.map +0 -7
  109. package/dist/lib/node/chunk-GDCG2BML.cjs +0 -58
  110. package/dist/lib/node/chunk-GDCG2BML.cjs.map +0 -7
  111. package/dist/lib/node/chunk-S3Z4AP77.cjs +0 -234
  112. package/dist/lib/node/chunk-S3Z4AP77.cjs.map +0 -7
  113. package/dist/lib/node/chunk-SV2CB3FT.cjs.map +0 -7
  114. package/dist/lib/node/chunk-TI3WBQIB.cjs.map +0 -7
  115. package/dist/lib/node/intent-resolver-Q7WJ4PZZ.cjs +0 -93
  116. package/dist/lib/node/intent-resolver-Q7WJ4PZZ.cjs.map +0 -7
  117. package/dist/lib/node/react-surface-43VHU36V.cjs.map +0 -7
  118. package/dist/lib/node/types.cjs +0 -30
  119. package/dist/lib/node/types.cjs.map +0 -7
  120. package/dist/lib/node-esm/AutomationContainer-OP43F4PD.mjs +0 -35
  121. package/dist/lib/node-esm/AutomationContainer-OP43F4PD.mjs.map +0 -7
  122. package/dist/lib/node-esm/AutomationPanel-ZQKRBWP2.mjs +0 -12
  123. package/dist/lib/node-esm/AutomationPanel-ZQKRBWP2.mjs.map +0 -7
  124. package/dist/lib/node-esm/FunctionsContainer-5TVRDIX5.mjs +0 -34
  125. package/dist/lib/node-esm/FunctionsContainer-5TVRDIX5.mjs.map +0 -7
  126. package/dist/lib/node-esm/FunctionsPanel-NMEW26KL.mjs +0 -11
  127. package/dist/lib/node-esm/FunctionsPanel-NMEW26KL.mjs.map +0 -7
  128. package/dist/lib/node-esm/app-graph-builder-UR2E5CQY.mjs +0 -80
  129. package/dist/lib/node-esm/app-graph-builder-UR2E5CQY.mjs.map +0 -7
  130. package/dist/lib/node-esm/chunk-AD4C4IK2.mjs +0 -89
  131. package/dist/lib/node-esm/chunk-AD4C4IK2.mjs.map +0 -7
  132. package/dist/lib/node-esm/chunk-CUPEMOYK.mjs +0 -16
  133. package/dist/lib/node-esm/chunk-CUPEMOYK.mjs.map +0 -7
  134. package/dist/lib/node-esm/chunk-DIUPZXCQ.mjs.map +0 -7
  135. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs +0 -212
  136. package/dist/lib/node-esm/chunk-DZ7RKC52.mjs.map +0 -7
  137. package/dist/lib/node-esm/chunk-EEA6CZ6B.mjs +0 -40
  138. package/dist/lib/node-esm/chunk-EEA6CZ6B.mjs.map +0 -7
  139. package/dist/lib/node-esm/intent-resolver-HEUGQ6SL.mjs +0 -78
  140. package/dist/lib/node-esm/intent-resolver-HEUGQ6SL.mjs.map +0 -7
  141. package/dist/lib/node-esm/react-surface-TER7JEF6.mjs +0 -69
  142. package/dist/lib/node-esm/react-surface-TER7JEF6.mjs.map +0 -7
  143. package/dist/lib/node-esm/types.mjs +0 -9
  144. package/dist/lib/node-esm/types.mjs.map +0 -7
  145. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  146. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  147. package/dist/types/src/components/AutomationContainer.d.ts +0 -7
  148. package/dist/types/src/components/AutomationContainer.d.ts.map +0 -1
  149. package/dist/types/src/components/FunctionsContainer.d.ts +0 -7
  150. package/dist/types/src/components/FunctionsContainer.d.ts.map +0 -1
  151. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts +0 -7
  152. package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +0 -1
  153. package/dist/types/src/components/FunctionsPanel/index.d.ts +0 -4
  154. package/dist/types/src/components/FunctionsPanel/index.d.ts.map +0 -1
  155. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +0 -12
  156. package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +0 -1
  157. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts +0 -5
  158. package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +0 -1
  159. package/dist/types/src/types.d.ts +0 -25
  160. package/dist/types/src/types.d.ts.map +0 -1
  161. package/src/capabilities/intent-resolver.ts +0 -73
  162. package/src/components/AutomationContainer.tsx +0 -31
  163. package/src/components/FunctionsContainer.tsx +0 -31
  164. package/src/components/FunctionsPanel/FunctionsPanel.tsx +0 -95
  165. package/src/components/FunctionsPanel/index.ts +0 -8
  166. package/src/components/TriggerEditor/FunctionInputEditor.tsx +0 -77
  167. package/src/components/TriggerEditor/SpecSelector.tsx +0 -59
  168. package/src/types.ts +0 -33
@@ -1,29 +1,30 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  TriggerEditor
4
- } from "./chunk-DZ7RKC52.mjs";
4
+ } from "./chunk-M4QXMIIB.mjs";
5
5
  import {
6
6
  AUTOMATION_PLUGIN
7
7
  } from "./chunk-DZ44LGYT.mjs";
8
8
 
9
9
  // packages/plugins/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
10
- import { Schema } from "effect";
11
10
  import React, { useState } from "react";
12
- import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions";
11
+ import { S } from "@dxos/echo-schema";
12
+ import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions/types";
13
13
  import { useClient } from "@dxos/react-client";
14
- import { live, Filter, useQuery, getSpace } from "@dxos/react-client/echo";
14
+ import { create, Filter, useQuery, getSpace } from "@dxos/react-client/echo";
15
15
  import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
16
16
  import { ControlItem, controlItemClasses } from "@dxos/react-ui-form";
17
17
  import { List } from "@dxos/react-ui-list";
18
+ import { StackItem } from "@dxos/react-ui-stack";
18
19
  import { ghostHover, mx } from "@dxos/react-ui-theme";
19
20
  var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
20
- var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
21
+ var AutomationPanel = ({ space, object }) => {
21
22
  const { t } = useTranslation(AUTOMATION_PLUGIN);
22
23
  const client = useClient();
23
- const triggers = useQuery(space, Filter.type(FunctionTrigger));
24
- const functions = useQuery(space, Filter.type(FunctionType));
25
- const scripts = useQuery(space, Filter.type(ScriptType));
26
- const [trigger, setTrigger] = useState(initialTrigger);
24
+ const triggers = useQuery(space, Filter.schema(FunctionTrigger));
25
+ const functions = useQuery(space, Filter.schema(FunctionType));
26
+ const scripts = useQuery(space, Filter.schema(ScriptType));
27
+ const [trigger, setTrigger] = useState();
27
28
  const [selected, setSelected] = useState();
28
29
  const handleSelect = (trigger2) => {
29
30
  const { id: _, ...values } = trigger2;
@@ -31,7 +32,7 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
31
32
  setSelected(trigger2);
32
33
  };
33
34
  const handleAdd = () => {
34
- setTrigger(live(FunctionTriggerSchema, {}));
35
+ setTrigger(create(FunctionTriggerSchema, {}));
35
36
  setSelected(void 0);
36
37
  };
37
38
  const handleDelete = (trigger2) => {
@@ -43,17 +44,17 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
43
44
  if (selected) {
44
45
  Object.assign(selected, trigger2);
45
46
  } else {
46
- space.db.add(live(FunctionTrigger, trigger2));
47
+ space.db.add(create(FunctionTrigger, trigger2));
47
48
  }
48
49
  setTrigger(void 0);
49
50
  setSelected(void 0);
50
- onDone?.();
51
51
  };
52
52
  const handleCancel = () => {
53
53
  setTrigger(void 0);
54
- onDone?.();
55
54
  };
56
- return /* @__PURE__ */ React.createElement("div", {
55
+ return /* @__PURE__ */ React.createElement(Clipboard.Provider, null, /* @__PURE__ */ React.createElement(StackItem.Content, {
56
+ classNames: "block overflow-y-auto"
57
+ }, /* @__PURE__ */ React.createElement("div", {
57
58
  className: "flex flex-col w-full"
58
59
  }, trigger ? /* @__PURE__ */ React.createElement(ControlItem, {
59
60
  title: t("trigger editor title")
@@ -67,7 +68,7 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
67
68
  className: controlItemClasses
68
69
  }, /* @__PURE__ */ React.createElement(List.Root, {
69
70
  items: triggers,
70
- isItem: Schema.is(FunctionTrigger),
71
+ isItem: S.is(FunctionTrigger),
71
72
  getId: (field) => field.id
72
73
  }, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
73
74
  role: "list",
@@ -98,16 +99,16 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
98
99
  icon: "ph--plus--regular",
99
100
  label: t("new trigger label"),
100
101
  onClick: handleAdd
101
- })));
102
+ })))));
102
103
  };
103
104
  var getCopyAction = (client, trigger) => {
104
- if (trigger?.spec?.kind === TriggerKind.Email) {
105
+ if (trigger?.spec?.type === TriggerKind.Email) {
105
106
  return {
106
107
  translationKey: "trigger copy email",
107
108
  contentProvider: () => `${getSpace(trigger).id}@dxos.network`
108
109
  };
109
110
  }
110
- if (trigger?.spec?.kind === TriggerKind.Webhook) {
111
+ if (trigger?.spec?.type === TriggerKind.Webhook) {
111
112
  return {
112
113
  translationKey: "trigger copy url",
113
114
  contentProvider: () => getWebhookUrl(client, trigger)
@@ -123,8 +124,8 @@ var getWebhookUrl = (client, trigger) => {
123
124
  return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
124
125
  };
125
126
  var getFunctionName = (scripts, functions, trigger) => {
126
- const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
127
- const functionObject = functions.find((fn) => fn === trigger.function?.target);
127
+ const shortId = trigger.function && `${trigger.function?.slice(0, 16)}\u2026`;
128
+ const functionObject = functions.find((fn) => `dxn:worker:${fn.name}` === trigger.function);
128
129
  if (!functionObject) {
129
130
  return shortId;
130
131
  }
@@ -133,9 +134,7 @@ var getFunctionName = (scripts, functions, trigger) => {
133
134
 
134
135
  // packages/plugins/plugin-automation/src/components/AutomationPanel/index.ts
135
136
  var AutomationPanel_default = AutomationPanel;
136
-
137
137
  export {
138
- AutomationPanel,
139
- AutomationPanel_default
138
+ AutomationPanel_default as default
140
139
  };
141
- //# sourceMappingURL=chunk-DIUPZXCQ.mjs.map
140
+ //# sourceMappingURL=AutomationPanel-XF7YPSKM.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 React, { useState } from 'react';\n\nimport { S } from '@dxos/echo-schema';\nimport {\n FunctionType,\n FunctionTrigger,\n FunctionTriggerSchema,\n TriggerKind,\n type FunctionTriggerType,\n ScriptType,\n} from '@dxos/functions/types';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { create, Filter, useQuery, type Space, type ReactiveObject, getSpace } from '@dxos/react-client/echo';\nimport { Clipboard, IconButton, Input, Separator, useTranslation } from '@dxos/react-ui';\nimport { ControlItem, controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\nimport { TriggerEditor, type TriggerEditorProps } from '../TriggerEditor';\n\nconst grid = 'grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]';\n\nexport type AutomationPanelProps = {\n space: Space;\n object?: ReactiveObject<any>;\n};\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ space, object }: AutomationPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const client = useClient();\n const triggers = useQuery(space, Filter.schema(FunctionTrigger));\n const functions = useQuery(space, Filter.schema(FunctionType));\n const scripts = useQuery(space, Filter.schema(ScriptType));\n\n const [trigger, setTrigger] = useState<FunctionTriggerType>();\n const [selected, setSelected] = useState<FunctionTrigger>();\n\n const handleSelect = (trigger: FunctionTrigger) => {\n const { id: _, ...values } = trigger;\n setTrigger(values);\n setSelected(trigger);\n };\n\n const handleAdd = () => {\n setTrigger(create(FunctionTriggerSchema, {}));\n setSelected(undefined);\n };\n\n const handleDelete = (trigger: FunctionTrigger) => {\n space.db.remove(trigger);\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleSave: TriggerEditorProps['onSave'] = (trigger) => {\n if (selected) {\n Object.assign(selected, trigger);\n } else {\n space.db.add(create(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n };\n\n return (\n <Clipboard.Provider>\n <StackItem.Content classNames='block overflow-y-auto'>\n <div className='flex flex-col w-full'>\n {trigger ? (\n <ControlItem title={t('trigger editor title')}>\n <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />\n </ControlItem>\n ) : (\n <div role='none' className={controlItemClasses}>\n <List.Root<FunctionTrigger> items={triggers} isItem={S.is(FunctionTrigger)} getId={(field) => field.id}>\n {({ items: triggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {triggers?.map((trigger) => {\n const copyAction = getCopyAction(client, trigger);\n return (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center', 'px-2')}\n >\n <Input.Root>\n <Input.Switch\n checked={trigger.enabled}\n onCheckedChange={(checked) => (trigger.enabled = checked)}\n />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle\n classNames='px-1 cursor-pointer w-0 shrink truncate'\n onClick={() => handleSelect(trigger)}\n >\n {getFunctionName(scripts, functions, trigger) ?? '∅'}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose copy action */}\n {copyAction && (\n <Clipboard.IconButton\n label={t(copyAction.translationKey)}\n value={copyAction.contentProvider()}\n />\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n {triggers.length > 0 && <Separator classNames='mlb-4' />}\n <IconButton icon='ph--plus--regular' label={t('new trigger label')} onClick={handleAdd} />\n </div>\n )}\n </div>\n </StackItem.Content>\n </Clipboard.Provider>\n );\n};\n\nconst getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.type === TriggerKind.Email) {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.type === TriggerKind.Webhook) {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTriggerType) => {\n // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function?.slice(0, 16)}…`;\n const functionObject = functions.find((fn) => `dxn:worker:${fn.name}` === trigger.function);\n if (!functionObject) {\n return shortId;\n }\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AutomationPanel } from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useState", "S", "FunctionType", "FunctionTrigger", "FunctionTriggerSchema", "TriggerKind", "ScriptType", "useClient", "create", "Filter", "useQuery", "getSpace", "Clipboard", "IconButton", "Input", "Separator", "useTranslation", "ControlItem", "controlItemClasses", "List", "StackItem", "ghostHover", "mx", "grid", "AutomationPanel", "space", "object", "t", "useTranslation", "AUTOMATION_PLUGIN", "client", "useClient", "triggers", "useQuery", "Filter", "schema", "FunctionTrigger", "functions", "FunctionType", "scripts", "ScriptType", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "id", "_", "values", "handleAdd", "create", "FunctionTriggerSchema", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "Clipboard", "Provider", "StackItem", "Content", "classNames", "div", "className", "ControlItem", "title", "TriggerEditor", "onSave", "onCancel", "role", "controlItemClasses", "List", "Root", "items", "isItem", "S", "is", "getId", "field", "map", "copyAction", "getCopyAction", "Item", "key", "item", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "length", "Separator", "icon", "spec", "type", "TriggerKind", "Email", "getSpace", "Webhook", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "slice", "functionObject", "find", "fn", "name", "s", "source", "target", "AutomationPanel"]
7
+ }
@@ -0,0 +1,41 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ meta
4
+ } from "./chunk-DZ44LGYT.mjs";
5
+
6
+ // packages/plugins/plugin-automation/src/capabilities/app-graph-builder.ts
7
+ import { Capabilities, contributes } from "@dxos/app-framework";
8
+ import { isInstanceOf } from "@dxos/echo-schema";
9
+ import { ScriptType } from "@dxos/functions";
10
+ import { PLANK_COMPANION_TYPE, ATTENDABLE_PATH_SEPARATOR } from "@dxos/plugin-deck/types";
11
+ import { createExtension } from "@dxos/plugin-graph";
12
+ import { SCRIPT_PLUGIN } from "@dxos/plugin-script/types";
13
+ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
14
+ createExtension({
15
+ id: `${SCRIPT_PLUGIN}/script-companion`,
16
+ filter: (node) => isInstanceOf(ScriptType, node.data),
17
+ connector: ({ node }) => [
18
+ {
19
+ id: [
20
+ node.id,
21
+ "automation"
22
+ ].join(ATTENDABLE_PATH_SEPARATOR),
23
+ type: PLANK_COMPANION_TYPE,
24
+ data: "automation",
25
+ properties: {
26
+ label: [
27
+ "script automation label",
28
+ {
29
+ ns: meta.id
30
+ }
31
+ ],
32
+ icon: "ph--lightning--regular"
33
+ }
34
+ }
35
+ ]
36
+ })
37
+ ]);
38
+ export {
39
+ app_graph_builder_default as default
40
+ };
41
+ //# sourceMappingURL=app-graph-builder-XCJR33VS.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 { Capabilities, contributes, type PluginsContext } 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, type Node } from '@dxos/plugin-graph';\nimport { SCRIPT_PLUGIN } from '@dxos/plugin-script/types';\n\nimport { meta } from '../meta';\n\nexport default (context: PluginsContext) =>\n contributes(Capabilities.AppGraphBuilder, [\n createExtension({\n id: `${SCRIPT_PLUGIN}/script-companion`,\n filter: (node): node is Node<ScriptType> => isInstanceOf(ScriptType, node.data),\n connector: ({ 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 }),\n ]);\n"],
5
+ "mappings": ";;;;;;AAIA,SAASA,cAAcC,mBAAwC;AAC/D,SAASC,oBAAoB;AAC7B,SAASC,kBAAkB;AAC3B,SAASC,sBAAsBC,iCAAiC;AAChE,SAASC,uBAAkC;AAC3C,SAASC,qBAAqB;AAI9B,IAAA,4BAAe,CAACC,YACdC,YAAYC,aAAaC,iBAAiB;EACxCC,gBAAgB;IACdC,IAAI,GAAGC,aAAAA;IACPC,QAAQ,CAACC,SAAmCC,aAAaC,YAAYF,KAAKG,IAAI;IAC9EC,WAAW,CAAC,EAAEJ,KAAI,MAAO;MACvB;QACEH,IAAI;UAACG,KAAKH;UAAI;UAAcQ,KAAKC,yBAAAA;QACjCC,MAAMC;QACNL,MAAM;QACNM,YAAY;UACVC,OAAO;YAAC;YAA2B;cAAEC,IAAIC,KAAKf;YAAG;;UACjDgB,MAAM;QACR;MACF;;EAEJ,CAAA;CACD;",
6
+ "names": ["Capabilities", "contributes", "isInstanceOf", "ScriptType", "PLANK_COMPANION_TYPE", "ATTENDABLE_PATH_SEPARATOR", "createExtension", "SCRIPT_PLUGIN", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "SCRIPT_PLUGIN", "filter", "node", "isInstanceOf", "ScriptType", "data", "connector", "join", "ATTENDABLE_PATH_SEPARATOR", "type", "PLANK_COMPANION_TYPE", "properties", "label", "ns", "meta", "icon"]
7
+ }
@@ -0,0 +1,139 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ AUTOMATION_PLUGIN
4
+ } from "./chunk-DZ44LGYT.mjs";
5
+
6
+ // packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
7
+ import React, { useCallback, useEffect, useMemo, useState } from "react";
8
+ import { ComputeGraph } from "@dxos/conductor";
9
+ import { FunctionType, FunctionTriggerSchema, ScriptType, TriggerKind } from "@dxos/functions/types";
10
+ import { Filter, useQuery } from "@dxos/react-client/echo";
11
+ import { IconButton, Input, useTranslation } from "@dxos/react-ui";
12
+ import { Form, SelectInput, TextInput, useInputProps } from "@dxos/react-ui-form";
13
+ var PayloadInput = (props) => {
14
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
15
+ const inputProps = useInputProps([
16
+ "meta",
17
+ props.property
18
+ ]);
19
+ return /* @__PURE__ */ React.createElement("div", {
20
+ role: "none",
21
+ className: "flex items-center mt-2 gap-1"
22
+ }, /* @__PURE__ */ React.createElement("div", {
23
+ role: "none",
24
+ className: "flex-1"
25
+ }, /* @__PURE__ */ React.createElement(TextInput, {
26
+ ...inputProps,
27
+ type: "string",
28
+ label: props.property
29
+ })), /* @__PURE__ */ React.createElement(IconButton, {
30
+ icon: "ph--trash--regular",
31
+ iconOnly: true,
32
+ classNames: "mt-6",
33
+ label: t("trigger meta remove"),
34
+ onClick: () => {
35
+ const newValues = {
36
+ ...props.getValue()
37
+ };
38
+ delete newValues[props.property];
39
+ props.onValueChange("object", newValues);
40
+ }
41
+ }));
42
+ };
43
+ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
44
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
45
+ const functions = useQuery(space, Filter.schema(FunctionType));
46
+ const workflows = useQuery(space, Filter.schema(ComputeGraph));
47
+ const scripts = useQuery(space, Filter.schema(ScriptType));
48
+ const handleSave = (values) => {
49
+ onSave?.(values);
50
+ };
51
+ const Custom = useMemo(() => ({
52
+ ["function"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
53
+ ...props,
54
+ options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
55
+ }),
56
+ ["spec.type"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
57
+ ...props,
58
+ options: Object.values(TriggerKind).map((kind) => ({
59
+ value: kind,
60
+ label: t(`trigger type ${kind}`)
61
+ }))
62
+ }),
63
+ // TODO(wittjosiah): Form should be able to handle arbitrary records by default.
64
+ ["meta"]: (props) => {
65
+ const payload = props.getValue() ?? {};
66
+ useEffect(() => props.onValueChange("object", {
67
+ ...payload
68
+ }), []);
69
+ const [newPayloadFieldName, setNewPayloadFieldName] = useState("");
70
+ const handleAddPayload = useCallback(() => {
71
+ if (newPayloadFieldName.length) {
72
+ const payload2 = props.getValue() ?? {};
73
+ const payloadWithNewProp = {
74
+ ...payload2,
75
+ [newPayloadFieldName]: ""
76
+ };
77
+ setNewPayloadFieldName("");
78
+ props.onValueChange("object", payloadWithNewProp);
79
+ }
80
+ }, [
81
+ newPayloadFieldName,
82
+ props.getValue,
83
+ props.onValueChange
84
+ ]);
85
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("div", null, "Payload"), [
86
+ ...Object.keys(payload)
87
+ ].map((key) => /* @__PURE__ */ React.createElement(PayloadInput, {
88
+ key,
89
+ property: key,
90
+ ...props
91
+ })), /* @__PURE__ */ React.createElement("div", {
92
+ role: "none",
93
+ className: "flex items-center mt-2 gap-1 plb-1"
94
+ }, /* @__PURE__ */ React.createElement("div", {
95
+ role: "none",
96
+ className: "flex-1"
97
+ }, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.TextInput, {
98
+ placeholder: t("trigger payload prop name placeholder"),
99
+ value: newPayloadFieldName,
100
+ onChange: (event) => setNewPayloadFieldName(event.target.value)
101
+ }))), /* @__PURE__ */ React.createElement(IconButton, {
102
+ icon: "ph--plus--regular",
103
+ iconOnly: true,
104
+ label: t("trigger payload add"),
105
+ onClick: handleAddPayload
106
+ })));
107
+ }
108
+ }), [
109
+ workflows,
110
+ scripts,
111
+ functions,
112
+ t
113
+ ]);
114
+ return /* @__PURE__ */ React.createElement(Form, {
115
+ schema: FunctionTriggerSchema,
116
+ values: trigger,
117
+ onSave: handleSave,
118
+ onCancel,
119
+ Custom
120
+ });
121
+ };
122
+ var getWorkflowOptions = (graphs) => {
123
+ return graphs.map((graph) => ({
124
+ label: `compute-${graph.id}`,
125
+ value: `dxn:echo:@:${graph.id}`
126
+ }));
127
+ };
128
+ var getFunctionOptions = (scripts, functions) => {
129
+ const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
130
+ return functions.map((fn) => ({
131
+ label: getLabel(fn),
132
+ value: `dxn:worker:${fn.name}`
133
+ }));
134
+ };
135
+
136
+ export {
137
+ TriggerEditor
138
+ };
139
+ //# sourceMappingURL=chunk-M4QXMIIB.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { ComputeGraph } from '@dxos/conductor';\nimport {\n FunctionType,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n type FunctionTrigger,\n ScriptType,\n TriggerKind,\n} from '@dxos/functions/types';\nimport { Filter, useQuery, type Space } from '@dxos/react-client/echo';\nimport { IconButton, Input, useTranslation } from '@dxos/react-ui';\nimport { type CustomInputMap, Form, type InputProps, SelectInput, TextInput, useInputProps } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nconst PayloadInput = (props: InputProps & { property: string }) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n // TODO(dmaretskyi): Prop name (`meta`) should be passed in.\n const inputProps = useInputProps(['meta', props.property]);\n return (\n <div role='none' className='flex items-center mt-2 gap-1'>\n <div role='none' className='flex-1'>\n <TextInput {...inputProps} type='string' label={props.property} />\n </div>\n <IconButton\n icon='ph--trash--regular'\n iconOnly\n classNames={'mt-6'}\n label={t('trigger meta remove')}\n onClick={() => {\n const newValues: any = { ...props.getValue() };\n delete newValues[props.property];\n props.onValueChange('object', newValues);\n }}\n />\n </div>\n );\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n\n const functions = useQuery(space, Filter.schema(FunctionType));\n const workflows = useQuery(space, Filter.schema(ComputeGraph));\n const scripts = useQuery(space, Filter.schema(ScriptType));\n\n const handleSave = (values: FunctionTriggerType) => {\n onSave?.(values);\n };\n\n const Custom = useMemo(\n (): CustomInputMap => ({\n ['function' satisfies keyof FunctionTriggerType]: (props) => (\n <SelectInput\n {...props}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n ),\n ['spec.type' as const]: (props) => (\n <SelectInput\n {...props}\n options={Object.values(TriggerKind).map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n }))}\n />\n ),\n // TODO(wittjosiah): Form should be able to handle arbitrary records by default.\n ['meta' as const]: (props) => {\n const payload = props.getValue() ?? {};\n useEffect(() => props.onValueChange('object', { ...payload }), []);\n const [newPayloadFieldName, setNewPayloadFieldName] = useState('');\n\n const handleAddPayload = useCallback(() => {\n if (newPayloadFieldName.length) {\n const payload = props.getValue() ?? {};\n const payloadWithNewProp = { ...payload, [newPayloadFieldName]: '' };\n setNewPayloadFieldName('');\n props.onValueChange('object', payloadWithNewProp);\n }\n }, [newPayloadFieldName, props.getValue, props.onValueChange]);\n\n return (\n <>\n <div>{/* TODO(wittjosiah): props.label */ 'Payload'}</div>\n {[...Object.keys(payload)].map((key) => (\n <PayloadInput key={key} property={key} {...props} />\n ))}\n <div role='none' className='flex items-center mt-2 gap-1 plb-1'>\n <div role='none' className='flex-1'>\n <Input.Root>\n <Input.TextInput\n placeholder={t('trigger payload prop name placeholder')}\n value={newPayloadFieldName}\n onChange={(event) => setNewPayloadFieldName(event.target.value)}\n />\n </Input.Root>\n </div>\n <IconButton\n icon='ph--plus--regular'\n iconOnly\n label={t('trigger payload add')}\n onClick={handleAddPayload}\n />\n </div>\n </>\n );\n },\n }),\n [workflows, scripts, functions, t],\n );\n\n return (\n <Form<FunctionTriggerType>\n schema={FunctionTriggerSchema}\n values={trigger}\n onSave={handleSave}\n onCancel={onCancel}\n Custom={Custom}\n />\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:worker:${fn.name}` }));\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useCallback", "useEffect", "useMemo", "useState", "ComputeGraph", "FunctionType", "FunctionTriggerSchema", "ScriptType", "TriggerKind", "Filter", "useQuery", "IconButton", "Input", "useTranslation", "Form", "SelectInput", "TextInput", "useInputProps", "PayloadInput", "props", "t", "useTranslation", "AUTOMATION_PLUGIN", "inputProps", "useInputProps", "property", "div", "role", "className", "TextInput", "type", "label", "IconButton", "icon", "iconOnly", "classNames", "onClick", "newValues", "getValue", "onValueChange", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "functions", "useQuery", "Filter", "schema", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "handleSave", "values", "Custom", "useMemo", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "Object", "TriggerKind", "map", "kind", "value", "payload", "useEffect", "newPayloadFieldName", "setNewPayloadFieldName", "useState", "handleAddPayload", "useCallback", "length", "payloadWithNewProp", "keys", "key", "Input", "Root", "placeholder", "onChange", "event", "target", "Form", "FunctionTriggerSchema", "graphs", "graph", "id", "getLabel", "fn", "find", "s", "source", "name"]
7
+ }
@@ -0,0 +1,10 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // packages/plugins/plugin-automation/src/components/index.ts
4
+ import { lazy } from "react";
5
+ var AutomationPanel = lazy(() => import("./AutomationPanel-XF7YPSKM.mjs"));
6
+
7
+ export {
8
+ AutomationPanel
9
+ };
10
+ //# sourceMappingURL=chunk-OA75PSGH.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './TriggerEditor';\n\nexport const AutomationPanel = lazy(() => import('./AutomationPanel'));\n"],
5
+ "mappings": ";;;AAIA,SAASA,YAAY;AAId,IAAMC,kBAAkBC,KAAK,MAAM,OAAO,gCAAA,CAAA;",
6
+ "names": ["lazy", "AutomationPanel", "lazy"]
7
+ }
@@ -1,13 +1,10 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
- AutomationContainer,
4
- AutomationPanel,
5
- FunctionsContainer,
6
- FunctionsPanel
7
- } from "./chunk-CUPEMOYK.mjs";
3
+ AutomationPanel
4
+ } from "./chunk-OA75PSGH.mjs";
8
5
  import {
9
6
  TriggerEditor
10
- } from "./chunk-DZ7RKC52.mjs";
7
+ } from "./chunk-M4QXMIIB.mjs";
11
8
  import {
12
9
  AUTOMATION_PLUGIN,
13
10
  meta
@@ -15,14 +12,14 @@ import {
15
12
 
16
13
  // packages/plugins/plugin-automation/src/AutomationPlugin.tsx
17
14
  import { Capabilities, contributes, defineModule, definePlugin, Events } from "@dxos/app-framework";
18
- import { FunctionType, FunctionTrigger } from "@dxos/functions";
15
+ import { FunctionType, FunctionTrigger } from "@dxos/functions/types";
19
16
  import { ClientCapabilities, ClientEvents } from "@dxos/plugin-client";
17
+ import { SpaceCapabilities, SpaceEvents } from "@dxos/plugin-space";
20
18
 
21
19
  // packages/plugins/plugin-automation/src/capabilities/index.ts
22
20
  import { lazy } from "@dxos/app-framework";
23
- var AppGraphBuilder = lazy(() => import("./app-graph-builder-UR2E5CQY.mjs"));
24
- var IntentResolver = lazy(() => import("./intent-resolver-HEUGQ6SL.mjs"));
25
- var ReactSurface = lazy(() => import("./react-surface-TER7JEF6.mjs"));
21
+ var AppGraphBuilder = lazy(() => import("./app-graph-builder-XCJR33VS.mjs"));
22
+ var ReactSurface = lazy(() => import("./react-surface-MGKM3OO3.mjs"));
26
23
 
27
24
  // packages/plugins/plugin-automation/src/translations.ts
28
25
  var translations_default = [
@@ -32,15 +29,7 @@ var translations_default = [
32
29
  "plugin name": "Automation",
33
30
  "automation panel label": "Automations",
34
31
  "script automation label": "Automation",
35
- "automation verbose label": "Manage automations",
36
- "automation description": "You can manage all the triggers which automate your space here.",
37
- "functions panel label": "Functions",
38
- "functions verbose label": "Manage deployed functions",
39
- "functions description": "You can manage all the functions deployed from your space on EDGE here.",
40
- "function copy id": "Copy Function ID",
41
- "no functions found": "No functions found",
42
- "go to function source button label": "Show function source",
43
- "trigger editor title": "Configure Trigger",
32
+ "trigger editor title": "New Trigger",
44
33
  "new trigger label": "Add Trigger",
45
34
  "trigger type timer": "Timer",
46
35
  "trigger type webhook": "Webhook",
@@ -79,9 +68,17 @@ var AutomationPlugin = () => definePlugin(meta, [
79
68
  activate: AppGraphBuilder
80
69
  }),
81
70
  defineModule({
82
- id: `${meta.id}/module/intent-resolver`,
83
- activatesOn: Events.SetupIntentResolver,
84
- activate: IntentResolver
71
+ id: `${meta.id}/module/space-settings`,
72
+ activatesOn: SpaceEvents.SetupSettingsPanel,
73
+ activate: () => contributes(SpaceCapabilities.SettingsSection, {
74
+ id: "automation",
75
+ label: [
76
+ "automation panel label",
77
+ {
78
+ ns: meta.id
79
+ }
80
+ ]
81
+ })
85
82
  }),
86
83
  defineModule({
87
84
  id: `${meta.id}/module/react-surface`,
@@ -91,11 +88,8 @@ var AutomationPlugin = () => definePlugin(meta, [
91
88
  ]);
92
89
  export {
93
90
  AUTOMATION_PLUGIN,
94
- AutomationContainer,
95
91
  AutomationPanel,
96
92
  AutomationPlugin,
97
- FunctionsContainer,
98
- FunctionsPanel,
99
93
  TriggerEditor,
100
94
  meta
101
95
  };
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/AutomationPlugin.tsx", "../../../src/capabilities/index.ts", "../../../src/translations.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Capabilities, contributes, defineModule, definePlugin, Events } from '@dxos/app-framework';\nimport { FunctionType, FunctionTrigger } from '@dxos/functions';\nimport { ClientCapabilities, ClientEvents } from '@dxos/plugin-client';\n\nimport { AppGraphBuilder, IntentResolver, ReactSurface } from './capabilities';\nimport { meta } from './meta';\nimport translations from './translations';\n\nexport const AutomationPlugin = () =>\n definePlugin(meta, [\n defineModule({\n id: `${meta.id}/module/translations`,\n activatesOn: Events.SetupTranslations,\n activate: () => contributes(Capabilities.Translations, translations),\n }),\n defineModule({\n id: `${meta.id}/module/schema`,\n activatesOn: ClientEvents.SetupSchema,\n activate: () => contributes(ClientCapabilities.Schema, [FunctionType, FunctionTrigger]),\n }),\n defineModule({\n id: `${meta.id}/module/app-graph-builder`,\n activatesOn: Events.SetupAppGraph,\n activate: AppGraphBuilder,\n }),\n defineModule({\n id: `${meta.id}/module/intent-resolver`,\n activatesOn: Events.SetupIntentResolver,\n activate: IntentResolver,\n }),\n defineModule({\n id: `${meta.id}/module/react-surface`,\n activatesOn: Events.SetupReactSurface,\n activate: ReactSurface,\n }),\n ]);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const AppGraphBuilder = lazy(() => import('./app-graph-builder'));\nexport const IntentResolver = lazy(() => import('./intent-resolver'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { AUTOMATION_PLUGIN } from './meta';\n\nexport default [\n {\n 'en-US': {\n [AUTOMATION_PLUGIN]: {\n 'plugin name': 'Automation',\n 'automation panel label': 'Automations',\n 'script automation label': 'Automation',\n 'automation verbose label': 'Manage automations',\n 'automation description': 'You can manage all the triggers which automate your space here.',\n\n 'functions panel label': 'Functions',\n 'functions verbose label': 'Manage deployed functions',\n 'functions description': 'You can manage all the functions deployed from your space on EDGE here.',\n 'function copy id': 'Copy Function ID',\n 'no functions found': 'No functions found',\n 'go to function source button label': 'Show function source',\n\n 'trigger editor title': 'Configure Trigger',\n 'new trigger label': 'Add Trigger',\n 'trigger type timer': 'Timer',\n 'trigger type webhook': 'Webhook',\n 'trigger type websocket': 'Websocket',\n 'trigger type subscription': 'Subscription',\n 'trigger type email': 'Email',\n 'trigger type queue': 'Queue',\n\n 'trigger copy url': 'Copy URL',\n 'trigger copy email': 'Copy Email',\n\n 'trigger payload add': 'Add',\n 'trigger payload remove': 'Remove',\n 'trigger payload prop name placeholder': 'New payload property name',\n },\n },\n },\n];\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;AAIA,SAASA,cAAcC,aAAaC,cAAcC,cAAcC,cAAc;AAC9E,SAASC,cAAcC,uBAAuB;AAC9C,SAASC,oBAAoBC,oBAAoB;;;ACFjD,SAASC,YAAY;AAEd,IAAMC,kBAAkBC,KAAK,MAAM,OAAO,kCAAA,CAAA;AAC1C,IAAMC,iBAAiBD,KAAK,MAAM,OAAO,gCAAA,CAAA;AACzC,IAAME,eAAeF,KAAK,MAAM,OAAO,8BAAA,CAAA;;;ACF9C,IAAA,uBAAe;EACb;IACE,SAAS;MACP,CAACG,iBAAAA,GAAoB;QACnB,eAAe;QACf,0BAA0B;QAC1B,2BAA2B;QAC3B,4BAA4B;QAC5B,0BAA0B;QAE1B,yBAAyB;QACzB,2BAA2B;QAC3B,yBAAyB;QACzB,oBAAoB;QACpB,sBAAsB;QACtB,sCAAsC;QAEtC,wBAAwB;QACxB,qBAAqB;QACrB,sBAAsB;QACtB,wBAAwB;QACxB,0BAA0B;QAC1B,6BAA6B;QAC7B,sBAAsB;QACtB,sBAAsB;QAEtB,oBAAoB;QACpB,sBAAsB;QAEtB,uBAAuB;QACvB,0BAA0B;QAC1B,yCAAyC;MAC3C;IACF;EACF;;;;AF5BK,IAAMC,mBAAmB,MAC9BC,aAAaC,MAAM;EACjBC,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOC;IACpBC,UAAU,MAAMC,YAAYC,aAAaC,cAAcC,oBAAAA;EACzD,CAAA;EACAT,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaQ,aAAaC;IAC1BN,UAAU,MAAMC,YAAYM,mBAAmBC,QAAQ;MAACC;MAAcC;KAAgB;EACxF,CAAA;EACAf,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOa;IACpBX,UAAUY;EACZ,CAAA;EACAjB,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOe;IACpBb,UAAUc;EACZ,CAAA;EACAnB,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOiB;IACpBf,UAAUgB;EACZ,CAAA;CACD;",
6
- "names": ["Capabilities", "contributes", "defineModule", "definePlugin", "Events", "FunctionType", "FunctionTrigger", "ClientCapabilities", "ClientEvents", "lazy", "AppGraphBuilder", "lazy", "IntentResolver", "ReactSurface", "AUTOMATION_PLUGIN", "AutomationPlugin", "definePlugin", "meta", "defineModule", "id", "activatesOn", "Events", "SetupTranslations", "activate", "contributes", "Capabilities", "Translations", "translations", "ClientEvents", "SetupSchema", "ClientCapabilities", "Schema", "FunctionType", "FunctionTrigger", "SetupAppGraph", "AppGraphBuilder", "SetupIntentResolver", "IntentResolver", "SetupReactSurface", "ReactSurface"]
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Capabilities, contributes, defineModule, definePlugin, Events } from '@dxos/app-framework';\nimport { FunctionType, FunctionTrigger } from '@dxos/functions/types';\nimport { ClientCapabilities, ClientEvents } from '@dxos/plugin-client';\nimport { SpaceCapabilities, SpaceEvents } from '@dxos/plugin-space';\n\nimport { AppGraphBuilder, ReactSurface } from './capabilities';\nimport { meta } from './meta';\nimport translations from './translations';\n\nexport const AutomationPlugin = () =>\n definePlugin(meta, [\n defineModule({\n id: `${meta.id}/module/translations`,\n activatesOn: Events.SetupTranslations,\n activate: () => contributes(Capabilities.Translations, translations),\n }),\n defineModule({\n id: `${meta.id}/module/schema`,\n activatesOn: ClientEvents.SetupSchema,\n activate: () => contributes(ClientCapabilities.Schema, [FunctionType, FunctionTrigger]),\n }),\n defineModule({\n id: `${meta.id}/module/app-graph-builder`,\n activatesOn: Events.SetupAppGraph,\n activate: AppGraphBuilder,\n }),\n defineModule({\n id: `${meta.id}/module/space-settings`,\n activatesOn: SpaceEvents.SetupSettingsPanel,\n activate: () =>\n contributes(SpaceCapabilities.SettingsSection, {\n id: 'automation',\n label: ['automation panel label', { ns: meta.id }],\n }),\n }),\n defineModule({\n id: `${meta.id}/module/react-surface`,\n activatesOn: Events.SetupReactSurface,\n activate: ReactSurface,\n }),\n ]);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const AppGraphBuilder = lazy(() => import('./app-graph-builder'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { AUTOMATION_PLUGIN } from './meta';\n\nexport default [\n {\n 'en-US': {\n [AUTOMATION_PLUGIN]: {\n 'plugin name': 'Automation',\n 'automation panel label': 'Automations',\n 'script automation label': 'Automation',\n\n 'trigger editor title': 'New Trigger',\n 'new trigger label': 'Add Trigger',\n 'trigger type timer': 'Timer',\n 'trigger type webhook': 'Webhook',\n 'trigger type websocket': 'Websocket',\n 'trigger type subscription': 'Subscription',\n 'trigger type email': 'Email',\n 'trigger type queue': 'Queue',\n\n 'trigger copy url': 'Copy URL',\n 'trigger copy email': 'Copy Email',\n\n 'trigger payload add': 'Add',\n 'trigger payload remove': 'Remove',\n 'trigger payload prop name placeholder': 'New payload property name',\n },\n },\n },\n];\n"],
5
+ "mappings": ";;;;;;;;;;;;;AAIA,SAASA,cAAcC,aAAaC,cAAcC,cAAcC,cAAc;AAC9E,SAASC,cAAcC,uBAAuB;AAC9C,SAASC,oBAAoBC,oBAAoB;AACjD,SAASC,mBAAmBC,mBAAmB;;;ACH/C,SAASC,YAAY;AAEd,IAAMC,kBAAkBC,KAAK,MAAM,OAAO,kCAAA,CAAA;AAC1C,IAAMC,eAAeD,KAAK,MAAM,OAAO,8BAAA,CAAA;;;ACD9C,IAAA,uBAAe;EACb;IACE,SAAS;MACP,CAACE,iBAAAA,GAAoB;QACnB,eAAe;QACf,0BAA0B;QAC1B,2BAA2B;QAE3B,wBAAwB;QACxB,qBAAqB;QACrB,sBAAsB;QACtB,wBAAwB;QACxB,0BAA0B;QAC1B,6BAA6B;QAC7B,sBAAsB;QACtB,sBAAsB;QAEtB,oBAAoB;QACpB,sBAAsB;QAEtB,uBAAuB;QACvB,0BAA0B;QAC1B,yCAAyC;MAC3C;IACF;EACF;;;;AFlBK,IAAMC,mBAAmB,MAC9BC,aAAaC,MAAM;EACjBC,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOC;IACpBC,UAAU,MAAMC,YAAYC,aAAaC,cAAcC,oBAAAA;EACzD,CAAA;EACAT,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaQ,aAAaC;IAC1BN,UAAU,MAAMC,YAAYM,mBAAmBC,QAAQ;MAACC;MAAcC;KAAgB;EACxF,CAAA;EACAf,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOa;IACpBX,UAAUY;EACZ,CAAA;EACAjB,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAagB,YAAYC;IACzBd,UAAU,MACRC,YAAYc,kBAAkBC,iBAAiB;MAC7CpB,IAAI;MACJqB,OAAO;QAAC;QAA0B;UAAEC,IAAIxB,KAAKE;QAAG;;IAClD,CAAA;EACJ,CAAA;EACAD,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOqB;IACpBnB,UAAUoB;EACZ,CAAA;CACD;",
6
+ "names": ["Capabilities", "contributes", "defineModule", "definePlugin", "Events", "FunctionType", "FunctionTrigger", "ClientCapabilities", "ClientEvents", "SpaceCapabilities", "SpaceEvents", "lazy", "AppGraphBuilder", "lazy", "ReactSurface", "AUTOMATION_PLUGIN", "AutomationPlugin", "definePlugin", "meta", "defineModule", "id", "activatesOn", "Events", "SetupTranslations", "activate", "contributes", "Capabilities", "Translations", "translations", "ClientEvents", "SetupSchema", "ClientCapabilities", "Schema", "FunctionType", "FunctionTrigger", "SetupAppGraph", "AppGraphBuilder", "SpaceEvents", "SetupSettingsPanel", "SpaceCapabilities", "SettingsSection", "label", "ns", "SetupReactSurface", "ReactSurface"]
7
7
  }