@copilotkit/runtime-client-gql 1.51.4 → 1.51.5-next.1
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/CHANGELOG.md +15 -0
- package/dist/_virtual/_rolldown/runtime.cjs +29 -0
- package/dist/client/CopilotRuntimeClient.cjs +119 -0
- package/dist/client/CopilotRuntimeClient.cjs.map +1 -0
- package/dist/client/CopilotRuntimeClient.d.cts +44 -0
- package/dist/client/CopilotRuntimeClient.d.cts.map +1 -0
- package/dist/client/CopilotRuntimeClient.d.mts +44 -0
- package/dist/client/CopilotRuntimeClient.d.mts.map +1 -0
- package/dist/client/CopilotRuntimeClient.mjs +116 -10
- package/dist/client/CopilotRuntimeClient.mjs.map +1 -1
- package/dist/client/conversion.cjs +194 -0
- package/dist/client/conversion.cjs.map +1 -0
- package/dist/client/{conversion.d.ts → conversion.d.cts} +5 -4
- package/dist/client/conversion.d.cts.map +1 -0
- package/dist/client/conversion.d.mts +12 -0
- package/dist/client/conversion.d.mts.map +1 -0
- package/dist/client/conversion.mjs +187 -17
- package/dist/client/conversion.mjs.map +1 -1
- package/dist/client/index.d.cts +5 -0
- package/dist/client/index.d.mts +5 -0
- package/dist/client/types.cjs +86 -0
- package/dist/client/types.cjs.map +1 -0
- package/dist/client/types.d.cts +76 -0
- package/dist/client/types.d.cts.map +1 -0
- package/dist/client/types.d.mts +76 -0
- package/dist/client/types.d.mts.map +1 -0
- package/dist/client/types.mjs +76 -21
- package/dist/client/types.mjs.map +1 -1
- package/dist/graphql/@generated/gql.cjs +15 -0
- package/dist/graphql/@generated/gql.cjs.map +1 -0
- package/dist/graphql/@generated/gql.mjs +13 -7
- package/dist/graphql/@generated/gql.mjs.map +1 -1
- package/dist/graphql/@generated/graphql.cjs +1154 -0
- package/dist/graphql/@generated/graphql.cjs.map +1 -0
- package/dist/graphql/@generated/graphql.d.cts +642 -0
- package/dist/graphql/@generated/graphql.d.cts.map +1 -0
- package/dist/graphql/@generated/graphql.d.mts +642 -0
- package/dist/graphql/@generated/graphql.d.mts.map +1 -0
- package/dist/graphql/@generated/graphql.mjs +1142 -24
- package/dist/graphql/@generated/graphql.mjs.map +1 -1
- package/dist/{chunk-E5FOLXLN.mjs → graphql/definitions/mutations.cjs} +8 -11
- package/dist/graphql/definitions/mutations.cjs.map +1 -0
- package/dist/graphql/definitions/mutations.mjs +140 -9
- package/dist/graphql/definitions/mutations.mjs.map +1 -1
- package/dist/graphql/definitions/queries.cjs +35 -0
- package/dist/graphql/definitions/queries.cjs.map +1 -0
- package/dist/graphql/definitions/queries.mjs +33 -11
- package/dist/graphql/definitions/queries.mjs.map +1 -1
- package/dist/index.cjs +43 -0
- package/dist/index.d.cts +9 -0
- package/dist/index.d.mts +9 -0
- package/dist/index.mjs +8 -91
- package/dist/index.umd.js +2080 -2
- package/dist/index.umd.js.map +1 -1
- package/dist/message-conversion/agui-to-gql.cjs +162 -0
- package/dist/message-conversion/agui-to-gql.cjs.map +1 -0
- package/dist/message-conversion/{agui-to-gql.d.ts → agui-to-gql.d.cts} +6 -5
- package/dist/message-conversion/agui-to-gql.d.cts.map +1 -0
- package/dist/message-conversion/agui-to-gql.d.mts +14 -0
- package/dist/message-conversion/agui-to-gql.d.mts.map +1 -0
- package/dist/message-conversion/agui-to-gql.mjs +156 -25
- package/dist/message-conversion/agui-to-gql.mjs.map +1 -1
- package/dist/message-conversion/gql-to-agui.cjs +169 -0
- package/dist/message-conversion/gql-to-agui.cjs.map +1 -0
- package/dist/message-conversion/{gql-to-agui.d.ts → gql-to-agui.d.cts} +6 -5
- package/dist/message-conversion/gql-to-agui.d.cts.map +1 -0
- package/dist/message-conversion/gql-to-agui.d.mts +13 -0
- package/dist/message-conversion/gql-to-agui.d.mts.map +1 -0
- package/dist/message-conversion/gql-to-agui.mjs +164 -23
- package/dist/message-conversion/gql-to-agui.mjs.map +1 -1
- package/dist/message-conversion/index.d.cts +2 -0
- package/dist/message-conversion/index.d.mts +2 -0
- package/dist/package.cjs +12 -0
- package/dist/package.cjs.map +1 -0
- package/dist/package.mjs +6 -0
- package/dist/package.mjs.map +1 -0
- package/package.json +15 -15
- package/src/message-conversion/agui-to-gql.test.ts +70 -0
- package/src/message-conversion/agui-to-gql.ts +4 -0
- package/tsdown.config.ts +49 -0
- package/vitest.config.mjs +11 -0
- package/dist/chunk-2XWNDVTL.mjs +0 -176
- package/dist/chunk-2XWNDVTL.mjs.map +0 -1
- package/dist/chunk-7ECCT6PK.mjs +0 -1
- package/dist/chunk-7ECCT6PK.mjs.map +0 -1
- package/dist/chunk-A4INSSNE.mjs +0 -17722
- package/dist/chunk-A4INSSNE.mjs.map +0 -1
- package/dist/chunk-CA4VMP2C.mjs +0 -1
- package/dist/chunk-CA4VMP2C.mjs.map +0 -1
- package/dist/chunk-DELDZXUX.mjs +0 -31
- package/dist/chunk-DELDZXUX.mjs.map +0 -1
- package/dist/chunk-E5FOLXLN.mjs.map +0 -1
- package/dist/chunk-LTVE64IE.mjs +0 -241
- package/dist/chunk-LTVE64IE.mjs.map +0 -1
- package/dist/chunk-M4CK5HDR.mjs +0 -237
- package/dist/chunk-M4CK5HDR.mjs.map +0 -1
- package/dist/chunk-OBDQ5BWD.mjs +0 -63
- package/dist/chunk-OBDQ5BWD.mjs.map +0 -1
- package/dist/chunk-QUH7QWUA.mjs +0 -38
- package/dist/chunk-QUH7QWUA.mjs.map +0 -1
- package/dist/chunk-SDQPJXLL.mjs +0 -20
- package/dist/chunk-SDQPJXLL.mjs.map +0 -1
- package/dist/chunk-UOAPP5IN.mjs +0 -93
- package/dist/chunk-UOAPP5IN.mjs.map +0 -1
- package/dist/chunk-VIHKTLUA.mjs +0 -221
- package/dist/chunk-VIHKTLUA.mjs.map +0 -1
- package/dist/chunk-XZPL6QVK.mjs +0 -24
- package/dist/chunk-XZPL6QVK.mjs.map +0 -1
- package/dist/client/CopilotRuntimeClient.d.ts +0 -39
- package/dist/client/CopilotRuntimeClient.js +0 -366
- package/dist/client/CopilotRuntimeClient.js.map +0 -1
- package/dist/client/conversion.js +0 -339
- package/dist/client/conversion.js.map +0 -1
- package/dist/client/index.d.ts +0 -8
- package/dist/client/index.js +0 -711
- package/dist/client/index.js.map +0 -1
- package/dist/client/index.mjs +0 -43
- package/dist/client/index.mjs.map +0 -1
- package/dist/client/types.d.ts +0 -75
- package/dist/client/types.js +0 -132
- package/dist/client/types.js.map +0 -1
- package/dist/graphql/@generated/fragment-masking.d.ts +0 -22
- package/dist/graphql/@generated/fragment-masking.js +0 -50
- package/dist/graphql/@generated/fragment-masking.js.map +0 -1
- package/dist/graphql/@generated/fragment-masking.mjs +0 -12
- package/dist/graphql/@generated/fragment-masking.mjs.map +0 -1
- package/dist/graphql/@generated/gql.d.ts +0 -48
- package/dist/graphql/@generated/gql.js +0 -45
- package/dist/graphql/@generated/gql.js.map +0 -1
- package/dist/graphql/@generated/graphql.d.ts +0 -655
- package/dist/graphql/@generated/graphql.js +0 -96
- package/dist/graphql/@generated/graphql.js.map +0 -1
- package/dist/graphql/@generated/index.d.ts +0 -4
- package/dist/graphql/@generated/index.js +0 -69
- package/dist/graphql/@generated/index.js.map +0 -1
- package/dist/graphql/@generated/index.mjs +0 -17
- package/dist/graphql/@generated/index.mjs.map +0 -1
- package/dist/graphql/definitions/mutations.d.ts +0 -9
- package/dist/graphql/definitions/mutations.js +0 -181
- package/dist/graphql/definitions/mutations.js.map +0 -1
- package/dist/graphql/definitions/queries.d.ts +0 -11
- package/dist/graphql/definitions/queries.js +0 -76
- package/dist/graphql/definitions/queries.js.map +0 -1
- package/dist/index.d.ts +0 -11
- package/dist/index.js +0 -1222
- package/dist/index.js.map +0 -1
- package/dist/index.mjs.map +0 -1
- package/dist/magic-string.es-XBKSJO3K.mjs +0 -1389
- package/dist/magic-string.es-XBKSJO3K.mjs.map +0 -1
- package/dist/message-conversion/agui-to-gql.js +0 -344
- package/dist/message-conversion/agui-to-gql.js.map +0 -1
- package/dist/message-conversion/agui-to-gql.test.d.ts +0 -2
- package/dist/message-conversion/agui-to-gql.test.js +0 -20553
- package/dist/message-conversion/agui-to-gql.test.js.map +0 -1
- package/dist/message-conversion/agui-to-gql.test.mjs +0 -1137
- package/dist/message-conversion/agui-to-gql.test.mjs.map +0 -1
- package/dist/message-conversion/gql-to-agui.js +0 -262
- package/dist/message-conversion/gql-to-agui.js.map +0 -1
- package/dist/message-conversion/gql-to-agui.test.d.ts +0 -2
- package/dist/message-conversion/gql-to-agui.test.js +0 -20850
- package/dist/message-conversion/gql-to-agui.test.js.map +0 -1
- package/dist/message-conversion/gql-to-agui.test.mjs +0 -1447
- package/dist/message-conversion/gql-to-agui.test.mjs.map +0 -1
- package/dist/message-conversion/index.d.ts +0 -6
- package/dist/message-conversion/index.js +0 -563
- package/dist/message-conversion/index.js.map +0 -1
- package/dist/message-conversion/index.mjs +0 -39
- package/dist/message-conversion/index.mjs.map +0 -1
- package/dist/message-conversion/roundtrip-conversion.test.d.ts +0 -2
- package/dist/message-conversion/roundtrip-conversion.test.js +0 -20095
- package/dist/message-conversion/roundtrip-conversion.test.js.map +0 -1
- package/dist/message-conversion/roundtrip-conversion.test.mjs +0 -489
- package/dist/message-conversion/roundtrip-conversion.test.mjs.map +0 -1
- package/jest.config.js +0 -5
- package/rollup.config.mjs +0 -62
- package/tsup.config.ts +0 -12
|
@@ -1,24 +1,165 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
1
|
+
import { MessageStatusCode } from "../graphql/@generated/graphql.mjs";
|
|
2
|
+
import { Role } from "../client/types.mjs";
|
|
3
|
+
|
|
4
|
+
//#region src/message-conversion/gql-to-agui.ts
|
|
5
|
+
const VALID_IMAGE_FORMATS = [
|
|
6
|
+
"jpeg",
|
|
7
|
+
"png",
|
|
8
|
+
"webp",
|
|
9
|
+
"gif"
|
|
10
|
+
];
|
|
11
|
+
function validateImageFormat(format) {
|
|
12
|
+
return VALID_IMAGE_FORMATS.includes(format);
|
|
13
|
+
}
|
|
14
|
+
function gqlToAGUI(messages, actions, coAgentStateRenders) {
|
|
15
|
+
let aguiMessages = [];
|
|
16
|
+
messages = Array.isArray(messages) ? messages : [messages];
|
|
17
|
+
const actionResults = /* @__PURE__ */ new Map();
|
|
18
|
+
for (const message of messages) if (message.isResultMessage()) actionResults.set(message.actionExecutionId, message.result);
|
|
19
|
+
for (const message of messages) if (message.isTextMessage()) aguiMessages.push(gqlTextMessageToAGUIMessage(message));
|
|
20
|
+
else if (message.isResultMessage()) aguiMessages.push(gqlResultMessageToAGUIMessage(message));
|
|
21
|
+
else if (message.isActionExecutionMessage()) aguiMessages.push(gqlActionExecutionMessageToAGUIMessage(message, actions, actionResults));
|
|
22
|
+
else if (message.isAgentStateMessage()) aguiMessages.push(gqlAgentStateMessageToAGUIMessage(message, coAgentStateRenders));
|
|
23
|
+
else if (message.isImageMessage()) aguiMessages.push(gqlImageMessageToAGUIMessage(message));
|
|
24
|
+
else throw new Error("Unknown message type");
|
|
25
|
+
return aguiMessages;
|
|
26
|
+
}
|
|
27
|
+
function gqlActionExecutionMessageToAGUIMessage(message, actions, actionResults) {
|
|
28
|
+
const hasSpecificAction = actions && Object.values(actions).some((action) => action.name === message.name);
|
|
29
|
+
const hasWildcardAction = actions && Object.values(actions).some((action) => action.name === "*");
|
|
30
|
+
if (!actions || !hasSpecificAction && !hasWildcardAction) return {
|
|
31
|
+
id: message.id,
|
|
32
|
+
role: "assistant",
|
|
33
|
+
toolCalls: [actionExecutionMessageToAGUIMessage(message)],
|
|
34
|
+
name: message.name
|
|
35
|
+
};
|
|
36
|
+
const action = Object.values(actions).find((action) => action.name === message.name) || Object.values(actions).find((action) => action.name === "*");
|
|
37
|
+
const createRenderWrapper = (originalRender) => {
|
|
38
|
+
if (!originalRender) return void 0;
|
|
39
|
+
return (props) => {
|
|
40
|
+
let actionResult = actionResults?.get(message.id);
|
|
41
|
+
let status = "inProgress";
|
|
42
|
+
if (actionResult !== void 0) status = "complete";
|
|
43
|
+
else if (message.status?.code !== MessageStatusCode.Pending) status = "executing";
|
|
44
|
+
if (typeof props?.result === "string") try {
|
|
45
|
+
props.result = JSON.parse(props.result);
|
|
46
|
+
} catch (e) {}
|
|
47
|
+
if (typeof actionResult === "string") try {
|
|
48
|
+
actionResult = JSON.parse(actionResult);
|
|
49
|
+
} catch (e) {}
|
|
50
|
+
const baseProps = {
|
|
51
|
+
status: props?.status || status,
|
|
52
|
+
args: message.arguments || {},
|
|
53
|
+
result: props?.result || actionResult || void 0,
|
|
54
|
+
messageId: message.id
|
|
55
|
+
};
|
|
56
|
+
if (action.name === "*") return originalRender({
|
|
57
|
+
...baseProps,
|
|
58
|
+
...props,
|
|
59
|
+
name: message.name
|
|
60
|
+
});
|
|
61
|
+
else {
|
|
62
|
+
const respond = props?.respond ?? (() => {});
|
|
63
|
+
return originalRender({
|
|
64
|
+
...baseProps,
|
|
65
|
+
...props,
|
|
66
|
+
respond
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
};
|
|
71
|
+
return {
|
|
72
|
+
id: message.id,
|
|
73
|
+
role: "assistant",
|
|
74
|
+
content: "",
|
|
75
|
+
toolCalls: [actionExecutionMessageToAGUIMessage(message)],
|
|
76
|
+
generativeUI: createRenderWrapper(action.render),
|
|
77
|
+
name: message.name
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
function gqlAgentStateMessageToAGUIMessage(message, coAgentStateRenders) {
|
|
81
|
+
if (coAgentStateRenders && Object.values(coAgentStateRenders).some((render) => render.name === message.agentName)) {
|
|
82
|
+
const render = Object.values(coAgentStateRenders).find((render) => render.name === message.agentName);
|
|
83
|
+
const createRenderWrapper = (originalRender) => {
|
|
84
|
+
if (!originalRender) return void 0;
|
|
85
|
+
return (props) => {
|
|
86
|
+
return originalRender({ state: message.state });
|
|
87
|
+
};
|
|
88
|
+
};
|
|
89
|
+
return {
|
|
90
|
+
id: message.id,
|
|
91
|
+
role: "assistant",
|
|
92
|
+
generativeUI: createRenderWrapper(render.render),
|
|
93
|
+
agentName: message.agentName,
|
|
94
|
+
state: message.state
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
return {
|
|
98
|
+
id: message.id,
|
|
99
|
+
role: "assistant",
|
|
100
|
+
agentName: message.agentName,
|
|
101
|
+
state: message.state
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
function actionExecutionMessageToAGUIMessage(actionExecutionMessage) {
|
|
105
|
+
return {
|
|
106
|
+
id: actionExecutionMessage.id,
|
|
107
|
+
function: {
|
|
108
|
+
name: actionExecutionMessage.name,
|
|
109
|
+
arguments: JSON.stringify(actionExecutionMessage.arguments)
|
|
110
|
+
},
|
|
111
|
+
type: "function"
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
function gqlTextMessageToAGUIMessage(message) {
|
|
115
|
+
switch (message.role) {
|
|
116
|
+
case Role.Developer: return {
|
|
117
|
+
id: message.id,
|
|
118
|
+
role: "developer",
|
|
119
|
+
content: message.content
|
|
120
|
+
};
|
|
121
|
+
case Role.System: return {
|
|
122
|
+
id: message.id,
|
|
123
|
+
role: "system",
|
|
124
|
+
content: message.content
|
|
125
|
+
};
|
|
126
|
+
case Role.Assistant: return {
|
|
127
|
+
id: message.id,
|
|
128
|
+
role: "assistant",
|
|
129
|
+
content: message.content
|
|
130
|
+
};
|
|
131
|
+
case Role.User: return {
|
|
132
|
+
id: message.id,
|
|
133
|
+
role: "user",
|
|
134
|
+
content: message.content
|
|
135
|
+
};
|
|
136
|
+
default: throw new Error("Unknown message role");
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
function gqlResultMessageToAGUIMessage(message) {
|
|
140
|
+
return {
|
|
141
|
+
id: message.id,
|
|
142
|
+
role: "tool",
|
|
143
|
+
content: message.result,
|
|
144
|
+
toolCallId: message.actionExecutionId,
|
|
145
|
+
toolName: message.actionName
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
function gqlImageMessageToAGUIMessage(message) {
|
|
149
|
+
if (!validateImageFormat(message.format)) throw new Error(`Invalid image format: ${message.format}. Supported formats are: ${VALID_IMAGE_FORMATS.join(", ")}`);
|
|
150
|
+
if (!message.bytes || typeof message.bytes !== "string" || message.bytes.trim() === "") throw new Error("Image bytes must be a non-empty string");
|
|
151
|
+
const role = message.role === Role.Assistant ? "assistant" : "user";
|
|
152
|
+
return {
|
|
153
|
+
id: message.id,
|
|
154
|
+
role,
|
|
155
|
+
content: "",
|
|
156
|
+
image: {
|
|
157
|
+
format: message.format,
|
|
158
|
+
bytes: message.bytes
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
//#endregion
|
|
164
|
+
export { gqlActionExecutionMessageToAGUIMessage, gqlImageMessageToAGUIMessage, gqlResultMessageToAGUIMessage, gqlTextMessageToAGUIMessage, gqlToAGUI };
|
|
24
165
|
//# sourceMappingURL=gql-to-agui.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
1
|
+
{"version":3,"file":"gql-to-agui.mjs","names":[],"sources":["../../src/message-conversion/gql-to-agui.ts"],"sourcesContent":["import * as gql from \"../client\";\nimport agui from \"@copilotkit/shared\";\nimport { MessageStatusCode } from \"../graphql/@generated/graphql\";\n\n// Define valid image formats based on the supported formats in the codebase\nconst VALID_IMAGE_FORMATS = [\"jpeg\", \"png\", \"webp\", \"gif\"] as const;\ntype ValidImageFormat = (typeof VALID_IMAGE_FORMATS)[number];\n\n// Validation function for image format\nfunction validateImageFormat(format: string): format is ValidImageFormat {\n return VALID_IMAGE_FORMATS.includes(format as ValidImageFormat);\n}\n\n/*\n ----------------------------\n GQL Message -> AGUI Message\n ----------------------------\n*/\nexport function gqlToAGUI(\n messages: gql.Message[] | gql.Message,\n actions?: Record<string, any>,\n coAgentStateRenders?: Record<string, any>,\n): agui.Message[] {\n let aguiMessages: agui.Message[] = [];\n messages = Array.isArray(messages) ? messages : [messages];\n\n // Create a map of action execution ID to result for completed actions\n const actionResults = new Map<string, string>();\n for (const message of messages) {\n if (message.isResultMessage()) {\n actionResults.set(message.actionExecutionId, message.result);\n }\n }\n\n for (const message of messages) {\n if (message.isTextMessage()) {\n aguiMessages.push(gqlTextMessageToAGUIMessage(message));\n } else if (message.isResultMessage()) {\n aguiMessages.push(gqlResultMessageToAGUIMessage(message));\n } else if (message.isActionExecutionMessage()) {\n aguiMessages.push(\n gqlActionExecutionMessageToAGUIMessage(message, actions, actionResults),\n );\n } else if (message.isAgentStateMessage()) {\n aguiMessages.push(\n gqlAgentStateMessageToAGUIMessage(message, coAgentStateRenders),\n );\n } else if (message.isImageMessage()) {\n aguiMessages.push(gqlImageMessageToAGUIMessage(message));\n } else {\n throw new Error(\"Unknown message type\");\n }\n }\n\n return aguiMessages;\n}\n\nexport function gqlActionExecutionMessageToAGUIMessage(\n message: gql.ActionExecutionMessage,\n actions?: Record<string, any>,\n actionResults?: Map<string, string>,\n): agui.Message {\n // Check if we have actions and if there's a specific action or wild card action\n const hasSpecificAction =\n actions &&\n Object.values(actions).some((action: any) => action.name === message.name);\n const hasWildcardAction =\n actions &&\n Object.values(actions).some((action: any) => action.name === \"*\");\n\n if (!actions || (!hasSpecificAction && !hasWildcardAction)) {\n return {\n id: message.id,\n role: \"assistant\",\n toolCalls: [actionExecutionMessageToAGUIMessage(message)],\n name: message.name,\n };\n }\n\n // Find the specific action first, then fall back to wild card action\n const action =\n Object.values(actions).find(\n (action: any) => action.name === message.name,\n ) || Object.values(actions).find((action: any) => action.name === \"*\");\n\n // Create render function wrapper that provides proper props\n const createRenderWrapper = (originalRender: any) => {\n if (!originalRender) return undefined;\n\n return (props?: any) => {\n // Determine the correct status based on the same logic as RenderActionExecutionMessage\n let actionResult: any = actionResults?.get(message.id);\n let status: \"inProgress\" | \"executing\" | \"complete\" = \"inProgress\";\n\n if (actionResult !== undefined) {\n status = \"complete\";\n } else if (message.status?.code !== MessageStatusCode.Pending) {\n status = \"executing\";\n }\n\n // if props.result is a string, parse it as JSON but don't throw an error if it's not valid JSON\n if (typeof props?.result === \"string\") {\n try {\n props.result = JSON.parse(props.result);\n } catch (e) {\n /* do nothing */\n }\n }\n\n // if actionResult is a string, parse it as JSON but don't throw an error if it's not valid JSON\n if (typeof actionResult === \"string\") {\n try {\n actionResult = JSON.parse(actionResult);\n } catch (e) {\n /* do nothing */\n }\n }\n\n // Base props that all actions receive\n const baseProps = {\n status: props?.status || status,\n args: message.arguments || {},\n result: props?.result || actionResult || undefined,\n messageId: message.id,\n };\n\n // Add properties based on action type\n if (action.name === \"*\") {\n // Wildcard actions get the tool name; ensure it cannot be overridden by incoming props\n return originalRender({\n ...baseProps,\n ...props,\n name: message.name,\n });\n } else {\n // Regular actions get respond (defaulting to a no-op if not provided)\n const respond = props?.respond ?? (() => {});\n return originalRender({\n ...baseProps,\n ...props,\n respond,\n });\n }\n };\n };\n\n return {\n id: message.id,\n role: \"assistant\",\n content: \"\",\n toolCalls: [actionExecutionMessageToAGUIMessage(message)],\n generativeUI: createRenderWrapper(action.render),\n name: message.name,\n } as agui.AIMessage;\n}\n\nfunction gqlAgentStateMessageToAGUIMessage(\n message: gql.AgentStateMessage,\n coAgentStateRenders?: Record<string, any>,\n): agui.Message {\n if (\n coAgentStateRenders &&\n Object.values(coAgentStateRenders).some(\n (render: any) => render.name === message.agentName,\n )\n ) {\n const render = Object.values(coAgentStateRenders).find(\n (render: any) => render.name === message.agentName,\n );\n\n // Create render function wrapper that provides proper props\n const createRenderWrapper = (originalRender: any) => {\n if (!originalRender) return undefined;\n\n return (props?: any) => {\n // Determine the correct status based on the same logic as RenderActionExecutionMessage\n const state = message.state;\n\n // Provide the full props structure that the render function expects\n const renderProps = {\n state: state,\n };\n\n return originalRender(renderProps);\n };\n };\n\n return {\n id: message.id,\n role: \"assistant\",\n generativeUI: createRenderWrapper(render.render),\n agentName: message.agentName,\n state: message.state,\n };\n }\n\n return {\n id: message.id,\n role: \"assistant\",\n agentName: message.agentName,\n state: message.state,\n };\n}\n\nfunction actionExecutionMessageToAGUIMessage(\n actionExecutionMessage: gql.ActionExecutionMessage,\n): agui.ToolCall {\n return {\n id: actionExecutionMessage.id,\n function: {\n name: actionExecutionMessage.name,\n arguments: JSON.stringify(actionExecutionMessage.arguments),\n },\n type: \"function\",\n };\n}\n\nexport function gqlTextMessageToAGUIMessage(\n message: gql.TextMessage,\n): agui.Message {\n switch (message.role) {\n case gql.Role.Developer:\n return {\n id: message.id,\n role: \"developer\",\n content: message.content,\n };\n case gql.Role.System:\n return {\n id: message.id,\n role: \"system\",\n content: message.content,\n };\n case gql.Role.Assistant:\n return {\n id: message.id,\n role: \"assistant\",\n content: message.content,\n };\n case gql.Role.User:\n return {\n id: message.id,\n role: \"user\",\n content: message.content,\n };\n default:\n throw new Error(\"Unknown message role\");\n }\n}\n\nexport function gqlResultMessageToAGUIMessage(\n message: gql.ResultMessage,\n): agui.Message {\n return {\n id: message.id,\n role: \"tool\",\n content: message.result,\n toolCallId: message.actionExecutionId,\n toolName: message.actionName,\n };\n}\n\nexport function gqlImageMessageToAGUIMessage(\n message: gql.ImageMessage,\n): agui.Message {\n // Validate image format\n if (!validateImageFormat(message.format)) {\n throw new Error(\n `Invalid image format: ${message.format}. Supported formats are: ${VALID_IMAGE_FORMATS.join(\", \")}`,\n );\n }\n\n // Validate that bytes is a non-empty string\n if (\n !message.bytes ||\n typeof message.bytes !== \"string\" ||\n message.bytes.trim() === \"\"\n ) {\n throw new Error(\"Image bytes must be a non-empty string\");\n }\n\n // Determine the role based on the message role\n const role = message.role === gql.Role.Assistant ? \"assistant\" : \"user\";\n\n // Create the image message with proper typing\n const imageMessage: agui.Message = {\n id: message.id,\n role,\n content: \"\",\n image: {\n format: message.format,\n bytes: message.bytes,\n },\n };\n\n return imageMessage;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { aguiMessageWithImageToGQLMessage, aguiMessageWithRenderToGQL, aguiTextMessageToGQLMessage, aguiToGQL, aguiToolCallToGQLActionExecution, aguiToolMessageToGQLResultMessage } from "./agui-to-gql.cjs";
|
|
2
|
+
import { gqlActionExecutionMessageToAGUIMessage, gqlImageMessageToAGUIMessage, gqlResultMessageToAGUIMessage, gqlTextMessageToAGUIMessage, gqlToAGUI } from "./gql-to-agui.cjs";
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { aguiMessageWithImageToGQLMessage, aguiMessageWithRenderToGQL, aguiTextMessageToGQLMessage, aguiToGQL, aguiToolCallToGQLActionExecution, aguiToolMessageToGQLResultMessage } from "./agui-to-gql.mjs";
|
|
2
|
+
import { gqlActionExecutionMessageToAGUIMessage, gqlImageMessageToAGUIMessage, gqlResultMessageToAGUIMessage, gqlTextMessageToAGUIMessage, gqlToAGUI } from "./gql-to-agui.mjs";
|
package/dist/package.cjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"package.cjs","names":[],"sources":["../package.json"],"sourcesContent":[""],"mappings":""}
|
package/dist/package.mjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"package.mjs","names":[],"sources":["../package.json"],"sourcesContent":[""],"mappings":""}
|
package/package.json
CHANGED
|
@@ -9,20 +9,20 @@
|
|
|
9
9
|
"publishConfig": {
|
|
10
10
|
"access": "public"
|
|
11
11
|
},
|
|
12
|
-
"version": "1.51.
|
|
12
|
+
"version": "1.51.5-next.1",
|
|
13
13
|
"sideEffects": false,
|
|
14
|
-
"main": "./dist/index.
|
|
14
|
+
"main": "./dist/index.cjs",
|
|
15
15
|
"module": "./dist/index.mjs",
|
|
16
16
|
"exports": {
|
|
17
17
|
".": {
|
|
18
18
|
"import": "./dist/index.mjs",
|
|
19
|
-
"require": "./dist/index.
|
|
20
|
-
|
|
21
|
-
|
|
19
|
+
"require": "./dist/index.cjs"
|
|
20
|
+
},
|
|
21
|
+
"./package.json": "./package.json"
|
|
22
22
|
},
|
|
23
23
|
"unpkg": "./dist/index.umd.js",
|
|
24
24
|
"jsdelivr": "./dist/index.umd.js",
|
|
25
|
-
"types": "./dist/index.d.
|
|
25
|
+
"types": "./dist/index.d.cts",
|
|
26
26
|
"license": "MIT",
|
|
27
27
|
"peerDependencies": {
|
|
28
28
|
"react": "^18 || ^19 || ^19.0.0-rc"
|
|
@@ -41,19 +41,17 @@
|
|
|
41
41
|
"concurrently": "^8.2.2",
|
|
42
42
|
"esbuild": "^0.23.0",
|
|
43
43
|
"graphql": "^16.8.1",
|
|
44
|
-
"jest": "^29.6.4",
|
|
45
|
-
"ts-jest": "^29.1.1",
|
|
46
44
|
"ts-node": "^10.9.2",
|
|
47
|
-
"
|
|
45
|
+
"tsdown": "^0.20.3",
|
|
48
46
|
"typescript": "^5.4.5",
|
|
49
|
-
"vitest": "^3.
|
|
47
|
+
"vitest": "^3.2.4"
|
|
50
48
|
},
|
|
51
49
|
"dependencies": {
|
|
52
50
|
"@urql/core": "^5.0.3",
|
|
53
51
|
"untruncate-json": "^0.0.1",
|
|
54
52
|
"urql": "^4.1.0",
|
|
55
|
-
"@copilotkit/runtime": "1.51.
|
|
56
|
-
"@copilotkit/shared": "1.51.
|
|
53
|
+
"@copilotkit/runtime": "1.51.5-next.1",
|
|
54
|
+
"@copilotkit/shared": "1.51.5-next.1"
|
|
57
55
|
},
|
|
58
56
|
"keywords": [
|
|
59
57
|
"copilotkit",
|
|
@@ -68,14 +66,16 @@
|
|
|
68
66
|
"textarea"
|
|
69
67
|
],
|
|
70
68
|
"scripts": {
|
|
71
|
-
"build": "pnpm run graphql-codegen &&
|
|
72
|
-
"dev": "concurrently \"pnpm run graphql-codegen:watch\" \"
|
|
69
|
+
"build": "pnpm run graphql-codegen && tsdown",
|
|
70
|
+
"dev": "concurrently \"pnpm run graphql-codegen:watch\" \"tsdown --watch\"",
|
|
73
71
|
"test": "vitest run",
|
|
74
72
|
"test:watch": "vitest",
|
|
75
73
|
"check-types": "tsc --noEmit",
|
|
76
74
|
"graphql-codegen": "graphql-codegen -c codegen.ts",
|
|
77
75
|
"graphql-codegen:watch": "graphql-codegen -c codegen.ts --watch",
|
|
78
76
|
"link:global": "pnpm link --global",
|
|
79
|
-
"unlink:global": "pnpm unlink --global"
|
|
77
|
+
"unlink:global": "pnpm unlink --global",
|
|
78
|
+
"publint": "publint .",
|
|
79
|
+
"attw": "attw --pack . --profile node16"
|
|
80
80
|
}
|
|
81
81
|
}
|
|
@@ -1292,4 +1292,74 @@ describe("agui-to-gql", () => {
|
|
|
1292
1292
|
expect((result[0] as any).actionName).toBe("booleanAction");
|
|
1293
1293
|
});
|
|
1294
1294
|
});
|
|
1295
|
+
|
|
1296
|
+
describe("Reasoning Messages", () => {
|
|
1297
|
+
test("should silently skip reasoning messages in aguiToGQL", () => {
|
|
1298
|
+
const aguiMessages: agui.Message[] = [
|
|
1299
|
+
{ id: "user-1", role: "user", content: "Hello" },
|
|
1300
|
+
{
|
|
1301
|
+
id: "reasoning-1",
|
|
1302
|
+
role: "reasoning",
|
|
1303
|
+
content: "thinking about this",
|
|
1304
|
+
} as agui.Message,
|
|
1305
|
+
{ id: "assistant-1", role: "assistant", content: "Hi there" },
|
|
1306
|
+
];
|
|
1307
|
+
|
|
1308
|
+
const result = aguiToGQL(aguiMessages);
|
|
1309
|
+
|
|
1310
|
+
// Only user and assistant messages should be converted; reasoning is skipped
|
|
1311
|
+
expect(result).toHaveLength(2);
|
|
1312
|
+
expect(result[0]).toBeInstanceOf(gql.TextMessage);
|
|
1313
|
+
expect(result[0].id).toBe("user-1");
|
|
1314
|
+
expect(result[1]).toBeInstanceOf(gql.TextMessage);
|
|
1315
|
+
expect(result[1].id).toBe("assistant-1");
|
|
1316
|
+
});
|
|
1317
|
+
|
|
1318
|
+
test("should handle conversation with reasoning messages interleaved", () => {
|
|
1319
|
+
const aguiMessages: agui.Message[] = [
|
|
1320
|
+
{ id: "user-1", role: "user", content: "What is 2+2?" },
|
|
1321
|
+
{
|
|
1322
|
+
id: "reasoning-1",
|
|
1323
|
+
role: "reasoning",
|
|
1324
|
+
content: "Let me calculate...",
|
|
1325
|
+
} as agui.Message,
|
|
1326
|
+
{ id: "assistant-1", role: "assistant", content: "The answer is 4." },
|
|
1327
|
+
{
|
|
1328
|
+
id: "reasoning-2",
|
|
1329
|
+
role: "reasoning",
|
|
1330
|
+
content: "User might ask follow-up",
|
|
1331
|
+
} as agui.Message,
|
|
1332
|
+
{ id: "user-2", role: "user", content: "And 3+3?" },
|
|
1333
|
+
{
|
|
1334
|
+
id: "reasoning-3",
|
|
1335
|
+
role: "reasoning",
|
|
1336
|
+
content: "Another calculation",
|
|
1337
|
+
} as agui.Message,
|
|
1338
|
+
{ id: "assistant-2", role: "assistant", content: "That's 6." },
|
|
1339
|
+
];
|
|
1340
|
+
|
|
1341
|
+
const result = aguiToGQL(aguiMessages);
|
|
1342
|
+
|
|
1343
|
+
// 4 non-reasoning messages: user-1, assistant-1, user-2, assistant-2
|
|
1344
|
+
expect(result).toHaveLength(4);
|
|
1345
|
+
expect(result.map((m) => m.id)).toEqual([
|
|
1346
|
+
"user-1",
|
|
1347
|
+
"assistant-1",
|
|
1348
|
+
"user-2",
|
|
1349
|
+
"assistant-2",
|
|
1350
|
+
]);
|
|
1351
|
+
});
|
|
1352
|
+
|
|
1353
|
+
test("should handle a single reasoning message without throwing", () => {
|
|
1354
|
+
const aguiMessage: agui.Message = {
|
|
1355
|
+
id: "reasoning-only",
|
|
1356
|
+
role: "reasoning",
|
|
1357
|
+
content: "just thinking",
|
|
1358
|
+
} as agui.Message;
|
|
1359
|
+
|
|
1360
|
+
const result = aguiToGQL(aguiMessage);
|
|
1361
|
+
|
|
1362
|
+
expect(result).toHaveLength(0);
|
|
1363
|
+
});
|
|
1364
|
+
});
|
|
1295
1365
|
});
|
|
@@ -118,6 +118,10 @@ export function aguiToGQL(
|
|
|
118
118
|
}
|
|
119
119
|
continue;
|
|
120
120
|
}
|
|
121
|
+
// Reasoning messages are ephemeral display-only content with no GQL equivalent — skip them
|
|
122
|
+
if (message.role === "reasoning") {
|
|
123
|
+
continue;
|
|
124
|
+
}
|
|
121
125
|
// Regular text messages
|
|
122
126
|
if (
|
|
123
127
|
message.role === "developer" ||
|
package/tsdown.config.ts
ADDED
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { defineConfig } from "tsdown";
|
|
2
|
+
|
|
3
|
+
export default defineConfig([
|
|
4
|
+
{
|
|
5
|
+
entry: ["src/index.ts"],
|
|
6
|
+
format: ["esm", "cjs"],
|
|
7
|
+
dts: true,
|
|
8
|
+
sourcemap: true,
|
|
9
|
+
target: "es2022",
|
|
10
|
+
outDir: "dist",
|
|
11
|
+
unbundle: true,
|
|
12
|
+
external: ["react", "@graphql-typed-document-node/core"],
|
|
13
|
+
exclude: ["**/*.test.ts", "**/*.test.tsx", "**/__tests__/*"],
|
|
14
|
+
exports: true,
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
entry: ["src/index.ts"],
|
|
18
|
+
format: ["umd"],
|
|
19
|
+
globalName: "CopilotKitRuntimeClientGQL",
|
|
20
|
+
sourcemap: true,
|
|
21
|
+
target: "es2018",
|
|
22
|
+
outDir: "dist",
|
|
23
|
+
external: [
|
|
24
|
+
"react",
|
|
25
|
+
"@copilotkit/runtime",
|
|
26
|
+
"@copilotkit/shared",
|
|
27
|
+
"urql",
|
|
28
|
+
"@urql/core",
|
|
29
|
+
"graphql",
|
|
30
|
+
"@graphql-typed-document-node/core",
|
|
31
|
+
"untruncate-json",
|
|
32
|
+
],
|
|
33
|
+
codeSplitting: false,
|
|
34
|
+
outputOptions(options) {
|
|
35
|
+
options.entryFileNames = "[name].umd.js";
|
|
36
|
+
options.globals = {
|
|
37
|
+
react: "React",
|
|
38
|
+
"@copilotkit/runtime": "CopilotKitRuntime",
|
|
39
|
+
"@copilotkit/shared": "CopilotKitShared",
|
|
40
|
+
urql: "Urql",
|
|
41
|
+
"@urql/core": "UrqlCore",
|
|
42
|
+
graphql: "GraphQL",
|
|
43
|
+
"@graphql-typed-document-node/core": "GraphQLTypedDocumentNode",
|
|
44
|
+
"untruncate-json": "untruncateJson",
|
|
45
|
+
};
|
|
46
|
+
return options;
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
]);
|
package/dist/chunk-2XWNDVTL.mjs
DELETED
|
@@ -1,176 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
getAvailableAgentsQuery,
|
|
3
|
-
loadAgentStateQuery
|
|
4
|
-
} from "./chunk-QUH7QWUA.mjs";
|
|
5
|
-
import {
|
|
6
|
-
generateCopilotResponseMutation
|
|
7
|
-
} from "./chunk-E5FOLXLN.mjs";
|
|
8
|
-
|
|
9
|
-
// src/client/CopilotRuntimeClient.ts
|
|
10
|
-
import { Client, cacheExchange, fetchExchange } from "@urql/core";
|
|
11
|
-
|
|
12
|
-
// package.json
|
|
13
|
-
var version = "1.51.4";
|
|
14
|
-
|
|
15
|
-
// src/client/CopilotRuntimeClient.ts
|
|
16
|
-
import {
|
|
17
|
-
ResolvedCopilotKitError,
|
|
18
|
-
CopilotKitLowLevelError,
|
|
19
|
-
CopilotKitError,
|
|
20
|
-
CopilotKitVersionMismatchError,
|
|
21
|
-
getPossibleVersionMismatch
|
|
22
|
-
} from "@copilotkit/shared";
|
|
23
|
-
var createFetchFn = (signal, handleGQLWarning) => async (...args) => {
|
|
24
|
-
var _a, _b;
|
|
25
|
-
const publicApiKey = (_b = (_a = args[1]) == null ? void 0 : _a.headers) == null ? void 0 : _b["x-copilotcloud-public-api-key"];
|
|
26
|
-
try {
|
|
27
|
-
const result = await fetch(args[0], { ...args[1] ?? {}, signal });
|
|
28
|
-
const mismatch = publicApiKey ? null : await getPossibleVersionMismatch({
|
|
29
|
-
runtimeVersion: result.headers.get("X-CopilotKit-Runtime-Version"),
|
|
30
|
-
runtimeClientGqlVersion: version
|
|
31
|
-
});
|
|
32
|
-
if (result.status !== 200) {
|
|
33
|
-
if (result.status >= 400 && result.status <= 500) {
|
|
34
|
-
if (mismatch) {
|
|
35
|
-
throw new CopilotKitVersionMismatchError(mismatch);
|
|
36
|
-
}
|
|
37
|
-
throw new ResolvedCopilotKitError({ status: result.status });
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
if (mismatch && handleGQLWarning) {
|
|
41
|
-
handleGQLWarning(mismatch.message);
|
|
42
|
-
}
|
|
43
|
-
return result;
|
|
44
|
-
} catch (error) {
|
|
45
|
-
if (error.message.includes("BodyStreamBuffer was aborted") || error.message.includes("signal is aborted without reason")) {
|
|
46
|
-
throw error;
|
|
47
|
-
}
|
|
48
|
-
if (error instanceof CopilotKitError) {
|
|
49
|
-
throw error;
|
|
50
|
-
}
|
|
51
|
-
throw new CopilotKitLowLevelError({
|
|
52
|
-
error,
|
|
53
|
-
url: args[0]
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
var CopilotRuntimeClient = class {
|
|
58
|
-
constructor(options) {
|
|
59
|
-
const headers = {};
|
|
60
|
-
this.handleGQLErrors = options.handleGQLErrors;
|
|
61
|
-
this.handleGQLWarning = options.handleGQLWarning;
|
|
62
|
-
if (options.headers) {
|
|
63
|
-
Object.assign(headers, options.headers);
|
|
64
|
-
}
|
|
65
|
-
if (options.publicApiKey) {
|
|
66
|
-
headers["x-copilotcloud-public-api-key"] = options.publicApiKey;
|
|
67
|
-
}
|
|
68
|
-
this.client = new Client({
|
|
69
|
-
url: options.url,
|
|
70
|
-
exchanges: [cacheExchange, fetchExchange],
|
|
71
|
-
fetchOptions: {
|
|
72
|
-
headers: {
|
|
73
|
-
...headers,
|
|
74
|
-
"X-CopilotKit-Runtime-Client-GQL-Version": version
|
|
75
|
-
},
|
|
76
|
-
...options.credentials ? { credentials: options.credentials } : {}
|
|
77
|
-
}
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
generateCopilotResponse({
|
|
81
|
-
data,
|
|
82
|
-
properties,
|
|
83
|
-
signal
|
|
84
|
-
}) {
|
|
85
|
-
const fetchFn = createFetchFn(signal, this.handleGQLWarning);
|
|
86
|
-
const result = this.client.mutation(
|
|
87
|
-
generateCopilotResponseMutation,
|
|
88
|
-
{ data, properties },
|
|
89
|
-
{ fetch: fetchFn }
|
|
90
|
-
);
|
|
91
|
-
return result;
|
|
92
|
-
}
|
|
93
|
-
asStream(source) {
|
|
94
|
-
const handleGQLErrors = this.handleGQLErrors;
|
|
95
|
-
return new ReadableStream({
|
|
96
|
-
start(controller) {
|
|
97
|
-
source.subscribe(({ data, hasNext, error }) => {
|
|
98
|
-
var _a;
|
|
99
|
-
if (error) {
|
|
100
|
-
if (error.message.includes("BodyStreamBuffer was aborted") || error.message.includes("signal is aborted without reason")) {
|
|
101
|
-
if (!hasNext)
|
|
102
|
-
controller.close();
|
|
103
|
-
console.warn("Abort error suppressed");
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
if ((_a = error.extensions) == null ? void 0 : _a.visibility) {
|
|
107
|
-
const syntheticError = {
|
|
108
|
-
...error,
|
|
109
|
-
graphQLErrors: [
|
|
110
|
-
{
|
|
111
|
-
message: error.message,
|
|
112
|
-
extensions: error.extensions
|
|
113
|
-
}
|
|
114
|
-
]
|
|
115
|
-
};
|
|
116
|
-
if (handleGQLErrors) {
|
|
117
|
-
handleGQLErrors(syntheticError);
|
|
118
|
-
}
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
controller.error(error);
|
|
122
|
-
if (handleGQLErrors) {
|
|
123
|
-
handleGQLErrors(error);
|
|
124
|
-
}
|
|
125
|
-
} else {
|
|
126
|
-
controller.enqueue(data);
|
|
127
|
-
if (!hasNext) {
|
|
128
|
-
controller.close();
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
});
|
|
132
|
-
}
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
availableAgents() {
|
|
136
|
-
const fetchFn = createFetchFn();
|
|
137
|
-
return this.client.query(
|
|
138
|
-
getAvailableAgentsQuery,
|
|
139
|
-
{},
|
|
140
|
-
{ fetch: fetchFn }
|
|
141
|
-
);
|
|
142
|
-
}
|
|
143
|
-
loadAgentState(data) {
|
|
144
|
-
const fetchFn = createFetchFn();
|
|
145
|
-
const result = this.client.query(
|
|
146
|
-
loadAgentStateQuery,
|
|
147
|
-
{ data },
|
|
148
|
-
{ fetch: fetchFn }
|
|
149
|
-
);
|
|
150
|
-
result.toPromise().then(({ error }) => {
|
|
151
|
-
if (error && this.handleGQLErrors) {
|
|
152
|
-
this.handleGQLErrors(error);
|
|
153
|
-
}
|
|
154
|
-
}).catch(() => {
|
|
155
|
-
});
|
|
156
|
-
return result;
|
|
157
|
-
}
|
|
158
|
-
static removeGraphQLTypename(data) {
|
|
159
|
-
if (Array.isArray(data)) {
|
|
160
|
-
data.forEach((item) => CopilotRuntimeClient.removeGraphQLTypename(item));
|
|
161
|
-
} else if (typeof data === "object" && data !== null) {
|
|
162
|
-
delete data.__typename;
|
|
163
|
-
Object.keys(data).forEach((key) => {
|
|
164
|
-
if (typeof data[key] === "object" && data[key] !== null) {
|
|
165
|
-
CopilotRuntimeClient.removeGraphQLTypename(data[key]);
|
|
166
|
-
}
|
|
167
|
-
});
|
|
168
|
-
}
|
|
169
|
-
return data;
|
|
170
|
-
}
|
|
171
|
-
};
|
|
172
|
-
|
|
173
|
-
export {
|
|
174
|
-
CopilotRuntimeClient
|
|
175
|
-
};
|
|
176
|
-
//# sourceMappingURL=chunk-2XWNDVTL.mjs.map
|