@dxos/plugin-automation 0.8.2-main.36232bc → 0.8.2-main.5ca3450
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.
- package/dist/lib/browser/{AutomationContainer-KEQ5RNIW.mjs → AutomationContainer-PDPL34DX.mjs} +3 -3
- package/dist/lib/browser/{AutomationPanel-G3OB6ELR.mjs → AutomationPanel-3WG2B7JM.mjs} +3 -3
- package/dist/lib/browser/{FunctionsContainer-STXBW4CX.mjs → FunctionsContainer-HLISW5QI.mjs} +2 -2
- package/dist/lib/browser/{FunctionsPanel-JJPLIAJW.mjs → FunctionsPanel-OKFRBXLO.mjs} +2 -2
- package/dist/lib/browser/chunk-ADYCSC6Y.mjs +39 -0
- package/dist/lib/browser/chunk-ADYCSC6Y.mjs.map +7 -0
- package/dist/lib/browser/{chunk-QJPKWYTL.mjs → chunk-GUPG3Q72.mjs} +5 -5
- package/dist/lib/browser/{chunk-65VL4EYS.mjs → chunk-IDCVJ2JW.mjs} +4 -4
- package/dist/lib/browser/chunk-IDCVJ2JW.mjs.map +7 -0
- package/dist/lib/browser/{chunk-NGG4ICAQ.mjs → chunk-QFIPNCNF.mjs} +9 -9
- package/dist/lib/browser/chunk-QFIPNCNF.mjs.map +7 -0
- package/dist/lib/browser/chunk-W4T2BTH2.mjs +211 -0
- package/dist/lib/browser/chunk-W4T2BTH2.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +5 -5
- package/dist/lib/browser/index.mjs.map +1 -1
- package/dist/lib/browser/{intent-resolver-SNIAQ7V5.mjs → intent-resolver-TCUIVOEW.mjs} +9 -10
- package/dist/lib/browser/intent-resolver-TCUIVOEW.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-L22QIANU.mjs → react-surface-P65PEZPN.mjs} +4 -4
- package/dist/lib/browser/{react-surface-L22QIANU.mjs.map → react-surface-P65PEZPN.mjs.map} +1 -1
- package/dist/lib/browser/types.mjs +1 -1
- package/dist/lib/node/{AutomationContainer-E5I76FPP.cjs → AutomationContainer-EXTHQ7B3.cjs} +7 -7
- package/dist/lib/node/{AutomationPanel-YLXAFJDP.cjs → AutomationPanel-G7R6RL7O.cjs} +8 -8
- package/dist/lib/node/{AutomationPanel-YLXAFJDP.cjs.map → AutomationPanel-G7R6RL7O.cjs.map} +2 -2
- package/dist/lib/node/{FunctionsContainer-3HCURMEB.cjs → FunctionsContainer-RNZTNQEU.cjs} +6 -6
- package/dist/lib/node/{FunctionsPanel-SYIZHPGU.cjs → FunctionsPanel-7I7YCHPJ.cjs} +7 -7
- package/dist/lib/node/{FunctionsPanel-SYIZHPGU.cjs.map → FunctionsPanel-7I7YCHPJ.cjs.map} +2 -2
- package/dist/lib/node/chunk-A4DMUH7U.cjs +234 -0
- package/dist/lib/node/chunk-A4DMUH7U.cjs.map +7 -0
- package/dist/lib/node/{chunk-L5TWLPGA.cjs → chunk-B3OL2E3B.cjs} +8 -8
- package/dist/lib/node/{chunk-SRXHHBDE.cjs → chunk-F74YVA6P.cjs} +18 -18
- package/dist/lib/node/chunk-F74YVA6P.cjs.map +7 -0
- package/dist/lib/node/{chunk-PSIJDHAX.cjs → chunk-GDCG2BML.cjs} +19 -19
- package/dist/lib/node/chunk-GDCG2BML.cjs.map +7 -0
- package/dist/lib/node/{chunk-BSK5SHTR.cjs → chunk-GLXGAIZC.cjs} +9 -9
- package/dist/lib/node/chunk-GLXGAIZC.cjs.map +7 -0
- package/dist/lib/node/index.cjs +12 -12
- package/dist/lib/node/index.cjs.map +2 -2
- package/dist/lib/node/{intent-resolver-A44BNFEG.cjs → intent-resolver-6XS2NYC7.cjs} +16 -17
- package/dist/lib/node/intent-resolver-6XS2NYC7.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/{react-surface-PCZCHIET.cjs → react-surface-OYJMJXJI.cjs} +11 -11
- package/dist/lib/node/react-surface-OYJMJXJI.cjs.map +7 -0
- package/dist/lib/node/types.cjs +2 -2
- package/dist/lib/node/types.cjs.map +1 -1
- package/dist/lib/node-esm/{AutomationContainer-22PUFPSE.mjs → AutomationContainer-FSWEGDKP.mjs} +3 -3
- package/dist/lib/node-esm/{AutomationPanel-6UXIAJVS.mjs → AutomationPanel-LIPLJA55.mjs} +3 -3
- package/dist/lib/node-esm/{FunctionsContainer-XG5WVAN3.mjs → FunctionsContainer-435FW56J.mjs} +2 -2
- package/dist/lib/node-esm/{FunctionsPanel-J3QGUESH.mjs → FunctionsPanel-NXXT5ERU.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-HMYAQLGF.mjs → chunk-27IHWHDH.mjs} +9 -9
- package/dist/lib/node-esm/chunk-27IHWHDH.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-YYBCQXB2.mjs → chunk-EEA6CZ6B.mjs} +16 -16
- package/dist/lib/node-esm/chunk-EEA6CZ6B.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-IS3BYE3I.mjs +212 -0
- package/dist/lib/node-esm/chunk-IS3BYE3I.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-4UPGANGV.mjs → chunk-VYSTWH6Q.mjs} +4 -4
- package/dist/lib/node-esm/chunk-VYSTWH6Q.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-TMMB5ETD.mjs → chunk-YCNX76NJ.mjs} +5 -5
- package/dist/lib/node-esm/index.mjs +5 -5
- package/dist/lib/node-esm/index.mjs.map +1 -1
- package/dist/lib/node-esm/{intent-resolver-JFLTVJ7D.mjs → intent-resolver-CHDYUFFN.mjs} +9 -10
- package/dist/lib/node-esm/intent-resolver-CHDYUFFN.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-VSO4NWC6.mjs → react-surface-FDGQORLY.mjs} +4 -4
- package/dist/lib/node-esm/{react-surface-VSO4NWC6.mjs.map → react-surface-FDGQORLY.mjs.map} +1 -1
- package/dist/lib/node-esm/types.mjs +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/components/AutomationContainer.d.ts.map +1 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
- package/dist/types/src/components/FunctionsContainer.d.ts.map +1 -1
- package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
- package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +12 -0
- package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts.map +1 -0
- package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts +5 -0
- package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +1 -0
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
- package/dist/types/src/testing/test-functions.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +15 -15
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +28 -24
- package/src/AutomationPlugin.tsx +1 -1
- package/src/capabilities/intent-resolver.ts +6 -9
- package/src/capabilities/react-surface.tsx +1 -1
- package/src/components/AutomationPanel/AutomationPanel.stories.tsx +1 -1
- package/src/components/AutomationPanel/AutomationPanel.tsx +8 -7
- package/src/components/FunctionsPanel/FunctionsPanel.tsx +3 -3
- package/src/components/TriggerEditor/FunctionInputEditor.tsx +77 -0
- package/src/components/TriggerEditor/SpecSelector.tsx +59 -0
- package/src/components/TriggerEditor/TriggerEditor.stories.tsx +16 -7
- package/src/components/TriggerEditor/TriggerEditor.tsx +50 -90
- package/src/testing/test-functions.ts +23 -9
- package/src/types.ts +11 -10
- package/dist/lib/browser/chunk-65VL4EYS.mjs.map +0 -7
- package/dist/lib/browser/chunk-FALBBJNO.mjs +0 -138
- package/dist/lib/browser/chunk-FALBBJNO.mjs.map +0 -7
- package/dist/lib/browser/chunk-FCLWFVFX.mjs +0 -39
- package/dist/lib/browser/chunk-FCLWFVFX.mjs.map +0 -7
- package/dist/lib/browser/chunk-NGG4ICAQ.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-SNIAQ7V5.mjs.map +0 -7
- package/dist/lib/node/chunk-BSK5SHTR.cjs.map +0 -7
- package/dist/lib/node/chunk-FTEDH5Q6.cjs +0 -167
- package/dist/lib/node/chunk-FTEDH5Q6.cjs.map +0 -7
- package/dist/lib/node/chunk-PSIJDHAX.cjs.map +0 -7
- package/dist/lib/node/chunk-SRXHHBDE.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-A44BNFEG.cjs.map +0 -7
- package/dist/lib/node/react-surface-PCZCHIET.cjs.map +0 -7
- package/dist/lib/node-esm/chunk-4UPGANGV.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HMYAQLGF.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-M4QXMIIB.mjs +0 -139
- package/dist/lib/node-esm/chunk-M4QXMIIB.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YYBCQXB2.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-JFLTVJ7D.mjs.map +0 -7
- /package/dist/lib/browser/{AutomationContainer-KEQ5RNIW.mjs.map → AutomationContainer-PDPL34DX.mjs.map} +0 -0
- /package/dist/lib/browser/{AutomationPanel-G3OB6ELR.mjs.map → AutomationPanel-3WG2B7JM.mjs.map} +0 -0
- /package/dist/lib/browser/{FunctionsContainer-STXBW4CX.mjs.map → FunctionsContainer-HLISW5QI.mjs.map} +0 -0
- /package/dist/lib/browser/{FunctionsPanel-JJPLIAJW.mjs.map → FunctionsPanel-OKFRBXLO.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-QJPKWYTL.mjs.map → chunk-GUPG3Q72.mjs.map} +0 -0
- /package/dist/lib/node/{AutomationContainer-E5I76FPP.cjs.map → AutomationContainer-EXTHQ7B3.cjs.map} +0 -0
- /package/dist/lib/node/{FunctionsContainer-3HCURMEB.cjs.map → FunctionsContainer-RNZTNQEU.cjs.map} +0 -0
- /package/dist/lib/node/{chunk-L5TWLPGA.cjs.map → chunk-B3OL2E3B.cjs.map} +0 -0
- /package/dist/lib/node-esm/{AutomationContainer-22PUFPSE.mjs.map → AutomationContainer-FSWEGDKP.mjs.map} +0 -0
- /package/dist/lib/node-esm/{AutomationPanel-6UXIAJVS.mjs.map → AutomationPanel-LIPLJA55.mjs.map} +0 -0
- /package/dist/lib/node-esm/{FunctionsContainer-XG5WVAN3.mjs.map → FunctionsContainer-435FW56J.mjs.map} +0 -0
- /package/dist/lib/node-esm/{FunctionsPanel-J3QGUESH.mjs.map → FunctionsPanel-NXXT5ERU.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-TMMB5ETD.mjs.map → chunk-YCNX76NJ.mjs.map} +0 -0
package/dist/lib/browser/{AutomationContainer-KEQ5RNIW.mjs → AutomationContainer-PDPL34DX.mjs}
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import {
|
|
2
2
|
AutomationPanel
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import "./chunk-
|
|
3
|
+
} from "./chunk-QFIPNCNF.mjs";
|
|
4
|
+
import "./chunk-W4T2BTH2.mjs";
|
|
5
5
|
import {
|
|
6
6
|
AUTOMATION_PLUGIN
|
|
7
7
|
} from "./chunk-WKKQV4PC.mjs";
|
|
@@ -31,4 +31,4 @@ export {
|
|
|
31
31
|
AutomationContainer,
|
|
32
32
|
AutomationContainer_default as default
|
|
33
33
|
};
|
|
34
|
-
//# sourceMappingURL=AutomationContainer-
|
|
34
|
+
//# sourceMappingURL=AutomationContainer-PDPL34DX.mjs.map
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import {
|
|
2
2
|
AutomationPanel,
|
|
3
3
|
AutomationPanel_default
|
|
4
|
-
} from "./chunk-
|
|
5
|
-
import "./chunk-
|
|
4
|
+
} from "./chunk-QFIPNCNF.mjs";
|
|
5
|
+
import "./chunk-W4T2BTH2.mjs";
|
|
6
6
|
import "./chunk-WKKQV4PC.mjs";
|
|
7
7
|
export {
|
|
8
8
|
AutomationPanel,
|
|
9
9
|
AutomationPanel_default as default
|
|
10
10
|
};
|
|
11
|
-
//# sourceMappingURL=AutomationPanel-
|
|
11
|
+
//# sourceMappingURL=AutomationPanel-3WG2B7JM.mjs.map
|
package/dist/lib/browser/{FunctionsContainer-STXBW4CX.mjs → FunctionsContainer-HLISW5QI.mjs}
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
FunctionsPanel
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-IDCVJ2JW.mjs";
|
|
4
4
|
import {
|
|
5
5
|
AUTOMATION_PLUGIN
|
|
6
6
|
} from "./chunk-WKKQV4PC.mjs";
|
|
@@ -30,4 +30,4 @@ export {
|
|
|
30
30
|
FunctionsContainer,
|
|
31
31
|
FunctionsContainer_default as default
|
|
32
32
|
};
|
|
33
|
-
//# sourceMappingURL=FunctionsContainer-
|
|
33
|
+
//# sourceMappingURL=FunctionsContainer-HLISW5QI.mjs.map
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import {
|
|
2
2
|
FunctionsPanel,
|
|
3
3
|
FunctionsPanel_default
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-IDCVJ2JW.mjs";
|
|
5
5
|
import "./chunk-WKKQV4PC.mjs";
|
|
6
6
|
export {
|
|
7
7
|
FunctionsPanel,
|
|
8
8
|
FunctionsPanel_default as default
|
|
9
9
|
};
|
|
10
|
-
//# sourceMappingURL=FunctionsPanel-
|
|
10
|
+
//# sourceMappingURL=FunctionsPanel-OKFRBXLO.mjs.map
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import {
|
|
2
|
+
AUTOMATION_PLUGIN
|
|
3
|
+
} from "./chunk-WKKQV4PC.mjs";
|
|
4
|
+
|
|
5
|
+
// packages/plugins/plugin-automation/src/types.ts
|
|
6
|
+
import { Schema } from "effect";
|
|
7
|
+
import { SpaceSchema } from "@dxos/react-client/echo";
|
|
8
|
+
var TriggerTemplate = Schema.Union(Schema.Struct({
|
|
9
|
+
type: Schema.Literal("timer"),
|
|
10
|
+
cron: Schema.String
|
|
11
|
+
}), Schema.Struct({
|
|
12
|
+
type: Schema.Literal("queue"),
|
|
13
|
+
queueDXN: Schema.Any
|
|
14
|
+
}));
|
|
15
|
+
var AutomationAction;
|
|
16
|
+
(function(AutomationAction2) {
|
|
17
|
+
const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;
|
|
18
|
+
class CreateTriggerFromTemplate extends Schema.TaggedClass()(`${AUTOMATION_ACTION}/create-trigger-from-template`, {
|
|
19
|
+
input: Schema.Struct({
|
|
20
|
+
space: SpaceSchema,
|
|
21
|
+
template: TriggerTemplate,
|
|
22
|
+
enabled: Schema.optional(Schema.Boolean),
|
|
23
|
+
// TODO(wittjosiah): Improve how this lookup is done.
|
|
24
|
+
scriptName: Schema.optional(Schema.String),
|
|
25
|
+
input: Schema.optional(Schema.Record({
|
|
26
|
+
key: Schema.String,
|
|
27
|
+
value: Schema.Any
|
|
28
|
+
}))
|
|
29
|
+
}),
|
|
30
|
+
output: Schema.Void
|
|
31
|
+
}) {
|
|
32
|
+
}
|
|
33
|
+
AutomationAction2.CreateTriggerFromTemplate = CreateTriggerFromTemplate;
|
|
34
|
+
})(AutomationAction || (AutomationAction = {}));
|
|
35
|
+
|
|
36
|
+
export {
|
|
37
|
+
AutomationAction
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=chunk-ADYCSC6Y.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/types.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { SpaceSchema } from '@dxos/react-client/echo';\n\nimport { AUTOMATION_PLUGIN } from './meta';\n\nconst TriggerTemplate = Schema.Union(\n Schema.Struct({ type: Schema.Literal('timer'), cron: Schema.String }),\n Schema.Struct({ type: Schema.Literal('queue'), queueDXN: Schema.Any }),\n);\n\nexport namespace AutomationAction {\n const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;\n\n export class CreateTriggerFromTemplate extends Schema.TaggedClass<CreateTriggerFromTemplate>()(\n `${AUTOMATION_ACTION}/create-trigger-from-template`,\n {\n input: Schema.Struct({\n space: SpaceSchema,\n template: TriggerTemplate,\n enabled: Schema.optional(Schema.Boolean),\n // TODO(wittjosiah): Improve how this lookup is done.\n scriptName: Schema.optional(Schema.String),\n input: Schema.optional(Schema.Record({ key: Schema.String, value: Schema.Any })),\n }),\n output: Schema.Void,\n },\n ) {}\n}\n"],
|
|
5
|
+
"mappings": ";;;;;AAIA,SAASA,cAAc;AAEvB,SAASC,mBAAmB;AAI5B,IAAMC,kBAAkBC,OAAOC,MAC7BD,OAAOE,OAAO;EAAEC,MAAMH,OAAOI,QAAQ,OAAA;EAAUC,MAAML,OAAOM;AAAO,CAAA,GACnEN,OAAOE,OAAO;EAAEC,MAAMH,OAAOI,QAAQ,OAAA;EAAUG,UAAUP,OAAOQ;AAAI,CAAA,CAAA;;UAGrDC,mBAAAA;AACf,QAAMC,oBAAoB,GAAGC,iBAAAA;EAEtB,MAAMC,kCAAkCZ,OAAOa,YAAW,EAC/D,GAAGH,iBAAAA,iCACH;IACEI,OAAOd,OAAOE,OAAO;MACnBa,OAAOC;MACPC,UAAUlB;MACVmB,SAASlB,OAAOmB,SAASnB,OAAOoB,OAAO;;MAEvCC,YAAYrB,OAAOmB,SAASnB,OAAOM,MAAM;MACzCQ,OAAOd,OAAOmB,SAASnB,OAAOsB,OAAO;QAAEC,KAAKvB,OAAOM;QAAQkB,OAAOxB,OAAOQ;MAAI,CAAA,CAAA;IAC/E,CAAA;IACAiB,QAAQzB,OAAO0B;EACjB,CAAA,EAAA;EACC;oBAbUd,4BAAAA;AAcf,GAjBiBH,qBAAAA,mBAAAA,CAAAA,EAAAA;",
|
|
6
|
+
"names": ["Schema", "SpaceSchema", "TriggerTemplate", "Schema", "Union", "Struct", "type", "Literal", "cron", "String", "queueDXN", "Any", "AutomationAction", "AUTOMATION_ACTION", "AUTOMATION_PLUGIN", "CreateTriggerFromTemplate", "TaggedClass", "input", "space", "SpaceSchema", "template", "enabled", "optional", "Boolean", "scriptName", "Record", "key", "value", "output", "Void"]
|
|
7
|
+
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
// packages/plugins/plugin-automation/src/components/index.ts
|
|
2
2
|
import { lazy } from "react";
|
|
3
|
-
var AutomationContainer = lazy(() => import("./AutomationContainer-
|
|
4
|
-
var AutomationPanel = lazy(() => import("./AutomationPanel-
|
|
5
|
-
var FunctionsContainer = lazy(() => import("./FunctionsContainer-
|
|
6
|
-
var FunctionsPanel = lazy(() => import("./FunctionsPanel-
|
|
3
|
+
var AutomationContainer = lazy(() => import("./AutomationContainer-PDPL34DX.mjs"));
|
|
4
|
+
var AutomationPanel = lazy(() => import("./AutomationPanel-3WG2B7JM.mjs"));
|
|
5
|
+
var FunctionsContainer = lazy(() => import("./FunctionsContainer-HLISW5QI.mjs"));
|
|
6
|
+
var FunctionsPanel = lazy(() => import("./FunctionsPanel-OKFRBXLO.mjs"));
|
|
7
7
|
|
|
8
8
|
export {
|
|
9
9
|
AutomationContainer,
|
|
@@ -11,4 +11,4 @@ export {
|
|
|
11
11
|
FunctionsContainer,
|
|
12
12
|
FunctionsPanel
|
|
13
13
|
};
|
|
14
|
-
//# sourceMappingURL=chunk-
|
|
14
|
+
//# sourceMappingURL=chunk-GUPG3Q72.mjs.map
|
|
@@ -3,10 +3,10 @@ import {
|
|
|
3
3
|
} from "./chunk-WKKQV4PC.mjs";
|
|
4
4
|
|
|
5
5
|
// packages/plugins/plugin-automation/src/components/FunctionsPanel/FunctionsPanel.tsx
|
|
6
|
+
import { Schema } from "effect";
|
|
6
7
|
import React, { useCallback, useMemo } from "react";
|
|
7
8
|
import { createIntent, LayoutAction, useIntentDispatcher } from "@dxos/app-framework";
|
|
8
|
-
import {
|
|
9
|
-
import { FunctionType, ScriptType } from "@dxos/functions/types";
|
|
9
|
+
import { FunctionType, ScriptType } from "@dxos/functions";
|
|
10
10
|
import { Filter, fullyQualifiedId, useQuery } from "@dxos/react-client/echo";
|
|
11
11
|
import { Button, useTranslation } from "@dxos/react-ui";
|
|
12
12
|
import { controlItemClasses } from "@dxos/react-ui-form";
|
|
@@ -56,7 +56,7 @@ var FunctionsPanel = ({ space }) => {
|
|
|
56
56
|
className: mx(controlItemClasses)
|
|
57
57
|
}, /* @__PURE__ */ React.createElement(List.Root, {
|
|
58
58
|
items: functions,
|
|
59
|
-
isItem:
|
|
59
|
+
isItem: Schema.is(FunctionType),
|
|
60
60
|
getId: (func) => func.id
|
|
61
61
|
}, ({ items }) => /* @__PURE__ */ React.createElement("div", {
|
|
62
62
|
role: "list",
|
|
@@ -85,4 +85,4 @@ export {
|
|
|
85
85
|
FunctionsPanel,
|
|
86
86
|
FunctionsPanel_default
|
|
87
87
|
};
|
|
88
|
-
//# sourceMappingURL=chunk-
|
|
88
|
+
//# sourceMappingURL=chunk-IDCVJ2JW.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/FunctionsPanel/FunctionsPanel.tsx", "../../../src/components/FunctionsPanel/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport React, { useCallback, useMemo } from 'react';\n\nimport { createIntent, LayoutAction, useIntentDispatcher } from '@dxos/app-framework';\nimport { FunctionType, ScriptType } from '@dxos/functions';\nimport { Filter, fullyQualifiedId, useQuery, type Space } from '@dxos/react-client/echo';\nimport { Button, useTranslation } from '@dxos/react-ui';\nimport { controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nconst grid = 'grid grid-cols-[1fr_auto] min-bs-[2.5rem]';\n\nexport type FunctionsPanelProps = {\n space: Space;\n};\n\nexport const FunctionsPanel = ({ space }: FunctionsPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const functions = useQuery(space, Filter.schema(FunctionType));\n const scripts = useQuery(space, Filter.schema(ScriptType));\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n\n const functionToScriptMap = useMemo(\n () =>\n functions.reduce(\n (map, func) => {\n const scriptId = func.source?.target?.id;\n if (scriptId) {\n const script = scripts.find((s) => s.id === scriptId);\n if (script) {\n map[func.id] = script;\n }\n }\n return map;\n },\n {} as Record<string, ScriptType>,\n ),\n [functions, scripts],\n );\n\n const getScriptName = useCallback(\n (func: FunctionType) => {\n const script = functionToScriptMap[func.id];\n return script?.name;\n },\n [functionToScriptMap],\n );\n\n const handleGoToScript = useCallback(\n (func: FunctionType) => {\n const script = functionToScriptMap[func.id];\n if (script) {\n void dispatch(createIntent(LayoutAction.Open, { part: 'main', subject: [fullyQualifiedId(script)] }));\n }\n },\n [functionToScriptMap, dispatch],\n );\n\n return (\n <div role='none' className={mx(controlItemClasses)}>\n <List.Root<FunctionType> items={functions} isItem={Schema.is(FunctionType)} getId={(func) => func.id}>\n {({ items }) => (\n <div role='list' className='flex flex-col w-full'>\n {items?.map((func) => (\n <List.Item<FunctionType>\n key={func.id}\n item={func}\n classNames={mx(grid, ghostHover, 'items-center', 'pli-2', 'min-bs-[3rem]')}\n >\n <div className='flex flex-col truncate'>\n <List.ItemTitle classNames='truncate'>{func.name}</List.ItemTitle>\n {getScriptName(func) && (\n <div className='text-xs text-description truncate'>{getScriptName(func)}</div>\n )}\n </div>\n {functionToScriptMap[func.id] && (\n <Button onClick={() => handleGoToScript(func)}>{t('go to function source button label')}</Button>\n )}\n </List.Item>\n ))}\n </div>\n )}\n </List.Root>\n\n {functions.length === 0 && <div className='text-center plb-4 text-gray-500'>{t('no functions found')}</div>}\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { FunctionsPanel } from './FunctionsPanel';\n\nexport * from './FunctionsPanel';\nexport default FunctionsPanel;\n"],
|
|
5
|
+
"mappings": ";;;;;AAIA,SAASA,cAAc;AACvB,OAAOC,SAASC,aAAaC,eAAe;AAE5C,SAASC,cAAcC,cAAcC,2BAA2B;AAChE,SAASC,cAAcC,kBAAkB;AACzC,SAASC,QAAQC,kBAAkBC,gBAA4B;AAC/D,SAASC,QAAQC,sBAAsB;AACvC,SAASC,0BAA0B;AACnC,SAASC,YAAY;AACrB,SAASC,YAAYC,UAAU;AAI/B,IAAMC,OAAO;AAMN,IAAMC,iBAAiB,CAAC,EAAEC,MAAK,MAAuB;AAC3D,QAAM,EAAEC,EAAC,IAAKC,eAAeC,iBAAAA;AAC7B,QAAMC,YAAYC,SAASL,OAAOM,OAAOC,OAAOC,YAAAA,CAAAA;AAChD,QAAMC,UAAUJ,SAASL,OAAOM,OAAOC,OAAOG,UAAAA,CAAAA;AAC9C,QAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AAEtC,QAAMC,sBAAsBC,QAC1B,MACEX,UAAUY,OACR,CAACC,KAAKC,SAAAA;AACJ,UAAMC,WAAWD,KAAKE,QAAQC,QAAQC;AACtC,QAAIH,UAAU;AACZ,YAAMI,SAASd,QAAQe,KAAK,CAACC,MAAMA,EAAEH,OAAOH,QAAAA;AAC5C,UAAII,QAAQ;AACVN,YAAIC,KAAKI,EAAE,IAAIC;MACjB;IACF;AACA,WAAON;EACT,GACA,CAAC,CAAA,GAEL;IAACb;IAAWK;GAAQ;AAGtB,QAAMiB,gBAAgBC,YACpB,CAACT,SAAAA;AACC,UAAMK,SAAST,oBAAoBI,KAAKI,EAAE;AAC1C,WAAOC,QAAQK;EACjB,GACA;IAACd;GAAoB;AAGvB,QAAMe,mBAAmBF,YACvB,CAACT,SAAAA;AACC,UAAMK,SAAST,oBAAoBI,KAAKI,EAAE;AAC1C,QAAIC,QAAQ;AACV,WAAKX,SAASkB,aAAaC,aAAaC,MAAM;QAAEC,MAAM;QAAQC,SAAS;UAACC,iBAAiBZ,MAAAA;;MAAS,CAAA,CAAA;IACpG;EACF,GACA;IAACT;IAAqBF;GAAS;AAGjC,SACE,sBAAA,cAACwB,OAAAA;IAAIC,MAAK;IAAOC,WAAWC,GAAGC,kBAAAA;KAC7B,sBAAA,cAACC,KAAKC,MAAI;IAAeC,OAAOvC;IAAWwC,QAAQC,OAAOC,GAAGtC,YAAAA;IAAeuC,OAAO,CAAC7B,SAASA,KAAKI;KAC/F,CAAC,EAAEqB,MAAK,MACP,sBAAA,cAACP,OAAAA;IAAIC,MAAK;IAAOC,WAAU;KACxBK,OAAO1B,IAAI,CAACC,SACX,sBAAA,cAACuB,KAAKO,MAAI;IACRC,KAAK/B,KAAKI;IACV4B,MAAMhC;IACNiC,YAAYZ,GAAGzC,MAAMsD,YAAY,gBAAgB,SAAS,eAAA;KAE1D,sBAAA,cAAChB,OAAAA;IAAIE,WAAU;KACb,sBAAA,cAACG,KAAKY,WAAS;IAACF,YAAW;KAAYjC,KAAKU,IAAI,GAC/CF,cAAcR,IAAAA,KACb,sBAAA,cAACkB,OAAAA;IAAIE,WAAU;KAAqCZ,cAAcR,IAAAA,CAAAA,CAAAA,GAGrEJ,oBAAoBI,KAAKI,EAAE,KAC1B,sBAAA,cAACgC,QAAAA;IAAOC,SAAS,MAAM1B,iBAAiBX,IAAAA;KAAQjB,EAAE,oCAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAQ7DG,UAAUoD,WAAW,KAAK,sBAAA,cAACpB,OAAAA;IAAIE,WAAU;KAAmCrC,EAAE,oBAAA,CAAA,CAAA;AAGrF;;;ACvFA,IAAA,yBAAewD;",
|
|
6
|
+
"names": ["Schema", "React", "useCallback", "useMemo", "createIntent", "LayoutAction", "useIntentDispatcher", "FunctionType", "ScriptType", "Filter", "fullyQualifiedId", "useQuery", "Button", "useTranslation", "controlItemClasses", "List", "ghostHover", "mx", "grid", "FunctionsPanel", "space", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "schema", "FunctionType", "scripts", "ScriptType", "dispatchPromise", "dispatch", "useIntentDispatcher", "functionToScriptMap", "useMemo", "reduce", "map", "func", "scriptId", "source", "target", "id", "script", "find", "s", "getScriptName", "useCallback", "name", "handleGoToScript", "createIntent", "LayoutAction", "Open", "part", "subject", "fullyQualifiedId", "div", "role", "className", "mx", "controlItemClasses", "List", "Root", "items", "isItem", "Schema", "is", "getId", "Item", "key", "item", "classNames", "ghostHover", "ItemTitle", "Button", "onClick", "length", "FunctionsPanel"]
|
|
7
|
+
}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import {
|
|
2
2
|
TriggerEditor
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-W4T2BTH2.mjs";
|
|
4
4
|
import {
|
|
5
5
|
AUTOMATION_PLUGIN
|
|
6
6
|
} from "./chunk-WKKQV4PC.mjs";
|
|
7
7
|
|
|
8
8
|
// packages/plugins/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
|
|
9
|
+
import { Schema } from "effect";
|
|
9
10
|
import React, { useState } from "react";
|
|
10
|
-
import {
|
|
11
|
-
import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions/types";
|
|
11
|
+
import { FunctionType, FunctionTrigger, FunctionTriggerSchema, TriggerKind, ScriptType } from "@dxos/functions";
|
|
12
12
|
import { useClient } from "@dxos/react-client";
|
|
13
13
|
import { live, Filter, useQuery, getSpace } from "@dxos/react-client/echo";
|
|
14
14
|
import { Clipboard, IconButton, Input, Separator, useTranslation } from "@dxos/react-ui";
|
|
@@ -66,7 +66,7 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
|
|
|
66
66
|
className: controlItemClasses
|
|
67
67
|
}, /* @__PURE__ */ React.createElement(List.Root, {
|
|
68
68
|
items: triggers,
|
|
69
|
-
isItem:
|
|
69
|
+
isItem: Schema.is(FunctionTrigger),
|
|
70
70
|
getId: (field) => field.id
|
|
71
71
|
}, ({ items: triggers2 }) => /* @__PURE__ */ React.createElement("div", {
|
|
72
72
|
role: "list",
|
|
@@ -100,13 +100,13 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
|
|
|
100
100
|
})));
|
|
101
101
|
};
|
|
102
102
|
var getCopyAction = (client, trigger) => {
|
|
103
|
-
if (trigger?.spec?.
|
|
103
|
+
if (trigger?.spec?.kind === TriggerKind.Email) {
|
|
104
104
|
return {
|
|
105
105
|
translationKey: "trigger copy email",
|
|
106
106
|
contentProvider: () => `${getSpace(trigger).id}@dxos.network`
|
|
107
107
|
};
|
|
108
108
|
}
|
|
109
|
-
if (trigger?.spec?.
|
|
109
|
+
if (trigger?.spec?.kind === TriggerKind.Webhook) {
|
|
110
110
|
return {
|
|
111
111
|
translationKey: "trigger copy url",
|
|
112
112
|
contentProvider: () => getWebhookUrl(client, trigger)
|
|
@@ -122,8 +122,8 @@ var getWebhookUrl = (client, trigger) => {
|
|
|
122
122
|
return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
|
|
123
123
|
};
|
|
124
124
|
var getFunctionName = (scripts, functions, trigger) => {
|
|
125
|
-
const shortId = trigger.function && `${trigger.function
|
|
126
|
-
const functionObject = functions.find((fn) =>
|
|
125
|
+
const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
|
|
126
|
+
const functionObject = functions.find((fn) => fn === trigger.function?.target);
|
|
127
127
|
if (!functionObject) {
|
|
128
128
|
return shortId;
|
|
129
129
|
}
|
|
@@ -137,4 +137,4 @@ export {
|
|
|
137
137
|
AutomationPanel,
|
|
138
138
|
AutomationPanel_default
|
|
139
139
|
};
|
|
140
|
-
//# sourceMappingURL=chunk-
|
|
140
|
+
//# sourceMappingURL=chunk-QFIPNCNF.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/AutomationPanel/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport React, { useState } from 'react';\n\nimport {\n FunctionType,\n FunctionTrigger,\n FunctionTriggerSchema,\n TriggerKind,\n type FunctionTriggerType,\n ScriptType,\n} from '@dxos/functions';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { live, Filter, useQuery, type Space, type Live, getSpace } from '@dxos/react-client/echo';\nimport { Clipboard, IconButton, Input, Separator, useTranslation } from '@dxos/react-ui';\nimport { ControlItem, controlItemClasses } from '@dxos/react-ui-form';\nimport { List } from '@dxos/react-ui-list';\nimport { ghostHover, mx } from '@dxos/react-ui-theme';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\nimport { TriggerEditor, type TriggerEditorProps } from '../TriggerEditor';\n\nconst grid = 'grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]';\n\nexport type AutomationPanelProps = {\n space: Space;\n object?: Live<any>;\n initialTrigger?: FunctionTriggerType;\n onDone?: () => void;\n};\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ space, object, initialTrigger, onDone }: AutomationPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const client = useClient();\n const triggers = useQuery(space, Filter.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 | undefined>(initialTrigger);\n const [selected, setSelected] = useState<FunctionTrigger>();\n\n const handleSelect = (trigger: FunctionTrigger) => {\n const { id: _, ...values } = trigger;\n setTrigger(values);\n setSelected(trigger);\n };\n\n const handleAdd = () => {\n setTrigger(live(FunctionTriggerSchema, {}));\n setSelected(undefined);\n };\n\n const handleDelete = (trigger: FunctionTrigger) => {\n space.db.remove(trigger);\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleSave: TriggerEditorProps['onSave'] = (trigger) => {\n if (selected) {\n Object.assign(selected, trigger);\n } else {\n space.db.add(live(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n onDone?.();\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n onDone?.();\n };\n\n return (\n <div className='flex flex-col w-full'>\n {trigger ? (\n <ControlItem title={t('trigger editor title')}>\n <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />\n </ControlItem>\n ) : (\n <div role='none' className={controlItemClasses}>\n <List.Root<FunctionTrigger> items={triggers} isItem={Schema.is(FunctionTrigger)} getId={(field) => field.id}>\n {({ items: triggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {triggers?.map((trigger) => {\n const copyAction = getCopyAction(client, trigger);\n return (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center', 'px-2')}\n >\n <Input.Root>\n <Input.Switch\n checked={trigger.enabled}\n onCheckedChange={(checked) => (trigger.enabled = checked)}\n />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle\n classNames='px-1 cursor-pointer w-0 shrink truncate'\n onClick={() => handleSelect(trigger)}\n >\n {getFunctionName(scripts, functions, trigger) ?? '∅'}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose copy action */}\n {copyAction && (\n <Clipboard.IconButton\n label={t(copyAction.translationKey)}\n value={copyAction.contentProvider()}\n />\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n {triggers.length > 0 && <Separator classNames='mlb-4' />}\n <IconButton icon='ph--plus--regular' label={t('new trigger label')} onClick={handleAdd} />\n </div>\n )}\n </div>\n );\n};\n\nconst getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.kind === TriggerKind.Email) {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.kind === TriggerKind.Webhook) {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTriggerType) => {\n // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}…`;\n const functionObject = functions.find((fn) => fn === trigger.function?.target);\n if (!functionObject) {\n return shortId;\n }\n\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AutomationPanel } from './AutomationPanel';\n\nexport * from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Schema", "React", "useState", "FunctionType", "FunctionTrigger", "FunctionTriggerSchema", "TriggerKind", "ScriptType", "useClient", "live", "Filter", "useQuery", "getSpace", "Clipboard", "IconButton", "Input", "Separator", "useTranslation", "ControlItem", "controlItemClasses", "List", "ghostHover", "mx", "grid", "AutomationPanel", "space", "object", "initialTrigger", "onDone", "t", "useTranslation", "AUTOMATION_PLUGIN", "client", "useClient", "triggers", "useQuery", "Filter", "schema", "FunctionTrigger", "functions", "FunctionType", "scripts", "ScriptType", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "id", "_", "values", "handleAdd", "live", "FunctionTriggerSchema", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "div", "className", "ControlItem", "title", "TriggerEditor", "onSave", "onCancel", "role", "controlItemClasses", "List", "Root", "items", "isItem", "Schema", "is", "getId", "field", "map", "copyAction", "getCopyAction", "Item", "key", "item", "classNames", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Clipboard", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "length", "Separator", "icon", "spec", "kind", "TriggerKind", "Email", "getSpace", "Webhook", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "dxn", "slice", "functionObject", "find", "fn", "target", "s", "source", "name", "AutomationPanel"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
import {
|
|
2
|
+
AUTOMATION_PLUGIN
|
|
3
|
+
} from "./chunk-WKKQV4PC.mjs";
|
|
4
|
+
|
|
5
|
+
// packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
|
|
6
|
+
import React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react";
|
|
7
|
+
import { ComputeGraph } from "@dxos/conductor";
|
|
8
|
+
import { DXN } from "@dxos/echo";
|
|
9
|
+
import { FunctionType, FunctionTriggerSchema, ScriptType } from "@dxos/functions";
|
|
10
|
+
import { Filter, Ref, useQuery } from "@dxos/react-client/echo";
|
|
11
|
+
import { useTranslation as useTranslation2 } from "@dxos/react-ui";
|
|
12
|
+
import { Form as Form2, SelectInput as SelectInput2, useRefQueryLookupHandler } from "@dxos/react-ui-form";
|
|
13
|
+
|
|
14
|
+
// packages/plugins/plugin-automation/src/components/TriggerEditor/FunctionInputEditor.tsx
|
|
15
|
+
import React, { useCallback, useMemo } from "react";
|
|
16
|
+
import { RefImpl, toEffectSchema } from "@dxos/echo-schema";
|
|
17
|
+
import { useOnTransition } from "@dxos/react-ui";
|
|
18
|
+
import { Form, useFormValues } from "@dxos/react-ui-form";
|
|
19
|
+
var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
|
|
20
|
+
const selectedFunctionValue = useFormValues([
|
|
21
|
+
"function"
|
|
22
|
+
]);
|
|
23
|
+
const selectedFunctionId = useMemo(() => {
|
|
24
|
+
if (selectedFunctionValue instanceof RefImpl) {
|
|
25
|
+
return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
|
|
26
|
+
}
|
|
27
|
+
}, [
|
|
28
|
+
selectedFunctionValue
|
|
29
|
+
]);
|
|
30
|
+
const selectedFunction = useMemo(() => functions.find((f) => f.id === selectedFunctionId), [
|
|
31
|
+
functions,
|
|
32
|
+
selectedFunctionId
|
|
33
|
+
]);
|
|
34
|
+
useOnTransition(
|
|
35
|
+
// Clear function parameter input when the function changes.
|
|
36
|
+
selectedFunctionValue,
|
|
37
|
+
(prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
|
|
38
|
+
(currValue) => currValue !== void 0,
|
|
39
|
+
() => onValueChange("object", {})
|
|
40
|
+
);
|
|
41
|
+
const inputSchema = useMemo(() => selectedFunction?.inputSchema, [
|
|
42
|
+
selectedFunction
|
|
43
|
+
]);
|
|
44
|
+
const effectSchema = useMemo(() => inputSchema ? toEffectSchema(inputSchema) : void 0, [
|
|
45
|
+
inputSchema
|
|
46
|
+
]);
|
|
47
|
+
const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
|
|
48
|
+
const values = useMemo(() => getValue() ?? {}, [
|
|
49
|
+
getValue
|
|
50
|
+
]);
|
|
51
|
+
const handleValuesChanged = useCallback((values2) => {
|
|
52
|
+
onValueChange("object", values2);
|
|
53
|
+
}, [
|
|
54
|
+
onValueChange
|
|
55
|
+
]);
|
|
56
|
+
if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("h3", {
|
|
60
|
+
className: "text-md"
|
|
61
|
+
}, "Function parameters"), /* @__PURE__ */ React.createElement(Form, {
|
|
62
|
+
schema: effectSchema,
|
|
63
|
+
values,
|
|
64
|
+
classNames: "p-0",
|
|
65
|
+
onValuesChanged: handleValuesChanged,
|
|
66
|
+
onQueryRefOptions
|
|
67
|
+
}));
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
// packages/plugins/plugin-automation/src/components/TriggerEditor/SpecSelector.tsx
|
|
71
|
+
import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
|
|
72
|
+
import { TriggerKind } from "@dxos/functions";
|
|
73
|
+
import { useTranslation } from "@dxos/react-ui";
|
|
74
|
+
import { SelectInput, useInputProps } from "@dxos/react-ui-form";
|
|
75
|
+
var SpecSelector = (props) => {
|
|
76
|
+
const { t } = useTranslation(AUTOMATION_PLUGIN);
|
|
77
|
+
const specProps = useInputProps([
|
|
78
|
+
"spec"
|
|
79
|
+
]);
|
|
80
|
+
const handleTypeChange = useCallback2((_type, value) => {
|
|
81
|
+
const getDefaultTriggerSpec = (kind) => {
|
|
82
|
+
switch (kind) {
|
|
83
|
+
case TriggerKind.Timer:
|
|
84
|
+
return {
|
|
85
|
+
type: TriggerKind.Timer,
|
|
86
|
+
cron: ""
|
|
87
|
+
};
|
|
88
|
+
case TriggerKind.Subscription:
|
|
89
|
+
return {
|
|
90
|
+
type: TriggerKind.Subscription,
|
|
91
|
+
filter: {}
|
|
92
|
+
};
|
|
93
|
+
case TriggerKind.Queue:
|
|
94
|
+
return {
|
|
95
|
+
type: TriggerKind.Queue,
|
|
96
|
+
queue: ""
|
|
97
|
+
};
|
|
98
|
+
case TriggerKind.Email:
|
|
99
|
+
return {
|
|
100
|
+
type: TriggerKind.Email
|
|
101
|
+
};
|
|
102
|
+
case TriggerKind.Webhook:
|
|
103
|
+
return {
|
|
104
|
+
type: TriggerKind.Webhook
|
|
105
|
+
};
|
|
106
|
+
default:
|
|
107
|
+
return void 0;
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
const defaultSpec = getDefaultTriggerSpec(value);
|
|
111
|
+
if (!defaultSpec) {
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
specProps.onValueChange("object", defaultSpec);
|
|
115
|
+
}, [
|
|
116
|
+
specProps
|
|
117
|
+
]);
|
|
118
|
+
const options = useMemo2(() => Object.values(TriggerKind).map((kind) => ({
|
|
119
|
+
value: kind,
|
|
120
|
+
label: t(`trigger type ${kind}`)
|
|
121
|
+
})), [
|
|
122
|
+
t
|
|
123
|
+
]);
|
|
124
|
+
return /* @__PURE__ */ React2.createElement(SelectInput, {
|
|
125
|
+
...props,
|
|
126
|
+
options,
|
|
127
|
+
onValueChange: handleTypeChange
|
|
128
|
+
});
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
// packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
|
|
132
|
+
var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
|
|
133
|
+
const { t } = useTranslation2(AUTOMATION_PLUGIN);
|
|
134
|
+
const functions = useQuery(space, Filter.schema(FunctionType));
|
|
135
|
+
const workflows = useQuery(space, Filter.schema(ComputeGraph));
|
|
136
|
+
const scripts = useQuery(space, Filter.schema(ScriptType));
|
|
137
|
+
const handleSave = (values) => {
|
|
138
|
+
onSave?.(values);
|
|
139
|
+
};
|
|
140
|
+
const handleRefQueryLookup = useRefQueryLookupHandler({
|
|
141
|
+
space
|
|
142
|
+
});
|
|
143
|
+
const Custom = useMemo3(() => ({
|
|
144
|
+
["function"]: (props) => {
|
|
145
|
+
const getValue = useCallback3(() => {
|
|
146
|
+
const formValue = props.getValue();
|
|
147
|
+
if (Ref.isRef(formValue)) {
|
|
148
|
+
return formValue.dxn.toString();
|
|
149
|
+
}
|
|
150
|
+
return void 0;
|
|
151
|
+
}, [
|
|
152
|
+
props
|
|
153
|
+
]);
|
|
154
|
+
const handleOnValueChange = useCallback3((_type, dxnString) => {
|
|
155
|
+
const dxn = DXN.parse(dxnString);
|
|
156
|
+
if (dxn) {
|
|
157
|
+
const ref = Ref.fromDXN(dxn);
|
|
158
|
+
props.onValueChange("object", ref);
|
|
159
|
+
}
|
|
160
|
+
}, [
|
|
161
|
+
props.onValueChange
|
|
162
|
+
]);
|
|
163
|
+
return /* @__PURE__ */ React3.createElement(SelectInput2, {
|
|
164
|
+
...props,
|
|
165
|
+
getValue,
|
|
166
|
+
onValueChange: handleOnValueChange,
|
|
167
|
+
options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
|
|
168
|
+
});
|
|
169
|
+
},
|
|
170
|
+
["spec.kind"]: SpecSelector,
|
|
171
|
+
["input"]: (props) => /* @__PURE__ */ React3.createElement(FunctionInputEditor, {
|
|
172
|
+
...props,
|
|
173
|
+
functions,
|
|
174
|
+
onQueryRefOptions: handleRefQueryLookup
|
|
175
|
+
})
|
|
176
|
+
}), [
|
|
177
|
+
workflows,
|
|
178
|
+
scripts,
|
|
179
|
+
functions,
|
|
180
|
+
t
|
|
181
|
+
]);
|
|
182
|
+
return /* @__PURE__ */ React3.createElement("div", {
|
|
183
|
+
role: "none",
|
|
184
|
+
className: "bs-full is-full"
|
|
185
|
+
}, /* @__PURE__ */ React3.createElement(Form2, {
|
|
186
|
+
schema: FunctionTriggerSchema,
|
|
187
|
+
values: trigger,
|
|
188
|
+
onSave: handleSave,
|
|
189
|
+
onCancel,
|
|
190
|
+
Custom,
|
|
191
|
+
onQueryRefOptions: handleRefQueryLookup
|
|
192
|
+
}));
|
|
193
|
+
};
|
|
194
|
+
var getWorkflowOptions = (graphs) => {
|
|
195
|
+
return graphs.map((graph) => ({
|
|
196
|
+
label: `compute-${graph.id}`,
|
|
197
|
+
value: `dxn:echo:@:${graph.id}`
|
|
198
|
+
}));
|
|
199
|
+
};
|
|
200
|
+
var getFunctionOptions = (scripts, functions) => {
|
|
201
|
+
const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
|
|
202
|
+
return functions.map((fn) => ({
|
|
203
|
+
label: getLabel(fn),
|
|
204
|
+
value: `dxn:echo:@:${fn.id}`
|
|
205
|
+
}));
|
|
206
|
+
};
|
|
207
|
+
|
|
208
|
+
export {
|
|
209
|
+
TriggerEditor
|
|
210
|
+
};
|
|
211
|
+
//# sourceMappingURL=chunk-W4T2BTH2.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx", "../../../src/components/TriggerEditor/FunctionInputEditor.tsx", "../../../src/components/TriggerEditor/SpecSelector.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { ComputeGraph } from '@dxos/conductor';\nimport { DXN } from '@dxos/echo';\nimport {\n FunctionType,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n type FunctionTrigger,\n ScriptType,\n} from '@dxos/functions';\nimport { Filter, Ref, useQuery, type Space } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { type CustomInputMap, Form, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { FunctionInputEditor } from './FunctionInputEditor';\nimport { SpecSelector } from './SpecSelector';\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n\n const functions = useQuery(space, Filter.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 handleRefQueryLookup = useRefQueryLookupHandler({ space });\n\n const Custom = useMemo(\n (): CustomInputMap => ({\n ['function' satisfies keyof FunctionTriggerType]: (props) => {\n const getValue = useCallback(() => {\n const formValue = props.getValue();\n if (Ref.isRef(formValue)) {\n return formValue.dxn.toString() as string;\n }\n return undefined;\n }, [props]);\n\n const handleOnValueChange = useCallback(\n (_type: any, dxnString: string) => {\n const dxn = DXN.parse(dxnString);\n if (dxn) {\n const ref = Ref.fromDXN(dxn);\n props.onValueChange('object', ref);\n }\n },\n [props.onValueChange],\n );\n\n return (\n <SelectInput\n {...props}\n getValue={getValue as any}\n onValueChange={handleOnValueChange}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n );\n },\n ['spec.kind' as const]: SpecSelector,\n ['input' as const]: (props) => (\n <FunctionInputEditor {...props} functions={functions} onQueryRefOptions={handleRefQueryLookup} />\n ),\n }),\n [workflows, scripts, functions, t],\n );\n\n return (\n <div role='none' className='bs-full is-full'>\n <Form\n schema={FunctionTriggerSchema}\n values={trigger}\n onSave={handleSave}\n onCancel={onCancel}\n Custom={Custom}\n onQueryRefOptions={handleRefQueryLookup}\n />\n </div>\n );\n};\n\nconst getWorkflowOptions = (graphs: ComputeGraph[]) => {\n return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));\n};\n\nconst getFunctionOptions = (scripts: ScriptType[], functions: FunctionType[]) => {\n const getLabel = (fn: FunctionType) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:echo:@:${fn.id}` }));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { type JsonPath, RefImpl, toEffectSchema } from '@dxos/echo-schema';\nimport { type FunctionType } from '@dxos/functions';\nimport { useOnTransition } from '@dxos/react-ui';\nimport { Form, type FormInputStateProps, type QueryRefOptions, useFormValues } from '@dxos/react-ui-form';\n\nexport type FunctionInputEditorProps = {\n functions: FunctionType[];\n onQueryRefOptions: QueryRefOptions;\n} & FormInputStateProps;\n\n/**\n * Editor component for function input parameters.\n */\nexport const FunctionInputEditor = ({\n functions,\n getValue,\n onValueChange,\n onQueryRefOptions,\n}: FunctionInputEditorProps) => {\n const selectedFunctionValue = useFormValues(['function' as JsonPath]);\n const selectedFunctionId = useMemo(() => {\n if (selectedFunctionValue instanceof RefImpl) {\n return selectedFunctionValue.dxn.toString().split('dxn:echo:@:').at(1);\n }\n }, [selectedFunctionValue]);\n\n const selectedFunction = useMemo(\n () => functions.find((f) => f.id === selectedFunctionId),\n [functions, selectedFunctionId],\n );\n\n useOnTransition(\n // Clear function parameter input when the function changes.\n selectedFunctionValue,\n (prevValue) => prevValue !== undefined && prevValue !== selectedFunctionValue,\n (currValue) => currValue !== undefined,\n () => onValueChange('object', {}),\n );\n\n const inputSchema = useMemo(() => selectedFunction?.inputSchema, [selectedFunction]);\n const effectSchema = useMemo(() => (inputSchema ? toEffectSchema(inputSchema) : undefined), [inputSchema]);\n const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;\n\n const values = useMemo(() => getValue() ?? {}, [getValue]);\n\n const handleValuesChanged = useCallback(\n (values: any) => {\n onValueChange('object', values);\n },\n [onValueChange],\n );\n\n if (selectedFunction === undefined || effectSchema === undefined || propertyCount === 0) {\n return null;\n }\n\n return (\n <>\n <h3 className='text-md'>Function parameters</h3>\n {/* TODO(ZaymonFC): Try using <FormFields /> internal component for this nesting.\n This would allow errors to flow up to the root context. */}\n <Form\n schema={effectSchema}\n values={values}\n classNames='p-0'\n onValuesChanged={handleValuesChanged}\n onQueryRefOptions={onQueryRefOptions}\n />\n </>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { type FunctionTriggerType, TriggerKind, type TriggerType } from '@dxos/functions';\nimport { useTranslation } from '@dxos/react-ui';\nimport { SelectInput, type InputProps, useInputProps } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type SpecSelectorProps = InputProps;\n\nexport const SpecSelector = (props: SpecSelectorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const specProps = useInputProps(['spec' satisfies keyof FunctionTriggerType]);\n\n const handleTypeChange = useCallback(\n (_type: any, value: string): TriggerType | undefined => {\n const getDefaultTriggerSpec = (kind: string) => {\n switch (kind) {\n case TriggerKind.Timer:\n return { type: TriggerKind.Timer, cron: '' };\n case TriggerKind.Subscription:\n return { type: TriggerKind.Subscription, filter: {} };\n case TriggerKind.Queue:\n return { type: TriggerKind.Queue, queue: '' };\n case TriggerKind.Email:\n return { type: TriggerKind.Email };\n case TriggerKind.Webhook:\n return { type: 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.type`.\n specProps.onValueChange('object', defaultSpec);\n },\n [specProps],\n );\n\n const options = useMemo(\n () =>\n Object.values(TriggerKind).map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n })),\n [t],\n );\n\n return <SelectInput {...props} options={options} onValueChange={handleTypeChange} />;\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "useCallback", "useMemo", "ComputeGraph", "DXN", "FunctionType", "FunctionTriggerSchema", "ScriptType", "Filter", "Ref", "useQuery", "useTranslation", "Form", "SelectInput", "useRefQueryLookupHandler", "React", "useCallback", "useMemo", "RefImpl", "toEffectSchema", "useOnTransition", "Form", "useFormValues", "FunctionInputEditor", "functions", "getValue", "onValueChange", "onQueryRefOptions", "selectedFunctionValue", "useFormValues", "selectedFunctionId", "useMemo", "RefImpl", "dxn", "toString", "split", "at", "selectedFunction", "find", "f", "id", "useOnTransition", "prevValue", "undefined", "currValue", "inputSchema", "effectSchema", "toEffectSchema", "propertyCount", "properties", "Object", "keys", "length", "values", "handleValuesChanged", "useCallback", "h3", "className", "Form", "schema", "classNames", "onValuesChanged", "React", "useCallback", "useMemo", "TriggerKind", "useTranslation", "SelectInput", "useInputProps", "SpecSelector", "props", "t", "useTranslation", "AUTOMATION_PLUGIN", "specProps", "useInputProps", "handleTypeChange", "useCallback", "_type", "value", "getDefaultTriggerSpec", "kind", "TriggerKind", "Timer", "type", "cron", "Subscription", "filter", "Queue", "queue", "Email", "Webhook", "undefined", "defaultSpec", "onValueChange", "options", "useMemo", "Object", "values", "map", "label", "React", "SelectInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "schema", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "handleSave", "values", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "useMemo", "props", "getValue", "useCallback", "formValue", "Ref", "isRef", "dxn", "toString", "undefined", "handleOnValueChange", "_type", "dxnString", "DXN", "parse", "ref", "fromDXN", "onValueChange", "React", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "SpecSelector", "FunctionInputEditor", "onQueryRefOptions", "div", "role", "className", "Form", "FunctionTriggerSchema", "graphs", "map", "graph", "label", "id", "value", "getLabel", "fn", "find", "s", "source", "target", "name"]
|
|
7
|
+
}
|
|
@@ -3,10 +3,10 @@ import {
|
|
|
3
3
|
AutomationPanel,
|
|
4
4
|
FunctionsContainer,
|
|
5
5
|
FunctionsPanel
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-GUPG3Q72.mjs";
|
|
7
7
|
import {
|
|
8
8
|
TriggerEditor
|
|
9
|
-
} from "./chunk-
|
|
9
|
+
} from "./chunk-W4T2BTH2.mjs";
|
|
10
10
|
import {
|
|
11
11
|
AUTOMATION_PLUGIN,
|
|
12
12
|
meta
|
|
@@ -14,14 +14,14 @@ import {
|
|
|
14
14
|
|
|
15
15
|
// packages/plugins/plugin-automation/src/AutomationPlugin.tsx
|
|
16
16
|
import { Capabilities, contributes, defineModule, definePlugin, Events } from "@dxos/app-framework";
|
|
17
|
-
import { FunctionType, FunctionTrigger } from "@dxos/functions
|
|
17
|
+
import { FunctionType, FunctionTrigger } from "@dxos/functions";
|
|
18
18
|
import { ClientCapabilities, ClientEvents } from "@dxos/plugin-client";
|
|
19
19
|
|
|
20
20
|
// packages/plugins/plugin-automation/src/capabilities/index.ts
|
|
21
21
|
import { lazy } from "@dxos/app-framework";
|
|
22
22
|
var AppGraphBuilder = lazy(() => import("./app-graph-builder-ND64CHOM.mjs"));
|
|
23
|
-
var IntentResolver = lazy(() => import("./intent-resolver-
|
|
24
|
-
var ReactSurface = lazy(() => import("./react-surface-
|
|
23
|
+
var IntentResolver = lazy(() => import("./intent-resolver-TCUIVOEW.mjs"));
|
|
24
|
+
var ReactSurface = lazy(() => import("./react-surface-P65PEZPN.mjs"));
|
|
25
25
|
|
|
26
26
|
// packages/plugins/plugin-automation/src/translations.ts
|
|
27
27
|
var translations_default = [
|
|
@@ -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
|
|
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
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
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"]
|
|
7
7
|
}
|