A lightweight markdown presentation tool
Project description
MarkDeck ๐ฌ
A lightweight, markdown-based presentation tool that runs locally.
โจ Features
- ๐ Markdown-based: Write presentations in plain text using familiar Markdown syntax
- ๐ Fast & Lightweight: No heavy frameworks, just clean HTML/CSS/JS
- ๐ฅ Hot Reload: Automatically refreshes when you edit your markdown file (with
--watch) - ๐จ Beautiful Design: Modern, distraction-free presentation interface with multiple themes
- โจ๏ธ Keyboard Shortcuts: Navigate efficiently with keyboard controls
- ๐ Grid View: Overview all slides at once with interactive thumbnail grid (press
O) - ๐ญ Multiple Themes: Dark, light, and beige themes (press
Tto cycle) - ๐ Two-Column Layouts: Create side-by-side content with easy syntax
- ๐ฌ Speaker Notes: Hidden notes visible in terminal
- ๐ฏ Syntax Highlighting: Beautiful code blocks powered by highlight.js
- ๐ Mermaid Diagrams: Create flowcharts, sequence diagrams, and more with Mermaid.js
- ๐ข Math Equations: LaTeX-style math rendering powered by KaTeX
- ๐ฑ Responsive: Works on different screen sizes
- ๐ง Easy Setup: Simple CLI interface, no complex configuration
๐ Quick Start
Installation
Install from GitHub (Recommended)
# Install directly from GitHub using uv
uv pip install git+https://github.com/orangewise/markdeck.git
# Install from a specific branch
uv pip install git+https://github.com/orangewise/markdeck.git@claude/init-markdeck-project-01DJeHxbuthmNtDFjgxToFrP
# Then run it
markdeck present examples/demo.md
Install from Local Clone
# Clone the repository
git clone https://github.com/orangewise/markdeck.git
cd markdeck
# Using uv (recommended)
uv pip install -e .
# Or using pip
pip install -e .
Run Without Installing
You can run MarkDeck directly without permanent installation:
# Create a test presentation
echo "# Hello MarkDeck
---
## Your First Slide
- Quick
- Easy
- Beautiful
---
## That's It!
Start creating your own presentations!" > test.md
# Run directly from a GitHub branch (no installation needed)
uvx --from git+https://github.com/orangewise/markdeck.git@claude/init-markdeck-project-01DJeHxbuthmNtDFjgxToFrP markdeck present test.md
# Or use the main branch
uvx --from git+https://github.com/orangewise/markdeck.git markdeck present test.md
Prune uv to clear caches
uv cache prune --force
uv cache clean markdeck
uvx . present examples/features.md --watch
Clear Browser Cache
- Safari: Cmd + Option + R (or hold Shift while clicking reload)
- Chrome/Edge: Cmd + Shift + R (should work)
- Firefox: Cmd + Shift + R
Create Your First Presentation
# Create a new presentation from template
markdeck init my-presentation.md
# Start presenting
markdeck present my-presentation.md
Your browser will automatically open to http://127.0.0.1:8000 with your presentation ready!
๐ Usage
Basic Commands
# Present a markdown file
markdeck present slides.md
# Present with hot reload (auto-refresh on file changes)
markdeck present slides.md --watch
# Present on a custom port
markdeck present slides.md --port 3000
# Present without auto-opening browser (useful for automated screenshot capture)
markdeck present slides.md --no-browser
# Combine options
markdeck present slides.md --watch --port 3000
# Create a new presentation
markdeck init my-talk.md
# Create with custom title
markdeck init my-talk.md --title "My Awesome Talk"
# Validate a presentation file
markdeck validate slides.md
# Show version
markdeck --version
Markdown Syntax
Create slides by separating content with --- on its own line:
# My First Slide
This is the content of the first slide.
---
# Second Slide
- Bullet point 1
- Bullet point 2
- Bullet point 3
---
# Code Example
```python
def hello_markdeck():
print("Hello from MarkDeck!")
```
---
# Slide with Speaker Notes
This content is visible to the audience.
<!--NOTES:
These are speaker notes.
They will appear in the terminal where you run markdeck.
-->
Keyboard Shortcuts
| Key | Action |
|---|---|
โ / Space / PageDown |
Next slide |
โ / PageUp |
Previous slide |
Home |
First slide |
End |
Last slide |
O |
Toggle grid view (slide overview) |
T |
Cycle themes (dark/light/beige) |
F |
Toggle fullscreen |
? |
Show help |
Esc |
Exit fullscreen/help/grid |
๐ Project Structure
markdeck/
โโโ markdeck/ # Main package
โ โโโ __init__.py
โ โโโ __main__.py # Entry point
โ โโโ cli.py # CLI interface
โ โโโ server.py # FastAPI server
โ โโโ parser.py # Markdown parser
โ โโโ static/ # Frontend files
โ โโโ index.html
โ โโโ style.css
โ โโโ slides.js
โโโ tests/ # Unit tests
โโโ examples/ # Example presentations
โ โโโ demo.md
โ โโโ features.md
โ โโโ code-examples.md
โโโ pyproject.toml # Project configuration
๐จ Features in Detail
Markdown Support
MarkDeck supports standard Markdown features:
- Headings:
#through###### - Bold:
**bold**or__bold__ - Italic:
*italic*or_italic_ - Code:
`inline code` - Links:
[text](url) - Images:
 - Lists: Unordered (
-,*,+) and ordered (1.,2.) - Tables: GitHub-flavored markdown tables
- Blockquotes:
> quote - Code blocks: Fenced with
```
Code Syntax Highlighting
MarkDeck includes syntax highlighting for many languages:
# Python
def fibonacci(n):
return n if n <= 1 else fibonacci(n-1) + fibonacci(n-2)
// JavaScript
const greet = (name) => console.log(`Hello, ${name}!`);
// Rust
fn main() {
println!("Hello, MarkDeck!");
}
Speaker Notes
Add speaker notes that are hidden from the main view:
# My Slide
Visible content here.
<!--NOTES:
These notes are only visible when you press 'S'
- Remember to mention X
- Don't forget Y
- Time: 2 minutes
-->
Mermaid Diagrams
MarkDeck supports Mermaid diagrams for visualizing concepts, workflows, and architecture:
```mermaid
graph TD
A[Start] --> B{Is it working?}
B -->|Yes| C[Great!]
B -->|No| D[Debug]
D --> B
C --> E[End]
```
Supported diagram types:
- Flowcharts (
graph,flowchart) - Sequence diagrams (
sequenceDiagram) - Class diagrams (
classDiagram) - State diagrams (
stateDiagram-v2) - Git graphs (
gitGraph) - Pie charts (
pie) - And many more!
Diagrams render with a dark theme that matches MarkDeck's interface and scale responsively to fit your slides.
Two-Column Layouts
MarkDeck supports two-column layouts for side-by-side content presentation:
:::columns
### Left Column
Content on the left side
|||
### Right Column
Content on the right side
:::
Features:
- Simple
:::columnssyntax with|||separator - Supports all markdown features in each column (code, lists, images, etc.)
- Responsive design - columns stack vertically on mobile devices
- Perfect for comparisons, code + documentation, pros/cons lists
Common use cases:
- Code comparisons: Before/after examples side-by-side
- Documentation: Code on one side, explanation on the other
- Comparisons: Pros vs Cons, Old vs New approaches
- Multi-language examples: Same logic in different languages
Example - Code & Explanation:
:::columns
### The Code
```python
def factorial(n):
if n <= 1:
return 1
return n * factorial(n - 1)
```
|||
### How It Works
This recursive function calculates factorials.
**Base case**: n โค 1 returns 1
**Recursive**: n ร factorial(n-1)
:::
See examples/two-column-examples.md for comprehensive examples.
Grid View / Slide Overview
MarkDeck provides a grid view for quick navigation and overview of your entire presentation:
How to use:
- Press
Oat any time to toggle the grid view - See all slides as interactive thumbnails in a responsive grid layout
- Click any slide to jump directly to it
- The current slide is highlighted with a blue border
Features:
- Visual previews of all slides
- Current slide indicator
- Quick navigation by clicking thumbnails
- Responsive grid layout that adapts to screen size
- Keyboard controls (
Oto toggle,Escto close)
Perfect for:
- Long presentations (20+ slides)
- Finding specific slides during Q&A
- Getting an overview of presentation structure
- Quick navigation during practice sessions
Visual Preview:
Click to see grid view screenshots
Normal presentation view
Grid view showing all slides as thumbnails
Current slide highlighted with blue border
Hot Reload
MarkDeck includes hot reload functionality for a seamless development experience:
# Start with watch mode enabled
markdeck present my-slides.md --watch
What happens:
- MarkDeck monitors your markdown file for changes
- When you save edits, the presentation automatically refreshes in your browser
- You stay on the current slide (or closest available slide if slides were removed)
- A brief "Presentation reloaded" notification appears
Perfect for:
- Iterating on your presentation content
- Live editing during practice sessions
- Quick feedback on formatting and layout changes
๐ ๏ธ Development
Setup Development Environment
# Clone the repository
git clone https://github.com/orangewise/markdeck.git
cd markdeck
# Install with development dependencies
uv pip install -e ".[dev]"
# Run tests
python -m unittest discover tests/
# Run linter
ruff check .
# Format code
ruff format .
Running Tests
# Run all tests
python -m unittest discover tests/
# Run with verbose output
python -m unittest discover tests/ -v
# Run specific test file
python -m unittest tests.test_parser
Project Commands
# Run the server in development mode
python -m markdeck present examples/demo.md
# Run linting
ruff check markdeck/ tests/
# Format code
ruff format markdeck/ tests/
๐ Examples
Check out the examples/ directory for sample presentations:
- features.md: Comprehensive feature showcase
- two-column-examples.md: Two-column layout examples
- code-examples.md: Syntax highlighting demo
Try them out:
markdeck present examples/features.md
markdeck present examples/two-column-examples.md
markdeck present examples/code-examples.md
๐บ๏ธ Roadmap
Phase 2 - Enhanced Features
- Hot reload (watch file for changes) โ
- Slide overview/grid view โ
- PyPI distribution โ
- Multiple themes (dark/light/beige) โ
- Two-column layouts โ
- Slide transitions
- Media embedding improvements
Phase 3 - Polish & Distribution (Planned)
- Export to PDF
- Export to standalone HTML
- Configuration file support
- Custom themes
- Plugin system
๐ค Contributing
Contributions are welcome! Here's how you can help:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Make your changes
- Add tests for new features
- Run tests and linting
- Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
Please ensure:
- Code follows PEP 8 style guide
- All tests pass
- New features include tests
- Documentation is updated
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
- FastAPI - Modern web framework
- marked.js - Markdown parser
- highlight.js - Syntax highlighting
- Mermaid.js - Diagram and flowchart generation
- Python-Markdown - Server-side markdown parsing
๐ Support
- ๐ Report bugs
- ๐ก Request features
- ๐ Documentation
โญ Show Your Support
If you find MarkDeck useful, please consider giving it a star on GitHub!
Made with โค๏ธ by the MarkDeck community
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file markdeck-0.4.0.tar.gz.
File metadata
- Download URL: markdeck-0.4.0.tar.gz
- Upload date:
- Size: 1.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
67eb5ae36595250be6259cfa4123734ce2346ccadc4f8f8fbc42ad0568e24cdb
|
|
| MD5 |
36c44f7aaca30ed40d6bb5961370dddc
|
|
| BLAKE2b-256 |
69f22ab725938774a05395f5bb2622b5d2135d634cda93d02558af78061445a7
|
File details
Details for the file markdeck-0.4.0-py3-none-any.whl.
File metadata
- Download URL: markdeck-0.4.0-py3-none-any.whl
- Upload date:
- Size: 25.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f26632f09c45ccda9df3c8baffd278e4517c6d76b2f16b2360aa1c92e8a62a41
|
|
| MD5 |
2c1540afbace6793ecb8d9d1f58244a2
|
|
| BLAKE2b-256 |
aea314c15e032f0eeb44cba30e73f57f1ed237f5c5f6722a85b1d42b043f7355
|