@dxos/plugin-automation 0.7.5-main.9d2a38b → 0.7.5-main.e9bb01b

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 (58) hide show
  1. package/dist/lib/browser/{AssistantPanel-N276BTPV.mjs → AssistantPanel-NTOUHOWA.mjs} +3 -3
  2. package/dist/lib/browser/{AssistantPanel-N276BTPV.mjs.map → AssistantPanel-NTOUHOWA.mjs.map} +2 -2
  3. package/dist/lib/browser/{AutomationPanel-IHZ4JKVS.mjs → AutomationPanel-KT3YFV56.mjs} +8 -9
  4. package/dist/lib/browser/AutomationPanel-KT3YFV56.mjs.map +7 -0
  5. package/dist/lib/browser/{app-graph-builder-IJTTULDP.mjs → app-graph-builder-6FSMLMT4.mjs} +2 -2
  6. package/dist/lib/browser/chunk-4ODBJDXM.mjs +10 -0
  7. package/dist/lib/browser/{chunk-HKX3D3ZP.mjs → chunk-DQ7ZSYJJ.mjs} +2 -2
  8. package/dist/lib/browser/{chunk-HKX3D3ZP.mjs.map → chunk-DQ7ZSYJJ.mjs.map} +2 -2
  9. package/dist/lib/browser/index.mjs +8 -8
  10. package/dist/lib/browser/index.mjs.map +3 -3
  11. package/dist/lib/browser/meta.json +1 -1
  12. package/dist/lib/browser/{react-surface-LL72F3F4.mjs → react-surface-5YTE5MRE.mjs} +3 -3
  13. package/dist/lib/node/{AssistantPanel-Z4GVHUF3.cjs → AssistantPanel-U7GDWPRC.cjs} +7 -7
  14. package/dist/lib/node/{AssistantPanel-Z4GVHUF3.cjs.map → AssistantPanel-U7GDWPRC.cjs.map} +2 -2
  15. package/dist/lib/node/{AutomationPanel-PPODB5XA.cjs → AutomationPanel-H5WE4FIU.cjs} +13 -14
  16. package/dist/lib/node/AutomationPanel-H5WE4FIU.cjs.map +7 -0
  17. package/dist/lib/node/{app-graph-builder-MF5M4QRS.cjs → app-graph-builder-65TBXO3I.cjs} +12 -12
  18. package/dist/lib/node/{chunk-25AQIF3L.cjs → chunk-JUSXT4U5.cjs} +6 -6
  19. package/dist/lib/node/{chunk-5VF5JKUN.cjs → chunk-TQEDPRY5.cjs} +5 -5
  20. package/dist/lib/node/{chunk-5VF5JKUN.cjs.map → chunk-TQEDPRY5.cjs.map} +2 -2
  21. package/dist/lib/node/index.cjs +22 -22
  22. package/dist/lib/node/index.cjs.map +3 -3
  23. package/dist/lib/node/meta.json +1 -1
  24. package/dist/lib/node/{react-surface-DVAU4MGD.cjs → react-surface-S6U5ISJ6.cjs} +10 -10
  25. package/dist/lib/node-esm/{AssistantPanel-DDCQHBJX.mjs → AssistantPanel-M67P24GS.mjs} +3 -3
  26. package/dist/lib/node-esm/{AssistantPanel-DDCQHBJX.mjs.map → AssistantPanel-M67P24GS.mjs.map} +2 -2
  27. package/dist/lib/node-esm/{AutomationPanel-R3D6CRF5.mjs → AutomationPanel-MW42U6I4.mjs} +8 -9
  28. package/dist/lib/node-esm/{AutomationPanel-R3D6CRF5.mjs.map → AutomationPanel-MW42U6I4.mjs.map} +3 -3
  29. package/dist/lib/node-esm/{app-graph-builder-5N7OK23B.mjs → app-graph-builder-4SD4F3KN.mjs} +2 -2
  30. package/dist/lib/node-esm/{chunk-X3LPRWIL.mjs → chunk-JFHI22MF.mjs} +2 -2
  31. package/dist/lib/node-esm/{chunk-X3LPRWIL.mjs.map → chunk-JFHI22MF.mjs.map} +2 -2
  32. package/dist/lib/node-esm/{chunk-XW7TEQA3.mjs → chunk-XVIEXSEZ.mjs} +3 -3
  33. package/dist/lib/node-esm/index.mjs +8 -8
  34. package/dist/lib/node-esm/index.mjs.map +3 -3
  35. package/dist/lib/node-esm/meta.json +1 -1
  36. package/dist/lib/node-esm/{react-surface-4BED2PZ4.mjs → react-surface-RWTR3TKT.mjs} +3 -3
  37. package/dist/types/src/capabilities/app-graph-builder.d.ts +22 -22
  38. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  39. package/dist/types/src/capabilities/index.d.ts +25 -25
  40. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  41. package/dist/types/src/meta.d.ts.map +1 -1
  42. package/package.json +38 -38
  43. package/src/AutomationPlugin.tsx +4 -4
  44. package/src/components/AssistantPanel/AssistantPanel.tsx +1 -4
  45. package/src/components/TriggerEditor/TriggerEditor.tsx +9 -9
  46. package/src/meta.ts +2 -1
  47. package/dist/lib/browser/AutomationPanel-IHZ4JKVS.mjs.map +0 -7
  48. package/dist/lib/browser/chunk-4AIMDHKY.mjs +0 -10
  49. package/dist/lib/node/AutomationPanel-PPODB5XA.cjs.map +0 -7
  50. /package/dist/lib/browser/{app-graph-builder-IJTTULDP.mjs.map → app-graph-builder-6FSMLMT4.mjs.map} +0 -0
  51. /package/dist/lib/browser/{chunk-4AIMDHKY.mjs.map → chunk-4ODBJDXM.mjs.map} +0 -0
  52. /package/dist/lib/browser/{react-surface-LL72F3F4.mjs.map → react-surface-5YTE5MRE.mjs.map} +0 -0
  53. /package/dist/lib/node/{app-graph-builder-MF5M4QRS.cjs.map → app-graph-builder-65TBXO3I.cjs.map} +0 -0
  54. /package/dist/lib/node/{chunk-25AQIF3L.cjs.map → chunk-JUSXT4U5.cjs.map} +0 -0
  55. /package/dist/lib/node/{react-surface-DVAU4MGD.cjs.map → react-surface-S6U5ISJ6.cjs.map} +0 -0
  56. /package/dist/lib/node-esm/{app-graph-builder-5N7OK23B.mjs.map → app-graph-builder-4SD4F3KN.mjs.map} +0 -0
  57. /package/dist/lib/node-esm/{chunk-XW7TEQA3.mjs.map → chunk-XVIEXSEZ.mjs.map} +0 -0
  58. /package/dist/lib/node-esm/{react-surface-4BED2PZ4.mjs.map → react-surface-RWTR3TKT.mjs.map} +0 -0
