django-markdownx/markdownx/widgets.py
Hopiu f7bd2186f8 Update widgets.py
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>
```
2017-04-11 08:45:30 +02:00

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'),
}