Create flows from templates, code, structured imports, or AI. Refine them visually, keep them local-first, and export without giving up diagram-as-code or developer workflows.
→ Launch the App | Documentation | Website | Issues | Contribute
| 🏠 Workspace Home Create · open · import No forced blank file |
🧑💻 Code → Diagram GitHub · SQL · Terraform K8s · Docker Compose |
🤖 AI Generation 9 providers · BYOK Streaming diff preview |
`{}` Diagram as Code Bidirectional live sync Git-friendly DSL |
🧩 Asset Libraries Developer · AWS · Azure GCP · CNCF · Icons |
🎬 Cinematic Export Animated video & GIF No upload required |
Every diagramming tool makes a compromise. OpenFlowKit doesn't.
| Tool | What's missing |
|---|---|
| Excalidraw / tldraw | Freeform whiteboards — no structured diagram types, no DSL, no code imports |
| Mermaid.js | Code-only — no visual canvas, no AI, no interactive editor |
| Draw.io | Decade-old UX — Limited AI integration, no developer import pipelines |
| Lucidchart / Miro | Cloud lock-in — expensive, account required, your data lives on their servers |
| PlantUML | Server-dependent rendering — no visual editor, no local-first model |
OpenFlowKit is the only MIT-licensed tool that combines a real workspace home, a professional visual canvas, bidirectional diagram-as-code, AI generation from 9 providers, deterministic and AI-assisted imports, asset libraries for technical diagrams, and cinematic animated export — with zero server-side storage.
| OpenFlowKit | Excalidraw | Draw.io | Mermaid | Lucidchart | |
|---|---|---|---|---|---|
| Visual canvas editor | ✅ | ✅ | ✅ | ❌ | ✅ |
| Bidirectional diagram-as-code | ✅ | ❌ | ❌ | ✅ | ❌ |
| AI generation (9 providers) | ✅ | ❌ | ❌ | ❌ | Limited |
| GitHub repo → diagram | ✅ | ❌ | ❌ | ❌ | ❌ |
| SQL → ERD (native parser) | ✅ | ❌ | ❌ | ❌ | ❌ |
| Terraform / K8s / Docker import | ✅ | ❌ | ❌ | ❌ | ❌ |
| AWS / Azure / GCP / CNCF icons | ✅ | ❌ | ✅ | Partial | ✅ |
| Real-time collaboration (P2P) | ✅ | ✅ | ❌ | ❌ | ✅ (cloud) |
| Cinematic animated export | ✅ | ❌ | ❌ | ❌ | ❌ |
| Figma export (editable SVG) | ✅ | ❌ | ❌ | ❌ | ❌ |
| No account required | ✅ | ✅ | ✅ | ✅ | ❌ |
| Open source (MIT) | ✅ | ✅ | ✅ | ✅ | ❌ |
Drop in your existing artifacts. Many formats are handled by deterministic native parsers that run entirely in your browser. AI-powered imports help when the source needs interpretation or when you want a richer first-pass architecture draft.
Native parsers (no API key needed):
CREATE TABLE orders (
id BIGINT PRIMARY KEY,
user_id BIGINT NOT NULL REFERENCES users(id),
status ENUM('pending','paid','shipped') NOT NULL
);→ Typed ERD with inferred foreign-key edges and cardinalities. Rendered in milliseconds, no server involved.
# docker-compose.yml
services:
api:
depends_on: [postgres, redis]
postgres:
image: postgres:16
redis:
image: redis:alpine→ Service architecture with depends_on edges and port labels.
AI-powered imports (API key required):
github.com/vercel/next.js → architecture diagram
→ Fetches the repo, analyzes code structure and dependencies, then generates an editable architecture diagram via AI. Quality depends on the model chosen.
| Source | Engine | API key? |
|---|---|---|
| GitHub repo URL | AI · 9 languages supported | Yes |
| SQL DDL | Native parser | No |
Terraform .tfstate |
Native parser | No |
| Terraform HCL | AI-assisted | Yes |
| Kubernetes YAML / Helm | Native parser | No |
| Docker Compose | Native parser | No |
| OpenAPI / Swagger spec | AI-assisted | Yes |
| Source code (single file) | AI-assisted · 9 languages | Yes |
| Mermaid | Native parser | No |
OpenFlowKit now treats the product as two clear surfaces:
- Home for creating, opening, duplicating, importing, and organizing flows
- Editor for actual canvas work once a real document exists
That means the app does not create a fake default flow just to get you onto the canvas. If you delete everything, your workspace can stay empty until you intentionally create the next flow.
Flowpilot sits directly in the editor. Describe a system, paste source code, upload a screenshot, or ask it to refine what's already on the canvas. Your API key is stored in your browser and sent directly to the provider — OpenFlowKit's servers never see it.
9 providers. Bring your own key. Switch any time.
| Provider | Default model | Why use it |
|---|---|---|
| Google Gemini | gemini-2.5-flash-lite |
Free tier available, fast, browser-safe |
| OpenAI | gpt-5-mini |
Best reasoning for complex architectures |
| Anthropic Claude | claude-sonnet-4-6 |
Excellent code and system understanding |
| Groq | llama-4-scout-17b-16e-instruct |
Fastest inference available |
| Mistral | mistral-medium-latest |
Strong European privacy-first alternative |
| NVIDIA NIM | llama-4-scout-17b-16e-instruct |
Enterprise GPU inference |
| Cerebras | gpt-oss-120b |
Fastest on WSE-3 silicon |
| OpenRouter | google/gemini-2.5-flash |
Access 100+ models through one key |
| Custom endpoint | Any model | Ollama, LM Studio, or any OpenAI-compatible API |
No proxy. No middleman. Direct browser-to-provider requests.
Every diagram has a live code panel. Edit the canvas → code updates. Edit the code → canvas updates. Two-way, always in sync.
flowchart TB
client[React App] --> gateway[API Gateway]
gateway --> auth[Auth Service]
gateway --> orders[Orders Service]
orders --> db[(PostgreSQL)]
orders --> cache[(Redis)]
auth --> db
- Mermaid-compatible syntax
- Export to Mermaid, PlantUML, or JSON
- Paste any Mermaid diagram and it renders immediately
- Version snapshots — restore any previous state
Not a freeform whiteboard. Structured diagram types with opinionated defaults, correct relationship semantics, and purpose-built node styles.
- 🔷 Flowcharts — processes, decision trees, system flows
- ☁️ Architecture — AWS / Azure / GCP / CNCF cloud provider icons built in
- 🗄️ Entity-Relationship — typed fields, FK edges, one-to-many / many-to-many notation
- 📐 Class diagrams — UML with inheritance, composition, and interface relationships
↔️ Sequence diagrams — async messages, actors, and lifelines- 🧠 Mind maps — collapsible radial trees with auto-layout
- 🛤️ User journeys — steps, phases, and sentiment scoring
- ⚙️ State machines — transitions, guards, entry and exit actions
OpenFlowKit works best when you move between the right surfaces instead of forcing everything through one panel:
- Toolbar add menu for quick insert actions
- Command Center for templates, import, assets, search, layout, pages, layers, and design systems
- Studio for Flowpilot, Mermaid, OpenFlow DSL, infra parsing, and linting
- Properties panel for exact visual and metadata edits
Large diagrams also get better organization with multi-page documents, layers, sections, and local-first document recovery.
Build your diagram once. Take it anywhere.
- PNG / SVG — transparent background, pixel-perfect at any resolution
- PDF — print-ready, vector-crisp
- Mermaid — paste directly into GitHub READMEs, Notion, Confluence, Linear
- PlantUML — for enterprise toolchains and legacy integrations
- Figma — full editable SVG import with preserved layers
- JSON — complete round-trip import/export, no data loss
- 🎬 Cinematic MP4 — an animated walkthrough of your diagram, node by node, edge by edge. Designed for demos, presentations, and architecture reviews. No other open-source diagramming tool does this.
Local-first stays the default. Your saved flows live in the browser, your AI keys stay on your device, and export is explicit. When you do want to work together, OpenFlowKit supports P2P collaboration over WebRTC with live presence and shared editing, without making a hosted backend mandatory for solo work.
| Shortcut | Action |
|---|---|
⌘ K / Ctrl K |
Command bar — search, import, layout, assets, and actions |
⌘ \ / Ctrl \ |
Toggle the live code panel |
⌘ Z / Ctrl Z |
Full undo with complete history |
⌘ D / Ctrl D |
Duplicate selection |
⌘ G / Ctrl G |
Group selected nodes |
⌘ / / Ctrl / |
Keyboard shortcuts reference |
Plus: smart alignment guides, snap-to-grid, multi-select, pages, layers, sections, architecture lint, light/dark/system theme, and full i18n in 7 languages.
Current roadmap focus:
- better layers and page workflows for larger technical diagrams
- stronger code and structured-import diagram quality
- smarter auto-layout defaults with less cleanup after import
- performance boosts for bigger canvases and heavier sessions
- continued docs and onboarding cleanup so the product surfaces stay easier to understand
git clone https://github.com/Vrun-design/openflowkit.git
cd openflowkit
npm install
npm run devOpen http://localhost:5173. Done.
Zero environment variables required. AI provider keys are configured in the in-app settings panel at runtime — nothing goes in
.env.
OpenFlowKit is a pure static SPA. There is no backend. Deploy the dist/ folder anywhere that serves HTML.
Cloudflare Pages / Netlify / Vercel:
npm run build
# upload dist/ to your providerDocker:
docker build -t openflowkit .
docker run -p 8080:80 openflowkitNo database. No secrets. No infrastructure. One folder.
| Layer | Technology |
|---|---|
| Framework | React 19 + TypeScript 5 |
| Build | Vite 6 |
| Canvas | React Flow (XYFlow) |
| Auto-layout | ELK.js |
| State | Zustand |
| Storage | IndexedDB — local-first, no backend |
| Styling | Tailwind CSS |
| Collaboration | WebRTC (P2P, no relay server) |
| i18n | react-i18next — 7 languages |
| Testing | Vitest + Playwright |
All contributions are welcome — bug fixes, new diagram types, parser improvements, translations, and documentation.
Start here:
npm run dev # development server at localhost:5173
npm run test # unit tests via Vitest
npm run test:e2e # end-to-end tests via Playwright
npm run lint # ESLint + TypeScript type-checkGood first issues are tagged good first issue. Before opening a PR, please read CONTRIBUTING.md.
OpenFlowKit is MIT licensed, locally hosted, and built in the open.
No cloud required. No account required. No lock-in.
| → Launch App | Docs | Website | Changelog |
| Bug Report | Feature Request | Contributing Guide | Security Policy |
If OpenFlowKit saves you time, the most impactful thing you can do is give it a star.
It helps other developers find the project.
React 19 · TypeScript 5 · Vite 6 · XYFlow · ELK.js · Zustand · Yjs · Framer Motion · Tailwind CSS · Cloudflare Pages
MIT Licensed · Local-first · No telemetry · No account · No server-side storage · No lock-in