examples/integrations/langgraph-python/README.md
This is a starter template for building AI agents using LangGraph and CopilotKit. It provides a modern Next.js application with an integrated LangGraph agent to be built on top of.
https://github.com/user-attachments/assets/47761912-d46a-4fb3-b9bd-cb41ddd02e34
# Using npm (default)
npm install
# Using pnpm
pnpm install
# Using yarn
yarn install
# Using bun
bun install
This will also install the Python agent dependencies via uv sync.
cp .env.example .env
Then edit the .env file and add your OpenAI API key:
OPENAI_API_KEY=your-openai-api-key-here
# Using npm (default)
npm run dev
# Using pnpm
pnpm dev
# Using yarn
yarn dev
# Using bun
bun run dev
This will start both the UI and agent servers concurrently.
The following scripts can also be run using your preferred package manager:
dev - Starts both UI and agent servers in development modedev:debug - Starts development servers with debug logging enableddev:ui - Starts only the Next.js UI serverdev:agent - Starts only the LangGraph agent serverbuild - Builds the Next.js application for productionstart - Starts the production serverinstall:agent - Installs Python dependencies for the agent├── src/ # Next.js frontend source
│ ├── app/
│ │ ├── page.tsx # Main page
│ │ └── api/copilotkit/ # CopilotKit API route
│ ├── components/
│ │ ├── example-canvas/ # Todo list UI
│ │ ├── example-layout/ # Layout: chat + canvas side-by-side
│ │ └── generative-ui/ # Example generative UI components
│ └── hooks/
├── agent/ # LangGraph Python agent
│ ├── main.py # Agent entry point
│ └── src/
│ ├── todos.py # Todo tools and state schema
│ └── query.py # Example data query tool
├── scripts/ # Agent setup and run scripts
│ ├── setup-agent.sh / .bat
│ └── run-agent.sh / .bat
├── public/ # Static assets
├── next.config.ts
├── tsconfig.json
└── package.json
This starter includes A2UI support, allowing the agent to generate rich, interactive UI surfaces declaratively. Instead of returning plain text, the agent sends a JSON description of the UI it wants to render, and the frontend turns it into real components.
A2UI uses three concepts:
layout.tsx via <CopilotKitProvider a2ui={{ catalog: demonstrationCatalog }}>.a2ui.render(operations=[...]) from a tool, which the middleware streams to the frontend.| Pattern | Description | Agent tool | Frontend |
|---|---|---|---|
| Fixed schema | Pre-defined component layout. Only the data changes per invocation. | search_flights | Schema in a2ui/schemas/flight_schema.json |
| Dynamic schema | A secondary LLM generates both components and data based on the conversation. | generate_a2ui | Components decided at runtime |
Both patterns use the same catalog on the frontend — the difference is where the component tree comes from.
| Purpose | Path |
|---|---|
| Catalog definitions (Zod schemas) | src/app/declarative-generative-ui/definitions.ts |
| Catalog renderers (React components) | src/app/declarative-generative-ui/renderers.tsx |
| Catalog registration | src/app/layout.tsx |
| Fixed-schema agent tool | agent/src/a2ui_fixed_schema.py |
| Dynamic-schema agent tool | agent/src/a2ui_dynamic_schema.py |
| Flight schema JSON | agent/src/a2ui/schemas/flight_schema.json |
| Showcase config | showcase.json |
Define the component schema in definitions.ts:
MyWidget: {
description: "A brief description for the agent.",
props: z.object({ title: z.string(), value: z.number() }),
},
Render it in renderers.tsx:
MyWidget: ({ props }) => (
<div>{props.title}: {props.value}</div>
),
Renderers are type-checked against the definitions — TypeScript will error if props don't match.
Use it from the agent. The component is automatically available to both fixed-schema templates and the dynamic-schema LLM.
agent/src/a2ui/schemas/ describing the component tree.a2ui.load_schema() and returns a2ui.render(operations=[...]) with your data. See a2ui_fixed_schema.py for the pattern.showcase.json controls which suggestion pills are visually highlighted. Set "showcase": "a2ui" to highlight the A2UI demos, or "showcase": "default" for no highlights. This is configured automatically when scaffolding via npx copilotkit create --framework a2ui.
Feel free to submit issues and enhancement requests! This starter is designed to be easily extensible.
This project is licensed under the MIT License - see the LICENSE file for details.
If you see "I'm having trouble connecting to my tools", make sure:
If you encounter Python import errors:
npm run install:agent