@dxos/plugin-automation 0.8.2-main.2f9c567 → 0.8.2-main.5885341
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-3MP23OGQ.mjs → AutomationContainer-KEQ5RNIW.mjs} +3 -3
- package/dist/lib/browser/{AutomationPanel-75HVBBNG.mjs → AutomationPanel-G3OB6ELR.mjs} +3 -3
- package/dist/lib/browser/{FunctionsContainer-HLISW5QI.mjs → FunctionsContainer-STXBW4CX.mjs} +2 -2
- package/dist/lib/browser/{FunctionsPanel-OKFRBXLO.mjs → FunctionsPanel-JJPLIAJW.mjs} +2 -2
- package/dist/lib/browser/{chunk-IDCVJ2JW.mjs → chunk-65VL4EYS.mjs} +4 -4
- package/dist/lib/browser/chunk-65VL4EYS.mjs.map +7 -0
- package/dist/lib/browser/chunk-FALBBJNO.mjs +138 -0
- package/dist/lib/browser/chunk-FALBBJNO.mjs.map +7 -0
- package/dist/lib/browser/chunk-FCLWFVFX.mjs +39 -0
- package/dist/lib/browser/chunk-FCLWFVFX.mjs.map +7 -0
- package/dist/lib/browser/{chunk-HTVXRMNH.mjs → chunk-NGG4ICAQ.mjs} +7 -7
- package/dist/lib/browser/chunk-NGG4ICAQ.mjs.map +7 -0
- package/dist/lib/browser/{chunk-N4PTKEWO.mjs → chunk-QJPKWYTL.mjs} +5 -5
- package/dist/lib/browser/index.mjs +5 -5
- package/dist/lib/browser/index.mjs.map +1 -1
- package/dist/lib/browser/{intent-resolver-YH4YPX52.mjs → intent-resolver-SNIAQ7V5.mjs} +8 -7
- package/dist/lib/browser/intent-resolver-SNIAQ7V5.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-GA67CQBV.mjs → react-surface-L22QIANU.mjs} +4 -4
- package/dist/lib/browser/{react-surface-GA67CQBV.mjs.map → react-surface-L22QIANU.mjs.map} +1 -1
- package/dist/lib/browser/types.mjs +1 -1
- package/dist/lib/node/{AutomationContainer-RIDHNHPT.cjs → AutomationContainer-E5I76FPP.cjs} +7 -7
- package/dist/lib/node/{AutomationPanel-6RLBWAGL.cjs → AutomationPanel-YLXAFJDP.cjs} +8 -8
- package/dist/lib/node/{AutomationPanel-6RLBWAGL.cjs.map → AutomationPanel-YLXAFJDP.cjs.map} +2 -2
- package/dist/lib/node/{FunctionsContainer-RNZTNQEU.cjs → FunctionsContainer-3HCURMEB.cjs} +6 -6
- package/dist/lib/node/{FunctionsPanel-7I7YCHPJ.cjs → FunctionsPanel-SYIZHPGU.cjs} +7 -7
- package/dist/lib/node/{FunctionsPanel-7I7YCHPJ.cjs.map → FunctionsPanel-SYIZHPGU.cjs.map} +2 -2
- package/dist/lib/node/{chunk-GLXGAIZC.cjs → chunk-BSK5SHTR.cjs} +9 -9
- package/dist/lib/node/chunk-BSK5SHTR.cjs.map +7 -0
- package/dist/lib/node/chunk-FTEDH5Q6.cjs +167 -0
- package/dist/lib/node/chunk-FTEDH5Q6.cjs.map +7 -0
- package/dist/lib/node/{chunk-HZTVNN4S.cjs → chunk-L5TWLPGA.cjs} +8 -8
- package/dist/lib/node/{chunk-GDCG2BML.cjs → chunk-PSIJDHAX.cjs} +19 -19
- package/dist/lib/node/chunk-PSIJDHAX.cjs.map +7 -0
- package/dist/lib/node/{chunk-52JFIUOD.cjs → chunk-SRXHHBDE.cjs} +18 -18
- package/dist/lib/node/chunk-SRXHHBDE.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-6FJ6PJJI.cjs → intent-resolver-A44BNFEG.cjs} +15 -14
- package/dist/lib/node/intent-resolver-A44BNFEG.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/{react-surface-UJDYSHZ5.cjs → react-surface-PCZCHIET.cjs} +11 -11
- package/dist/lib/node/react-surface-PCZCHIET.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-MCUWF267.mjs → AutomationContainer-22PUFPSE.mjs} +3 -3
- package/dist/lib/node-esm/{AutomationPanel-U34H2Q7Z.mjs → AutomationPanel-6UXIAJVS.mjs} +3 -3
- package/dist/lib/node-esm/{FunctionsContainer-435FW56J.mjs → FunctionsContainer-XG5WVAN3.mjs} +2 -2
- package/dist/lib/node-esm/{FunctionsPanel-NXXT5ERU.mjs → FunctionsPanel-J3QGUESH.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-VYSTWH6Q.mjs → chunk-4UPGANGV.mjs} +4 -4
- package/dist/lib/node-esm/chunk-4UPGANGV.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-WYXWQFPK.mjs → chunk-HMYAQLGF.mjs} +7 -7
- package/dist/lib/node-esm/chunk-HMYAQLGF.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-M4QXMIIB.mjs +139 -0
- package/dist/lib/node-esm/chunk-M4QXMIIB.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-RG3M42SO.mjs → chunk-TMMB5ETD.mjs} +5 -5
- package/dist/lib/node-esm/{chunk-EEA6CZ6B.mjs → chunk-YYBCQXB2.mjs} +16 -16
- package/dist/lib/node-esm/chunk-YYBCQXB2.mjs.map +7 -0
- 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-PVY22PBL.mjs → intent-resolver-JFLTVJ7D.mjs} +8 -7
- package/dist/lib/node-esm/intent-resolver-JFLTVJ7D.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-R72A4EHM.mjs → react-surface-VSO4NWC6.mjs} +4 -4
- package/dist/lib/node-esm/{react-surface-R72A4EHM.mjs.map → react-surface-VSO4NWC6.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/AutomationPanel/AutomationPanel.d.ts +1 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
- package/dist/types/src/components/FunctionsPanel/FunctionsPanel.d.ts.map +1 -1
- 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/package.json +24 -28
- package/src/AutomationPlugin.tsx +1 -1
- package/src/capabilities/intent-resolver.ts +7 -4
- package/src/capabilities/react-surface.tsx +1 -1
- package/src/components/AutomationPanel/AutomationPanel.stories.tsx +1 -1
- package/src/components/AutomationPanel/AutomationPanel.tsx +5 -6
- package/src/components/FunctionsPanel/FunctionsPanel.tsx +3 -3
- package/src/components/TriggerEditor/TriggerEditor.stories.tsx +6 -15
- package/src/components/TriggerEditor/TriggerEditor.tsx +89 -49
- package/src/testing/test-functions.ts +9 -23
- package/src/types.ts +10 -11
- package/dist/lib/browser/chunk-ADYCSC6Y.mjs +0 -39
- package/dist/lib/browser/chunk-ADYCSC6Y.mjs.map +0 -7
- package/dist/lib/browser/chunk-HTVXRMNH.mjs.map +0 -7
- package/dist/lib/browser/chunk-IDCVJ2JW.mjs.map +0 -7
- package/dist/lib/browser/chunk-Q2ACSERA.mjs +0 -211
- package/dist/lib/browser/chunk-Q2ACSERA.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-YH4YPX52.mjs.map +0 -7
- package/dist/lib/node/chunk-52JFIUOD.cjs.map +0 -7
- package/dist/lib/node/chunk-ESVJ2X6U.cjs +0 -234
- package/dist/lib/node/chunk-ESVJ2X6U.cjs.map +0 -7
- package/dist/lib/node/chunk-GDCG2BML.cjs.map +0 -7
- package/dist/lib/node/chunk-GLXGAIZC.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-6FJ6PJJI.cjs.map +0 -7
- package/dist/lib/node/react-surface-UJDYSHZ5.cjs.map +0 -7
- package/dist/lib/node-esm/chunk-5JC4JVYZ.mjs +0 -212
- package/dist/lib/node-esm/chunk-5JC4JVYZ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-EEA6CZ6B.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-VYSTWH6Q.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-WYXWQFPK.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-PVY22PBL.mjs.map +0 -7
- package/dist/types/src/components/TriggerEditor/FunctionPayloadEditor.d.ts +0 -12
- package/dist/types/src/components/TriggerEditor/FunctionPayloadEditor.d.ts.map +0 -1
- package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts +0 -5
- package/dist/types/src/components/TriggerEditor/SpecSelector.d.ts.map +0 -1
- package/src/components/TriggerEditor/FunctionPayloadEditor.tsx +0 -77
- package/src/components/TriggerEditor/SpecSelector.tsx +0 -59
- /package/dist/lib/browser/{AutomationContainer-3MP23OGQ.mjs.map → AutomationContainer-KEQ5RNIW.mjs.map} +0 -0
- /package/dist/lib/browser/{AutomationPanel-75HVBBNG.mjs.map → AutomationPanel-G3OB6ELR.mjs.map} +0 -0
- /package/dist/lib/browser/{FunctionsContainer-HLISW5QI.mjs.map → FunctionsContainer-STXBW4CX.mjs.map} +0 -0
- /package/dist/lib/browser/{FunctionsPanel-OKFRBXLO.mjs.map → FunctionsPanel-JJPLIAJW.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-N4PTKEWO.mjs.map → chunk-QJPKWYTL.mjs.map} +0 -0
- /package/dist/lib/node/{AutomationContainer-RIDHNHPT.cjs.map → AutomationContainer-E5I76FPP.cjs.map} +0 -0
- /package/dist/lib/node/{FunctionsContainer-RNZTNQEU.cjs.map → FunctionsContainer-3HCURMEB.cjs.map} +0 -0
- /package/dist/lib/node/{chunk-HZTVNN4S.cjs.map → chunk-L5TWLPGA.cjs.map} +0 -0
- /package/dist/lib/node-esm/{AutomationContainer-MCUWF267.mjs.map → AutomationContainer-22PUFPSE.mjs.map} +0 -0
- /package/dist/lib/node-esm/{AutomationPanel-U34H2Q7Z.mjs.map → AutomationPanel-6UXIAJVS.mjs.map} +0 -0
- /package/dist/lib/node-esm/{FunctionsContainer-435FW56J.mjs.map → FunctionsContainer-XG5WVAN3.mjs.map} +0 -0
- /package/dist/lib/node-esm/{FunctionsPanel-NXXT5ERU.mjs.map → FunctionsPanel-J3QGUESH.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-RG3M42SO.mjs.map → chunk-TMMB5ETD.mjs.map} +0 -0
|
@@ -1,234 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var chunk_ESVJ2X6U_exports = {};
|
|
30
|
-
__export(chunk_ESVJ2X6U_exports, {
|
|
31
|
-
TriggerEditor: () => TriggerEditor
|
|
32
|
-
});
|
|
33
|
-
module.exports = __toCommonJS(chunk_ESVJ2X6U_exports);
|
|
34
|
-
var import_chunk_7GXNXMSM = require("./chunk-7GXNXMSM.cjs");
|
|
35
|
-
var import_react = __toESM(require("react"));
|
|
36
|
-
var import_conductor = require("@dxos/conductor");
|
|
37
|
-
var import_echo = require("@dxos/echo");
|
|
38
|
-
var import_functions = require("@dxos/functions");
|
|
39
|
-
var import_echo2 = require("@dxos/react-client/echo");
|
|
40
|
-
var import_react_ui = require("@dxos/react-ui");
|
|
41
|
-
var import_react_ui_form = require("@dxos/react-ui-form");
|
|
42
|
-
var import_react2 = __toESM(require("react"));
|
|
43
|
-
var import_echo_schema = require("@dxos/echo-schema");
|
|
44
|
-
var import_react_ui2 = require("@dxos/react-ui");
|
|
45
|
-
var import_react_ui_form2 = require("@dxos/react-ui-form");
|
|
46
|
-
var import_react3 = __toESM(require("react"));
|
|
47
|
-
var import_functions2 = require("@dxos/functions");
|
|
48
|
-
var import_react_ui3 = require("@dxos/react-ui");
|
|
49
|
-
var import_react_ui_form3 = require("@dxos/react-ui-form");
|
|
50
|
-
var FunctionPayloadEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
|
|
51
|
-
const selectedFunctionValue = (0, import_react_ui_form2.useFormValues)([
|
|
52
|
-
"function"
|
|
53
|
-
]);
|
|
54
|
-
const selectedFunctionName = (0, import_react2.useMemo)(() => {
|
|
55
|
-
if (selectedFunctionValue instanceof import_echo_schema.RefImpl) {
|
|
56
|
-
return selectedFunctionValue.dxn.toString().split("dxn:worker:").at(1);
|
|
57
|
-
}
|
|
58
|
-
}, [
|
|
59
|
-
selectedFunctionValue
|
|
60
|
-
]);
|
|
61
|
-
const selectedFunction = (0, import_react2.useMemo)(() => functions.find((f) => f.name === selectedFunctionName), [
|
|
62
|
-
functions,
|
|
63
|
-
selectedFunctionName
|
|
64
|
-
]);
|
|
65
|
-
(0, import_react_ui2.useOnTransition)(
|
|
66
|
-
// Clear function parameter meta when the function changes.
|
|
67
|
-
selectedFunctionValue,
|
|
68
|
-
(prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
|
|
69
|
-
(currValue) => currValue !== void 0,
|
|
70
|
-
() => onValueChange("object", {})
|
|
71
|
-
);
|
|
72
|
-
const inputSchema = (0, import_react2.useMemo)(() => selectedFunction?.inputSchema, [
|
|
73
|
-
selectedFunction
|
|
74
|
-
]);
|
|
75
|
-
const effectSchema = (0, import_react2.useMemo)(() => inputSchema ? (0, import_echo_schema.toEffectSchema)(inputSchema) : void 0, [
|
|
76
|
-
inputSchema
|
|
77
|
-
]);
|
|
78
|
-
const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
|
|
79
|
-
const values = (0, import_react2.useMemo)(() => getValue() ?? {}, [
|
|
80
|
-
getValue
|
|
81
|
-
]);
|
|
82
|
-
const handleValuesChanged = (0, import_react2.useCallback)((values2) => {
|
|
83
|
-
onValueChange("object", values2);
|
|
84
|
-
}, [
|
|
85
|
-
onValueChange
|
|
86
|
-
]);
|
|
87
|
-
if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
|
|
88
|
-
return null;
|
|
89
|
-
}
|
|
90
|
-
return /* @__PURE__ */ import_react2.default.createElement(import_react2.default.Fragment, null, /* @__PURE__ */ import_react2.default.createElement("h3", {
|
|
91
|
-
className: "text-md"
|
|
92
|
-
}, "Function parameters"), /* @__PURE__ */ import_react2.default.createElement(import_react_ui_form2.Form, {
|
|
93
|
-
schema: effectSchema,
|
|
94
|
-
values,
|
|
95
|
-
classNames: "p-0",
|
|
96
|
-
onValuesChanged: handleValuesChanged,
|
|
97
|
-
onQueryRefOptions
|
|
98
|
-
}));
|
|
99
|
-
};
|
|
100
|
-
var SpecSelector = (props) => {
|
|
101
|
-
const { t } = (0, import_react_ui3.useTranslation)(import_chunk_7GXNXMSM.AUTOMATION_PLUGIN);
|
|
102
|
-
const specProps = (0, import_react_ui_form3.useInputProps)([
|
|
103
|
-
"spec"
|
|
104
|
-
]);
|
|
105
|
-
const handleTypeChange = (0, import_react3.useCallback)((_type, value) => {
|
|
106
|
-
const getDefaultTriggerSpec = (kind) => {
|
|
107
|
-
switch (kind) {
|
|
108
|
-
case import_functions2.TriggerKind.Timer:
|
|
109
|
-
return {
|
|
110
|
-
type: import_functions2.TriggerKind.Timer,
|
|
111
|
-
cron: ""
|
|
112
|
-
};
|
|
113
|
-
case import_functions2.TriggerKind.Subscription:
|
|
114
|
-
return {
|
|
115
|
-
type: import_functions2.TriggerKind.Subscription,
|
|
116
|
-
filter: {}
|
|
117
|
-
};
|
|
118
|
-
case import_functions2.TriggerKind.Queue:
|
|
119
|
-
return {
|
|
120
|
-
type: import_functions2.TriggerKind.Queue,
|
|
121
|
-
queue: ""
|
|
122
|
-
};
|
|
123
|
-
case import_functions2.TriggerKind.Email:
|
|
124
|
-
return {
|
|
125
|
-
type: import_functions2.TriggerKind.Email
|
|
126
|
-
};
|
|
127
|
-
case import_functions2.TriggerKind.Webhook:
|
|
128
|
-
return {
|
|
129
|
-
type: import_functions2.TriggerKind.Webhook
|
|
130
|
-
};
|
|
131
|
-
default:
|
|
132
|
-
return void 0;
|
|
133
|
-
}
|
|
134
|
-
};
|
|
135
|
-
const defaultSpec = getDefaultTriggerSpec(value);
|
|
136
|
-
if (!defaultSpec) {
|
|
137
|
-
return;
|
|
138
|
-
}
|
|
139
|
-
specProps.onValueChange("object", defaultSpec);
|
|
140
|
-
}, [
|
|
141
|
-
specProps
|
|
142
|
-
]);
|
|
143
|
-
const options = (0, import_react3.useMemo)(() => Object.values(import_functions2.TriggerKind).map((kind) => ({
|
|
144
|
-
value: kind,
|
|
145
|
-
label: t(`trigger type ${kind}`)
|
|
146
|
-
})), [
|
|
147
|
-
t
|
|
148
|
-
]);
|
|
149
|
-
return /* @__PURE__ */ import_react3.default.createElement(import_react_ui_form3.SelectInput, {
|
|
150
|
-
...props,
|
|
151
|
-
options,
|
|
152
|
-
onValueChange: handleTypeChange
|
|
153
|
-
});
|
|
154
|
-
};
|
|
155
|
-
var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
|
|
156
|
-
const { t } = (0, import_react_ui.useTranslation)(import_chunk_7GXNXMSM.AUTOMATION_PLUGIN);
|
|
157
|
-
const functions = (0, import_echo2.useQuery)(space, import_echo2.Filter.schema(import_functions.FunctionType));
|
|
158
|
-
const workflows = (0, import_echo2.useQuery)(space, import_echo2.Filter.schema(import_conductor.ComputeGraph));
|
|
159
|
-
const scripts = (0, import_echo2.useQuery)(space, import_echo2.Filter.schema(import_functions.ScriptType));
|
|
160
|
-
const handleSave = (values) => {
|
|
161
|
-
onSave?.(values);
|
|
162
|
-
};
|
|
163
|
-
const handleRefQueryLookup = (0, import_react_ui_form.useRefQueryLookupHandler)({
|
|
164
|
-
space
|
|
165
|
-
});
|
|
166
|
-
const Custom = (0, import_react.useMemo)(() => ({
|
|
167
|
-
["function"]: (props) => {
|
|
168
|
-
const getValue = (0, import_react.useCallback)(() => {
|
|
169
|
-
const formValue = props.getValue();
|
|
170
|
-
if (formValue instanceof import_echo.DXN) {
|
|
171
|
-
return formValue.toString();
|
|
172
|
-
}
|
|
173
|
-
return void 0;
|
|
174
|
-
}, [
|
|
175
|
-
props
|
|
176
|
-
]);
|
|
177
|
-
const handleOnValueChange = (0, import_react.useCallback)((_type, dxnString) => {
|
|
178
|
-
const dxn = import_echo.DXN.parse(dxnString);
|
|
179
|
-
if (dxn) {
|
|
180
|
-
const ref = import_echo2.Ref.fromDXN(dxn);
|
|
181
|
-
props.onValueChange("object", ref);
|
|
182
|
-
}
|
|
183
|
-
}, [
|
|
184
|
-
props.onValueChange
|
|
185
|
-
]);
|
|
186
|
-
return /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.SelectInput, {
|
|
187
|
-
...props,
|
|
188
|
-
getValue,
|
|
189
|
-
onValueChange: handleOnValueChange,
|
|
190
|
-
options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
|
|
191
|
-
});
|
|
192
|
-
},
|
|
193
|
-
["spec.type"]: SpecSelector,
|
|
194
|
-
["payload"]: (props) => /* @__PURE__ */ import_react.default.createElement(FunctionPayloadEditor, {
|
|
195
|
-
...props,
|
|
196
|
-
functions,
|
|
197
|
-
onQueryRefOptions: handleRefQueryLookup
|
|
198
|
-
})
|
|
199
|
-
}), [
|
|
200
|
-
workflows,
|
|
201
|
-
scripts,
|
|
202
|
-
functions,
|
|
203
|
-
t
|
|
204
|
-
]);
|
|
205
|
-
return /* @__PURE__ */ import_react.default.createElement("div", {
|
|
206
|
-
role: "none",
|
|
207
|
-
className: "bs-full is-full"
|
|
208
|
-
}, /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.Form, {
|
|
209
|
-
schema: import_functions.FunctionTriggerSchema,
|
|
210
|
-
values: trigger,
|
|
211
|
-
onSave: handleSave,
|
|
212
|
-
onCancel,
|
|
213
|
-
Custom,
|
|
214
|
-
onQueryRefOptions: handleRefQueryLookup
|
|
215
|
-
}));
|
|
216
|
-
};
|
|
217
|
-
var getWorkflowOptions = (graphs) => {
|
|
218
|
-
return graphs.map((graph) => ({
|
|
219
|
-
label: `compute-${graph.id}`,
|
|
220
|
-
value: `dxn:echo:@:${graph.id}`
|
|
221
|
-
}));
|
|
222
|
-
};
|
|
223
|
-
var getFunctionOptions = (scripts, functions) => {
|
|
224
|
-
const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
|
|
225
|
-
return functions.map((fn) => ({
|
|
226
|
-
label: getLabel(fn),
|
|
227
|
-
value: `dxn:worker:${fn.name}`
|
|
228
|
-
}));
|
|
229
|
-
};
|
|
230
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
231
|
-
0 && (module.exports = {
|
|
232
|
-
TriggerEditor
|
|
233
|
-
});
|
|
234
|
-
//# sourceMappingURL=chunk-ESVJ2X6U.cjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx", "../../../src/components/TriggerEditor/FunctionPayloadEditor.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 { FunctionPayloadEditor } from './FunctionPayloadEditor';\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 (formValue instanceof DXN) {\n return formValue.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.type' as const]: SpecSelector,\n ['payload' as const]: (props) => (\n <FunctionPayloadEditor {...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:worker:${fn.name}` }));\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 FunctionMetaEditorProps = {\n functions: FunctionType[];\n onQueryRefOptions: QueryRefOptions;\n} & FormInputStateProps;\n\n/**\n * Editor component for function meta parameters.\n */\nexport const FunctionPayloadEditor = ({\n functions,\n getValue,\n onValueChange,\n onQueryRefOptions,\n}: FunctionMetaEditorProps) => {\n const selectedFunctionValue = useFormValues(['function' as JsonPath]);\n const selectedFunctionName = useMemo(() => {\n if (selectedFunctionValue instanceof RefImpl) {\n return selectedFunctionValue.dxn.toString().split('dxn:worker:').at(1);\n }\n }, [selectedFunctionValue]);\n\n const selectedFunction = useMemo(\n () => functions.find((f) => f.name === selectedFunctionName),\n [functions, selectedFunctionName],\n );\n\n useOnTransition(\n // Clear function parameter meta 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": ["import_echo", "import_react", "import_react_ui", "import_react_ui_form", "import_functions", "FunctionPayloadEditor", "functions", "getValue", "onValueChange", "onQueryRefOptions", "selectedFunctionValue", "useFormValues", "selectedFunctionName", "useMemo", "RefImpl", "dxn", "toString", "split", "at", "selectedFunction", "find", "f", "name", "useOnTransition", "prevValue", "undefined", "currValue", "inputSchema", "effectSchema", "toEffectSchema", "propertyCount", "properties", "Object", "keys", "length", "values", "handleValuesChanged", "useCallback", "React", "h3", "className", "Form", "schema", "classNames", "onValuesChanged", "SpecSelector", "props", "t", "useTranslation", "AUTOMATION_PLUGIN", "specProps", "useInputProps", "handleTypeChange", "_type", "value", "getDefaultTriggerSpec", "kind", "TriggerKind", "Timer", "type", "cron", "Subscription", "filter", "Queue", "queue", "Email", "Webhook", "defaultSpec", "options", "map", "label", "SelectInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "useQuery", "Filter", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "handleSave", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "formValue", "DXN", "handleOnValueChange", "dxnString", "parse", "ref", "Ref", "fromDXN", "getWorkflowOptions", "concat", "getFunctionOptions", "div", "role", "FunctionTriggerSchema", "graphs", "graph", "id", "getLabel", "fn", "s", "source", "target"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
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,oBAAuB;AAEvB,kBAA4B;AAI5B,IAAMA,kBAAkBC,qBAAOC,MAC7BD,qBAAOE,OAAO;EAAEC,MAAMH,qBAAOI,QAAQ,OAAA;EAAUC,MAAML,qBAAOM;AAAO,CAAA,GACnEN,qBAAOE,OAAO;EAAEC,MAAMH,qBAAOI,QAAQ,OAAA;EAAUG,UAAUP,qBAAOQ;AAAI,CAAA,CAAA;;UAGrDC,mBAAAA;AACf,QAAMC,oBAAoB,GAAGC,uCAAAA;EAEtB,MAAMC,kCAAkCZ,qBAAOa,YAAW,EAC/D,GAAGH,iBAAAA,iCACH;IACEI,OAAOd,qBAAOE,OAAO;MACnBa,OAAOC;MACPC,UAAUlB;MACVmB,SAASlB,qBAAOmB,SAASnB,qBAAOoB,OAAO;;MAEvCC,YAAYrB,qBAAOmB,SAASnB,qBAAOM,MAAM;MACzCQ,OAAOd,qBAAOmB,SAASnB,qBAAOsB,OAAO;QAAEC,KAAKvB,qBAAOM;QAAQkB,OAAOxB,qBAAOQ;MAAI,CAAA,CAAA;IAC/E,CAAA;IACAiB,QAAQzB,qBAAO0B;EACjB,CAAA,EAAA;EACC;oBAbUd,4BAAAA;AAcf,GAjBiBH,qBAAAA,mBAAAA,CAAAA,EAAAA;",
|
|
6
|
-
"names": ["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,7 +0,0 @@
|
|
|
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,oBAAuB;AACvB,mBAA4C;AAE5C,2BAAgE;AAChE,uBAAyC;AACzC,kBAA+D;AAC/D,sBAAuC;AACvC,2BAAmC;AACnC,2BAAqB;AACrB,4BAA+B;AAI/B,IAAMA,OAAO;AAMN,IAAMC,iBAAiB,CAAC,EAAEC,MAAK,MAAuB;AAC3D,QAAM,EAAEC,EAAC,QAAKC,gCAAeC,uCAAAA;AAC7B,QAAMC,gBAAYC,sBAASL,OAAOM,mBAAOC,OAAOC,6BAAAA,CAAAA;AAChD,QAAMC,cAAUJ,sBAASL,OAAOM,mBAAOC,OAAOG,2BAAAA,CAAAA;AAC9C,QAAM,EAAEC,iBAAiBC,SAAQ,QAAKC,0CAAAA;AAEtC,QAAMC,0BAAsBC,sBAC1B,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,oBAAgBC,0BACpB,CAACT,SAAAA;AACC,UAAMK,SAAST,oBAAoBI,KAAKI,EAAE;AAC1C,WAAOC,QAAQK;EACjB,GACA;IAACd;GAAoB;AAGvB,QAAMe,uBAAmBF,0BACvB,CAACT,SAAAA;AACC,UAAMK,SAAST,oBAAoBI,KAAKI,EAAE;AAC1C,QAAIC,QAAQ;AACV,WAAKX,aAASkB,mCAAaC,kCAAaC,MAAM;QAAEC,MAAM;QAAQC,SAAS;cAACC,8BAAiBZ,MAAAA;;MAAS,CAAA,CAAA;IACpG;EACF,GACA;IAACT;IAAqBF;GAAS;AAGjC,SACE,6BAAAwB,QAAA,cAACC,OAAAA;IAAIC,MAAK;IAAOC,eAAWC,0BAAGC,uCAAAA;KAC7B,6BAAAL,QAAA,cAACM,0BAAKC,MAAI;IAAeC,OAAOxC;IAAWyC,QAAQC,qBAAOC,GAAGvC,6BAAAA;IAAewC,OAAO,CAAC9B,SAASA,KAAKI;KAC/F,CAAC,EAAEsB,MAAK,MACP,6BAAAR,QAAA,cAACC,OAAAA;IAAIC,MAAK;IAAOC,WAAU;KACxBK,OAAO3B,IAAI,CAACC,SACX,6BAAAkB,QAAA,cAACM,0BAAKO,MAAI;IACRC,KAAKhC,KAAKI;IACV6B,MAAMjC;IACNkC,gBAAYZ,0BAAG1C,MAAMuD,kCAAY,gBAAgB,SAAS,eAAA;KAE1D,6BAAAjB,QAAA,cAACC,OAAAA;IAAIE,WAAU;KACb,6BAAAH,QAAA,cAACM,0BAAKY,WAAS;IAACF,YAAW;KAAYlC,KAAKU,IAAI,GAC/CF,cAAcR,IAAAA,KACb,6BAAAkB,QAAA,cAACC,OAAAA;IAAIE,WAAU;KAAqCb,cAAcR,IAAAA,CAAAA,CAAAA,GAGrEJ,oBAAoBI,KAAKI,EAAE,KAC1B,6BAAAc,QAAA,cAACmB,wBAAAA;IAAOC,SAAS,MAAM3B,iBAAiBX,IAAAA;KAAQjB,EAAE,oCAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAQ7DG,UAAUqD,WAAW,KAAK,6BAAArB,QAAA,cAACC,OAAAA;IAAIE,WAAU;KAAmCtC,EAAE,oBAAA,CAAA,CAAA;AAGrF;ACvFA,IAAA,yBAAeF;",
|
|
6
|
-
"names": ["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", "React", "div", "role", "className", "mx", "controlItemClasses", "List", "Root", "items", "isItem", "Schema", "is", "getId", "Item", "key", "item", "classNames", "ghostHover", "ItemTitle", "Button", "onClick", "length"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/intent-resolver.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport {\n contributes,\n Capabilities,\n createResolver,\n type PluginsContext,\n createIntent,\n LayoutAction,\n} from '@dxos/app-framework';\nimport { Type } from '@dxos/echo';\nimport { FunctionTrigger, FunctionType, ScriptType, TriggerKind } from '@dxos/functions';\nimport { type DXN } from '@dxos/keys';\nimport { live } from '@dxos/live-object';\nimport { ATTENDABLE_PATH_SEPARATOR } from '@dxos/plugin-deck/types';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { Filter } from '@dxos/react-client/echo';\n\nimport { AutomationAction } from '../types';\n\nexport default (context: PluginsContext) =>\n contributes(Capabilities.IntentResolver, [\n createResolver({\n intent: AutomationAction.CreateTriggerFromTemplate,\n resolve: async ({ space, template, enabled = false, scriptName, input }) => {\n const trigger = live(FunctionTrigger, { enabled, input });\n\n // TODO(wittjosiah): Factor out function lookup by script name?\n if (scriptName) {\n const {\n objects: [script],\n } = await space.db.query(Filter.schema(ScriptType, { name: scriptName })).run();\n if (script) {\n const {\n objects: [fn],\n } = await space.db.query(Filter.schema(FunctionType, { source: script })).run();\n if (fn) {\n trigger.function = Type.ref(fn);\n }\n }\n }\n\n switch (template.type) {\n case 'timer': {\n trigger.spec = { type: TriggerKind.Timer, cron: template.cron };\n break;\n }\n case 'queue': {\n trigger.spec = { type: TriggerKind.Queue, queue: (template.queueDXN as DXN).toString() };\n break;\n }\n default: {\n break;\n }\n }\n\n return {\n intents: [\n createIntent(SpaceAction.AddObject, { object: trigger, target: space }),\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [`automation-settings${ATTENDABLE_PATH_SEPARATOR}${space.id}`],\n options: {\n workspace: space.id,\n },\n }),\n ],\n };\n },\n }),\n ]);\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAIA,2BAOO;AACP,kBAAqB;AACrB,uBAAuE;AAEvE,yBAAqB;AACrB,mBAA0C;AAC1C,IAAAA,gBAA4B;AAC5B,IAAAC,eAAuB;AAIvB,IAAA,0BAAe,CAACC,gBACdC,kCAAYC,kCAAaC,gBAAgB;MACvCC,qCAAe;IACbC,QAAQC,uCAAiBC;IACzBC,SAAS,OAAO,EAAEC,OAAOC,UAAUC,UAAU,OAAOC,YAAYC,MAAK,MAAE;AACrE,YAAMC,cAAUC,yBAAKC,kCAAiB;QAAEL;QAASE;MAAM,CAAA;AAGvD,UAAID,YAAY;AACd,cAAM,EACJK,SAAS,CAACC,MAAAA,EAAO,IACf,MAAMT,MAAMU,GAAGC,MAAMC,oBAAOC,OAAOC,6BAAY;UAAEC,MAAMZ;QAAW,CAAA,CAAA,EAAIa,IAAG;AAC7E,YAAIP,QAAQ;AACV,gBAAM,EACJD,SAAS,CAACS,EAAAA,EAAG,IACX,MAAMjB,MAAMU,GAAGC,MAAMC,oBAAOC,OAAOK,+BAAc;YAAEC,QAAQV;UAAO,CAAA,CAAA,EAAIO,IAAG;AAC7E,cAAIC,IAAI;AACNZ,oBAAQe,WAAWC,iBAAKC,IAAIL,EAAAA;UAC9B;QACF;MACF;AAEA,cAAQhB,SAASsB,MAAI;QACnB,KAAK,SAAS;AACZlB,kBAAQmB,OAAO;YAAED,MAAME,6BAAYC;YAAOC,MAAM1B,SAAS0B;UAAK;AAC9D;QACF;QACA,KAAK,SAAS;AACZtB,kBAAQmB,OAAO;YAAED,MAAME,6BAAYG;YAAOC,OAAQ5B,SAAS6B,SAAiBC,SAAQ;UAAG;AACvF;QACF;QACA,SAAS;AACP;QACF;MACF;AAEA,aAAO;QACLC,SAAS;cACPC,mCAAaC,0BAAYC,WAAW;YAAEC,QAAQ/B;YAASgC,QAAQrC;UAAM,CAAA;cACrEiC,mCAAaK,kCAAaC,MAAM;YAC9BC,MAAM;YACNC,SAAS;cAAC,sBAAsBC,sCAAAA,GAA4B1C,MAAM2C,EAAE;;YACpEC,SAAS;cACPC,WAAW7C,MAAM2C;YACnB;UACF,CAAA;;MAEJ;IACF;EACF,CAAA;CACD;",
|
|
6
|
-
"names": ["import_types", "import_echo", "context", "contributes", "Capabilities", "IntentResolver", "createResolver", "intent", "AutomationAction", "CreateTriggerFromTemplate", "resolve", "space", "template", "enabled", "scriptName", "input", "trigger", "live", "FunctionTrigger", "objects", "script", "db", "query", "Filter", "schema", "ScriptType", "name", "run", "fn", "FunctionType", "source", "function", "Type", "ref", "type", "spec", "TriggerKind", "Timer", "cron", "Queue", "queue", "queueDXN", "toString", "intents", "createIntent", "SpaceAction", "AddObject", "object", "target", "LayoutAction", "Open", "part", "subject", "ATTENDABLE_PATH_SEPARATOR", "id", "options", "workspace"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/react-surface.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, contributes, createSurface, useLayout } from '@dxos/app-framework';\nimport { isInstanceOf } from '@dxos/echo-schema';\nimport { ScriptType } from '@dxos/functions';\nimport { getSpace, parseId, useSpace } from '@dxos/react-client/echo';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { AutomationContainer, AutomationPanel, FunctionsContainer } from '../components';\nimport { meta } from '../meta';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: `${meta.id}/space-settings-automation`,\n role: 'article',\n filter: (data): data is { subject: string } => data.subject === `${meta.id}/space-settings-automation`,\n component: () => {\n const layout = useLayout();\n const { spaceId } = parseId(layout.workspace);\n const space = useSpace(spaceId);\n if (!space || !spaceId) {\n return null;\n }\n\n return <AutomationContainer space={space} />;\n },\n }),\n createSurface({\n id: `${meta.id}/space-settings-functions`,\n role: 'article',\n filter: (data): data is { subject: string } => data.subject === `${meta.id}/space-settings-functions`,\n component: () => {\n const layout = useLayout();\n const { spaceId } = parseId(layout.workspace);\n const space = useSpace(spaceId);\n if (!space || !spaceId) {\n return null;\n }\n\n return <FunctionsContainer space={space} />;\n },\n }),\n createSurface({\n id: `${meta.id}/companion/automation`,\n role: 'article',\n filter: (data): data is { companionTo: ScriptType; subject: 'automation' } =>\n isInstanceOf(ScriptType, data.companionTo) && data.subject === 'automation',\n component: ({ data, role }) => {\n return (\n <StackItem.Content role={role}>\n <AutomationPanel space={getSpace(data.companionTo)!} object={data.companionTo} />\n </StackItem.Content>\n );\n },\n }),\n ]);\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,mBAAkB;AAElB,2BAAoE;AACpE,yBAA6B;AAC7B,uBAA2B;AAC3B,kBAA4C;AAC5C,4BAA0B;AAK1B,IAAA,wBAAe,UACbA,kCAAYC,kCAAaC,cAAc;MACrCC,oCAAc;IACZC,IAAI,GAAGC,2BAAKD,EAAE;IACdE,MAAM;IACNC,QAAQ,CAACC,SAAsCA,KAAKC,YAAY,GAAGJ,2BAAKD,EAAE;IAC1EM,WAAW,MAAA;AACT,YAAMC,aAASC,gCAAAA;AACf,YAAM,EAAEC,QAAO,QAAKC,qBAAQH,OAAOI,SAAS;AAC5C,YAAMC,YAAQC,sBAASJ,OAAAA;AACvB,UAAI,CAACG,SAAS,CAACH,SAAS;AACtB,eAAO;MACT;AAEA,aAAO,6BAAAK,QAAA,cAACC,2CAAAA;QAAoBH;;IAC9B;EACF,CAAA;MACAb,oCAAc;IACZC,IAAI,GAAGC,2BAAKD,EAAE;IACdE,MAAM;IACNC,QAAQ,CAACC,SAAsCA,KAAKC,YAAY,GAAGJ,2BAAKD,EAAE;IAC1EM,WAAW,MAAA;AACT,YAAMC,aAASC,gCAAAA;AACf,YAAM,EAAEC,QAAO,QAAKC,qBAAQH,OAAOI,SAAS;AAC5C,YAAMC,YAAQC,sBAASJ,OAAAA;AACvB,UAAI,CAACG,SAAS,CAACH,SAAS;AACtB,eAAO;MACT;AAEA,aAAO,6BAAAK,QAAA,cAACE,0CAAAA;QAAmBJ;;IAC7B;EACF,CAAA;MACAb,oCAAc;IACZC,IAAI,GAAGC,2BAAKD,EAAE;IACdE,MAAM;IACNC,QAAQ,CAACC,aACPa,iCAAaC,6BAAYd,KAAKe,WAAW,KAAKf,KAAKC,YAAY;IACjEC,WAAW,CAAC,EAAEF,MAAMF,KAAI,MAAE;AACxB,aACE,6BAAAY,QAAA,cAACM,gCAAUC,SAAO;QAACnB;SACjB,6BAAAY,QAAA,cAACQ,uCAAAA;QAAgBV,WAAOW,sBAASnB,KAAKe,WAAW;QAAIK,QAAQpB,KAAKe;;IAGxE;EACF,CAAA;CACD;",
|
|
6
|
-
"names": ["contributes", "Capabilities", "ReactSurface", "createSurface", "id", "meta", "role", "filter", "data", "subject", "component", "layout", "useLayout", "spaceId", "parseId", "workspace", "space", "useSpace", "React", "AutomationContainer", "FunctionsContainer", "isInstanceOf", "ScriptType", "companionTo", "StackItem", "Content", "AutomationPanel", "getSpace", "object"]
|
|
7
|
-
}
|
|
@@ -1,212 +0,0 @@
|
|
|
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 React3, { useCallback as useCallback3, useMemo as useMemo3 } from "react";
|
|
8
|
-
import { ComputeGraph } from "@dxos/conductor";
|
|
9
|
-
import { DXN } from "@dxos/echo";
|
|
10
|
-
import { FunctionType, FunctionTriggerSchema, ScriptType } from "@dxos/functions";
|
|
11
|
-
import { Filter, Ref, useQuery } from "@dxos/react-client/echo";
|
|
12
|
-
import { useTranslation as useTranslation2 } from "@dxos/react-ui";
|
|
13
|
-
import { Form as Form2, SelectInput as SelectInput2, useRefQueryLookupHandler } from "@dxos/react-ui-form";
|
|
14
|
-
|
|
15
|
-
// packages/plugins/plugin-automation/src/components/TriggerEditor/FunctionPayloadEditor.tsx
|
|
16
|
-
import React, { useCallback, useMemo } from "react";
|
|
17
|
-
import { RefImpl, toEffectSchema } from "@dxos/echo-schema";
|
|
18
|
-
import { useOnTransition } from "@dxos/react-ui";
|
|
19
|
-
import { Form, useFormValues } from "@dxos/react-ui-form";
|
|
20
|
-
var FunctionPayloadEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
|
|
21
|
-
const selectedFunctionValue = useFormValues([
|
|
22
|
-
"function"
|
|
23
|
-
]);
|
|
24
|
-
const selectedFunctionName = useMemo(() => {
|
|
25
|
-
if (selectedFunctionValue instanceof RefImpl) {
|
|
26
|
-
return selectedFunctionValue.dxn.toString().split("dxn:worker:").at(1);
|
|
27
|
-
}
|
|
28
|
-
}, [
|
|
29
|
-
selectedFunctionValue
|
|
30
|
-
]);
|
|
31
|
-
const selectedFunction = useMemo(() => functions.find((f) => f.name === selectedFunctionName), [
|
|
32
|
-
functions,
|
|
33
|
-
selectedFunctionName
|
|
34
|
-
]);
|
|
35
|
-
useOnTransition(
|
|
36
|
-
// Clear function parameter meta when the function changes.
|
|
37
|
-
selectedFunctionValue,
|
|
38
|
-
(prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
|
|
39
|
-
(currValue) => currValue !== void 0,
|
|
40
|
-
() => onValueChange("object", {})
|
|
41
|
-
);
|
|
42
|
-
const inputSchema = useMemo(() => selectedFunction?.inputSchema, [
|
|
43
|
-
selectedFunction
|
|
44
|
-
]);
|
|
45
|
-
const effectSchema = useMemo(() => inputSchema ? toEffectSchema(inputSchema) : void 0, [
|
|
46
|
-
inputSchema
|
|
47
|
-
]);
|
|
48
|
-
const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
|
|
49
|
-
const values = useMemo(() => getValue() ?? {}, [
|
|
50
|
-
getValue
|
|
51
|
-
]);
|
|
52
|
-
const handleValuesChanged = useCallback((values2) => {
|
|
53
|
-
onValueChange("object", values2);
|
|
54
|
-
}, [
|
|
55
|
-
onValueChange
|
|
56
|
-
]);
|
|
57
|
-
if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
|
|
58
|
-
return null;
|
|
59
|
-
}
|
|
60
|
-
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("h3", {
|
|
61
|
-
className: "text-md"
|
|
62
|
-
}, "Function parameters"), /* @__PURE__ */ React.createElement(Form, {
|
|
63
|
-
schema: effectSchema,
|
|
64
|
-
values,
|
|
65
|
-
classNames: "p-0",
|
|
66
|
-
onValuesChanged: handleValuesChanged,
|
|
67
|
-
onQueryRefOptions
|
|
68
|
-
}));
|
|
69
|
-
};
|
|
70
|
-
|
|
71
|
-
// packages/plugins/plugin-automation/src/components/TriggerEditor/SpecSelector.tsx
|
|
72
|
-
import React2, { useCallback as useCallback2, useMemo as useMemo2 } from "react";
|
|
73
|
-
import { TriggerKind } from "@dxos/functions";
|
|
74
|
-
import { useTranslation } from "@dxos/react-ui";
|
|
75
|
-
import { SelectInput, useInputProps } from "@dxos/react-ui-form";
|
|
76
|
-
var SpecSelector = (props) => {
|
|
77
|
-
const { t } = useTranslation(AUTOMATION_PLUGIN);
|
|
78
|
-
const specProps = useInputProps([
|
|
79
|
-
"spec"
|
|
80
|
-
]);
|
|
81
|
-
const handleTypeChange = useCallback2((_type, value) => {
|
|
82
|
-
const getDefaultTriggerSpec = (kind) => {
|
|
83
|
-
switch (kind) {
|
|
84
|
-
case TriggerKind.Timer:
|
|
85
|
-
return {
|
|
86
|
-
type: TriggerKind.Timer,
|
|
87
|
-
cron: ""
|
|
88
|
-
};
|
|
89
|
-
case TriggerKind.Subscription:
|
|
90
|
-
return {
|
|
91
|
-
type: TriggerKind.Subscription,
|
|
92
|
-
filter: {}
|
|
93
|
-
};
|
|
94
|
-
case TriggerKind.Queue:
|
|
95
|
-
return {
|
|
96
|
-
type: TriggerKind.Queue,
|
|
97
|
-
queue: ""
|
|
98
|
-
};
|
|
99
|
-
case TriggerKind.Email:
|
|
100
|
-
return {
|
|
101
|
-
type: TriggerKind.Email
|
|
102
|
-
};
|
|
103
|
-
case TriggerKind.Webhook:
|
|
104
|
-
return {
|
|
105
|
-
type: TriggerKind.Webhook
|
|
106
|
-
};
|
|
107
|
-
default:
|
|
108
|
-
return void 0;
|
|
109
|
-
}
|
|
110
|
-
};
|
|
111
|
-
const defaultSpec = getDefaultTriggerSpec(value);
|
|
112
|
-
if (!defaultSpec) {
|
|
113
|
-
return;
|
|
114
|
-
}
|
|
115
|
-
specProps.onValueChange("object", defaultSpec);
|
|
116
|
-
}, [
|
|
117
|
-
specProps
|
|
118
|
-
]);
|
|
119
|
-
const options = useMemo2(() => Object.values(TriggerKind).map((kind) => ({
|
|
120
|
-
value: kind,
|
|
121
|
-
label: t(`trigger type ${kind}`)
|
|
122
|
-
})), [
|
|
123
|
-
t
|
|
124
|
-
]);
|
|
125
|
-
return /* @__PURE__ */ React2.createElement(SelectInput, {
|
|
126
|
-
...props,
|
|
127
|
-
options,
|
|
128
|
-
onValueChange: handleTypeChange
|
|
129
|
-
});
|
|
130
|
-
};
|
|
131
|
-
|
|
132
|
-
// packages/plugins/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
|
|
133
|
-
var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
|
|
134
|
-
const { t } = useTranslation2(AUTOMATION_PLUGIN);
|
|
135
|
-
const functions = useQuery(space, Filter.schema(FunctionType));
|
|
136
|
-
const workflows = useQuery(space, Filter.schema(ComputeGraph));
|
|
137
|
-
const scripts = useQuery(space, Filter.schema(ScriptType));
|
|
138
|
-
const handleSave = (values) => {
|
|
139
|
-
onSave?.(values);
|
|
140
|
-
};
|
|
141
|
-
const handleRefQueryLookup = useRefQueryLookupHandler({
|
|
142
|
-
space
|
|
143
|
-
});
|
|
144
|
-
const Custom = useMemo3(() => ({
|
|
145
|
-
["function"]: (props) => {
|
|
146
|
-
const getValue = useCallback3(() => {
|
|
147
|
-
const formValue = props.getValue();
|
|
148
|
-
if (formValue instanceof DXN) {
|
|
149
|
-
return formValue.toString();
|
|
150
|
-
}
|
|
151
|
-
return void 0;
|
|
152
|
-
}, [
|
|
153
|
-
props
|
|
154
|
-
]);
|
|
155
|
-
const handleOnValueChange = useCallback3((_type, dxnString) => {
|
|
156
|
-
const dxn = DXN.parse(dxnString);
|
|
157
|
-
if (dxn) {
|
|
158
|
-
const ref = Ref.fromDXN(dxn);
|
|
159
|
-
props.onValueChange("object", ref);
|
|
160
|
-
}
|
|
161
|
-
}, [
|
|
162
|
-
props.onValueChange
|
|
163
|
-
]);
|
|
164
|
-
return /* @__PURE__ */ React3.createElement(SelectInput2, {
|
|
165
|
-
...props,
|
|
166
|
-
getValue,
|
|
167
|
-
onValueChange: handleOnValueChange,
|
|
168
|
-
options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
|
|
169
|
-
});
|
|
170
|
-
},
|
|
171
|
-
["spec.type"]: SpecSelector,
|
|
172
|
-
["payload"]: (props) => /* @__PURE__ */ React3.createElement(FunctionPayloadEditor, {
|
|
173
|
-
...props,
|
|
174
|
-
functions,
|
|
175
|
-
onQueryRefOptions: handleRefQueryLookup
|
|
176
|
-
})
|
|
177
|
-
}), [
|
|
178
|
-
workflows,
|
|
179
|
-
scripts,
|
|
180
|
-
functions,
|
|
181
|
-
t
|
|
182
|
-
]);
|
|
183
|
-
return /* @__PURE__ */ React3.createElement("div", {
|
|
184
|
-
role: "none",
|
|
185
|
-
className: "bs-full is-full"
|
|
186
|
-
}, /* @__PURE__ */ React3.createElement(Form2, {
|
|
187
|
-
schema: FunctionTriggerSchema,
|
|
188
|
-
values: trigger,
|
|
189
|
-
onSave: handleSave,
|
|
190
|
-
onCancel,
|
|
191
|
-
Custom,
|
|
192
|
-
onQueryRefOptions: handleRefQueryLookup
|
|
193
|
-
}));
|
|
194
|
-
};
|
|
195
|
-
var getWorkflowOptions = (graphs) => {
|
|
196
|
-
return graphs.map((graph) => ({
|
|
197
|
-
label: `compute-${graph.id}`,
|
|
198
|
-
value: `dxn:echo:@:${graph.id}`
|
|
199
|
-
}));
|
|
200
|
-
};
|
|
201
|
-
var getFunctionOptions = (scripts, functions) => {
|
|
202
|
-
const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
|
|
203
|
-
return functions.map((fn) => ({
|
|
204
|
-
label: getLabel(fn),
|
|
205
|
-
value: `dxn:worker:${fn.name}`
|
|
206
|
-
}));
|
|
207
|
-
};
|
|
208
|
-
|
|
209
|
-
export {
|
|
210
|
-
TriggerEditor
|
|
211
|
-
};
|
|
212
|
-
//# sourceMappingURL=chunk-5JC4JVYZ.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx", "../../../src/components/TriggerEditor/FunctionPayloadEditor.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 { FunctionPayloadEditor } from './FunctionPayloadEditor';\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 (formValue instanceof DXN) {\n return formValue.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.type' as const]: SpecSelector,\n ['payload' as const]: (props) => (\n <FunctionPayloadEditor {...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:worker:${fn.name}` }));\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 FunctionMetaEditorProps = {\n functions: FunctionType[];\n onQueryRefOptions: QueryRefOptions;\n} & FormInputStateProps;\n\n/**\n * Editor component for function meta parameters.\n */\nexport const FunctionPayloadEditor = ({\n functions,\n getValue,\n onValueChange,\n onQueryRefOptions,\n}: FunctionMetaEditorProps) => {\n const selectedFunctionValue = useFormValues(['function' as JsonPath]);\n const selectedFunctionName = useMemo(() => {\n if (selectedFunctionValue instanceof RefImpl) {\n return selectedFunctionValue.dxn.toString().split('dxn:worker:').at(1);\n }\n }, [selectedFunctionValue]);\n\n const selectedFunction = useMemo(\n () => functions.find((f) => f.name === selectedFunctionName),\n [functions, selectedFunctionName],\n );\n\n useOnTransition(\n // Clear function parameter meta 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", "FunctionPayloadEditor", "functions", "getValue", "onValueChange", "onQueryRefOptions", "selectedFunctionValue", "useFormValues", "selectedFunctionName", "useMemo", "RefImpl", "dxn", "toString", "split", "at", "selectedFunction", "find", "f", "name", "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", "DXN", "toString", "undefined", "handleOnValueChange", "_type", "dxnString", "dxn", "parse", "ref", "Ref", "fromDXN", "onValueChange", "React", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "SpecSelector", "FunctionPayloadEditor", "onQueryRefOptions", "div", "role", "className", "Form", "FunctionTriggerSchema", "graphs", "map", "graph", "label", "id", "value", "getLabel", "fn", "find", "s", "source", "target", "name"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
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,7 +0,0 @@
|
|
|
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
|
-
}
|