@dxos/plugin-automation 0.8.4-main.f9ba587 → 0.8.4-main.fffef41
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-7OECLR5N.mjs +11 -0
- package/dist/lib/browser/AutomationSettings-KCZISXI6.mjs +68 -0
- package/dist/lib/browser/AutomationSettings-KCZISXI6.mjs.map +7 -0
- package/dist/lib/browser/FunctionsContainer-MIWEISRR.mjs +151 -0
- package/dist/lib/browser/FunctionsContainer-MIWEISRR.mjs.map +7 -0
- package/dist/lib/browser/{FunctionsPanel-56ZKRVM5.mjs → FunctionsPanel-CRW6SJUN.mjs} +3 -3
- package/dist/lib/browser/{app-graph-builder-ZTAUTFI4.mjs → app-graph-builder-W7LLC6XW.mjs} +13 -12
- package/dist/lib/browser/app-graph-builder-W7LLC6XW.mjs.map +7 -0
- package/dist/lib/browser/chunk-EPEXQP45.mjs +14 -0
- package/dist/lib/browser/chunk-EPEXQP45.mjs.map +7 -0
- package/dist/lib/browser/{chunk-FSJZXTS2.mjs → chunk-JW7XSPYW.mjs} +69 -32
- package/dist/lib/browser/chunk-JW7XSPYW.mjs.map +7 -0
- package/dist/lib/browser/chunk-LZQFZO3B.mjs +17 -0
- package/dist/lib/browser/chunk-LZQFZO3B.mjs.map +7 -0
- package/dist/lib/browser/chunk-NAPXRXTY.mjs +100 -0
- package/dist/lib/browser/chunk-NAPXRXTY.mjs.map +7 -0
- package/dist/lib/browser/{chunk-ERTIGJYE.mjs → chunk-QKFBHAGN.mjs} +72 -35
- package/dist/lib/browser/chunk-QKFBHAGN.mjs.map +7 -0
- package/dist/lib/browser/{chunk-LYJVTIVD.mjs → chunk-TWWFNOIR.mjs} +30 -15
- package/dist/lib/browser/chunk-TWWFNOIR.mjs.map +7 -0
- package/dist/lib/browser/chunk-XAKZ4ANY.mjs +15 -0
- package/dist/lib/browser/chunk-XAKZ4ANY.mjs.map +7 -0
- package/dist/lib/browser/{chunk-S2LE7SYB.mjs → chunk-YBPJCY3F.mjs} +6 -7
- package/dist/lib/browser/chunk-YBPJCY3F.mjs.map +7 -0
- package/dist/lib/browser/compute-runtime-EIQTHJFZ.mjs +113 -0
- package/dist/lib/browser/compute-runtime-EIQTHJFZ.mjs.map +7 -0
- package/dist/lib/browser/hooks/index.mjs +13 -0
- package/dist/lib/browser/index.mjs +48 -19
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/{intent-resolver-YLRSMLH4.mjs → intent-resolver-5HR7M7T6.mjs} +15 -14
- package/dist/lib/browser/intent-resolver-5HR7M7T6.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-4DFSM7OX.mjs → react-surface-YQW7WCFW.mjs} +20 -20
- package/dist/lib/browser/react-surface-YQW7WCFW.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +8 -0
- package/dist/lib/node-esm/{AutomationPanel-YYUMSK2W.mjs → AutomationPanel-HCVFNHGQ.mjs} +4 -4
- package/dist/lib/node-esm/AutomationSettings-UUUPVNUJ.mjs +69 -0
- package/dist/lib/node-esm/AutomationSettings-UUUPVNUJ.mjs.map +7 -0
- package/dist/lib/node-esm/FunctionsContainer-6OB3JN5O.mjs +152 -0
- package/dist/lib/node-esm/FunctionsContainer-6OB3JN5O.mjs.map +7 -0
- package/dist/lib/node-esm/{FunctionsPanel-KGIOZSPZ.mjs → FunctionsPanel-RVVCS6VH.mjs} +3 -3
- package/dist/lib/node-esm/{app-graph-builder-3FP63ZSG.mjs → app-graph-builder-SLQOO7GH.mjs} +13 -12
- package/dist/lib/node-esm/app-graph-builder-SLQOO7GH.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-HIMYPGHF.mjs → chunk-6YRKST6M.mjs} +72 -35
- package/dist/lib/node-esm/chunk-6YRKST6M.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-CEVIVRTY.mjs +19 -0
- package/dist/lib/node-esm/chunk-CEVIVRTY.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-CPP35BE6.mjs +16 -0
- package/dist/lib/node-esm/chunk-CPP35BE6.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-UKATFY3R.mjs → chunk-ECJKIUBO.mjs} +6 -7
- package/dist/lib/node-esm/chunk-ECJKIUBO.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-KB7NFEYY.mjs +16 -0
- package/dist/lib/node-esm/chunk-KB7NFEYY.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-PICJ2REN.mjs +101 -0
- package/dist/lib/node-esm/chunk-PICJ2REN.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-ZGPUV5VS.mjs → chunk-RVK52XGK.mjs} +30 -15
- package/dist/lib/node-esm/chunk-RVK52XGK.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-AZH66CED.mjs → chunk-W76WUTZY.mjs} +69 -32
- package/dist/lib/node-esm/chunk-W76WUTZY.mjs.map +7 -0
- package/dist/lib/node-esm/compute-runtime-URROOC34.mjs +114 -0
- package/dist/lib/node-esm/compute-runtime-URROOC34.mjs.map +7 -0
- package/dist/lib/node-esm/hooks/index.mjs +14 -0
- package/dist/lib/node-esm/hooks/index.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +48 -19
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/{intent-resolver-LU7EYWEO.mjs → intent-resolver-KDRYB5BC.mjs} +15 -14
- package/dist/lib/node-esm/intent-resolver-KDRYB5BC.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-3PNW7NDW.mjs → react-surface-NNHYNBO6.mjs} +20 -20
- package/dist/lib/node-esm/react-surface-NNHYNBO6.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 +1 -1
- 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 +20 -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/capabilities/react-surface.d.ts.map +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 +48 -4
- 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/FunctionsRegistry/FunctionsRegistry.d.ts +8 -0
- package/dist/types/src/components/FunctionsRegistry/FunctionsRegistry.d.ts.map +1 -0
- package/dist/types/src/components/FunctionsRegistry/index.d.ts +2 -0
- package/dist/types/src/components/FunctionsRegistry/index.d.ts.map +1 -0
- package/dist/types/src/components/TriggerEditor/FunctionInputEditor.d.ts +2 -2
- package/dist/types/src/components/TriggerEditor/FunctionInputEditor.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 +7 -5
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts +49 -4
- 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/events.d.ts +4 -0
- package/dist/types/src/events.d.ts.map +1 -0
- 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 +12 -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 +3 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +0 -1
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +5 -0
- 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} +4 -4
- package/dist/types/src/types/schema.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +66 -41
- package/src/AutomationPlugin.tsx +37 -31
- package/src/capabilities/app-graph-builder.ts +16 -15
- package/src/capabilities/capabilities.ts +41 -0
- package/src/capabilities/compute-runtime.ts +127 -0
- package/src/capabilities/index.ts +3 -0
- package/src/capabilities/intent-resolver.ts +11 -11
- package/src/capabilities/react-surface.tsx +15 -15
- package/src/components/AutomationPanel/AutomationPanel.stories.tsx +16 -17
- package/src/components/AutomationPanel/AutomationPanel.tsx +105 -53
- package/src/components/AutomationSettings.tsx +30 -0
- package/src/components/FunctionsContainer.tsx +18 -13
- package/src/components/FunctionsPanel/FunctionsPanel.tsx +35 -16
- package/src/components/FunctionsRegistry/FunctionsRegistry.tsx +135 -0
- package/src/components/FunctionsRegistry/index.ts +5 -0
- package/src/components/TriggerEditor/FunctionInputEditor.tsx +10 -4
- package/src/components/TriggerEditor/SpecSelector.tsx +23 -17
- package/src/components/TriggerEditor/TriggerEditor.stories.tsx +70 -27
- package/src/components/TriggerEditor/TriggerEditor.tsx +45 -25
- package/src/components/TriggerSettings.tsx +25 -0
- package/src/components/index.ts +1 -1
- package/src/events.ts +11 -0
- package/src/hooks/index.ts +6 -0
- package/src/hooks/useComputeRuntimeCallback.ts +68 -0
- package/src/hooks/useTriggerRuntimeControls.ts +53 -0
- package/src/index.ts +3 -0
- package/src/meta.ts +6 -5
- package/src/testing/test-functions.ts +1 -1
- package/src/translations.ts +7 -0
- package/src/types/index.ts +5 -0
- package/src/{types.ts → types/schema.ts} +3 -5
- package/dist/lib/browser/AutomationContainer-VZNV2ZQF.mjs +0 -38
- package/dist/lib/browser/AutomationContainer-VZNV2ZQF.mjs.map +0 -7
- package/dist/lib/browser/AutomationPanel-ZWA6GOFY.mjs +0 -11
- package/dist/lib/browser/FunctionsContainer-IOB333TX.mjs +0 -39
- package/dist/lib/browser/FunctionsContainer-IOB333TX.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-ZTAUTFI4.mjs.map +0 -7
- package/dist/lib/browser/chunk-ECSTS2UI.mjs +0 -14
- package/dist/lib/browser/chunk-ECSTS2UI.mjs.map +0 -7
- package/dist/lib/browser/chunk-ERTIGJYE.mjs.map +0 -7
- package/dist/lib/browser/chunk-FSJZXTS2.mjs.map +0 -7
- package/dist/lib/browser/chunk-GW5U2DGT.mjs +0 -15
- package/dist/lib/browser/chunk-GW5U2DGT.mjs.map +0 -7
- package/dist/lib/browser/chunk-LYJVTIVD.mjs.map +0 -7
- package/dist/lib/browser/chunk-S2LE7SYB.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-YLRSMLH4.mjs.map +0 -7
- package/dist/lib/browser/react-surface-4DFSM7OX.mjs.map +0 -7
- package/dist/lib/browser/types.mjs +0 -8
- package/dist/lib/node-esm/AutomationContainer-WMIH3F4V.mjs +0 -39
- package/dist/lib/node-esm/AutomationContainer-WMIH3F4V.mjs.map +0 -7
- package/dist/lib/node-esm/FunctionsContainer-DJWB6WFH.mjs +0 -40
- package/dist/lib/node-esm/FunctionsContainer-DJWB6WFH.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-3FP63ZSG.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-AZH66CED.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HIMYPGHF.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NK5N3QKD.mjs +0 -17
- package/dist/lib/node-esm/chunk-NK5N3QKD.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-SGZPTJ47.mjs +0 -16
- package/dist/lib/node-esm/chunk-SGZPTJ47.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-UKATFY3R.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ZGPUV5VS.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-LU7EYWEO.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-3PNW7NDW.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-ZWA6GOFY.mjs.map → AutomationPanel-7OECLR5N.mjs.map} +0 -0
- /package/dist/lib/browser/{FunctionsPanel-56ZKRVM5.mjs.map → FunctionsPanel-CRW6SJUN.mjs.map} +0 -0
- /package/dist/lib/browser/{types.mjs.map → hooks/index.mjs.map} +0 -0
- /package/dist/lib/{node-esm/AutomationPanel-YYUMSK2W.mjs.map → browser/types/index.mjs.map} +0 -0
- /package/dist/lib/node-esm/{FunctionsPanel-KGIOZSPZ.mjs.map → AutomationPanel-HCVFNHGQ.mjs.map} +0 -0
- /package/dist/lib/node-esm/{types.mjs.map → FunctionsPanel-RVVCS6VH.mjs.map} +0 -0
|
@@ -5,13 +5,13 @@
|
|
|
5
5
|
import React, { useCallback, useMemo } from 'react';
|
|
6
6
|
|
|
7
7
|
import { Ref, Type } from '@dxos/echo';
|
|
8
|
-
import { type JsonPath } from '@dxos/echo
|
|
9
|
-
import { type
|
|
8
|
+
import { type JsonPath } from '@dxos/echo/internal';
|
|
9
|
+
import { type Function } from '@dxos/functions';
|
|
10
10
|
import { useOnTransition } from '@dxos/react-ui';
|
|
11
11
|
import { Form, type FormInputStateProps, type QueryRefOptions, useFormValues } from '@dxos/react-ui-form';
|
|
12
12
|
|
|
13
13
|
export type FunctionInputEditorProps = {
|
|
14
|
-
functions:
|
|
14
|
+
functions: Function.Function[];
|
|
15
15
|
onQueryRefOptions: QueryRefOptions;
|
|
16
16
|
} & FormInputStateProps;
|
|
17
17
|
|
|
@@ -39,7 +39,13 @@ export const FunctionInputEditor = ({
|
|
|
39
39
|
useOnTransition(
|
|
40
40
|
// Clear function parameter input when the function changes.
|
|
41
41
|
selectedFunctionValue,
|
|
42
|
-
(prevValue) =>
|
|
42
|
+
(prevValue) => {
|
|
43
|
+
if (!Ref.isRef(prevValue) || !Ref.isRef(selectedFunctionValue)) {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
return prevValue.dxn.toString() !== selectedFunctionValue.dxn.toString();
|
|
48
|
+
},
|
|
43
49
|
(currValue) => currValue !== undefined,
|
|
44
50
|
() => onValueChange('object', {}),
|
|
45
51
|
);
|
|
@@ -4,32 +4,38 @@
|
|
|
4
4
|
|
|
5
5
|
import React, { useCallback, useMemo } from 'react';
|
|
6
6
|
|
|
7
|
-
import {
|
|
7
|
+
import { Filter, Query } from '@dxos/echo';
|
|
8
|
+
import { Trigger } from '@dxos/functions';
|
|
8
9
|
import { useTranslation } from '@dxos/react-ui';
|
|
9
|
-
import {
|
|
10
|
+
import { type InputProps, SelectInput, useInputProps } from '@dxos/react-ui-form';
|
|
10
11
|
|
|
11
|
-
import {
|
|
12
|
+
import { meta } from '../../meta';
|
|
12
13
|
|
|
13
14
|
export type SpecSelectorProps = InputProps;
|
|
14
15
|
|
|
15
16
|
export const SpecSelector = (props: SpecSelectorProps) => {
|
|
16
|
-
const { t } = useTranslation(
|
|
17
|
-
const specProps = useInputProps(['spec' satisfies keyof
|
|
17
|
+
const { t } = useTranslation(meta.id);
|
|
18
|
+
const specProps = useInputProps(['spec' satisfies keyof Trigger.Trigger]);
|
|
18
19
|
|
|
19
20
|
const handleTypeChange = useCallback(
|
|
20
|
-
(_type: any, value: string):
|
|
21
|
+
(_type: any, value: string): Trigger.Spec | undefined => {
|
|
21
22
|
const getDefaultTriggerSpec = (kind: string) => {
|
|
22
23
|
switch (kind) {
|
|
23
|
-
case
|
|
24
|
-
return { kind:
|
|
25
|
-
case
|
|
26
|
-
return {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
24
|
+
case 'timer':
|
|
25
|
+
return { kind: 'timer', cron: '' };
|
|
26
|
+
case 'subscription':
|
|
27
|
+
return {
|
|
28
|
+
kind: 'subscription',
|
|
29
|
+
query: {
|
|
30
|
+
ast: Query.select(Filter.nothing()).ast,
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
case 'queue':
|
|
34
|
+
return { kind: 'queue', queue: 'dxn:' };
|
|
35
|
+
case 'email':
|
|
36
|
+
return { kind: 'email' };
|
|
37
|
+
case 'webhook':
|
|
38
|
+
return { kind: 'webhook' };
|
|
33
39
|
default:
|
|
34
40
|
return undefined;
|
|
35
41
|
}
|
|
@@ -48,7 +54,7 @@ export const SpecSelector = (props: SpecSelectorProps) => {
|
|
|
48
54
|
|
|
49
55
|
const options = useMemo(
|
|
50
56
|
() =>
|
|
51
|
-
|
|
57
|
+
Trigger.Kinds.map((kind) => ({
|
|
52
58
|
value: kind,
|
|
53
59
|
label: t(`trigger type ${kind}`),
|
|
54
60
|
})),
|
|
@@ -2,32 +2,56 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import '@
|
|
5
|
+
import { type Meta, type StoryObj } from '@storybook/react-vite';
|
|
6
|
+
import React, { useState } from 'react';
|
|
6
7
|
|
|
7
|
-
import {
|
|
8
|
-
import
|
|
9
|
-
|
|
10
|
-
import {
|
|
11
|
-
import { FunctionType, FunctionTrigger, TriggerKind } from '@dxos/functions';
|
|
8
|
+
import { Filter, Obj, Ref, Tag, Type } from '@dxos/echo';
|
|
9
|
+
import { Function } from '@dxos/functions';
|
|
10
|
+
import { Trigger } from '@dxos/functions';
|
|
11
|
+
import { invariant } from '@dxos/invariant';
|
|
12
12
|
import { faker } from '@dxos/random';
|
|
13
|
-
import {
|
|
14
|
-
import { ContactType, withClientProvider } from '@dxos/react-client/testing';
|
|
15
|
-
import {
|
|
13
|
+
import { useQuery } from '@dxos/react-client/echo';
|
|
14
|
+
import { ContactType, useClientProvider, withClientProvider } from '@dxos/react-client/testing';
|
|
15
|
+
import { useAsyncEffect } from '@dxos/react-ui';
|
|
16
|
+
import { withLayout, withTheme } from '@dxos/react-ui/testing';
|
|
17
|
+
import { Employer, Organization, Person, Project } from '@dxos/types';
|
|
16
18
|
|
|
17
|
-
import { TriggerEditor } from './TriggerEditor';
|
|
18
19
|
import { functions } from '../../testing';
|
|
19
20
|
import { translations } from '../../translations';
|
|
20
21
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
22
|
+
import { TriggerEditor, type TriggerEditorProps } from './TriggerEditor';
|
|
23
|
+
|
|
24
|
+
const types = [
|
|
25
|
+
// TODO(burdon): Get label from annotation.
|
|
26
|
+
{ value: Organization.Organization.typename, label: 'Organization' },
|
|
27
|
+
{ value: Person.Person.typename, label: 'Person' },
|
|
28
|
+
{ value: Type.getTypename(Project.Project), label: 'Project' },
|
|
29
|
+
{ value: Employer.Employer.typename, label: 'Employer' },
|
|
30
|
+
];
|
|
31
|
+
|
|
32
|
+
const DefaultStory = (props: Partial<TriggerEditorProps>) => {
|
|
33
|
+
const { space } = useClientProvider();
|
|
34
|
+
const [trigger, setTrigger] = useState<Trigger.Trigger>();
|
|
35
|
+
const tags = useQuery(space, Filter.type(Tag.Tag));
|
|
36
|
+
|
|
37
|
+
useAsyncEffect(async () => {
|
|
26
38
|
if (!space) {
|
|
27
39
|
return;
|
|
28
40
|
}
|
|
29
41
|
|
|
30
|
-
const
|
|
42
|
+
const result = await space.db.query(Filter.type(Function.Function)).run();
|
|
43
|
+
const fn = result.objects.find((fn) => fn.name === 'example.com/function/forex');
|
|
44
|
+
invariant(fn);
|
|
45
|
+
const trigger = space.db.add(
|
|
46
|
+
Trigger.make({
|
|
47
|
+
function: Ref.make(fn),
|
|
48
|
+
spec: { kind: 'webhook' },
|
|
49
|
+
input: {
|
|
50
|
+
from: 'USD',
|
|
51
|
+
to: 'JPY',
|
|
52
|
+
},
|
|
53
|
+
}),
|
|
54
|
+
);
|
|
31
55
|
setTrigger(trigger);
|
|
32
56
|
}, [space]);
|
|
33
57
|
|
|
@@ -36,24 +60,37 @@ const DefaultStory = () => {
|
|
|
36
60
|
}
|
|
37
61
|
|
|
38
62
|
return (
|
|
39
|
-
<div role='none' className='
|
|
40
|
-
<TriggerEditor
|
|
63
|
+
<div role='none' className='is-[32rem] bs-fit border border-separator rounded-sm'>
|
|
64
|
+
<TriggerEditor
|
|
65
|
+
space={space}
|
|
66
|
+
trigger={trigger}
|
|
67
|
+
types={types}
|
|
68
|
+
tags={tags}
|
|
69
|
+
onSave={(values) => console.log('on save', values)}
|
|
70
|
+
{...props}
|
|
71
|
+
/>
|
|
41
72
|
</div>
|
|
42
73
|
);
|
|
43
74
|
};
|
|
44
75
|
|
|
45
|
-
const meta
|
|
76
|
+
const meta = {
|
|
46
77
|
title: 'plugins/plugin-automation/TriggerEditor',
|
|
47
|
-
component: TriggerEditor,
|
|
78
|
+
component: TriggerEditor as any,
|
|
48
79
|
render: DefaultStory,
|
|
49
80
|
decorators: [
|
|
81
|
+
withTheme,
|
|
82
|
+
withLayout({ container: 'column' }),
|
|
50
83
|
withClientProvider({
|
|
51
84
|
createIdentity: true,
|
|
52
85
|
createSpace: true,
|
|
53
|
-
types: [
|
|
54
|
-
|
|
86
|
+
types: [Tag.Tag, Function.Function, Trigger.Trigger, ContactType],
|
|
87
|
+
onCreateSpace: ({ space }) => {
|
|
88
|
+
space.db.add(Tag.make({ label: 'Important' }));
|
|
89
|
+
space.db.add(Tag.make({ label: 'Investor' }));
|
|
90
|
+
space.db.add(Tag.make({ label: 'New' }));
|
|
91
|
+
|
|
55
92
|
for (const fn of functions) {
|
|
56
|
-
space.db.add(
|
|
93
|
+
space.db.add(Function.make(fn));
|
|
57
94
|
}
|
|
58
95
|
Array.from({ length: 10 }).map(() => {
|
|
59
96
|
return space.db.add(
|
|
@@ -65,14 +102,20 @@ const meta: Meta = {
|
|
|
65
102
|
});
|
|
66
103
|
},
|
|
67
104
|
}),
|
|
68
|
-
withLayout({ fullscreen: true, classNames: 'flex justify-center m-2' }),
|
|
69
|
-
withTheme,
|
|
70
105
|
],
|
|
71
106
|
parameters: {
|
|
72
107
|
translations,
|
|
73
108
|
},
|
|
74
|
-
}
|
|
109
|
+
} satisfies Meta<typeof DefaultStory>;
|
|
75
110
|
|
|
76
111
|
export default meta;
|
|
77
112
|
|
|
78
|
-
|
|
113
|
+
type Story = StoryObj<typeof meta>;
|
|
114
|
+
|
|
115
|
+
export const Default: Story = {};
|
|
116
|
+
|
|
117
|
+
export const ReadonlySpec: Story = {
|
|
118
|
+
args: {
|
|
119
|
+
readonlySpec: true,
|
|
120
|
+
},
|
|
121
|
+
};
|
|
@@ -5,40 +5,38 @@
|
|
|
5
5
|
import React, { useCallback, useMemo } from 'react';
|
|
6
6
|
|
|
7
7
|
import { ComputeGraph } from '@dxos/conductor';
|
|
8
|
-
import { Type } from '@dxos/echo';
|
|
9
|
-
import {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
ScriptType,
|
|
15
|
-
} from '@dxos/functions';
|
|
16
|
-
import { Filter, Ref, useQuery, type Space } from '@dxos/react-client/echo';
|
|
17
|
-
import { type CustomInputMap, Form, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';
|
|
8
|
+
import { type Query, Type } from '@dxos/echo';
|
|
9
|
+
import { Function, Script, Trigger } from '@dxos/functions';
|
|
10
|
+
import { Filter, Ref, type Space, useQuery } from '@dxos/react-client/echo';
|
|
11
|
+
import { Input } from '@dxos/react-ui';
|
|
12
|
+
import { QueryForm, type QueryFormProps } from '@dxos/react-ui-components';
|
|
13
|
+
import { type CustomInputMap, Form, InputHeader, SelectInput, useRefQueryLookupHandler } from '@dxos/react-ui-form';
|
|
18
14
|
|
|
19
15
|
import { FunctionInputEditor, type FunctionInputEditorProps } from './FunctionInputEditor';
|
|
20
16
|
import { SpecSelector } from './SpecSelector';
|
|
21
17
|
|
|
22
18
|
export type TriggerEditorProps = {
|
|
23
19
|
space: Space;
|
|
24
|
-
trigger:
|
|
25
|
-
|
|
20
|
+
trigger: Trigger.Trigger;
|
|
21
|
+
// TODO(wittjosiah): This needs to apply to whole spec but currently only applies to spec.kind & spec.query.
|
|
22
|
+
readonlySpec?: boolean;
|
|
23
|
+
onSave?: (trigger: Omit<Trigger.Trigger, 'id'>) => void;
|
|
26
24
|
onCancel?: () => void;
|
|
27
|
-
}
|
|
25
|
+
} & Pick<QueryFormProps, 'types' | 'tags'>;
|
|
28
26
|
|
|
29
|
-
export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {
|
|
30
|
-
const handleSave = (values:
|
|
27
|
+
export const TriggerEditor = ({ space, trigger, readonlySpec, types, tags, onSave, onCancel }: TriggerEditorProps) => {
|
|
28
|
+
const handleSave = ({ id: _, ...values }: Trigger.Trigger) => {
|
|
31
29
|
onSave?.(values);
|
|
32
30
|
};
|
|
33
31
|
|
|
34
32
|
const handleRefQueryLookup = useRefQueryLookupHandler({ space });
|
|
35
|
-
const Custom = useCustomInputs(space, handleRefQueryLookup);
|
|
33
|
+
const Custom = useCustomInputs({ space, readonlySpec, types, tags, onQueryRefOptions: handleRefQueryLookup });
|
|
36
34
|
|
|
37
35
|
return (
|
|
38
36
|
<Form
|
|
39
37
|
outerSpacing={false}
|
|
40
38
|
Custom={Custom}
|
|
41
|
-
schema={
|
|
39
|
+
schema={Trigger.Trigger}
|
|
42
40
|
values={trigger}
|
|
43
41
|
onSave={handleSave}
|
|
44
42
|
onCancel={onCancel}
|
|
@@ -47,15 +45,21 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEdito
|
|
|
47
45
|
);
|
|
48
46
|
};
|
|
49
47
|
|
|
50
|
-
|
|
51
|
-
|
|
48
|
+
type UseCustomInputsProps = {
|
|
49
|
+
space: Space;
|
|
50
|
+
readonlySpec?: boolean;
|
|
51
|
+
onQueryRefOptions: FunctionInputEditorProps['onQueryRefOptions'];
|
|
52
|
+
} & Pick<QueryFormProps, 'types' | 'tags'>;
|
|
53
|
+
|
|
54
|
+
const useCustomInputs = ({ space, readonlySpec, types, tags, onQueryRefOptions }: UseCustomInputsProps) => {
|
|
55
|
+
const functions = useQuery(space, Filter.type(Function.Function));
|
|
52
56
|
const workflows = useQuery(space, Filter.type(ComputeGraph));
|
|
53
|
-
const scripts = useQuery(space, Filter.type(
|
|
57
|
+
const scripts = useQuery(space, Filter.type(Script.Script));
|
|
54
58
|
|
|
55
59
|
return useMemo(
|
|
56
60
|
(): CustomInputMap => ({
|
|
57
61
|
// Function selector.
|
|
58
|
-
['function' satisfies keyof
|
|
62
|
+
['function' satisfies keyof Trigger.Trigger]: (props) => {
|
|
59
63
|
const getValue = useCallback(() => {
|
|
60
64
|
const formValue = props.getValue();
|
|
61
65
|
if (Ref.isRef(formValue)) {
|
|
@@ -86,14 +90,30 @@ const useCustomInputs = (space: Space, onQueryRefOptions: FunctionInputEditorPro
|
|
|
86
90
|
},
|
|
87
91
|
|
|
88
92
|
// Spec selector.
|
|
89
|
-
['spec.kind' as const]: SpecSelector
|
|
93
|
+
['spec.kind' as const]: (props) => <SpecSelector {...props} readonly={readonlySpec ? 'disabled-input' : false} />,
|
|
94
|
+
|
|
95
|
+
// TODO(wittjosiah): Copied from ViewEditor.
|
|
96
|
+
// Query input editor.
|
|
97
|
+
['spec.query' as const]: (props) => {
|
|
98
|
+
const handleChange = useCallback(
|
|
99
|
+
(query: Query.Any) => props.onValueChange('object', { ast: query.ast }),
|
|
100
|
+
[props.onValueChange],
|
|
101
|
+
);
|
|
102
|
+
|
|
103
|
+
return (
|
|
104
|
+
<Input.Root>
|
|
105
|
+
<InputHeader label={props.label} />
|
|
106
|
+
<QueryForm initialQuery={(props.getValue() as any).ast} types={types} tags={tags} onChange={handleChange} />
|
|
107
|
+
</Input.Root>
|
|
108
|
+
);
|
|
109
|
+
},
|
|
90
110
|
|
|
91
111
|
// Function input editor.
|
|
92
112
|
['input' as const]: (props) => (
|
|
93
113
|
<FunctionInputEditor {...props} functions={functions} onQueryRefOptions={onQueryRefOptions} />
|
|
94
114
|
),
|
|
95
115
|
}),
|
|
96
|
-
[workflows, scripts, functions],
|
|
116
|
+
[workflows, scripts, functions, readonlySpec],
|
|
97
117
|
);
|
|
98
118
|
};
|
|
99
119
|
|
|
@@ -101,7 +121,7 @@ const getWorkflowOptions = (graphs: ComputeGraph[]) => {
|
|
|
101
121
|
return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));
|
|
102
122
|
};
|
|
103
123
|
|
|
104
|
-
const getFunctionOptions = (scripts:
|
|
105
|
-
const getLabel = (fn:
|
|
124
|
+
const getFunctionOptions = (scripts: Script.Script[], functions: Function.Function[]) => {
|
|
125
|
+
const getLabel = (fn: Function.Function) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
|
|
106
126
|
return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:echo:@:${fn.id}` }));
|
|
107
127
|
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import React from 'react';
|
|
6
|
+
|
|
7
|
+
import { type Space } from '@dxos/react-client/echo';
|
|
8
|
+
import { Input, useTranslation } from '@dxos/react-ui';
|
|
9
|
+
import { ControlItemInput } from '@dxos/react-ui-form';
|
|
10
|
+
|
|
11
|
+
import { useTriggerRuntimeControls } from '../hooks';
|
|
12
|
+
import { meta } from '../meta';
|
|
13
|
+
|
|
14
|
+
export const TriggersSettings = ({ space }: { space: Space }) => {
|
|
15
|
+
const { triggers, isRunning, start, stop } = useTriggerRuntimeControls(space);
|
|
16
|
+
const { t } = useTranslation(meta.id);
|
|
17
|
+
|
|
18
|
+
return (
|
|
19
|
+
<div className='container-max-width grid grid-cols-1 md:grid-cols-[1fr_min-content]'>
|
|
20
|
+
<ControlItemInput title={t('runtime label')} description={t('runtime description')}>
|
|
21
|
+
<Input.Switch classNames='justify-self-end' checked={isRunning} onCheckedChange={isRunning ? stop : start} />
|
|
22
|
+
</ControlItemInput>
|
|
23
|
+
</div>
|
|
24
|
+
);
|
|
25
|
+
};
|
package/src/components/index.ts
CHANGED
|
@@ -6,7 +6,7 @@ import { lazy } from 'react';
|
|
|
6
6
|
|
|
7
7
|
export * from './TriggerEditor';
|
|
8
8
|
|
|
9
|
-
export const AutomationContainer = lazy(() => import('./AutomationContainer'));
|
|
10
9
|
export const AutomationPanel = lazy(() => import('./AutomationPanel'));
|
|
10
|
+
export const AutomationSettings = lazy(() => import('./AutomationSettings'));
|
|
11
11
|
export const FunctionsContainer = lazy(() => import('./FunctionsContainer'));
|
|
12
12
|
export const FunctionsPanel = lazy(() => import('./FunctionsPanel'));
|
package/src/events.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { defineEvent } from '@dxos/app-framework';
|
|
6
|
+
|
|
7
|
+
import { meta } from './meta';
|
|
8
|
+
|
|
9
|
+
export namespace AutomationEvents {
|
|
10
|
+
export const ComputeRuntimeReady = defineEvent(`${meta.id}/event/compute-runtime-ready`);
|
|
11
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Cause from 'effect/Cause';
|
|
6
|
+
import * as Effect from 'effect/Effect';
|
|
7
|
+
import * as Exit from 'effect/Exit';
|
|
8
|
+
import { useCallback } from 'react';
|
|
9
|
+
|
|
10
|
+
import { useCapability } from '@dxos/app-framework/react';
|
|
11
|
+
import { type FunctionDefinition, FunctionInvocationService } from '@dxos/functions';
|
|
12
|
+
import { InvocationTracer, TracingServiceExt } from '@dxos/functions-runtime';
|
|
13
|
+
import { log } from '@dxos/log';
|
|
14
|
+
import type { Space } from '@dxos/react-client/echo';
|
|
15
|
+
|
|
16
|
+
import { AutomationCapabilities } from '../capabilities';
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Create an effectful function that has access to compute services
|
|
20
|
+
*/
|
|
21
|
+
// TODO(burdon): Factor out (figure out cross-plugin capabilities dependencies).
|
|
22
|
+
export const useComputeRuntimeCallback = <T>(
|
|
23
|
+
space: Space | undefined,
|
|
24
|
+
fn: () => Effect.Effect<T, any, AutomationCapabilities.ComputeServices>,
|
|
25
|
+
deps?: React.DependencyList,
|
|
26
|
+
): (() => Promise<T>) => {
|
|
27
|
+
const computeRuntime = useCapability(AutomationCapabilities.ComputeRuntime);
|
|
28
|
+
const runtime = space !== undefined ? computeRuntime.getRuntime(space.id) : undefined;
|
|
29
|
+
|
|
30
|
+
return useCallback(() => {
|
|
31
|
+
if (!runtime) {
|
|
32
|
+
throw new TypeError('Space not provided to useComputeRuntimeCallback');
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
return runtime.runPromise(fn());
|
|
36
|
+
}, [runtime, ...(deps ?? [])]);
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
// TODO(wittjosiah): Function invoking should automatically be traced (DX-647).
|
|
40
|
+
export const invokeFunctionWithTracing = <I, O>(functionDef: FunctionDefinition<I, O>, inputData: I) =>
|
|
41
|
+
Effect.gen(function* () {
|
|
42
|
+
const tracer = yield* InvocationTracer;
|
|
43
|
+
const trace = yield* tracer.traceInvocationStart({
|
|
44
|
+
target: undefined,
|
|
45
|
+
payload: {
|
|
46
|
+
data: {},
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
// Invoke the function.
|
|
51
|
+
const result = yield* FunctionInvocationService.invokeFunction(functionDef, inputData).pipe(
|
|
52
|
+
Effect.provide(TracingServiceExt.layerQueue(trace.invocationTraceQueue)),
|
|
53
|
+
Effect.exit,
|
|
54
|
+
);
|
|
55
|
+
|
|
56
|
+
if (Exit.isFailure(result)) {
|
|
57
|
+
const error = Cause.prettyErrors(result.cause)[0];
|
|
58
|
+
log.error(error.message, error.cause ?? error.stack);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
yield* tracer.traceInvocationEnd({
|
|
62
|
+
trace,
|
|
63
|
+
// TODO(dmaretskyi): Might miss errors.
|
|
64
|
+
exception: Exit.isFailure(result) ? Cause.prettyErrors(result.cause)[0] : undefined,
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
return result;
|
|
68
|
+
});
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
|
|
7
|
+
import { Filter } from '@dxos/echo';
|
|
8
|
+
import { Trigger } from '@dxos/functions';
|
|
9
|
+
import { TriggerDispatcher } from '@dxos/functions-runtime';
|
|
10
|
+
import { type Space, useQuery } from '@dxos/react-client/echo';
|
|
11
|
+
import { useAsyncState } from '@dxos/react-ui';
|
|
12
|
+
|
|
13
|
+
import { useComputeRuntimeCallback } from './useComputeRuntimeCallback';
|
|
14
|
+
|
|
15
|
+
interface TriggerRuntimeControls {
|
|
16
|
+
triggers: Trigger.Trigger[];
|
|
17
|
+
isRunning: boolean;
|
|
18
|
+
start: () => void;
|
|
19
|
+
stop: () => void;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export const useTriggerRuntimeControls = (space: Space | undefined): TriggerRuntimeControls => {
|
|
23
|
+
const triggers = useQuery(space, Filter.type(Trigger.Trigger));
|
|
24
|
+
|
|
25
|
+
const [isRunningState, setIsRunningState] = useAsyncState(
|
|
26
|
+
useComputeRuntimeCallback(space, () => TriggerDispatcher.pipe(Effect.map((t) => t.running))),
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
const start = useComputeRuntimeCallback(
|
|
30
|
+
space,
|
|
31
|
+
Effect.fnUntraced(function* () {
|
|
32
|
+
const dispatcher = yield* TriggerDispatcher;
|
|
33
|
+
yield* dispatcher.start();
|
|
34
|
+
setIsRunningState(true);
|
|
35
|
+
}),
|
|
36
|
+
);
|
|
37
|
+
|
|
38
|
+
const stop = useComputeRuntimeCallback(
|
|
39
|
+
space,
|
|
40
|
+
Effect.fnUntraced(function* () {
|
|
41
|
+
const dispatcher = yield* TriggerDispatcher;
|
|
42
|
+
yield* dispatcher.stop();
|
|
43
|
+
setIsRunningState(false);
|
|
44
|
+
}),
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
return {
|
|
48
|
+
triggers,
|
|
49
|
+
isRunning: isRunningState ?? false,
|
|
50
|
+
start: () => void start(),
|
|
51
|
+
stop: () => void stop(),
|
|
52
|
+
};
|
|
53
|
+
};
|
package/src/index.ts
CHANGED
package/src/meta.ts
CHANGED
|
@@ -3,14 +3,15 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { type PluginMeta } from '@dxos/app-framework';
|
|
6
|
-
|
|
7
|
-
export const AUTOMATION_PLUGIN = 'dxos.org/plugin/automation';
|
|
6
|
+
import { trim } from '@dxos/util';
|
|
8
7
|
|
|
9
8
|
export const meta: PluginMeta = {
|
|
10
|
-
id:
|
|
9
|
+
id: 'dxos.org/plugin/automation',
|
|
11
10
|
name: 'Automation',
|
|
12
|
-
description:
|
|
13
|
-
|
|
11
|
+
description: trim`
|
|
12
|
+
Workflow automation engine that triggers custom actions based on object events and conditions.
|
|
13
|
+
Create automated pipelines that respond to changes and streamline repetitive tasks.
|
|
14
|
+
`,
|
|
14
15
|
icon: 'ph--robot--regular',
|
|
15
16
|
source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-automation',
|
|
16
17
|
};
|
package/src/translations.ts
CHANGED
|
@@ -16,12 +16,19 @@ export const translations = [
|
|
|
16
16
|
'automation verbose label': 'Manage automations',
|
|
17
17
|
'automation description': 'You can manage all the triggers which automate your space here.',
|
|
18
18
|
|
|
19
|
+
'runtime label': 'Enable Local Runtime',
|
|
20
|
+
'runtime description':
|
|
21
|
+
'This will start a trigger dispatcher locally for this space to run triggers on your device while Composer is running.',
|
|
22
|
+
|
|
19
23
|
'functions panel label': 'Functions',
|
|
20
24
|
'functions verbose label': 'Manage deployed functions',
|
|
25
|
+
'functions registry verbose label': 'Functions registry',
|
|
26
|
+
'functions registry description': 'Import functions from the registry',
|
|
21
27
|
'functions description': 'You can manage all the functions deployed from your space on EDGE here.',
|
|
22
28
|
'function copy id': 'Copy Function ID',
|
|
23
29
|
'no functions found': 'No functions found',
|
|
24
30
|
'go to function source button label': 'Show function source',
|
|
31
|
+
'delete function button label': 'Delete function',
|
|
25
32
|
|
|
26
33
|
'trigger editor title': 'Configure Trigger',
|
|
27
34
|
'new trigger label': 'Add Trigger',
|
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
5
|
+
import * as Schema from 'effect/Schema';
|
|
6
6
|
|
|
7
7
|
import { SpaceSchema } from '@dxos/react-client/echo';
|
|
8
8
|
|
|
9
|
-
import {
|
|
9
|
+
import { meta } from '../meta';
|
|
10
10
|
|
|
11
11
|
const TriggerTemplate = Schema.Union(
|
|
12
12
|
Schema.Struct({ type: Schema.Literal('timer'), cron: Schema.String }),
|
|
@@ -14,10 +14,8 @@ const TriggerTemplate = Schema.Union(
|
|
|
14
14
|
);
|
|
15
15
|
|
|
16
16
|
export namespace AutomationAction {
|
|
17
|
-
const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;
|
|
18
|
-
|
|
19
17
|
export class CreateTriggerFromTemplate extends Schema.TaggedClass<CreateTriggerFromTemplate>()(
|
|
20
|
-
`${
|
|
18
|
+
`${meta.id}/action/create-trigger-from-template`,
|
|
21
19
|
{
|
|
22
20
|
input: Schema.Struct({
|
|
23
21
|
space: SpaceSchema,
|