2014-11-02 19:44:46 +00:00
[](https://pypi.python.org/pypi/django-markdownx/)
[](https://pypi.python.org/pypi/django-markdownx/)
[](https://pypi.python.org/pypi/django-markdownx/)
2014-11-01 23:20:50 +00:00
2014-11-01 21:02:31 +00:00
# django-markdownx
2014-11-01 22:13:25 +00:00
Django Markdownx is a markdown editor built for Django.
2014-11-01 21:02:31 +00:00
2014-11-02 19:44:46 +00:00
It is simply an extension of the Django's Textarea widget made for editing Markdown with a live preview. It also supports uploading images with drag& drop functionality and auto tag insertion. Preview pane is rendered (for now only) with [Marked ](https://github.com/chjj/marked ) – JS Markdown compiler.
2014-11-01 21:02:31 +00:00
## Quick Start
2014-11-01 22:16:52 +00:00
1. Install *django-markdownx* package
2014-11-01 21:02:31 +00:00
2014-11-01 22:16:52 +00:00
```python
pip install django-markdownx
```
2014-11-01 21:02:31 +00:00
2014-11-01 22:16:52 +00:00
1. Add *markdownx* to your *INSTALLED_APPS*
2014-11-01 21:02:31 +00:00
2014-11-01 22:16:52 +00:00
```python
2014-11-02 19:44:46 +00:00
#settings .py
2014-11-01 22:16:52 +00:00
INSTALLED_APPS = (
[...]
'markdownx',
```
2014-11-01 21:02:31 +00:00
2014-11-01 22:16:52 +00:00
1. Add *url* pattern to your *urls.py*
```python
2014-11-02 19:44:46 +00:00
#urls .py
2014-11-01 22:16:52 +00:00
urlpatterns = [
[...]
url(r'^markdownx/', include('markdownx.urls')),
]
```
1. Use *MarkdownxInput* widget in your *forms.py*
```python
2014-11-02 19:44:46 +00:00
#forms .py
2014-11-01 22:16:52 +00:00
from django import forms
from markdownx.widgets import MarkdownxInput
class MyForm(forms.ModelForm):
content = forms.CharField(widget=MarkdownxInput)
```
2014-11-01 21:02:31 +00:00
2014-11-02 19:57:16 +00:00
1. Collect included static files
2014-11-01 22:16:52 +00:00
2014-11-02 19:57:16 +00:00
Use `manage.py collectstatic` to copy those files:
2014-11-01 22:16:52 +00:00
static/css/markdownx.css
2014-11-02 20:10:09 +00:00
static/js/markdownx.js
2014-11-01 22:16:52 +00:00
2014-11-02 19:57:16 +00:00
1. Include *[jQuery](http://jquery.com)* and *[Marked](https://github.com/chjj/marked)* files
2014-11-01 22:16:52 +00:00
```html
< head >
[...]
< script src = "{{ STATIC_URL }}js/jquery.js" > < / script >
< script src = "{{ STATIC_URL }}js/marked.js" > < / script >
< / head >
```
2014-11-01 22:09:46 +00:00
2014-11-01 21:02:31 +00:00
# Settings
2014-11-02 19:57:16 +00:00
Place settings in your *settings.py* to override default values:
2014-11-02 19:44:46 +00:00
2014-11-01 22:09:46 +00:00
```python
2014-11-01 23:20:50 +00:00
#settings.py
2014-11-01 22:09:46 +00:00
MARKDOWNX_MEDIA_PATH = 'markdownx/' # subdirectory, where images will be stored in MEDIA_ROOT folder
MARKDOWNX_MAX_UPLOAD_SIZE = 52428800 # 50MB
MARKDOWNX_CONTENT_TYPES = ['image/jpeg', 'image/png']
MARKDOWNX_IMAGE_SIZE = {'size': (500, 500), 'quality': 90,}
```
2014-11-01 21:02:31 +00:00
2014-11-02 19:57:16 +00:00
*MARKDOWNX_IMAGE_SIZE* dict properties:
2014-11-01 21:02:31 +00:00
2014-11-02 19:44:46 +00:00
* **size** – (width, height). When `0` used, i.e.: (500,0), property will figure out proper height by itself
2014-11-01 21:02:31 +00:00
* **quality** – default: `None` – image quality, from `0` (full compression) to `100` (no compression)
* **crop** – default: `False` – if `True` use `size` to crop final image
2014-11-02 19:44:46 +00:00
* **upscale** – default: `False` – if image dimensions are smaller than those in `size` , upscale image to `size` dimensions
2014-11-01 21:02:31 +00:00
2014-11-01 23:20:50 +00:00
# Template
2014-11-01 21:02:31 +00:00
2014-11-01 23:20:50 +00:00
Default template looks like:
2014-11-01 21:02:31 +00:00
2014-11-01 22:09:46 +00:00
```html
< div id = "markdownx" >
< h6 > {% trans "Editor" %}< / h6 >
2014-11-02 20:10:09 +00:00
{{ markdownx_editor }}
2014-11-01 22:09:46 +00:00
< h6 > {% trans "Preview" %}< / h6 >
< div id = "markdownx_preview" > < / div >
< / div >
```
2014-11-01 21:02:31 +00:00
2014-11-01 23:20:50 +00:00
It is easy customizable, i.e. when you want to use Bootstrap 3 and "real" side-by-side panes. Just place `templates/markdownx/widget.html` file with:
2014-11-01 21:02:31 +00:00
2014-11-01 22:09:46 +00:00
```html
< div class = "row" id = "markdownx" >
< div class = "col-sm-6" >
< h6 > {% trans "Editor" %}< / h6 >
2014-11-02 20:10:09 +00:00
{{ markdownx_editor }}
2014-11-01 22:09:46 +00:00
< / div >
< div class = "col-sm-6" >
< h6 > {% trans "Preview" %}< / h6 >
< div id = "markdownx_preview" > < / div >
< / div >
< / div >
```
2014-11-01 21:02:31 +00:00
2014-11-01 23:08:20 +00:00
# Dependencies
2014-11-01 23:24:25 +00:00
* jQuery – AJAX upload and JS functionality
* Marked.js – markdown compiler
2014-11-01 21:02:31 +00:00
# TODO
* use whatever JS markdown compiler
2014-11-01 23:08:20 +00:00
* custom URL upload link
2014-11-02 19:44:46 +00:00
* custom media path function
2014-11-01 23:08:20 +00:00
* tests
2014-11-02 19:44:46 +00:00
* python 3 compatibility
2014-11-01 21:02:31 +00:00
# Changelog
2014-11-03 09:31:41 +00:00
### v0.1.3
* README.md fix on PyPi
2014-11-03 09:14:41 +00:00
### v0.1.2
* critical setuptools fix
2014-11-02 20:10:09 +00:00
### v0.1.1
* change context name `editor` to `markdownx_editor` for better consistency
2014-11-01 22:13:25 +00:00
### v0.1.0
2014-11-01 21:02:31 +00:00
* init
2014-11-01 23:08:20 +00:00
# Notes
**django-markdownx** was inspired by great [django-images ](https://github.com/mirumee/django-images ) and [django-bootstrap-markdown ](http://thegoods.aj7may.com/django-bootstrap-markdown/ ) packages.