@dxos/plugin-automation 0.7.4-staging.f7e8224 → 0.7.5-labs.5f04cf6

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 (201) hide show
  1. package/dist/lib/browser/{AssistantPanel-N3QSALKY.mjs → AssistantPanel-KO6DZBTU.mjs} +10 -11
  2. package/dist/lib/browser/AssistantPanel-KO6DZBTU.mjs.map +7 -0
  3. package/dist/lib/browser/AutomationPanel-BMLM533Z.mjs +131 -0
  4. package/dist/lib/browser/AutomationPanel-BMLM533Z.mjs.map +7 -0
  5. package/dist/lib/browser/ChatContainer-SIAJFRFF.mjs +300 -0
  6. package/dist/lib/browser/ChatContainer-SIAJFRFF.mjs.map +7 -0
  7. package/dist/lib/browser/ai-client-6CRYUC6D.mjs +22 -0
  8. package/dist/lib/browser/ai-client-6CRYUC6D.mjs.map +7 -0
  9. package/dist/lib/browser/app-graph-builder-IJTTULDP.mjs +131 -0
  10. package/dist/lib/browser/app-graph-builder-IJTTULDP.mjs.map +7 -0
  11. package/dist/lib/browser/{chunk-7KB4UMXO.mjs → chunk-C3VRGDR6.mjs} +30 -4
  12. package/dist/lib/browser/chunk-C3VRGDR6.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-EKJVAFT2.mjs +226 -0
  14. package/dist/lib/browser/chunk-EKJVAFT2.mjs.map +7 -0
  15. package/dist/lib/browser/{chunk-X5KMOH3I.mjs → chunk-HKX3D3ZP.mjs} +3 -3
  16. package/dist/lib/browser/chunk-HKX3D3ZP.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-HZ4TA7HY.mjs +15 -0
  18. package/dist/lib/browser/chunk-HZ4TA7HY.mjs.map +7 -0
  19. package/dist/lib/browser/chunk-JSNPW6JF.mjs +14 -0
  20. package/dist/lib/browser/chunk-JSNPW6JF.mjs.map +7 -0
  21. package/dist/lib/browser/chunk-KPSDH6XZ.mjs +118 -0
  22. package/dist/lib/browser/chunk-KPSDH6XZ.mjs.map +7 -0
  23. package/dist/lib/browser/chunk-YZF3SDZL.mjs +139 -0
  24. package/dist/lib/browser/chunk-YZF3SDZL.mjs.map +7 -0
  25. package/dist/lib/browser/index.mjs +143 -249
  26. package/dist/lib/browser/index.mjs.map +4 -4
  27. package/dist/lib/browser/intent-resolver-AHDQ3KQP.mjs +24 -0
  28. package/dist/lib/browser/intent-resolver-AHDQ3KQP.mjs.map +7 -0
  29. package/dist/lib/browser/meta.json +1 -1
  30. package/dist/lib/browser/react-surface-IGMBLSV7.mjs +49 -0
  31. package/dist/lib/browser/react-surface-IGMBLSV7.mjs.map +7 -0
  32. package/dist/lib/browser/types/index.mjs +6 -3
  33. package/dist/lib/node/{AssistantPanel-RIA4TI3B.cjs → AssistantPanel-PPFS2HKK.cjs} +20 -21
  34. package/dist/lib/node/AssistantPanel-PPFS2HKK.cjs.map +7 -0
  35. package/dist/lib/node/{AutomationPanel-HZS5WKI5.cjs → AutomationPanel-RXJDVLCF.cjs} +52 -72
  36. package/dist/lib/node/AutomationPanel-RXJDVLCF.cjs.map +7 -0
  37. package/dist/lib/node/ChatContainer-GS2SC5OG.cjs +318 -0
  38. package/dist/lib/node/ChatContainer-GS2SC5OG.cjs.map +7 -0
  39. package/dist/lib/node/ai-client-A3RRU55B.cjs +38 -0
  40. package/dist/lib/node/ai-client-A3RRU55B.cjs.map +7 -0
  41. package/dist/lib/node/app-graph-builder-MF5M4QRS.cjs +147 -0
  42. package/dist/lib/node/app-graph-builder-MF5M4QRS.cjs.map +7 -0
  43. package/dist/lib/node/{chunk-DTJ7XVO2.cjs → chunk-5VF5JKUN.cjs} +7 -7
  44. package/dist/lib/node/chunk-5VF5JKUN.cjs.map +7 -0
  45. package/dist/lib/node/{chunk-CUCUWUAF.cjs → chunk-BUQOZA4N.cjs} +32 -8
  46. package/dist/lib/node/chunk-BUQOZA4N.cjs.map +7 -0
  47. package/dist/lib/node/chunk-DNLBVFR7.cjs +147 -0
  48. package/dist/lib/node/chunk-DNLBVFR7.cjs.map +7 -0
  49. package/dist/lib/node/chunk-TWDGP26W.cjs +172 -0
  50. package/dist/lib/node/chunk-TWDGP26W.cjs.map +7 -0
  51. package/dist/lib/node/chunk-VEGLN4YN.cjs +250 -0
  52. package/dist/lib/node/chunk-VEGLN4YN.cjs.map +7 -0
  53. package/dist/lib/node/chunk-Z2YFE5SJ.cjs +49 -0
  54. package/dist/lib/node/chunk-Z2YFE5SJ.cjs.map +7 -0
  55. package/dist/lib/node/{meta.cjs → chunk-ZS5RZ7RM.cjs} +12 -8
  56. package/dist/lib/node/chunk-ZS5RZ7RM.cjs.map +7 -0
  57. package/dist/lib/node/index.cjs +159 -279
  58. package/dist/lib/node/index.cjs.map +4 -4
  59. package/dist/lib/node/intent-resolver-TBHYXBDI.cjs +39 -0
  60. package/dist/lib/node/intent-resolver-TBHYXBDI.cjs.map +7 -0
  61. package/dist/lib/node/meta.json +1 -1
  62. package/dist/lib/node/react-surface-BVUZMKYS.cjs +69 -0
  63. package/dist/lib/node/react-surface-BVUZMKYS.cjs.map +7 -0
  64. package/dist/lib/node/types/index.cjs +10 -7
  65. package/dist/lib/node/types/index.cjs.map +2 -2
  66. package/dist/lib/node-esm/{AssistantPanel-72YH43CH.mjs → AssistantPanel-XSSKKCJY.mjs} +10 -11
  67. package/dist/lib/node-esm/AssistantPanel-XSSKKCJY.mjs.map +7 -0
  68. package/dist/lib/node-esm/AutomationPanel-GQZZ4UBI.mjs +132 -0
  69. package/dist/lib/node-esm/AutomationPanel-GQZZ4UBI.mjs.map +7 -0
  70. package/dist/lib/node-esm/ChatContainer-57ILGC3R.mjs +301 -0
  71. package/dist/lib/node-esm/ChatContainer-57ILGC3R.mjs.map +7 -0
  72. package/dist/lib/node-esm/ai-client-2GBZRHBA.mjs +23 -0
  73. package/dist/lib/node-esm/ai-client-2GBZRHBA.mjs.map +7 -0
  74. package/dist/lib/node-esm/app-graph-builder-5N7OK23B.mjs +132 -0
  75. package/dist/lib/node-esm/app-graph-builder-5N7OK23B.mjs.map +7 -0
  76. package/dist/lib/node-esm/chunk-5QUXIXNB.mjs +227 -0
  77. package/dist/lib/node-esm/chunk-5QUXIXNB.mjs.map +7 -0
  78. package/dist/lib/node-esm/chunk-ICHNUP5M.mjs +119 -0
  79. package/dist/lib/node-esm/chunk-ICHNUP5M.mjs.map +7 -0
  80. package/dist/lib/node-esm/chunk-ISYLEDVU.mjs +16 -0
  81. package/dist/lib/node-esm/chunk-ISYLEDVU.mjs.map +7 -0
  82. package/dist/lib/node-esm/{chunk-23LY7DYS.mjs → chunk-JCYVS5GG.mjs} +29 -4
  83. package/dist/lib/node-esm/chunk-JCYVS5GG.mjs.map +7 -0
  84. package/dist/lib/node-esm/chunk-L2B6VGMG.mjs +16 -0
  85. package/dist/lib/node-esm/chunk-L2B6VGMG.mjs.map +7 -0
  86. package/dist/lib/node-esm/chunk-U7HXYMPZ.mjs +141 -0
  87. package/dist/lib/node-esm/chunk-U7HXYMPZ.mjs.map +7 -0
  88. package/dist/lib/node-esm/{chunk-HNOBZHWK.mjs → chunk-X3LPRWIL.mjs} +3 -3
  89. package/dist/lib/node-esm/chunk-X3LPRWIL.mjs.map +7 -0
  90. package/dist/lib/node-esm/index.mjs +143 -249
  91. package/dist/lib/node-esm/index.mjs.map +4 -4
  92. package/dist/lib/node-esm/intent-resolver-DPJJHFGK.mjs +25 -0
  93. package/dist/lib/node-esm/intent-resolver-DPJJHFGK.mjs.map +7 -0
  94. package/dist/lib/node-esm/meta.json +1 -1
  95. package/dist/lib/node-esm/react-surface-77S6XJOM.mjs +50 -0
  96. package/dist/lib/node-esm/react-surface-77S6XJOM.mjs.map +7 -0
  97. package/dist/lib/node-esm/types/index.mjs +6 -3
  98. package/dist/types/src/AutomationPlugin.d.ts +1 -3
  99. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  100. package/dist/types/src/artifacts.stories.d.ts +30 -0
  101. package/dist/types/src/artifacts.stories.d.ts.map +1 -0
  102. package/dist/types/src/capabilities/ai-client.d.ts +5 -0
  103. package/dist/types/src/capabilities/ai-client.d.ts.map +1 -0
  104. package/dist/types/src/capabilities/app-graph-builder.d.ts +180 -0
  105. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
  106. package/dist/types/src/capabilities/capabilities.d.ts +5 -0
  107. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -0
  108. package/dist/types/src/capabilities/index.d.ts +182 -0
  109. package/dist/types/src/capabilities/index.d.ts.map +1 -0
  110. package/dist/types/src/capabilities/intent-resolver.d.ts +4 -0
  111. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -0
  112. package/dist/types/src/capabilities/react-surface.d.ts +4 -0
  113. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  114. package/dist/types/src/components/AssistantPanel/AssistantPanel.d.ts.map +1 -1
  115. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -1
  116. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  117. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  118. package/dist/types/src/components/ChatContainer.d.ts +8 -0
  119. package/dist/types/src/components/ChatContainer.d.ts.map +1 -0
  120. package/dist/types/src/components/Thread/Thread.d.ts +14 -0
  121. package/dist/types/src/components/Thread/Thread.d.ts.map +1 -0
  122. package/dist/types/src/components/Thread/Thread.stories.d.ts +12 -0
  123. package/dist/types/src/components/Thread/Thread.stories.d.ts.map +1 -0
  124. package/dist/types/src/components/Thread/index.d.ts +2 -0
  125. package/dist/types/src/components/Thread/index.d.ts.map +1 -0
  126. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -2
  127. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  128. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  129. package/dist/types/src/components/index.d.ts +8 -1
  130. package/dist/types/src/components/index.d.ts.map +1 -1
  131. package/dist/types/src/hooks/email.d.ts.map +1 -1
  132. package/dist/types/src/hooks/index.d.ts +1 -0
  133. package/dist/types/src/hooks/index.d.ts.map +1 -1
  134. package/dist/types/src/hooks/invocation-handler.d.ts.map +1 -1
  135. package/dist/types/src/hooks/processor.d.ts +46 -0
  136. package/dist/types/src/hooks/processor.d.ts.map +1 -0
  137. package/dist/types/src/hooks/processor.test.d.ts +2 -0
  138. package/dist/types/src/hooks/processor.test.d.ts.map +1 -0
  139. package/dist/types/src/index.d.ts +1 -2
  140. package/dist/types/src/index.d.ts.map +1 -1
  141. package/dist/types/src/meta.d.ts +1 -2
  142. package/dist/types/src/meta.d.ts.map +1 -1
  143. package/dist/types/src/testing/testing.d.ts +2 -0
  144. package/dist/types/src/testing/testing.d.ts.map +1 -1
  145. package/dist/types/src/translations.d.ts +76 -0
  146. package/dist/types/src/translations.d.ts.map +1 -1
  147. package/dist/types/src/types/schema.d.ts +40 -39
  148. package/dist/types/src/types/schema.d.ts.map +1 -1
  149. package/dist/types/src/types/types.d.ts +16 -5
  150. package/dist/types/src/types/types.d.ts.map +1 -1
  151. package/dist/types/tsconfig.tsbuildinfo +1 -0
  152. package/package.json +48 -47
  153. package/src/AutomationPlugin.tsx +85 -194
  154. package/src/artifacts.stories.tsx +180 -0
  155. package/src/capabilities/ai-client.ts +19 -0
  156. package/src/capabilities/app-graph-builder.ts +127 -0
  157. package/src/capabilities/capabilities.ts +12 -0
  158. package/src/capabilities/index.ts +12 -0
  159. package/src/capabilities/intent-resolver.ts +22 -0
  160. package/src/capabilities/react-surface.tsx +34 -0
  161. package/src/components/AssistantPanel/AssistantPanel.tsx +10 -8
  162. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +1 -2
  163. package/src/components/AutomationPanel/AutomationPanel.tsx +61 -39
  164. package/src/components/ChatContainer.tsx +80 -0
  165. package/src/components/PromptEditor/PromptEditor.stories.tsx +3 -3
  166. package/src/components/Thread/Thread.stories.tsx +142 -0
  167. package/src/components/Thread/Thread.tsx +149 -0
  168. package/src/components/Thread/index.ts +5 -0
  169. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +1 -2
  170. package/src/components/TriggerEditor/TriggerEditor.tsx +83 -16
  171. package/src/components/index.ts +5 -0
  172. package/src/hooks/email.ts +2 -2
  173. package/src/hooks/index.ts +1 -0
  174. package/src/hooks/invocation-handler.ts +2 -2
  175. package/src/hooks/processor.test.ts +15 -0
  176. package/src/hooks/processor.ts +161 -0
  177. package/src/index.ts +1 -4
  178. package/src/meta.ts +1 -1
  179. package/src/testing/testing.ts +9 -2
  180. package/src/translations.ts +13 -0
  181. package/src/types/schema.ts +9 -2
  182. package/src/types/types.ts +15 -21
  183. package/dist/lib/browser/AssistantPanel-N3QSALKY.mjs.map +0 -7
  184. package/dist/lib/browser/AutomationPanel-AQMN2CQR.mjs +0 -153
  185. package/dist/lib/browser/AutomationPanel-AQMN2CQR.mjs.map +0 -7
  186. package/dist/lib/browser/chunk-7KB4UMXO.mjs.map +0 -7
  187. package/dist/lib/browser/chunk-X5KMOH3I.mjs.map +0 -7
  188. package/dist/lib/browser/meta.mjs +0 -9
  189. package/dist/lib/browser/meta.mjs.map +0 -7
  190. package/dist/lib/node/AssistantPanel-RIA4TI3B.cjs.map +0 -7
  191. package/dist/lib/node/AutomationPanel-HZS5WKI5.cjs.map +0 -7
  192. package/dist/lib/node/chunk-CUCUWUAF.cjs.map +0 -7
  193. package/dist/lib/node/chunk-DTJ7XVO2.cjs.map +0 -7
  194. package/dist/lib/node/meta.cjs.map +0 -7
  195. package/dist/lib/node-esm/AssistantPanel-72YH43CH.mjs.map +0 -7
  196. package/dist/lib/node-esm/AutomationPanel-JUHOWQWW.mjs +0 -154
  197. package/dist/lib/node-esm/AutomationPanel-JUHOWQWW.mjs.map +0 -7
  198. package/dist/lib/node-esm/chunk-23LY7DYS.mjs.map +0 -7
  199. package/dist/lib/node-esm/chunk-HNOBZHWK.mjs.map +0 -7
  200. package/dist/lib/node-esm/meta.mjs +0 -10
  201. package/dist/lib/node-esm/meta.mjs.map +0 -7
