@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.
Files changed (107) hide show
  1. package/dist/lib/browser/{AssistantPanel-32FH2RA6.mjs → AssistantPanel-N276BTPV.mjs} +2 -2
  2. package/dist/lib/browser/AutomationPanel-IHZ4JKVS.mjs +232 -0
  3. package/dist/lib/browser/AutomationPanel-IHZ4JKVS.mjs.map +7 -0
  4. package/dist/lib/browser/app-graph-builder-IJTTULDP.mjs +131 -0
  5. package/dist/lib/browser/app-graph-builder-IJTTULDP.mjs.map +7 -0
  6. package/dist/lib/browser/chunk-4AIMDHKY.mjs +10 -0
  7. package/dist/lib/browser/chunk-4AIMDHKY.mjs.map +7 -0
  8. package/dist/lib/browser/{chunk-DN5M2QL5.mjs → chunk-DL6LB2NI.mjs} +2 -8
  9. package/dist/lib/browser/{chunk-DN5M2QL5.mjs.map → chunk-DL6LB2NI.mjs.map} +4 -4
  10. package/dist/lib/browser/{chunk-X5KMOH3I.mjs → chunk-HKX3D3ZP.mjs} +3 -3
  11. package/dist/lib/browser/chunk-HKX3D3ZP.mjs.map +7 -0
  12. package/dist/lib/browser/index.mjs +89 -236
  13. package/dist/lib/browser/index.mjs.map +4 -4
  14. package/dist/lib/browser/meta.json +1 -1
  15. package/dist/lib/browser/react-surface-LL72F3F4.mjs +34 -0
  16. package/dist/lib/browser/react-surface-LL72F3F4.mjs.map +7 -0
  17. package/dist/lib/browser/types/index.mjs +1 -3
  18. package/dist/lib/node/{AssistantPanel-XANI7YNV.cjs → AssistantPanel-Z4GVHUF3.cjs} +6 -6
  19. package/dist/lib/node/{AutomationPanel-VADY3HMP.cjs → AutomationPanel-PPODB5XA.cjs} +113 -32
  20. package/dist/lib/node/AutomationPanel-PPODB5XA.cjs.map +7 -0
  21. package/dist/lib/node/app-graph-builder-MF5M4QRS.cjs +147 -0
  22. package/dist/lib/node/app-graph-builder-MF5M4QRS.cjs.map +7 -0
  23. package/dist/lib/node/chunk-25AQIF3L.cjs +43 -0
  24. package/dist/lib/node/chunk-25AQIF3L.cjs.map +7 -0
  25. package/dist/lib/node/{chunk-DTJ7XVO2.cjs → chunk-5VF5JKUN.cjs} +7 -7
  26. package/dist/lib/node/chunk-5VF5JKUN.cjs.map +7 -0
  27. package/dist/lib/node/{chunk-NIL4TP6U.cjs → chunk-JNDMZQH7.cjs} +4 -9
  28. package/dist/lib/node/chunk-JNDMZQH7.cjs.map +7 -0
  29. package/dist/lib/node/index.cjs +112 -258
  30. package/dist/lib/node/index.cjs.map +4 -4
  31. package/dist/lib/node/meta.json +1 -1
  32. package/dist/lib/node/react-surface-DVAU4MGD.cjs +57 -0
  33. package/dist/lib/node/react-surface-DVAU4MGD.cjs.map +7 -0
  34. package/dist/lib/node/types/index.cjs +5 -7
  35. package/dist/lib/node/types/index.cjs.map +2 -2
  36. package/dist/lib/node-esm/{AssistantPanel-5M6O6JV7.mjs → AssistantPanel-DDCQHBJX.mjs} +2 -2
  37. package/dist/lib/node-esm/AutomationPanel-R3D6CRF5.mjs +233 -0
  38. package/dist/lib/node-esm/AutomationPanel-R3D6CRF5.mjs.map +7 -0
  39. package/dist/lib/node-esm/app-graph-builder-5N7OK23B.mjs +132 -0
  40. package/dist/lib/node-esm/app-graph-builder-5N7OK23B.mjs.map +7 -0
  41. package/dist/lib/node-esm/{chunk-GCHXTXVT.mjs → chunk-GIAYUM5I.mjs} +2 -8
  42. package/dist/lib/node-esm/{chunk-GCHXTXVT.mjs.map → chunk-GIAYUM5I.mjs.map} +4 -4
  43. package/dist/lib/node-esm/{chunk-HNOBZHWK.mjs → chunk-X3LPRWIL.mjs} +3 -3
  44. package/dist/lib/node-esm/chunk-X3LPRWIL.mjs.map +7 -0
  45. package/dist/lib/node-esm/chunk-XW7TEQA3.mjs +12 -0
  46. package/dist/lib/node-esm/chunk-XW7TEQA3.mjs.map +7 -0
  47. package/dist/lib/node-esm/index.mjs +89 -236
  48. package/dist/lib/node-esm/index.mjs.map +4 -4
  49. package/dist/lib/node-esm/meta.json +1 -1
  50. package/dist/lib/node-esm/react-surface-4BED2PZ4.mjs +35 -0
  51. package/dist/lib/node-esm/react-surface-4BED2PZ4.mjs.map +7 -0
  52. package/dist/lib/node-esm/types/index.mjs +1 -3
  53. package/dist/types/src/AutomationPlugin.d.ts +1 -3
  54. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  55. package/dist/types/src/capabilities/app-graph-builder.d.ts +180 -0
  56. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
  57. package/dist/types/src/capabilities/index.d.ts +179 -0
  58. package/dist/types/src/capabilities/index.d.ts.map +1 -0
  59. package/dist/types/src/capabilities/react-surface.d.ts +4 -0
  60. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  61. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -1
  62. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  63. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -2
  64. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  65. package/dist/types/src/components/index.d.ts +1 -1
  66. package/dist/types/src/components/index.d.ts.map +1 -1
  67. package/dist/types/src/index.d.ts +1 -2
  68. package/dist/types/src/index.d.ts.map +1 -1
  69. package/dist/types/src/meta.d.ts +1 -2
  70. package/dist/types/src/meta.d.ts.map +1 -1
  71. package/dist/types/src/translations.d.ts +7 -0
  72. package/dist/types/src/translations.d.ts.map +1 -1
  73. package/dist/types/src/types/index.d.ts +0 -1
  74. package/dist/types/src/types/index.d.ts.map +1 -1
  75. package/dist/types/tsconfig.tsbuildinfo +1 -1
  76. package/package.json +38 -46
  77. package/src/AutomationPlugin.tsx +55 -193
  78. package/src/capabilities/app-graph-builder.ts +127 -0
  79. package/src/capabilities/index.ts +8 -0
  80. package/src/capabilities/react-surface.tsx +27 -0
  81. package/src/components/AutomationPanel/AutomationPanel.tsx +54 -37
  82. package/src/components/TriggerEditor/TriggerEditor.tsx +63 -6
  83. package/src/index.ts +1 -4
  84. package/src/meta.ts +1 -1
  85. package/src/translations.ts +9 -0
  86. package/src/types/index.ts +0 -1
  87. package/dist/lib/browser/AutomationPanel-ABGPG5LE.mjs +0 -151
  88. package/dist/lib/browser/AutomationPanel-ABGPG5LE.mjs.map +0 -7
  89. package/dist/lib/browser/chunk-X5KMOH3I.mjs.map +0 -7
  90. package/dist/lib/browser/meta.mjs +0 -9
  91. package/dist/lib/browser/meta.mjs.map +0 -7
  92. package/dist/lib/node/AutomationPanel-VADY3HMP.cjs.map +0 -7
  93. package/dist/lib/node/chunk-DTJ7XVO2.cjs.map +0 -7
  94. package/dist/lib/node/chunk-NIL4TP6U.cjs.map +0 -7
  95. package/dist/lib/node/meta.cjs +0 -30
  96. package/dist/lib/node/meta.cjs.map +0 -7
  97. package/dist/lib/node-esm/AutomationPanel-EETYIDPA.mjs +0 -152
  98. package/dist/lib/node-esm/AutomationPanel-EETYIDPA.mjs.map +0 -7
  99. package/dist/lib/node-esm/chunk-HNOBZHWK.mjs.map +0 -7
  100. package/dist/lib/node-esm/meta.mjs +0 -10
  101. package/dist/lib/node-esm/meta.mjs.map +0 -7
  102. package/dist/types/src/types/types.d.ts +0 -7
  103. package/dist/types/src/types/types.d.ts.map +0 -1
  104. package/src/types/types.ts +0 -27
  105. /package/dist/lib/browser/{AssistantPanel-32FH2RA6.mjs.map → AssistantPanel-N276BTPV.mjs.map} +0 -0
  106. /package/dist/lib/node/{AssistantPanel-XANI7YNV.cjs.map → AssistantPanel-Z4GVHUF3.cjs.map} +0 -0
  107. /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
