Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eddyluten/mkdocs-live-edit-plugin
An MkDocs plugin that allows editing pages directly from the browser.
https://github.com/eddyluten/mkdocs-live-edit-plugin
documentation live-editing mkdocs mkdocs-plugin wiki
Last synced: 4 months ago
JSON representation
An MkDocs plugin that allows editing pages directly from the browser.
- Host: GitHub
- URL: https://github.com/eddyluten/mkdocs-live-edit-plugin
- Owner: EddyLuten
- License: mit
- Created: 2023-06-22T07:14:15.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-03-07T04:51:29.000Z (11 months ago)
- Last Synced: 2024-10-01T10:01:52.266Z (4 months ago)
- Topics: documentation, live-editing, mkdocs, mkdocs-plugin, wiki
- Language: Python
- Homepage:
- Size: 45.9 KB
- Stars: 13
- Watchers: 2
- Forks: 2
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# mkdocs-live-edit-plugin
[![PyPI version](https://badge.fury.io/py/mkdocs-live-edit-plugin.svg)](https://pypi.org/project/mkdocs-live-edit-plugin/) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) ![example workflow](https://github.com/eddyluten/mkdocs-live-edit-plugin/actions/workflows/pylint.yml/badge.svg) [![Downloads](https://pepy.tech/badge/mkdocs-live-edit-plugin)](https://pepy.tech/project/mkdocs-live-edit-plugin)
mkdocs-live-edit-plugin is 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
- Creating a brand new pageSome 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 changesIf you like this plugin, you'll probably also like [mkdocs-categories-plugin](https://github.com/EddyLuten/mkdocs-categories-plugin) and [mkdocs-alias-plugin](https://github.com/EddyLuten/mkdocs-alias-plugin).
## Installation
Using Python 3.10 or greater, install the package using pip:
```zsh
pip install mkdocs-live-edit-plugin
```Then add the following entry to the plugins section of your `mkdocs.yml` file:
```yml
plugins:
- live-edit
```## Usage
[![A video showing how to use v0.1.0](https://img.youtube.com/vi/8aUToGfXGVA/0.jpg)](https://www.youtube.com/watch?v=8aUToGfXGVA)
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:
```yml
plugins:
- live-edit:
websockets_port: 9999 # or any other port you want
```## TODO
- Creating new pages (not sure how picking directories would work)
- Moving pages (also not sure about handling directories here)
- Integration with [mkdocs-categories-plugin](https://github.com/EddyLuten/mkdocs-categories-plugin)
- Integration with [mkdocs-alias-plugin](https://github.com/EddyLuten/mkdocs-alias-plugin)## How Does it Work?
The short answer: [WebSockets](https://developer.mozilla.org/en-US/docs/Web/API/WebSockets_API) 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 in the browser, 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.2.0
**New Feature:** Creating pages. The plugin now exposes a button that allows you to create a brand new page from any other page.
### 0.1.5
**Bug fix:** fixes an issue where the WebSocket connection would host on localhost over IPv6. See [#3](https://github.com/EddyLuten/mkdocs-live-edit-plugin/issues/3) for context.
### 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.