146 lines
3.0 KiB
Markdown
146 lines
3.0 KiB
Markdown
<img src="logoExcaliDash.png" alt="[Image Description]" width="80" height="88">
|
|
|
|
# ExcaliDash v0.1.0
|
|
|
|
A self hosted dashboard and organizer for [Excalidraw](https://github.com/excalidraw/excalidraw) with live collaboration.
|
|

|
|
|
|

|
|
|
|
[Features](#Features)
|
|
|
|
[Installation](#Installation)
|
|
|
|
[Development](#Development)
|
|
|
|
[Credits](#Credits)
|
|
|
|
# Features
|
|
|
|
## Persistent storage for all your drawings
|
|
|
|

|
|
|
|
## Real time collaboration
|
|
|
|

|
|
|
|
## Search your drawings
|
|
|
|

|
|
|
|
## Drag and drop drawings into collections
|
|
|
|

|
|
|
|
## Export/import your drawings and databases for backup
|
|
|
|

|
|
|
|
# Installation
|
|
|
|
> [!CAUTION]
|
|
> NOT for production use. This is just a side project (and also the first release), and it likely contains some bugs.
|
|
|
|
## Dockerhub (recommended)
|
|
|
|
[Install Docker](https://docs.docker.com/desktop/)
|
|
|
|
```bash
|
|
# Download docker-compose.prod.yml
|
|
curl -OL https://raw.githubusercontent.com/ZimengXiong/ExcaliDash/refs/heads/main/docker-compose.prod.yml
|
|
|
|
# Pull images
|
|
docker compose -f docker-compose.prod.yml pull
|
|
|
|
# Run container
|
|
docker compose -f docker-compose.prod.yml up -d
|
|
|
|
# Access the frontend at localhost:6767
|
|
```
|
|
|
|
## Docker build
|
|
|
|
[Install Docker](https://docs.docker.com/desktop/)
|
|
|
|
```bash
|
|
# Clone the repository (recommended)
|
|
git clone git@github.com:ZimengXiong/ExcaliDash.git
|
|
|
|
# or, clone with HTTPS
|
|
# git clone https://github.com/ZimengXiong/ExcaliDash.git
|
|
|
|
docker compose build
|
|
docker compose up -d
|
|
|
|
# Access the frontend at localhost:6767
|
|
```
|
|
|
|
# Development
|
|
|
|
## Clone the repository
|
|
|
|
```bash
|
|
# Clone the repository (recommended)
|
|
git clone git@github.com:ZimengXiong/ExcaliDash.git
|
|
|
|
# or, clone with HTTPS
|
|
# git clone https://github.com/ZimengXiong/ExcaliDash.git
|
|
```
|
|
|
|
## Frontend
|
|
|
|
```bash
|
|
cd ExcaliDash/frontend
|
|
npm install
|
|
|
|
# Copy environment file and customize if needed
|
|
cp .env.example .env
|
|
|
|
npm run dev
|
|
```
|
|
|
|
## Backend
|
|
|
|
```bash
|
|
cd ExcaliDash/backend
|
|
npm install
|
|
|
|
# Copy environment file and customize if needed
|
|
cp .env.example .env
|
|
|
|
# Generate Prisma client and setup database
|
|
npx prisma generate
|
|
npx prisma db push
|
|
|
|
npm run dev
|
|
```
|
|
|
|
## Structure
|
|
|
|
```
|
|
ExcaliDash/
|
|
├── backend/ # Node.js + Express + Prisma
|
|
│ ├── src/
|
|
│ │ └── index.ts # Main server file
|
|
│ ├── prisma/
|
|
│ │ ├── schema.prisma # Database schema
|
|
│ │ └── dev.db # SQLite database
|
|
│ └── package.json
|
|
├── frontend/ # React + TypeScript + Vite
|
|
│ ├── src/
|
|
│ │ ├── components/ # React components
|
|
│ │ ├── pages/ # Page components
|
|
│ │ ├── hooks/ # Custom hooks
|
|
│ │ └── api/ # API client
|
|
│ └── package.json
|
|
└── README.md
|
|
```
|
|
|
|
# Credits
|
|
|
|
- Example designs from:
|
|
- https://github.com/Prakash-sa/system-design-ultimatum/tree/main
|
|
- https://github.com/kitsteam/excalidraw-examples/tree/main
|
|
- [Excalidraw](https://github.com/ZimengXiong/ExcaliDash)
|