@dxos/plugin-automation 0.8.3-staging.0fa589b → 0.8.4-main.1da679c
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/AutomationPanel-N5HFJJXW.mjs +11 -0
- package/dist/lib/browser/AutomationSettings-S3F2VT7Q.mjs +70 -0
- package/dist/lib/browser/AutomationSettings-S3F2VT7Q.mjs.map +7 -0
- package/dist/lib/browser/{FunctionsContainer-JY7V7PLF.mjs → FunctionsContainer-U4HASI4P.mjs} +6 -9
- package/dist/lib/browser/FunctionsContainer-U4HASI4P.mjs.map +7 -0
- package/dist/lib/browser/{FunctionsPanel-LY4IFKR7.mjs → FunctionsPanel-I443Y6KB.mjs} +3 -3
- package/dist/lib/browser/{app-graph-builder-T34RV5UA.mjs → app-graph-builder-SRA3X2GQ.mjs} +6 -6
- package/dist/lib/{node-esm/app-graph-builder-DYWAKQM3.mjs.map → browser/app-graph-builder-SRA3X2GQ.mjs.map} +3 -3
- package/dist/lib/browser/{chunk-C5VOC5EE.mjs → chunk-4TWQV33E.mjs} +14 -18
- package/dist/lib/browser/chunk-4TWQV33E.mjs.map +7 -0
- package/dist/lib/browser/chunk-CRUNQZ2M.mjs +15 -0
- package/dist/lib/browser/chunk-CRUNQZ2M.mjs.map +7 -0
- package/dist/lib/browser/{chunk-IHAKPP5A.mjs → chunk-GW5U2DGT.mjs} +2 -2
- package/dist/lib/browser/{chunk-4E2KPMLB.mjs → chunk-HN7OHFCB.mjs} +5 -6
- package/dist/lib/browser/chunk-HN7OHFCB.mjs.map +7 -0
- package/dist/lib/browser/chunk-NQGKPPXI.mjs +14 -0
- package/dist/lib/browser/chunk-NQGKPPXI.mjs.map +7 -0
- package/dist/lib/browser/chunk-P6YOYDXP.mjs +53 -0
- package/dist/lib/browser/chunk-P6YOYDXP.mjs.map +7 -0
- package/dist/lib/browser/{chunk-N5VLW7UZ.mjs → chunk-S4SM663I.mjs} +20 -20
- package/dist/lib/browser/chunk-S4SM663I.mjs.map +7 -0
- package/dist/lib/browser/chunk-UHXDXRP4.mjs +14 -0
- package/dist/lib/browser/chunk-UHXDXRP4.mjs.map +7 -0
- package/dist/lib/browser/{chunk-RHSCK7AU.mjs → chunk-Z5DT4MHW.mjs} +5 -5
- package/dist/lib/{node-esm/chunk-2IH4VB3R.mjs.map → browser/chunk-Z5DT4MHW.mjs.map} +3 -3
- package/dist/lib/browser/compute-runtime-G25R3RSS.mjs +154 -0
- package/dist/lib/browser/compute-runtime-G25R3RSS.mjs.map +7 -0
- package/dist/lib/browser/hooks/index.mjs +12 -0
- package/dist/lib/browser/index.mjs +30 -19
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/{intent-resolver-AX46HSU7.mjs → intent-resolver-CMLGPFD6.mjs} +12 -11
- package/dist/lib/browser/intent-resolver-CMLGPFD6.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-Z7A272CA.mjs → react-surface-IYFH2BEM.mjs} +18 -18
- package/dist/lib/browser/react-surface-IYFH2BEM.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +8 -0
- package/dist/lib/node-esm/{AutomationPanel-Y3ODAHH7.mjs → AutomationPanel-MKOLA2FE.mjs} +4 -4
- package/dist/lib/node-esm/AutomationSettings-C3GNAUYC.mjs +71 -0
- package/dist/lib/node-esm/AutomationSettings-C3GNAUYC.mjs.map +7 -0
- package/dist/lib/node-esm/{FunctionsContainer-25M5VT3J.mjs → FunctionsContainer-VZIVURH6.mjs} +6 -9
- package/dist/lib/node-esm/FunctionsContainer-VZIVURH6.mjs.map +7 -0
- package/dist/lib/node-esm/{FunctionsPanel-HVGF5AJP.mjs → FunctionsPanel-ELINCXPW.mjs} +3 -3
- package/dist/lib/node-esm/{app-graph-builder-DYWAKQM3.mjs → app-graph-builder-R5XQJKZS.mjs} +6 -6
- package/dist/lib/{browser/app-graph-builder-T34RV5UA.mjs.map → node-esm/app-graph-builder-R5XQJKZS.mjs.map} +3 -3
- package/dist/lib/node-esm/{chunk-2T2OZC3A.mjs → chunk-AONUBWBE.mjs} +14 -18
- package/dist/lib/node-esm/chunk-AONUBWBE.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-BTD2B4SZ.mjs +16 -0
- package/dist/lib/node-esm/chunk-BTD2B4SZ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-CTAX6WBZ.mjs +16 -0
- package/dist/lib/node-esm/chunk-CTAX6WBZ.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-2IH4VB3R.mjs → chunk-CX2AILIS.mjs} +5 -5
- package/dist/lib/{browser/chunk-RHSCK7AU.mjs.map → node-esm/chunk-CX2AILIS.mjs.map} +3 -3
- package/dist/lib/node-esm/{chunk-HCCLRNMJ.mjs → chunk-NK5N3QKD.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-6JOJ2NN4.mjs → chunk-OEZNHUL2.mjs} +5 -6
- package/dist/lib/node-esm/chunk-OEZNHUL2.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-UAOO5IZQ.mjs +16 -0
- package/dist/lib/node-esm/chunk-UAOO5IZQ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-XL33Y62M.mjs +54 -0
- package/dist/lib/node-esm/chunk-XL33Y62M.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-UFHDB2OA.mjs → chunk-ZOJVKPCA.mjs} +20 -20
- package/dist/lib/node-esm/chunk-ZOJVKPCA.mjs.map +7 -0
- package/dist/lib/node-esm/compute-runtime-LHO62OVM.mjs +155 -0
- package/dist/lib/node-esm/compute-runtime-LHO62OVM.mjs.map +7 -0
- package/dist/lib/node-esm/hooks/index.mjs +13 -0
- package/dist/lib/node-esm/hooks/index.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +30 -19
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/{intent-resolver-WXHFNJJI.mjs → intent-resolver-NUPI6NC6.mjs} +12 -11
- package/dist/lib/node-esm/intent-resolver-NUPI6NC6.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-TP6IYSR4.mjs → react-surface-FDRJ76PK.mjs} +18 -18
- package/dist/lib/node-esm/react-surface-FDRJ76PK.mjs.map +7 -0
- package/dist/lib/node-esm/{types.mjs → types/index.mjs} +3 -3
- package/dist/lib/node-esm/types/index.mjs.map +7 -0
- package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/capabilities.d.ts +18 -0
- package/dist/types/src/capabilities/capabilities.d.ts.map +1 -0
- package/dist/types/src/capabilities/compute-runtime.d.ts +5 -0
- package/dist/types/src/capabilities/compute-runtime.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +5 -3
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts +1 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +6 -5
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts +45 -3
- package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
- package/dist/types/src/components/AutomationSettings.d.ts +5 -0
- package/dist/types/src/components/AutomationSettings.d.ts.map +1 -0
- 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/SpecSelector.d.ts.map +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +2 -2
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts +45 -3
- package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/TriggerSettings.d.ts +6 -0
- package/dist/types/src/components/TriggerSettings.d.ts.map +1 -0
- package/dist/types/src/components/index.d.ts +2 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/hooks/index.d.ts +3 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -0
- package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts +8 -0
- package/dist/types/src/hooks/useComputeRuntimeCallback.d.ts.map +1 -0
- package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts +11 -0
- package/dist/types/src/hooks/useTriggerRuntimeControls.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +1 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +31 -29
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +2 -0
- package/dist/types/src/types/index.d.ts.map +1 -0
- package/dist/types/src/{types.d.ts → types/schema.d.ts} +3 -3
- package/dist/types/src/types/schema.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +55 -34
- package/src/AutomationPlugin.tsx +9 -4
- package/src/capabilities/app-graph-builder.ts +2 -2
- package/src/capabilities/capabilities.ts +52 -0
- package/src/capabilities/compute-runtime.ts +124 -0
- package/src/capabilities/index.ts +3 -0
- package/src/capabilities/intent-resolver.ts +7 -7
- package/src/capabilities/react-surface.tsx +11 -11
- package/src/components/AutomationPanel/AutomationPanel.stories.tsx +11 -8
- package/src/components/AutomationPanel/AutomationPanel.tsx +15 -27
- package/src/components/AutomationSettings.tsx +30 -0
- package/src/components/FunctionsContainer.tsx +10 -12
- package/src/components/FunctionsPanel/FunctionsPanel.tsx +2 -2
- package/src/components/TriggerEditor/SpecSelector.tsx +14 -14
- package/src/components/TriggerEditor/TriggerEditor.stories.tsx +12 -9
- package/src/components/TriggerEditor/TriggerEditor.tsx +6 -12
- package/src/components/TriggerSettings.tsx +25 -0
- package/src/components/index.ts +1 -1
- package/src/hooks/index.ts +6 -0
- package/src/hooks/useComputeRuntimeCallback.ts +30 -0
- package/src/hooks/useTriggerRuntimeControls.ts +52 -0
- package/src/index.ts +1 -0
- package/src/translations.ts +10 -4
- package/src/types/index.ts +5 -0
- package/src/{types.ts → types/schema.ts} +2 -4
- package/dist/lib/browser/AutomationContainer-OGNK3HD5.mjs +0 -38
- package/dist/lib/browser/AutomationContainer-OGNK3HD5.mjs.map +0 -7
- package/dist/lib/browser/AutomationPanel-PRIIAXD5.mjs +0 -11
- package/dist/lib/browser/FunctionsContainer-JY7V7PLF.mjs.map +0 -7
- package/dist/lib/browser/chunk-4E2KPMLB.mjs.map +0 -7
- package/dist/lib/browser/chunk-C5VOC5EE.mjs.map +0 -7
- package/dist/lib/browser/chunk-N5VLW7UZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-VQWJ5UYA.mjs +0 -14
- package/dist/lib/browser/chunk-VQWJ5UYA.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-AX46HSU7.mjs.map +0 -7
- package/dist/lib/browser/react-surface-Z7A272CA.mjs.map +0 -7
- package/dist/lib/browser/types.mjs +0 -8
- package/dist/lib/node/AutomationContainer-B7PSJFIS.cjs +0 -66
- package/dist/lib/node/AutomationContainer-B7PSJFIS.cjs.map +0 -7
- package/dist/lib/node/AutomationPanel-XYLZU4MI.cjs +0 -32
- package/dist/lib/node/AutomationPanel-XYLZU4MI.cjs.map +0 -7
- package/dist/lib/node/FunctionsContainer-4FGOQW5X.cjs +0 -67
- package/dist/lib/node/FunctionsContainer-4FGOQW5X.cjs.map +0 -7
- package/dist/lib/node/FunctionsPanel-EWWAZK3W.cjs +0 -31
- package/dist/lib/node/FunctionsPanel-EWWAZK3W.cjs.map +0 -7
- package/dist/lib/node/app-graph-builder-5XRIIV7E.cjs +0 -96
- package/dist/lib/node/app-graph-builder-5XRIIV7E.cjs.map +0 -7
- package/dist/lib/node/chunk-3EF7MLFX.cjs +0 -38
- package/dist/lib/node/chunk-3EF7MLFX.cjs.map +0 -7
- package/dist/lib/node/chunk-6X3XJ4VI.cjs +0 -122
- package/dist/lib/node/chunk-6X3XJ4VI.cjs.map +0 -7
- package/dist/lib/node/chunk-GIIVTK4O.cjs +0 -58
- package/dist/lib/node/chunk-GIIVTK4O.cjs.map +0 -7
- package/dist/lib/node/chunk-IXUCZ3YY.cjs +0 -173
- package/dist/lib/node/chunk-IXUCZ3YY.cjs.map +0 -7
- package/dist/lib/node/chunk-LQ6XK4N5.cjs +0 -253
- package/dist/lib/node/chunk-LQ6XK4N5.cjs.map +0 -7
- package/dist/lib/node/chunk-TH4XDKAY.cjs +0 -49
- package/dist/lib/node/chunk-TH4XDKAY.cjs.map +0 -7
- package/dist/lib/node/index.cjs +0 -124
- package/dist/lib/node/index.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-EAREQZFE.cjs +0 -92
- package/dist/lib/node/intent-resolver-EAREQZFE.cjs.map +0 -7
- package/dist/lib/node/meta.json +0 -1
- package/dist/lib/node/react-surface-OI6CDHEI.cjs +0 -87
- package/dist/lib/node/react-surface-OI6CDHEI.cjs.map +0 -7
- package/dist/lib/node/types.cjs +0 -30
- package/dist/lib/node/types.cjs.map +0 -7
- package/dist/lib/node-esm/AutomationContainer-ANCUYDDA.mjs +0 -39
- package/dist/lib/node-esm/AutomationContainer-ANCUYDDA.mjs.map +0 -7
- package/dist/lib/node-esm/FunctionsContainer-25M5VT3J.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-2T2OZC3A.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-6JOJ2NN4.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-UFHDB2OA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-WJHKFPX2.mjs +0 -16
- package/dist/lib/node-esm/chunk-WJHKFPX2.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-WXHFNJJI.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-TP6IYSR4.mjs.map +0 -7
- package/dist/types/src/components/AutomationContainer.d.ts +0 -5
- package/dist/types/src/components/AutomationContainer.d.ts.map +0 -1
- package/dist/types/src/types.d.ts.map +0 -1
- package/src/components/AutomationContainer.tsx +0 -30
- /package/dist/lib/browser/{AutomationPanel-PRIIAXD5.mjs.map → AutomationPanel-N5HFJJXW.mjs.map} +0 -0
- /package/dist/lib/browser/{FunctionsPanel-LY4IFKR7.mjs.map → FunctionsPanel-I443Y6KB.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-IHAKPP5A.mjs.map → chunk-GW5U2DGT.mjs.map} +0 -0
- /package/dist/lib/browser/{types.mjs.map → hooks/index.mjs.map} +0 -0
- /package/dist/lib/{node-esm/AutomationPanel-Y3ODAHH7.mjs.map → browser/types/index.mjs.map} +0 -0
- /package/dist/lib/node-esm/{FunctionsPanel-HVGF5AJP.mjs.map → AutomationPanel-MKOLA2FE.mjs.map} +0 -0
- /package/dist/lib/node-esm/{types.mjs.map → FunctionsPanel-ELINCXPW.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-HCCLRNMJ.mjs.map → chunk-NK5N3QKD.mjs.map} +0 -0
|
@@ -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,173 +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_IXUCZ3YY_exports = {};
|
|
30
|
-
__export(chunk_IXUCZ3YY_exports, {
|
|
31
|
-
AutomationPanel: () => AutomationPanel,
|
|
32
|
-
AutomationPanel_default: () => AutomationPanel_default
|
|
33
|
-
});
|
|
34
|
-
module.exports = __toCommonJS(chunk_IXUCZ3YY_exports);
|
|
35
|
-
var import_chunk_LQ6XK4N5 = require("./chunk-LQ6XK4N5.cjs");
|
|
36
|
-
var import_chunk_3EF7MLFX = require("./chunk-3EF7MLFX.cjs");
|
|
37
|
-
var import_tracking = require("@preact-signals/safe-react/tracking");
|
|
38
|
-
var import_effect = require("effect");
|
|
39
|
-
var import_react = __toESM(require("react"));
|
|
40
|
-
var import_echo = require("@dxos/echo");
|
|
41
|
-
var import_functions = require("@dxos/functions");
|
|
42
|
-
var import_react_client = require("@dxos/react-client");
|
|
43
|
-
var import_echo2 = require("@dxos/react-client/echo");
|
|
44
|
-
var import_react_ui = require("@dxos/react-ui");
|
|
45
|
-
var import_react_ui_form = require("@dxos/react-ui-form");
|
|
46
|
-
var import_react_ui_list = require("@dxos/react-ui-list");
|
|
47
|
-
var import_react_ui_theme = require("@dxos/react-ui-theme");
|
|
48
|
-
var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
|
|
49
|
-
var AutomationPanel = ({ space, object, initialTrigger, onDone }) => {
|
|
50
|
-
var _effect = (0, import_tracking.useSignals)();
|
|
51
|
-
try {
|
|
52
|
-
const { t } = (0, import_react_ui.useTranslation)(import_chunk_3EF7MLFX.AUTOMATION_PLUGIN);
|
|
53
|
-
const client = (0, import_react_client.useClient)();
|
|
54
|
-
const triggers = (0, import_echo2.useQuery)(space, import_echo.Filter.type(import_functions.FunctionTrigger));
|
|
55
|
-
const functions = (0, import_echo2.useQuery)(space, import_echo.Filter.type(import_functions.FunctionType));
|
|
56
|
-
const scripts = (0, import_echo2.useQuery)(space, import_echo.Filter.type(import_functions.ScriptType));
|
|
57
|
-
const [trigger, setTrigger] = (0, import_react.useState)(initialTrigger);
|
|
58
|
-
const [selected, setSelected] = (0, import_react.useState)();
|
|
59
|
-
const handleSelect = (trigger2) => {
|
|
60
|
-
const { id: _, ...values } = trigger2;
|
|
61
|
-
setTrigger(values);
|
|
62
|
-
setSelected(trigger2);
|
|
63
|
-
};
|
|
64
|
-
const handleAdd = () => {
|
|
65
|
-
setTrigger(import_echo.Obj.make(import_functions.FunctionTriggerSchema, {}));
|
|
66
|
-
setSelected(void 0);
|
|
67
|
-
};
|
|
68
|
-
const handleDelete = (trigger2) => {
|
|
69
|
-
space.db.remove(trigger2);
|
|
70
|
-
setTrigger(void 0);
|
|
71
|
-
setSelected(void 0);
|
|
72
|
-
};
|
|
73
|
-
const handleSave = (trigger2) => {
|
|
74
|
-
if (selected) {
|
|
75
|
-
Object.assign(selected, trigger2);
|
|
76
|
-
} else {
|
|
77
|
-
space.db.add(import_echo.Obj.make(import_functions.FunctionTrigger, trigger2));
|
|
78
|
-
}
|
|
79
|
-
setTrigger(void 0);
|
|
80
|
-
setSelected(void 0);
|
|
81
|
-
onDone?.();
|
|
82
|
-
};
|
|
83
|
-
const handleCancel = () => {
|
|
84
|
-
setTrigger(void 0);
|
|
85
|
-
onDone?.();
|
|
86
|
-
};
|
|
87
|
-
if (trigger) {
|
|
88
|
-
return /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.ControlItem, {
|
|
89
|
-
title: t("trigger editor title")
|
|
90
|
-
}, /* @__PURE__ */ import_react.default.createElement(import_chunk_LQ6XK4N5.TriggerEditor, {
|
|
91
|
-
space,
|
|
92
|
-
trigger,
|
|
93
|
-
onSave: handleSave,
|
|
94
|
-
onCancel: handleCancel
|
|
95
|
-
}));
|
|
96
|
-
}
|
|
97
|
-
return /* @__PURE__ */ import_react.default.createElement("div", {
|
|
98
|
-
className: import_react_ui_form.controlItemClasses
|
|
99
|
-
}, triggers.length > 0 && /* @__PURE__ */ import_react.default.createElement(import_react_ui_list.List.Root, {
|
|
100
|
-
items: triggers,
|
|
101
|
-
isItem: import_effect.Schema.is(import_functions.FunctionTrigger),
|
|
102
|
-
getId: (field) => field.id
|
|
103
|
-
}, ({ items: triggers2 }) => /* @__PURE__ */ import_react.default.createElement("div", {
|
|
104
|
-
role: "list",
|
|
105
|
-
className: "flex flex-col w-full"
|
|
106
|
-
}, triggers2?.map((trigger2) => {
|
|
107
|
-
const copyAction = getCopyAction(client, trigger2);
|
|
108
|
-
return /* @__PURE__ */ import_react.default.createElement(import_react_ui_list.List.Item, {
|
|
109
|
-
key: trigger2.id,
|
|
110
|
-
item: trigger2,
|
|
111
|
-
classNames: (0, import_react_ui_theme.mx)(grid, import_react_ui_theme.ghostHover, "items-center", "px-2")
|
|
112
|
-
}, /* @__PURE__ */ import_react.default.createElement(import_react_ui.Input.Root, null, /* @__PURE__ */ import_react.default.createElement(import_react_ui.Input.Switch, {
|
|
113
|
-
checked: trigger2.enabled,
|
|
114
|
-
onCheckedChange: (checked) => trigger2.enabled = checked
|
|
115
|
-
})), /* @__PURE__ */ import_react.default.createElement("div", {
|
|
116
|
-
className: "flex"
|
|
117
|
-
}, /* @__PURE__ */ import_react.default.createElement(import_react_ui_list.List.ItemTitle, {
|
|
118
|
-
classNames: "px-1 cursor-pointer w-0 shrink truncate",
|
|
119
|
-
onClick: () => handleSelect(trigger2)
|
|
120
|
-
}, getFunctionName(scripts, functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ import_react.default.createElement(import_react_ui.Clipboard.IconButton, {
|
|
121
|
-
label: t(copyAction.translationKey),
|
|
122
|
-
value: copyAction.contentProvider()
|
|
123
|
-
})), /* @__PURE__ */ import_react.default.createElement(import_react_ui_list.List.ItemDeleteButton, {
|
|
124
|
-
onClick: () => handleDelete(trigger2)
|
|
125
|
-
}));
|
|
126
|
-
}))), triggers.length > 0 && /* @__PURE__ */ import_react.default.createElement(import_react_ui.Separator, {
|
|
127
|
-
classNames: "mlb-4"
|
|
128
|
-
}), /* @__PURE__ */ import_react.default.createElement(import_react_ui.IconButton, {
|
|
129
|
-
icon: "ph--plus--regular",
|
|
130
|
-
label: t("new trigger label"),
|
|
131
|
-
onClick: handleAdd
|
|
132
|
-
}));
|
|
133
|
-
} finally {
|
|
134
|
-
_effect.f();
|
|
135
|
-
}
|
|
136
|
-
};
|
|
137
|
-
var getCopyAction = (client, trigger) => {
|
|
138
|
-
if (trigger?.spec?.kind === import_functions.TriggerKind.Email) {
|
|
139
|
-
return {
|
|
140
|
-
translationKey: "trigger copy email",
|
|
141
|
-
contentProvider: () => `${(0, import_echo2.getSpace)(trigger).id}@dxos.network`
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
|
-
if (trigger?.spec?.kind === import_functions.TriggerKind.Webhook) {
|
|
145
|
-
return {
|
|
146
|
-
translationKey: "trigger copy url",
|
|
147
|
-
contentProvider: () => getWebhookUrl(client, trigger)
|
|
148
|
-
};
|
|
149
|
-
}
|
|
150
|
-
return void 0;
|
|
151
|
-
};
|
|
152
|
-
var getWebhookUrl = (client, trigger) => {
|
|
153
|
-
const spaceId = (0, import_echo2.getSpace)(trigger).id;
|
|
154
|
-
const edgeUrl = new URL(client.config.values.runtime.services.edge.url);
|
|
155
|
-
const isSecure = edgeUrl.protocol.startsWith("https") || edgeUrl.protocol.startsWith("wss");
|
|
156
|
-
edgeUrl.protocol = isSecure ? "https" : "http";
|
|
157
|
-
return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
|
|
158
|
-
};
|
|
159
|
-
var getFunctionName = (scripts, functions, trigger) => {
|
|
160
|
-
const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}\u2026`;
|
|
161
|
-
const functionObject = functions.find((fn) => fn === trigger.function?.target);
|
|
162
|
-
if (!functionObject) {
|
|
163
|
-
return shortId;
|
|
164
|
-
}
|
|
165
|
-
return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;
|
|
166
|
-
};
|
|
167
|
-
var AutomationPanel_default = AutomationPanel;
|
|
168
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
169
|
-
0 && (module.exports = {
|
|
170
|
-
AutomationPanel,
|
|
171
|
-
AutomationPanel_default
|
|
172
|
-
});
|
|
173
|
-
//# sourceMappingURL=chunk-IXUCZ3YY.cjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/AutomationPanel/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Schema } from 'effect';\nimport React, { useState } from 'react';\n\nimport { Filter, Obj } from '@dxos/echo';\nimport {\n FunctionType,\n FunctionTrigger,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n ScriptType,\n TriggerKind,\n} from '@dxos/functions';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { useQuery, type Space, 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?: Obj.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.type(FunctionTrigger));\n const functions = useQuery(space, Filter.type(FunctionType));\n const scripts = useQuery(space, Filter.type(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(Obj.make(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(Obj.make(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 if (trigger) {\n return (\n <ControlItem title={t('trigger editor title')}>\n <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />\n </ControlItem>\n );\n }\n\n return (\n <div className={controlItemClasses}>\n {triggers.length > 0 && (\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 )}\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};\n\nconst getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.kind === TriggerKind.Email) {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.kind === TriggerKind.Webhook) {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTriggerType) => {\n // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function.dxn.toString().slice(0, 16)}…`;\n const functionObject = functions.find((fn) => fn === trigger.function?.target);\n if (!functionObject) {\n return shortId;\n }\n\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AutomationPanel } from './AutomationPanel';\n\nexport * from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["import_echo", "grid", "AutomationPanel", "space", "object", "initialTrigger", "onDone", "t", "useTranslation", "AUTOMATION_PLUGIN", "client", "useClient", "triggers", "useQuery", "Filter", "type", "FunctionTrigger", "functions", "FunctionType", "scripts", "ScriptType", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "id", "_", "values", "handleAdd", "Obj", "make", "FunctionTriggerSchema", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "React", "ControlItem", "title", "TriggerEditor", "onSave", "onCancel", "div", "className", "controlItemClasses", "length", "List", "Root", "items", "isItem", "Schema", "is", "getId", "field", "role", "map", "copyAction", "getCopyAction", "Item", "key", "item", "classNames", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Clipboard", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "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
|
-
}
|
|
@@ -1,253 +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_LQ6XK4N5_exports = {};
|
|
30
|
-
__export(chunk_LQ6XK4N5_exports, {
|
|
31
|
-
TriggerEditor: () => TriggerEditor
|
|
32
|
-
});
|
|
33
|
-
module.exports = __toCommonJS(chunk_LQ6XK4N5_exports);
|
|
34
|
-
var import_chunk_3EF7MLFX = require("./chunk-3EF7MLFX.cjs");
|
|
35
|
-
var import_tracking = require("@preact-signals/safe-react/tracking");
|
|
36
|
-
var import_react = __toESM(require("react"));
|
|
37
|
-
var import_conductor = require("@dxos/conductor");
|
|
38
|
-
var import_echo = require("@dxos/echo");
|
|
39
|
-
var import_functions = require("@dxos/functions");
|
|
40
|
-
var import_echo2 = require("@dxos/react-client/echo");
|
|
41
|
-
var import_react_ui_form = require("@dxos/react-ui-form");
|
|
42
|
-
var import_tracking2 = require("@preact-signals/safe-react/tracking");
|
|
43
|
-
var import_react2 = __toESM(require("react"));
|
|
44
|
-
var import_echo3 = require("@dxos/echo");
|
|
45
|
-
var import_react_ui = require("@dxos/react-ui");
|
|
46
|
-
var import_react_ui_form2 = require("@dxos/react-ui-form");
|
|
47
|
-
var import_tracking3 = require("@preact-signals/safe-react/tracking");
|
|
48
|
-
var import_react3 = __toESM(require("react"));
|
|
49
|
-
var import_functions2 = require("@dxos/functions");
|
|
50
|
-
var import_react_ui2 = require("@dxos/react-ui");
|
|
51
|
-
var import_react_ui_form3 = require("@dxos/react-ui-form");
|
|
52
|
-
var FunctionInputEditor = ({ functions, getValue, onValueChange, onQueryRefOptions }) => {
|
|
53
|
-
var _effect = (0, import_tracking2.useSignals)();
|
|
54
|
-
try {
|
|
55
|
-
const selectedFunctionValue = (0, import_react_ui_form2.useFormValues)([
|
|
56
|
-
"function"
|
|
57
|
-
]);
|
|
58
|
-
const selectedFunctionId = (0, import_react2.useMemo)(() => {
|
|
59
|
-
if (import_echo3.Ref.isRef(selectedFunctionValue)) {
|
|
60
|
-
return selectedFunctionValue.dxn.toString().split("dxn:echo:@:").at(1);
|
|
61
|
-
}
|
|
62
|
-
}, [
|
|
63
|
-
selectedFunctionValue
|
|
64
|
-
]);
|
|
65
|
-
const selectedFunction = (0, import_react2.useMemo)(() => functions.find((fn) => fn.id === selectedFunctionId), [
|
|
66
|
-
functions,
|
|
67
|
-
selectedFunctionId
|
|
68
|
-
]);
|
|
69
|
-
(0, import_react_ui.useOnTransition)(
|
|
70
|
-
// Clear function parameter input when the function changes.
|
|
71
|
-
selectedFunctionValue,
|
|
72
|
-
(prevValue) => prevValue !== void 0 && prevValue !== selectedFunctionValue,
|
|
73
|
-
(currValue) => currValue !== void 0,
|
|
74
|
-
() => onValueChange("object", {})
|
|
75
|
-
);
|
|
76
|
-
const inputSchema = (0, import_react2.useMemo)(() => selectedFunction?.inputSchema, [
|
|
77
|
-
selectedFunction
|
|
78
|
-
]);
|
|
79
|
-
const effectSchema = (0, import_react2.useMemo)(() => inputSchema ? import_echo3.Type.toEffectSchema(inputSchema) : void 0, [
|
|
80
|
-
inputSchema
|
|
81
|
-
]);
|
|
82
|
-
const propertyCount = inputSchema?.properties ? Object.keys(inputSchema.properties).length : 0;
|
|
83
|
-
const values = (0, import_react2.useMemo)(() => getValue() ?? {}, [
|
|
84
|
-
getValue
|
|
85
|
-
]);
|
|
86
|
-
const handleValuesChanged = (0, import_react2.useCallback)((values2) => {
|
|
87
|
-
onValueChange("object", values2);
|
|
88
|
-
}, [
|
|
89
|
-
onValueChange
|
|
90
|
-
]);
|
|
91
|
-
if (selectedFunction === void 0 || effectSchema === void 0 || propertyCount === 0) {
|
|
92
|
-
return null;
|
|
93
|
-
}
|
|
94
|
-
return /* @__PURE__ */ import_react2.default.createElement(import_react2.default.Fragment, null, /* @__PURE__ */ import_react2.default.createElement("h3", {
|
|
95
|
-
className: "text-md"
|
|
96
|
-
}, "Function parameters"), /* @__PURE__ */ import_react2.default.createElement(import_react_ui_form2.Form, {
|
|
97
|
-
schema: effectSchema,
|
|
98
|
-
values,
|
|
99
|
-
onValuesChanged: handleValuesChanged,
|
|
100
|
-
onQueryRefOptions,
|
|
101
|
-
outerSpacing: false
|
|
102
|
-
}));
|
|
103
|
-
} finally {
|
|
104
|
-
_effect.f();
|
|
105
|
-
}
|
|
106
|
-
};
|
|
107
|
-
var SpecSelector = (props) => {
|
|
108
|
-
var _effect = (0, import_tracking3.useSignals)();
|
|
109
|
-
try {
|
|
110
|
-
const { t } = (0, import_react_ui2.useTranslation)(import_chunk_3EF7MLFX.AUTOMATION_PLUGIN);
|
|
111
|
-
const specProps = (0, import_react_ui_form3.useInputProps)([
|
|
112
|
-
"spec"
|
|
113
|
-
]);
|
|
114
|
-
const handleTypeChange = (0, import_react3.useCallback)((_type, value) => {
|
|
115
|
-
const getDefaultTriggerSpec = (kind) => {
|
|
116
|
-
switch (kind) {
|
|
117
|
-
case import_functions2.TriggerKind.Timer:
|
|
118
|
-
return {
|
|
119
|
-
kind: import_functions2.TriggerKind.Timer,
|
|
120
|
-
cron: ""
|
|
121
|
-
};
|
|
122
|
-
case import_functions2.TriggerKind.Subscription:
|
|
123
|
-
return {
|
|
124
|
-
kind: import_functions2.TriggerKind.Subscription,
|
|
125
|
-
filter: {}
|
|
126
|
-
};
|
|
127
|
-
case import_functions2.TriggerKind.Queue:
|
|
128
|
-
return {
|
|
129
|
-
kind: import_functions2.TriggerKind.Queue,
|
|
130
|
-
queue: ""
|
|
131
|
-
};
|
|
132
|
-
case import_functions2.TriggerKind.Email:
|
|
133
|
-
return {
|
|
134
|
-
kind: import_functions2.TriggerKind.Email
|
|
135
|
-
};
|
|
136
|
-
case import_functions2.TriggerKind.Webhook:
|
|
137
|
-
return {
|
|
138
|
-
kind: import_functions2.TriggerKind.Webhook
|
|
139
|
-
};
|
|
140
|
-
default:
|
|
141
|
-
return void 0;
|
|
142
|
-
}
|
|
143
|
-
};
|
|
144
|
-
const defaultSpec = getDefaultTriggerSpec(value);
|
|
145
|
-
if (!defaultSpec) {
|
|
146
|
-
return;
|
|
147
|
-
}
|
|
148
|
-
specProps.onValueChange("object", defaultSpec);
|
|
149
|
-
}, [
|
|
150
|
-
specProps
|
|
151
|
-
]);
|
|
152
|
-
const options = (0, import_react3.useMemo)(() => Object.values(import_functions2.TriggerKind).map((kind) => ({
|
|
153
|
-
value: kind,
|
|
154
|
-
label: t(`trigger type ${kind}`)
|
|
155
|
-
})), [
|
|
156
|
-
t
|
|
157
|
-
]);
|
|
158
|
-
return /* @__PURE__ */ import_react3.default.createElement(import_react_ui_form3.SelectInput, {
|
|
159
|
-
...props,
|
|
160
|
-
options,
|
|
161
|
-
onValueChange: handleTypeChange
|
|
162
|
-
});
|
|
163
|
-
} finally {
|
|
164
|
-
_effect.f();
|
|
165
|
-
}
|
|
166
|
-
};
|
|
167
|
-
var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
|
|
168
|
-
var _effect = (0, import_tracking.useSignals)();
|
|
169
|
-
try {
|
|
170
|
-
const handleSave = (values) => {
|
|
171
|
-
onSave?.(values);
|
|
172
|
-
};
|
|
173
|
-
const handleRefQueryLookup = (0, import_react_ui_form.useRefQueryLookupHandler)({
|
|
174
|
-
space
|
|
175
|
-
});
|
|
176
|
-
const Custom = useCustomInputs(space, handleRefQueryLookup);
|
|
177
|
-
return /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.Form, {
|
|
178
|
-
outerSpacing: false,
|
|
179
|
-
Custom,
|
|
180
|
-
schema: import_functions.FunctionTriggerSchema,
|
|
181
|
-
values: trigger,
|
|
182
|
-
onSave: handleSave,
|
|
183
|
-
onCancel,
|
|
184
|
-
onQueryRefOptions: handleRefQueryLookup
|
|
185
|
-
});
|
|
186
|
-
} finally {
|
|
187
|
-
_effect.f();
|
|
188
|
-
}
|
|
189
|
-
};
|
|
190
|
-
var useCustomInputs = (space, onQueryRefOptions) => {
|
|
191
|
-
const functions = (0, import_echo2.useQuery)(space, import_echo2.Filter.type(import_functions.FunctionType));
|
|
192
|
-
const workflows = (0, import_echo2.useQuery)(space, import_echo2.Filter.type(import_conductor.ComputeGraph));
|
|
193
|
-
const scripts = (0, import_echo2.useQuery)(space, import_echo2.Filter.type(import_functions.ScriptType));
|
|
194
|
-
return (0, import_react.useMemo)(() => ({
|
|
195
|
-
// Function selector.
|
|
196
|
-
["function"]: (props) => {
|
|
197
|
-
const getValue = (0, import_react.useCallback)(() => {
|
|
198
|
-
const formValue = props.getValue();
|
|
199
|
-
if (import_echo2.Ref.isRef(formValue)) {
|
|
200
|
-
return formValue.dxn.toString();
|
|
201
|
-
}
|
|
202
|
-
return void 0;
|
|
203
|
-
}, [
|
|
204
|
-
props
|
|
205
|
-
]);
|
|
206
|
-
const handleOnValueChange = (0, import_react.useCallback)((_type, dxnString) => {
|
|
207
|
-
const dxn = import_echo.Type.DXN.parse(dxnString);
|
|
208
|
-
if (dxn) {
|
|
209
|
-
const ref = import_echo2.Ref.fromDXN(dxn);
|
|
210
|
-
props.onValueChange("object", ref);
|
|
211
|
-
}
|
|
212
|
-
}, [
|
|
213
|
-
props.onValueChange
|
|
214
|
-
]);
|
|
215
|
-
return /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.SelectInput, {
|
|
216
|
-
...props,
|
|
217
|
-
getValue,
|
|
218
|
-
onValueChange: handleOnValueChange,
|
|
219
|
-
options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
|
|
220
|
-
});
|
|
221
|
-
},
|
|
222
|
-
// Spec selector.
|
|
223
|
-
["spec.kind"]: SpecSelector,
|
|
224
|
-
// Function input editor.
|
|
225
|
-
["input"]: (props) => /* @__PURE__ */ import_react.default.createElement(FunctionInputEditor, {
|
|
226
|
-
...props,
|
|
227
|
-
functions,
|
|
228
|
-
onQueryRefOptions
|
|
229
|
-
})
|
|
230
|
-
}), [
|
|
231
|
-
workflows,
|
|
232
|
-
scripts,
|
|
233
|
-
functions
|
|
234
|
-
]);
|
|
235
|
-
};
|
|
236
|
-
var getWorkflowOptions = (graphs) => {
|
|
237
|
-
return graphs.map((graph) => ({
|
|
238
|
-
label: `compute-${graph.id}`,
|
|
239
|
-
value: `dxn:echo:@:${graph.id}`
|
|
240
|
-
}));
|
|
241
|
-
};
|
|
242
|
-
var getFunctionOptions = (scripts, functions) => {
|
|
243
|
-
const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
|
|
244
|
-
return functions.map((fn) => ({
|
|
245
|
-
label: getLabel(fn),
|
|
246
|
-
value: `dxn:echo:@:${fn.id}`
|
|
247
|
-
}));
|
|
248
|
-
};
|
|
249
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
250
|
-
0 && (module.exports = {
|
|
251
|
-
TriggerEditor
|
|
252
|
-
});
|
|
253
|
-
//# sourceMappingURL=chunk-LQ6XK4N5.cjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx", "../../../src/components/TriggerEditor/FunctionInputEditor.tsx", "../../../src/components/TriggerEditor/SpecSelector.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { ComputeGraph } from '@dxos/conductor';\nimport { Type } from '@dxos/echo';\nimport {\n FunctionType,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n type FunctionTrigger,\n ScriptType,\n} from '@dxos/functions';\nimport { Filter, Ref, useQuery, type Space } from '@dxos/react-client/echo';\nimport { type CustomInputMap, Form, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { FunctionInputEditor, type FunctionInputEditorProps } from './FunctionInputEditor';\nimport { SpecSelector } from './SpecSelector';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const handleSave = (values: FunctionTriggerType) => {\n onSave?.(values);\n };\n\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n const Custom = useCustomInputs(space, handleRefQueryLookup);\n\n return (\n <Form\n outerSpacing={false}\n Custom={Custom}\n schema={FunctionTriggerSchema}\n values={trigger}\n onSave={handleSave}\n onCancel={onCancel}\n onQueryRefOptions={handleRefQueryLookup}\n />\n );\n};\n\nconst useCustomInputs = (space: Space, onQueryRefOptions: FunctionInputEditorProps['onQueryRefOptions']) => {\n const functions = useQuery(space, Filter.type(FunctionType));\n const workflows = useQuery(space, Filter.type(ComputeGraph));\n const scripts = useQuery(space, Filter.type(ScriptType));\n\n return useMemo(\n (): CustomInputMap => ({\n // Function selector.\n ['function' satisfies keyof FunctionTriggerType]: (props) => {\n const getValue = useCallback(() => {\n const formValue = props.getValue();\n if (Ref.isRef(formValue)) {\n return formValue.dxn.toString() as string;\n }\n return undefined;\n }, [props]);\n\n const handleOnValueChange = useCallback(\n (_type: any, dxnString: string) => {\n const dxn = Type.DXN.parse(dxnString);\n if (dxn) {\n const ref = Ref.fromDXN(dxn);\n props.onValueChange('object', ref);\n }\n },\n [props.onValueChange],\n );\n\n return (\n <SelectInput\n {...props}\n getValue={getValue as any}\n onValueChange={handleOnValueChange}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n );\n },\n\n // Spec selector.\n ['spec.kind' as const]: SpecSelector,\n\n // Function input editor.\n ['input' as const]: (props) => (\n <FunctionInputEditor {...props} functions={functions} onQueryRefOptions={onQueryRefOptions} />\n ),\n }),\n [workflows, scripts, functions],\n );\n};\n\nconst getWorkflowOptions = (graphs: ComputeGraph[]) => {\n return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));\n};\n\nconst getFunctionOptions = (scripts: ScriptType[], functions: FunctionType[]) => {\n const getLabel = (fn: FunctionType) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:echo:@:${fn.id}` }));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Ref, Type } from '@dxos/echo';\nimport { type JsonPath } 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 (Ref.isRef(selectedFunctionValue)) {\n return selectedFunctionValue.dxn.toString().split('dxn:echo:@:').at(1);\n }\n }, [selectedFunctionValue]);\n\n const selectedFunction = useMemo(\n () => functions.find((fn) => fn.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 ? Type.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 onValuesChanged={handleValuesChanged}\n onQueryRefOptions={onQueryRefOptions}\n outerSpacing={false}\n />\n </>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { type FunctionTriggerType, TriggerKind, type TriggerType } from '@dxos/functions';\nimport { useTranslation } from '@dxos/react-ui';\nimport { SelectInput, type InputProps, useInputProps } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type SpecSelectorProps = InputProps;\n\nexport const SpecSelector = (props: SpecSelectorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const specProps = useInputProps(['spec' satisfies keyof FunctionTriggerType]);\n\n const handleTypeChange = useCallback(\n (_type: any, value: string): TriggerType | undefined => {\n const getDefaultTriggerSpec = (kind: string) => {\n switch (kind) {\n case TriggerKind.Timer:\n return { kind: TriggerKind.Timer, cron: '' };\n case TriggerKind.Subscription:\n return { kind: TriggerKind.Subscription, filter: {} };\n case TriggerKind.Queue:\n return { kind: TriggerKind.Queue, queue: '' };\n case TriggerKind.Email:\n return { kind: TriggerKind.Email };\n case TriggerKind.Webhook:\n return { kind: TriggerKind.Webhook };\n default:\n return undefined;\n }\n };\n\n const defaultSpec = getDefaultTriggerSpec(value);\n if (!defaultSpec) {\n return;\n }\n\n // Update the entire spec object, not just the `spec.kind`.\n specProps.onValueChange('object', defaultSpec);\n },\n [specProps],\n );\n\n const options = useMemo(\n () =>\n Object.values(TriggerKind).map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n })),\n [t],\n );\n\n return <SelectInput {...props} options={options} onValueChange={handleTypeChange} />;\n};\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["import_echo", "import_react", "import_react_ui_form", "import_functions", "import_react_ui", "FunctionInputEditor", "functions", "getValue", "onValueChange", "onQueryRefOptions", "selectedFunctionValue", "useFormValues", "selectedFunctionId", "useMemo", "Ref", "isRef", "dxn", "toString", "split", "at", "selectedFunction", "find", "fn", "id", "useOnTransition", "prevValue", "undefined", "currValue", "inputSchema", "effectSchema", "Type", "toEffectSchema", "propertyCount", "properties", "Object", "keys", "length", "values", "handleValuesChanged", "useCallback", "React", "h3", "className", "Form", "schema", "onValuesChanged", "outerSpacing", "SpecSelector", "props", "t", "useTranslation", "AUTOMATION_PLUGIN", "specProps", "useInputProps", "handleTypeChange", "_type", "value", "getDefaultTriggerSpec", "kind", "TriggerKind", "Timer", "cron", "Subscription", "filter", "Queue", "queue", "Email", "Webhook", "defaultSpec", "options", "map", "label", "SelectInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "handleSave", "handleRefQueryLookup", "useRefQueryLookupHandler", "Custom", "useCustomInputs", "FunctionTriggerSchema", "useQuery", "Filter", "type", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "formValue", "handleOnValueChange", "dxnString", "DXN", "parse", "ref", "fromDXN", "getWorkflowOptions", "concat", "getFunctionOptions", "graphs", "graph", "getLabel", "s", "source", "target", "name"]
|
|
7
|
-
}
|
|
@@ -1,49 +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_TH4XDKAY_exports = {};
|
|
30
|
-
__export(chunk_TH4XDKAY_exports, {
|
|
31
|
-
AutomationContainer: () => AutomationContainer,
|
|
32
|
-
AutomationPanel: () => AutomationPanel,
|
|
33
|
-
FunctionsContainer: () => FunctionsContainer,
|
|
34
|
-
FunctionsPanel: () => FunctionsPanel
|
|
35
|
-
});
|
|
36
|
-
module.exports = __toCommonJS(chunk_TH4XDKAY_exports);
|
|
37
|
-
var import_react = require("react");
|
|
38
|
-
var AutomationContainer = (0, import_react.lazy)(() => import("./AutomationContainer-B7PSJFIS.cjs"));
|
|
39
|
-
var AutomationPanel = (0, import_react.lazy)(() => import("./AutomationPanel-XYLZU4MI.cjs"));
|
|
40
|
-
var FunctionsContainer = (0, import_react.lazy)(() => import("./FunctionsContainer-4FGOQW5X.cjs"));
|
|
41
|
-
var FunctionsPanel = (0, import_react.lazy)(() => import("./FunctionsPanel-EWWAZK3W.cjs"));
|
|
42
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
43
|
-
0 && (module.exports = {
|
|
44
|
-
AutomationContainer,
|
|
45
|
-
AutomationPanel,
|
|
46
|
-
FunctionsContainer,
|
|
47
|
-
FunctionsPanel
|
|
48
|
-
});
|
|
49
|
-
//# sourceMappingURL=chunk-TH4XDKAY.cjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './TriggerEditor';\n\nexport const AutomationContainer = lazy(() => import('./AutomationContainer'));\nexport const AutomationPanel = lazy(() => import('./AutomationPanel'));\nexport const FunctionsContainer = lazy(() => import('./FunctionsContainer'));\nexport const FunctionsPanel = lazy(() => import('./FunctionsPanel'));\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,mBAAqB;AAId,IAAMA,0BAAsBC,mBAAK,MAAM,OAAO,oCAAA,CAAA;AAC9C,IAAMC,sBAAkBD,mBAAK,MAAM,OAAO,gCAAA,CAAA;AAC1C,IAAME,yBAAqBF,mBAAK,MAAM,OAAO,mCAAA,CAAA;AAC7C,IAAMG,qBAAiBH,mBAAK,MAAM,OAAO,+BAAA,CAAA;",
|
|
6
|
-
"names": ["AutomationContainer", "lazy", "AutomationPanel", "FunctionsContainer", "FunctionsPanel"]
|
|
7
|
-
}
|