Skip to main content

A lightweight markdown presentation tool

Project description

MarkDeck ๐ŸŽฌ

A lightweight, markdown-based presentation tool that runs locally.

Python License: MIT

โœจ 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 T to cycle)
  • ๐Ÿ“‘ Two-Column Layouts: Create side-by-side content with easy syntax
  • ๐Ÿ“ Wide Slide Mode: Expand slides to 90-98% viewport for wide tables and content
  • ๐Ÿ’ฌ 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: ![alt](url)
  • 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 :::columns syntax 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.

Wide Slide Mode

For slides with wide tables or content that needs more horizontal space, use the <!--SLIDE:wide--> directive:

<!--SLIDE:wide-->

## Wide Table Example

| Column 1 | Column 2 | Column 3 | Column 4 | Column 5 | Column 6 |
|----------|----------|----------|----------|----------|----------|
| Data     | Data     | Data     | Data     | Data     | Data     |

Available width modes:

  • <!--SLIDE:wide--> - 90% viewport width
  • <!--SLIDE:full--> - 95% viewport width
  • <!--SLIDE:ultra-wide--> - 98% viewport width

Usage:

  • Place the directive at the very top of the slide (before any content)
  • Only affects the current slide - other slides maintain normal width
  • Perfect for wide tables, comparison charts, or detailed data

Visual Preview:

Wide Slide Example Wide mode showing a multi-column table with expanded width

Grid View / Slide Overview

MarkDeck provides a grid view for quick navigation and overview of your entire presentation:

How to use:

  • Press O at 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 (O to toggle, Esc to 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 View Normal presentation view

Grid Overview Grid view showing all slides as thumbnails

Current Slide Highlighted 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 โœ“
  • Wide slide mode โœ“
  • 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:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes
  4. Add tests for new features
  5. Run tests and linting
  6. Commit your changes (git commit -m 'Add amazing feature')
  7. Push to the branch (git push origin feature/amazing-feature)
  8. 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

๐Ÿ“ž Support

โญ 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

markdeck-0.5.0.tar.gz (1.6 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

markdeck-0.5.0-py3-none-any.whl (26.5 kB view details)

Uploaded Python 3

File details

Details for the file markdeck-0.5.0.tar.gz.

File metadata

  • Download URL: markdeck-0.5.0.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for markdeck-0.5.0.tar.gz
Algorithm Hash digest
SHA256 d2919a0cb7982c796895f5c6851e4b414e6fc59b9e3519fd5643ab94d1de5b37
MD5 6d824f8ab1d83f2afeb498d793296c12
BLAKE2b-256 0962934d4d227b218789d9e8f58ef7fbf9c22db8f6edb4619e5a8892353dc8c9

See more details on using hashes here.

File details

Details for the file markdeck-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: markdeck-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 26.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for markdeck-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6f066f9efd956be840e14ba5fc096653bed7845d04615d26683e3e74132d665f
MD5 6b95c15e093368b0ecab01b64e0add2f
BLAKE2b-256 6ef91f1c80e5224bbec619156db0538b02ccd79a731a6406bdabd44f76c36893

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page