@@ -0,0 +1,118 @@
1
+ import {
2
+ AUTOMATION_PLUGIN
3
+ } from "./chunk-HKX3D3ZP.mjs";
4
+
5
+ // packages/plugins/experimental/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
6
+ import React, { useState } from "react";
7
+ import { ComputeGraph } from "@dxos/conductor";
8
+ import { FunctionType, FunctionTriggerSchema, ScriptType, TriggerKind } from "@dxos/functions";
9
+ import { Filter, useQuery } from "@dxos/react-client/echo";
10
+ import { IconButton, Input, useTranslation } from "@dxos/react-ui";
11
+ import { Form, SelectInput, TextInput } from "@dxos/react-ui-form";
12
+ var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
13
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
14
+ const functions = useQuery(space, Filter.schema(FunctionType));
15
+ const workflows = useQuery(space, Filter.schema(ComputeGraph));
16
+ const scripts = useQuery(space, Filter.schema(ScriptType));
17
+ const handleSave = (values) => {
18
+ onSave?.(values);
19
+ };
20
+ return /* @__PURE__ */ React.createElement(Form, {
21
+ schema: FunctionTriggerSchema,
22
+ values: trigger,
23
+ onSave: handleSave,
24
+ onCancel,
25
+ Custom: {
26
+ ["function"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
27
+ ...props,
28
+ options: getWorkflowOptions(workflows).concat(getFunctionOptions(scripts, functions))
29
+ }),
30
+ ["spec.type"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
31
+ ...props,
32
+ options: Object.values(TriggerKind).map((kind) => ({
33
+ value: kind,
34
+ label: t(`trigger type ${kind}`)
35
+ }))
36
+ }),
37
+ ["meta"]: (props) => {
38
+ const meta = props.getValue();
39
+ const [newMetaFieldName, setNewMetaFieldName] = useState("");
40
+ React.useEffect(() => props.onValueChange("object", {
41
+ ...meta
42
+ }), []);
43
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("div", null, props.label), [
44
+ ...Object.keys(meta)
45
+ ].map((key) => {
46
+ const compositeKey = `meta.${key}`;
47
+ return /* @__PURE__ */ React.createElement("div", {
48
+ key: compositeKey,
49
+ role: "none",
50
+ className: "flex items-center mt-2 gap-1"
51
+ }, /* @__PURE__ */ React.createElement("div", {
52
+ role: "none",
53
+ className: "flex-1"
54
+ }, /* @__PURE__ */ React.createElement(TextInput, {
55
+ ...props,
56
+ type: "string",
57
+ label: key
58
+ })), /* @__PURE__ */ React.createElement(IconButton, {
59
+ icon: "ph--trash--regular",
60
+ iconOnly: true,
61
+ classNames: "mt-6",
62
+ label: t("trigger meta remove"),
63
+ onClick: () => {
64
+ const newValues = {
65
+ ...props.getValue()
66
+ };
67
+ delete newValues[key];
68
+ props.onValueChange("object", newValues);
69
+ }
70
+ }));
71
+ }), /* @__PURE__ */ React.createElement("div", {
72
+ role: "none",
73
+ className: "flex items-center mt-2 gap-1 plb-1"
74
+ }, /* @__PURE__ */ React.createElement("div", {
75
+ role: "none",
76
+ className: "flex-1"
77
+ }, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.TextInput, {
78
+ placeholder: t("trigger meta prop name placeholder"),
79
+ value: newMetaFieldName,
80
+ onChange: (event) => setNewMetaFieldName(event.target.value)
81
+ }))), /* @__PURE__ */ React.createElement(IconButton, {
82
+ icon: "ph--plus--regular",
83
+ iconOnly: true,
84
+ label: t("trigger meta add"),
85
+ onClick: () => {
86
+ if (newMetaFieldName.length) {
87
+ const meta2 = props.getValue() ?? {};
88
+ const metaWithNewProp = {
89
+ ...meta2,
90
+ [newMetaFieldName]: ""
91
+ };
92
+ setNewMetaFieldName("");
93
+ props.onValueChange("object", metaWithNewProp);
94
+ }
95
+ }
96
+ })));
97
+ }
98
+ }
99
+ });
100
+ };
101
+ var getWorkflowOptions = (graphs) => {
102
+ return graphs.map((graph) => ({
103
+ label: `compute-${graph.id}`,
104
+ value: `dxn:echo:@:${graph.id}`
105
+ }));
106
+ };
107
+ var getFunctionOptions = (scripts, functions) => {
108
+ const getLabel = (fn) => scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
109
+ return functions.map((fn) => ({
110
+ label: getLabel(fn),
111
+ value: `dxn:worker:${fn.name}`
112
+ }));
113
+ };
114
+
115
+ export {
116
+ TriggerEditor
117
+ };
118
+ //# sourceMappingURL=chunk-KPSDH6XZ.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/TriggerEditor/TriggerEditor.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { 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\n const [newMetaFieldName, setNewMetaFieldName] = useState('');\n\n React.useEffect(() => props.onValueChange('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} 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() };\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", "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", "newMetaFieldName", "setNewMetaFieldName", "useState", "React", "useEffect", "onValueChange", "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
+ }
@@ -0,0 +1,139 @@
1
+ // packages/plugins/experimental/plugin-automation/src/components/Thread/Thread.tsx
2
+ import React, { useCallback, useEffect, useRef, useState } from "react";
3
+ import { Icon, Input, useThemeContext } from "@dxos/react-ui";
4
+ import { createBasicExtensions, createMarkdownExtensions, createThemeExtensions, decorateMarkdown, useTextEditor } from "@dxos/react-ui-editor";
5
+ import { Ball } from "@dxos/react-ui-sfx";
6
+ import { SyntaxHighlighter } from "@dxos/react-ui-syntax-highlighter";
7
+ import { mx } from "@dxos/react-ui-theme";
8
+ var Thread = ({ messages, streaming, onSubmit }) => {
9
+ const scrollRef = useRef(null);
10
+ const scroll = () => scrollRef.current?.scrollTo({
11
+ top: scrollRef.current.scrollHeight,
12
+ behavior: "smooth"
13
+ });
14
+ const [text, setText] = useState("");
15
+ useEffect(() => scroll(), [
16
+ messages
17
+ ]);
18
+ const handleKeyDown = useCallback((ev) => {
19
+ switch (ev.key) {
20
+ case "Escape": {
21
+ setText("");
22
+ break;
23
+ }
24
+ case "Enter": {
25
+ const value = text.trim();
26
+ if (value.length > 0) {
27
+ onSubmit(value);
28
+ setText("");
29
+ scroll();
30
+ }
31
+ break;
32
+ }
33
+ }
34
+ }, [
35
+ text
36
+ ]);
37
+ return /* @__PURE__ */ React.createElement("div", {
38
+ className: "flex flex-col grow overflow-hidden"
39
+ }, /* @__PURE__ */ React.createElement("div", {
40
+ ref: scrollRef,
41
+ className: "flex flex-col grow overflow-x-hidden overflow-y-scroll scrollbar-thin divide-y divide-separator"
42
+ }, messages.map((message, i) => /* @__PURE__ */ React.createElement(ThreadMessage, {
43
+ key: i,
44
+ classNames: "px-4 py-2",
45
+ message
46
+ }))), /* @__PURE__ */ React.createElement("div", {
47
+ className: "flex p-4 gap-3 items-center"
48
+ }, /* @__PURE__ */ React.createElement(Ball, {
49
+ active: streaming
50
+ }), /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.TextInput, {
51
+ autoFocus: true,
52
+ classNames: "px-2 bg-base rounded",
53
+ placeholder: "Ask a question...",
54
+ value: text,
55
+ onChange: (ev) => setText(ev.target.value),
56
+ onKeyDown: handleKeyDown
57
+ })), /* @__PURE__ */ React.createElement(Icon, {
58
+ icon: "ph--spinner-gap--regular",
59
+ classNames: mx("animate-spin opacity-0 transition duration-500", streaming && "opacity-100"),
60
+ size: 6
61
+ })));
62
+ };
63
+ var ThreadMessage = ({ classNames, message }) => {
64
+ if (typeof message !== "object") {
65
+ return /* @__PURE__ */ React.createElement("div", {
66
+ className: mx(classNames)
67
+ }, message);
68
+ }
69
+ const { role, content = [] } = message;
70
+ return /* @__PURE__ */ React.createElement("div", {
71
+ className: mx("flex", classNames, role === "user" && "justify-end")
72
+ }, /* @__PURE__ */ React.createElement("div", {
73
+ className: mx("block rounded-md p-1 px-2 bg-base overflow-hidden divide-y divid-separator", role === "user" ? "dark:bg-blue-800" : "whitespace-pre-wrap")
74
+ }, content.map((item, idx) => {
75
+ switch (item.type) {
76
+ case "text":
77
+ return /* @__PURE__ */ React.createElement(Markdown, {
78
+ key: idx,
79
+ text: item.text.trim()
80
+ });
81
+ case "json":
82
+ return /* @__PURE__ */ React.createElement(Json, {
83
+ key: idx,
84
+ data: item.json
85
+ });
86
+ default:
87
+ return /* @__PURE__ */ React.createElement(Json, {
88
+ key: idx,
89
+ data: item
90
+ });
91
+ }
92
+ })));
93
+ };
94
+ var Markdown = ({ text, classNames }) => {
95
+ const { themeMode } = useThemeContext();
96
+ const { parentRef, view } = useTextEditor(() => ({
97
+ initialValue: text,
98
+ extensions: [
99
+ // TOOD(burdon): Optional line wrapping.
100
+ createBasicExtensions({
101
+ lineWrapping: true,
102
+ readonly: true
103
+ }),
104
+ createMarkdownExtensions(),
105
+ createThemeExtensions({
106
+ themeMode
107
+ }),
108
+ decorateMarkdown()
109
+ ]
110
+ }));
111
+ useEffect(() => {
112
+ view?.dispatch({
113
+ // TODO(burdon): Append?
114
+ changes: {
115
+ from: 0,
116
+ to: view.state.doc.length,
117
+ insert: text
118
+ }
119
+ });
120
+ }, [
121
+ text
122
+ ]);
123
+ return /* @__PURE__ */ React.createElement("div", {
124
+ ref: parentRef,
125
+ className: mx("w-full overflow-hidden", classNames)
126
+ });
127
+ };
128
+ var Json = ({ data, classNames }) => {
129
+ return /* @__PURE__ */ React.createElement(SyntaxHighlighter, {
130
+ language: "json",
131
+ classNames: "w-full overflow-hidden text-sm"
132
+ }, JSON.stringify(data, null, 2));
133
+ };
134
+
135
+ export {
136
+ Thread,
137
+ ThreadMessage
138
+ };
139
+ //# sourceMappingURL=chunk-YZF3SDZL.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/Thread/Thread.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { type KeyboardEventHandler, useCallback, useEffect, useRef, useState } from 'react';\n\nimport { type Message } from '@dxos/artifact';\nimport { Icon, Input, useThemeContext, type ThemedClassName } from '@dxos/react-ui';\nimport {\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n decorateMarkdown,\n useTextEditor,\n} from '@dxos/react-ui-editor';\nimport { Ball } from '@dxos/react-ui-sfx';\nimport { SyntaxHighlighter } from '@dxos/react-ui-syntax-highlighter';\nimport { mx } from '@dxos/react-ui-theme';\n\nexport type ThreadProps = {\n messages: Message[];\n streaming?: boolean;\n onSubmit: (message: string) => void;\n};\n\nexport const Thread = ({ messages, streaming, onSubmit }: ThreadProps) => {\n const scrollRef = useRef<HTMLDivElement>(null);\n const scroll = () => scrollRef.current?.scrollTo({ top: scrollRef.current.scrollHeight, behavior: 'smooth' });\n const [text, setText] = useState('');\n useEffect(() => scroll(), [messages]);\n\n const handleKeyDown = useCallback<KeyboardEventHandler<HTMLInputElement>>(\n (ev) => {\n switch (ev.key) {\n case 'Escape': {\n setText('');\n break;\n }\n case 'Enter': {\n const value = text.trim();\n if (value.length > 0) {\n onSubmit(value);\n setText('');\n scroll();\n }\n break;\n }\n }\n },\n [text],\n );\n\n return (\n <div className='flex flex-col grow overflow-hidden'>\n <div\n ref={scrollRef}\n className='flex flex-col grow overflow-x-hidden overflow-y-scroll scrollbar-thin divide-y divide-separator'\n >\n {messages.map((message, i) => (\n <ThreadMessage key={i} classNames='px-4 py-2' message={message} />\n ))}\n </div>\n\n <div className='flex p-4 gap-3 items-center'>\n <Ball active={streaming} />\n <Input.Root>\n <Input.TextInput\n autoFocus\n classNames='px-2 bg-base rounded'\n placeholder='Ask a question...'\n value={text}\n onChange={(ev) => setText(ev.target.value)}\n onKeyDown={handleKeyDown}\n />\n </Input.Root>\n <Icon\n icon={'ph--spinner-gap--regular'}\n classNames={mx('animate-spin opacity-0 transition duration-500', streaming && 'opacity-100')}\n size={6}\n />\n </div>\n </div>\n );\n};\n\nexport type ThreadMessageProps = ThemedClassName<{\n message: Message;\n}>;\n\nexport const ThreadMessage = ({ classNames, message }: ThreadMessageProps) => {\n if (typeof message !== 'object') {\n return <div className={mx(classNames)}>{message}</div>;\n }\n\n const { role, content = [] } = message;\n return (\n <div className={mx('flex', classNames, role === 'user' && 'justify-end')}>\n <div\n className={mx(\n 'block rounded-md p-1 px-2 bg-base overflow-hidden divide-y divid-separator',\n role === 'user' ? 'dark:bg-blue-800' : 'whitespace-pre-wrap',\n )}\n >\n {/* TODO(burdon): Use message ID for stable rendering. */}\n {content.map((item, idx) => {\n switch (item.type) {\n case 'text':\n return <Markdown key={idx} text={item.text.trim()} />;\n case 'json':\n return <Json key={idx} data={item.json} />;\n default:\n return <Json key={idx} data={item} />;\n }\n })}\n </div>\n </div>\n );\n};\n\nconst Markdown = ({ text, classNames }: ThemedClassName<{ text: string }>) => {\n const { themeMode } = useThemeContext();\n const { parentRef, view } = useTextEditor(() => ({\n initialValue: text,\n extensions: [\n // TOOD(burdon): Optional line wrapping.\n createBasicExtensions({ lineWrapping: true, readonly: true }),\n createMarkdownExtensions(),\n createThemeExtensions({ themeMode }),\n decorateMarkdown(),\n ],\n }));\n\n useEffect(() => {\n view?.dispatch({\n // TODO(burdon): Append?\n changes: { from: 0, to: view.state.doc.length, insert: text },\n });\n }, [text]);\n\n return <div ref={parentRef} className={mx('w-full overflow-hidden', classNames)} />;\n};\n\nconst Json = ({ data, classNames }: ThemedClassName<{ data: any }>) => {\n return (\n <SyntaxHighlighter language='json' classNames='w-full overflow-hidden text-sm'>\n {JSON.stringify(data, null, 2)}\n </SyntaxHighlighter>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useCallback", "useEffect", "useRef", "useState", "Icon", "Input", "useThemeContext", "createBasicExtensions", "createMarkdownExtensions", "createThemeExtensions", "decorateMarkdown", "useTextEditor", "Ball", "SyntaxHighlighter", "mx", "Thread", "messages", "streaming", "onSubmit", "scrollRef", "useRef", "scroll", "current", "scrollTo", "top", "scrollHeight", "behavior", "text", "setText", "useState", "useEffect", "handleKeyDown", "useCallback", "ev", "key", "value", "trim", "length", "div", "className", "ref", "map", "message", "i", "ThreadMessage", "classNames", "Ball", "active", "Input", "Root", "TextInput", "autoFocus", "placeholder", "onChange", "target", "onKeyDown", "Icon", "icon", "mx", "size", "role", "content", "item", "idx", "type", "Markdown", "Json", "data", "json", "themeMode", "useThemeContext", "parentRef", "view", "useTextEditor", "initialValue", "extensions", "createBasicExtensions", "lineWrapping", "readonly", "createMarkdownExtensions", "createThemeExtensions", "decorateMarkdown", "dispatch", "changes", "from", "to", "state", "doc", "insert", "SyntaxHighlighter", "language", "JSON", "stringify"]
7
+ }