TypstDrive is a collaborative web editor for Typst. With built-in dark mode, multiple themes, and a clean Google Docs-like interface, it makes creating and sharing documents effortless.
- Real-Time Collaboration: Powered by Yjs and CodeMirror 6, see changes and cursors from other users instantly.
- Instant Preview: Compile Typst to SVG on the fly with sub-second latency, featuring interactive document zoom controls and a collapsible preview pane.
- Customizable Themes: Choose from multiple editor themes (Catppuccin, Arch Linux, Cerberus) and toggle global dark mode.
- Export Options: Export your compiled documents directly to PDF, PNG, SVG, HTML, Markdown, Word, or LaTeX formats using internal conversion and Pandoc integrations.
- User Authentication & Document Access: Secure accounts, workspaces, and sharing features via email-based collaborator invitations (Editor or Viewer roles) for all your documents.
- Admin System: First-run setup wizard creates an admin account. Admins can manage all users, create new accounts with temporary passwords, toggle admin privileges, and delete accounts from the Settings panel.
- Presentation Mode: Turn your documents into instant slideshows with built-in slide controls and a live drawing/annotation tool overlay.
- Asset Management: Upload and seamlessly use custom fonts and images directly within your documents.
TypstDrive allows you to upload custom .ttf or .otf fonts and image files (.png, .jpg, .svg, etc.) to your folders or directly to a document's workspace.
Upload .ttf or .otf files from the dashboard or the editor toolbar. TypstDrive reads the typographic family name embedded in the file, registers all weight and style variants (Bold, Italic, etc.) under that family, and makes them available immediately to the Typst compiler and the tinymist LSP — no page refresh required.
Use the font by its family name, which appears automatically in the editor's font dropdown:
#set text(font: "JetBrains Mono")Bold, italic, and other variants resolve automatically as long as the corresponding font files are uploaded:
#set text(font: "Noto Sans")
*This renders in Noto Sans Italic.*
*#strong[This renders in Noto Sans Bold.]*Google Fonts downloads come as a ZIP containing one .ttf per variant (e.g., NotoSans-Regular.ttf, NotoSans-Bold.ttf, NotoSans-Italic.ttf). Do not upload the ZIP — extract it first, then select and upload all the .ttf files at once. The dashboard file picker supports multi-file selection.
For Google Fonts that offer a variable font (a single file covering all weights and styles), uploading just that one file is sufficient.
The LSP restarts automatically after a font upload, providing instant autocompletion and clearing any "Unknown Font Family" warnings.
Uploaded images can be referenced natively using the #image function in Typst. Simply upload your image file (e.g., logo.png) to your dashboard and reference it by its exact filename in your .typ document.
#image("logo.png", width: 50%)TypstDrive is completely self-hostable. A Docker image packages both the Rust backend and the SvelteKit frontend into a single container.
-
Clone the repository:
git clone https://github.com/your-username/typstdrive.git cd typstdrive -
Start the application:
docker compose up -d
-
Open your browser and navigate to
http://localhost:3000.
On first launch with no users in the database, you will be redirected to the Setup page to create the initial admin account.
By default, TypstDrive uses SQLite — no separate database container required. All data is stored in a single file persisted via the appdata Docker volume.
To switch to PostgreSQL, uncomment the db service in docker-compose.yml and update DATABASE_URL and DB_TYPE as shown in the comments there.
All variables can be set in the environment: section of docker-compose.yml or passed directly to the container.
| Variable | Default | Description |
|---|---|---|
DATABASE_URL |
sqlite:///data/typstdrive.db?mode=rwc |
Database connection URL. Use sqlite:///path/to/file.db?mode=rwc for SQLite or postgres://user:pass@host:5432/db for PostgreSQL. |
DB_TYPE |
auto-detected | Database backend. Set to sqlite or postgres. Auto-detected from DATABASE_URL prefix if omitted. |
PORT |
3000 |
Port the HTTP server listens on. |
STATIC_DIR |
/app/build |
Path to compiled frontend assets. |
COOKIE_SECRET |
(random) | 64+ byte secret used to sign session cookies. If not set, a random key is generated on startup and all sessions are invalidated on every container restart. Generate a stable value with: openssl rand -hex 64 |
ALLOW_REGISTRATION |
true |
Set to false to disable public self-registration. When disabled, the register link is hidden on the login page and the registration endpoint returns 403. Admins can still create accounts from the Settings panel. |
RUST_LOG |
server=debug,tower_http=debug |
Log filter. Set to info for quieter production logs. |
environment:
- DATABASE_URL=sqlite:///data/typstdrive.db?mode=rwc
- DB_TYPE=sqlite
- PORT=3000
- COOKIE_SECRET=your-64-plus-byte-secret-here
- ALLOW_REGISTRATION=false
- RUST_LOG=infoGenerate a COOKIE_SECRET:
openssl rand -hex 64The first account created via the setup wizard is automatically an administrator. Admins have access to an Admin section in Settings (/settings) which provides:
- A list of all users with creation dates
- Create User — set a username, email, and temporary password; optionally grant admin privileges immediately
- Toggle Admin — promote or demote any other user
- Delete User — permanently remove any account other than your own
Clone the official Typst compiler into the typst/ folder before building the backend:
git clone https://github.com/typst/typst.git typst- Install dependencies:
bun install - Run the dev server:
bun run dev
- Install system dependencies (e.g., on Ubuntu:
sudo apt-get install libssl-dev). - Install
tinymistand ensure it is on yourPATH— the backend uses it for LSP features:curl -L -o ~/.cargo/bin/tinymist \ https://github.com/Myriad-Dreamin/tinymist/releases/latest/download/tinymist-linux-x64 \ && chmod +x ~/.cargo/bin/tinymist
- Set the required environment variables (copy from
docker-compose.ymlor export them). - Navigate to
server/and run:cargo run
The frontend dev server proxies API calls to localhost:3000 automatically.


