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.
https://github.com/user-attachments/assets/9d60a3e8-4a1c-4b5e-acbb-26af2d3eabd1
Here are some example prompts and their generated diagrams:
|
Animated transformer connectors Prompt: Give me a **animated connector** diagram of transformer's architecture. | |
|
GCP architecture diagram Prompt: Generate a GCP architecture diagram with **GCP icons**. In this diagram, users connect to a frontend hosted on an instance. |
AWS architecture diagram Prompt: Generate a AWS architecture diagram with **AWS icons**. In this diagram, users connect to a frontend hosted on an instance. |
|
Azure architecture diagram Prompt: Generate a Azure architecture diagram with **Azure icons**. In this diagram, users connect to a frontend hosted on an instance. |
Cat sketch prompt Prompt: Draw a cute cat for me. |
Preview Feature: This feature is experimental and may not stable.
Use Next AI Draw.io with AI agents like Claude Desktop, Cursor, and VS Code via MCP (Model Context Protocol).
{
"mcpServers": {
"drawio": {
"command": "npx",
"args": ["@next-ai-drawio/mcp-server@latest"]
}
}
}
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 for VS Code, Cursor, and other client configurations.
No installation needed! Try the app directly on our demo site:
Note: Due to high traffic, the demo site currently uses minimax-m2. For best results, we recommend self-hosting with Claude Sonnet 4.5 or Claude Opus 4.5.
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.
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
Then run:
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
Or use an env file:
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
Open http://localhost:3000 in your browser.
Replace the environment variables with your preferred AI provider configuration. See Multi-Provider Support for available options.
Offline Deployment: If
embed.diagrams.netis blocked, see Offline Deployment for configuration options.
git clone https://github.com/DayuanJiang/next-ai-draw-io
cd next-ai-draw-io
npm install
Create a .env.local file in the root directory:
cp env.example .env.local
Edit .env.local and configure your chosen provider:
AI_PROVIDER to your chosen provider (bedrock, openai, anthropic, google, azure, ollama, openrouter, deepseek, siliconflow)AI_MODEL to the specific model you want to useTEMPERATURE: Optional temperature setting (e.g., 0 for deterministic output). Leave unset for models that don't support it (e.g., reasoning models).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.
See the Provider Configuration Guide for detailed setup instructions for each provider.
npm run dev
The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.
Check out the Next.js deployment documentation for more details.
Or you can deploy by this button.
Be sure to set the environment variables in the Vercel dashboard as you did in your local .env.local file.
All providers except AWS Bedrock and OpenRouter support custom endpoints.
📖 Detailed Provider Configuration Guide - See setup instructions for each provider.
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.
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.
The application uses the following technologies:
ai + @ai-sdk/*): For streaming AI responses and multi-provider supportDiagrams are represented as XML that can be rendered in draw.io. The AI processes your commands and generates or modifies this XML accordingly.
app/ # Next.js App Router api/chat/ # Chat API endpoint with AI tools page.tsx # Main page with DrawIO embed components/ # React components chat-panel.tsx # Chat interface with diagram control chat-input.tsx # User input component with file upload history-dialog.tsx # Diagram version history viewer ui/ # UI components (buttons, cards, etc.) contexts/ # React context providers diagram-context.tsx # Global diagram state management lib/ # Utility functions and helpers ai-providers.ts # Multi-provider AI configuration utils.ts # XML processing and conversion utilities public/ # Static assets including example images
If you find this project useful, please consider sponsoring to help me host the live demo site!
For support or inquiries, please open an issue on the GitHub repository or contact the maintainer at: