@dxos/plugin-automation 0.7.2-main.f1adc9f → 0.7.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/{chunk-R6GS7UA7.mjs → chunk-B3Z4NQC2.mjs} +8 -2
- package/dist/lib/browser/{chunk-R6GS7UA7.mjs.map → chunk-B3Z4NQC2.mjs.map} +3 -3
- package/dist/lib/browser/{chunk-X5KMOH3I.mjs → chunk-PQLGYMNY.mjs} +2 -2
- package/dist/lib/browser/{chunk-X5KMOH3I.mjs.map → chunk-PQLGYMNY.mjs.map} +1 -1
- package/dist/lib/browser/index.mjs +286 -109
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/meta.mjs +1 -1
- package/dist/lib/browser/types/index.mjs +2 -1
- package/dist/lib/node/{chunk-DTJ7XVO2.cjs → chunk-JSZ6PAYL.cjs} +5 -5
- package/dist/lib/node/{chunk-DTJ7XVO2.cjs.map → chunk-JSZ6PAYL.cjs.map} +1 -1
- package/dist/lib/node/{chunk-JHKEVE65.cjs → chunk-SUMUWFZA.cjs} +8 -5
- package/dist/lib/node/{chunk-JHKEVE65.cjs.map → chunk-SUMUWFZA.cjs.map} +3 -3
- package/dist/lib/node/index.cjs +313 -143
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/meta.cjs +3 -3
- package/dist/lib/node/meta.cjs.map +1 -1
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/types/index.cjs +7 -6
- package/dist/lib/node/types/index.cjs.map +2 -2
- package/dist/lib/node-esm/{chunk-HNOBZHWK.mjs → chunk-B35UD3D7.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-HNOBZHWK.mjs.map → chunk-B35UD3D7.mjs.map} +1 -1
- package/dist/lib/node-esm/{chunk-ISJZVA2J.mjs → chunk-PYT2WY4B.mjs} +7 -2
- package/dist/lib/node-esm/{chunk-ISJZVA2J.mjs.map → chunk-PYT2WY4B.mjs.map} +3 -3
- package/dist/lib/node-esm/index.mjs +286 -109
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/meta.mjs +1 -1
- package/dist/lib/node-esm/types/index.mjs +2 -1
- package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
- package/dist/types/src/components/AutomationPanel.d.ts +3 -0
- package/dist/types/src/components/AutomationPanel.d.ts.map +1 -0
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +2 -4
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +3 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +0 -2
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +3 -3
- package/dist/types/src/types/types.d.ts +1 -0
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/package.json +34 -37
- package/src/AutomationPlugin.tsx +35 -88
- package/src/components/AutomationPanel.tsx +23 -0
- package/src/components/TriggerEditor/TriggerEditor.stories.tsx +32 -2
- package/src/components/TriggerEditor/TriggerEditor.tsx +43 -9
- package/src/components/index.ts +3 -4
- package/src/meta.ts +1 -1
- package/src/translations.ts +0 -3
- package/src/types/types.ts +5 -3
- package/dist/lib/browser/AssistantPanel-622FK3DP.mjs +0 -341
- package/dist/lib/browser/AssistantPanel-622FK3DP.mjs.map +0 -7
- package/dist/lib/browser/AutomationPanel-PVI2EJNE.mjs +0 -125
- package/dist/lib/browser/AutomationPanel-PVI2EJNE.mjs.map +0 -7
- package/dist/lib/node/AssistantPanel-HRJRVOZD.cjs +0 -361
- package/dist/lib/node/AssistantPanel-HRJRVOZD.cjs.map +0 -7
- package/dist/lib/node/AutomationPanel-Z2XW24BN.cjs +0 -145
- package/dist/lib/node/AutomationPanel-Z2XW24BN.cjs.map +0 -7
- package/dist/lib/node-esm/AssistantPanel-QIIX7S4V.mjs +0 -342
- package/dist/lib/node-esm/AssistantPanel-QIIX7S4V.mjs.map +0 -7
- package/dist/lib/node-esm/AutomationPanel-5L5NFVKU.mjs +0 -126
- package/dist/lib/node-esm/AutomationPanel-5L5NFVKU.mjs.map +0 -7
- package/dist/types/src/components/AssistantPanel/AssistantPanel.d.ts +0 -8
- package/dist/types/src/components/AssistantPanel/AssistantPanel.d.ts.map +0 -1
- package/dist/types/src/components/AssistantPanel/index.d.ts +0 -3
- package/dist/types/src/components/AssistantPanel/index.d.ts.map +0 -1
- package/dist/types/src/components/AssistantPanel/system-instructions.d.ts +0 -6
- package/dist/types/src/components/AssistantPanel/system-instructions.d.ts.map +0 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +0 -9
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +0 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts +0 -6
- package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +0 -1
- package/dist/types/src/components/AutomationPanel/index.d.ts +0 -3
- package/dist/types/src/components/AutomationPanel/index.d.ts.map +0 -1
- package/dist/types/src/testing/index.d.ts +0 -2
- package/dist/types/src/testing/index.d.ts.map +0 -1
- package/dist/types/src/testing/testing.d.ts +0 -12
- package/dist/types/src/testing/testing.d.ts.map +0 -1
- package/src/components/AssistantPanel/AssistantPanel.tsx +0 -230
- package/src/components/AssistantPanel/index.ts +0 -7
- package/src/components/AssistantPanel/system-instructions.ts +0 -166
- package/src/components/AutomationPanel/AutomationPanel.stories.tsx +0 -57
- package/src/components/AutomationPanel/AutomationPanel.tsx +0 -96
- package/src/components/AutomationPanel/index.ts +0 -7
- package/src/testing/index.ts +0 -5
- package/src/testing/testing.ts +0 -34
|
@@ -1,341 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
AUTOMATION_PLUGIN
|
|
3
|
-
} from "./chunk-X5KMOH3I.mjs";
|
|
4
|
-
|
|
5
|
-
// packages/plugins/experimental/plugin-automation/src/components/AssistantPanel/AssistantPanel.tsx
|
|
6
|
-
import React, { useEffect, useRef, useState } from "react";
|
|
7
|
-
import { AIServiceClientImpl, ObjectId } from "@dxos/assistant";
|
|
8
|
-
import { SpaceId } from "@dxos/keys";
|
|
9
|
-
import { useClient, useConfig } from "@dxos/react-client";
|
|
10
|
-
import { ContextMenu } from "@dxos/react-ui";
|
|
11
|
-
import { Icon, Input, Toolbar, useTranslation } from "@dxos/react-ui";
|
|
12
|
-
import { SyntaxHighlighter } from "@dxos/react-ui-syntax-highlighter";
|
|
13
|
-
import { mx } from "@dxos/react-ui-theme";
|
|
14
|
-
|
|
15
|
-
// packages/plugins/experimental/plugin-automation/src/components/AssistantPanel/system-instructions.ts
|
|
16
|
-
import { asyncTimeout } from "@dxos/async";
|
|
17
|
-
import { getTypename } from "@dxos/echo-schema";
|
|
18
|
-
import { log } from "@dxos/log";
|
|
19
|
-
import { Filter, getSpace, ResultFormat } from "@dxos/react-client/echo";
|
|
20
|
-
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/experimental/plugin-automation/src/components/AssistantPanel/system-instructions.ts";
|
|
21
|
-
var createSystemInstructions = async (context) => {
|
|
22
|
-
let instructions = `
|
|
23
|
-
<instructions>
|
|
24
|
-
Before replying always think step-by-step on how to proceed.
|
|
25
|
-
Print your thoughts inside <cot> tags.
|
|
26
|
-
|
|
27
|
-
<example>
|
|
28
|
-
<cot>To answer the question I need to ...</cot>
|
|
29
|
-
</example>
|
|
30
|
-
</instructions>
|
|
31
|
-
|
|
32
|
-
<current_time>${(/* @__PURE__ */ new Date()).toLocaleString()}</current_time>
|
|
33
|
-
`;
|
|
34
|
-
if (context.subject) {
|
|
35
|
-
instructions += `
|
|
36
|
-
<user_attention>
|
|
37
|
-
The user is currently interacting with an object in Composer application:
|
|
38
|
-
|
|
39
|
-
${await formatContextObject(context.subject)}
|
|
40
|
-
</user_attention>
|
|
41
|
-
`;
|
|
42
|
-
}
|
|
43
|
-
return looseFormatXml(instructions);
|
|
44
|
-
};
|
|
45
|
-
var formatContextObject = async (object) => {
|
|
46
|
-
let data;
|
|
47
|
-
try {
|
|
48
|
-
data = await asyncTimeout(preprocessContextObject(object), CONTEXT_OBJECT_QUERY_TIMEOUT);
|
|
49
|
-
} catch (err) {
|
|
50
|
-
log.error("Failed to preprocess context object:", {
|
|
51
|
-
err
|
|
52
|
-
}, {
|
|
53
|
-
F: __dxlog_file,
|
|
54
|
-
L: 48,
|
|
55
|
-
S: void 0,
|
|
56
|
-
C: (f, a) => f(...a)
|
|
57
|
-
});
|
|
58
|
-
data = object;
|
|
59
|
-
}
|
|
60
|
-
if (typeof data === "string") {
|
|
61
|
-
return data;
|
|
62
|
-
} else {
|
|
63
|
-
return `
|
|
64
|
-
<object>
|
|
65
|
-
<type>${getTypename(object)}</type>
|
|
66
|
-
<id>${object.id}</id>
|
|
67
|
-
${formatObjectAsXMLTags(data)}
|
|
68
|
-
</object>
|
|
69
|
-
`;
|
|
70
|
-
}
|
|
71
|
-
};
|
|
72
|
-
var preprocessContextObject = async (object) => {
|
|
73
|
-
const space = getSpace(object);
|
|
74
|
-
if (!space) {
|
|
75
|
-
return {
|
|
76
|
-
...object
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
switch (getTypename(object)) {
|
|
80
|
-
// TODO(dmaretskyi): Reference types somehow without plugin-automation depending on other plugins.
|
|
81
|
-
case "dxos.org/type/Document": {
|
|
82
|
-
const data = space.db.query({
|
|
83
|
-
id: object.id
|
|
84
|
-
}, {
|
|
85
|
-
format: ResultFormat.Plain,
|
|
86
|
-
include: {
|
|
87
|
-
content: true
|
|
88
|
-
}
|
|
89
|
-
}).first() ?? {
|
|
90
|
-
content: {
|
|
91
|
-
content: ""
|
|
92
|
-
}
|
|
93
|
-
};
|
|
94
|
-
return {
|
|
95
|
-
...data,
|
|
96
|
-
threads: void 0
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
case "dxos.org/type/Table": {
|
|
100
|
-
const schema = object.view ? space?.db.schemaRegistry.getSchema(object.view.query.typename) : void 0;
|
|
101
|
-
const { objects: rows } = (schema && await space.db.query(Filter.schema(schema), {
|
|
102
|
-
format: ResultFormat.Plain,
|
|
103
|
-
limit: TABLE_ROWS_LIMIT
|
|
104
|
-
}).run()) ?? {};
|
|
105
|
-
return `
|
|
106
|
-
<object>
|
|
107
|
-
<id>${object.id}</id>
|
|
108
|
-
<type>${getTypename(object)}</type>
|
|
109
|
-
${formatObjectAsXMLTags(object)}
|
|
110
|
-
|
|
111
|
-
<rows>
|
|
112
|
-
<!-- Limited to first ${TABLE_ROWS_LIMIT} rows. -->
|
|
113
|
-
${rows?.map((row) => `<row>
|
|
114
|
-
${formatObjectAsXMLTags(row)}
|
|
115
|
-
</row>`).join("\n")}
|
|
116
|
-
</rows>
|
|
117
|
-
|
|
118
|
-
`;
|
|
119
|
-
}
|
|
120
|
-
default:
|
|
121
|
-
return {
|
|
122
|
-
...object
|
|
123
|
-
};
|
|
124
|
-
}
|
|
125
|
-
};
|
|
126
|
-
var formatObjectAsXMLTags = (object, depth = 1) => {
|
|
127
|
-
return Object.entries(object).filter(([key, value]) => [
|
|
128
|
-
"string",
|
|
129
|
-
"number",
|
|
130
|
-
"boolean",
|
|
131
|
-
"object"
|
|
132
|
-
].includes(typeof value)).map(([key, value]) => {
|
|
133
|
-
if (typeof value === "object" && value !== null) {
|
|
134
|
-
if (depth === 0) {
|
|
135
|
-
return "";
|
|
136
|
-
} else {
|
|
137
|
-
return `<${key}>
|
|
138
|
-
${formatObjectAsXMLTags(value, depth - 1)}
|
|
139
|
-
</${key}>`;
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
return `<${key}>${value}</${key}>`;
|
|
143
|
-
}).join("\n");
|
|
144
|
-
};
|
|
145
|
-
var CONTEXT_OBJECT_QUERY_TIMEOUT = 5e3;
|
|
146
|
-
var TABLE_ROWS_LIMIT = 10;
|
|
147
|
-
var looseFormatXml = (xml) => {
|
|
148
|
-
let currentIndent = 0;
|
|
149
|
-
return xml.split("\n").map((line) => {
|
|
150
|
-
if (line.match(RE_CLOSE_TAG_LINE)) {
|
|
151
|
-
currentIndent--;
|
|
152
|
-
}
|
|
153
|
-
const indent = currentIndent;
|
|
154
|
-
if (line.match(RE_OPEN_TAG_LINE)) {
|
|
155
|
-
currentIndent++;
|
|
156
|
-
}
|
|
157
|
-
return " ".repeat(indent * 2) + line.trimStart();
|
|
158
|
-
}).join("\n");
|
|
159
|
-
};
|
|
160
|
-
var RE_OPEN_TAG_LINE = /^[ ]*<[a-zA-Z0-9\-_]+>[ ]*$/;
|
|
161
|
-
var RE_CLOSE_TAG_LINE = /^[ ]*<\/[a-zA-Z0-9\-_]+>[ ]*$/;
|
|
162
|
-
|
|
163
|
-
// packages/plugins/experimental/plugin-automation/src/components/AssistantPanel/AssistantPanel.tsx
|
|
164
|
-
var PROPERTIES_ASSISTANT_KEY = "dxos.assistant.beta.properties";
|
|
165
|
-
var AssistantPanel = ({ subject, classNames }) => {
|
|
166
|
-
const { t } = useTranslation(AUTOMATION_PLUGIN);
|
|
167
|
-
const config = useConfig();
|
|
168
|
-
const client = useClient();
|
|
169
|
-
const aiClient = useRef();
|
|
170
|
-
const [contextSpaceId, setContextSpaceId] = useState();
|
|
171
|
-
const [threadId, setThreadId] = useState();
|
|
172
|
-
const [history, setHistory] = useState([]);
|
|
173
|
-
const [input, setInput] = useState("");
|
|
174
|
-
useEffect(() => {
|
|
175
|
-
if (!aiClient.current) {
|
|
176
|
-
const endpoint = config.values.runtime?.services?.ai?.server;
|
|
177
|
-
if (!endpoint) {
|
|
178
|
-
throw new Error("AI service endpoint is not configured");
|
|
179
|
-
}
|
|
180
|
-
aiClient.current = new AIServiceClientImpl({
|
|
181
|
-
endpoint
|
|
182
|
-
});
|
|
183
|
-
}
|
|
184
|
-
queueMicrotask(async () => {
|
|
185
|
-
const properties = client.spaces.default.properties;
|
|
186
|
-
properties[PROPERTIES_ASSISTANT_KEY] ??= {};
|
|
187
|
-
properties[PROPERTIES_ASSISTANT_KEY].contextSpaceId ??= SpaceId.random();
|
|
188
|
-
properties[PROPERTIES_ASSISTANT_KEY].threadId ??= ObjectId.random();
|
|
189
|
-
const contextSpaceId2 = properties[PROPERTIES_ASSISTANT_KEY].contextSpaceId;
|
|
190
|
-
const threadId2 = properties[PROPERTIES_ASSISTANT_KEY].threadId;
|
|
191
|
-
setContextSpaceId(contextSpaceId2);
|
|
192
|
-
setThreadId(threadId2);
|
|
193
|
-
const messages = await aiClient.current.getMessagesInThread(contextSpaceId2, threadId2);
|
|
194
|
-
setHistory(messages);
|
|
195
|
-
});
|
|
196
|
-
}, []);
|
|
197
|
-
const handleRequest = async (input2) => {
|
|
198
|
-
if (input2 === "") {
|
|
199
|
-
return;
|
|
200
|
-
}
|
|
201
|
-
setInput("");
|
|
202
|
-
const userMessage = {
|
|
203
|
-
id: ObjectId.random(),
|
|
204
|
-
spaceId: contextSpaceId,
|
|
205
|
-
threadId,
|
|
206
|
-
role: "user",
|
|
207
|
-
content: [
|
|
208
|
-
{
|
|
209
|
-
type: "text",
|
|
210
|
-
text: input2
|
|
211
|
-
}
|
|
212
|
-
]
|
|
213
|
-
};
|
|
214
|
-
await aiClient.current.insertMessages([
|
|
215
|
-
userMessage
|
|
216
|
-
]);
|
|
217
|
-
setHistory([
|
|
218
|
-
...history,
|
|
219
|
-
userMessage
|
|
220
|
-
]);
|
|
221
|
-
const generationStream = await aiClient.current.generate({
|
|
222
|
-
model: "@anthropic/claude-3-5-sonnet-20241022",
|
|
223
|
-
spaceId: contextSpaceId,
|
|
224
|
-
threadId,
|
|
225
|
-
tools: [],
|
|
226
|
-
systemPrompt: await getSystemPrompt()
|
|
227
|
-
});
|
|
228
|
-
const historyBefore = [
|
|
229
|
-
...history,
|
|
230
|
-
userMessage
|
|
231
|
-
];
|
|
232
|
-
for await (const _event of generationStream) {
|
|
233
|
-
setHistory([
|
|
234
|
-
...historyBefore,
|
|
235
|
-
...generationStream.accumulatedMessages
|
|
236
|
-
]);
|
|
237
|
-
}
|
|
238
|
-
await aiClient.current.insertMessages(await generationStream.complete());
|
|
239
|
-
};
|
|
240
|
-
const getSystemPrompt = async () => {
|
|
241
|
-
return createSystemInstructions({
|
|
242
|
-
subject
|
|
243
|
-
});
|
|
244
|
-
};
|
|
245
|
-
const clearThread = async () => {
|
|
246
|
-
const properties = client.spaces.default.properties;
|
|
247
|
-
properties[PROPERTIES_ASSISTANT_KEY] ??= {};
|
|
248
|
-
properties[PROPERTIES_ASSISTANT_KEY].threadId = ObjectId.random();
|
|
249
|
-
const threadId2 = properties[PROPERTIES_ASSISTANT_KEY].threadId;
|
|
250
|
-
setThreadId(threadId2);
|
|
251
|
-
const messages = await aiClient.current.getMessagesInThread(contextSpaceId, threadId2);
|
|
252
|
-
setHistory(messages);
|
|
253
|
-
};
|
|
254
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
255
|
-
className: mx("flex flex-col h-full overflow-hidden", classNames)
|
|
256
|
-
}, history.length > 0 && /* @__PURE__ */ React.createElement("div", {
|
|
257
|
-
className: "flex flex-col gap-6 h-full p-2 overflow-x-hidden overflow-y-auto"
|
|
258
|
-
}, history.map((message) => /* @__PURE__ */ React.createElement(MessageItem, {
|
|
259
|
-
key: message.id,
|
|
260
|
-
message
|
|
261
|
-
}))), /* @__PURE__ */ React.createElement(Toolbar.Root, {
|
|
262
|
-
classNames: "p-1"
|
|
263
|
-
}, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.TextInput, {
|
|
264
|
-
autoFocus: true,
|
|
265
|
-
placeholder: t("ask me anything"),
|
|
266
|
-
value: input,
|
|
267
|
-
onChange: (ev) => setInput(ev.target.value),
|
|
268
|
-
onKeyDown: (ev) => ev.key === "Enter" && handleRequest(input)
|
|
269
|
-
})), /* @__PURE__ */ React.createElement(ContextMenu.Root, null, /* @__PURE__ */ React.createElement(ContextMenu.Trigger, {
|
|
270
|
-
asChild: true
|
|
271
|
-
}, /* @__PURE__ */ React.createElement(Toolbar.Button, {
|
|
272
|
-
onClick: () => handleRequest(input)
|
|
273
|
-
}, /* @__PURE__ */ React.createElement(Icon, {
|
|
274
|
-
icon: "ph--play--regular",
|
|
275
|
-
size: 4
|
|
276
|
-
}))), /* @__PURE__ */ React.createElement(ContextMenu.Portal, null, /* @__PURE__ */ React.createElement(ContextMenu.Content, {
|
|
277
|
-
classNames: "z-[31]"
|
|
278
|
-
}, /* @__PURE__ */ React.createElement(ContextMenu.Viewport, null, /* @__PURE__ */ React.createElement(ContextMenu.Item, {
|
|
279
|
-
onClick: clearThread
|
|
280
|
-
}, "Clear thread"), /* @__PURE__ */ React.createElement(ContextMenu.Item, {
|
|
281
|
-
onClick: async () => console.log(await getSystemPrompt())
|
|
282
|
-
}, "Print instructions to console")))))));
|
|
283
|
-
};
|
|
284
|
-
var MessageItem = ({ classNames, message }) => {
|
|
285
|
-
const { id: _, role, content } = message;
|
|
286
|
-
const styleContainer = "flex flex-col overflow-x-hidden overflow-y-auto rounded-md gap-2 divide-y divide-separator";
|
|
287
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
288
|
-
className: mx("flex", role === "user" ? "ml-[1rem] justify-end" : "mr-[1rem]", classNames)
|
|
289
|
-
}, content.map((content2, i) => {
|
|
290
|
-
switch (content2.type) {
|
|
291
|
-
case "text": {
|
|
292
|
-
const { cot, message: message2 } = parseMessage(content2.text);
|
|
293
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
294
|
-
key: i,
|
|
295
|
-
role: "none",
|
|
296
|
-
className: mx(styleContainer, role === "user" ? "bg-primary-400 dark:bg-primary-600" : "bg-hoverSurface")
|
|
297
|
-
}, cot && /* @__PURE__ */ React.createElement("div", {
|
|
298
|
-
className: "p-2 whitespace-pre-wrap text-xs text-subdued"
|
|
299
|
-
}, cot), /* @__PURE__ */ React.createElement("div", {
|
|
300
|
-
className: "p-2 whitespace-pre-wrap"
|
|
301
|
-
}, message2));
|
|
302
|
-
}
|
|
303
|
-
case "tool_use": {
|
|
304
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
305
|
-
key: i,
|
|
306
|
-
className: mx(styleContainer, "text-xs")
|
|
307
|
-
}, /* @__PURE__ */ React.createElement("div", null, /* @__PURE__ */ React.createElement("span", {
|
|
308
|
-
className: "p-2 text-primary"
|
|
309
|
-
}, "Tool use"), ": ", content2.name, " ", content2.id), /* @__PURE__ */ React.createElement(SyntaxHighlighter, {
|
|
310
|
-
language: "json"
|
|
311
|
-
}, content2.inputJson));
|
|
312
|
-
}
|
|
313
|
-
case "tool_result": {
|
|
314
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
315
|
-
key: i,
|
|
316
|
-
className: mx(styleContainer, "text-xs", content2.isError && "text-error")
|
|
317
|
-
}, /* @__PURE__ */ React.createElement("div", null, /* @__PURE__ */ React.createElement("span", {
|
|
318
|
-
className: "p-2 text-primary"
|
|
319
|
-
}, "Tool result"), ": ", content2.toolUseId), /* @__PURE__ */ React.createElement(SyntaxHighlighter, {
|
|
320
|
-
language: "json"
|
|
321
|
-
}, content2.content));
|
|
322
|
-
}
|
|
323
|
-
}
|
|
324
|
-
return null;
|
|
325
|
-
}));
|
|
326
|
-
};
|
|
327
|
-
var parseMessage = (text) => {
|
|
328
|
-
const regex = /<cot>([\s\S]*?)<\/cot>\s*([\s\S]*)/;
|
|
329
|
-
const match = text.match(regex);
|
|
330
|
-
return {
|
|
331
|
-
cot: match?.[1].trim(),
|
|
332
|
-
message: match?.[2] ?? text ?? "\xD8"
|
|
333
|
-
};
|
|
334
|
-
};
|
|
335
|
-
|
|
336
|
-
// packages/plugins/experimental/plugin-automation/src/components/AssistantPanel/index.ts
|
|
337
|
-
var AssistantPanel_default = AssistantPanel;
|
|
338
|
-
export {
|
|
339
|
-
AssistantPanel_default as default
|
|
340
|
-
};
|
|
341
|
-
//# sourceMappingURL=AssistantPanel-622FK3DP.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/AssistantPanel/AssistantPanel.tsx", "../../../src/components/AssistantPanel/system-instructions.ts", "../../../src/components/AssistantPanel/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\n/* eslint-disable no-console */\n\nimport React, { useEffect, useRef, useState } from 'react';\n\nimport { type AIServiceClient, AIServiceClientImpl, ObjectId, type Message } from '@dxos/assistant';\nimport type { ReactiveEchoObject } from '@dxos/echo-db';\nimport { SpaceId } from '@dxos/keys';\nimport { useClient, useConfig } from '@dxos/react-client';\nimport { ContextMenu, type ThemedClassName } from '@dxos/react-ui';\nimport { Icon, Input, Toolbar, useTranslation } from '@dxos/react-ui';\nimport { SyntaxHighlighter } from '@dxos/react-ui-syntax-highlighter';\nimport { mx } from '@dxos/react-ui-theme';\n\nimport { createSystemInstructions } from './system-instructions';\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nconst PROPERTIES_ASSISTANT_KEY = 'dxos.assistant.beta.properties';\n\nexport type AssistantPanelProps = ThemedClassName<{\n subject?: ReactiveEchoObject<any>;\n}>;\n\nexport const AssistantPanel = ({ subject, classNames }: AssistantPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const config = useConfig();\n const client = useClient();\n const aiClient = useRef<AIServiceClient>();\n const [contextSpaceId, setContextSpaceId] = useState<SpaceId | undefined>();\n const [threadId, setThreadId] = useState<ObjectId | undefined>();\n const [history, setHistory] = useState<Message[]>([]);\n const [input, setInput] = useState('');\n\n useEffect(() => {\n if (!aiClient.current) {\n const endpoint = config.values.runtime?.services?.ai?.server;\n if (!endpoint) {\n throw new Error('AI service endpoint is not configured');\n }\n aiClient.current = new AIServiceClientImpl({\n endpoint,\n });\n }\n\n queueMicrotask(async () => {\n const properties = client.spaces.default.properties;\n\n properties[PROPERTIES_ASSISTANT_KEY] ??= {};\n properties[PROPERTIES_ASSISTANT_KEY].contextSpaceId ??= SpaceId.random();\n properties[PROPERTIES_ASSISTANT_KEY].threadId ??= ObjectId.random();\n\n const contextSpaceId = properties[PROPERTIES_ASSISTANT_KEY].contextSpaceId;\n const threadId = properties[PROPERTIES_ASSISTANT_KEY].threadId;\n\n setContextSpaceId(contextSpaceId);\n setThreadId(threadId);\n\n const messages = await aiClient.current!.getMessagesInThread(contextSpaceId, threadId);\n setHistory(messages);\n });\n }, []);\n\n const handleRequest = async (input: string) => {\n if (input === '') {\n return;\n }\n\n setInput('');\n\n // TODO(dmaretskyi): Can we call `create(Message, { ... })` here?\n const userMessage: Message = {\n id: ObjectId.random(),\n spaceId: contextSpaceId!,\n threadId: threadId!,\n role: 'user',\n content: [{ type: 'text', text: input }],\n };\n await aiClient.current!.insertMessages([userMessage]);\n setHistory([...history, userMessage]);\n\n const generationStream = await aiClient.current!.generate({\n model: '@anthropic/claude-3-5-sonnet-20241022',\n spaceId: contextSpaceId!,\n threadId: threadId!,\n tools: [],\n systemPrompt: await getSystemPrompt(),\n });\n\n const historyBefore = [...history, userMessage];\n for await (const _event of generationStream) {\n setHistory([...historyBefore, ...generationStream.accumulatedMessages]);\n }\n\n await aiClient.current!.insertMessages(await generationStream.complete());\n };\n\n const getSystemPrompt = async () => {\n return createSystemInstructions({ subject });\n };\n\n const clearThread = async () => {\n const properties = client.spaces.default.properties;\n\n properties[PROPERTIES_ASSISTANT_KEY] ??= {};\n // properties[PROPERTIES_ASSISTANT_KEY].contextSpaceId ??= SpaceId.random();\n properties[PROPERTIES_ASSISTANT_KEY].threadId = ObjectId.random();\n\n // const contextSpaceId = properties[PROPERTIES_ASSISTANT_KEY].contextSpaceId;\n const threadId = properties[PROPERTIES_ASSISTANT_KEY].threadId;\n\n // setContextSpaceId(contextSpaceId);\n setThreadId(threadId);\n\n const messages = await aiClient.current!.getMessagesInThread(contextSpaceId!, threadId);\n setHistory(messages);\n };\n\n // TODO(burdon): Factor out with script plugin.\n return (\n <div className={mx('flex flex-col h-full overflow-hidden', classNames)}>\n {history.length > 0 && (\n <div className='flex flex-col gap-6 h-full p-2 overflow-x-hidden overflow-y-auto'>\n {history.map((message) => (\n <MessageItem key={message.id} message={message} />\n ))}\n </div>\n )}\n\n <Toolbar.Root classNames='p-1'>\n <Input.Root>\n <Input.TextInput\n autoFocus\n placeholder={t('ask me anything')}\n value={input}\n onChange={(ev) => setInput(ev.target.value)}\n onKeyDown={(ev) => ev.key === 'Enter' && handleRequest(input)}\n />\n </Input.Root>\n <ContextMenu.Root>\n <ContextMenu.Trigger asChild>\n <Toolbar.Button onClick={() => handleRequest(input)}>\n <Icon icon='ph--play--regular' size={4} />\n </Toolbar.Button>\n </ContextMenu.Trigger>\n <ContextMenu.Portal>\n <ContextMenu.Content classNames='z-[31]'>\n <ContextMenu.Viewport>\n <ContextMenu.Item onClick={clearThread}>Clear thread</ContextMenu.Item>\n <ContextMenu.Item onClick={async () => console.log(await getSystemPrompt())}>\n Print instructions to console\n </ContextMenu.Item>\n </ContextMenu.Viewport>\n </ContextMenu.Content>\n </ContextMenu.Portal>\n </ContextMenu.Root>\n\n {/* <Toolbar.Button onClick={() => (state ? handleStop() : handleClear())}>\n <Icon icon={state ? 'ph--stop--regular' : 'ph--trash--regular'} size={4} />\n </Toolbar.Button> */}\n </Toolbar.Root>\n </div>\n );\n};\n\nconst MessageItem = ({ classNames, message }: ThemedClassName<{ message: Message }>) => {\n const { id: _, role, content } = message;\n const styleContainer = 'flex flex-col overflow-x-hidden overflow-y-auto rounded-md gap-2 divide-y divide-separator';\n\n return (\n <div className={mx('flex', role === 'user' ? 'ml-[1rem] justify-end' : 'mr-[1rem]', classNames)}>\n {content.map((content, i) => {\n switch (content.type) {\n case 'text': {\n const { cot, message } = parseMessage(content.text);\n return (\n <div\n key={i}\n role='none'\n className={mx(\n styleContainer,\n role === 'user' ? 'bg-primary-400 dark:bg-primary-600' : 'bg-hoverSurface',\n )}\n >\n {cot && <div className='p-2 whitespace-pre-wrap text-xs text-subdued'>{cot}</div>}\n <div className='p-2 whitespace-pre-wrap'>{message}</div>\n </div>\n );\n }\n\n case 'tool_use': {\n return (\n <div key={i} className={mx(styleContainer, 'text-xs')}>\n <div>\n <span className='p-2 text-primary'>Tool use</span>: {content.name} {content.id}\n </div>\n <SyntaxHighlighter language='json'>{content.inputJson}</SyntaxHighlighter>\n </div>\n );\n }\n\n case 'tool_result': {\n return (\n <div key={i} className={mx(styleContainer, 'text-xs', content.isError && 'text-error')}>\n <div>\n <span className='p-2 text-primary'>Tool result</span>: {content.toolUseId}\n </div>\n <SyntaxHighlighter language='json'>{content.content}</SyntaxHighlighter>\n </div>\n );\n }\n }\n\n return null;\n })}\n </div>\n );\n};\n\n// TODO(burdon): Move to server-side parsing.\nconst parseMessage = (text: string): { cot?: string; message: string } => {\n const regex = /<cot>([\\s\\S]*?)<\\/cot>\\s*([\\s\\S]*)/;\n const match = text.match(regex);\n return {\n cot: match?.[1].trim(),\n message: match?.[2] ?? text ?? '\\u00D8',\n };\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { asyncTimeout } from '@dxos/async';\nimport type { ReactiveEchoObject } from '@dxos/echo-db';\nimport { getTypename } from '@dxos/echo-schema';\nimport { log } from '@dxos/log';\nimport { Filter, getSpace, ResultFormat } from '@dxos/react-client/echo';\n\n// TODO(burdon): Move into assistant-protocol.\nexport type ThreadContext = {\n subject?: ReactiveEchoObject<any>;\n};\n\nexport const createSystemInstructions = async (context: ThreadContext): Promise<string> => {\n let instructions = `\n <instructions>\n Before replying always think step-by-step on how to proceed.\n Print your thoughts inside <cot> tags.\n\n <example>\n <cot>To answer the question I need to ...</cot>\n </example>\n </instructions>\n\n <current_time>${new Date().toLocaleString()}</current_time>\n `;\n\n if (context.subject) {\n instructions += `\n <user_attention>\n The user is currently interacting with an object in Composer application:\n\n ${await formatContextObject(context.subject)}\n </user_attention>\n `;\n }\n\n return looseFormatXml(instructions);\n};\n\nconst formatContextObject = async (object: ReactiveEchoObject<any>): Promise<string> => {\n let data;\n try {\n data = await asyncTimeout(preprocessContextObject(object), CONTEXT_OBJECT_QUERY_TIMEOUT);\n } catch (err: any) {\n log.error('Failed to preprocess context object:', { err });\n data = object;\n }\n\n if (typeof data === 'string') {\n return data;\n } else {\n return `\n <object>\n <type>${getTypename(object)}</type>\n <id>${object.id}</id>\n ${formatObjectAsXMLTags(data)}\n </object>\n `;\n }\n};\n\nconst preprocessContextObject = async (object: ReactiveEchoObject<any>): Promise<Record<string, any> | string> => {\n const space = getSpace(object);\n if (!space) {\n return { ...object };\n }\n\n // TODO(dmaretskyi): Serialize based on schema annotations.\n switch (getTypename(object)) {\n // TODO(dmaretskyi): Reference types somehow without plugin-automation depending on other plugins.\n case 'dxos.org/type/Document': {\n const data = space.db\n .query({ id: object.id }, { format: ResultFormat.Plain, include: { content: true } })\n .first() ?? { content: { content: '' } };\n\n return {\n ...data,\n threads: undefined,\n };\n }\n\n case 'dxos.org/type/Table': {\n // TODO(dmaretskyi): Load references.\n const schema = object.view ? space?.db.schemaRegistry.getSchema(object.view.query.typename) : undefined;\n const { objects: rows } =\n (schema &&\n (await space.db\n .query(Filter.schema(schema), { format: ResultFormat.Plain, limit: TABLE_ROWS_LIMIT })\n .run())) ??\n {};\n\n // TODO(dmaretskyi): Format table schema.\n return `\n <object>\n <id>${object.id}</id>\n <type>${getTypename(object)}</type>\n ${formatObjectAsXMLTags(object)}\n\n <rows>\n <!-- Limited to first ${TABLE_ROWS_LIMIT} rows. -->\n ${rows\n ?.map(\n (row: any) => `<row>\n ${formatObjectAsXMLTags(row)}\n </row>`,\n )\n .join('\\n')}\n </rows>\n\n `;\n }\n\n default:\n return { ...object };\n }\n};\n\nconst formatObjectAsXMLTags = (object: any, depth = 1): string => {\n return Object.entries(object)\n .filter(([key, value]) => ['string', 'number', 'boolean', 'object'].includes(typeof value))\n .map(([key, value]) => {\n if (typeof value === 'object' && value !== null) {\n if (depth === 0) {\n return '';\n } else {\n return `<${key}>\n ${formatObjectAsXMLTags(value, depth - 1)}\n </${key}>`;\n }\n }\n\n return `<${key}>${value}</${key}>`;\n })\n .join('\\n');\n};\n\nconst CONTEXT_OBJECT_QUERY_TIMEOUT = 5_000;\n\nconst TABLE_ROWS_LIMIT = 10;\n\n/**\n * Formats XML indentation for instructions so they are easier to read during debugging.\n */\nconst looseFormatXml = (xml: string): string => {\n let currentIndent = 0;\n\n return xml\n .split('\\n')\n .map((line) => {\n if (line.match(RE_CLOSE_TAG_LINE)) {\n currentIndent--;\n }\n const indent = currentIndent;\n if (line.match(RE_OPEN_TAG_LINE)) {\n currentIndent++;\n }\n return ' '.repeat(indent * 2) + line.trimStart();\n })\n .join('\\n');\n};\n\nconst RE_OPEN_TAG_LINE = /^[ ]*<[a-zA-Z0-9\\-_]+>[ ]*$/;\nconst RE_CLOSE_TAG_LINE = /^[ ]*<\\/[a-zA-Z0-9\\-_]+>[ ]*$/;\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { AssistantPanel } from './AssistantPanel';\n\nexport default AssistantPanel;\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["React", "useEffect", "useRef", "useState", "AIServiceClientImpl", "ObjectId", "SpaceId", "useClient", "useConfig", "ContextMenu", "Icon", "Input", "Toolbar", "useTranslation", "SyntaxHighlighter", "mx", "asyncTimeout", "getTypename", "log", "Filter", "getSpace", "ResultFormat", "createSystemInstructions", "context", "instructions", "Date", "toLocaleString", "subject", "formatContextObject", "looseFormatXml", "object", "data", "preprocessContextObject", "CONTEXT_OBJECT_QUERY_TIMEOUT", "err", "error", "id", "formatObjectAsXMLTags", "space", "db", "query", "format", "Plain", "include", "content", "first", "threads", "undefined", "schema", "view", "schemaRegistry", "getSchema", "typename", "objects", "rows", "limit", "TABLE_ROWS_LIMIT", "run", "map", "row", "join", "depth", "Object", "entries", "filter", "key", "value", "includes", "xml", "currentIndent", "split", "line", "match", "RE_CLOSE_TAG_LINE", "indent", "RE_OPEN_TAG_LINE", "repeat", "trimStart", "PROPERTIES_ASSISTANT_KEY", "AssistantPanel", "subject", "classNames", "t", "useTranslation", "AUTOMATION_PLUGIN", "config", "useConfig", "client", "useClient", "aiClient", "useRef", "contextSpaceId", "setContextSpaceId", "useState", "threadId", "setThreadId", "history", "setHistory", "input", "setInput", "useEffect", "current", "endpoint", "values", "runtime", "services", "ai", "server", "Error", "AIServiceClientImpl", "queueMicrotask", "properties", "spaces", "default", "SpaceId", "random", "ObjectId", "messages", "getMessagesInThread", "handleRequest", "userMessage", "id", "spaceId", "role", "content", "type", "text", "insertMessages", "generationStream", "generate", "model", "tools", "systemPrompt", "getSystemPrompt", "historyBefore", "_event", "accumulatedMessages", "complete", "createSystemInstructions", "clearThread", "div", "className", "mx", "length", "map", "message", "MessageItem", "key", "Toolbar", "Root", "Input", "TextInput", "autoFocus", "placeholder", "value", "onChange", "ev", "target", "onKeyDown", "ContextMenu", "Trigger", "asChild", "Button", "onClick", "Icon", "icon", "size", "Portal", "Content", "Viewport", "Item", "console", "log", "_", "styleContainer", "i", "cot", "parseMessage", "span", "name", "SyntaxHighlighter", "language", "inputJson", "isError", "toolUseId", "regex", "match", "trim", "AssistantPanel"]
|
|
7
|
-
}
|
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
AUTOMATION_PLUGIN
|
|
3
|
-
} from "./chunk-X5KMOH3I.mjs";
|
|
4
|
-
|
|
5
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
|
|
6
|
-
import React2, { useState } from "react";
|
|
7
|
-
import { S } from "@dxos/echo-schema";
|
|
8
|
-
import { FunctionTriggerSchema as FunctionTriggerSchema2, FunctionTrigger } from "@dxos/functions";
|
|
9
|
-
import { create, Filter as Filter2, useQuery as useQuery2 } from "@dxos/react-client/echo";
|
|
10
|
-
import { IconButton, Input, useTranslation as useTranslation2 } from "@dxos/react-ui";
|
|
11
|
-
import { List } from "@dxos/react-ui-list";
|
|
12
|
-
import { ghostHover, mx } from "@dxos/react-ui-theme";
|
|
13
|
-
|
|
14
|
-
// packages/plugins/experimental/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
|
|
15
|
-
import React from "react";
|
|
16
|
-
import { FunctionTriggerSchema, TriggerKind } from "@dxos/functions";
|
|
17
|
-
import { FunctionType } from "@dxos/plugin-script/types";
|
|
18
|
-
import { Filter, useQuery } from "@dxos/react-client/echo";
|
|
19
|
-
import { useTranslation } from "@dxos/react-ui";
|
|
20
|
-
import { Form, SelectInput } from "@dxos/react-ui-form";
|
|
21
|
-
var TriggerEditor = ({ space, trigger, onSave, onCancel }) => {
|
|
22
|
-
const { t } = useTranslation(AUTOMATION_PLUGIN);
|
|
23
|
-
const functions = useQuery(space, Filter.schema(FunctionType));
|
|
24
|
-
const handleSave = (values) => {
|
|
25
|
-
onSave?.(values);
|
|
26
|
-
};
|
|
27
|
-
return /* @__PURE__ */ React.createElement(Form, {
|
|
28
|
-
schema: FunctionTriggerSchema,
|
|
29
|
-
values: trigger,
|
|
30
|
-
filter: (props) => props.filter((p) => p.name !== "meta"),
|
|
31
|
-
onSave: handleSave,
|
|
32
|
-
onCancel,
|
|
33
|
-
Custom: {
|
|
34
|
-
["function"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
|
|
35
|
-
...props,
|
|
36
|
-
options: functions.map(({ name }) => ({
|
|
37
|
-
value: name,
|
|
38
|
-
label: name
|
|
39
|
-
}))
|
|
40
|
-
}),
|
|
41
|
-
["spec.type"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
|
|
42
|
-
...props,
|
|
43
|
-
options: Object.values(TriggerKind).map((kind) => ({
|
|
44
|
-
value: kind,
|
|
45
|
-
label: t(`trigger type ${kind}`)
|
|
46
|
-
}))
|
|
47
|
-
})
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
|
|
53
|
-
var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
|
|
54
|
-
var AutomationPanel = ({ space }) => {
|
|
55
|
-
const { t } = useTranslation2(AUTOMATION_PLUGIN);
|
|
56
|
-
const triggers = useQuery2(space, Filter2.schema(FunctionTrigger));
|
|
57
|
-
const [trigger, setTrigger] = useState();
|
|
58
|
-
const [selected, setSelected] = useState();
|
|
59
|
-
const handleSelect = (trigger2) => {
|
|
60
|
-
const { id: _, ...values } = trigger2;
|
|
61
|
-
setTrigger(values);
|
|
62
|
-
setSelected(trigger2);
|
|
63
|
-
};
|
|
64
|
-
const handleAdd = () => {
|
|
65
|
-
setTrigger(create(FunctionTriggerSchema2, {}));
|
|
66
|
-
setSelected(void 0);
|
|
67
|
-
};
|
|
68
|
-
const handleDelete = (trigger2) => {
|
|
69
|
-
space.db.remove(trigger2);
|
|
70
|
-
setTrigger(void 0);
|
|
71
|
-
setSelected(void 0);
|
|
72
|
-
};
|
|
73
|
-
const handleSave = (trigger2) => {
|
|
74
|
-
if (selected) {
|
|
75
|
-
Object.assign(selected, trigger2);
|
|
76
|
-
} else {
|
|
77
|
-
space.db.add(create(FunctionTrigger, trigger2));
|
|
78
|
-
}
|
|
79
|
-
setTrigger(void 0);
|
|
80
|
-
setSelected(void 0);
|
|
81
|
-
};
|
|
82
|
-
const handleCancel = () => {
|
|
83
|
-
setTrigger(void 0);
|
|
84
|
-
};
|
|
85
|
-
return /* @__PURE__ */ React2.createElement("div", {
|
|
86
|
-
className: "flex flex-col w-full divide-y divide-separator overflow-y-auto"
|
|
87
|
-
}, /* @__PURE__ */ React2.createElement(List.Root, {
|
|
88
|
-
items: triggers,
|
|
89
|
-
isItem: S.is(FunctionTrigger),
|
|
90
|
-
getId: (field) => field.id
|
|
91
|
-
}, ({ items: triggers2 }) => /* @__PURE__ */ React2.createElement("div", {
|
|
92
|
-
role: "list",
|
|
93
|
-
className: "flex flex-col w-full"
|
|
94
|
-
}, triggers2?.map((trigger2) => /* @__PURE__ */ React2.createElement(List.Item, {
|
|
95
|
-
key: trigger2.id,
|
|
96
|
-
item: trigger2,
|
|
97
|
-
classNames: mx(grid, ghostHover, "items-center")
|
|
98
|
-
}, /* @__PURE__ */ React2.createElement(Input.Root, null, /* @__PURE__ */ React2.createElement(Input.Switch, {
|
|
99
|
-
checked: trigger2.enabled,
|
|
100
|
-
onCheckedChange: (checked) => trigger2.enabled = checked
|
|
101
|
-
})), /* @__PURE__ */ React2.createElement(List.ItemTitle, {
|
|
102
|
-
classNames: "px-2 cursor-pointer",
|
|
103
|
-
onClick: () => handleSelect(trigger2)
|
|
104
|
-
}, trigger2.function), /* @__PURE__ */ React2.createElement(List.ItemDeleteButton, {
|
|
105
|
-
onClick: () => handleDelete(trigger2)
|
|
106
|
-
}))))), trigger && /* @__PURE__ */ React2.createElement(TriggerEditor, {
|
|
107
|
-
space,
|
|
108
|
-
trigger,
|
|
109
|
-
onSave: handleSave,
|
|
110
|
-
onCancel: handleCancel
|
|
111
|
-
}), !trigger && /* @__PURE__ */ React2.createElement("div", {
|
|
112
|
-
className: "flex p-2 justify-center"
|
|
113
|
-
}, /* @__PURE__ */ React2.createElement(IconButton, {
|
|
114
|
-
icon: "ph--plus--regular",
|
|
115
|
-
label: t("new trigger"),
|
|
116
|
-
onClick: handleAdd
|
|
117
|
-
})));
|
|
118
|
-
};
|
|
119
|
-
|
|
120
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/index.ts
|
|
121
|
-
var AutomationPanel_default = AutomationPanel;
|
|
122
|
-
export {
|
|
123
|
-
AutomationPanel_default as default
|
|
124
|
-
};
|
|
125
|
-
//# sourceMappingURL=AutomationPanel-PVI2EJNE.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 { type ReactiveObject, S } from '@dxos/echo-schema';\nimport { FunctionTriggerSchema, FunctionTrigger, type FunctionTriggerType } from '@dxos/functions';\nimport { create, Filter, useQuery, type Space } from '@dxos/react-client/echo';\nimport { 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 }: AutomationPanelProps) => {\n const { t } = useTranslation(AUTOMATION_PLUGIN);\n const triggers = useQuery(space, Filter.schema(FunctionTrigger));\n const [trigger, setTrigger] = useState<FunctionTriggerType>();\n const [selected, setSelected] = useState<FunctionTrigger>();\n\n const handleSelect = (trigger: FunctionTrigger) => {\n const { id: _, ...values } = trigger;\n setTrigger(values);\n setSelected(trigger);\n };\n\n const handleAdd = () => {\n setTrigger(create(FunctionTriggerSchema, {}));\n setSelected(undefined);\n };\n\n const handleDelete = (trigger: FunctionTrigger) => {\n space.db.remove(trigger);\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleSave: TriggerEditorProps['onSave'] = (trigger) => {\n if (selected) {\n Object.assign(selected, trigger);\n } else {\n space.db.add(create(FunctionTrigger, trigger));\n }\n\n setTrigger(undefined);\n setSelected(undefined);\n };\n\n const handleCancel: TriggerEditorProps['onCancel'] = () => {\n setTrigger(undefined);\n };\n\n return (\n <div className='flex flex-col w-full divide-y divide-separator overflow-y-auto'>\n <List.Root<FunctionTrigger> items={triggers} isItem={S.is(FunctionTrigger)} getId={(field) => field.id}>\n {({ items: triggers }) => (\n <div role='list' className='flex flex-col w-full'>\n {triggers?.map((trigger) => (\n <List.Item<FunctionTrigger>\n key={trigger.id}\n item={trigger}\n classNames={mx(grid, ghostHover, 'items-center')}\n >\n <Input.Root>\n <Input.Switch checked={trigger.enabled} onCheckedChange={(checked) => (trigger.enabled = checked)} />\n </Input.Root>\n <List.ItemTitle classNames='px-2 cursor-pointer' onClick={() => handleSelect(trigger)}>\n {trigger.function}\n </List.ItemTitle>\n <List.ItemDeleteButton onClick={() => handleDelete(trigger)} />\n </List.Item>\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", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { FunctionTriggerSchema, type FunctionTriggerType, type FunctionTrigger, TriggerKind } from '@dxos/functions';\nimport { FunctionType } from '@dxos/plugin-script/types';\nimport { Filter, useQuery, type Space } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { Form, SelectInput } from '@dxos/react-ui-form';\n\nimport { AUTOMATION_PLUGIN } from '../../meta';\n\nexport type TriggerEditorProps = {\n space: Space;\n trigger: Omit<FunctionTrigger, 'id'>;\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 const functions = useQuery(space, Filter.schema(FunctionType));\n\n const handleSave = (values: FunctionTriggerType) => {\n onSave?.(values);\n };\n\n return (\n <Form<FunctionTriggerType>\n schema={FunctionTriggerSchema}\n values={trigger}\n filter={(props) => props.filter((p) => p.name !== 'meta')}\n onSave={handleSave}\n onCancel={onCancel}\n Custom={{\n ['function' satisfies keyof FunctionTriggerType]: (props) => (\n <SelectInput<FunctionTriggerType>\n {...props}\n options={functions.map(({ name }) => ({\n value: name,\n label: name,\n }))}\n />\n ),\n ['spec.type' as const]: (props) => (\n <SelectInput<FunctionTriggerType>\n {...props}\n options={Object.values(TriggerKind).map((kind) => ({\n value: kind,\n label: t(`trigger type ${kind}`),\n }))}\n />\n ),\n }}\n />\n );\n};\n", "//\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", "FunctionTriggerSchema", "FunctionTrigger", "create", "Filter", "useQuery", "IconButton", "Input", "useTranslation", "List", "ghostHover", "mx", "React", "FunctionTriggerSchema", "TriggerKind", "FunctionType", "Filter", "useQuery", "useTranslation", "Form", "SelectInput", "TriggerEditor", "space", "trigger", "onSave", "onCancel", "t", "useTranslation", "AUTOMATION_PLUGIN", "functions", "useQuery", "Filter", "schema", "FunctionType", "handleSave", "values", "Form", "FunctionTriggerSchema", "filter", "props", "p", "name", "Custom", "SelectInput", "options", "map", "value", "label", "Object", "TriggerKind", "kind", "grid", "AutomationPanel", "space", "t", "useTranslation", "AUTOMATION_PLUGIN", "triggers", "useQuery", "Filter", "schema", "FunctionTrigger", "trigger", "setTrigger", "useState", "selected", "setSelected", "handleSelect", "id", "_", "values", "handleAdd", "create", "FunctionTriggerSchema", "undefined", "handleDelete", "db", "remove", "handleSave", "Object", "assign", "add", "handleCancel", "React", "div", "className", "List", "Root", "items", "isItem", "S", "is", "getId", "field", "role", "map", "Item", "key", "item", "classNames", "mx", "ghostHover", "Input", "Switch", "checked", "enabled", "onCheckedChange", "ItemTitle", "onClick", "function", "ItemDeleteButton", "TriggerEditor", "onSave", "onCancel", "IconButton", "icon", "label", "AutomationPanel"]
|
|
7
|
-
}
|