@dxos/plugin-automation 0.7.5-main.9cb18ac → 0.7.5-main.9d2a38b
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/{AssistantPanel-32FH2RA6.mjs → AssistantPanel-N276BTPV.mjs} +2 -2
- package/dist/lib/browser/AutomationPanel-IHZ4JKVS.mjs +232 -0
- package/dist/lib/browser/AutomationPanel-IHZ4JKVS.mjs.map +7 -0
- package/dist/lib/browser/app-graph-builder-IJTTULDP.mjs +131 -0
- package/dist/lib/browser/app-graph-builder-IJTTULDP.mjs.map +7 -0
- package/dist/lib/browser/chunk-4AIMDHKY.mjs +10 -0
- package/dist/lib/browser/chunk-4AIMDHKY.mjs.map +7 -0
- package/dist/lib/browser/{chunk-DN5M2QL5.mjs → chunk-DL6LB2NI.mjs} +2 -8
- package/dist/lib/browser/{chunk-DN5M2QL5.mjs.map → chunk-DL6LB2NI.mjs.map} +4 -4
- package/dist/lib/browser/{chunk-X5KMOH3I.mjs → chunk-HKX3D3ZP.mjs} +3 -3
- package/dist/lib/browser/chunk-HKX3D3ZP.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +89 -236
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-surface-LL72F3F4.mjs +34 -0
- package/dist/lib/browser/react-surface-LL72F3F4.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +1 -3
- package/dist/lib/node/{AssistantPanel-XANI7YNV.cjs → AssistantPanel-Z4GVHUF3.cjs} +6 -6
- package/dist/lib/node/{AutomationPanel-VADY3HMP.cjs → AutomationPanel-PPODB5XA.cjs} +113 -32
- package/dist/lib/node/AutomationPanel-PPODB5XA.cjs.map +7 -0
- package/dist/lib/node/app-graph-builder-MF5M4QRS.cjs +147 -0
- package/dist/lib/node/app-graph-builder-MF5M4QRS.cjs.map +7 -0
- package/dist/lib/node/chunk-25AQIF3L.cjs +43 -0
- package/dist/lib/node/chunk-25AQIF3L.cjs.map +7 -0
- package/dist/lib/node/{chunk-DTJ7XVO2.cjs → chunk-5VF5JKUN.cjs} +7 -7
- package/dist/lib/node/chunk-5VF5JKUN.cjs.map +7 -0
- package/dist/lib/node/{chunk-NIL4TP6U.cjs → chunk-JNDMZQH7.cjs} +4 -9
- package/dist/lib/node/chunk-JNDMZQH7.cjs.map +7 -0
- package/dist/lib/node/index.cjs +112 -258
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/react-surface-DVAU4MGD.cjs +57 -0
- package/dist/lib/node/react-surface-DVAU4MGD.cjs.map +7 -0
- package/dist/lib/node/types/index.cjs +5 -7
- package/dist/lib/node/types/index.cjs.map +2 -2
- package/dist/lib/node-esm/{AssistantPanel-5M6O6JV7.mjs → AssistantPanel-DDCQHBJX.mjs} +2 -2
- package/dist/lib/node-esm/AutomationPanel-R3D6CRF5.mjs +233 -0
- package/dist/lib/node-esm/AutomationPanel-R3D6CRF5.mjs.map +7 -0
- package/dist/lib/node-esm/app-graph-builder-5N7OK23B.mjs +132 -0
- package/dist/lib/node-esm/app-graph-builder-5N7OK23B.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-GCHXTXVT.mjs → chunk-GIAYUM5I.mjs} +2 -8
- package/dist/lib/node-esm/{chunk-GCHXTXVT.mjs.map → chunk-GIAYUM5I.mjs.map} +4 -4
- package/dist/lib/node-esm/{chunk-HNOBZHWK.mjs → chunk-X3LPRWIL.mjs} +3 -3
- package/dist/lib/node-esm/chunk-X3LPRWIL.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-XW7TEQA3.mjs +12 -0
- package/dist/lib/node-esm/chunk-XW7TEQA3.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +89 -236
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react-surface-4BED2PZ4.mjs +35 -0
- package/dist/lib/node-esm/react-surface-4BED2PZ4.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +1 -3
- package/dist/types/src/AutomationPlugin.d.ts +1 -3
- package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts +180 -0
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +179 -0
- package/dist/types/src/capabilities/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-surface.d.ts +4 -0
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -2
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +1 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -2
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +1 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +7 -0
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +0 -1
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +38 -46
- package/src/AutomationPlugin.tsx +55 -193
- package/src/capabilities/app-graph-builder.ts +127 -0
- package/src/capabilities/index.ts +8 -0
- package/src/capabilities/react-surface.tsx +27 -0
- package/src/components/AutomationPanel/AutomationPanel.tsx +54 -37
- package/src/components/TriggerEditor/TriggerEditor.tsx +63 -6
- package/src/index.ts +1 -4
- package/src/meta.ts +1 -1
- package/src/translations.ts +9 -0
- package/src/types/index.ts +0 -1
- package/dist/lib/browser/AutomationPanel-ABGPG5LE.mjs +0 -151
- package/dist/lib/browser/AutomationPanel-ABGPG5LE.mjs.map +0 -7
- package/dist/lib/browser/chunk-X5KMOH3I.mjs.map +0 -7
- package/dist/lib/browser/meta.mjs +0 -9
- package/dist/lib/browser/meta.mjs.map +0 -7
- package/dist/lib/node/AutomationPanel-VADY3HMP.cjs.map +0 -7
- package/dist/lib/node/chunk-DTJ7XVO2.cjs.map +0 -7
- package/dist/lib/node/chunk-NIL4TP6U.cjs.map +0 -7
- package/dist/lib/node/meta.cjs +0 -30
- package/dist/lib/node/meta.cjs.map +0 -7
- package/dist/lib/node-esm/AutomationPanel-EETYIDPA.mjs +0 -152
- package/dist/lib/node-esm/AutomationPanel-EETYIDPA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HNOBZHWK.mjs.map +0 -7
- package/dist/lib/node-esm/meta.mjs +0 -10
- package/dist/lib/node-esm/meta.mjs.map +0 -7
- package/dist/types/src/types/types.d.ts +0 -7
- package/dist/types/src/types/types.d.ts.map +0 -1
- package/src/types/types.ts +0 -27
- /package/dist/lib/browser/{AssistantPanel-32FH2RA6.mjs.map → AssistantPanel-N276BTPV.mjs.map} +0 -0
- /package/dist/lib/node/{AssistantPanel-XANI7YNV.cjs.map → AssistantPanel-Z4GVHUF3.cjs.map} +0 -0
- /package/dist/lib/node-esm/{AssistantPanel-5M6O6JV7.mjs.map → AssistantPanel-DDCQHBJX.mjs.map} +0 -0
|
@@ -9,6 +9,7 @@ import {
|
|
|
9
9
|
FunctionType,
|
|
10
10
|
FunctionTrigger,
|
|
11
11
|
FunctionTriggerSchema,
|
|
12
|
+
TriggerKind,
|
|
12
13
|
type FunctionTriggerType,
|
|
13
14
|
ScriptType,
|
|
14
15
|
} from '@dxos/functions';
|
|
@@ -29,7 +30,7 @@ export type AutomationPanelProps = {
|
|
|
29
30
|
};
|
|
30
31
|
|
|
31
32
|
// TODO(burdon): Factor out common layout with ViewEditor.
|
|
32
|
-
export const AutomationPanel = ({ space }: AutomationPanelProps) => {
|
|
33
|
+
export const AutomationPanel = ({ space, object }: AutomationPanelProps) => {
|
|
33
34
|
const { t } = useTranslation(AUTOMATION_PLUGIN);
|
|
34
35
|
const client = useClient();
|
|
35
36
|
const triggers = useQuery(space, Filter.schema(FunctionTrigger));
|
|
@@ -46,7 +47,7 @@ export const AutomationPanel = ({ space }: AutomationPanelProps) => {
|
|
|
46
47
|
};
|
|
47
48
|
|
|
48
49
|
const handleAdd = () => {
|
|
49
|
-
setTrigger(create(FunctionTriggerSchema, {}));
|
|
50
|
+
setTrigger(create(FunctionTriggerSchema, { meta: {} }));
|
|
50
51
|
setSelected(undefined);
|
|
51
52
|
};
|
|
52
53
|
|
|
@@ -76,43 +77,46 @@ export const AutomationPanel = ({ space }: AutomationPanelProps) => {
|
|
|
76
77
|
<List.Root<FunctionTrigger> items={triggers} isItem={S.is(FunctionTrigger)} getId={(field) => field.id}>
|
|
77
78
|
{({ items: triggers }) => (
|
|
78
79
|
<div role='list' className='flex flex-col w-full'>
|
|
79
|
-
{triggers?.map((trigger) =>
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
</
|
|
93
|
-
|
|
94
|
-
{
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
80
|
+
{triggers?.map((trigger) => {
|
|
81
|
+
const copyAction = getCopyAction(client, trigger);
|
|
82
|
+
return (
|
|
83
|
+
<List.Item<FunctionTrigger>
|
|
84
|
+
key={trigger.id}
|
|
85
|
+
item={trigger}
|
|
86
|
+
classNames={mx(grid, ghostHover, 'items-center', 'px-2')}
|
|
87
|
+
>
|
|
88
|
+
<Input.Root>
|
|
89
|
+
<Input.Switch
|
|
90
|
+
checked={trigger.enabled}
|
|
91
|
+
onCheckedChange={(checked) => (trigger.enabled = checked)}
|
|
92
|
+
/>
|
|
93
|
+
</Input.Root>
|
|
94
|
+
|
|
95
|
+
<div className={'flex'}>
|
|
96
|
+
<List.ItemTitle
|
|
97
|
+
classNames='px-1 cursor-pointer w-0 shrink truncate'
|
|
98
|
+
onClick={() => handleSelect(trigger)}
|
|
99
|
+
>
|
|
100
|
+
{getFunctionName(scripts, functions, trigger) ?? '∅'}
|
|
101
|
+
</List.ItemTitle>
|
|
102
|
+
|
|
103
|
+
{/* TODO: a better way to expose copy action */}
|
|
104
|
+
{copyAction && (
|
|
105
|
+
<Button onClick={() => navigator.clipboard.writeText(copyAction.contentProvider())}>
|
|
106
|
+
{t(copyAction.translationKey)}
|
|
107
|
+
</Button>
|
|
108
|
+
)}
|
|
109
|
+
</div>
|
|
110
|
+
|
|
111
|
+
<List.ItemDeleteButton onClick={() => handleDelete(trigger)} />
|
|
112
|
+
</List.Item>
|
|
113
|
+
);
|
|
114
|
+
})}
|
|
103
115
|
</div>
|
|
104
116
|
)}
|
|
105
117
|
</List.Root>
|
|
106
118
|
|
|
107
|
-
{trigger &&
|
|
108
|
-
<TriggerEditor
|
|
109
|
-
space={space}
|
|
110
|
-
storedTrigger={selected}
|
|
111
|
-
trigger={trigger}
|
|
112
|
-
onSave={handleSave}
|
|
113
|
-
onCancel={handleCancel}
|
|
114
|
-
/>
|
|
115
|
-
)}
|
|
119
|
+
{trigger && <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />}
|
|
116
120
|
|
|
117
121
|
{!trigger && (
|
|
118
122
|
<div className='flex p-2 justify-center'>
|
|
@@ -123,6 +127,18 @@ export const AutomationPanel = ({ space }: AutomationPanelProps) => {
|
|
|
123
127
|
);
|
|
124
128
|
};
|
|
125
129
|
|
|
130
|
+
const getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {
|
|
131
|
+
if (trigger?.spec?.type === TriggerKind.Email) {
|
|
132
|
+
return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
if (trigger?.spec?.type === TriggerKind.Webhook) {
|
|
136
|
+
return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
return undefined;
|
|
140
|
+
};
|
|
141
|
+
|
|
126
142
|
const getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {
|
|
127
143
|
const spaceId = getSpace(trigger)!.id;
|
|
128
144
|
const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);
|
|
@@ -132,9 +148,10 @@ const getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {
|
|
|
132
148
|
};
|
|
133
149
|
|
|
134
150
|
const getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTriggerType) => {
|
|
151
|
+
const shortId = trigger.function && `${trigger.function?.slice(0, 16)}…`;
|
|
135
152
|
const functionObject = functions.find((fn) => fn.name === trigger.function);
|
|
136
153
|
if (!functionObject) {
|
|
137
|
-
return
|
|
154
|
+
return shortId;
|
|
138
155
|
}
|
|
139
|
-
return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ??
|
|
156
|
+
return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;
|
|
140
157
|
};
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import React from 'react';
|
|
5
|
+
import React, { useState } from 'react';
|
|
6
6
|
|
|
7
7
|
import {
|
|
8
8
|
FunctionType,
|
|
@@ -13,21 +13,21 @@ import {
|
|
|
13
13
|
TriggerKind,
|
|
14
14
|
} from '@dxos/functions';
|
|
15
15
|
import { Filter, useQuery, type Space } from '@dxos/react-client/echo';
|
|
16
|
-
import { useTranslation } from '@dxos/react-ui';
|
|
17
|
-
import { Form, SelectInput } from '@dxos/react-ui-form';
|
|
16
|
+
import { IconButton, Input, useTranslation } from '@dxos/react-ui';
|
|
17
|
+
import { Form, SelectInput, TextInput } from '@dxos/react-ui-form';
|
|
18
18
|
|
|
19
19
|
import { AUTOMATION_PLUGIN } from '../../meta';
|
|
20
20
|
|
|
21
21
|
export type TriggerEditorProps = {
|
|
22
22
|
space: Space;
|
|
23
23
|
trigger: FunctionTriggerType;
|
|
24
|
-
storedTrigger?: FunctionTrigger;
|
|
25
24
|
onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;
|
|
26
25
|
onCancel?: () => void;
|
|
27
26
|
};
|
|
28
27
|
|
|
29
|
-
export const TriggerEditor = ({ space, trigger, onSave, onCancel
|
|
28
|
+
export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {
|
|
30
29
|
const { t } = useTranslation(AUTOMATION_PLUGIN);
|
|
30
|
+
|
|
31
31
|
const functions = useQuery(space, Filter.schema(FunctionType));
|
|
32
32
|
const scripts = useQuery(space, Filter.schema(ScriptType));
|
|
33
33
|
|
|
@@ -39,7 +39,6 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel, storedTrigger
|
|
|
39
39
|
<Form<FunctionTriggerType>
|
|
40
40
|
schema={FunctionTriggerSchema}
|
|
41
41
|
values={trigger}
|
|
42
|
-
filter={(props) => props.filter((p) => p.name !== 'meta')}
|
|
43
42
|
onSave={handleSave}
|
|
44
43
|
onCancel={onCancel}
|
|
45
44
|
Custom={{
|
|
@@ -61,6 +60,64 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel, storedTrigger
|
|
|
61
60
|
}))}
|
|
62
61
|
/>
|
|
63
62
|
),
|
|
63
|
+
['meta' as const]: (props) => {
|
|
64
|
+
const meta = props.getValue('meta')!;
|
|
65
|
+
|
|
66
|
+
const [newMetaFieldName, setNewMetaFieldName] = useState('');
|
|
67
|
+
|
|
68
|
+
React.useEffect(() => props.onValueChange('meta', 'object', { ...meta }), []);
|
|
69
|
+
|
|
70
|
+
return (
|
|
71
|
+
<>
|
|
72
|
+
<div>{props.label}</div>
|
|
73
|
+
{[...Object.keys(meta)].map((key) => {
|
|
74
|
+
const compositeKey: any = `meta.${key}`;
|
|
75
|
+
return (
|
|
76
|
+
<div key={compositeKey} role='none' className='flex items-center mt-2 gap-1'>
|
|
77
|
+
<div role='none' className='flex-1'>
|
|
78
|
+
<TextInput {...props} property={compositeKey} type={'string'} label={key} />
|
|
79
|
+
</div>
|
|
80
|
+
<IconButton
|
|
81
|
+
icon='ph--trash--regular'
|
|
82
|
+
iconOnly
|
|
83
|
+
classNames={'mt-6'}
|
|
84
|
+
label={t('trigger meta remove')}
|
|
85
|
+
onClick={() => {
|
|
86
|
+
const newValues: any = { ...props.getValue('meta') };
|
|
87
|
+
delete newValues[key];
|
|
88
|
+
props.onValueChange('meta', 'object', newValues);
|
|
89
|
+
}}
|
|
90
|
+
/>
|
|
91
|
+
</div>
|
|
92
|
+
);
|
|
93
|
+
})}
|
|
94
|
+
<div role='none' className='flex items-center mt-2 gap-1 plb-1'>
|
|
95
|
+
<div role='none' className='flex-1'>
|
|
96
|
+
<Input.Root>
|
|
97
|
+
<Input.TextInput
|
|
98
|
+
placeholder={t('trigger meta prop name placeholder')}
|
|
99
|
+
value={newMetaFieldName}
|
|
100
|
+
onChange={(event) => setNewMetaFieldName(event.target.value)}
|
|
101
|
+
/>
|
|
102
|
+
</Input.Root>
|
|
103
|
+
</div>
|
|
104
|
+
<IconButton
|
|
105
|
+
icon='ph--plus--regular'
|
|
106
|
+
iconOnly
|
|
107
|
+
label={t('trigger meta add')}
|
|
108
|
+
onClick={() => {
|
|
109
|
+
if (newMetaFieldName.length) {
|
|
110
|
+
const meta = props.getValue('meta') ?? {};
|
|
111
|
+
const metaWithNewProp = { ...meta, [newMetaFieldName]: '' };
|
|
112
|
+
setNewMetaFieldName('');
|
|
113
|
+
props.onValueChange('meta', 'object', metaWithNewProp);
|
|
114
|
+
}
|
|
115
|
+
}}
|
|
116
|
+
/>
|
|
117
|
+
</div>
|
|
118
|
+
</>
|
|
119
|
+
);
|
|
120
|
+
},
|
|
64
121
|
}}
|
|
65
122
|
/>
|
|
66
123
|
);
|
package/src/index.ts
CHANGED
|
@@ -2,11 +2,8 @@
|
|
|
2
2
|
// Copyright 2023 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { AutomationPlugin } from './AutomationPlugin';
|
|
6
|
-
|
|
7
|
-
export default AutomationPlugin;
|
|
8
|
-
|
|
9
5
|
export * from './AutomationPlugin';
|
|
10
6
|
export * from './components';
|
|
7
|
+
export * from './meta';
|
|
11
8
|
export * from './presets';
|
|
12
9
|
export * from './types';
|
package/src/meta.ts
CHANGED
package/src/translations.ts
CHANGED
|
@@ -18,6 +18,7 @@ export default [
|
|
|
18
18
|
'value placeholder': 'Enter value...',
|
|
19
19
|
'select preset template placeholder': 'Select preset',
|
|
20
20
|
'open automation panel label': 'Show Automations',
|
|
21
|
+
'automation panel label': 'Automations',
|
|
21
22
|
|
|
22
23
|
'function select label': 'Function',
|
|
23
24
|
'function select placeholder': 'Select function',
|
|
@@ -29,12 +30,20 @@ export default [
|
|
|
29
30
|
'trigger type webhook': 'Webhook',
|
|
30
31
|
'trigger type websocket': 'Websocket',
|
|
31
32
|
'trigger type subscription': 'Subscription',
|
|
33
|
+
'trigger type email': 'Email',
|
|
32
34
|
|
|
33
35
|
'trigger filter': 'Filter',
|
|
34
36
|
'trigger cron': 'Cron',
|
|
35
37
|
'trigger method': 'Method',
|
|
36
38
|
'trigger endpoint': 'Endpoint',
|
|
37
39
|
|
|
40
|
+
'trigger copy url': 'Copy URL',
|
|
41
|
+
'trigger copy email': 'Copy Email',
|
|
42
|
+
|
|
43
|
+
'trigger meta add': 'Add',
|
|
44
|
+
'trigger meta remove': 'Remove',
|
|
45
|
+
'trigger meta prop name placeholder': 'New meta property name',
|
|
46
|
+
|
|
38
47
|
'open assistant panel label': 'Show Assistant',
|
|
39
48
|
'assistant panel label': 'Assistant',
|
|
40
49
|
},
|
package/src/types/index.ts
CHANGED
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
AUTOMATION_PLUGIN
|
|
3
|
-
} from "./chunk-X5KMOH3I.mjs";
|
|
4
|
-
|
|
5
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
|
|
6
|
-
import React2, { useState } from "react";
|
|
7
|
-
import { S } from "@dxos/echo-schema";
|
|
8
|
-
import { FunctionType as FunctionType2, FunctionTrigger, FunctionTriggerSchema as FunctionTriggerSchema2, ScriptType as ScriptType2 } from "@dxos/functions";
|
|
9
|
-
import { useClient } from "@dxos/react-client";
|
|
10
|
-
import { create, Filter as Filter2, useQuery as useQuery2, getSpace } from "@dxos/react-client/echo";
|
|
11
|
-
import { IconButton, Input, useTranslation as useTranslation2, Button } from "@dxos/react-ui";
|
|
12
|
-
import { List } from "@dxos/react-ui-list";
|
|
13
|
-
import { ghostHover, mx } from "@dxos/react-ui-theme";
|
|
14
|
-
|
|
15
|
-
// packages/plugins/experimental/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
|
|
16
|
-
import React from "react";
|
|
17
|
-
import { FunctionType, FunctionTriggerSchema, ScriptType, TriggerKind } from "@dxos/functions";
|
|
18
|
-
import { Filter, useQuery } from "@dxos/react-client/echo";
|
|
19
|
-
import { useTranslation } from "@dxos/react-ui";
|
|
20
|
-
import { Form, SelectInput } from "@dxos/react-ui-form";
|
|
21
|
-
var TriggerEditor = ({ space, trigger, onSave, onCancel, storedTrigger }) => {
|
|
22
|
-
const { t } = useTranslation(AUTOMATION_PLUGIN);
|
|
23
|
-
const functions = useQuery(space, Filter.schema(FunctionType));
|
|
24
|
-
const scripts = useQuery(space, Filter.schema(ScriptType));
|
|
25
|
-
const handleSave = (values) => {
|
|
26
|
-
onSave?.(values);
|
|
27
|
-
};
|
|
28
|
-
return /* @__PURE__ */ React.createElement(Form, {
|
|
29
|
-
schema: FunctionTriggerSchema,
|
|
30
|
-
values: trigger,
|
|
31
|
-
filter: (props) => props.filter((p) => p.name !== "meta"),
|
|
32
|
-
onSave: handleSave,
|
|
33
|
-
onCancel,
|
|
34
|
-
Custom: {
|
|
35
|
-
["function"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
|
|
36
|
-
...props,
|
|
37
|
-
options: functions.map((fn) => ({
|
|
38
|
-
value: fn.name,
|
|
39
|
-
label: getFunctionName(scripts, fn)
|
|
40
|
-
}))
|
|
41
|
-
}),
|
|
42
|
-
["spec.type"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
|
|
43
|
-
...props,
|
|
44
|
-
options: Object.values(TriggerKind).map((kind) => ({
|
|
45
|
-
value: kind,
|
|
46
|
-
label: t(`trigger type ${kind}`)
|
|
47
|
-
}))
|
|
48
|
-
})
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
};
|
|
52
|
-
var getFunctionName = (scripts, fn) => {
|
|
53
|
-
return scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
|
|
57
|
-
var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
|
|
58
|
-
var AutomationPanel = ({ space }) => {
|
|
59
|
-
const { t } = useTranslation2(AUTOMATION_PLUGIN);
|
|
60
|
-
const client = useClient();
|
|
61
|
-
const triggers = useQuery2(space, Filter2.schema(FunctionTrigger));
|
|
62
|
-
const functions = useQuery2(space, Filter2.schema(FunctionType2));
|
|
63
|
-
const scripts = useQuery2(space, Filter2.schema(ScriptType2));
|
|
64
|
-
const [trigger, setTrigger] = useState();
|
|
65
|
-
const [selected, setSelected] = useState();
|
|
66
|
-
const handleSelect = (trigger2) => {
|
|
67
|
-
const { id: _, ...values } = trigger2;
|
|
68
|
-
setTrigger(values);
|
|
69
|
-
setSelected(trigger2);
|
|
70
|
-
};
|
|
71
|
-
const handleAdd = () => {
|
|
72
|
-
setTrigger(create(FunctionTriggerSchema2, {}));
|
|
73
|
-
setSelected(void 0);
|
|
74
|
-
};
|
|
75
|
-
const handleDelete = (trigger2) => {
|
|
76
|
-
space.db.remove(trigger2);
|
|
77
|
-
setTrigger(void 0);
|
|
78
|
-
setSelected(void 0);
|
|
79
|
-
};
|
|
80
|
-
const handleSave = (trigger2) => {
|
|
81
|
-
if (selected) {
|
|
82
|
-
Object.assign(selected, trigger2);
|
|
83
|
-
} else {
|
|
84
|
-
space.db.add(create(FunctionTrigger, trigger2));
|
|
85
|
-
}
|
|
86
|
-
setTrigger(void 0);
|
|
87
|
-
setSelected(void 0);
|
|
88
|
-
};
|
|
89
|
-
const handleCancel = () => {
|
|
90
|
-
setTrigger(void 0);
|
|
91
|
-
};
|
|
92
|
-
return /* @__PURE__ */ React2.createElement("div", {
|
|
93
|
-
className: "flex flex-col w-full divide-y divide-separator overflow-y-auto"
|
|
94
|
-
}, /* @__PURE__ */ React2.createElement(List.Root, {
|
|
95
|
-
items: triggers,
|
|
96
|
-
isItem: S.is(FunctionTrigger),
|
|
97
|
-
getId: (field) => field.id
|
|
98
|
-
}, ({ items: triggers2 }) => /* @__PURE__ */ React2.createElement("div", {
|
|
99
|
-
role: "list",
|
|
100
|
-
className: "flex flex-col w-full"
|
|
101
|
-
}, triggers2?.map((trigger2) => /* @__PURE__ */ React2.createElement(List.Item, {
|
|
102
|
-
key: trigger2.id,
|
|
103
|
-
item: trigger2,
|
|
104
|
-
classNames: mx(grid, ghostHover, "items-center")
|
|
105
|
-
}, /* @__PURE__ */ React2.createElement(Input.Root, null, /* @__PURE__ */ React2.createElement(Input.Switch, {
|
|
106
|
-
checked: trigger2.enabled,
|
|
107
|
-
onCheckedChange: (checked) => trigger2.enabled = checked
|
|
108
|
-
})), /* @__PURE__ */ React2.createElement("div", {
|
|
109
|
-
className: "flex"
|
|
110
|
-
}, /* @__PURE__ */ React2.createElement(List.ItemTitle, {
|
|
111
|
-
classNames: "px-2 cursor-pointer w-0 shrink",
|
|
112
|
-
onClick: () => handleSelect(trigger2)
|
|
113
|
-
}, getFunctionName2(scripts, functions, trigger2)), /* @__PURE__ */ React2.createElement(Button, {
|
|
114
|
-
onClick: () => navigator.clipboard.writeText(getWebhookUrl(client, trigger2))
|
|
115
|
-
}, "Copy URL")), /* @__PURE__ */ React2.createElement(List.ItemDeleteButton, {
|
|
116
|
-
onClick: () => handleDelete(trigger2)
|
|
117
|
-
}))))), trigger && /* @__PURE__ */ React2.createElement(TriggerEditor, {
|
|
118
|
-
space,
|
|
119
|
-
storedTrigger: selected,
|
|
120
|
-
trigger,
|
|
121
|
-
onSave: handleSave,
|
|
122
|
-
onCancel: handleCancel
|
|
123
|
-
}), !trigger && /* @__PURE__ */ React2.createElement("div", {
|
|
124
|
-
className: "flex p-2 justify-center"
|
|
125
|
-
}, /* @__PURE__ */ React2.createElement(IconButton, {
|
|
126
|
-
icon: "ph--plus--regular",
|
|
127
|
-
label: t("new trigger"),
|
|
128
|
-
onClick: handleAdd
|
|
129
|
-
})));
|
|
130
|
-
};
|
|
131
|
-
var getWebhookUrl = (client, trigger) => {
|
|
132
|
-
const spaceId = getSpace(trigger).id;
|
|
133
|
-
const edgeUrl = new URL(client.config.values.runtime.services.edge.url);
|
|
134
|
-
const isSecure = edgeUrl.protocol.startsWith("https") || edgeUrl.protocol.startsWith("wss");
|
|
135
|
-
edgeUrl.protocol = isSecure ? "https" : "http";
|
|
136
|
-
return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
|
|
137
|
-
};
|
|
138
|
-
var getFunctionName2 = (scripts, functions, trigger) => {
|
|
139
|
-
const functionObject = functions.find((fn) => fn.name === trigger.function);
|
|
140
|
-
if (!functionObject) {
|
|
141
|
-
return trigger.function;
|
|
142
|
-
}
|
|
143
|
-
return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? functionObject.name;
|
|
144
|
-
};
|
|
145
|
-
|
|
146
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/index.ts
|
|
147
|
-
var AutomationPanel_default = AutomationPanel;
|
|
148
|
-
export {
|
|
149
|
-
AutomationPanel_default as default
|
|
150
|
-
};
|
|
151
|
-
//# sourceMappingURL=AutomationPanel-ABGPG5LE.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/TriggerEditor/TriggerEditor.tsx", "../../../src/components/AutomationPanel/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useState } from 'react';\n\nimport { S } from '@dxos/echo-schema';\nimport {\n FunctionType,\n FunctionTrigger,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n ScriptType,\n} from '@dxos/functions';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { create, Filter, useQuery, type Space, type ReactiveObject, getSpace } from '@dxos/react-client/echo';\nimport { IconButton, Input, useTranslation, Button } from '@dxos/react-ui';\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?: ReactiveObject<any>;\n};\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ space }: AutomationPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const client = useClient();\n const triggers = useQuery(space, Filter.schema(FunctionTrigger));\n const functions = useQuery(space, Filter.schema(FunctionType));\n const scripts = useQuery(space, Filter.schema(ScriptType));\n\n const [trigger, setTrigger] = useState<FunctionTriggerType>();\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(create(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(create(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n };\n\n return (\n <div className='flex flex-col w-full divide-y divide-separator overflow-y-auto'>\n <List.Root<FunctionTrigger> items={triggers} isItem={S.is(FunctionTrigger)} getId={(field) => field.id}>\n {({ items: triggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {triggers?.map((trigger) => (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center')}\n >\n <Input.Root>\n <Input.Switch checked={trigger.enabled} onCheckedChange={(checked) => (trigger.enabled = checked)} />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle classNames='px-2 cursor-pointer w-0 shrink' onClick={() => handleSelect(trigger)}>\n {getFunctionName(scripts, functions, trigger)}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose URL copy action */}\n <Button onClick={() => navigator.clipboard.writeText(getWebhookUrl(client, trigger))}>\n Copy URL\n </Button>\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n ))}\n </div>\n )}\n </List.Root>\n\n {trigger && (\n <TriggerEditor\n space={space}\n storedTrigger={selected}\n trigger={trigger}\n onSave={handleSave}\n onCancel={handleCancel}\n />\n )}\n\n {!trigger && (\n <div className='flex p-2 justify-center'>\n <IconButton icon='ph--plus--regular' label={t('new trigger')} onClick={handleAdd} />\n </div>\n )}\n </div>\n );\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 const functionObject = functions.find((fn) => fn.name === trigger.function);\n if (!functionObject) {\n return trigger.function;\n }\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? functionObject.name;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport {\n FunctionType,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n type FunctionTrigger,\n ScriptType,\n TriggerKind,\n} from '@dxos/functions';\nimport { Filter, useQuery, type Space } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { Form, SelectInput } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n storedTrigger?: FunctionTrigger;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel, storedTrigger }: TriggerEditorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const functions = useQuery(space, Filter.schema(FunctionType));\n const scripts = useQuery(space, Filter.schema(ScriptType));\n\n const handleSave = (values: FunctionTriggerType) => {\n onSave?.(values);\n };\n\n return (\n <Form<FunctionTriggerType>\n schema={FunctionTriggerSchema}\n values={trigger}\n filter={(props) => props.filter((p) => p.name !== 'meta')}\n onSave={handleSave}\n onCancel={onCancel}\n Custom={{\n ['function' satisfies keyof FunctionTriggerType]: (props) => (\n <SelectInput<FunctionTriggerType>\n {...props}\n options={functions.map((fn) => ({\n value: fn.name,\n label: getFunctionName(scripts, fn),\n }))}\n />\n ),\n ['spec.type' as const]: (props) => (\n <SelectInput<FunctionTriggerType>\n {...props}\n options={Object.values(TriggerKind).map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n }))}\n />\n ),\n }}\n />\n );\n};\n\nconst getFunctionName = (scripts: ScriptType[], fn: FunctionType) => {\n return scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AutomationPanel } from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["React", "useState", "S", "FunctionType", "FunctionTrigger", "FunctionTriggerSchema", "ScriptType", "useClient", "create", "Filter", "useQuery", "getSpace", "IconButton", "Input", "useTranslation", "Button", "List", "ghostHover", "mx", "React", "FunctionType", "FunctionTriggerSchema", "ScriptType", "TriggerKind", "Filter", "useQuery", "useTranslation", "Form", "SelectInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "storedTrigger", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "schema", "FunctionType", "scripts", "ScriptType", "handleSave", "values", "Form", "FunctionTriggerSchema", "filter", "props", "p", "name", "Custom", "SelectInput", "options", "map", "fn", "value", "label", "getFunctionName", "Object", "TriggerKind", "kind", "find", "s", "source", "target", "id", "grid", "AutomationPanel", "space", "t", "useTranslation", "AUTOMATION_PLUGIN", "client", "useClient", "triggers", "useQuery", "Filter", "schema", "FunctionTrigger", "functions", "FunctionType", "scripts", "ScriptType", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "id", "_", "values", "handleAdd", "create", "FunctionTriggerSchema", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "React", "div", "className", "List", "Root", "items", "isItem", "S", "is", "getId", "field", "role", "map", "Item", "key", "item", "classNames", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Button", "navigator", "clipboard", "writeText", "getWebhookUrl", "ItemDeleteButton", "TriggerEditor", "storedTrigger", "onSave", "onCancel", "IconButton", "icon", "label", "spaceId", "getSpace", "edgeUrl", "URL", "config", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "functionObject", "find", "fn", "name", "function", "s", "source", "target", "AutomationPanel"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/meta.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const AUTOMATION_PLUGIN = 'dxos.org/plugin/automation';\n\nexport default {\n id: AUTOMATION_PLUGIN,\n name: 'Automation',\n description: 'Automation workflows.',\n icon: 'ph--magic-wand--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-automation',\n tags: ['experimental'],\n} satisfies PluginMeta;\n"],
|
|
5
|
-
"mappings": ";AAMO,IAAMA,oBAAoB;AAEjC,IAAA,eAAe;EACbC,IAAID;EACJE,MAAM;EACNC,aAAa;EACbC,MAAM;EACNC,QAAQ;EACRC,MAAM;IAAC;;AACT;",
|
|
6
|
-
"names": ["AUTOMATION_PLUGIN", "id", "name", "description", "icon", "source", "tags"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/TriggerEditor/TriggerEditor.tsx", "../../../src/components/AutomationPanel/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useState } from 'react';\n\nimport { S } from '@dxos/echo-schema';\nimport {\n FunctionType,\n FunctionTrigger,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n ScriptType,\n} from '@dxos/functions';\nimport { type Client, useClient } from '@dxos/react-client';\nimport { create, Filter, useQuery, type Space, type ReactiveObject, getSpace } from '@dxos/react-client/echo';\nimport { IconButton, Input, useTranslation, Button } from '@dxos/react-ui';\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?: ReactiveObject<any>;\n};\n\n// TODO(burdon): Factor out common layout with ViewEditor.\nexport const AutomationPanel = ({ space }: AutomationPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const client = useClient();\n const triggers = useQuery(space, Filter.schema(FunctionTrigger));\n const functions = useQuery(space, Filter.schema(FunctionType));\n const scripts = useQuery(space, Filter.schema(ScriptType));\n\n const [trigger, setTrigger] = useState<FunctionTriggerType>();\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(create(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(create(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n };\n\n return (\n <div className='flex flex-col w-full divide-y divide-separator overflow-y-auto'>\n <List.Root<FunctionTrigger> items={triggers} isItem={S.is(FunctionTrigger)} getId={(field) => field.id}>\n {({ items: triggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {triggers?.map((trigger) => (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center')}\n >\n <Input.Root>\n <Input.Switch checked={trigger.enabled} onCheckedChange={(checked) => (trigger.enabled = checked)} />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle classNames='px-2 cursor-pointer w-0 shrink' onClick={() => handleSelect(trigger)}>\n {getFunctionName(scripts, functions, trigger)}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose URL copy action */}\n <Button onClick={() => navigator.clipboard.writeText(getWebhookUrl(client, trigger))}>\n Copy URL\n </Button>\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n ))}\n </div>\n )}\n </List.Root>\n\n {trigger && (\n <TriggerEditor\n space={space}\n storedTrigger={selected}\n trigger={trigger}\n onSave={handleSave}\n onCancel={handleCancel}\n />\n )}\n\n {!trigger && (\n <div className='flex p-2 justify-center'>\n <IconButton icon='ph--plus--regular' label={t('new trigger')} onClick={handleAdd} />\n </div>\n )}\n </div>\n );\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 const functionObject = functions.find((fn) => fn.name === trigger.function);\n if (!functionObject) {\n return trigger.function;\n }\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? functionObject.name;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport {\n FunctionType,\n FunctionTriggerSchema,\n type FunctionTriggerType,\n type FunctionTrigger,\n ScriptType,\n TriggerKind,\n} from '@dxos/functions';\nimport { Filter, useQuery, type Space } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { Form, SelectInput } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n storedTrigger?: FunctionTrigger;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel, storedTrigger }: TriggerEditorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const functions = useQuery(space, Filter.schema(FunctionType));\n const scripts = useQuery(space, Filter.schema(ScriptType));\n\n const handleSave = (values: FunctionTriggerType) => {\n onSave?.(values);\n };\n\n return (\n <Form<FunctionTriggerType>\n schema={FunctionTriggerSchema}\n values={trigger}\n filter={(props) => props.filter((p) => p.name !== 'meta')}\n onSave={handleSave}\n onCancel={onCancel}\n Custom={{\n ['function' satisfies keyof FunctionTriggerType]: (props) => (\n <SelectInput<FunctionTriggerType>\n {...props}\n options={functions.map((fn) => ({\n value: fn.name,\n label: getFunctionName(scripts, fn),\n }))}\n />\n ),\n ['spec.type' as const]: (props) => (\n <SelectInput<FunctionTriggerType>\n {...props}\n options={Object.values(TriggerKind).map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n }))}\n />\n ),\n }}\n />\n );\n};\n\nconst getFunctionName = (scripts: ScriptType[], fn: FunctionType) => {\n return scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AutomationPanel } from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["import_react", "import_functions", "import_echo", "import_react_ui", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "storedTrigger", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "schema", "FunctionType", "scripts", "ScriptType", "handleSave", "values", "React", "Form", "FunctionTriggerSchema", "filter", "props", "p", "name", "Custom", "SelectInput", "options", "map", "fn", "value", "label", "getFunctionName", "Object", "TriggerKind", "kind", "find", "s", "source", "target", "id", "grid", "AutomationPanel", "client", "useClient", "triggers", "FunctionTrigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "_", "handleAdd", "create", "undefined", "handleDelete", "db", "remove", "assign", "add", "handleCancel", "div", "className", "List", "Root", "items", "isItem", "S", "is", "getId", "field", "role", "Item", "key", "item", "classNames", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "Button", "navigator", "clipboard", "writeText", "getWebhookUrl", "ItemDeleteButton", "IconButton", "icon", "spaceId", "getSpace", "edgeUrl", "URL", "config", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "functionObject", "function"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/meta.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const AUTOMATION_PLUGIN = 'dxos.org/plugin/automation';\n\nexport default {\n id: AUTOMATION_PLUGIN,\n name: 'Automation',\n description: 'Automation workflows.',\n icon: 'ph--magic-wand--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-automation',\n tags: ['experimental'],\n} satisfies PluginMeta;\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAMO,IAAMA,oBAAoB;AAEjC,IAAA,eAAe;EACbC,IAAID;EACJE,MAAM;EACNC,aAAa;EACbC,MAAM;EACNC,QAAQ;EACRC,MAAM;IAAC;;AACT;",
|
|
6
|
-
"names": ["AUTOMATION_PLUGIN", "id", "name", "description", "icon", "source", "tags"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/types/schema.ts", "../../../src/types/types.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Ref, S, TypedObject } from '@dxos/echo-schema';\n\n// TODO(burdon): Change to S.Literal (and discriminated union).\nexport enum ChainInputType {\n VALUE = 0,\n PASS_THROUGH = 1,\n RETRIEVER = 2,\n FUNCTION = 3,\n QUERY = 4,\n RESOLVER = 5,\n CONTEXT = 6,\n SCHEMA = 7,\n}\n\nexport const ChainInputSchema = S.mutable(\n S.Struct({\n name: S.String,\n type: S.optional(S.Enums(ChainInputType)),\n value: S.optional(S.String),\n }),\n);\n\nexport type ChainInput = S.Schema.Type<typeof ChainInputSchema>;\n\nexport class ChainPromptType extends TypedObject({ typename: 'dxos.org/type/ChainPrompt', version: '0.1.0' })({\n command: S.optional(S.String),\n template: S.String,\n inputs: S.optional(S.mutable(S.Array(ChainInputSchema))),\n}) {}\n\nexport class ChainType extends TypedObject({ typename: 'dxos.org/type/Chain', version: '0.1.0' })({\n name: S.optional(S.String),\n prompts: S.optional(S.mutable(S.Array(Ref(ChainPromptType)))),\n}) {}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport type {\n GraphBuilderProvides,\n IntentResolverProvides,\n MetadataRecordsProvides,\n SurfaceProvides,\n TranslationsProvides,\n} from '@dxos/app-framework';\nimport { type PanelProvides } from '@dxos/plugin-deck/types';\nimport { type SchemaProvides } from '@dxos/plugin-space';\n\n// import { AUTOMATION_PLUGIN } from '../meta';\n\n// const AUTOMATION_ACTION = `${AUTOMATION_PLUGIN}/action`;\n\nexport enum AutomationAction {}\n\nexport type AutomationPluginProvides = SurfaceProvides &\n IntentResolverProvides &\n MetadataRecordsProvides &\n TranslationsProvides &\n GraphBuilderProvides &\n SchemaProvides &\n PanelProvides;\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,yBAAoC;;UAGxBA,iBAAAA;;;;;;;;;GAAAA,mBAAAA,iBAAAA,CAAAA,EAAAA;AAWL,IAAMC,mBAAmBC,qBAAEC,QAChCD,qBAAEE,OAAO;EACPC,MAAMH,qBAAEI;EACRC,MAAML,qBAAEM,SAASN,qBAAEO,MAAMT,cAAAA,CAAAA;EACzBU,OAAOR,qBAAEM,SAASN,qBAAEI,MAAM;AAC5B,CAAA,CAAA;AAKK,IAAMK,kBAAN,kBAA8BC,gCAAY;EAAEC,UAAU;EAA6BC,SAAS;AAAQ,CAAA,EAAG;EAC5GC,SAASb,qBAAEM,SAASN,qBAAEI,MAAM;EAC5BU,UAAUd,qBAAEI;EACZW,QAAQf,qBAAEM,SAASN,qBAAEC,QAAQD,qBAAEgB,MAAMjB,gBAAAA,CAAAA,CAAAA;AACvC,CAAA,EAAA;AAAI;AAEG,IAAMkB,YAAN,kBAAwBP,gCAAY;EAAEC,UAAU;EAAuBC,SAAS;AAAQ,CAAA,EAAG;EAChGT,MAAMH,qBAAEM,SAASN,qBAAEI,MAAM;EACzBc,SAASlB,qBAAEM,SAASN,qBAAEC,QAAQD,qBAAEgB,UAAMG,wBAAIV,eAAAA,CAAAA,CAAAA,CAAAA;AAC5C,CAAA,EAAA;AAAI;;0BCnBQW,mBAAAA;AAAAA,GAAAA,qBAAAA,mBAAAA,CAAAA,EAAAA;",
|
|
6
|
-
"names": ["ChainInputType", "ChainInputSchema", "S", "mutable", "Struct", "name", "String", "type", "optional", "Enums", "value", "ChainPromptType", "TypedObject", "typename", "version", "command", "template", "inputs", "Array", "ChainType", "prompts", "Ref", "AutomationAction"]
|
|
7
|
-
}
|
package/dist/lib/node/meta.cjs
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var meta_exports = {};
|
|
20
|
-
__export(meta_exports, {
|
|
21
|
-
AUTOMATION_PLUGIN: () => import_chunk_DTJ7XVO2.AUTOMATION_PLUGIN,
|
|
22
|
-
default: () => import_chunk_DTJ7XVO2.meta_default
|
|
23
|
-
});
|
|
24
|
-
module.exports = __toCommonJS(meta_exports);
|
|
25
|
-
var import_chunk_DTJ7XVO2 = require("./chunk-DTJ7XVO2.cjs");
|
|
26
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
27
|
-
0 && (module.exports = {
|
|
28
|
-
AUTOMATION_PLUGIN
|
|
29
|
-
});
|
|
30
|
-
//# sourceMappingURL=meta.cjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["meta.cjs"],
|
|
4
|
-
"sourcesContent": ["import {\n AUTOMATION_PLUGIN,\n meta_default\n} from \"./chunk-DTJ7XVO2.cjs\";\nexport {\n AUTOMATION_PLUGIN,\n meta_default as default\n};\n//# sourceMappingURL=meta.cjs.map\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAGO;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|