Skip to main content

An MkDocs plugin that allows editing pages directly from the browser.

Project description

mkdocs-live-edit-plugin

PyPI version License: MIT example workflow Downloads

An MkDocs plugin that allows editing pages directly from the browser.

Things you can do with this plugin when running via mkdocs serve:

  • Editing a page's Markdown source from the page itself.
  • Renaming a page's filename
  • Deleting a page

Some basic editor shortcuts available while editing:

  • Ctrl+B/Cmd+B toggles your selection to be Bold
  • Ctrl+I/Cmd+I toggles your selection to be Italic
  • Alt+S/Opt+S toggles your selection to be Strikethrough
  • Ctrl+S/Cmd+S to save your changes

If you like this plugin, you'll probably also like mkdocs-categories-plugin and mkdocs-alias-plugin.

Installation

Using Python 3.10 or greater, install the package using pip:

pip install mkdocs-live-edit-plugin

Then add the following entry to the plugins section of your mkdocs.yml file:

plugins:
  - live-edit

Usage

A video showing how to use v0.1.0

If for any reason you want to override the port that the Live Edit WebSocket is operating on, you can do so by setting the websockets_port option for the live-edit plugin, like so:

plugins:
  - live-edit:
      websockets_port: 9999 # or any other port you want

TODO

How Does it Work?

The short answer: WebSockets handle client-server communication, while MkDocs handles reloading when files change.

The Longer Answer

Once installed, when running your local live-reload server, the plugin registers a separate WebSockets server that runs on a specified port. Once your wiki is built, a WebSockets client is installed in your browser, allowing for asynchronous communication between the two.

When you edit the contents of a file, they are sent to the server via WebSockets where the plugin writes the contents to disk. Here, MkDocs picks up on the change and sends a reload signal back to the browser -- this is the same live-reload mechanism that picks up on changes you make via a text editor.

A similar mechanism is in place for other operations like renaming and deleting.

Changelog

0.1.4

Bug fix: Improved WebSocket connectivity and error handling. Updated the documentation to match.

0.1.3

Bug fix: The WebSocket connection now honors the hostname as supplied by the browser in window.location.hostname.

0.1.2

Bug fix: include missing data files

0.1.1

Bug fix: include non-python files in the package

0.1.0

Initial release with editing, renaming, and deletion logic in place.

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-live-edit-plugin-0.1.4.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

mkdocs_live_edit_plugin-0.1.4-py3-none-any.whl (14.1 kB view details)

Uploaded Python 3

File details

Details for the file mkdocs-live-edit-plugin-0.1.4.tar.gz.

File metadata

  • Download URL: mkdocs-live-edit-plugin-0.1.4.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for mkdocs-live-edit-plugin-0.1.4.tar.gz
Algorithm Hash digest
SHA256 308665e843189dd4207b12524cf7d1178bca513a28c5f337ed44d317f9066244
MD5 36b7d829003b3cb9c28fffbec4128448
BLAKE2b-256 05dc2e47753d754313195b514eb8614ffe6c80e0f6a94adf4c1d2d2da42dc771

See more details on using hashes here.

File details

Details for the file mkdocs_live_edit_plugin-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for mkdocs_live_edit_plugin-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0e64f064f1f47c5cdb7d3c4df25304a5a98510fd349d2ac3c4fde08af8073f92
MD5 5e27f2a53d5da2ff409a60fe6f543b18
BLAKE2b-256 47e0962581dba7a880c98c54baa6f44c16f624c0c08890fffcc30ff620f53251

See more details on using hashes here.

Supported by

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