@dxos/plugin-automation 0.8.2-main.2f9c567 → 0.8.2-main.30e4dbb
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-PDPL34DX.mjs} +3 -3
- package/dist/lib/browser/{AutomationPanel-75HVBBNG.mjs → AutomationPanel-3WG2B7JM.mjs} +3 -3
- package/dist/lib/browser/{chunk-N4PTKEWO.mjs → chunk-GUPG3Q72.mjs} +3 -3
- package/dist/lib/browser/{chunk-HTVXRMNH.mjs → chunk-QFIPNCNF.mjs} +4 -4
- package/dist/lib/browser/{chunk-HTVXRMNH.mjs.map → chunk-QFIPNCNF.mjs.map} +2 -2
- package/dist/lib/browser/{chunk-Q2ACSERA.mjs → chunk-W4T2BTH2.mjs} +13 -13
- package/dist/lib/browser/chunk-W4T2BTH2.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +4 -4
- package/dist/lib/browser/{intent-resolver-YH4YPX52.mjs → intent-resolver-TCUIVOEW.mjs} +3 -3
- package/dist/lib/browser/{intent-resolver-YH4YPX52.mjs.map → intent-resolver-TCUIVOEW.mjs.map} +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-GA67CQBV.mjs → react-surface-P65PEZPN.mjs} +3 -3
- package/dist/lib/node/{AutomationContainer-RIDHNHPT.cjs → AutomationContainer-EXTHQ7B3.cjs} +7 -7
- package/dist/lib/node/{AutomationPanel-6RLBWAGL.cjs → AutomationPanel-G7R6RL7O.cjs} +8 -8
- package/dist/lib/node/{AutomationPanel-6RLBWAGL.cjs.map → AutomationPanel-G7R6RL7O.cjs.map} +2 -2
- package/dist/lib/node/{chunk-ESVJ2X6U.cjs → chunk-A4DMUH7U.cjs} +15 -15
- package/dist/lib/node/chunk-A4DMUH7U.cjs.map +7 -0
- package/dist/lib/node/{chunk-HZTVNN4S.cjs → chunk-B3OL2E3B.cjs} +6 -6
- package/dist/lib/node/{chunk-52JFIUOD.cjs → chunk-F74YVA6P.cjs} +8 -8
- package/dist/lib/node/{chunk-52JFIUOD.cjs.map → chunk-F74YVA6P.cjs.map} +2 -2
- package/dist/lib/node/index.cjs +9 -9
- package/dist/lib/node/{intent-resolver-6FJ6PJJI.cjs → intent-resolver-6XS2NYC7.cjs} +6 -6
- package/dist/lib/node/{intent-resolver-6FJ6PJJI.cjs.map → intent-resolver-6XS2NYC7.cjs.map} +3 -3
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/{react-surface-UJDYSHZ5.cjs → react-surface-OYJMJXJI.cjs} +9 -9
- package/dist/lib/node-esm/{AutomationContainer-MCUWF267.mjs → AutomationContainer-FSWEGDKP.mjs} +3 -3
- package/dist/lib/node-esm/{AutomationPanel-U34H2Q7Z.mjs → AutomationPanel-LIPLJA55.mjs} +3 -3
- package/dist/lib/node-esm/{chunk-WYXWQFPK.mjs → chunk-27IHWHDH.mjs} +4 -4
- package/dist/lib/node-esm/{chunk-WYXWQFPK.mjs.map → chunk-27IHWHDH.mjs.map} +2 -2
- package/dist/lib/node-esm/{chunk-5JC4JVYZ.mjs → chunk-IS3BYE3I.mjs} +13 -13
- package/dist/lib/node-esm/chunk-IS3BYE3I.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-RG3M42SO.mjs → chunk-YCNX76NJ.mjs} +3 -3
- package/dist/lib/node-esm/index.mjs +4 -4
- package/dist/lib/node-esm/{intent-resolver-PVY22PBL.mjs → intent-resolver-CHDYUFFN.mjs} +3 -3
- package/dist/lib/node-esm/{intent-resolver-PVY22PBL.mjs.map → intent-resolver-CHDYUFFN.mjs.map} +3 -3
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-R72A4EHM.mjs → react-surface-FDGQORLY.mjs} +3 -3
- 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.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.map +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +26 -26
- package/src/capabilities/intent-resolver.ts +2 -2
- package/src/components/AutomationPanel/AutomationPanel.stories.tsx +1 -1
- package/src/components/AutomationPanel/AutomationPanel.tsx +2 -2
- package/src/components/TriggerEditor/{FunctionPayloadEditor.tsx → FunctionInputEditor.tsx} +9 -9
- package/src/components/TriggerEditor/TriggerEditor.stories.tsx +2 -2
- package/src/components/TriggerEditor/TriggerEditor.tsx +7 -7
- package/dist/lib/browser/chunk-Q2ACSERA.mjs.map +0 -7
- package/dist/lib/node/chunk-ESVJ2X6U.cjs.map +0 -7
- package/dist/lib/node-esm/chunk-5JC4JVYZ.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/lib/browser/{AutomationContainer-3MP23OGQ.mjs.map → AutomationContainer-PDPL34DX.mjs.map} +0 -0
- /package/dist/lib/browser/{AutomationPanel-75HVBBNG.mjs.map → AutomationPanel-3WG2B7JM.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-N4PTKEWO.mjs.map → chunk-GUPG3Q72.mjs.map} +0 -0
- /package/dist/lib/browser/{react-surface-GA67CQBV.mjs.map → react-surface-P65PEZPN.mjs.map} +0 -0
- /package/dist/lib/node/{AutomationContainer-RIDHNHPT.cjs.map → AutomationContainer-EXTHQ7B3.cjs.map} +0 -0
- /package/dist/lib/node/{chunk-HZTVNN4S.cjs.map → chunk-B3OL2E3B.cjs.map} +0 -0
- /package/dist/lib/node/{react-surface-UJDYSHZ5.cjs.map → react-surface-OYJMJXJI.cjs.map} +0 -0
- /package/dist/lib/node-esm/{AutomationContainer-MCUWF267.mjs.map → AutomationContainer-FSWEGDKP.mjs.map} +0 -0
- /package/dist/lib/node-esm/{AutomationPanel-U34H2Q7Z.mjs.map → AutomationPanel-LIPLJA55.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-RG3M42SO.mjs.map → chunk-YCNX76NJ.mjs.map} +0 -0
- /package/dist/lib/node-esm/{react-surface-R72A4EHM.mjs.map → react-surface-FDGQORLY.mjs.map} +0 -0
|
@@ -16,17 +16,17 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
16
|
return to;
|
|
17
17
|
};
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var
|
|
20
|
-
__export(
|
|
21
|
-
AutomationPanel: () =>
|
|
22
|
-
default: () =>
|
|
19
|
+
var AutomationPanel_G7R6RL7O_exports = {};
|
|
20
|
+
__export(AutomationPanel_G7R6RL7O_exports, {
|
|
21
|
+
AutomationPanel: () => import_chunk_F74YVA6P.AutomationPanel,
|
|
22
|
+
default: () => import_chunk_F74YVA6P.AutomationPanel_default
|
|
23
23
|
});
|
|
24
|
-
module.exports = __toCommonJS(
|
|
25
|
-
var
|
|
26
|
-
var
|
|
24
|
+
module.exports = __toCommonJS(AutomationPanel_G7R6RL7O_exports);
|
|
25
|
+
var import_chunk_F74YVA6P = require("./chunk-F74YVA6P.cjs");
|
|
26
|
+
var import_chunk_A4DMUH7U = require("./chunk-A4DMUH7U.cjs");
|
|
27
27
|
var import_chunk_7GXNXMSM = require("./chunk-7GXNXMSM.cjs");
|
|
28
28
|
// Annotate the CommonJS export names for ESM import in node:
|
|
29
29
|
0 && (module.exports = {
|
|
30
30
|
AutomationPanel
|
|
31
31
|
});
|
|
32
|
-
//# sourceMappingURL=AutomationPanel-
|
|
32
|
+
//# sourceMappingURL=AutomationPanel-G7R6RL7O.cjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["AutomationPanel-
|
|
4
|
-
"sourcesContent": ["import {\n AutomationPanel,\n AutomationPanel_default\n} from \"./chunk-
|
|
3
|
+
"sources": ["AutomationPanel-G7R6RL7O.cjs"],
|
|
4
|
+
"sourcesContent": ["import {\n AutomationPanel,\n AutomationPanel_default\n} from \"./chunk-F74YVA6P.cjs\";\nimport \"./chunk-A4DMUH7U.cjs\";\nimport \"./chunk-7GXNXMSM.cjs\";\nexport {\n AutomationPanel,\n AutomationPanel_default as default\n};\n//# sourceMappingURL=AutomationPanel-G7R6RL7O.cjs.map\n"],
|
|
5
5
|
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAGO;AACP,4BAAO;AACP,4BAAO;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -26,11 +26,11 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
26
26
|
mod
|
|
27
27
|
));
|
|
28
28
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var
|
|
30
|
-
__export(
|
|
29
|
+
var chunk_A4DMUH7U_exports = {};
|
|
30
|
+
__export(chunk_A4DMUH7U_exports, {
|
|
31
31
|
TriggerEditor: () => TriggerEditor
|
|
32
32
|
});
|
|
33
|
-
module.exports = __toCommonJS(
|
|
33
|
+
module.exports = __toCommonJS(chunk_A4DMUH7U_exports);
|
|
34
34
|
var import_chunk_7GXNXMSM = require("./chunk-7GXNXMSM.cjs");
|
|
35
35
|
var import_react = __toESM(require("react"));
|
|
36
36
|
var import_conductor = require("@dxos/conductor");
|
|
@@ -47,23 +47,23 @@ var import_react3 = __toESM(require("react"));
|
|
|
47
47
|
var import_functions2 = require("@dxos/functions");
|
|
48
48
|
var import_react_ui3 = require("@dxos/react-ui");
|
|
49
49
|
var import_react_ui_form3 = require("@dxos/react-ui-form");
|
|
50
|
-
var
|
|
50
|
+
var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
|
|
51
51
|
const selectedFunctionValue = (0, import_react_ui_form2.useFormValues)([
|
|
52
52
|
"function"
|
|
53
53
|
]);
|
|
54
|
-
const
|
|
54
|
+
const selectedFunctionId = (0, import_react2.useMemo)(() => {
|
|
55
55
|
if (selectedFunctionValue instanceof import_echo_schema.RefImpl) {
|
|
56
|
-
return selectedFunctionValue.dxn.toString().split("dxn:
|
|
56
|
+
return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
|
|
57
57
|
}
|
|
58
58
|
}, [
|
|
59
59
|
selectedFunctionValue
|
|
60
60
|
]);
|
|
61
|
-
const selectedFunction = (0, import_react2.useMemo)(() => functions.find((f) => f.
|
|
61
|
+
const selectedFunction = (0, import_react2.useMemo)(() => functions.find((f) => f.id === selectedFunctionId), [
|
|
62
62
|
functions,
|
|
63
|
-
|
|
63
|
+
selectedFunctionId
|
|
64
64
|
]);
|
|
65
65
|
(0, import_react_ui2.useOnTransition)(
|
|
66
|
-
// Clear function parameter
|
|
66
|
+
// Clear function parameter input when the function changes.
|
|
67
67
|
selectedFunctionValue,
|
|
68
68
|
(prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
|
|
69
69
|
(currValue) => currValue !== void 0,
|
|
@@ -167,8 +167,8 @@ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
|
|
|
167
167
|
["function"]: (props) => {
|
|
168
168
|
const getValue = (0, import_react.useCallback)(() => {
|
|
169
169
|
const formValue = props.getValue();
|
|
170
|
-
if (formValue
|
|
171
|
-
return formValue.toString();
|
|
170
|
+
if (import_echo2.Ref.isRef(formValue)) {
|
|
171
|
+
return formValue.dxn.toString();
|
|
172
172
|
}
|
|
173
173
|
return void 0;
|
|
174
174
|
}, [
|
|
@@ -190,8 +190,8 @@ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
|
|
|
190
190
|
options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
|
|
191
191
|
});
|
|
192
192
|
},
|
|
193
|
-
["spec.
|
|
194
|
-
["
|
|
193
|
+
["spec.kind"]: SpecSelector,
|
|
194
|
+
["input"]: (props) => /* @__PURE__ */ import_react.default.createElement(FunctionInputEditor, {
|
|
195
195
|
...props,
|
|
196
196
|
functions,
|
|
197
197
|
onQueryRefOptions: handleRefQueryLookup
|
|
@@ -224,11 +224,11 @@ var getFunctionOptions = (scripts, functions) => {
|
|
|
224
224
|
const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
|
|
225
225
|
return functions.map((fn) => ({
|
|
226
226
|
label: getLabel(fn),
|
|
227
|
-
value: `dxn:
|
|
227
|
+
value: `dxn:echo:@:${fn.id}`
|
|
228
228
|
}));
|
|
229
229
|
};
|
|
230
230
|
// Annotate the CommonJS export names for ESM import in node:
|
|
231
231
|
0 && (module.exports = {
|
|
232
232
|
TriggerEditor
|
|
233
233
|
});
|
|
234
|
-
//# sourceMappingURL=chunk-
|
|
234
|
+
//# sourceMappingURL=chunk-A4DMUH7U.cjs.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": ["import_echo", "import_react", "import_react_ui", "import_react_ui_form", "import_functions", "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", "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", "Ref", "isRef", "handleOnValueChange", "dxnString", "DXN", "parse", "ref", "fromDXN", "getWorkflowOptions", "concat", "getFunctionOptions", "div", "role", "FunctionTriggerSchema", "graphs", "graph", "getLabel", "fn", "s", "source", "target", "name"]
|
|
7
|
+
}
|
|
@@ -26,17 +26,17 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
26
26
|
mod
|
|
27
27
|
));
|
|
28
28
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var
|
|
30
|
-
__export(
|
|
29
|
+
var chunk_B3OL2E3B_exports = {};
|
|
30
|
+
__export(chunk_B3OL2E3B_exports, {
|
|
31
31
|
AutomationContainer: () => AutomationContainer,
|
|
32
32
|
AutomationPanel: () => AutomationPanel,
|
|
33
33
|
FunctionsContainer: () => FunctionsContainer,
|
|
34
34
|
FunctionsPanel: () => FunctionsPanel
|
|
35
35
|
});
|
|
36
|
-
module.exports = __toCommonJS(
|
|
36
|
+
module.exports = __toCommonJS(chunk_B3OL2E3B_exports);
|
|
37
37
|
var import_react = require("react");
|
|
38
|
-
var AutomationContainer = (0, import_react.lazy)(() => import("./AutomationContainer-
|
|
39
|
-
var AutomationPanel = (0, import_react.lazy)(() => import("./AutomationPanel-
|
|
38
|
+
var AutomationContainer = (0, import_react.lazy)(() => import("./AutomationContainer-EXTHQ7B3.cjs"));
|
|
39
|
+
var AutomationPanel = (0, import_react.lazy)(() => import("./AutomationPanel-G7R6RL7O.cjs"));
|
|
40
40
|
var FunctionsContainer = (0, import_react.lazy)(() => import("./FunctionsContainer-RNZTNQEU.cjs"));
|
|
41
41
|
var FunctionsPanel = (0, import_react.lazy)(() => import("./FunctionsPanel-7I7YCHPJ.cjs"));
|
|
42
42
|
// Annotate the CommonJS export names for ESM import in node:
|
|
@@ -46,4 +46,4 @@ var FunctionsPanel = (0, import_react.lazy)(() => import("./FunctionsPanel-7I7YC
|
|
|
46
46
|
FunctionsContainer,
|
|
47
47
|
FunctionsPanel
|
|
48
48
|
});
|
|
49
|
-
//# sourceMappingURL=chunk-
|
|
49
|
+
//# sourceMappingURL=chunk-B3OL2E3B.cjs.map
|
|
@@ -26,13 +26,13 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
26
26
|
mod
|
|
27
27
|
));
|
|
28
28
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var
|
|
30
|
-
__export(
|
|
29
|
+
var chunk_F74YVA6P_exports = {};
|
|
30
|
+
__export(chunk_F74YVA6P_exports, {
|
|
31
31
|
AutomationPanel: () => AutomationPanel,
|
|
32
32
|
AutomationPanel_default: () => AutomationPanel_default
|
|
33
33
|
});
|
|
34
|
-
module.exports = __toCommonJS(
|
|
35
|
-
var
|
|
34
|
+
module.exports = __toCommonJS(chunk_F74YVA6P_exports);
|
|
35
|
+
var import_chunk_A4DMUH7U = require("./chunk-A4DMUH7U.cjs");
|
|
36
36
|
var import_chunk_7GXNXMSM = require("./chunk-7GXNXMSM.cjs");
|
|
37
37
|
var import_effect = require("effect");
|
|
38
38
|
var import_react = __toESM(require("react"));
|
|
@@ -84,7 +84,7 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
|
|
|
84
84
|
className: "flex flex-col w-full"
|
|
85
85
|
}, trigger ? /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.ControlItem, {
|
|
86
86
|
title: t("trigger editor title")
|
|
87
|
-
}, /* @__PURE__ */ import_react.default.createElement(
|
|
87
|
+
}, /* @__PURE__ */ import_react.default.createElement(import_chunk_A4DMUH7U.TriggerEditor, {
|
|
88
88
|
space,
|
|
89
89
|
trigger,
|
|
90
90
|
onSave: handleSave,
|
|
@@ -128,13 +128,13 @@ var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
|
|
|
128
128
|
})));
|
|
129
129
|
};
|
|
130
130
|
var getCopyAction = (client, trigger) => {
|
|
131
|
-
if (trigger?.spec?.
|
|
131
|
+
if (trigger?.spec?.kind === import_functions.TriggerKind.Email) {
|
|
132
132
|
return {
|
|
133
133
|
translationKey: "trigger copy email",
|
|
134
134
|
contentProvider: () => `${(0, import_echo.getSpace)(trigger).id}@dxos.network`
|
|
135
135
|
};
|
|
136
136
|
}
|
|
137
|
-
if (trigger?.spec?.
|
|
137
|
+
if (trigger?.spec?.kind === import_functions.TriggerKind.Webhook) {
|
|
138
138
|
return {
|
|
139
139
|
translationKey: "trigger copy url",
|
|
140
140
|
contentProvider: () => getWebhookUrl(client, trigger)
|
|
@@ -163,4 +163,4 @@ var AutomationPanel_default = AutomationPanel;
|
|
|
163
163
|
AutomationPanel,
|
|
164
164
|
AutomationPanel_default
|
|
165
165
|
});
|
|
166
|
-
//# sourceMappingURL=chunk-
|
|
166
|
+
//# sourceMappingURL=chunk-F74YVA6P.cjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
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?.
|
|
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
5
|
"mappings": "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",
|
|
6
|
-
"names": ["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", "React", "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", "
|
|
6
|
+
"names": ["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", "React", "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"]
|
|
7
7
|
}
|
package/dist/lib/node/index.cjs
CHANGED
|
@@ -29,25 +29,25 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
29
29
|
var node_exports = {};
|
|
30
30
|
__export(node_exports, {
|
|
31
31
|
AUTOMATION_PLUGIN: () => import_chunk_7GXNXMSM.AUTOMATION_PLUGIN,
|
|
32
|
-
AutomationContainer: () =>
|
|
33
|
-
AutomationPanel: () =>
|
|
32
|
+
AutomationContainer: () => import_chunk_B3OL2E3B.AutomationContainer,
|
|
33
|
+
AutomationPanel: () => import_chunk_B3OL2E3B.AutomationPanel,
|
|
34
34
|
AutomationPlugin: () => AutomationPlugin,
|
|
35
|
-
FunctionsContainer: () =>
|
|
36
|
-
FunctionsPanel: () =>
|
|
37
|
-
TriggerEditor: () =>
|
|
35
|
+
FunctionsContainer: () => import_chunk_B3OL2E3B.FunctionsContainer,
|
|
36
|
+
FunctionsPanel: () => import_chunk_B3OL2E3B.FunctionsPanel,
|
|
37
|
+
TriggerEditor: () => import_chunk_A4DMUH7U.TriggerEditor,
|
|
38
38
|
meta: () => import_chunk_7GXNXMSM.meta
|
|
39
39
|
});
|
|
40
40
|
module.exports = __toCommonJS(node_exports);
|
|
41
|
-
var
|
|
42
|
-
var
|
|
41
|
+
var import_chunk_B3OL2E3B = require("./chunk-B3OL2E3B.cjs");
|
|
42
|
+
var import_chunk_A4DMUH7U = require("./chunk-A4DMUH7U.cjs");
|
|
43
43
|
var import_chunk_7GXNXMSM = require("./chunk-7GXNXMSM.cjs");
|
|
44
44
|
var import_app_framework = require("@dxos/app-framework");
|
|
45
45
|
var import_functions = require("@dxos/functions");
|
|
46
46
|
var import_plugin_client = require("@dxos/plugin-client");
|
|
47
47
|
var import_app_framework2 = require("@dxos/app-framework");
|
|
48
48
|
var AppGraphBuilder = (0, import_app_framework2.lazy)(() => import("./app-graph-builder-TVFR6RXO.cjs"));
|
|
49
|
-
var IntentResolver = (0, import_app_framework2.lazy)(() => import("./intent-resolver-
|
|
50
|
-
var ReactSurface = (0, import_app_framework2.lazy)(() => import("./react-surface-
|
|
49
|
+
var IntentResolver = (0, import_app_framework2.lazy)(() => import("./intent-resolver-6XS2NYC7.cjs"));
|
|
50
|
+
var ReactSurface = (0, import_app_framework2.lazy)(() => import("./react-surface-OYJMJXJI.cjs"));
|
|
51
51
|
var translations_default = [
|
|
52
52
|
{
|
|
53
53
|
"en-US": {
|
|
@@ -16,11 +16,11 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
16
|
return to;
|
|
17
17
|
};
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var
|
|
20
|
-
__export(
|
|
19
|
+
var intent_resolver_6XS2NYC7_exports = {};
|
|
20
|
+
__export(intent_resolver_6XS2NYC7_exports, {
|
|
21
21
|
default: () => intent_resolver_default
|
|
22
22
|
});
|
|
23
|
-
module.exports = __toCommonJS(
|
|
23
|
+
module.exports = __toCommonJS(intent_resolver_6XS2NYC7_exports);
|
|
24
24
|
var import_chunk_GDCG2BML = require("./chunk-GDCG2BML.cjs");
|
|
25
25
|
var import_chunk_7GXNXMSM = require("./chunk-7GXNXMSM.cjs");
|
|
26
26
|
var import_app_framework = require("@dxos/app-framework");
|
|
@@ -54,14 +54,14 @@ var intent_resolver_default = (context) => (0, import_app_framework.contributes)
|
|
|
54
54
|
switch (template.type) {
|
|
55
55
|
case "timer": {
|
|
56
56
|
trigger.spec = {
|
|
57
|
-
|
|
57
|
+
kind: import_functions.TriggerKind.Timer,
|
|
58
58
|
cron: template.cron
|
|
59
59
|
};
|
|
60
60
|
break;
|
|
61
61
|
}
|
|
62
62
|
case "queue": {
|
|
63
63
|
trigger.spec = {
|
|
64
|
-
|
|
64
|
+
kind: import_functions.TriggerKind.Queue,
|
|
65
65
|
queue: template.queueDXN.toString()
|
|
66
66
|
};
|
|
67
67
|
break;
|
|
@@ -90,4 +90,4 @@ var intent_resolver_default = (context) => (0, import_app_framework.contributes)
|
|
|
90
90
|
}
|
|
91
91
|
})
|
|
92
92
|
]);
|
|
93
|
-
//# sourceMappingURL=intent-resolver-
|
|
93
|
+
//# sourceMappingURL=intent-resolver-6XS2NYC7.cjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
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 = {
|
|
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;
|
|
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"]
|
|
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 = { kind: TriggerKind.Timer, cron: template.cron };\n break;\n }\n case 'queue': {\n trigger.spec = { kind: 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;YAAEC,MAAMC,6BAAYC;YAAOC,MAAM3B,SAAS2B;UAAK;AAC9D;QACF;QACA,KAAK,SAAS;AACZvB,kBAAQmB,OAAO;YAAEC,MAAMC,6BAAYG;YAAOC,OAAQ7B,SAAS8B,SAAiBC,SAAQ;UAAG;AACvF;QACF;QACA,SAAS;AACP;QACF;MACF;AAEA,aAAO;QACLC,SAAS;cACPC,mCAAaC,0BAAYC,WAAW;YAAEC,QAAQhC;YAASiC,QAAQtC;UAAM,CAAA;cACrEkC,mCAAaK,kCAAaC,MAAM;YAC9BC,MAAM;YACNC,SAAS;cAAC,sBAAsBC,sCAAAA,GAA4B3C,MAAM4C,EAAE;;YACpEC,SAAS;cACPC,WAAW9C,MAAM4C;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", "kind", "TriggerKind", "Timer", "cron", "Queue", "queue", "queueDXN", "toString", "intents", "createIntent", "SpaceAction", "AddObject", "object", "target", "LayoutAction", "Open", "part", "subject", "ATTENDABLE_PATH_SEPARATOR", "id", "options", "workspace"]
|
|
7
7
|
}
|