- <List.Item<FunctionTrigger>
81
- key={trigger.id}
82
- item={trigger}
83
- classNames={mx(grid, ghostHover, 'items-center')}
84
- >
85
- <Input.Root>
86
- <Input.Switch checked={trigger.enabled} onCheckedChange={(checked) => (trigger.enabled = checked)} />
87
- </Input.Root>
88
-
89
- <div className={'flex'}>
90
- <List.ItemTitle classNames='px-2 cursor-pointer w-0 shrink' onClick={() => handleSelect(trigger)}>
91
- {getFunctionName(scripts, functions, trigger)}
92
- </List.ItemTitle>
93
-
94
- {/* TODO: a better way to expose URL copy action */}
95
- <Button onClick={() => navigator.clipboard.writeText(getWebhookUrl(client, trigger))}>
96
- Copy URL
97
- </Button>
98
- </div>
99
-
100
- <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />
101
- </List.Item>
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 trigger.function;
154
+ return shortId;
138
155
  }
139
- return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? functionObject.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, storedTrigger }: TriggerEditorProps) => {
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
@@ -6,7 +6,7 @@ import { type PluginMeta } from '@dxos/app-framework';
6
6
 
7
7
  export const AUTOMATION_PLUGIN = 'dxos.org/plugin/automation';
8
8
 
9
- export default {
9
+ export const meta = {
10
10
  id: AUTOMATION_PLUGIN,
11
11
  name: 'Automation',
12
12
  description: 'Automation workflows.',
@@ -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
  },
@@ -3,4 +3,3 @@
3
3
  //
4
4
 
5
5
  export * from './schema';
6
- export * from './types';
@@ -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,9 +0,0 @@
1
- import {
2
- AUTOMATION_PLUGIN,
3
- meta_default
4
- } from "./chunk-X5KMOH3I.mjs";
5
- export {
6
- AUTOMATION_PLUGIN,
7
- meta_default as default
8
- };
9
- //# sourceMappingURL=meta.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": [],
4
- "sourcesContent": [],
5
- "mappings": "",
6
- "names": []
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
- }
@@ -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
- }