mirror of
https://github.com/Hopiu/django-markdownx.git
synced 2026-03-17 05:50:23 +00:00
How about adding those additional values to the template context? This allows having more options on how to render templates.
For example something like bootstrap tabs:
```
<!-- Nav tabs -->
<ul class="nav nav-tabs" role="tablist">
<li class="nav-item">
<a class="nav-link active" data-toggle="tab" href="#edit-{{attrs.id}}" role="tab">Edit</a>
</li>
<li class="nav-item">
<a class="nav-link" data-toggle="tab" href="#preview-{{attrs.id}}" role="tab">Preview</a>
</li>
</ul>
<!-- Tab panes -->
<div class="tab-content markdownx">
<div class="tab-pane active" id="edit-{{attrs.id}}" role="tabpanel">
{{ markdownx_editor }}
</div>
<div class="tab-pane" id="preview-{{attrs.id}}" role="tabpanel">
<div class="markdownx-preview"></div>
</div>
</div>
```
130 lines
3 KiB
Python
Executable file
130 lines
3 KiB
Python
Executable file
from django import VERSION as DJANGO_VERSION
|
|
from django import forms
|
|
from django.template.loader import get_template
|
|
from django.contrib.admin import widgets
|
|
from django.conf import settings
|
|
|
|
from .settings import (
|
|
MARKDOWNX_EDITOR_RESIZABLE,
|
|
MARKDOWNX_URLS_PATH,
|
|
MARKDOWNX_UPLOAD_URLS_PATH,
|
|
MARKDOWNX_SERVER_CALL_LATENCY
|
|
)
|
|
|
|
|
|
DEBUG = getattr(settings, 'DEBUG', False)
|
|
|
|
|
|
class MarkdownxWidget(forms.Textarea):
|
|
"""
|
|
|
|
"""
|
|
|
|
if DJANGO_VERSION[:2] >= (1, 11):
|
|
template_name = 'markdownx/widget2.html'
|
|
|
|
def get_context(self, name, value, attrs=None):
|
|
"""
|
|
|
|
:param name:
|
|
:type name:
|
|
:param value:
|
|
:type value:
|
|
:param attrs:
|
|
:type attrs:
|
|
:return:
|
|
:rtype:
|
|
"""
|
|
if not DJANGO_VERSION[:2] >= (1, 11):
|
|
return super(MarkdownxWidget, self).get_context(name, value, attrs)
|
|
|
|
if attrs is None:
|
|
attrs = {}
|
|
|
|
attrs.update(self.add_markdownx_attrs(attrs))
|
|
|
|
return super(MarkdownxWidget, self).get_context(name, value, attrs)
|
|
|
|
def render(self, name, value, attrs=None, renderer=None):
|
|
"""
|
|
|
|
:param name:
|
|
:type name:
|
|
:param value:
|
|
:type value:
|
|
:param attrs:
|
|
:type attrs:
|
|
:param renderer:
|
|
:type renderer:
|
|
:return:
|
|
:rtype:
|
|
"""
|
|
if not DJANGO_VERSION[:2] < (1, 11):
|
|
return super(MarkdownxWidget, self).render(name, value, attrs, renderer)
|
|
|
|
attrs = self.build_attrs(attrs, name=name)
|
|
attrs.update(self.add_markdownx_attrs(attrs))
|
|
|
|
widget = super(MarkdownxWidget, self).render(name, value, attrs)
|
|
|
|
template = get_template('markdownx/widget.html')
|
|
|
|
return template.render({
|
|
'markdownx_editor': widget,
|
|
'name': name,
|
|
'value': value,
|
|
'attrs': attrs,
|
|
})
|
|
|
|
@staticmethod
|
|
def add_markdownx_attrs(attrs):
|
|
"""
|
|
|
|
:param attrs:
|
|
:type attrs:
|
|
:return:
|
|
:rtype:
|
|
"""
|
|
if 'class' in attrs:
|
|
attrs['class'] += ' markdownx-editor'
|
|
else:
|
|
attrs.update({
|
|
'class': 'markdownx-editor'
|
|
})
|
|
|
|
attrs.update({
|
|
'data-markdownx-editor-resizable': MARKDOWNX_EDITOR_RESIZABLE,
|
|
'data-markdownx-urls-path': MARKDOWNX_URLS_PATH,
|
|
'data-markdownx-upload-urls-path': MARKDOWNX_UPLOAD_URLS_PATH,
|
|
'data-markdownx-latency': MARKDOWNX_SERVER_CALL_LATENCY
|
|
})
|
|
|
|
return attrs
|
|
|
|
class Media:
|
|
"""
|
|
|
|
"""
|
|
|
|
js = {
|
|
'markdownx/js/' + ('markdownx.min.js' if not DEBUG else 'markdownx.js'),
|
|
}
|
|
|
|
|
|
class AdminMarkdownxWidget(MarkdownxWidget, widgets.AdminTextareaWidget):
|
|
"""
|
|
|
|
"""
|
|
|
|
class Media:
|
|
"""
|
|
|
|
"""
|
|
|
|
css = {
|
|
'all': {'markdownx/admin/css/markdownx.css', }
|
|
}
|
|
|
|
js = {
|
|
'markdownx/js/' + ('markdownx.min.js' if not DEBUG else 'markdownx.js'),
|
|
}
|