Stream interface for ReactAgent instances created with createAgent.
Extends UseGraphStream with tool calling capabilities. Tool calls are automatically typed based on the agent's tools configuration.
Use this interface when streaming from an agent created with createAgent.
For subagent streaming capabilities, use UseDeepAgentStream with createDeepAgent.
This interface is subject to change.
interface UseAgentStreamBaseStream<StateType, ToolCall, Bag>This interface adds tool calling on top of UseGraphStream:
toolCalls - Array of tool calls paired with their resultsgetToolCalls(message) - Get tool calls for a specific AI messageIt does NOT include subagent streaming features. For those, use
UseDeepAgentStream with createDeepAgent.
import { createAgent, tool } from "@langchain/langgraph";
import { useStream } from "@langchain/langgraph-sdk/react";
import { z } from "zod";
// Define tools with typed schemas
const searchTool = tool(
async ({ query }) => `Results for: ${query}`,
{ name: "search", schema: z.object({ query: z.string() }) }
);
const calculatorTool = tool(
async ({ expression }) => eval(expression).toString(),
{ name: "calculator", schema: z.object({ expression: z.string() }) }
);
// Create the agent
const agent = createAgent({
model: "gpt-4",
tools: [searchTool, calculatorTool],
});
// In React component:
function Chat() {
const stream = useStream<typeof agent>({
assistantId: "my-agent",
apiUrl: "http://localhost:2024",
});
// Tool calls are typed!
stream.toolCalls.forEach(tc => {
if (tc.call.name === "search") {
// tc.call.args is typed as { query: string }
console.log("Searching for:", tc.call.args.query);
} else if (tc.call.name === "calculator") {
// tc.call.args is typed as { expression: string }
console.log("Calculating:", tc.call.args.expression);
}
});
}The current branch of the thread. Used for navigating between different conversation branches.
LangGraph SDK client used to send requests and receive responses.
Get the metadata for a message, such as first thread state the message was seen in and branch information.
Get tool calls for a specific AI message.
Use this to find which tool calls were initiated by a particular assistant message, useful for rendering tool calls inline with messages.
messages.map(message => {
if (message.type === "ai") {
const calls = stream.getToolCalls(message);
return (
<>
<MessageBubble message={message} />
{calls.map(tc => <ToolCallCard key={tc.call.id} {...tc} />)}
</>
);
}
return <MessageBubble message={message} />;
});Flattened history of thread states of a thread. Contains all states in the current branch's history.
Current interrupt, if the stream is interrupted.
Convenience alias for interrupts[0].
For workflows with multiple concurrent interrupts, use interrupts instead.
Interrupt payloads collected during the run, if any.
Mirrors the in-process run.interrupts.
Whether the stream is currently running.
true while streaming, false when idle or completed.
Whether the thread is currently being loaded.
true during initial thread data fetch.
Join an active stream that's already running.
Server-side submission queue. Pending runs created via
multitaskStrategy: "enqueue" when submitting while the agent is busy.
Set the branch of the thread.
Stops the currently running stream.
Create and stream a run to the thread.
Switch to a different thread, clearing the current stream state.
Pass null to reset to no thread (a new thread will be created on next submit).
Progress of tool executions during streaming. Populated when stream mode includes "tools" and tools yield or report progress.
The current branch of the thread.
LangGraph SDK client used to send requests and receive responses.
Tree of all branches for the thread.
Get the metadata for a message, such as first thread state the message
Flattened history of thread states of a thread.
Current interrupt, if the stream is interrupted.
Interrupt payloads collected during the run, if any.
Whether the stream is currently running.
Whether the thread is currently being loaded.
Join an active stream that's already running.
Server-side submission queue. Pending runs created via
Set the branch of the thread.
Stops the currently running stream.
Create and stream a run to the thread.
Switch to a different thread, clearing the current stream state.
Progress of tool executions during streaming. Populated when stream mode includes "tools"