No Description

Minh Nguyen 8621ddb6a2 Extract backend URLs into environment variables (#1772) (#1848) 4 years ago
.github d39d8e3cb1 New Crowdin updates (#1846) 4 years ago
public b21f723eee use absolute positioning instead of fixed (#1860) 4 years ago
scripts 89cf826555 Change target branch of coverage and pretty print (#1850) 4 years ago
src 8621ddb6a2 Extract backend URLs into environment variables (#1772) (#1848) 4 years ago
.dockerignore 4369d88898 feat: add option for self-hosting via Docker (#1503) 5 years ago
.editorconfig 8dccc793ee add editorconfig (#1198) 5 years ago
.env 8621ddb6a2 Extract backend URLs into environment variables (#1772) (#1848) 4 years ago
.eslintignore 89cf826555 Change target branch of coverage and pretty print (#1850) 4 years ago
.eslintrc.json 0220341966 Rename .eslintrc to .eslintrc.json (#1481) 5 years ago
.gitignore a18342b5b5 Refactor LayerUI (#1434) 5 years ago
.lintstagedrc.js b7a6ceba68 Eslint tweaks (#696) 5 years ago
.npmrc ba1a39c9f3 Add npmrc to have pinned deps (#727) 5 years ago
.nvmrc 45e4949da0 Add .nvmrc file (#1157) 5 years ago
.prettierignore 89cf826555 Change target branch of coverage and pretty print (#1850) 4 years ago
.prettierrc ee68af0fd3 Set Trailing Cmma to (#525) 5 years ago
.watchmanconfig 24fa657093 Don't reset cache while zooming using a gesture (#1103) 5 years ago
CONTRIBUTING.md 1ae3c64860 fix(font): modify exclamation point in font (#394) 5 years ago
Dockerfile 8f65e37dac Disable Sentry inside Docker (#1781) 4 years ago
LICENSE 6f33d72e35 Add MIT License (#176) 5 years ago
README.md 8c3549f336 Add script to calculate percentage of translation (#1826) 4 years ago
crowdin.yml 99cd65de4a Locale 5 years ago
docker-compose.yml f1ceeab8d9 Prepare for Docker publishing (#1771) 4 years ago
now.json 0b971ea570 Remove CSP (#1418) 5 years ago
package-lock.json 24fe05f023 Bump @sentry/* to the latest (#1855) 4 years ago
package.json 24fe05f023 Bump @sentry/* to the latest (#1855) 4 years ago
tsconfig.json 5b9c18a8b7 Remove support for some older browsers that probably didn’t wor… (#1080) 5 years ago

README.md

Excalidraw is a whiteboard tool that lets you easily sketch diagrams with a hand-drawn feel.

Follow Excalidraw on Twitter

Try it now

Go to https://excalidraw.com to start sketching.

Read our blog and follow the guides to learn more about Excalidraw and how to use it effectively.

Run the code

Code Sandbox

Local Installation

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Clone the repo

git clone https://github.com/excalidraw/excalidraw.git

Commands

Command Description
npm install Install the dependencies
npm start Run the project
npm run fix Reformat all files with Prettier
npm test Run tests
npm run test:update Update test snapshots
npm run test:code Test for formatting with Prettier

Docker Compose

You can use docker-compose to work on excalidraw locally if you don't want to setup a Node.js env.

docker-compose up --build -d

Self hosting

We publish a Docker image with the Excalidraw client at excalidraw/excalidraw. You can use it to self host your own client under your own domain, on Kubernetes, AWS ECS, etc.

docker build -t excalidraw/excalidraw .
docker run --rm -dit --name excalidraw -p 5000:80 excalidraw/excalidraw:latest

The Docker image is free of analytics and other tracking libraries.

At the moment, self-hosting your own instance doesn't support sharing or collaboration features.

We are working towards providing a full-fledged solution for self hosting your own Excalidraw.

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Translating

To translate Excalidraw into other languages, please visit our Crowdin page. To add a new language, open an issue so we can get things set up on our end first.

Translations will be available on the app if they exceed a certain threshold of completion (currently 85%).

Excalidraw is built using these awesome tools

And the main source of inspiration for starting the project is the awesome Zwibbler app.

Testimonials

Contributors

Code Contributors

This project exists thanks to all the people who contribute. [Contribute].

Financial Contributors

Become a financial contributor and help us sustain our community. [Contribute]

Individuals

Organizations

Support this project with your organization. Your logo will show up here with a link to your website. [Contribute]