2025-03-23 15:03:38 +00:00
# Next AI Draw.io
2025-12-02 22:53:31 +09:00
< div align = "center" >
2025-03-23 15:03:38 +00:00
2025-12-02 22:53:31 +09:00
**AI-Powered Diagram Creation Tool - Chat, Draw, Visualize**
2025-12-08 12:08:35 +09:00
English | [中文 ](./docs/README_CN.md ) | [日本語 ](./docs/README_JA.md )
2025-12-02 22:53:31 +09:00
2025-12-08 11:48:14 +09:00
[](https://next-ai-drawio.jiang.jp/)
[](https://opensource.org/licenses/Apache-2.0)
[](https://nextjs.org/)
[](https://react.dev/)
2025-12-02 22:53:31 +09:00
[](https://github.com/sponsors/DayuanJiang)
2025-12-08 11:48:14 +09:00
[](https://next-ai-drawio.jiang.jp/)
2025-12-02 22:53:31 +09:00
< / div >
2025-11-10 11:42:38 +09:00
2025-12-02 22:53:31 +09:00
A Next.js web application that integrates AI capabilities with draw.io diagrams. Create, modify, and enhance diagrams through natural language commands and AI-assisted visualization.
2025-12-29 11:30:58 +09:00
> Note: Thanks to <img src="https://raw.githubusercontent.com/DayuanJiang/next-ai-draw-io/main/public/doubao-color.png" alt="" height="20" /> [ByteDance Doubao](https://console.volcengine.com/ark/region:ark+cn-beijing/overview?briefPage=0&briefType=introduce&type=new&utm_campaign=doubao&utm_content=aidrawio&utm_medium=github&utm_source=coopensrc&utm_term=project) sponsorship, the demo site now uses the powerful K2-thinking model!
2025-12-11 12:25:00 +09:00
https://github.com/user-attachments/assets/9d60a3e8-4a1c-4b5e-acbb-26af2d3eabd1
2025-03-23 15:28:05 +00:00
2025-12-08 11:48:14 +09:00
## Table of Contents
2025-12-29 11:30:58 +09:00
- [Next AI Draw.io ](#next-ai-drawio )
2025-12-08 11:48:14 +09:00
- [Table of Contents ](#table-of-contents )
- [Examples ](#examples )
- [Features ](#features )
2025-12-17 14:50:07 +09:00
- [MCP Server (Preview) ](#mcp-server-preview )
2025-12-29 11:30:58 +09:00
- [Claude Code CLI ](#claude-code-cli )
2025-12-08 11:48:14 +09:00
- [Getting Started ](#getting-started )
- [Try it Online ](#try-it-online )
2025-12-22 10:39:28 +09:00
- [Desktop Application ](#desktop-application )
2025-12-08 11:48:14 +09:00
- [Run with Docker (Recommended) ](#run-with-docker-recommended )
- [Installation ](#installation )
- [Deployment ](#deployment )
2025-12-29 11:30:58 +09:00
- [Deploy on Vercel (Recommended) ](#deploy-on-vercel-recommended )
- [Deploy on Cloudflare Workers ](#deploy-on-cloudflare-workers )
2025-12-08 11:48:14 +09:00
- [Multi-Provider Support ](#multi-provider-support )
- [How It Works ](#how-it-works )
- [Project Structure ](#project-structure )
- [Support \& Contact ](#support--contact )
- [Star History ](#star-history )
## Examples
2025-11-17 15:12:16 +09:00
Here are some example prompts and their generated diagrams:
2025-11-17 19:35:55 +09:00
< div align = "center" >
< table width = "100%" >
2025-12-02 22:53:31 +09:00
< tr >
< td colspan = "2" valign = "top" align = "center" >
< strong > Animated transformer connectors< / strong > < br / >
< p >< strong > Prompt:</ strong > Give me a **animated connector** diagram of transformer's architecture.</ p >
< img src = "./public/animated_connectors.svg" alt = "Transformer Architecture with Animated Connectors" width = "480" / >
< / td >
< / tr >
2025-11-17 19:35:55 +09:00
< tr >
< td width = "50%" valign = "top" >
< strong > GCP architecture diagram< / strong > < br / >
< p >< strong > Prompt:</ strong > Generate a GCP architecture diagram with **GCP icons** . In this diagram, users connect to a frontend hosted on an instance.</ p >
< img src = "./public/gcp_demo.svg" alt = "GCP Architecture Diagram" width = "480" / >
< / td >
< td width = "50%" valign = "top" >
< strong > AWS architecture diagram< / strong > < br / >
< p >< strong > Prompt:</ strong > Generate a AWS architecture diagram with **AWS icons** . In this diagram, users connect to a frontend hosted on an instance.</ p >
< img src = "./public/aws_demo.svg" alt = "AWS Architecture Diagram" width = "480" / >
< / td >
< / tr >
< tr >
< td width = "50%" valign = "top" >
< strong > Azure architecture diagram< / strong > < br / >
< p >< strong > Prompt:</ strong > Generate a Azure architecture diagram with **Azure icons** . In this diagram, users connect to a frontend hosted on an instance.</ p >
< img src = "./public/azure_demo.svg" alt = "Azure Architecture Diagram" width = "480" / >
< / td >
< td width = "50%" valign = "top" >
< strong > Cat sketch prompt< / strong > < br / >
< p > < strong > Prompt:< / strong > Draw a cute cat for me.< / p >
2025-12-02 22:53:31 +09:00
< img src = "./public/cat_demo.svg" alt = "Cat Drawing" width = "240" / >
2025-11-17 19:35:55 +09:00
< / td >
< / tr >
2025-11-17 15:12:16 +09:00
< / table >
2025-11-17 19:35:55 +09:00
< / div >
2025-03-19 06:04:06 +00:00
2025-12-08 11:48:14 +09:00
## Features
2025-03-23 15:03:38 +00:00
2025-12-08 11:48:14 +09:00
- **LLM-Powered Diagram Creation** : Leverage Large Language Models to create and manipulate draw.io diagrams directly through natural language commands
- **Image-Based Diagram Replication** : Upload existing diagrams or images and have the AI replicate and enhance them automatically
2025-12-11 14:57:16 +09:00
- **PDF & Text File Upload** : Upload PDF documents and text files to extract content and generate diagrams from existing documents
- **AI Reasoning Display** : View the AI's thinking process for supported models (OpenAI o1/o3, Gemini, Claude, etc.)
2025-12-08 11:48:14 +09:00
- **Diagram History** : Comprehensive version control that tracks all changes, allowing you to view and restore previous versions of your diagrams before the AI editing.
- **Interactive Chat Interface** : Communicate with AI to refine your diagrams in real-time
2025-12-11 14:57:16 +09:00
- **Cloud Architecture Diagram Support** : Specialized support for generating cloud architecture diagrams (AWS, GCP, Azure)
2025-12-08 11:48:14 +09:00
- **Animated Connectors** : Create dynamic and animated connectors between diagram elements for better visualization
2025-03-23 15:24:49 +00:00
2025-12-17 14:50:07 +09:00
## MCP Server (Preview)
2025-12-17 14:52:39 +09:00
> **Preview Feature**: This feature is experimental and may not stable.
2025-12-17 14:50:07 +09:00
Use Next AI Draw.io with AI agents like Claude Desktop, Cursor, and VS Code via MCP (Model Context Protocol).
```json
{
"mcpServers": {
"drawio": {
"command": "npx",
"args": ["@next -ai-drawio/mcp-server@latest "]
}
}
}
```
### Claude Code CLI
```bash
claude mcp add drawio -- npx @next -ai-drawio/mcp-server@latest
```
Then ask Claude to create diagrams:
> "Create a flowchart showing user authentication with login, MFA, and session management"
The diagram appears in your browser in real-time!
See the [MCP Server README ](./packages/mcp-server/README.md ) for VS Code, Cursor, and other client configurations.
2025-12-08 11:48:14 +09:00
## Getting Started
2025-11-15 13:36:42 +09:00
2025-12-08 11:48:14 +09:00
### Try it Online
2025-11-15 13:36:42 +09:00
2025-12-08 11:48:14 +09:00
No installation needed! Try the app directly on our demo site:
2025-12-05 18:53:34 +09:00
2025-12-08 11:48:14 +09:00
[](https://next-ai-drawio.jiang.jp/)
2025-12-05 18:53:34 +09:00
2025-12-29 11:30:58 +09:00
2025-03-23 15:03:38 +00:00
feat: add bring-your-own-API-key support (#186)
- Add AI provider settings to config panel (provider, model, API key, base URL)
- Support 7 providers: OpenAI, Anthropic, Google, Azure, OpenRouter, DeepSeek, SiliconFlow
- Client API keys stored in localStorage, never stored on server
- Client settings override server env vars when provided
- Skip server credential validation when client provides API key
- Bypass usage limits (request/token/TPM) when using own API key
- Add /api/config endpoint for fetching usage limits
- Add privacy notices to settings dialog, about pages, and quota toast
- Add clear settings button to reset saved API keys
- Update README files (EN/CN/JA) with BYOK documentation
Co-authored-by: dayuan.jiang <jiangdy@amazon.co.jp>
2025-12-09 17:50:07 +09:00
> **Bring Your Own API Key**: You can use your own API key to bypass usage limits on the demo site. Click the Settings icon in the chat panel to configure your provider and API key. Your key is stored locally in your browser and is never stored on the server.
2025-12-22 10:39:28 +09:00
### Desktop Application
Download the native desktop app for your platform from the [Releases page ](https://github.com/DayuanJiang/next-ai-draw-io/releases ):
| Platform | Download |
|----------|----------|
| macOS | `.dmg` (Intel & Apple Silicon) |
| Windows | `.exe` installer (x64 & ARM64) |
| Linux | `.AppImage` or `.deb` (x64 & ARM64) |
**Features:**
- **Secure API key storage**: Credentials encrypted using OS keychain
- **Configuration presets**: Save and switch between AI providers via menu
- **Native file dialogs**: Open/save `.drawio` files directly
- **Offline capable**: Works without internet after first launch
**Quick Setup:**
1. Download and install for your platform
2. Open the app → **Menu → Configuration → Manage Presets**
3. Add your AI provider credentials
4. Start creating diagrams!
2025-12-03 21:15:25 +09:00
### Run with Docker (Recommended)
If you just want to run it locally, the best way is to use Docker.
First, install Docker if you haven't already: [Get Docker ](https://docs.docker.com/get-docker/ )
Then run:
```bash
docker run -d -p 3000:3000 \
-e AI_PROVIDER=openai \
-e AI_MODEL=gpt-4o \
-e OPENAI_API_KEY=your_api_key \
ghcr.io/dayuanjiang/next-ai-draw-io:latest
```
2025-12-10 09:40:48 +09:00
Or use an env file:
2025-12-07 11:49:01 +09:00
```bash
cp env.example .env
# Edit .env with your configuration
docker run -d -p 3000:3000 --env-file .env ghcr.io/dayuanjiang/next-ai-draw-io:latest
```
2025-12-03 21:15:25 +09:00
Open [http://localhost:3000 ](http://localhost:3000 ) in your browser.
Replace the environment variables with your preferred AI provider configuration. See [Multi-Provider Support ](#multi-provider-support ) for available options.
2025-12-09 22:19:28 +09:00
> **Offline Deployment:** If `embed.diagrams.net` is blocked, see [Offline Deployment](./docs/offline-deployment.md) for configuration options.
2025-12-09 22:00:54 +09:00
2025-03-23 15:03:38 +00:00
### Installation
1. Clone the repository:
```bash
2025-03-23 15:24:49 +00:00
git clone https://github.com/DayuanJiang/next-ai-draw-io
2025-03-23 15:03:38 +00:00
cd next-ai-draw-io
```
2. Install dependencies:
```bash
npm install
```
2025-11-15 13:36:42 +09:00
3. Configure your AI provider:
Create a `.env.local` file in the root directory:
2025-03-23 15:03:38 +00:00
2025-11-10 19:52:08 +09:00
```bash
2025-11-15 15:32:21 +09:00
cp env.example .env.local
2025-03-23 15:03:38 +00:00
```
2025-11-10 19:52:08 +09:00
2025-11-15 13:36:42 +09:00
Edit `.env.local` and configure your chosen provider:
2025-11-15 15:32:21 +09:00
2025-12-29 11:30:58 +09:00
- Set `AI_PROVIDER` to your chosen provider (doubao,bedrock, openai, anthropic, google, azure, ollama, openrouter, deepseek, siliconflow)
2025-11-15 15:32:21 +09:00
- Set `AI_MODEL` to the specific model you want to use
- Add the required API keys for your provider
2025-12-06 22:04:59 +05:30
- `TEMPERATURE` : Optional temperature setting (e.g., `0` for deterministic output). Leave unset for models that don't support it (e.g., reasoning models).
2025-12-05 21:09:34 +08:00
- `ACCESS_CODE_LIST` : Optional access password(s), can be comma-separated for multiple passwords.
> Warning: If you do not set `ACCESS_CODE_LIST`, anyone can access your deployed site directly, which may lead to rapid depletion of your token. It is recommended to set this option.
2025-11-10 19:52:08 +09:00
2025-12-05 18:53:34 +09:00
See the [Provider Configuration Guide ](./docs/ai-providers.md ) for detailed setup instructions for each provider.
2025-03-23 15:03:38 +00:00
4. Run the development server:
2025-03-19 06:04:06 +00:00
```bash
npm run dev
```
2025-03-23 15:03:38 +00:00
5. Open [http://localhost:3000 ](http://localhost:3000 ) in your browser to see the application.
2025-03-24 01:02:09 +00:00
## Deployment
2025-03-19 06:04:06 +00:00
2025-12-29 11:30:58 +09:00
### Deploy on Vercel (Recommended)
2025-03-23 15:03:38 +00:00
2025-03-24 01:02:09 +00:00
[](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2FDayuanJiang%2Fnext-ai-draw-io)
2025-03-23 15:03:38 +00:00
2025-12-29 11:30:58 +09:00
The easiest way to deploy is using [Vercel ](https://vercel.com/new ), the creators of Next.js. Be sure to **set the environment variables** in the Vercel dashboard as you did in your local `.env.local` file.
See the [Next.js deployment documentation ](https://nextjs.org/docs/app/building-your-application/deploying ) for more details.
2025-11-15 15:32:21 +09:00
2025-12-29 11:30:58 +09:00
### Deploy on Cloudflare Workers
2025-12-27 17:43:23 +05:30
[Go to Cloudflare Deploy Guide ](./docs/Cloudflare_Deploy.md )
2025-12-08 11:48:14 +09:00
## Multi-Provider Support
2025-12-29 11:30:58 +09:00
- [ByteDance Doubao ](https://console.volcengine.com/ark/region:ark+cn-beijing/overview?briefPage=0&briefType=introduce&type=new&utm_campaign=doubao&utm_content=aidrawio&utm_medium=github&utm_source=coopensrc&utm_term=project )
2025-12-08 11:48:14 +09:00
- AWS Bedrock (default)
- OpenAI
- Anthropic
- Google AI
- Azure OpenAI
- Ollama
- OpenRouter
- DeepSeek
- SiliconFlow
2025-12-29 11:30:58 +09:00
2025-12-08 11:48:14 +09:00
All providers except AWS Bedrock and OpenRouter support custom endpoints.
📖 ** [Detailed Provider Configuration Guide ](./docs/ai-providers.md )** - See setup instructions for each provider.
2025-12-10 08:19:21 +09:00
**Model Requirements**: This task requires strong model capabilities for generating long-form text with strict formatting constraints (draw.io XML). Recommended models include Claude Sonnet 4.5, GPT-5.1, Gemini 3 Pro, and DeepSeek V3.2/R1.
2025-12-08 11:48:14 +09:00
2025-12-14 15:08:07 +09:00
Note that `claude` series has trained on draw.io diagrams with cloud architecture logos like AWS, Azure, GCP. So if you want to create cloud architecture diagrams, this is the best choice.
2025-12-08 11:48:14 +09:00
## How It Works
The application uses the following technologies:
- **Next.js** : For the frontend framework and routing
- **Vercel AI SDK** (`ai` + `@ai-sdk/*` ): For streaming AI responses and multi-provider support
- **react-drawio** : For diagram representation and manipulation
Diagrams are represented as XML that can be rendered in draw.io. The AI processes your commands and generates or modifies this XML accordingly.
2025-03-23 15:03:38 +00:00
## Project Structure
```
2025-12-02 22:53:31 +09:00
app/ # Next.js App Router
api/chat/ # Chat API endpoint with AI tools
page.tsx # Main page with DrawIO embed
2025-03-23 15:03:38 +00:00
components/ # React components
2025-12-02 22:53:31 +09:00
chat-panel.tsx # Chat interface with diagram control
chat-input.tsx # User input component with file upload
history-dialog.tsx # Diagram version history viewer
2025-03-23 15:03:38 +00:00
ui/ # UI components (buttons, cards, etc.)
2025-12-02 22:53:31 +09:00
contexts/ # React context providers
diagram-context.tsx # Global diagram state management
2025-03-23 15:03:38 +00:00
lib/ # Utility functions and helpers
2025-12-02 22:53:31 +09:00
ai-providers.ts # Multi-provider AI configuration
utils.ts # XML processing and conversion utilities
2025-03-23 15:03:38 +00:00
public/ # Static assets including example images
```
## Support & Contact
2025-12-29 11:30:58 +09:00
**Special thanks to [ByteDance Doubao ](https://console.volcengine.com/ark/region:ark+cn-beijing/overview?briefPage=0&briefType=introduce&type=new&utm_campaign=doubao&utm_content=aidrawio&utm_medium=github&utm_source=coopensrc&utm_term=project ) for sponsoring the API token usage of the demo site!** Register on the ARK platform to get 500K free tokens for all models!
2025-12-02 22:53:31 +09:00
If you find this project useful, please consider [sponsoring ](https://github.com/sponsors/DayuanJiang ) to help me host the live demo site!
2025-03-23 15:03:38 +00:00
For support or inquiries, please open an issue on the GitHub repository or contact the maintainer at:
2025-03-23 15:24:49 +00:00
- Email: me[at]jiang.jp
2025-03-19 06:04:06 +00:00
2025-12-01 22:40:43 +09:00
## Star History
[](https://www.star-history.com/#DayuanJiang/next -ai-draw-io& type=date& legend=top-left)
2025-03-23 15:24:49 +00:00
---