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.
with-langgraph.mp4
- Node.js 18+
- Python 3.8+
- Any of the following package managers:
- OpenAI API Key (for the LangGraph agent)
Note: This repository ignores lock files (package-lock.json, yarn.lock, pnpm-lock.yaml, bun.lockb) to avoid conflicts between different package managers. Each developer should generate their own lock file using their preferred package manager. After that, make sure to delete it from the .gitignore.
- Install dependencies using your preferred package manager:
# Using pnpm (recommended)
pnpm install
# Using npm
npm install
# Using yarn
yarn install
# Using bun
bun install- Set up your environment variables:
cp .env.example .envThen edit the .env file and add your OpenAI API key:
OPENAI_API_KEY=your-openai-api-key-here- Start the development server:
# Using pnpm
pnpm dev
# Using npm
npm run dev
# Using yarn
yarn dev
# Using bun
bun run devThis 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 serverlint- Runs ESLint for code lintinginstall:agent- Installs Python dependencies for the agent
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:
- Catalog — a set of component definitions (schema) paired with React renderers. Registered once in
layout.tsxvia<CopilotKitProvider a2ui={{ catalog: demonstrationCatalog }}>. - Surface — a rendered UI instance. The agent creates a surface, sets its components, and binds data to it.
- Operations — the agent returns
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) | apps/app/src/app/declarative-generative-ui/definitions.ts |
| Catalog renderers (React components) | apps/app/src/app/declarative-generative-ui/renderers.tsx |
| Catalog registration | apps/app/src/app/layout.tsx |
| Fixed-schema agent tool | apps/agent/src/a2ui_fixed_schema.py |
| Dynamic-schema agent tool | apps/agent/src/a2ui_dynamic_schema.py |
| Flight schema JSON | apps/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.
- Create a JSON schema file in
apps/agent/src/a2ui/schemas/describing the component tree. - Create a Python tool that loads the schema with
a2ui.load_schema()and returnsa2ui.render(operations=[...])with your data. Seea2ui_fixed_schema.pyfor 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.
- LangGraph Documentation - Learn more about LangGraph and its features
- CopilotKit Documentation - Explore CopilotKit's capabilities
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:
- The LangGraph agent is running on port 8000
- Your OpenAI API key is set correctly
- Both servers started successfully
If you encounter Python import errors:
npm install:agent