@dxos/plugin-automation 0.8.1-main.ae460ac → 0.8.1-staging.31c3ee1

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 (100) hide show
  1. package/dist/lib/browser/{AutomationPanel-ITYXSN5Z.mjs → AutomationPanel-YAHFXQX6.mjs} +28 -21
  2. package/dist/lib/browser/AutomationPanel-YAHFXQX6.mjs.map +7 -0
  3. package/dist/lib/browser/app-graph-builder-K3BIQFWW.mjs +40 -0
  4. package/dist/lib/browser/app-graph-builder-K3BIQFWW.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-FALBBJNO.mjs +138 -0
  6. package/dist/lib/browser/chunk-FALBBJNO.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-MT3FZH4V.mjs +8 -0
  8. package/dist/lib/browser/{chunk-OFDNNRLE.mjs → chunk-WKKQV4PC.mjs} +2 -2
  9. package/dist/lib/browser/chunk-WKKQV4PC.mjs.map +7 -0
  10. package/dist/lib/browser/index.mjs +33 -18
  11. package/dist/lib/browser/index.mjs.map +3 -3
  12. package/dist/lib/browser/meta.json +1 -1
  13. package/dist/lib/browser/react-surface-4QQSJR4A.mjs +42 -0
  14. package/dist/lib/browser/react-surface-4QQSJR4A.mjs.map +7 -0
  15. package/dist/lib/node/{AutomationPanel-X33HHDMQ.cjs → AutomationPanel-ZKAMIU6O.cjs} +36 -29
  16. package/dist/lib/node/AutomationPanel-ZKAMIU6O.cjs.map +7 -0
  17. package/dist/lib/node/app-graph-builder-HO4FPGZ5.cjs +56 -0
  18. package/dist/lib/node/app-graph-builder-HO4FPGZ5.cjs.map +7 -0
  19. package/dist/lib/node/{chunk-ORMEYEBE.cjs → chunk-7GXNXMSM.cjs} +4 -4
  20. package/dist/lib/node/chunk-7GXNXMSM.cjs.map +7 -0
  21. package/dist/lib/node/{chunk-CB5OB6JH.cjs → chunk-AGJ6XTDN.cjs} +5 -5
  22. package/dist/lib/node/chunk-FTEDH5Q6.cjs +167 -0
  23. package/dist/lib/node/chunk-FTEDH5Q6.cjs.map +7 -0
  24. package/dist/lib/node/index.cjs +40 -25
  25. package/dist/lib/node/index.cjs.map +3 -3
  26. package/dist/lib/node/meta.json +1 -1
  27. package/dist/lib/node/{react-surface-2WRVAPGR.cjs → react-surface-52M54VWV.cjs} +28 -13
  28. package/dist/lib/node/react-surface-52M54VWV.cjs.map +7 -0
  29. package/dist/lib/node-esm/{AutomationPanel-HY3GB4BT.mjs → AutomationPanel-XF7YPSKM.mjs} +28 -21
  30. package/dist/lib/node-esm/AutomationPanel-XF7YPSKM.mjs.map +7 -0
  31. package/dist/lib/node-esm/app-graph-builder-XCJR33VS.mjs +41 -0
  32. package/dist/lib/node-esm/app-graph-builder-XCJR33VS.mjs.map +7 -0
  33. package/dist/lib/node-esm/{chunk-6MUUH67V.mjs → chunk-DZ44LGYT.mjs} +2 -2
  34. package/dist/lib/node-esm/chunk-DZ44LGYT.mjs.map +7 -0
  35. package/dist/lib/node-esm/chunk-M4QXMIIB.mjs +139 -0
  36. package/dist/lib/node-esm/chunk-M4QXMIIB.mjs.map +7 -0
  37. package/dist/lib/node-esm/chunk-OA75PSGH.mjs +10 -0
  38. package/dist/lib/node-esm/index.mjs +33 -18
  39. package/dist/lib/node-esm/index.mjs.map +3 -3
  40. package/dist/lib/node-esm/meta.json +1 -1
  41. package/dist/lib/node-esm/react-surface-MGKM3OO3.mjs +43 -0
  42. package/dist/lib/node-esm/react-surface-MGKM3OO3.mjs.map +7 -0
  43. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  44. package/dist/types/src/capabilities/app-graph-builder.d.ts +181 -0
  45. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
  46. package/dist/types/src/capabilities/index.d.ts +177 -1
  47. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  48. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  49. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +2 -1
  50. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  51. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +3 -2
  52. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  53. package/dist/types/src/components/index.d.ts +1 -1
  54. package/dist/types/src/components/index.d.ts.map +1 -1
  55. package/dist/types/src/meta.d.ts +2 -7
  56. package/dist/types/src/meta.d.ts.map +1 -1
  57. package/dist/types/src/translations.d.ts +5 -3
  58. package/dist/types/src/translations.d.ts.map +1 -1
  59. package/package.json +24 -20
  60. package/src/AutomationPlugin.tsx +15 -6
  61. package/src/capabilities/app-graph-builder.ts +31 -0
  62. package/src/capabilities/index.ts +1 -1
  63. package/src/capabilities/react-surface.tsx +22 -7
  64. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +1 -1
  65. package/src/components/AutomationPanel/AutomationPanel.tsx +60 -56
  66. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +1 -1
  67. package/src/components/TriggerEditor/TriggerEditor.tsx +90 -81
  68. package/src/meta.ts +2 -2
  69. package/src/translations.ts +6 -4
  70. package/dist/lib/browser/AutomationPanel-ITYXSN5Z.mjs.map +0 -7
  71. package/dist/lib/browser/chunk-OFDNNRLE.mjs.map +0 -7
  72. package/dist/lib/browser/chunk-U7QLNY2S.mjs +0 -8
  73. package/dist/lib/browser/chunk-WY2C7JY4.mjs +0 -119
  74. package/dist/lib/browser/chunk-WY2C7JY4.mjs.map +0 -7
  75. package/dist/lib/browser/complementary-panel-4CPOJL4Y.mjs +0 -56
  76. package/dist/lib/browser/complementary-panel-4CPOJL4Y.mjs.map +0 -7
  77. package/dist/lib/browser/react-surface-SAPMN4PF.mjs +0 -27
  78. package/dist/lib/browser/react-surface-SAPMN4PF.mjs.map +0 -7
  79. package/dist/lib/node/AutomationPanel-X33HHDMQ.cjs.map +0 -7
  80. package/dist/lib/node/chunk-7Q5SNGCL.cjs +0 -148
  81. package/dist/lib/node/chunk-7Q5SNGCL.cjs.map +0 -7
  82. package/dist/lib/node/chunk-ORMEYEBE.cjs.map +0 -7
  83. package/dist/lib/node/complementary-panel-ZYJJ42ZU.cjs +0 -72
  84. package/dist/lib/node/complementary-panel-ZYJJ42ZU.cjs.map +0 -7
  85. package/dist/lib/node/react-surface-2WRVAPGR.cjs.map +0 -7
  86. package/dist/lib/node-esm/AutomationPanel-HY3GB4BT.mjs.map +0 -7
  87. package/dist/lib/node-esm/chunk-6MUUH67V.mjs.map +0 -7
  88. package/dist/lib/node-esm/chunk-R3P2WPBQ.mjs +0 -10
  89. package/dist/lib/node-esm/chunk-UDD2VA6G.mjs +0 -120
  90. package/dist/lib/node-esm/chunk-UDD2VA6G.mjs.map +0 -7
  91. package/dist/lib/node-esm/complementary-panel-S42RIIAY.mjs +0 -57
  92. package/dist/lib/node-esm/complementary-panel-S42RIIAY.mjs.map +0 -7
  93. package/dist/lib/node-esm/react-surface-QWLPOYXO.mjs +0 -28
  94. package/dist/lib/node-esm/react-surface-QWLPOYXO.mjs.map +0 -7
  95. package/dist/types/src/capabilities/complementary-panel.d.ts +0 -4
  96. package/dist/types/src/capabilities/complementary-panel.d.ts.map +0 -1
  97. package/src/capabilities/complementary-panel.ts +0 -56
  98. /package/dist/lib/browser/{chunk-U7QLNY2S.mjs.map → chunk-MT3FZH4V.mjs.map} +0 -0
  99. /package/dist/lib/node/{chunk-CB5OB6JH.cjs.map → chunk-AGJ6XTDN.cjs.map} +0 -0
  100. /package/dist/lib/node-esm/{chunk-R3P2WPBQ.mjs.map → chunk-OA75PSGH.mjs.map} +0 -0
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useEffect, useState } from 'react';\n\nimport { ComputeGraph } from '@dxos/conductor';\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 workflows = useQuery(space, Filter.schema(ComputeGraph));\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\n {...props}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n ),\n ['spec.type' as const]: (props) => (\n <SelectInput\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()!;\n useEffect(() => props.onValueChange('object', { ...meta }), []);\n const [newMetaFieldName, setNewMetaFieldName] = useState('');\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\n {...props}\n getValue={() => (props.getValue() as any)[key]}\n type={'string'}\n label={key}\n />\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() };\n delete newValues[key];\n props.onValueChange('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() ?? {};\n const metaWithNewProp = { ...meta, [newMetaFieldName]: '' };\n setNewMetaFieldName('');\n props.onValueChange('object', metaWithNewProp);\n }\n }}\n />\n </div>\n </>\n );\n },\n }}\n />\n );\n};\n\nconst getWorkflowOptions = (graphs: ComputeGraph[]) => {\n return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));\n};\n\nconst getFunctionOptions = (scripts: ScriptType[], functions: FunctionType[]) => {\n const getLabel = (fn: FunctionType) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:worker:${fn.name}` }));\n};\n"],
5
- "mappings": "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",
6
- "names": ["React", "useEffect", "useState", "ComputeGraph", "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", "workflows", "ComputeGraph", "scripts", "ScriptType", "handleSave", "values", "Form", "FunctionTriggerSchema", "Custom", "props", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "Object", "TriggerKind", "map", "kind", "value", "label", "meta", "getValue", "useEffect", "onValueChange", "newMetaFieldName", "setNewMetaFieldName", "useState", "div", "keys", "key", "compositeKey", "role", "className", "TextInput", "type", "IconButton", "icon", "iconOnly", "classNames", "onClick", "newValues", "Input", "Root", "placeholder", "onChange", "event", "target", "length", "metaWithNewProp", "graphs", "graph", "id", "getLabel", "fn", "find", "s", "source", "name"]
7
- }
@@ -1,56 +0,0 @@
1
- import {
2
- AUTOMATION_PLUGIN
3
- } from "./chunk-OFDNNRLE.mjs";
4
-
5
- // packages/plugins/experimental/plugin-automation/src/capabilities/complementary-panel.ts
6
- import { effect, untracked } from "@preact/signals-core";
7
- import { Capabilities, contributes } from "@dxos/app-framework";
8
- import { FunctionType } from "@dxos/functions/types";
9
- import { create } from "@dxos/live-object";
10
- import { ClientCapabilities } from "@dxos/plugin-client";
11
- import { DeckCapabilities } from "@dxos/plugin-deck";
12
- import { Filter, parseId } from "@dxos/react-client/echo";
13
- var complementary_panel_default = (context) => {
14
- const state = create({
15
- functionsAvailable: false
16
- });
17
- const setState = (next) => {
18
- if (next !== state.functionsAvailable) {
19
- state.functionsAvailable = next;
20
- }
21
- };
22
- const unsubscribe = effect(() => {
23
- const client = context.requestCapabilities(ClientCapabilities.Client)[0];
24
- const workspace = context.requestCapabilities(Capabilities.Layout)[0]?.workspace;
25
- return untracked(() => {
26
- const { spaceId } = parseId(workspace);
27
- if (!spaceId || !client) {
28
- setState(false);
29
- return;
30
- }
31
- const space = client.spaces.get(spaceId);
32
- if (!space) {
33
- setState(false);
34
- return;
35
- }
36
- return space.db.query(Filter.schema(FunctionType)).subscribe((query) => setState(query.objects.length > 0), {
37
- fire: true
38
- });
39
- });
40
- });
41
- return contributes(DeckCapabilities.ComplementaryPanel, {
42
- id: "automation",
43
- label: [
44
- "automation panel label",
45
- {
46
- ns: AUTOMATION_PLUGIN
47
- }
48
- ],
49
- icon: "ph--robot--regular",
50
- filter: () => state.functionsAvailable
51
- }, () => unsubscribe());
52
- };
53
- export {
54
- complementary_panel_default as default
55
- };
56
- //# sourceMappingURL=complementary-panel-4CPOJL4Y.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/complementary-panel.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { effect, untracked } from '@preact/signals-core';\n\nimport { Capabilities, contributes, type PluginsContext } from '@dxos/app-framework';\nimport { FunctionType } from '@dxos/functions/types';\nimport { create } from '@dxos/live-object';\nimport { ClientCapabilities } from '@dxos/plugin-client';\nimport { DeckCapabilities } from '@dxos/plugin-deck';\nimport { Filter, parseId } from '@dxos/react-client/echo';\n\nimport { AUTOMATION_PLUGIN } from '../meta';\n\nexport default (context: PluginsContext) => {\n const state = create({ functionsAvailable: false });\n const setState = (next: boolean) => {\n if (next !== state.functionsAvailable) {\n state.functionsAvailable = next;\n }\n };\n\n const unsubscribe = effect(() => {\n const client = context.requestCapabilities(ClientCapabilities.Client)[0];\n const workspace = context.requestCapabilities(Capabilities.Layout)[0]?.workspace;\n return untracked(() => {\n const { spaceId } = parseId(workspace);\n if (!spaceId || !client) {\n setState(false);\n return;\n }\n\n const space = client.spaces.get(spaceId);\n if (!space) {\n setState(false);\n return;\n }\n\n return space.db\n .query(Filter.schema(FunctionType))\n .subscribe((query) => setState(query.objects.length > 0), { fire: true });\n });\n });\n\n return contributes(\n DeckCapabilities.ComplementaryPanel,\n {\n id: 'automation',\n label: ['automation panel label', { ns: AUTOMATION_PLUGIN }],\n icon: 'ph--robot--regular',\n filter: () => state.functionsAvailable,\n },\n () => unsubscribe(),\n );\n};\n"],
5
- "mappings": ";;;;;AAIA,SAASA,QAAQC,iBAAiB;AAElC,SAASC,cAAcC,mBAAwC;AAC/D,SAASC,oBAAoB;AAC7B,SAASC,cAAc;AACvB,SAASC,0BAA0B;AACnC,SAASC,wBAAwB;AACjC,SAASC,QAAQC,eAAe;AAIhC,IAAA,8BAAe,CAACC,YAAAA;AACd,QAAMC,QAAQC,OAAO;IAAEC,oBAAoB;EAAM,CAAA;AACjD,QAAMC,WAAW,CAACC,SAAAA;AAChB,QAAIA,SAASJ,MAAME,oBAAoB;AACrCF,YAAME,qBAAqBE;IAC7B;EACF;AAEA,QAAMC,cAAcC,OAAO,MAAA;AACzB,UAAMC,SAASR,QAAQS,oBAAoBC,mBAAmBC,MAAM,EAAE,CAAA;AACtE,UAAMC,YAAYZ,QAAQS,oBAAoBI,aAAaC,MAAM,EAAE,CAAA,GAAIF;AACvE,WAAOG,UAAU,MAAA;AACf,YAAM,EAAEC,QAAO,IAAKC,QAAQL,SAAAA;AAC5B,UAAI,CAACI,WAAW,CAACR,QAAQ;AACvBJ,iBAAS,KAAA;AACT;MACF;AAEA,YAAMc,QAAQV,OAAOW,OAAOC,IAAIJ,OAAAA;AAChC,UAAI,CAACE,OAAO;AACVd,iBAAS,KAAA;AACT;MACF;AAEA,aAAOc,MAAMG,GACVC,MAAMC,OAAOC,OAAOC,YAAAA,CAAAA,EACpBC,UAAU,CAACJ,UAAUlB,SAASkB,MAAMK,QAAQC,SAAS,CAAA,GAAI;QAAEC,MAAM;MAAK,CAAA;IAC3E,CAAA;EACF,CAAA;AAEA,SAAOC,YACLC,iBAAiBC,oBACjB;IACEC,IAAI;IACJC,OAAO;MAAC;MAA0B;QAAEC,IAAIC;MAAkB;;IAC1DC,MAAM;IACNC,QAAQ,MAAMrC,MAAME;EACtB,GACA,MAAMG,YAAAA,CAAAA;AAEV;",
6
- "names": ["effect", "untracked", "Capabilities", "contributes", "FunctionType", "create", "ClientCapabilities", "DeckCapabilities", "Filter", "parseId", "context", "state", "create", "functionsAvailable", "setState", "next", "unsubscribe", "effect", "client", "requestCapabilities", "ClientCapabilities", "Client", "workspace", "Capabilities", "Layout", "untracked", "spaceId", "parseId", "space", "spaces", "get", "db", "query", "Filter", "schema", "FunctionType", "subscribe", "objects", "length", "fire", "contributes", "DeckCapabilities", "ComplementaryPanel", "id", "label", "ns", "AUTOMATION_PLUGIN", "icon", "filter"]
7
- }
@@ -1,27 +0,0 @@
1
- import {
2
- AutomationPanel
3
- } from "./chunk-U7QLNY2S.mjs";
4
- import "./chunk-WY2C7JY4.mjs";
5
- import {
6
- AUTOMATION_PLUGIN
7
- } from "./chunk-OFDNNRLE.mjs";
8
-
9
- // packages/plugins/experimental/plugin-automation/src/capabilities/react-surface.tsx
10
- import React from "react";
11
- import { Capabilities, contributes, createSurface } from "@dxos/app-framework";
12
- import { getSpace, isEchoObject } from "@dxos/react-client/echo";
13
- var react_surface_default = () => contributes(Capabilities.ReactSurface, [
14
- createSurface({
15
- id: `${AUTOMATION_PLUGIN}/automation`,
16
- role: "complementary--automation",
17
- filter: (data) => isEchoObject(data.subject) && !!getSpace(data.subject),
18
- component: ({ data }) => /* @__PURE__ */ React.createElement(AutomationPanel, {
19
- space: getSpace(data.subject),
20
- object: data.subject
21
- })
22
- })
23
- ]);
24
- export {
25
- react_surface_default as default
26
- };
27
- //# sourceMappingURL=react-surface-SAPMN4PF.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/react-surface.tsx"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, contributes, createSurface } from '@dxos/app-framework';\nimport { getSpace, isEchoObject, type ReactiveEchoObject } from '@dxos/react-client/echo';\n\nimport { AutomationPanel } from '../components';\nimport { AUTOMATION_PLUGIN } from '../meta';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: `${AUTOMATION_PLUGIN}/automation`,\n role: 'complementary--automation',\n filter: (data): data is { subject: ReactiveEchoObject<any> } =>\n isEchoObject(data.subject) && !!getSpace(data.subject),\n component: ({ data }) => <AutomationPanel space={getSpace(data.subject)!} object={data.subject} />,\n }),\n ]);\n"],
5
- "mappings": ";;;;;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,cAAcC,aAAaC,qBAAqB;AACzD,SAASC,UAAUC,oBAA6C;AAKhE,IAAA,wBAAe,MACbC,YAAYC,aAAaC,cAAc;EACrCC,cAAc;IACZC,IAAI,GAAGC,iBAAAA;IACPC,MAAM;IACNC,QAAQ,CAACC,SACPC,aAAaD,KAAKE,OAAO,KAAK,CAAC,CAACC,SAASH,KAAKE,OAAO;IACvDE,WAAW,CAAC,EAAEJ,KAAI,MAAO,sBAAA,cAACK,iBAAAA;MAAgBC,OAAOH,SAASH,KAAKE,OAAO;MAAIK,QAAQP,KAAKE;;EACzF,CAAA;CACD;",
6
- "names": ["React", "Capabilities", "contributes", "createSurface", "getSpace", "isEchoObject", "contributes", "Capabilities", "ReactSurface", "createSurface", "id", "AUTOMATION_PLUGIN", "role", "filter", "data", "isEchoObject", "subject", "getSpace", "component", "AutomationPanel", "space", "object"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/AutomationPanel/index.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport 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 { Clipboard, IconButton, Input, useTranslation } 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 <Clipboard.Provider>\n <div className='flex flex-col w-full'>\n {!trigger && (\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 <Clipboard.IconButton\n label={t(copyAction.translationKey)}\n value={copyAction.contentProvider()}\n />\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n )}\n\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 label')} onClick={handleAdd} />\n </div>\n )}\n </div>\n </Clipboard.Provider>\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 // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function?.slice(0, 16)}…`;\n const functionObject = functions.find((fn) => `dxn:worker:${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 { AutomationPanel } from './AutomationPanel';\n\nexport default AutomationPanel;\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,mBAAgC;AAEhC,yBAAkB;AAClB,uBAOO;AACP,0BAAuC;AACvC,kBAAoF;AACpF,sBAA6D;AAC7D,2BAAqB;AACrB,4BAA+B;AAK/B,IAAMA,OAAO;AAQN,IAAMC,kBAAkB,CAAC,EAAEC,OAAOC,OAAM,MAAwB;AACrE,QAAM,EAAEC,EAAC,QAAKC,gCAAeC,uCAAAA;AAC7B,QAAMC,aAASC,+BAAAA;AACf,QAAMC,eAAWC,sBAASR,OAAOS,mBAAOC,OAAOC,gCAAAA,CAAAA;AAC/C,QAAMC,gBAAYJ,sBAASR,OAAOS,mBAAOC,OAAOG,6BAAAA,CAAAA;AAChD,QAAMC,cAAUN,sBAASR,OAAOS,mBAAOC,OAAOK,2BAAAA,CAAAA;AAE9C,QAAM,CAACC,SAASC,UAAAA,QAAcC,uBAAAA;AAC9B,QAAM,CAACC,UAAUC,WAAAA,QAAeF,uBAAAA;AAEhC,QAAMG,eAAe,CAACL,aAAAA;AACpB,UAAM,EAAEM,IAAIC,GAAG,GAAGC,OAAAA,IAAWR;AAC7BC,eAAWO,MAAAA;AACXJ,gBAAYJ,QAAAA;EACd;AAEA,QAAMS,YAAY,MAAA;AAChBR,mBAAWS,oBAAOC,wCAAuB;MAAEC,MAAM,CAAC;IAAE,CAAA,CAAA;AACpDR,gBAAYS,MAAAA;EACd;AAEA,QAAMC,eAAe,CAACd,aAAAA;AACpBhB,UAAM+B,GAAGC,OAAOhB,QAAAA;AAChBC,eAAWY,MAAAA;AACXT,gBAAYS,MAAAA;EACd;AAEA,QAAMI,aAA2C,CAACjB,aAAAA;AAChD,QAAIG,UAAU;AACZe,aAAOC,OAAOhB,UAAUH,QAAAA;IAC1B,OAAO;AACLhB,YAAM+B,GAAGK,QAAIV,oBAAOf,kCAAiBK,QAAAA,CAAAA;IACvC;AAEAC,eAAWY,MAAAA;AACXT,gBAAYS,MAAAA;EACd;AAEA,QAAMQ,eAA+C,MAAA;AACnDpB,eAAWY,MAAAA;EACb;AAEA,SACE,6BAAAS,QAAA,cAACC,0BAAUC,UAAQ,MACjB,6BAAAF,QAAA,cAACG,OAAAA;IAAIC,WAAU;KACZ,CAAC1B,WACA,6BAAAsB,QAAA,cAACK,0BAAKC,MAAI;IAAkBC,OAAOtC;IAAUuC,QAAQC,qBAAEC,GAAGrC,gCAAAA;IAAkBsC,OAAO,CAACC,UAAUA,MAAM5B;KACjG,CAAC,EAAEuB,OAAOtC,UAAQ,MACjB,6BAAA+B,QAAA,cAACG,OAAAA;IAAIU,MAAK;IAAOT,WAAU;KACxBnC,WAAU6C,IAAI,CAACpC,aAAAA;AACd,UAAMqC,aAAaC,cAAcjD,QAAQW,QAAAA;AACzC,WACE,6BAAAsB,QAAA,cAACK,0BAAKY,MAAI;MACRC,KAAKxC,SAAQM;MACbmC,MAAMzC;MACN0C,gBAAYC,0BAAG7D,MAAM8D,kCAAY,gBAAgB,MAAA;OAEjD,6BAAAtB,QAAA,cAACuB,sBAAMjB,MAAI,MACT,6BAAAN,QAAA,cAACuB,sBAAMC,QAAM;MACXC,SAAS/C,SAAQgD;MACjBC,iBAAiB,CAACF,YAAa/C,SAAQgD,UAAUD;SAIrD,6BAAAzB,QAAA,cAACG,OAAAA;MAAIC,WAAW;OACd,6BAAAJ,QAAA,cAACK,0BAAKuB,WAAS;MACbR,YAAW;MACXS,SAAS,MAAM9C,aAAaL,QAAAA;OAE3BoD,gBAAgBtD,SAASF,WAAWI,QAAAA,KAAY,QAAA,GAIlDqC,cACC,6BAAAf,QAAA,cAACC,0BAAU8B,YAAU;MACnBC,OAAOpE,EAAEmD,WAAWkB,cAAc;MAClCC,OAAOnB,WAAWoB,gBAAe;SAKvC,6BAAAnC,QAAA,cAACK,0BAAK+B,kBAAgB;MAACP,SAAS,MAAMrC,aAAad,QAAAA;;EAGzD,CAAA,CAAA,CAAA,GAMPA,WAAW,6BAAAsB,QAAA,cAACqC,qCAAAA;IAAc3E;IAAcgB;IAAkB4D,QAAQ3C;IAAY4C,UAAUxC;MAExF,CAACrB,WACA,6BAAAsB,QAAA,cAACG,OAAAA;IAAIC,WAAU;KACb,6BAAAJ,QAAA,cAAC+B,4BAAAA;IAAWS,MAAK;IAAoBR,OAAOpE,EAAE,mBAAA;IAAsBiE,SAAS1C;;AAMzF;AAEA,IAAM6B,gBAAgB,CAACjD,QAAgBW,YAAAA;AACrC,MAAIA,SAAS+D,MAAMC,SAASC,6BAAYC,OAAO;AAC7C,WAAO;MAAEX,gBAAgB;MAAsBE,iBAAiB,MAAM,OAAGU,sBAASnE,OAAAA,EAAUM,EAAE;IAAgB;EAChH;AAEA,MAAIN,SAAS+D,MAAMC,SAASC,6BAAYG,SAAS;AAC/C,WAAO;MAAEb,gBAAgB;MAAoBE,iBAAiB,MAAMY,cAAchF,QAAQW,OAAAA;IAAS;EACrG;AAEA,SAAOa;AACT;AAEA,IAAMwD,gBAAgB,CAAChF,QAAgBW,YAAAA;AACrC,QAAMsE,cAAUH,sBAASnE,OAAAA,EAAUM;AACnC,QAAMiE,UAAU,IAAIC,IAAInF,OAAOoF,OAAOjE,OAAOkE,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,IAAWtE,QAAQM,EAAE,IAAIiE,OAAAA,EAASU,SAAQ;AACvE;AAEA,IAAM7B,kBAAkB,CAACtD,SAAuBF,WAA2BI,YAAAA;AAGzE,QAAMkF,UAAUlF,QAAQmF,YAAY,GAAGnF,QAAQmF,UAAUC,MAAM,GAAG,EAAA,CAAA;AAClE,QAAMC,iBAAiBzF,UAAU0F,KAAK,CAACC,OAAO,cAAcA,GAAGC,IAAI,OAAOxF,QAAQmF,QAAQ;AAC1F,MAAI,CAACE,gBAAgB;AACnB,WAAOH;EACT;AACA,SAAOpF,QAAQwF,KAAK,CAACG,MAAMJ,eAAeK,QAAQC,QAAQrF,OAAOmF,EAAEnF,EAAE,GAAGkF,QAAQN;AAClF;AC7JA,IAAA,0BAAenG;",
6
- "names": ["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", "Clipboard", "Provider", "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", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "TriggerEditor", "onSave", "onCancel", "icon", "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"]
7
- }
@@ -1,148 +0,0 @@
1
- "use strict";
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
- mod
27
- ));
28
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
- var chunk_7Q5SNGCL_exports = {};
30
- __export(chunk_7Q5SNGCL_exports, {
31
- TriggerEditor: () => TriggerEditor
32
- });
33
- module.exports = __toCommonJS(chunk_7Q5SNGCL_exports);
34
- var import_chunk_ORMEYEBE = require("./chunk-ORMEYEBE.cjs");
35
- var import_react = __toESM(require("react"));
36
- var import_conductor = require("@dxos/conductor");
37
- var import_functions = require("@dxos/functions");
38
- var import_echo = require("@dxos/react-client/echo");
39
- var import_react_ui = require("@dxos/react-ui");
40
- var import_react_ui_form = require("@dxos/react-ui-form");
41
- var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
42
- const { t } = (0, import_react_ui.useTranslation)(import_chunk_ORMEYEBE.AUTOMATION_PLUGIN);
43
- const functions = (0, import_echo.useQuery)(space, import_echo.Filter.schema(import_functions.FunctionType));
44
- const workflows = (0, import_echo.useQuery)(space, import_echo.Filter.schema(import_conductor.ComputeGraph));
45
- const scripts = (0, import_echo.useQuery)(space, import_echo.Filter.schema(import_functions.ScriptType));
46
- const handleSave = (values) => {
47
- onSave?.(values);
48
- };
49
- return /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.Form, {
50
- schema: import_functions.FunctionTriggerSchema,
51
- values: trigger,
52
- onSave: handleSave,
53
- onCancel,
54
- Custom: {
55
- ["function"]: (props) => /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.SelectInput, {
56
- ...props,
57
- options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
58
- }),
59
- ["spec.type"]: (props) => /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.SelectInput, {
60
- ...props,
61
- options: Object.values(import_functions.TriggerKind).map((kind) => ({
62
- value: kind,
63
- label: t(`trigger type ${kind}`)
64
- }))
65
- }),
66
- ["meta"]: (props) => {
67
- const meta = props.getValue();
68
- (0, import_react.useEffect)(() => props.onValueChange("object", {
69
- ...meta
70
- }), []);
71
- const [newMetaFieldName, setNewMetaFieldName] = (0, import_react.useState)("");
72
- return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement("div", null, props.label), [
73
- ...Object.keys(meta)
74
- ].map((key) => {
75
- const compositeKey = `meta.${key}`;
76
- return /* @__PURE__ */ import_react.default.createElement("div", {
77
- key: compositeKey,
78
- role: "none",
79
- className: "flex items-center mt-2 gap-1"
80
- }, /* @__PURE__ */ import_react.default.createElement("div", {
81
- role: "none",
82
- className: "flex-1"
83
- }, /* @__PURE__ */ import_react.default.createElement(import_react_ui_form.TextInput, {
84
- ...props,
85
- getValue: () => props.getValue()[key],
86
- type: "string",
87
- label: key
88
- })), /* @__PURE__ */ import_react.default.createElement(import_react_ui.IconButton, {
89
- icon: "ph--trash--regular",
90
- iconOnly: true,
91
- classNames: "mt-6",
92
- label: t("trigger meta remove"),
93
- onClick: () => {
94
- const newValues = {
95
- ...props.getValue()
96
- };
97
- delete newValues[key];
98
- props.onValueChange("object", newValues);
99
- }
100
- }));
101
- }), /* @__PURE__ */ import_react.default.createElement("div", {
102
- role: "none",
103
- className: "flex items-center mt-2 gap-1 plb-1"
104
- }, /* @__PURE__ */ import_react.default.createElement("div", {
105
- role: "none",
106
- className: "flex-1"
107
- }, /* @__PURE__ */ import_react.default.createElement(import_react_ui.Input.Root, null, /* @__PURE__ */ import_react.default.createElement(import_react_ui.Input.TextInput, {
108
- placeholder: t("trigger meta prop name placeholder"),
109
- value: newMetaFieldName,
110
- onChange: (event) => setNewMetaFieldName(event.target.value)
111
- }))), /* @__PURE__ */ import_react.default.createElement(import_react_ui.IconButton, {
112
- icon: "ph--plus--regular",
113
- iconOnly: true,
114
- label: t("trigger meta add"),
115
- onClick: () => {
116
- if (newMetaFieldName.length) {
117
- const meta2 = props.getValue() ?? {};
118
- const metaWithNewProp = {
119
- ...meta2,
120
- [newMetaFieldName]: ""
121
- };
122
- setNewMetaFieldName("");
123
- props.onValueChange("object", metaWithNewProp);
124
- }
125
- }
126
- })));
127
- }
128
- }
129
- });
130
- };
131
- var getWorkflowOptions = (graphs) => {
132
- return graphs.map((graph) => ({
133
- label: `compute-${graph.id}`,
134
- value: `dxn:echo:@:${graph.id}`
135
- }));
136
- };
137
- var getFunctionOptions = (scripts, functions) => {
138
- const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
139
- return functions.map((fn) => ({
140
- label: getLabel(fn),
141
- value: `dxn:worker:${fn.name}`
142
- }));
143
- };
144
- // Annotate the CommonJS export names for ESM import in node:
145
- 0 && (module.exports = {
146
- TriggerEditor
147
- });
148
- //# sourceMappingURL=chunk-7Q5SNGCL.cjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useEffect, useState } from 'react';\n\nimport { ComputeGraph } from '@dxos/conductor';\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 workflows = useQuery(space, Filter.schema(ComputeGraph));\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\n {...props}\n options={getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))}\n />\n ),\n ['spec.type' as const]: (props) => (\n <SelectInput\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()!;\n useEffect(() => props.onValueChange('object', { ...meta }), []);\n const [newMetaFieldName, setNewMetaFieldName] = useState('');\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\n {...props}\n getValue={() => (props.getValue() as any)[key]}\n type={'string'}\n label={key}\n />\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() };\n delete newValues[key];\n props.onValueChange('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() ?? {};\n const metaWithNewProp = { ...meta, [newMetaFieldName]: '' };\n setNewMetaFieldName('');\n props.onValueChange('object', metaWithNewProp);\n }\n }}\n />\n </div>\n </>\n );\n },\n }}\n />\n );\n};\n\nconst getWorkflowOptions = (graphs: ComputeGraph[]) => {\n return graphs.map((graph) => ({ label: `compute-${graph.id}`, value: `dxn:echo:@:${graph.id}` }));\n};\n\nconst getFunctionOptions = (scripts: ScriptType[], functions: FunctionType[]) => {\n const getLabel = (fn: FunctionType) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;\n return functions.map((fn) => ({ label: getLabel(fn), value: `dxn:worker:${fn.name}` }));\n};\n"],
5
- "mappings": "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",
6
- "names": ["TriggerEditor", "space", "trigger", "onSave", "onCancel", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "schema", "FunctionType", "workflows", "ComputeGraph", "scripts", "ScriptType", "handleSave", "values", "React", "Form", "FunctionTriggerSchema", "Custom", "props", "SelectInput", "options", "getWorkflowOptions", "concat", "getFunctionOptions", "Object", "TriggerKind", "map", "kind", "value", "label", "meta", "getValue", "useEffect", "onValueChange", "newMetaFieldName", "setNewMetaFieldName", "useState", "div", "keys", "key", "compositeKey", "role", "className", "TextInput", "type", "IconButton", "icon", "iconOnly", "classNames", "onClick", "newValues", "Input", "Root", "placeholder", "onChange", "event", "target", "length", "metaWithNewProp", "graphs", "graph", "id", "getLabel", "fn", "find", "s", "source", "name"]
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 const meta = {\n id: AUTOMATION_PLUGIN,\n name: 'Automation',\n description:\n 'The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.',\n icon: 'ph--robot--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-automation',\n} satisfies PluginMeta;\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAMO,IAAMA,oBAAoB;AAE1B,IAAMC,OAAO;EAClBC,IAAIF;EACJG,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;AACV;",
6
- "names": ["AUTOMATION_PLUGIN", "meta", "id", "name", "description", "icon", "source"]
7
- }
@@ -1,72 +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 complementary_panel_ZYJJ42ZU_exports = {};
20
- __export(complementary_panel_ZYJJ42ZU_exports, {
21
- default: () => complementary_panel_default
22
- });
23
- module.exports = __toCommonJS(complementary_panel_ZYJJ42ZU_exports);
24
- var import_chunk_ORMEYEBE = require("./chunk-ORMEYEBE.cjs");
25
- var import_signals_core = require("@preact/signals-core");
26
- var import_app_framework = require("@dxos/app-framework");
27
- var import_types = require("@dxos/functions/types");
28
- var import_live_object = require("@dxos/live-object");
29
- var import_plugin_client = require("@dxos/plugin-client");
30
- var import_plugin_deck = require("@dxos/plugin-deck");
31
- var import_echo = require("@dxos/react-client/echo");
32
- var complementary_panel_default = (context) => {
33
- const state = (0, import_live_object.create)({
34
- functionsAvailable: false
35
- });
36
- const setState = (next) => {
37
- if (next !== state.functionsAvailable) {
38
- state.functionsAvailable = next;
39
- }
40
- };
41
- const unsubscribe = (0, import_signals_core.effect)(() => {
42
- const client = context.requestCapabilities(import_plugin_client.ClientCapabilities.Client)[0];
43
- const workspace = context.requestCapabilities(import_app_framework.Capabilities.Layout)[0]?.workspace;
44
- return (0, import_signals_core.untracked)(() => {
45
- const { spaceId } = (0, import_echo.parseId)(workspace);
46
- if (!spaceId || !client) {
47
- setState(false);
48
- return;
49
- }
50
- const space = client.spaces.get(spaceId);
51
- if (!space) {
52
- setState(false);
53
- return;
54
- }
55
- return space.db.query(import_echo.Filter.schema(import_types.FunctionType)).subscribe((query) => setState(query.objects.length > 0), {
56
- fire: true
57
- });
58
- });
59
- });
60
- return (0, import_app_framework.contributes)(import_plugin_deck.DeckCapabilities.ComplementaryPanel, {
61
- id: "automation",
62
- label: [
63
- "automation panel label",
64
- {
65
- ns: import_chunk_ORMEYEBE.AUTOMATION_PLUGIN
66
- }
67
- ],
68
- icon: "ph--robot--regular",
69
- filter: () => state.functionsAvailable
70
- }, () => unsubscribe());
71
- };
72
- //# sourceMappingURL=complementary-panel-ZYJJ42ZU.cjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/complementary-panel.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { effect, untracked } from '@preact/signals-core';\n\nimport { Capabilities, contributes, type PluginsContext } from '@dxos/app-framework';\nimport { FunctionType } from '@dxos/functions/types';\nimport { create } from '@dxos/live-object';\nimport { ClientCapabilities } from '@dxos/plugin-client';\nimport { DeckCapabilities } from '@dxos/plugin-deck';\nimport { Filter, parseId } from '@dxos/react-client/echo';\n\nimport { AUTOMATION_PLUGIN } from '../meta';\n\nexport default (context: PluginsContext) => {\n const state = create({ functionsAvailable: false });\n const setState = (next: boolean) => {\n if (next !== state.functionsAvailable) {\n state.functionsAvailable = next;\n }\n };\n\n const unsubscribe = effect(() => {\n const client = context.requestCapabilities(ClientCapabilities.Client)[0];\n const workspace = context.requestCapabilities(Capabilities.Layout)[0]?.workspace;\n return untracked(() => {\n const { spaceId } = parseId(workspace);\n if (!spaceId || !client) {\n setState(false);\n return;\n }\n\n const space = client.spaces.get(spaceId);\n if (!space) {\n setState(false);\n return;\n }\n\n return space.db\n .query(Filter.schema(FunctionType))\n .subscribe((query) => setState(query.objects.length > 0), { fire: true });\n });\n });\n\n return contributes(\n DeckCapabilities.ComplementaryPanel,\n {\n id: 'automation',\n label: ['automation panel label', { ns: AUTOMATION_PLUGIN }],\n icon: 'ph--robot--regular',\n filter: () => state.functionsAvailable,\n },\n () => unsubscribe(),\n );\n};\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;AAIA,0BAAkC;AAElC,2BAA+D;AAC/D,mBAA6B;AAC7B,yBAAuB;AACvB,2BAAmC;AACnC,yBAAiC;AACjC,kBAAgC;AAIhC,IAAA,8BAAe,CAACA,YAAAA;AACd,QAAMC,YAAQC,2BAAO;IAAEC,oBAAoB;EAAM,CAAA;AACjD,QAAMC,WAAW,CAACC,SAAAA;AAChB,QAAIA,SAASJ,MAAME,oBAAoB;AACrCF,YAAME,qBAAqBE;IAC7B;EACF;AAEA,QAAMC,kBAAcC,4BAAO,MAAA;AACzB,UAAMC,SAASR,QAAQS,oBAAoBC,wCAAmBC,MAAM,EAAE,CAAA;AACtE,UAAMC,YAAYZ,QAAQS,oBAAoBI,kCAAaC,MAAM,EAAE,CAAA,GAAIF;AACvE,eAAOG,+BAAU,MAAA;AACf,YAAM,EAAEC,QAAO,QAAKC,qBAAQL,SAAAA;AAC5B,UAAI,CAACI,WAAW,CAACR,QAAQ;AACvBJ,iBAAS,KAAA;AACT;MACF;AAEA,YAAMc,QAAQV,OAAOW,OAAOC,IAAIJ,OAAAA;AAChC,UAAI,CAACE,OAAO;AACVd,iBAAS,KAAA;AACT;MACF;AAEA,aAAOc,MAAMG,GACVC,MAAMC,mBAAOC,OAAOC,yBAAAA,CAAAA,EACpBC,UAAU,CAACJ,UAAUlB,SAASkB,MAAMK,QAAQC,SAAS,CAAA,GAAI;QAAEC,MAAM;MAAK,CAAA;IAC3E,CAAA;EACF,CAAA;AAEA,aAAOC,kCACLC,oCAAiBC,oBACjB;IACEC,IAAI;IACJC,OAAO;MAAC;MAA0B;QAAEC,IAAIC;MAAkB;;IAC1DC,MAAM;IACNC,QAAQ,MAAMrC,MAAME;EACtB,GACA,MAAMG,YAAAA,CAAAA;AAEV;",
6
- "names": ["context", "state", "create", "functionsAvailable", "setState", "next", "unsubscribe", "effect", "client", "requestCapabilities", "ClientCapabilities", "Client", "workspace", "Capabilities", "Layout", "untracked", "spaceId", "parseId", "space", "spaces", "get", "db", "query", "Filter", "schema", "FunctionType", "subscribe", "objects", "length", "fire", "contributes", "DeckCapabilities", "ComplementaryPanel", "id", "label", "ns", "AUTOMATION_PLUGIN", "icon", "filter"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/capabilities/react-surface.tsx"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, contributes, createSurface } from '@dxos/app-framework';\nimport { getSpace, isEchoObject, type ReactiveEchoObject } from '@dxos/react-client/echo';\n\nimport { AutomationPanel } from '../components';\nimport { AUTOMATION_PLUGIN } from '../meta';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: `${AUTOMATION_PLUGIN}/automation`,\n role: 'complementary--automation',\n filter: (data): data is { subject: ReactiveEchoObject<any> } =>\n isEchoObject(data.subject) && !!getSpace(data.subject),\n component: ({ data }) => <AutomationPanel space={getSpace(data.subject)!} object={data.subject} />,\n }),\n ]);\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,mBAAkB;AAElB,2BAAyD;AACzD,kBAAgE;AAKhE,IAAA,wBAAe,UACbA,kCAAYC,kCAAaC,cAAc;MACrCC,oCAAc;IACZC,IAAI,GAAGC,uCAAAA;IACPC,MAAM;IACNC,QAAQ,CAACC,aACPC,0BAAaD,KAAKE,OAAO,KAAK,CAAC,KAACC,sBAASH,KAAKE,OAAO;IACvDE,WAAW,CAAC,EAAEJ,KAAI,MAAO,6BAAAK,QAAA,cAACC,uCAAAA;MAAgBC,WAAOJ,sBAASH,KAAKE,OAAO;MAAIM,QAAQR,KAAKE;;EACzF,CAAA;CACD;",
6
- "names": ["contributes", "Capabilities", "ReactSurface", "createSurface", "id", "AUTOMATION_PLUGIN", "role", "filter", "data", "isEchoObject", "subject", "getSpace", "component", "React", "AutomationPanel", "space", "object"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/components/AutomationPanel/AutomationPanel.tsx", "../../../src/components/AutomationPanel/index.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport 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 { Clipboard, IconButton, Input, useTranslation } 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 <Clipboard.Provider>\n <div className='flex flex-col w-full'>\n {!trigger && (\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 <Clipboard.IconButton\n label={t(copyAction.translationKey)}\n value={copyAction.contentProvider()}\n />\n )}\n </div>\n\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\n );\n })}\n </div>\n )}\n </List.Root>\n )}\n\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 label')} onClick={handleAdd} />\n </div>\n )}\n </div>\n </Clipboard.Provider>\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 // TODO(wittjosiah): Truncation should be done in the UI.\n // Warning that the List component is currently a can of worms.\n const shortId = trigger.function && `${trigger.function?.slice(0, 16)}…`;\n const functionObject = functions.find((fn) => `dxn:worker:${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 { 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", "Clipboard", "IconButton", "Input", "useTranslation", "List", "ghostHover", "mx", "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", "Clipboard", "Provider", "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", "IconButton", "label", "translationKey", "value", "contentProvider", "ItemDeleteButton", "TriggerEditor", "onSave", "onCancel", "icon", "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,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 const meta = {\n id: AUTOMATION_PLUGIN,\n name: 'Automation',\n description:\n 'The Automation tab allows you to trigger pre-defined workflows related to the element you are interacting with inside of Composer.',\n icon: 'ph--robot--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-automation',\n} satisfies PluginMeta;\n"],
5
- "mappings": ";;;AAMO,IAAMA,oBAAoB;AAE1B,IAAMC,OAAO;EAClBC,IAAIF;EACJG,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;AACV;",
6
- "names": ["AUTOMATION_PLUGIN", "meta", "id", "name", "description", "icon", "source"]
7
- }
@@ -1,10 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
-
3
- // packages/plugins/experimental/plugin-automation/src/components/index.ts
4
- import { lazy } from "react";
5
- var AutomationPanel = lazy(() => import("./AutomationPanel-HY3GB4BT.mjs"));
6
-
7
- export {
8
- AutomationPanel
9
- };
10
- //# sourceMappingURL=chunk-R3P2WPBQ.mjs.map