Sen descrición

David Luzar 1eee488dab feat: add thai lang support (#6314) %!s(int64=2) %!d(string=hai) anos
.codesandbox 59a1d192d2 chore: update CodeSandbox links and add a config (#5624) %!s(int64=3) %!d(string=hai) anos
.github a1dcd6d984 build: move release scripts to use release branch (#5958) %!s(int64=2) %!d(string=hai) anos
.husky d0b33d35db build: temporarily disable pre-commit (#6132) %!s(int64=2) %!d(string=hai) anos
dev-docs 3322f0fa6f build(deps): bump @sideway/formula from 3.0.0 to 3.0.1 in /dev-docs (#6309) %!s(int64=2) %!d(string=hai) anos
firebase-project 7431ca81d1 fix: update `storage.rules` (#5020) %!s(int64=3) %!d(string=hai) anos
public cf38c0f933 fix: declare css variable for font in excalidraw so its available in host (#6160) %!s(int64=2) %!d(string=hai) anos
scripts 1eee488dab feat: add thai lang support (#6314) %!s(int64=2) %!d(string=hai) anos
src dd4c333925 fix: add an offset of 0.5px for text editor in containers (#6328) %!s(int64=2) %!d(string=hai) anos
.dockerignore e1c5c706c6 build: stops ignoring .env files from docker context so env variables get set during react app build. (#5809) %!s(int64=3) %!d(string=hai) anos
.editorconfig 8dccc793ee add editorconfig (#1198) %!s(int64=5) %!d(string=hai) anos
.env.development 9f9666110e chore: Add debug flag to enable text container bounding box (#6296) %!s(int64=2) %!d(string=hai) anos
.env.production bed9fca4a5 feat: go-to-excalidrawplus button (#5202) %!s(int64=3) %!d(string=hai) anos
.eslintignore 163ad1f4c4 feat: image support (#4011) %!s(int64=4) %!d(string=hai) anos
.eslintrc.json 8d4f455cd3 chore: Update Typescript to 4.4.4 (#4188) %!s(int64=4) %!d(string=hai) anos
.gitattributes c814917927 Add gitattributes (#2164) %!s(int64=5) %!d(string=hai) anos
.gitignore 4cb6f09559 fix: set the dimensions of bound text correctly (#5710) %!s(int64=3) %!d(string=hai) anos
.lintstagedrc.js 5d295415db Keep errors, elements and comments consistent (#2340) %!s(int64=5) %!d(string=hai) anos
.npmrc ba1a39c9f3 Add npmrc to have pinned deps (#727) %!s(int64=5) %!d(string=hai) anos
.nvmrc 785a944ac2 Chore: Update .nvmrc to match package.json engines definition (#3148) %!s(int64=4) %!d(string=hai) anos
.prettierignore 89cf826555 Change target branch of coverage and pretty print (#1850) %!s(int64=5) %!d(string=hai) anos
.watchmanconfig 24fa657093 Don't reset cache while zooming using a gesture (#1103) %!s(int64=5) %!d(string=hai) anos
CHANGELOG.md 5950fa9a40 support embedding scene data to PNG/SVG (#2219) %!s(int64=5) %!d(string=hai) anos
CONTRIBUTING.md f23cdc47ee docs: migrating dev docs to docusaurus :) (#6073) %!s(int64=2) %!d(string=hai) anos
Dockerfile c3c45a8c37 fix: docker build architecture:linux/amd64 error occur on linux/arm64 instance (#6197) %!s(int64=2) %!d(string=hai) anos
LICENSE 6f33d72e35 Add MIT License (#176) %!s(int64=5) %!d(string=hai) anos
README.md 0fcbddda8e docs: Fix outdated link in README.md (#6263) %!s(int64=2) %!d(string=hai) anos
crowdin.yml 99cd65de4a Locale %!s(int64=5) %!d(string=hai) anos
docker-compose.yml baf9da2b83 chore: Update action versions and docker build (#3065) %!s(int64=4) %!d(string=hai) anos
package.json 7562d9b533 fix: make tunnels work in multi-instance scenarios (#6178) %!s(int64=2) %!d(string=hai) anos
tsconfig-types.json 620b662085 chore: bump typescript@4.5.2 (#4283) %!s(int64=3) %!d(string=hai) anos
tsconfig.json 620b662085 chore: bump typescript@4.5.2 (#4283) %!s(int64=3) %!d(string=hai) anos
vercel.json 9135ebf2e2 feat: redirect vscode.excalidraw.com to vscode marketplace (#5285) %!s(int64=3) %!d(string=hai) anos
yarn.lock 7562d9b533 fix: make tunnels work in multi-instance scenarios (#6178) %!s(int64=2) %!d(string=hai) anos

README.md


<img alt="Excalidraw is released under the MIT license." src="https://img.shields.io/badge/license-MIT-blue.svg"  />

<img alt="PRs welcome!" src="https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat"  />

<img alt="Chat on Discord" src="https://img.shields.io/discord/723672430744174682?color=738ad6&label=Chat%20on%20Discord&logo=discord&logoColor=ffffff&widge=false"/>

<img alt="Follow Excalidraw on Twitter" src="https://img.shields.io/twitter/follow/excalidraw.svg?label=follow+@excalidraw&style=social&logo=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