# Next AI Draw.io
**AI搭載のダイアグラム作成ツール - チャット、描画、可視化** [English](../README.md) | [中文](./README_CN.md) | 日本語 [![TrendShift](https://trendshift.io/api/badge/repositories/15449)](https://next-ai-drawio.jiang.jp/) [![License: Apache 2.0](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0) [![Next.js](https://img.shields.io/badge/Next.js-16.x-black)](https://nextjs.org/) [![React](https://img.shields.io/badge/React-19.x-61dafb)](https://react.dev/) [![Sponsor](https://img.shields.io/badge/Sponsor-❤-ea4aaa)](https://github.com/sponsors/DayuanJiang) [![Live Demo](../public/live-demo-button.svg)](https://next-ai-drawio.jiang.jp/)
AI機能とdraw.ioダイアグラムを統合したNext.jsウェブアプリケーションです。自然言語コマンドとAI支援の可視化により、ダイアグラムを作成、修正、強化できます。 https://github.com/user-attachments/assets/b2eef5f3-b335-4e71-a755-dc2e80931979 ## 目次 - [Next AI Draw.io](#next-ai-drawio) - [目次](#目次) - [例](#例) - [機能](#機能) - [MCPサーバー(プレビュー)](#mcpサーバープレビュー) - [はじめに](#はじめに) - [オンラインで試す](#オンラインで試す) - [Dockerで実行(推奨)](#dockerで実行推奨) - [インストール](#インストール) - [デプロイ](#デプロイ) - [マルチプロバイダーサポート](#マルチプロバイダーサポート) - [仕組み](#仕組み) - [プロジェクト構造](#プロジェクト構造) - [サポート&お問い合わせ](#サポートお問い合わせ) - [スター履歴](#スター履歴) ## 例 以下はいくつかのプロンプト例と生成されたダイアグラムです:
アニメーションTransformerコネクタ

プロンプト: **アニメーションコネクタ**付きのTransformerアーキテクチャ図を作成してください。

アニメーションコネクタ付きTransformerアーキテクチャ
GCPアーキテクチャ図

プロンプト: **GCPアイコン**を使用してGCPアーキテクチャ図を生成してください。この図では、ユーザーがインスタンス上でホストされているフロントエンドに接続します。

GCPアーキテクチャ図
AWSアーキテクチャ図

プロンプト: **AWSアイコン**を使用してAWSアーキテクチャ図を生成してください。この図では、ユーザーがインスタンス上でホストされているフロントエンドに接続します。

AWSアーキテクチャ図
Azureアーキテクチャ図

プロンプト: **Azureアイコン**を使用してAzureアーキテクチャ図を生成してください。この図では、ユーザーがインスタンス上でホストされているフロントエンドに接続します。

Azureアーキテクチャ図
猫のスケッチ

プロンプト: かわいい猫を描いてください。

猫の絵
## 機能 - **LLM搭載のダイアグラム作成**:大規模言語モデルを活用して、自然言語コマンドで直接draw.ioダイアグラムを作成・操作 - **画像ベースのダイアグラム複製**:既存のダイアグラムや画像をアップロードし、AIが自動的に複製・強化 - **PDFとテキストファイルのアップロード**:PDFドキュメントやテキストファイルをアップロードして、既存のドキュメントからコンテンツを抽出し、ダイアグラムを生成 - **AI推論プロセス表示**:サポートされているモデル(OpenAI o1/o3、Gemini、Claudeなど)のAIの思考プロセスを表示 - **ダイアグラム履歴**:すべての変更を追跡する包括的なバージョン管理。AI編集前のダイアグラムの以前のバージョンを表示・復元可能 - **インタラクティブなチャットインターフェース**:AIとリアルタイムでコミュニケーションしてダイアグラムを改善 - **クラウドアーキテクチャダイアグラムサポート**:クラウドアーキテクチャダイアグラムの生成を専門的にサポート(AWS、GCP、Azure) - **アニメーションコネクタ**:より良い可視化のためにダイアグラム要素間に動的でアニメーション化されたコネクタを作成 ## MCPサーバー(プレビュー) > **プレビュー機能**:この機能は実験的であり、変更される可能性があります。 MCP(Model Context Protocol)を介して、Claude Desktop、Cursor、VS CodeなどのAIエージェントでNext AI Draw.ioを使用できます。 ```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 ``` Claudeにダイアグラムの作成を依頼: > 「ログイン、MFA、セッション管理を含むユーザー認証のフローチャートを作成してください」 ダイアグラムがリアルタイムでブラウザに表示されます! 詳細は[MCPサーバーREADME](../packages/mcp-server/README.md)をご覧ください(VS Code、Cursorなどのクライアント設定も含む)。 ## はじめに ### オンラインで試す インストール不要!デモサイトで直接お試しください: [![Live Demo](../public/live-demo-button.svg)](https://next-ai-drawio.jiang.jp/) > 注意:アクセス数が多いため、デモサイトでは現在 minimax-m2 モデルを使用しています。最高の結果を得るには、Claude Sonnet 4.5 または Claude Opus 4.5 でのセルフホスティングをお勧めします。 > **自分のAPIキーを使用**:自分のAPIキーを使用することで、デモサイトの利用制限を回避できます。チャットパネルの設定アイコンをクリックして、プロバイダーとAPIキーを設定してください。キーはブラウザのローカルに保存され、サーバーには保存されません。 ### Dockerで実行(推奨) ローカルで実行したいだけなら、Dockerを使用するのが最も簡単です。 まず、Dockerをインストールしていない場合はインストールしてください:[Dockerを入手](https://docs.docker.com/get-docker/) 次に実行: ```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 ``` または env ファイルを使用: ```bash cp env.example .env # .env を編集して設定を入力 docker run -d -p 3000:3000 --env-file .env ghcr.io/dayuanjiang/next-ai-draw-io:latest ``` ブラウザで [http://localhost:3000](http://localhost:3000) を開いてください。 環境変数はお好みのAIプロバイダー設定に置き換えてください。利用可能なオプションについては[マルチプロバイダーサポート](#マルチプロバイダーサポート)を参照してください。 > **オフラインデプロイ:** `embed.diagrams.net` がブロックされている場合は、[オフラインデプロイガイド](./offline-deployment.md) で設定オプションをご確認ください。 ### インストール 1. リポジトリをクローン: ```bash git clone https://github.com/DayuanJiang/next-ai-draw-io cd next-ai-draw-io ``` 2. 依存関係をインストール: ```bash npm install ``` 3. AIプロバイダーを設定: ルートディレクトリに`.env.local`ファイルを作成: ```bash cp env.example .env.local ``` `.env.local`を編集して選択したプロバイダーを設定: - `AI_PROVIDER`を選択したプロバイダーに設定(bedrock, openai, anthropic, google, azure, ollama, openrouter, deepseek, siliconflow) - `AI_MODEL`を使用する特定のモデルに設定 - プロバイダーに必要なAPIキーを追加 - `TEMPERATURE`:オプションの温度設定(例:`0`で決定論的な出力)。温度をサポートしないモデル(推論モデルなど)では設定しないでください。 - `ACCESS_CODE_LIST` アクセスパスワード(オプション)。カンマ区切りで複数のパスワードを指定できます。 > 警告:`ACCESS_CODE_LIST`を設定しない場合、誰でもデプロイされたサイトに直接アクセスできるため、トークンが急速に消費される可能性があります。このオプションを設定することをお勧めします。 詳細な設定手順については[プロバイダー設定ガイド](./ai-providers.md)を参照してください。 4. 開発サーバーを起動: ```bash npm run dev ``` 5. ブラウザで[http://localhost:3000](http://localhost:3000)を開いてアプリケーションを確認。 ## デプロイ Next.jsアプリをデプロイする最も簡単な方法は、Next.jsの作成者による[Vercelプラットフォーム](https://vercel.com/new)を使用することです。 詳細は[Next.jsデプロイメントドキュメント](https://nextjs.org/docs/app/building-your-application/deploying)をご覧ください。 または、このボタンでデプロイできます: [![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2FDayuanJiang%2Fnext-ai-draw-io) ローカルの`.env.local`ファイルと同様に、Vercelダッシュボードで**環境変数を設定**してください。 ## マルチプロバイダーサポート - AWS Bedrock(デフォルト) - OpenAI - Anthropic - Google AI - Azure OpenAI - Ollama - OpenRouter - DeepSeek - SiliconFlow AWS BedrockとOpenRouter以外のすべてのプロバイダーはカスタムエンドポイントをサポートしています。 📖 **[詳細なプロバイダー設定ガイド](./ai-providers.md)** - 各プロバイダーの設定手順をご覧ください。 **モデル要件**:このタスクは厳密なフォーマット制約(draw.io XML)を持つ長文テキスト生成を伴うため、強力なモデル機能が必要です。Claude Sonnet 4.5、GPT-4o、Gemini 2.0、DeepSeek V3/R1を推奨します。 注:`claude-sonnet-4-5`はAWSロゴ付きのdraw.ioダイアグラムで学習されているため、AWSアーキテクチャダイアグラムを作成したい場合は最適な選択です。 ## 仕組み 本アプリケーションは以下の技術を使用しています: - **Next.js**:フロントエンドフレームワークとルーティング - **Vercel AI SDK**(`ai` + `@ai-sdk/*`):ストリーミングAIレスポンスとマルチプロバイダーサポート - **react-drawio**:ダイアグラムの表現と操作 ダイアグラムはdraw.ioでレンダリングできるXMLとして表現されます。AIがコマンドを処理し、それに応じてこのXMLを生成または変更します。 ## プロジェクト構造 ``` app/ # Next.js App Router api/chat/ # AIツール付きチャットAPIエンドポイント page.tsx # DrawIO埋め込み付きメインページ components/ # Reactコンポーネント chat-panel.tsx # ダイアグラム制御付きチャットインターフェース chat-input.tsx # ファイルアップロード付きユーザー入力コンポーネント history-dialog.tsx # ダイアグラムバージョン履歴ビューア ui/ # UIコンポーネント(ボタン、カードなど) contexts/ # Reactコンテキストプロバイダー diagram-context.tsx # グローバルダイアグラム状態管理 lib/ # ユーティリティ関数とヘルパー ai-providers.ts # マルチプロバイダーAI設定 utils.ts # XML処理と変換ユーティリティ public/ # サンプル画像を含む静的アセット ``` ## サポート&お問い合わせ このプロジェクトが役に立ったら、ライブデモサイトのホスティングを支援するために[スポンサー](https://github.com/sponsors/DayuanJiang)をご検討ください! サポートやお問い合わせについては、GitHubリポジトリでissueを開くか、メンテナーにご連絡ください: - メール:me[at]jiang.jp ## スター履歴 [![Star History Chart](https://api.star-history.com/svg?repos=DayuanJiang/next-ai-draw-io&type=date&legend=top-left)](https://www.star-history.com/#DayuanJiang/next-ai-draw-io&type=date&legend=top-left) ---