@@ -43,7 +43,7 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEdito
43
43
  onCancel={onCancel}
44
44
  Custom={{
45
45
  ['function' satisfies keyof FunctionTriggerType]: (props) => (
46
- <SelectInput<FunctionTriggerType>
46
+ <SelectInput
47
47
  {...props}
48
48
  options={functions.map((fn) => ({
49
49
  value: fn.name,
@@ -52,7 +52,7 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEdito
52
52
  />
53
53
  ),
54
54
  ['spec.type' as const]: (props) => (
55
- <SelectInput<FunctionTriggerType>
55
+ <SelectInput
56
56
  {...props}
57
57
  options={Object.values(TriggerKind).map((kind) => ({
58
58
  value: kind,
@@ -61,11 +61,11 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEdito
61
61
  />
62
62
  ),
63
63
  ['meta' as const]: (props) => {
64
- const meta = props.getValue('meta')!;
64
+ const meta = props.getValue()!;
65
65
 
66
66
  const [newMetaFieldName, setNewMetaFieldName] = useState('');
67
67
 
68
- React.useEffect(() => props.onValueChange('meta', 'object', { ...meta }), []);
68
+ React.useEffect(() => props.onValueChange('object', { ...meta }), []);
69
69
 
70
70
  return (
71
71
  <>
@@ -75,7 +75,7 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEdito
75
75
  return (
76
76
  <div key={compositeKey} role='none' className='flex items-center mt-2 gap-1'>
77
77
  <div role='none' className='flex-1'>
78
- <TextInput {...props} property={compositeKey} type={'string'} label={key} />
78
+ <TextInput {...props} type={'string'} label={key} />
79
79
  </div>
80
80
  <IconButton
81
81
  icon='ph--trash--regular'
@@ -83,9 +83,9 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEdito
83
83
  classNames={'mt-6'}
84
84
  label={t('trigger meta remove')}
85
85
  onClick={() => {
86
- const newValues: any = { ...props.getValue('meta') };
86
+ const newValues: any = { ...props.getValue() };
87
87
  delete newValues[key];
88
- props.onValueChange('meta', 'object', newValues);
88
+ props.onValueChange('object', newValues);
89
89
  }}
90
90
  />
91
91
  </div>
@@ -107,10 +107,10 @@ export const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEdito
107
107
  label={t('trigger meta add')}
108
108
  onClick={() => {
109
109
  if (newMetaFieldName.length) {
110
- const meta = props.getValue('meta') ?? {};
110
+ const meta = props.getValue() ?? {};
111
111
  const metaWithNewProp = { ...meta, [newMetaFieldName]: '' };
112
112
  setNewMetaFieldName('');
113
- props.onValueChange('meta', 'object', metaWithNewProp);
113
+ props.onValueChange('object', metaWithNewProp);
114
114
  }
115
115
  }}
116
116
  />
package/src/meta.ts CHANGED
@@ -9,7 +9,8 @@ export const AUTOMATION_PLUGIN = 'dxos.org/plugin/automation';
9
9
  export const meta = {
10
10
  id: AUTOMATION_PLUGIN,
11
11
  name: 'Automation',
12
- description: 'Automation workflows.',
12
+ description:
13
+ 'The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.',
13
14
  icon: 'ph--magic-wand--regular',
14
15
  source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-automation',
15
16
  tags: ['experimental'],
@@ -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 TriggerKind,\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, object }: 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, { meta: {} }));\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 const copyAction = getCopyAction(client, trigger);\n return (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center', 'px-2')}\n >\n <Input.Root>\n <Input.Switch\n checked={trigger.enabled}\n onCheckedChange={(checked) => (trigger.enabled = checked)}\n />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle\n classNames='px-1 cursor-pointer w-0 shrink truncate'\n onClick={() => handleSelect(trigger)}\n >\n {getFunctionName(scripts, functions, trigger) ?? '∅'}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose copy action */}\n {copyAction && (\n <Button onClick={() => navigator.clipboard.writeText(copyAction.contentProvider())}>\n {t(copyAction.translationKey)}\n </Button>\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n\n {trigger && <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />}\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 getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.type === TriggerKind.Email) {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.type === TriggerKind.Webhook) {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTriggerType) => {\n const shortId = trigger.function && `${trigger.function?.slice(0, 16)}…`;\n const functionObject = functions.find((fn) => fn.name === trigger.function);\n if (!functionObject) {\n return shortId;\n }\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useState } 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 { IconButton, Input, useTranslation } from '@dxos/react-ui';\nimport { Form, SelectInput, TextInput } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n\n const functions = useQuery(space, Filter.schema(FunctionType));\n const 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 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 ['meta' as const]: (props) => {\n const meta = props.getValue('meta')!;\n\n const [newMetaFieldName, setNewMetaFieldName] = useState('');\n\n React.useEffect(() => props.onValueChange('meta', 'object', { ...meta }), []);\n\n return (\n <>\n <div>{props.label}</div>\n {[...Object.keys(meta)].map((key) => {\n const compositeKey: any = `meta.${key}`;\n return (\n <div key={compositeKey} role='none' className='flex items-center mt-2 gap-1'>\n <div role='none' className='flex-1'>\n <TextInput {...props} property={compositeKey} type={'string'} label={key} />\n </div>\n <IconButton\n icon='ph--trash--regular'\n iconOnly\n classNames={'mt-6'}\n label={t('trigger meta remove')}\n onClick={() => {\n const newValues: any = { ...props.getValue('meta') };\n delete newValues[key];\n props.onValueChange('meta', 'object', newValues);\n }}\n />\n </div>\n );\n })}\n <div role='none' className='flex items-center mt-2 gap-1 plb-1'>\n <div role='none' className='flex-1'>\n <Input.Root>\n <Input.TextInput\n placeholder={t('trigger meta prop name placeholder')}\n value={newMetaFieldName}\n onChange={(event) => setNewMetaFieldName(event.target.value)}\n />\n </Input.Root>\n </div>\n <IconButton\n icon='ph--plus--regular'\n iconOnly\n label={t('trigger meta add')}\n onClick={() => {\n if (newMetaFieldName.length) {\n const meta = props.getValue('meta') ?? {};\n const metaWithNewProp = { ...meta, [newMetaFieldName]: '' };\n setNewMetaFieldName('');\n props.onValueChange('meta', 'object', metaWithNewProp);\n }\n }}\n />\n </div>\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", "TriggerKind", "ScriptType", "useClient", "create", "Filter", "useQuery", "getSpace", "IconButton", "Input", "useTranslation", "Button", "List", "ghostHover", "mx", "React", "useState", "FunctionType", "FunctionTriggerSchema", "ScriptType", "TriggerKind", "Filter", "useQuery", "IconButton", "Input", "useTranslation", "Form", "SelectInput", "TextInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "schema", "FunctionType", "scripts", "ScriptType", "handleSave", "values", "Form", "FunctionTriggerSchema", "Custom", "props", "SelectInput", "options", "map", "fn", "value", "name", "label", "getFunctionName", "Object", "TriggerKind", "kind", "meta", "getValue", "newMetaFieldName", "setNewMetaFieldName", "useState", "React", "useEffect", "onValueChange", "div", "keys", "key", "compositeKey", "role", "className", "TextInput", "property", "type", "IconButton", "icon", "iconOnly", "classNames", "onClick", "newValues", "Input", "Root", "placeholder", "onChange", "event", "target", "length", "metaWithNewProp", "find", "s", "source", "id", "grid", "AutomationPanel", "space", "object", "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", "meta", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "React", "div", "className", "List", "Root", "items", "isItem", "S", "is", "getId", "field", "role", "map", "copyAction", "getCopyAction", "Item", "key", "item", "classNames", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "getFunctionName", "Button", "navigator", "clipboard", "writeText", "contentProvider", "translationKey", "ItemDeleteButton", "TriggerEditor", "onSave", "onCancel", "IconButton", "icon", "label", "spec", "type", "TriggerKind", "Email", "getSpace", "Webhook", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "slice", "functionObject", "find", "fn", "name", "s", "source", "target", "AutomationPanel"]
7
- }
@@ -1,10 +0,0 @@
1
- // packages/plugins/experimental/plugin-automation/src/components/index.ts
2
- import { lazy } from "react";
3
- var AssistantPanel = lazy(() => import("./AssistantPanel-N276BTPV.mjs"));
4
- var AutomationPanel = lazy(() => import("./AutomationPanel-IHZ4JKVS.mjs"));
5
-
6
- export {
7
- AssistantPanel,
8
- AutomationPanel
9
- };
10
- //# sourceMappingURL=chunk-4AIMDHKY.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 TriggerKind,\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, object }: 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, { meta: {} }));\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 const copyAction = getCopyAction(client, trigger);\n return (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center', 'px-2')}\n >\n <Input.Root>\n <Input.Switch\n checked={trigger.enabled}\n onCheckedChange={(checked) => (trigger.enabled = checked)}\n />\n </Input.Root>\n\n <div className={'flex'}>\n <List.ItemTitle\n classNames='px-1 cursor-pointer w-0 shrink truncate'\n onClick={() => handleSelect(trigger)}\n >\n {getFunctionName(scripts, functions, trigger) ?? '∅'}\n </List.ItemTitle>\n\n {/* TODO: a better way to expose copy action */}\n {copyAction && (\n <Button onClick={() => navigator.clipboard.writeText(copyAction.contentProvider())}>\n {t(copyAction.translationKey)}\n </Button>\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n\n {trigger && <TriggerEditor space={space} trigger={trigger} onSave={handleSave} onCancel={handleCancel} />}\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 getCopyAction = (client: Client, trigger: FunctionTrigger | undefined) => {\n if (trigger?.spec?.type === TriggerKind.Email) {\n return { translationKey: 'trigger copy email', contentProvider: () => `${getSpace(trigger)!.id}@dxos.network` };\n }\n\n if (trigger?.spec?.type === TriggerKind.Webhook) {\n return { translationKey: 'trigger copy url', contentProvider: () => getWebhookUrl(client, trigger) };\n }\n\n return undefined;\n};\n\nconst getWebhookUrl = (client: Client, trigger: FunctionTrigger) => {\n const spaceId = getSpace(trigger)!.id;\n const edgeUrl = new URL(client.config.values.runtime!.services!.edge!.url!);\n const isSecure = edgeUrl.protocol.startsWith('https') || edgeUrl.protocol.startsWith('wss');\n edgeUrl.protocol = isSecure ? 'https' : 'http';\n return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();\n};\n\nconst getFunctionName = (scripts: ScriptType[], functions: FunctionType[], trigger: FunctionTriggerType) => {\n const shortId = trigger.function && `${trigger.function?.slice(0, 16)}…`;\n const functionObject = functions.find((fn) => fn.name === trigger.function);\n if (!functionObject) {\n return shortId;\n }\n return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useState } 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 { IconButton, Input, useTranslation } from '@dxos/react-ui';\nimport { Form, SelectInput, TextInput } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: FunctionTriggerType;\n onSave?: (trigger: Omit<FunctionTrigger, 'id'>) => void;\n onCancel?: () => void;\n};\n\nexport const TriggerEditor = ({ space, trigger, onSave, onCancel }: TriggerEditorProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n\n const functions = useQuery(space, Filter.schema(FunctionType));\n const 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 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 ['meta' as const]: (props) => {\n const meta = props.getValue('meta')!;\n\n const [newMetaFieldName, setNewMetaFieldName] = useState('');\n\n React.useEffect(() => props.onValueChange('meta', 'object', { ...meta }), []);\n\n return (\n <>\n <div>{props.label}</div>\n {[...Object.keys(meta)].map((key) => {\n const compositeKey: any = `meta.${key}`;\n return (\n <div key={compositeKey} role='none' className='flex items-center mt-2 gap-1'>\n <div role='none' className='flex-1'>\n <TextInput {...props} property={compositeKey} type={'string'} label={key} />\n </div>\n <IconButton\n icon='ph--trash--regular'\n iconOnly\n classNames={'mt-6'}\n label={t('trigger meta remove')}\n onClick={() => {\n const newValues: any = { ...props.getValue('meta') };\n delete newValues[key];\n props.onValueChange('meta', 'object', newValues);\n }}\n />\n </div>\n );\n })}\n <div role='none' className='flex items-center mt-2 gap-1 plb-1'>\n <div role='none' className='flex-1'>\n <Input.Root>\n <Input.TextInput\n placeholder={t('trigger meta prop name placeholder')}\n value={newMetaFieldName}\n onChange={(event) => setNewMetaFieldName(event.target.value)}\n />\n </Input.Root>\n </div>\n <IconButton\n icon='ph--plus--regular'\n iconOnly\n label={t('trigger meta add')}\n onClick={() => {\n if (newMetaFieldName.length) {\n const meta = props.getValue('meta') ?? {};\n const metaWithNewProp = { ...meta, [newMetaFieldName]: '' };\n setNewMetaFieldName('');\n props.onValueChange('meta', 'object', metaWithNewProp);\n }\n }}\n />\n </div>\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": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,mBAAgC;AAEhC,yBAAkB;AAClB,uBAOO;AACP,0BAAuC;AACvC,kBAAoF;AACpF,sBAA0D;AAC1D,2BAAqB;AACrB,4BAA+B;ACf/B,IAAAA,gBAAgC;AAEhC,IAAAC,oBAOO;AACP,IAAAC,eAA6C;AAC7C,IAAAC,mBAAkD;AAClD,2BAA6C;AAWtC,IAAMC,gBAAgB,CAAC,EAAEC,OAAOC,SAASC,QAAQC,SAAQ,MAAsB;AACpF,QAAM,EAAEC,EAAC,QAAKC,iCAAeC,uCAAAA;AAE7B,QAAMC,gBAAYC,uBAASR,OAAOS,oBAAOC,OAAOC,8BAAAA,CAAAA;AAChD,QAAMC,cAAUJ,uBAASR,OAAOS,oBAAOC,OAAOG,4BAAAA,CAAAA;AAE9C,QAAMC,aAAa,CAACC,WAAAA;AAClBb,aAASa,MAAAA;EACX;AAEA,SACE,8BAAAC,QAAA,cAACC,2BAAAA;IACCP,QAAQQ;IACRH,QAAQd;IACRC,QAAQY;IACRX;IACAgB,QAAQ;MACN,CAAC,UAAA,GAAiD,CAACC,UACjD,8BAAAJ,QAAA,cAACK,kCAAAA;QACE,GAAGD;QACJE,SAASf,UAAUgB,IAAI,CAACC,QAAQ;UAC9BC,OAAOD,GAAGE;UACVC,OAAOC,gBAAgBhB,SAASY,EAAAA;QAClC,EAAA;;MAGJ,CAAC,WAAA,GAAuB,CAACJ,UACvB,8BAAAJ,QAAA,cAACK,kCAAAA;QACE,GAAGD;QACJE,SAASO,OAAOd,OAAOe,6BAAAA,EAAaP,IAAI,CAACQ,UAAU;UACjDN,OAAOM;UACPJ,OAAOvB,EAAE,gBAAgB2B,IAAAA,EAAM;QACjC,EAAA;;MAGJ,CAAC,MAAA,GAAkB,CAACX,UAAAA;AAClB,cAAMY,OAAOZ,MAAMa,SAAS,MAAA;AAE5B,cAAM,CAACC,kBAAkBC,mBAAAA,QAAuBC,wBAAS,EAAA;AAEzDpB,sBAAAA,QAAMqB,UAAU,MAAMjB,MAAMkB,cAAc,QAAQ,UAAU;UAAE,GAAGN;QAAK,CAAA,GAAI,CAAA,CAAE;AAE5E,eACE,8BAAAhB,QAAA,cAAA,cAAAA,QAAA,UAAA,MACE,8BAAAA,QAAA,cAACuB,OAAAA,MAAKnB,MAAMO,KAAK,GAChB;aAAIE,OAAOW,KAAKR,IAAAA;UAAOT,IAAI,CAACkB,QAAAA;AAC3B,gBAAMC,eAAoB,QAAQD,GAAAA;AAClC,iBACE,8BAAAzB,QAAA,cAACuB,OAAAA;YAAIE,KAAKC;YAAcC,MAAK;YAAOC,WAAU;aAC5C,8BAAA5B,QAAA,cAACuB,OAAAA;YAAII,MAAK;YAAOC,WAAU;aACzB,8BAAA5B,QAAA,cAAC6B,gCAAAA;YAAW,GAAGzB;YAAO0B,UAAUJ;YAAcK,MAAM;YAAUpB,OAAOc;eAEvE,8BAAAzB,QAAA,cAACgC,6BAAAA;YACCC,MAAK;YACLC,UAAAA;YACAC,YAAY;YACZxB,OAAOvB,EAAE,qBAAA;YACTgD,SAAS,MAAA;AACP,oBAAMC,YAAiB;gBAAE,GAAGjC,MAAMa,SAAS,MAAA;cAAQ;AACnD,qBAAOoB,UAAUZ,GAAAA;AACjBrB,oBAAMkB,cAAc,QAAQ,UAAUe,SAAAA;YACxC;;QAIR,CAAA,GACA,8BAAArC,QAAA,cAACuB,OAAAA;UAAII,MAAK;UAAOC,WAAU;WACzB,8BAAA5B,QAAA,cAACuB,OAAAA;UAAII,MAAK;UAAOC,WAAU;WACzB,8BAAA5B,QAAA,cAACsC,uBAAMC,MAAI,MACT,8BAAAvC,QAAA,cAACsC,uBAAMT,WAAS;UACdW,aAAapD,EAAE,oCAAA;UACfqB,OAAOS;UACPuB,UAAU,CAACC,UAAUvB,oBAAoBuB,MAAMC,OAAOlC,KAAK;cAIjE,8BAAAT,QAAA,cAACgC,6BAAAA;UACCC,MAAK;UACLC,UAAAA;UACAvB,OAAOvB,EAAE,kBAAA;UACTgD,SAAS,MAAA;AACP,gBAAIlB,iBAAiB0B,QAAQ;AAC3B,oBAAM5B,QAAOZ,MAAMa,SAAS,MAAA,KAAW,CAAC;AACxC,oBAAM4B,kBAAkB;gBAAE,GAAG7B;gBAAM,CAACE,gBAAAA,GAAmB;cAAG;AAC1DC,kCAAoB,EAAA;AACpBf,oBAAMkB,cAAc,QAAQ,UAAUuB,eAAAA;YACxC;UACF;;MAKV;IACF;;AAGN;AAEA,IAAMjC,kBAAkB,CAAChB,SAAuBY,OAAAA;AAC9C,SAAOZ,QAAQkD,KAAK,CAACC,MAAMvC,GAAGwC,QAAQL,QAAQM,OAAOF,EAAEE,EAAE,GAAGvC,QAAQF,GAAGE;AACzE;ADvGA,IAAMwC,OAAO;AAQN,IAAMC,kBAAkB,CAAC,EAAEnE,OAAOoE,OAAM,MAAwB;AACrE,QAAM,EAAEhE,EAAC,QAAKC,gBAAAA,gBAAeC,uCAAAA;AAC7B,QAAM+D,aAASC,+BAAAA;AACf,QAAMC,eAAW/D,YAAAA,UAASR,OAAOS,YAAAA,OAAOC,OAAO8D,gCAAAA,CAAAA;AAC/C,QAAMjE,gBAAYC,YAAAA,UAASR,OAAOS,YAAAA,OAAOC,OAAOC,iBAAAA,YAAAA,CAAAA;AAChD,QAAMC,cAAUJ,YAAAA,UAASR,OAAOS,YAAAA,OAAOC,OAAOG,iBAAAA,UAAAA,CAAAA;AAE9C,QAAM,CAACZ,SAASwE,UAAAA,QAAcrC,aAAAA,UAAAA;AAC9B,QAAM,CAACsC,UAAUC,WAAAA,QAAevC,aAAAA,UAAAA;AAEhC,QAAMwC,eAAe,CAAC3E,aAAAA;AACpB,UAAM,EAAEgE,IAAIY,GAAG,GAAG9D,OAAAA,IAAWd;AAC7BwE,eAAW1D,MAAAA;AACX4D,gBAAY1E,QAAAA;EACd;AAEA,QAAM6E,YAAY,MAAA;AAChBL,mBAAWM,oBAAO7D,iBAAAA,uBAAuB;MAAEc,MAAM,CAAC;IAAE,CAAA,CAAA;AACpD2C,gBAAYK,MAAAA;EACd;AAEA,QAAMC,eAAe,CAAChF,aAAAA;AACpBD,UAAMkF,GAAGC,OAAOlF,QAAAA;AAChBwE,eAAWO,MAAAA;AACXL,gBAAYK,MAAAA;EACd;AAEA,QAAMlE,aAA2C,CAACb,aAAAA;AAChD,QAAIyE,UAAU;AACZ7C,aAAOuD,OAAOV,UAAUzE,QAAAA;IAC1B,OAAO;AACLD,YAAMkF,GAAGG,QAAIN,oBAAOP,kCAAiBvE,QAAAA,CAAAA;IACvC;AAEAwE,eAAWO,MAAAA;AACXL,gBAAYK,MAAAA;EACd;AAEA,QAAMM,eAA+C,MAAA;AACnDb,eAAWO,MAAAA;EACb;AAEA,SACEhE,6BAAAA,QAAA,cAACuB,OAAAA;IAAIK,WAAU;KACb5B,6BAAAA,QAAA,cAACuE,0BAAKhC,MAAI;IAAkBiC,OAAOjB;IAAUkB,QAAQC,qBAAEC,GAAGnB,gCAAAA;IAAkBoB,OAAO,CAACC,UAAUA,MAAM5B;KACjG,CAAC,EAAEuB,OAAOjB,UAAQ,MACjBvD,6BAAAA,QAAA,cAACuB,OAAAA;IAAII,MAAK;IAAOC,WAAU;KACxB2B,WAAUhD,IAAI,CAACtB,aAAAA;AACd,UAAM6F,aAAaC,cAAc1B,QAAQpE,QAAAA;AACzC,WACEe,6BAAAA,QAAA,cAACuE,0BAAKS,MAAI;MACRvD,KAAKxC,SAAQgE;MACbgC,MAAMhG;MACNkD,gBAAY+C,0BAAGhC,MAAMiC,kCAAY,gBAAgB,MAAA;OAEjDnF,6BAAAA,QAAA,cAACsC,gBAAAA,MAAMC,MAAI,MACTvC,6BAAAA,QAAA,cAACsC,gBAAAA,MAAM8C,QAAM;MACXC,SAASpG,SAAQqG;MACjBC,iBAAiB,CAACF,YAAapG,SAAQqG,UAAUD;SAIrDrF,6BAAAA,QAAA,cAACuB,OAAAA;MAAIK,WAAW;OACd5B,6BAAAA,QAAA,cAACuE,0BAAKiB,WAAS;MACbrD,YAAW;MACXC,SAAS,MAAMwB,aAAa3E,QAAAA;OAE3B2B,iBAAgBhB,SAASL,WAAWN,QAAAA,KAAY,QAAA,GAIlD6F,cACC9E,6BAAAA,QAAA,cAACyF,wBAAAA;MAAOrD,SAAS,MAAMsD,UAAUC,UAAUC,UAAUd,WAAWe,gBAAe,CAAA;OAC5EzG,EAAE0F,WAAWgB,cAAc,CAAA,CAAA,GAKlC9F,6BAAAA,QAAA,cAACuE,0BAAKwB,kBAAgB;MAAC3D,SAAS,MAAM6B,aAAahF,QAAAA;;EAGzD,CAAA,CAAA,CAAA,GAKLA,WAAWe,6BAAAA,QAAA,cAACjB,eAAAA;IAAcC;IAAcC;IAAkBC,QAAQY;IAAYX,UAAUmF;MAExF,CAACrF,WACAe,6BAAAA,QAAA,cAACuB,OAAAA;IAAIK,WAAU;KACb5B,6BAAAA,QAAA,cAACgC,gBAAAA,YAAAA;IAAWC,MAAK;IAAoBtB,OAAOvB,EAAE,aAAA;IAAgBgD,SAAS0B;;AAKjF;AAEA,IAAMiB,gBAAgB,CAAC1B,QAAgBpE,YAAAA;AACrC,MAAIA,SAAS+G,MAAMjE,SAASjB,iBAAAA,YAAYmF,OAAO;AAC7C,WAAO;MAAEH,gBAAgB;MAAsBD,iBAAiB,MAAM,OAAGK,sBAASjH,OAAAA,EAAUgE,EAAE;IAAgB;EAChH;AAEA,MAAIhE,SAAS+G,MAAMjE,SAASjB,iBAAAA,YAAYqF,SAAS;AAC/C,WAAO;MAAEL,gBAAgB;MAAoBD,iBAAiB,MAAMO,cAAc/C,QAAQpE,OAAAA;IAAS;EACrG;AAEA,SAAO+E;AACT;AAEA,IAAMoC,gBAAgB,CAAC/C,QAAgBpE,YAAAA;AACrC,QAAMoH,cAAUH,sBAASjH,OAAAA,EAAUgE;AACnC,QAAMqD,UAAU,IAAIC,IAAIlD,OAAOmD,OAAOzG,OAAO0G,QAASC,SAAUC,KAAMC,GAAG;AACzE,QAAMC,WAAWP,QAAQQ,SAASC,WAAW,OAAA,KAAYT,QAAQQ,SAASC,WAAW,KAAA;AACrFT,UAAQQ,WAAWD,WAAW,UAAU;AACxC,SAAO,IAAIN,IAAI,YAAYF,OAAAA,IAAWpH,QAAQgE,EAAE,IAAIqD,OAAAA,EAASU,SAAQ;AACvE;AAEA,IAAMpG,mBAAkB,CAAChB,SAAuBL,WAA2BN,YAAAA;AACzE,QAAMgI,UAAUhI,QAAQiI,YAAY,GAAGjI,QAAQiI,UAAUC,MAAM,GAAG,EAAA,CAAA;AAClE,QAAMC,iBAAiB7H,UAAUuD,KAAK,CAACtC,OAAOA,GAAGE,SAASzB,QAAQiI,QAAQ;AAC1E,MAAI,CAACE,gBAAgB;AACnB,WAAOH;EACT;AACA,SAAOrH,QAAQkD,KAAK,CAACC,MAAMqE,eAAepE,QAAQL,QAAQM,OAAOF,EAAEE,EAAE,GAAGvC,QAAQuG;AAClF;AEtJA,IAAA,0BAAe9D;",
6
- "names": ["import_react", "import_functions", "import_echo", "import_react_ui", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "schema", "FunctionType", "scripts", "ScriptType", "handleSave", "values", "React", "Form", "FunctionTriggerSchema", "Custom", "props", "SelectInput", "options", "map", "fn", "value", "name", "label", "getFunctionName", "Object", "TriggerKind", "kind", "meta", "getValue", "newMetaFieldName", "setNewMetaFieldName", "useState", "useEffect", "onValueChange", "div", "keys", "key", "compositeKey", "role", "className", "TextInput", "property", "type", "IconButton", "icon", "iconOnly", "classNames", "onClick", "newValues", "Input", "Root", "placeholder", "onChange", "event", "target", "length", "metaWithNewProp", "find", "s", "source", "id", "grid", "AutomationPanel", "object", "client", "useClient", "triggers", "FunctionTrigger", "setTrigger", "selected", "setSelected", "handleSelect", "_", "handleAdd", "create", "undefined", "handleDelete", "db", "remove", "assign", "add", "handleCancel", "List", "items", "isItem", "S", "is", "getId", "field", "copyAction", "getCopyAction", "Item", "item", "mx", "ghostHover", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "Button", "navigator", "clipboard", "writeText", "contentProvider", "translationKey", "ItemDeleteButton", "spec", "Email", "getSpace", "Webhook", "getWebhookUrl", "spaceId", "edgeUrl", "URL", "config", "runtime", "services", "edge", "url", "isSecure", "protocol", "startsWith", "toString", "shortId", "function", "slice", "functionObject"]
7
- }