Virtual whiteboard for sketching hand-drawn like diagrams
 
 
 
 
Go to file
Aakansha Doshi 9f9666110e
chore: Add debug flag to enable text container bounding box ()
* debug: Add debug flag to enable text container bounding box

* newline

* fix
.codesandbox chore: update CodeSandbox links and add a config ()
.github build: move release scripts to use release branch ()
.husky build: temporarily disable pre-commit ()
dev-docs build(deps): bump http-cache-semantics from 4.1.0 to 4.1.1 in /dev-docs ()
firebase-project fix: update `storage.rules` ()
public fix: declare css variable for font in excalidraw so its available in host ()
scripts fix: PWA not working after CRA@5 update ()
src chore: Add debug flag to enable text container bounding box ()
.dockerignore build: stops ignoring .env files from docker context so env variables get set during react app build. ()
.editorconfig add editorconfig ()
.env.development chore: Add debug flag to enable text container bounding box ()
.env.production feat: go-to-excalidrawplus button ()
.eslintignore feat: image support ()
.eslintrc.json chore: Update Typescript to 4.4.4 ()
.gitattributes Add gitattributes ()
.gitignore fix: set the dimensions of bound text correctly ()
.lintstagedrc.js Keep errors, elements and comments consistent ()
.npmrc Add npmrc to have pinned deps ()
.nvmrc Chore: Update .nvmrc to match package.json engines definition ()
.prettierignore Change target branch of coverage and pretty print ()
.watchmanconfig Don't reset cache while zooming using a gesture ()
CHANGELOG.md support embedding scene data to PNG/SVG ()
CONTRIBUTING.md docs: migrating dev docs to docusaurus :) ()
Dockerfile fix: docker build architecture:linux/amd64 error occur on linux/arm64 instance ()
LICENSE Add MIT License ()
README.md docs: Fix outdated link in README.md ()
crowdin.yml Locale
docker-compose.yml chore: Update action versions and docker build ()
package.json fix: make tunnels work in multi-instance scenarios ()
tsconfig-types.json chore: bump typescript@4.5.2 ()
tsconfig.json chore: bump typescript@4.5.2 ()
vercel.json feat: redirect vscode.excalidraw.com to vscode marketplace ()
yarn.lock fix: make tunnels work in multi-instance scenarios ()

README.md

Excalidraw

Excalidraw Editor | Blog | Documentation | Excalidraw+

An open source virtual hand-drawn style whiteboard.
Collaborative and end-to-end encrypted.


Excalidraw is released under the MIT license. PRs welcome! Chat on Discord Follow Excalidraw on Twitter

Product showcase

Create beautiful hand-drawn like diagrams, wireframes, or whatever you like.

Features

The Excalidraw editor (npm package) supports:

  • 💯 Free & open-source.
  • 🎨 Infinite, canvas-based whiteboard.
  • ✍️ Hand-drawn like style.
  • 🌓 Dark mode.
  • 🏗️ Customizable.
  • 📷 Image support.
  • 😀 Shape libraries support.
  • 👅 Localization (i18n) support.
  • 🖼️ Export to PNG, SVG & clipboard.
  • 💾 Open format - export drawings as an .excalidraw json file.
  • ⚒️ Wide range of tools - rectangle, circle, diamond, arrow, line, free-draw, eraser...
  • ➡️ Arrow-binding & labeled arrows.
  • 🔙 Undo / Redo.
  • 🔍 Zoom and panning support.

Excalidraw.com

The app hosted at excalidraw.com is a minimal showcase of what you can build with Excalidraw. Its source code is part of this repository as well, and the app features:

  • 📡 PWA support (works offline).
  • 🤼 Real-time collaboration.
  • 🔒 End-to-end encryption.
  • 💾 Local-first support (autosaves to the browser).
  • 🔗 Shareable links (export to a readonly link you can share with others).

We'll be adding these features as drop-in plugins for the npm package in the future.

Quick start

Install the Excalidraw npm package:

npm install react react-dom @excalidraw/excalidraw

or via yarn

yarn add react react-dom @excalidraw/excalidraw

Don't forget to check out our Documentation!

Contributing

Integrations

Who's integrating Excalidraw

Google CloudMetaCodeSandboxObsidian ExcalidrawReplitSliteNotionHackerRank • and many others

Sponsors & support

If you like the project, you can become a sponsor at Open Collective or use Excalidraw+.

Thank you for supporting Excalidraw

Last but not least, we're thankful to these companies for offering their services for free:

Vercel Sentry Crowdin