forked from CopilotKit/CopilotKit
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathagent.ts
More file actions
57 lines (51 loc) · 1.82 KB
/
Copy pathagent.ts
File metadata and controls
57 lines (51 loc) · 1.82 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import { z } from "zod";
import { createAgent } from "langchain";
import { ChatOpenAI } from "@langchain/openai";
import {
copilotkitMiddleware,
CopilotKitStateSchema,
zodState,
} from "@copilotkit/sdk-js/langgraph";
import { StateSchema } from "@langchain/langgraph";
import {
stateItem,
stateStreamingMiddleware,
} from "@copilotkit/sdk-js/langgraph-middlewares";
import { todo_tools, TodoSchema } from "./todos.js";
import { query_data } from "./query.js";
import { search_flights } from "./a2ui_fixed_schema.js";
import { generate_a2ui } from "./a2ui_dynamic_schema.js";
const AgentStateSchema = new StateSchema({
todos: zodState(z.array(TodoSchema).default(() => [])),
...(CopilotKitStateSchema.fields as Record<string, any>),
});
const model = new ChatOpenAI({
model: "gpt-5.4",
modelKwargs: { parallel_tool_calls: false },
});
export const graph = createAgent({
model,
tools: [query_data, ...todo_tools, generate_a2ui, search_flights],
middleware: [
copilotkitMiddleware,
stateStreamingMiddleware(
stateItem({
stateKey: "todos",
tool: "manage_todos",
toolArgument: "todos",
}),
),
],
stateSchema: AgentStateSchema,
systemPrompt: `
You are a polished, professional demo assistant. Keep responses to 1-2 sentences.
Tool guidance:
- Flights: call search_flights to show flight cards with a pre-built schema.
- Dashboards & rich UI: call generate_a2ui to create dashboard UIs with metrics,
charts, tables, and cards. It handles rendering automatically.
- Charts: call query_data first, then render with the chart component.
- Todos: enable app mode first, then manage todos.
- A2UI actions: when you see a log_a2ui_event result (e.g. "view_details"),
respond with a brief confirmation. The UI already updated on the frontend.
`,
});