examples/integrations/langgraph-js/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 (TypeScript) 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 also installs the agent dependencies via npm install inside agent/.
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 agent (Node) dependencies├── 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 TypeScript agent
│ ├── src/
│ │ ├── agent.ts # Agent entry point (createAgent)
│ │ ├── todos.ts # Todo tools and state schema
│ │ ├── query.ts # Example data query tool
│ │ ├── a2ui.ts # A2UI operation helpers
│ │ ├── a2ui_fixed_schema.ts # Fixed-schema A2UI tool (flights)
│ │ └── a2ui_dynamic_schema.ts # Dynamic-schema A2UI tool
│ └── langgraph.json
├── scripts/ # Agent run scripts
│ └── 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 }}>.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.ts |
| Dynamic-schema agent tool | agent/src/a2ui_dynamic_schema.ts |
| 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.loadSchema() and returns render([...]) with your data. See a2ui_fixed_schema.ts 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 agent import errors:
npm run install:agent