Skip to main content

Add Zettelkasten features to MkDocs

Project description

MkDocs Zettelkasten

This is a Zettelkasten theme and plugin for MkDocs. It renders the MkDocs pages as cards (zettels).

For more information, head on over to the documentation

Install

pip install mkdocs-zettelkasten

Development

uv sync                    # install deps
uv run playwright install  # install browsers (first time only)

Testing

Three levels of testing, from fast to thorough:

1. Unit tests — plugin logic without building the site:

make test      # ~0.3s, 143 tests

2. E2E tests — playwright builds the site from docs/, serves it, and checks the UI automatically:

make test-e2e  # ~27s, 81 tests

3. Manual acceptance — build and serve the site from docs/, open localhost:8000 in a browser and walk through the checklists in .local/testscripts/:

make run                # default (solarized, validation on)
make run-selenized      # selenized color scheme
make run-editor         # markdown editor enabled
make run-no-validation  # validation disabled

Release

mise adds dev/bin to PATH. Tags with rc in the name publish to TestPyPI; stable tags go to PyPI. Manual workflow dispatch defaults to TestPyPI.

release patch|minor|major              # tag and push -> CI publishes to PyPI
release --pre rc1                      # pre-release current version to TestPyPI
release --pre rc1 minor                # bump + pre-release to TestPyPI
release                                # after rc: strip suffix, release stable to PyPI
release --dry-run patch                # preview without doing anything

First-time setup (already done for mkdocs-zettelkasten):

  • pypi.org: add trusted publisher (owner: buvis, repo: mkdocs-zettelkasten, workflow: publish.yml, env: pypi)
  • test.pypi.org: same, env: testpypi
  • GitHub repo settings: create pypi and testpypi environments

The release script updates the pinned version in .github/workflows/requirements.txt (used by docs deployment), commits, tags, and pushes both. Version derives from git tags via hatch-vcs — no version field in pyproject.toml. This works for pure Python packages. Projects with native extensions (like buvis/gems with maturin/Rust) need an explicit version in pyproject.toml because maturin reads it at build time.

Stable releases (no rc in tag) auto-create a GitHub Release with a changelog generated from conventional commits since the previous tag.

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

mkdocs_zettelkasten-0.6.0.tar.gz (932.0 kB view details)

Uploaded Source

Built Distribution

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

mkdocs_zettelkasten-0.6.0-py3-none-any.whl (897.6 kB view details)

Uploaded Python 3

File details

Details for the file mkdocs_zettelkasten-0.6.0.tar.gz.

File metadata

  • Download URL: mkdocs_zettelkasten-0.6.0.tar.gz
  • Upload date:
  • Size: 932.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mkdocs_zettelkasten-0.6.0.tar.gz
Algorithm Hash digest
SHA256 dba9ff9732457341e9ecbdb971c84bb0f816252bb4cfab147e8db29e8342a165
MD5 5a37bb1f0f48fe68a2bceaac6de50a30
BLAKE2b-256 16bdef8f2c8ae773664db1163d35db75074c796173ad63ad21af0ab735e6752b

See more details on using hashes here.

Provenance

The following attestation bundles were made for mkdocs_zettelkasten-0.6.0.tar.gz:

Publisher: publish.yml on buvis/mkdocs-zettelkasten

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

File details

Details for the file mkdocs_zettelkasten-0.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mkdocs_zettelkasten-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 204804a30d661be7bc166f8d0a7b7fa1e05e114cf1a66c50f2effd40a5966583
MD5 07d9b8a5d5d2158da42d36728116d082
BLAKE2b-256 65badead45dc5b8221767c340b5fb81e622614b4c5dffa3d7d79b98cc769ac4e

See more details on using hashes here.

Provenance

The following attestation bundles were made for mkdocs_zettelkasten-0.6.0-py3-none-any.whl:

Publisher: publish.yml on buvis/mkdocs-zettelkasten

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