Skip to main content

Live reveal.js slideshow for MyST Markdown notebooks in JupyterLab.

Project description

jupyterlab-myst-revealjs

Github Actions Status

Live reveal.js slideshow for MyST Markdown notebooks in JupyterLab.

Screenshot

Open any notebook as a slideshow panel beside the notebook editor. Markdown cells are rendered via jupyterlab-myst, code cells use JupyterLab's native CodeCell widget — execute code and see results on slides in real time.

Features

  • reveal.js slideshow — present notebooks as reveal.js slides directly in JupyterLab
  • Slide structureslide, subslide, fragment, skip via cell metadata
  • MyST Markdown — admonitions, math, cross-references, and all MyST directives
  • Live code execution — Shift+Enter runs code cells on slides (shared kernel with notebook)
  • Cell tags
    • Jupyter Book compatible — hide-input, hide-output, hide-cell, remove-input, remove-output, remove-cell
    • Grid layout — gridwidth-* tags for multi-column layouts
  • Customization
    • Slide backgrounds — per-slide background color/image via cell metadata
    • Themes — 6 bundled reveal.js themes (black, white, dracula, serif, and more)
    • Custom CSS — drop a myst-revealjs.css next to your notebook for custom styling
    • Header / Footer — CSS-based overlays customizable via myst-revealjs.css
  • Keyboard controls
    • Code visibility toggle — i / o keys to toggle input/output on focused code cells during the slideshow
    • Fullscreen / Overview — f for fullscreen, o for slide overview

Requirements

Install

pip install jupyterlab-myst-revealjs

No Node.js required — this is a prebuilt extension.

Uninstall

pip uninstall jupyterlab-myst-revealjs

Quick Start

  1. Open a notebook in JupyterLab.
  2. Click the slideshow button in the toolbar, or run slideshow:open from the Command Palette.
  3. Set slide types via the Property Inspector (right sidebar).
  4. Press Shift+Enter on code cells to execute them on slides.

Configuration

Add a myst-revealjs key to your notebook metadata to configure reveal.js options:

{
  "myst-revealjs": {
    "theme": "white",
    "transition": "fade",
    "slideNumber": true
  }
}

See the documentation for full configuration options, cell metadata reference, and migration guide from RISE.

Development

Building

uv venv && uv pip install -e ".[dev]"
jlpm install && jlpm build
jupyter labextension develop . --overwrite

Run jlpm watch in one terminal and jupyter lab in another for live development.

Testing

jlpm test                    # Unit tests (Jest)
cd ui-tests && jlpm test     # E2E tests (Playwright + Galata)

See CONTRIBUTING for details.

License

MIT

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

jupyterlab_myst_revealjs-1.4.1.tar.gz (4.3 MB view details)

Uploaded Source

Built Distribution

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

jupyterlab_myst_revealjs-1.4.1-py3-none-any.whl (4.5 MB view details)

Uploaded Python 3

File details

Details for the file jupyterlab_myst_revealjs-1.4.1.tar.gz.

File metadata

  • Download URL: jupyterlab_myst_revealjs-1.4.1.tar.gz
  • Upload date:
  • Size: 4.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for jupyterlab_myst_revealjs-1.4.1.tar.gz
Algorithm Hash digest
SHA256 52027f820e54ee11e459b42bbab88f9cdada21a6ee1e1f49c35e2a6d7dbae0a3
MD5 a4363c4d23bcbb8b954b1c97c2860cbc
BLAKE2b-256 97f5882cc166817b3b7b2e2c75304c0fe9e8c50f4959e3674c802ecbfd5db54e

See more details on using hashes here.

Provenance

The following attestation bundles were made for jupyterlab_myst_revealjs-1.4.1.tar.gz:

Publisher: publish.yml on CojiroSasaki/jupyterlab-myst-revealjs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jupyterlab_myst_revealjs-1.4.1-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyterlab_myst_revealjs-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 de21585936fa46fb096bf330966589f180429fb01511cf12d153a37769b76576
MD5 5dcdc65f10ad0c10d11a3fdae7f29a8e
BLAKE2b-256 48cc59e87bc0ff5a880028ca5fa835251fd0d1085cf726f701dac3e70decacef

See more details on using hashes here.

Provenance

The following attestation bundles were made for jupyterlab_myst_revealjs-1.4.1-py3-none-any.whl:

Publisher: publish.yml on CojiroSasaki/jupyterlab-myst-revealjs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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