@dxos/plugin-automation 0.7.5-main.9d2a38b → 0.7.5-main.e94eead
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/AutomationPanel-ITYXSN5Z.mjs +132 -0
- package/dist/lib/browser/AutomationPanel-ITYXSN5Z.mjs.map +7 -0
- package/dist/lib/browser/{chunk-HKX3D3ZP.mjs → chunk-OFDNNRLE.mjs} +4 -7
- package/dist/lib/browser/{chunk-HKX3D3ZP.mjs.map → chunk-OFDNNRLE.mjs.map} +3 -3
- package/dist/lib/browser/chunk-U7QLNY2S.mjs +8 -0
- package/dist/lib/browser/chunk-U7QLNY2S.mjs.map +7 -0
- package/dist/lib/browser/chunk-WY2C7JY4.mjs +119 -0
- package/dist/lib/browser/chunk-WY2C7JY4.mjs.map +7 -0
- package/dist/lib/browser/complementary-panel-4CPOJL4Y.mjs +56 -0
- package/dist/lib/browser/complementary-panel-4CPOJL4Y.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +21 -313
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-LL72F3F4.mjs → react-surface-SAPMN4PF.mjs} +4 -11
- package/dist/lib/browser/react-surface-SAPMN4PF.mjs.map +7 -0
- package/dist/lib/node/{AutomationPanel-PPODB5XA.cjs → AutomationPanel-X33HHDMQ.cjs} +19 -117
- package/dist/lib/node/AutomationPanel-X33HHDMQ.cjs.map +7 -0
- package/dist/lib/node/chunk-7Q5SNGCL.cjs +148 -0
- package/dist/lib/node/chunk-7Q5SNGCL.cjs.map +7 -0
- package/dist/lib/node/{chunk-25AQIF3L.cjs → chunk-CB5OB6JH.cjs} +5 -8
- package/dist/lib/node/chunk-CB5OB6JH.cjs.map +7 -0
- package/dist/lib/node/{chunk-5VF5JKUN.cjs → chunk-ORMEYEBE.cjs} +7 -10
- package/dist/lib/node/{chunk-5VF5JKUN.cjs.map → chunk-ORMEYEBE.cjs.map} +3 -3
- package/dist/lib/node/complementary-panel-ZYJJ42ZU.cjs +72 -0
- package/dist/lib/node/complementary-panel-ZYJJ42ZU.cjs.map +7 -0
- package/dist/lib/node/index.cjs +26 -318
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/{react-surface-DVAU4MGD.cjs → react-surface-2WRVAPGR.cjs} +9 -15
- package/dist/lib/node/react-surface-2WRVAPGR.cjs.map +7 -0
- package/dist/lib/node-esm/AutomationPanel-HY3GB4BT.mjs +133 -0
- package/dist/lib/node-esm/AutomationPanel-HY3GB4BT.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-X3LPRWIL.mjs → chunk-6MUUH67V.mjs} +4 -7
- package/dist/lib/node-esm/{chunk-X3LPRWIL.mjs.map → chunk-6MUUH67V.mjs.map} +3 -3
- package/dist/lib/node-esm/{chunk-XW7TEQA3.mjs → chunk-R3P2WPBQ.mjs} +2 -4
- package/dist/lib/node-esm/chunk-R3P2WPBQ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-UDD2VA6G.mjs +120 -0
- package/dist/lib/node-esm/chunk-UDD2VA6G.mjs.map +7 -0
- package/dist/lib/node-esm/complementary-panel-S42RIIAY.mjs +57 -0
- package/dist/lib/node-esm/complementary-panel-S42RIIAY.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +21 -313
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-4BED2PZ4.mjs → react-surface-QWLPOYXO.mjs} +4 -11
- package/dist/lib/node-esm/react-surface-QWLPOYXO.mjs.map +7 -0
- package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/complementary-panel.d.ts +4 -0
- package/dist/types/src/capabilities/complementary-panel.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +2 -178
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -2
- package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
- package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
- package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -2
- 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 +2 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -3
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +0 -1
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/testing/index.d.ts +1 -1
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/{testing.d.ts → test-functions.d.ts} +1 -1
- package/dist/types/src/testing/test-functions.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +2 -20
- package/dist/types/src/translations.d.ts.map +1 -1
- package/package.json +23 -57
- package/src/AutomationPlugin.tsx +10 -42
- package/src/capabilities/complementary-panel.ts +56 -0
- package/src/capabilities/index.ts +1 -1
- package/src/capabilities/react-surface.tsx +1 -6
- package/src/components/AutomationPanel/AutomationPanel.stories.tsx +1 -2
- package/src/components/AutomationPanel/AutomationPanel.tsx +56 -49
- package/src/components/TriggerEditor/TriggerEditor.stories.tsx +1 -2
- package/src/components/TriggerEditor/TriggerEditor.tsx +25 -18
- package/src/components/index.ts +2 -1
- package/src/index.ts +2 -3
- package/src/meta.ts +3 -3
- package/src/testing/index.ts +1 -1
- package/src/testing/{testing.ts → test-functions.ts} +2 -2
- package/src/translations.ts +2 -23
- package/dist/lib/browser/AssistantPanel-N276BTPV.mjs +0 -339
- package/dist/lib/browser/AssistantPanel-N276BTPV.mjs.map +0 -7
- package/dist/lib/browser/AutomationPanel-IHZ4JKVS.mjs +0 -232
- package/dist/lib/browser/AutomationPanel-IHZ4JKVS.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-IJTTULDP.mjs +0 -131
- package/dist/lib/browser/app-graph-builder-IJTTULDP.mjs.map +0 -7
- package/dist/lib/browser/chunk-4AIMDHKY.mjs +0 -10
- package/dist/lib/browser/chunk-4AIMDHKY.mjs.map +0 -7
- package/dist/lib/browser/chunk-DL6LB2NI.mjs +0 -43
- package/dist/lib/browser/chunk-DL6LB2NI.mjs.map +0 -7
- package/dist/lib/browser/react-surface-LL72F3F4.mjs.map +0 -7
- package/dist/lib/browser/types/index.mjs +0 -13
- package/dist/lib/browser/types/index.mjs.map +0 -7
- package/dist/lib/node/AssistantPanel-Z4GVHUF3.cjs +0 -359
- package/dist/lib/node/AssistantPanel-Z4GVHUF3.cjs.map +0 -7
- package/dist/lib/node/AutomationPanel-PPODB5XA.cjs.map +0 -7
- package/dist/lib/node/app-graph-builder-MF5M4QRS.cjs +0 -147
- package/dist/lib/node/app-graph-builder-MF5M4QRS.cjs.map +0 -7
- package/dist/lib/node/chunk-25AQIF3L.cjs.map +0 -7
- package/dist/lib/node/chunk-JNDMZQH7.cjs +0 -68
- package/dist/lib/node/chunk-JNDMZQH7.cjs.map +0 -7
- package/dist/lib/node/react-surface-DVAU4MGD.cjs.map +0 -7
- package/dist/lib/node/types/index.cjs +0 -35
- package/dist/lib/node/types/index.cjs.map +0 -7
- package/dist/lib/node-esm/AssistantPanel-DDCQHBJX.mjs +0 -340
- package/dist/lib/node-esm/AssistantPanel-DDCQHBJX.mjs.map +0 -7
- package/dist/lib/node-esm/AutomationPanel-R3D6CRF5.mjs +0 -233
- package/dist/lib/node-esm/AutomationPanel-R3D6CRF5.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-5N7OK23B.mjs +0 -132
- package/dist/lib/node-esm/app-graph-builder-5N7OK23B.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GIAYUM5I.mjs +0 -45
- package/dist/lib/node-esm/chunk-GIAYUM5I.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-XW7TEQA3.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-4BED2PZ4.mjs.map +0 -7
- package/dist/lib/node-esm/types/index.mjs +0 -14
- package/dist/lib/node-esm/types/index.mjs.map +0 -7
- package/dist/types/src/capabilities/app-graph-builder.d.ts +0 -180
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +0 -1
- 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/PromptEditor/PromptEditor.d.ts +0 -10
- package/dist/types/src/components/PromptEditor/PromptEditor.d.ts.map +0 -1
- package/dist/types/src/components/PromptEditor/PromptEditor.stories.d.ts +0 -6
- package/dist/types/src/components/PromptEditor/PromptEditor.stories.d.ts.map +0 -1
- package/dist/types/src/components/PromptEditor/index.d.ts +0 -2
- package/dist/types/src/components/PromptEditor/index.d.ts.map +0 -1
- package/dist/types/src/components/PromptEditor/prompt-extension.d.ts +0 -4
- package/dist/types/src/components/PromptEditor/prompt-extension.d.ts.map +0 -1
- package/dist/types/src/components/PromptEditor/types.d.ts +0 -18
- package/dist/types/src/components/PromptEditor/types.d.ts.map +0 -1
- package/dist/types/src/hooks/email.d.ts +0 -4
- package/dist/types/src/hooks/email.d.ts.map +0 -1
- package/dist/types/src/hooks/index.d.ts +0 -2
- package/dist/types/src/hooks/index.d.ts.map +0 -1
- package/dist/types/src/hooks/invocation-handler.d.ts +0 -5
- package/dist/types/src/hooks/invocation-handler.d.ts.map +0 -1
- package/dist/types/src/hooks/useLocalTriggerManager.d.ts +0 -3
- package/dist/types/src/hooks/useLocalTriggerManager.d.ts.map +0 -1
- package/dist/types/src/presets.d.ts +0 -9
- package/dist/types/src/presets.d.ts.map +0 -1
- package/dist/types/src/testing/testing.d.ts.map +0 -1
- package/dist/types/src/types/index.d.ts +0 -2
- package/dist/types/src/types/index.d.ts.map +0 -1
- package/dist/types/src/types/schema.d.ts +0 -63
- package/dist/types/src/types/schema.d.ts.map +0 -1
- package/src/capabilities/app-graph-builder.ts +0 -127
- 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/PromptEditor/PromptEditor.stories.tsx +0 -64
- package/src/components/PromptEditor/PromptEditor.tsx +0 -222
- package/src/components/PromptEditor/index.ts +0 -5
- package/src/components/PromptEditor/prompt-extension.ts +0 -43
- package/src/components/PromptEditor/types.tsx +0 -28
- package/src/hooks/email.ts +0 -49
- package/src/hooks/index.ts +0 -5
- package/src/hooks/invocation-handler.ts +0 -109
- package/src/hooks/useLocalTriggerManager.ts +0 -82
- package/src/presets.ts +0 -248
- package/src/types/index.ts +0 -5
- package/src/types/schema.ts +0 -38
|
@@ -1,339 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
AUTOMATION_PLUGIN
|
|
3
|
-
} from "./chunk-HKX3D3ZP.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.type) : 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, null, /* @__PURE__ */ React.createElement(ContextMenu.Viewport, null, /* @__PURE__ */ React.createElement(ContextMenu.Item, {
|
|
277
|
-
onClick: clearThread
|
|
278
|
-
}, "Clear thread"), /* @__PURE__ */ React.createElement(ContextMenu.Item, {
|
|
279
|
-
onClick: async () => console.log(await getSystemPrompt())
|
|
280
|
-
}, "Print instructions to console")))))));
|
|
281
|
-
};
|
|
282
|
-
var MessageItem = ({ classNames, message }) => {
|
|
283
|
-
const { id: _, role, content } = message;
|
|
284
|
-
const styleContainer = "flex flex-col overflow-x-hidden overflow-y-auto rounded-md gap-2 divide-y divide-separator";
|
|
285
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
286
|
-
className: mx("flex", role === "user" ? "ml-[1rem] justify-end" : "mr-[1rem]", classNames)
|
|
287
|
-
}, content.map((content2, i) => {
|
|
288
|
-
switch (content2.type) {
|
|
289
|
-
case "text": {
|
|
290
|
-
const { cot, message: message2 } = parseMessage(content2.text);
|
|
291
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
292
|
-
key: i,
|
|
293
|
-
role: "none",
|
|
294
|
-
className: mx(styleContainer, role === "user" ? "bg-primary-400 dark:bg-primary-600" : "bg-hoverSurface")
|
|
295
|
-
}, cot && /* @__PURE__ */ React.createElement("div", {
|
|
296
|
-
className: "p-2 whitespace-pre-wrap text-xs text-subdued"
|
|
297
|
-
}, cot), /* @__PURE__ */ React.createElement("div", {
|
|
298
|
-
className: "p-2 whitespace-pre-wrap"
|
|
299
|
-
}, message2));
|
|
300
|
-
}
|
|
301
|
-
case "tool_use": {
|
|
302
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
303
|
-
key: i,
|
|
304
|
-
className: mx(styleContainer, "text-xs")
|
|
305
|
-
}, /* @__PURE__ */ React.createElement("div", null, /* @__PURE__ */ React.createElement("span", {
|
|
306
|
-
className: "p-2 text-primary"
|
|
307
|
-
}, "Tool use"), ": ", content2.name, " ", content2.id), /* @__PURE__ */ React.createElement(SyntaxHighlighter, {
|
|
308
|
-
language: "json"
|
|
309
|
-
}, content2.inputJson));
|
|
310
|
-
}
|
|
311
|
-
case "tool_result": {
|
|
312
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
313
|
-
key: i,
|
|
314
|
-
className: mx(styleContainer, "text-xs", content2.isError && "text-error")
|
|
315
|
-
}, /* @__PURE__ */ React.createElement("div", null, /* @__PURE__ */ React.createElement("span", {
|
|
316
|
-
className: "p-2 text-primary"
|
|
317
|
-
}, "Tool result"), ": ", content2.toolUseId), /* @__PURE__ */ React.createElement(SyntaxHighlighter, {
|
|
318
|
-
language: "json"
|
|
319
|
-
}, content2.content));
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
return null;
|
|
323
|
-
}));
|
|
324
|
-
};
|
|
325
|
-
var parseMessage = (text) => {
|
|
326
|
-
const regex = /<cot>([\s\S]*?)<\/cot>\s*([\s\S]*)/;
|
|
327
|
-
const match = text.match(regex);
|
|
328
|
-
return {
|
|
329
|
-
cot: match?.[1].trim(),
|
|
330
|
-
message: match?.[2] ?? text ?? "\xD8"
|
|
331
|
-
};
|
|
332
|
-
};
|
|
333
|
-
|
|
334
|
-
// packages/plugins/experimental/plugin-automation/src/components/AssistantPanel/index.ts
|
|
335
|
-
var AssistantPanel_default = AssistantPanel;
|
|
336
|
-
export {
|
|
337
|
-
AssistantPanel_default as default
|
|
338
|
-
};
|
|
339
|
-
//# sourceMappingURL=AssistantPanel-N276BTPV.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>\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.type) : 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", "type", "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,232 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
AUTOMATION_PLUGIN
|
|
3
|
-
} from "./chunk-HKX3D3ZP.mjs";
|
|
4
|
-
|
|
5
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
|
|
6
|
-
import React2, { useState as useState2 } from "react";
|
|
7
|
-
import { S } from "@dxos/echo-schema";
|
|
8
|
-
import { FunctionType as FunctionType2, FunctionTrigger, FunctionTriggerSchema as FunctionTriggerSchema2, TriggerKind as TriggerKind2, ScriptType as ScriptType2 } from "@dxos/functions";
|
|
9
|
-
import { useClient } from "@dxos/react-client";
|
|
10
|
-
import { create, Filter as Filter2, useQuery as useQuery2, getSpace } from "@dxos/react-client/echo";
|
|
11
|
-
import { IconButton as IconButton2, Input as Input2, useTranslation as useTranslation2, Button } from "@dxos/react-ui";
|
|
12
|
-
import { List } from "@dxos/react-ui-list";
|
|
13
|
-
import { ghostHover, mx } from "@dxos/react-ui-theme";
|
|
14
|
-
|
|
15
|
-
// packages/plugins/experimental/plugin-automation/src/components/TriggerEditor/TriggerEditor.tsx
|
|
16
|
-
import React, { useState } from "react";
|
|
17
|
-
import { FunctionType, FunctionTriggerSchema, ScriptType, TriggerKind } from "@dxos/functions";
|
|
18
|
-
import { Filter, useQuery } from "@dxos/react-client/echo";
|
|
19
|
-
import { IconButton, Input, useTranslation } from "@dxos/react-ui";
|
|
20
|
-
import { Form, SelectInput, TextInput } 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 scripts = useQuery(space, Filter.schema(ScriptType));
|
|
25
|
-
const handleSave = (values) => {
|
|
26
|
-
onSave?.(values);
|
|
27
|
-
};
|
|
28
|
-
return /* @__PURE__ */ React.createElement(Form, {
|
|
29
|
-
schema: FunctionTriggerSchema,
|
|
30
|
-
values: trigger,
|
|
31
|
-
onSave: handleSave,
|
|
32
|
-
onCancel,
|
|
33
|
-
Custom: {
|
|
34
|
-
["function"]: (props) => /* @__PURE__ */ React.createElement(SelectInput, {
|
|
35
|
-
...props,
|
|
36
|
-
options: functions.map((fn) => ({
|
|
37
|
-
value: fn.name,
|
|
38
|
-
label: getFunctionName(scripts, fn)
|
|
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
|
-
["meta"]: (props) => {
|
|
49
|
-
const meta = props.getValue("meta");
|
|
50
|
-
const [newMetaFieldName, setNewMetaFieldName] = useState("");
|
|
51
|
-
React.useEffect(() => props.onValueChange("meta", "object", {
|
|
52
|
-
...meta
|
|
53
|
-
}), []);
|
|
54
|
-
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("div", null, props.label), [
|
|
55
|
-
...Object.keys(meta)
|
|
56
|
-
].map((key) => {
|
|
57
|
-
const compositeKey = `meta.${key}`;
|
|
58
|
-
return /* @__PURE__ */ React.createElement("div", {
|
|
59
|
-
key: compositeKey,
|
|
60
|
-
role: "none",
|
|
61
|
-
className: "flex items-center mt-2 gap-1"
|
|
62
|
-
}, /* @__PURE__ */ React.createElement("div", {
|
|
63
|
-
role: "none",
|
|
64
|
-
className: "flex-1"
|
|
65
|
-
}, /* @__PURE__ */ React.createElement(TextInput, {
|
|
66
|
-
...props,
|
|
67
|
-
property: compositeKey,
|
|
68
|
-
type: "string",
|
|
69
|
-
label: key
|
|
70
|
-
})), /* @__PURE__ */ React.createElement(IconButton, {
|
|
71
|
-
icon: "ph--trash--regular",
|
|
72
|
-
iconOnly: true,
|
|
73
|
-
classNames: "mt-6",
|
|
74
|
-
label: t("trigger meta remove"),
|
|
75
|
-
onClick: () => {
|
|
76
|
-
const newValues = {
|
|
77
|
-
...props.getValue("meta")
|
|
78
|
-
};
|
|
79
|
-
delete newValues[key];
|
|
80
|
-
props.onValueChange("meta", "object", newValues);
|
|
81
|
-
}
|
|
82
|
-
}));
|
|
83
|
-
}), /* @__PURE__ */ React.createElement("div", {
|
|
84
|
-
role: "none",
|
|
85
|
-
className: "flex items-center mt-2 gap-1 plb-1"
|
|
86
|
-
}, /* @__PURE__ */ React.createElement("div", {
|
|
87
|
-
role: "none",
|
|
88
|
-
className: "flex-1"
|
|
89
|
-
}, /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.TextInput, {
|
|
90
|
-
placeholder: t("trigger meta prop name placeholder"),
|
|
91
|
-
value: newMetaFieldName,
|
|
92
|
-
onChange: (event) => setNewMetaFieldName(event.target.value)
|
|
93
|
-
}))), /* @__PURE__ */ React.createElement(IconButton, {
|
|
94
|
-
icon: "ph--plus--regular",
|
|
95
|
-
iconOnly: true,
|
|
96
|
-
label: t("trigger meta add"),
|
|
97
|
-
onClick: () => {
|
|
98
|
-
if (newMetaFieldName.length) {
|
|
99
|
-
const meta2 = props.getValue("meta") ?? {};
|
|
100
|
-
const metaWithNewProp = {
|
|
101
|
-
...meta2,
|
|
102
|
-
[newMetaFieldName]: ""
|
|
103
|
-
};
|
|
104
|
-
setNewMetaFieldName("");
|
|
105
|
-
props.onValueChange("meta", "object", metaWithNewProp);
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
})));
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
});
|
|
112
|
-
};
|
|
113
|
-
var getFunctionName = (scripts, fn) => {
|
|
114
|
-
return scripts.find((s) => fn.source?.target?.id === s.id)?.name ?? fn.name;
|
|
115
|
-
};
|
|
116
|
-
|
|
117
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/AutomationPanel.tsx
|
|
118
|
-
var grid = "grid grid-cols-[40px_1fr_32px] min-bs-[2.5rem]";
|
|
119
|
-
var AutomationPanel = ({ space, object }) => {
|
|
120
|
-
const { t } = useTranslation2(AUTOMATION_PLUGIN);
|
|
121
|
-
const client = useClient();
|
|
122
|
-
const triggers = useQuery2(space, Filter2.schema(FunctionTrigger));
|
|
123
|
-
const functions = useQuery2(space, Filter2.schema(FunctionType2));
|
|
124
|
-
const scripts = useQuery2(space, Filter2.schema(ScriptType2));
|
|
125
|
-
const [trigger, setTrigger] = useState2();
|
|
126
|
-
const [selected, setSelected] = useState2();
|
|
127
|
-
const handleSelect = (trigger2) => {
|
|
128
|
-
const { id: _, ...values } = trigger2;
|
|
129
|
-
setTrigger(values);
|
|
130
|
-
setSelected(trigger2);
|
|
131
|
-
};
|
|
132
|
-
const handleAdd = () => {
|
|
133
|
-
setTrigger(create(FunctionTriggerSchema2, {
|
|
134
|
-
meta: {}
|
|
135
|
-
}));
|
|
136
|
-
setSelected(void 0);
|
|
137
|
-
};
|
|
138
|
-
const handleDelete = (trigger2) => {
|
|
139
|
-
space.db.remove(trigger2);
|
|
140
|
-
setTrigger(void 0);
|
|
141
|
-
setSelected(void 0);
|
|
142
|
-
};
|
|
143
|
-
const handleSave = (trigger2) => {
|
|
144
|
-
if (selected) {
|
|
145
|
-
Object.assign(selected, trigger2);
|
|
146
|
-
} else {
|
|
147
|
-
space.db.add(create(FunctionTrigger, trigger2));
|
|
148
|
-
}
|
|
149
|
-
setTrigger(void 0);
|
|
150
|
-
setSelected(void 0);
|
|
151
|
-
};
|
|
152
|
-
const handleCancel = () => {
|
|
153
|
-
setTrigger(void 0);
|
|
154
|
-
};
|
|
155
|
-
return /* @__PURE__ */ React2.createElement("div", {
|
|
156
|
-
className: "flex flex-col w-full divide-y divide-separator overflow-y-auto"
|
|
157
|
-
}, /* @__PURE__ */ React2.createElement(List.Root, {
|
|
158
|
-
items: triggers,
|
|
159
|
-
isItem: S.is(FunctionTrigger),
|
|
160
|
-
getId: (field) => field.id
|
|
161
|
-
}, ({ items: triggers2 }) => /* @__PURE__ */ React2.createElement("div", {
|
|
162
|
-
role: "list",
|
|
163
|
-
className: "flex flex-col w-full"
|
|
164
|
-
}, triggers2?.map((trigger2) => {
|
|
165
|
-
const copyAction = getCopyAction(client, trigger2);
|
|
166
|
-
return /* @__PURE__ */ React2.createElement(List.Item, {
|
|
167
|
-
key: trigger2.id,
|
|
168
|
-
item: trigger2,
|
|
169
|
-
classNames: mx(grid, ghostHover, "items-center", "px-2")
|
|
170
|
-
}, /* @__PURE__ */ React2.createElement(Input2.Root, null, /* @__PURE__ */ React2.createElement(Input2.Switch, {
|
|
171
|
-
checked: trigger2.enabled,
|
|
172
|
-
onCheckedChange: (checked) => trigger2.enabled = checked
|
|
173
|
-
})), /* @__PURE__ */ React2.createElement("div", {
|
|
174
|
-
className: "flex"
|
|
175
|
-
}, /* @__PURE__ */ React2.createElement(List.ItemTitle, {
|
|
176
|
-
classNames: "px-1 cursor-pointer w-0 shrink truncate",
|
|
177
|
-
onClick: () => handleSelect(trigger2)
|
|
178
|
-
}, getFunctionName2(scripts, functions, trigger2) ?? "\u2205"), copyAction && /* @__PURE__ */ React2.createElement(Button, {
|
|
179
|
-
onClick: () => navigator.clipboard.writeText(copyAction.contentProvider())
|
|
180
|
-
}, t(copyAction.translationKey))), /* @__PURE__ */ React2.createElement(List.ItemDeleteButton, {
|
|
181
|
-
onClick: () => handleDelete(trigger2)
|
|
182
|
-
}));
|
|
183
|
-
}))), trigger && /* @__PURE__ */ React2.createElement(TriggerEditor, {
|
|
184
|
-
space,
|
|
185
|
-
trigger,
|
|
186
|
-
onSave: handleSave,
|
|
187
|
-
onCancel: handleCancel
|
|
188
|
-
}), !trigger && /* @__PURE__ */ React2.createElement("div", {
|
|
189
|
-
className: "flex p-2 justify-center"
|
|
190
|
-
}, /* @__PURE__ */ React2.createElement(IconButton2, {
|
|
191
|
-
icon: "ph--plus--regular",
|
|
192
|
-
label: t("new trigger"),
|
|
193
|
-
onClick: handleAdd
|
|
194
|
-
})));
|
|
195
|
-
};
|
|
196
|
-
var getCopyAction = (client, trigger) => {
|
|
197
|
-
if (trigger?.spec?.type === TriggerKind2.Email) {
|
|
198
|
-
return {
|
|
199
|
-
translationKey: "trigger copy email",
|
|
200
|
-
contentProvider: () => `${getSpace(trigger).id}@dxos.network`
|
|
201
|
-
};
|
|
202
|
-
}
|
|
203
|
-
if (trigger?.spec?.type === TriggerKind2.Webhook) {
|
|
204
|
-
return {
|
|
205
|
-
translationKey: "trigger copy url",
|
|
206
|
-
contentProvider: () => getWebhookUrl(client, trigger)
|
|
207
|
-
};
|
|
208
|
-
}
|
|
209
|
-
return void 0;
|
|
210
|
-
};
|
|
211
|
-
var getWebhookUrl = (client, trigger) => {
|
|
212
|
-
const spaceId = getSpace(trigger).id;
|
|
213
|
-
const edgeUrl = new URL(client.config.values.runtime.services.edge.url);
|
|
214
|
-
const isSecure = edgeUrl.protocol.startsWith("https") || edgeUrl.protocol.startsWith("wss");
|
|
215
|
-
edgeUrl.protocol = isSecure ? "https" : "http";
|
|
216
|
-
return new URL(`/webhook/${spaceId}:${trigger.id}`, edgeUrl).toString();
|
|
217
|
-
};
|
|
218
|
-
var getFunctionName2 = (scripts, functions, trigger) => {
|
|
219
|
-
const shortId = trigger.function && `${trigger.function?.slice(0, 16)}\u2026`;
|
|
220
|
-
const functionObject = functions.find((fn) => fn.name === trigger.function);
|
|
221
|
-
if (!functionObject) {
|
|
222
|
-
return shortId;
|
|
223
|
-
}
|
|
224
|
-
return scripts.find((s) => functionObject.source?.target?.id === s.id)?.name ?? shortId;
|
|
225
|
-
};
|
|
226
|
-
|
|
227
|
-
// packages/plugins/experimental/plugin-automation/src/components/AutomationPanel/index.ts
|
|
228
|
-
var AutomationPanel_default = AutomationPanel;
|
|
229
|
-
export {
|
|
230
|
-
AutomationPanel_default as default
|
|
231
|
-
};
|
|
232
|
-
//# sourceMappingURL=AutomationPanel-IHZ4JKVS.mjs.map
|