DayuanJiang

    DayuanJiang/next-ai-draw-io

    A next.js web application that integrates AI capabilities with draw.io diagrams. This app allows you to create, modify, and enhance diagrams through natural language commands and AI-assisted visualization.

    ai
    diagrams
    productivity
    TypeScript
    Apache-2.0
    22.0K stars
    2.3K forks
    22.0K watching
    Updated 2/27/2026
    View on GitHub
    Backblaze Advertisement

    Loading star history...

    Health Score

    75

    Weekly Growth

    +0

    +0.0% this week

    Contributors

    1

    Total contributors

    Open Issues

    128

    Generated Insights

    About next-ai-draw-io

    Next AI Draw.io

    AI-Powered Diagram Creation Tool - Chat, Draw, Visualize

    English | 中文 | 日本語

    License: MIT Next.js TypeScript Sponsor

    🚀 Live Demo

    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/b2eef5f3-b335-4e71-a755-dc2e80931979

    Features

    • 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
    • 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
    • AWS Architecture Diagram Support: Specialized support for generating AWS architecture diagrams
    • Animated Connectors: Create dynamic and animated connectors between diagram elements for better visualization

    Examples

    Here are some example prompts and their generated diagrams:

    Animated transformer connectors

    Prompt: Give me a **animated connector** diagram of transformer's architecture.

    Transformer Architecture with Animated Connectors
    GCP architecture diagram

    Prompt: Generate a GCP architecture diagram with **GCP icons**. In this diagram, users connect to a frontend hosted on an instance.

    GCP Architecture Diagram
    AWS architecture diagram

    Prompt: Generate a AWS architecture diagram with **AWS icons**. In this diagram, users connect to a frontend hosted on an instance.

    AWS Architecture Diagram
    Azure architecture diagram

    Prompt: Generate a Azure architecture diagram with **Azure icons**. In this diagram, users connect to a frontend hosted on an instance.

    Azure Architecture Diagram
    Cat sketch prompt

    Prompt: Draw a cute cat for me.

    Cat Drawing

    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.

    Multi-Provider Support

    • AWS Bedrock (default)
    • OpenAI / OpenAI-compatible APIs (via OPENAI_BASE_URL)
    • Anthropic
    • Google AI
    • Azure OpenAI
    • Ollama
    • OpenRouter
    • DeepSeek

    Note that claude-sonnet-4-5 has trained on draw.io diagrams with AWS logos, so if you want to create AWS architecture diagrams, this is the best choice.

    Getting Started

    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
    

    Open http://localhost:3000 in your browser.

    Replace the environment variables with your preferred AI provider configuration. See Multi-Provider Support for available options.

    Installation

    1. Clone the repository:
    git clone https://github.com/DayuanJiang/next-ai-draw-io
    cd next-ai-draw-io
    
    1. Install dependencies:
    npm install
    # or
    yarn install
    
    1. Configure your AI provider:

    Create a .env.local file in the root directory:

    cp env.example .env.local
    

    Edit .env.local and configure your chosen provider:

    • Set AI_PROVIDER to your chosen provider (bedrock, openai, anthropic, google, azure, ollama, openrouter, deepseek)
    • Set AI_MODEL to the specific model you want to use
    • Add the required API keys for your provider

    See the Multi-Provider Support section above for provider-specific configuration examples.

    1. Run the development server:
    npm run dev
    
    1. Open http://localhost:3000 in your browser to see the application.

    Deployment

    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. Deploy with Vercel

    Be sure to set the environment variables in the Vercel dashboard as you did in your local .env.local file.

    Project Structure

    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
    

    TODOs

    • Allow the LLM to modify the XML instead of generating it from scratch everytime.
    • Improve the smoothness of shape streaming updates.
    • Add multiple AI provider support (OpenAI, Anthropic, Google, Azure, Ollama)
    • Solve the bug that generation will fail for session that longer than 60s.
    • Add API config on the UI.

    Support & Contact

    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:

    • Email: me[at]jiang.jp

    Star History

    Star History Chart


    Discover Repositories

    Search across tracked repositories by name or description