117 lines
3.1 KiB
Markdown
117 lines
3.1 KiB
Markdown
# CopilotKit <> PydanticAI Starter
|
|
|
|
This is a starter template for building AI agents using [PydanticAI](https://ai.pydantic.dev/) and [CopilotKit](https://copilotkit.ai). It provides a modern Next.js application with an integrated investment analyst agent that can research stocks, analyze market data, and provide investment insights.
|
|
|
|
## Prerequisites
|
|
|
|
- OpenAI API Key (for the PydanticAI agent)
|
|
- Python 3.12+
|
|
- uv
|
|
- Node.js 20+
|
|
- Any of the following package managers:
|
|
- pnpm (recommended)
|
|
- npm
|
|
- yarn
|
|
- bun
|
|
|
|
> **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.
|
|
|
|
## Getting Started
|
|
|
|
1. Install dependencies using your preferred package manager:
|
|
```bash
|
|
# Using pnpm (recommended)
|
|
pnpm install
|
|
|
|
# Using npm
|
|
npm install
|
|
|
|
# Using yarn
|
|
yarn install
|
|
|
|
# Using bun
|
|
bun install
|
|
```
|
|
|
|
> **Note:** This will automatically setup the Python environment as well.
|
|
>
|
|
> If you have manual isseus, you can run:
|
|
>
|
|
> ```sh
|
|
> npm run install:agent
|
|
> ```
|
|
|
|
|
|
3. Set up your OpenAI API key:
|
|
|
|
Create a `.env` file inside the `agent` folder with the following content:
|
|
|
|
```
|
|
OPENAI_API_KEY=sk-...your-openai-key-here...
|
|
```
|
|
|
|
|
|
4. Start the development server:
|
|
```bash
|
|
# Using pnpm
|
|
pnpm dev
|
|
|
|
# Using npm
|
|
npm run dev
|
|
|
|
# Using yarn
|
|
yarn dev
|
|
|
|
# Using bun
|
|
bun run dev
|
|
```
|
|
|
|
This will start both the UI and agent servers concurrently.
|
|
|
|
## Available Scripts
|
|
The following scripts can also be run using your preferred package manager:
|
|
- `dev` - Starts both UI and agent servers in development mode
|
|
- `dev:debug` - Starts development servers with debug logging enabled
|
|
- `dev:ui` - Starts only the Next.js UI server
|
|
- `dev:agent` - Starts only the PydanticAI agent server
|
|
- `build` - Builds the Next.js application for production
|
|
- `start` - Starts the production server
|
|
- `lint` - Runs ESLint for code linting
|
|
- `install:agent` - Installs Python dependencies for the agent
|
|
|
|
## Documentation
|
|
|
|
The main UI component is in `src/app/page.tsx`. You can:
|
|
- Modify the theme colors and styling
|
|
- Add new frontend actions
|
|
- Customize the CopilotKit sidebar appearance
|
|
|
|
## 📚 Documentation
|
|
|
|
- [PydanticAI Documentation](https://ai.pydantic.dev) - Learn more about PydanticAI and its features
|
|
- [CopilotKit Documentation](https://docs.copilotkit.ai) - Explore CopilotKit's capabilities
|
|
- [Next.js Documentation](https://nextjs.org/docs) - Learn about Next.js features and API
|
|
|
|
## Contributing
|
|
|
|
Feel free to submit issues and enhancement requests! This starter is designed to be easily extensible.
|
|
|
|
## License
|
|
|
|
This project is licensed under the MIT License - see the LICENSE file for details.
|
|
|
|
## Troubleshooting
|
|
|
|
### Agent Connection Issues
|
|
If you see "I'm having trouble connecting to my tools", make sure:
|
|
1. The PydanticAI agent is running on port 8000
|
|
2. Your OpenAI API key is set correctly
|
|
3. Both servers started successfully
|
|
|
|
### Python Dependencies
|
|
If you encounter Python import errors:
|
|
```bash
|
|
cd agent
|
|
uv sync
|
|
uv run src/main.py
|
|
``` |