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
- โจ๏ธ Keyboard Shortcuts: Navigate efficiently with keyboard controls
- ๐ฌ 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
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
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.
### Keyboard Shortcuts
| Key | Action |
|-----|--------|
| `โ` / `Space` / `PageDown` | Next slide |
| `โ` / `PageUp` | Previous slide |
| `Home` | First slide |
| `End` | Last slide |
| `F` | Toggle fullscreen |
| `?` | Show help |
| `Esc` | Exit fullscreen/help |
## ๐ 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
# 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.
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/YOUR_USERNAME/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:
- demo.md: Basic introduction to MarkDeck
- features.md: Comprehensive feature showcase
- code-examples.md: Syntax highlighting demo
- mermaid-test.md: Mermaid diagram examples
Try them out:
markdeck present examples/demo.md
markdeck present examples/features.md
markdeck present examples/code-examples.md
markdeck present examples/mermaid-test.md
๐บ๏ธ Roadmap
Phase 2 - Enhanced Features
- Hot reload (watch file for changes) โ
- Multiple themes (dark/light mode toggle)
- Slide overview/grid view
- Slide transitions
- Two-column layouts
- Media embedding improvements
Phase 3 - Polish & Distribution (Planned)
- Export to PDF
- Export to standalone HTML
- Configuration file support
- Custom themes
- PyPI distribution
- 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.3.0.tar.gz.
File metadata
- Download URL: markdeck-0.3.0.tar.gz
- Upload date:
- Size: 893.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ebd4cf2041a7410b7420fbfbaccee52dcf7f8d5c3d9e93262f98a1db89514239
|
|
| MD5 |
e96838f842e0f26d7dc041b9a93dc0d8
|
|
| BLAKE2b-256 |
d2fb0aee43ddfbc34ccf565e75dc2207caba6e2ded28c4848e081575237aca4a
|
File details
Details for the file markdeck-0.3.0-py3-none-any.whl.
File metadata
- Download URL: markdeck-0.3.0-py3-none-any.whl
- Upload date:
- Size: 21.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9589cd4729b9bdaec89c80ba46e03e16572dd74dd629a20d373ba13c7ae15c81
|
|
| MD5 |
9bd51ff86e8827fa32b36d131208a8fa
|
|
| BLAKE2b-256 |
e72347e2bf121e679160c0cab7910a5d95970c2e6376eeddfa7018a2dccac9c9
|