experimental-agent 0.5.0 → 0.6.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/dist/{adapter-Cl735Kp4.d.mts → adapter-txsF6hou.d.mts} +2 -0
- package/dist/{adapter-Cl735Kp4.d.ts → adapter-txsF6hou.d.ts} +2 -0
- package/dist/{chunk-AB2JYY6A.mjs → chunk-CCWLV27N.mjs} +10 -2
- package/dist/chunk-CS2SEUAA.mjs +405 -0
- package/dist/{chunk-6MS4CGEZ.mjs → chunk-D35AQN7O.mjs} +5 -5
- package/dist/chunk-LZOMFHX3.mjs +38 -0
- package/dist/chunk-PH2FXKOU.mjs +9 -0
- package/dist/client-B2ohNvwc.d.mts +494 -0
- package/dist/client-BbQZtxca.d.ts +494 -0
- package/dist/client.mjs +1 -1
- package/dist/{docker-OBUQX5ZI.mjs → docker-FCSNVBEQ.mjs} +1 -1
- package/dist/{entry-Bs17QEiq.d.mts → entry-BUiucCNp.d.mts} +1 -1
- package/dist/{entry-QNyd4S1s.d.ts → entry-ok9EBUS3.d.ts} +1 -1
- package/dist/index.d.mts +475 -475
- package/dist/index.d.ts +475 -475
- package/dist/index.js +16595 -245
- package/dist/index.mjs +16406 -117
- package/dist/lifecycle-workflow-steps.d.mts +2 -2
- package/dist/lifecycle-workflow-steps.d.ts +2 -2
- package/dist/lifecycle-workflow-steps.mjs +1 -1
- package/dist/lifecycle-workflow.d.mts +2 -2
- package/dist/lifecycle-workflow.d.ts +2 -2
- package/dist/lifecycle-workflow.mjs +1 -1
- package/dist/{local-4C3V4EFS.mjs → local-NXHIUJTO.mjs} +1 -1
- package/dist/next/loader.js +10 -2
- package/dist/next/loader.mjs +2 -2
- package/dist/next.js +10 -2
- package/dist/next.mjs +2 -2
- package/dist/{process-manager-WQHAIVRB.mjs → process-manager-26NELLRU.mjs} +1 -1
- package/dist/react.d.mts +56 -0
- package/dist/react.d.ts +56 -0
- package/dist/react.js +144 -0
- package/dist/react.mjs +117 -0
- package/dist/sandbox.d.mts +3 -3
- package/dist/sandbox.d.ts +3 -3
- package/dist/sandbox.js +5 -5
- package/dist/sandbox.mjs +2 -2
- package/dist/{steps-XA4wG8W3.d.ts → steps-BOKeU8X3.d.ts} +3 -2
- package/dist/{steps-eTytqxQb.d.mts → steps-Mi3sjYbD.d.mts} +3 -2
- package/dist/storage.d.mts +2 -2
- package/dist/storage.d.ts +2 -2
- package/dist/storage.js +107 -48
- package/dist/storage.mjs +2 -2
- package/dist/{vercel-6ORAC625.mjs → vercel-BOGHAFI4.mjs} +2 -2
- package/package.json +9 -1
- package/dist/chunk-BJTO5JO5.mjs +0 -11
- package/dist/chunk-I5DCB7RU.mjs +0 -346
package/dist/react.js
ADDED
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/react/index.ts
|
|
21
|
+
var react_exports = {};
|
|
22
|
+
__export(react_exports, {
|
|
23
|
+
useAgent: () => useAgent,
|
|
24
|
+
useInterruptSession: () => useInterruptSession,
|
|
25
|
+
useSessionHistory: () => useSessionHistory
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(react_exports);
|
|
28
|
+
|
|
29
|
+
// src/react/use-agent.ts
|
|
30
|
+
var import_react = require("@ai-sdk/react");
|
|
31
|
+
var import_ai = require("ai");
|
|
32
|
+
var import_react2 = require("react");
|
|
33
|
+
|
|
34
|
+
// src/rpc/base-path.ts
|
|
35
|
+
function basePathForAgent(agent) {
|
|
36
|
+
return `/api/agents/${agent}`;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
// src/react/use-agent.ts
|
|
40
|
+
function useAgent(name, {
|
|
41
|
+
headers,
|
|
42
|
+
id,
|
|
43
|
+
...options
|
|
44
|
+
} = {}) {
|
|
45
|
+
const basePath = options.basePath ?? basePathForAgent(name);
|
|
46
|
+
const [agentStatus, setAgentStatus] = (0, import_react2.useState)(null);
|
|
47
|
+
const onData = (0, import_react2.useRef)(options.onData);
|
|
48
|
+
(0, import_react2.useEffect)(() => {
|
|
49
|
+
onData.current = options.onData;
|
|
50
|
+
}, [options.onData]);
|
|
51
|
+
const chat = (0, import_react.useChat)({
|
|
52
|
+
chat: (0, import_react2.useMemo)(
|
|
53
|
+
() => new import_react.Chat({
|
|
54
|
+
id,
|
|
55
|
+
transport: new import_ai.DefaultChatTransport({
|
|
56
|
+
api: basePath,
|
|
57
|
+
prepareSendMessagesRequest: async ({ messages }) => {
|
|
58
|
+
const h = await (typeof headers === "function" ? headers() : headers);
|
|
59
|
+
const lastAssistant = messages.findLast(
|
|
60
|
+
(m) => m.role === "assistant"
|
|
61
|
+
);
|
|
62
|
+
const lastPartContent = lastAssistant?.parts.at(-1);
|
|
63
|
+
const lastPart = lastAssistant && lastPartContent != null ? {
|
|
64
|
+
index: lastAssistant.parts.length - 1,
|
|
65
|
+
part: lastPartContent
|
|
66
|
+
} : void 0;
|
|
67
|
+
const body = {
|
|
68
|
+
message: messages.at(-1),
|
|
69
|
+
interruptIfStreaming: lastPart ? { lastPart } : true
|
|
70
|
+
};
|
|
71
|
+
return {
|
|
72
|
+
body,
|
|
73
|
+
headers: new Headers(h),
|
|
74
|
+
api: `${basePath}/${id}`
|
|
75
|
+
};
|
|
76
|
+
},
|
|
77
|
+
prepareReconnectToStreamRequest: async (request) => {
|
|
78
|
+
const h = await (typeof headers === "function" ? headers() : headers);
|
|
79
|
+
return {
|
|
80
|
+
...request,
|
|
81
|
+
api: `${basePath}/${id}/reconnect`,
|
|
82
|
+
headers: h
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
}),
|
|
86
|
+
onData: (_part) => {
|
|
87
|
+
const part = _part;
|
|
88
|
+
if (part.type === "data-status") {
|
|
89
|
+
setAgentStatus(part.data);
|
|
90
|
+
}
|
|
91
|
+
onData.current?.(part);
|
|
92
|
+
}
|
|
93
|
+
}),
|
|
94
|
+
[id, basePath, headers]
|
|
95
|
+
)
|
|
96
|
+
});
|
|
97
|
+
return {
|
|
98
|
+
chat,
|
|
99
|
+
agentStatus
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
// src/react/use-history-query.ts
|
|
104
|
+
var import_react_query2 = require("@tanstack/react-query");
|
|
105
|
+
|
|
106
|
+
// src/react/use-query.ts
|
|
107
|
+
var import_react_query = require("@tanstack/react-query");
|
|
108
|
+
var client = new import_react_query.QueryClient();
|
|
109
|
+
function useQuery(options) {
|
|
110
|
+
return (0, import_react_query.useQuery)(options, client);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
// src/react/use-history-query.ts
|
|
114
|
+
function useSessionHistory(options) {
|
|
115
|
+
return useQuery({
|
|
116
|
+
...options.options,
|
|
117
|
+
queryKey: ["history", options.sessionId],
|
|
118
|
+
queryFn: options.sessionId ? async () => {
|
|
119
|
+
const path = `${options.basePath}/${options.sessionId}`;
|
|
120
|
+
return await fetch(path).then((res) => res.json());
|
|
121
|
+
} : import_react_query2.skipToken
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// src/react/use-interrupt.ts
|
|
126
|
+
var import_react_query3 = require("@tanstack/react-query");
|
|
127
|
+
function useInterruptSession(options) {
|
|
128
|
+
return (0, import_react_query3.useMutation)({
|
|
129
|
+
mutationFn: async (input) => {
|
|
130
|
+
const path = `${options.basePath}/${options.sessionId}/interrupt`;
|
|
131
|
+
return await fetch(path, {
|
|
132
|
+
method: "POST",
|
|
133
|
+
body: JSON.stringify(input)
|
|
134
|
+
}).then((res) => res.json());
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
139
|
+
0 && (module.exports = {
|
|
140
|
+
useAgent,
|
|
141
|
+
useInterruptSession,
|
|
142
|
+
useSessionHistory
|
|
143
|
+
});
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/react/index.ts", "../src/react/use-agent.ts", "../src/rpc/base-path.ts", "../src/react/use-history-query.ts", "../src/react/use-query.ts", "../src/react/use-interrupt.ts"],
  "sourcesContent": ["export { useAgent } from \"./use-agent\";\nexport { useSessionHistory } from \"./use-history-query\";\nexport { useInterruptSession } from \"./use-interrupt\";\n", "import { Chat, useChat } from \"@ai-sdk/react\";\nimport { DefaultChatTransport } from \"ai\";\nimport { useEffect, useMemo, useRef, useState } from \"react\";\nimport type { AgentStatus, AnyAgent } from \"../agent/client\";\nimport { basePathForAgent } from \"../rpc/base-path\";\n\ntype DataEvent = {\n  type: \"data-status\";\n  data: AgentStatus;\n};\n\nexport function useAgent<Agent extends AnyAgent>(\n  name: Agent[\"name\"],\n  {\n    headers,\n    id,\n    ...options\n  }: {\n    basePath?: string;\n    headers?: HeadersInit | (() => Promise<HeadersInit>);\n    id?: string;\n    onData?: (data: DataEvent) => void;\n  } = {}\n) {\n  const basePath = options.basePath ?? basePathForAgent(name);\n  const [agentStatus, setAgentStatus] = useState<AgentStatus | null>(null);\n  const onData = useRef(options.onData);\n  useEffect(() => {\n    onData.current = options.onData;\n  }, [options.onData]);\n  const chat = useChat<Agent[\"$UIMessage\"]>({\n    chat: useMemo(\n      () =>\n        new Chat({\n          id,\n          transport: new DefaultChatTransport({\n            api: basePath,\n            prepareSendMessagesRequest: async ({ messages }) => {\n              const h = await (typeof headers === \"function\"\n                ? headers()\n                : headers);\n              const lastAssistant = messages.findLast(\n                (m) => m.role === \"assistant\"\n              );\n              const lastPartContent = lastAssistant?.parts.at(-1);\n              const lastPart =\n                lastAssistant && lastPartContent != null\n                  ? {\n                      index: lastAssistant.parts.length - 1,\n                      part: lastPartContent,\n                    }\n                  : undefined;\n              const body: Record<string, unknown> = {\n                message: messages.at(-1),\n                interruptIfStreaming: lastPart ? { lastPart } : true,\n              };\n              return {\n                body,\n                headers: new Headers(h),\n                api: `${basePath}/${id}`,\n              };\n            },\n            prepareReconnectToStreamRequest: async (request) => {\n              const h = await (typeof headers === \"function\"\n                ? headers()\n                : headers);\n              return {\n                ...request,\n                api: `${basePath}/${id}/reconnect`,\n                headers: h,\n              };\n            },\n          }),\n          onData: (_part) => {\n            const part = _part as unknown as DataEvent;\n            if (part.type === \"data-status\") {\n              setAgentStatus(part.data);\n            }\n            onData.current?.(part);\n          },\n        }),\n      [id, basePath, headers]\n    ),\n  });\n\n  return {\n    chat,\n    agentStatus,\n  };\n}\n", "export type BasePath = `/api/agents/[agent]`;\nexport type SessionPath = `${BasePath | (string & {})}/[sessionId]`;\nexport type ReconnectPath = `${SessionPath | (string & {})}/reconnect`;\nexport type InterruptPath = `${SessionPath | (string & {})}/interrupt`;\n\nexport type Path = SessionPath | ReconnectPath | InterruptPath;\n\nexport function basePathForAgent(agent: string) {\n  return `/api/agents/${agent}` as const;\n}\n", "import { type QueryOptions, skipToken } from \"@tanstack/react-query\";\nimport type { AnyAgent } from \"../agent/client\";\nimport { useQuery } from \"./use-query\";\n\ntype Response<Agent extends AnyAgent> = Awaited<\n  ReturnType<ReturnType<Agent[\"session\"]>[\"history\"]>\n>;\n\nexport function useSessionHistory<Agent extends AnyAgent>(options: {\n  basePath?: string;\n  sessionId: string | undefined;\n  options?: Omit<QueryOptions<Response<Agent>>, \"queryKey\" | \"queryFn\">;\n}) {\n  return useQuery<Response<Agent>>({\n    ...options.options,\n    queryKey: [\"history\", options.sessionId],\n    queryFn: options.sessionId\n      ? async () => {\n          const path = `${options.basePath}/${options.sessionId}`;\n          return await fetch(path).then((res) => res.json());\n        }\n      : skipToken,\n  });\n}\n", "import {\n  QueryClient,\n  type UseMutationOptions,\n  type UseQueryOptions,\n  useMutation as useUpstreamMutation,\n  useQuery as useUpstreamQuery,\n} from \"@tanstack/react-query\";\n\nconst client = new QueryClient();\n\nexport function useQuery<T>(options: UseQueryOptions<T>) {\n  return useUpstreamQuery<T>(options, client);\n}\n\nexport function useMutation<T, Variables, Error, Data>(\n  options: UseMutationOptions<T, Variables, Error, Data>\n) {\n  return useUpstreamMutation<T, Variables, Error, Data>(options, client);\n}\n", "import { useMutation } from \"@tanstack/react-query\";\nimport type { AnyAgent } from \"../agent/client\";\n\ntype Fn<Agent extends AnyAgent> = ReturnType<Agent[\"session\"]>[\"interrupt\"];\ntype Response<Agent extends AnyAgent> = Awaited<ReturnType<Fn<Agent>>>;\ntype Variables<Agent extends AnyAgent> = Parameters<Fn<Agent>>[0];\n\nexport function useInterruptSession<Agent extends AnyAgent>(options: {\n  basePath?: string;\n  sessionId: string;\n}) {\n  return useMutation<Response<Agent>, Error, Variables<Agent>, void>({\n    mutationFn: async (input) => {\n      const path = `${options.basePath}/${options.sessionId}/interrupt`;\n      return await fetch(path, {\n        method: \"POST\",\n        body: JSON.stringify(input),\n      }).then((res) => res.json());\n    },\n  });\n}\n"],
  "mappings": "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",
  "names": ["import_react", "import_react_query", "useUpstreamQuery", "import_react_query"]
}

|
package/dist/react.mjs
ADDED
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import {
|
|
2
|
+
basePathForAgent
|
|
3
|
+
} from "./chunk-PH2FXKOU.mjs";
|
|
4
|
+
import "./chunk-LZOMFHX3.mjs";
|
|
5
|
+
|
|
6
|
+
// src/react/use-agent.ts
|
|
7
|
+
import { Chat, useChat } from "@ai-sdk/react";
|
|
8
|
+
import { DefaultChatTransport } from "ai";
|
|
9
|
+
import { useEffect, useMemo, useRef, useState } from "react";
|
|
10
|
+
function useAgent(name, {
|
|
11
|
+
headers,
|
|
12
|
+
id,
|
|
13
|
+
...options
|
|
14
|
+
} = {}) {
|
|
15
|
+
const basePath = options.basePath ?? basePathForAgent(name);
|
|
16
|
+
const [agentStatus, setAgentStatus] = useState(null);
|
|
17
|
+
const onData = useRef(options.onData);
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
onData.current = options.onData;
|
|
20
|
+
}, [options.onData]);
|
|
21
|
+
const chat = useChat({
|
|
22
|
+
chat: useMemo(
|
|
23
|
+
() => new Chat({
|
|
24
|
+
id,
|
|
25
|
+
transport: new DefaultChatTransport({
|
|
26
|
+
api: basePath,
|
|
27
|
+
prepareSendMessagesRequest: async ({ messages }) => {
|
|
28
|
+
const h = await (typeof headers === "function" ? headers() : headers);
|
|
29
|
+
const lastAssistant = messages.findLast(
|
|
30
|
+
(m) => m.role === "assistant"
|
|
31
|
+
);
|
|
32
|
+
const lastPartContent = lastAssistant?.parts.at(-1);
|
|
33
|
+
const lastPart = lastAssistant && lastPartContent != null ? {
|
|
34
|
+
index: lastAssistant.parts.length - 1,
|
|
35
|
+
part: lastPartContent
|
|
36
|
+
} : void 0;
|
|
37
|
+
const body = {
|
|
38
|
+
message: messages.at(-1),
|
|
39
|
+
interruptIfStreaming: lastPart ? { lastPart } : true
|
|
40
|
+
};
|
|
41
|
+
return {
|
|
42
|
+
body,
|
|
43
|
+
headers: new Headers(h),
|
|
44
|
+
api: `${basePath}/${id}`
|
|
45
|
+
};
|
|
46
|
+
},
|
|
47
|
+
prepareReconnectToStreamRequest: async (request) => {
|
|
48
|
+
const h = await (typeof headers === "function" ? headers() : headers);
|
|
49
|
+
return {
|
|
50
|
+
...request,
|
|
51
|
+
api: `${basePath}/${id}/reconnect`,
|
|
52
|
+
headers: h
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
}),
|
|
56
|
+
onData: (_part) => {
|
|
57
|
+
const part = _part;
|
|
58
|
+
if (part.type === "data-status") {
|
|
59
|
+
setAgentStatus(part.data);
|
|
60
|
+
}
|
|
61
|
+
onData.current?.(part);
|
|
62
|
+
}
|
|
63
|
+
}),
|
|
64
|
+
[id, basePath, headers]
|
|
65
|
+
)
|
|
66
|
+
});
|
|
67
|
+
return {
|
|
68
|
+
chat,
|
|
69
|
+
agentStatus
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
// src/react/use-history-query.ts
|
|
74
|
+
import { skipToken } from "@tanstack/react-query";
|
|
75
|
+
|
|
76
|
+
// src/react/use-query.ts
|
|
77
|
+
import {
|
|
78
|
+
QueryClient,
|
|
79
|
+
useMutation as useUpstreamMutation,
|
|
80
|
+
useQuery as useUpstreamQuery
|
|
81
|
+
} from "@tanstack/react-query";
|
|
82
|
+
var client = new QueryClient();
|
|
83
|
+
function useQuery(options) {
|
|
84
|
+
return useUpstreamQuery(options, client);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
// src/react/use-history-query.ts
|
|
88
|
+
function useSessionHistory(options) {
|
|
89
|
+
return useQuery({
|
|
90
|
+
...options.options,
|
|
91
|
+
queryKey: ["history", options.sessionId],
|
|
92
|
+
queryFn: options.sessionId ? async () => {
|
|
93
|
+
const path = `${options.basePath}/${options.sessionId}`;
|
|
94
|
+
return await fetch(path).then((res) => res.json());
|
|
95
|
+
} : skipToken
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
// src/react/use-interrupt.ts
|
|
100
|
+
import { useMutation } from "@tanstack/react-query";
|
|
101
|
+
function useInterruptSession(options) {
|
|
102
|
+
return useMutation({
|
|
103
|
+
mutationFn: async (input) => {
|
|
104
|
+
const path = `${options.basePath}/${options.sessionId}/interrupt`;
|
|
105
|
+
return await fetch(path, {
|
|
106
|
+
method: "POST",
|
|
107
|
+
body: JSON.stringify(input)
|
|
108
|
+
}).then((res) => res.json());
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
export {
|
|
113
|
+
useAgent,
|
|
114
|
+
useInterruptSession,
|
|
115
|
+
useSessionHistory
|
|
116
|
+
};
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/react/use-agent.ts", "../src/react/use-history-query.ts", "../src/react/use-query.ts", "../src/react/use-interrupt.ts"],
  "sourcesContent": ["import { Chat, useChat } from \"@ai-sdk/react\";\nimport { DefaultChatTransport } from \"ai\";\nimport { useEffect, useMemo, useRef, useState } from \"react\";\nimport type { AgentStatus, AnyAgent } from \"../agent/client\";\nimport { basePathForAgent } from \"../rpc/base-path\";\n\ntype DataEvent = {\n  type: \"data-status\";\n  data: AgentStatus;\n};\n\nexport function useAgent<Agent extends AnyAgent>(\n  name: Agent[\"name\"],\n  {\n    headers,\n    id,\n    ...options\n  }: {\n    basePath?: string;\n    headers?: HeadersInit | (() => Promise<HeadersInit>);\n    id?: string;\n    onData?: (data: DataEvent) => void;\n  } = {}\n) {\n  const basePath = options.basePath ?? basePathForAgent(name);\n  const [agentStatus, setAgentStatus] = useState<AgentStatus | null>(null);\n  const onData = useRef(options.onData);\n  useEffect(() => {\n    onData.current = options.onData;\n  }, [options.onData]);\n  const chat = useChat<Agent[\"$UIMessage\"]>({\n    chat: useMemo(\n      () =>\n        new Chat({\n          id,\n          transport: new DefaultChatTransport({\n            api: basePath,\n            prepareSendMessagesRequest: async ({ messages }) => {\n              const h = await (typeof headers === \"function\"\n                ? headers()\n                : headers);\n              const lastAssistant = messages.findLast(\n                (m) => m.role === \"assistant\"\n              );\n              const lastPartContent = lastAssistant?.parts.at(-1);\n              const lastPart =\n                lastAssistant && lastPartContent != null\n                  ? {\n                      index: lastAssistant.parts.length - 1,\n                      part: lastPartContent,\n                    }\n                  : undefined;\n              const body: Record<string, unknown> = {\n                message: messages.at(-1),\n                interruptIfStreaming: lastPart ? { lastPart } : true,\n              };\n              return {\n                body,\n                headers: new Headers(h),\n                api: `${basePath}/${id}`,\n              };\n            },\n            prepareReconnectToStreamRequest: async (request) => {\n              const h = await (typeof headers === \"function\"\n                ? headers()\n                : headers);\n              return {\n                ...request,\n                api: `${basePath}/${id}/reconnect`,\n                headers: h,\n              };\n            },\n          }),\n          onData: (_part) => {\n            const part = _part as unknown as DataEvent;\n            if (part.type === \"data-status\") {\n              setAgentStatus(part.data);\n            }\n            onData.current?.(part);\n          },\n        }),\n      [id, basePath, headers]\n    ),\n  });\n\n  return {\n    chat,\n    agentStatus,\n  };\n}\n", "import { type QueryOptions, skipToken } from \"@tanstack/react-query\";\nimport type { AnyAgent } from \"../agent/client\";\nimport { useQuery } from \"./use-query\";\n\ntype Response<Agent extends AnyAgent> = Awaited<\n  ReturnType<ReturnType<Agent[\"session\"]>[\"history\"]>\n>;\n\nexport function useSessionHistory<Agent extends AnyAgent>(options: {\n  basePath?: string;\n  sessionId: string | undefined;\n  options?: Omit<QueryOptions<Response<Agent>>, \"queryKey\" | \"queryFn\">;\n}) {\n  return useQuery<Response<Agent>>({\n    ...options.options,\n    queryKey: [\"history\", options.sessionId],\n    queryFn: options.sessionId\n      ? async () => {\n          const path = `${options.basePath}/${options.sessionId}`;\n          return await fetch(path).then((res) => res.json());\n        }\n      : skipToken,\n  });\n}\n", "import {\n  QueryClient,\n  type UseMutationOptions,\n  type UseQueryOptions,\n  useMutation as useUpstreamMutation,\n  useQuery as useUpstreamQuery,\n} from \"@tanstack/react-query\";\n\nconst client = new QueryClient();\n\nexport function useQuery<T>(options: UseQueryOptions<T>) {\n  return useUpstreamQuery<T>(options, client);\n}\n\nexport function useMutation<T, Variables, Error, Data>(\n  options: UseMutationOptions<T, Variables, Error, Data>\n) {\n  return useUpstreamMutation<T, Variables, Error, Data>(options, client);\n}\n", "import { useMutation } from \"@tanstack/react-query\";\nimport type { AnyAgent } from \"../agent/client\";\n\ntype Fn<Agent extends AnyAgent> = ReturnType<Agent[\"session\"]>[\"interrupt\"];\ntype Response<Agent extends AnyAgent> = Awaited<ReturnType<Fn<Agent>>>;\ntype Variables<Agent extends AnyAgent> = Parameters<Fn<Agent>>[0];\n\nexport function useInterruptSession<Agent extends AnyAgent>(options: {\n  basePath?: string;\n  sessionId: string;\n}) {\n  return useMutation<Response<Agent>, Error, Variables<Agent>, void>({\n    mutationFn: async (input) => {\n      const path = `${options.basePath}/${options.sessionId}/interrupt`;\n      return await fetch(path, {\n        method: \"POST\",\n        body: JSON.stringify(input),\n      }).then((res) => res.json());\n    },\n  });\n}\n"],
  "mappings": "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",
  "names": []
}

|
package/dist/sandbox.d.mts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { E as ExecResult,
|
|
2
|
-
export { d as dockerSandbox, l as localSandbox, v as vercelSandbox } from './entry-
|
|
1
|
+
export { E as ExecResult, S as SandboxAgentRef, a as SandboxBinding, b as SandboxInstance, c as SandboxSetupFields, U as UploadableFile } from './steps-Mi3sjYbD.mjs';
|
|
2
|
+
export { d as dockerSandbox, l as localSandbox, v as vercelSandbox } from './entry-BUiucCNp.mjs';
|
|
3
3
|
import '@vercel/sandbox';
|
|
4
|
-
import './adapter-
|
|
4
|
+
import './adapter-txsF6hou.mjs';
|
|
5
5
|
import '@workflow/serde';
|
|
6
6
|
import 'ai';
|
package/dist/sandbox.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { E as ExecResult,
|
|
2
|
-
export { d as dockerSandbox, l as localSandbox, v as vercelSandbox } from './entry-
|
|
1
|
+
export { E as ExecResult, S as SandboxAgentRef, a as SandboxBinding, b as SandboxInstance, c as SandboxSetupFields, U as UploadableFile } from './steps-BOKeU8X3.js';
|
|
2
|
+
export { d as dockerSandbox, l as localSandbox, v as vercelSandbox } from './entry-ok9EBUS3.js';
|
|
3
3
|
import '@vercel/sandbox';
|
|
4
|
-
import './adapter-
|
|
4
|
+
import './adapter-txsF6hou.js';
|
|
5
5
|
import '@workflow/serde';
|
|
6
6
|
import 'ai';
|