1. vollust
  2. django-markitup-widget


django-markitup-widget / markitup / widgets.py

widgets for django-markitup

Time-stamp: <2010-01-06 12:31:06 carljm widgets.py>

from django import forms
from django.utils.safestring import mark_safe
from django.contrib.admin.widgets import AdminTextareaWidget

from markitup import settings
from markitup.util import absolute_url, absolute_jquery_url
import posixpath

from markupfield.widgets import MarkupTextarea

#class MarkupTextarea(forms.Textarea):
#    def render(self, name, value, attrs=None):
#        if value is not None:
            # Special handling for MarkupField value.
            # This won't touch simple TextFields because they don't have
            # 'raw' attribute.
#            try:
#                value = value.raw
#            except AttributeError:
#                pass
#        return super(MarkupTextarea, self).render(name, value, attrs)

class MarkItUpWidget(MarkupTextarea):
    Widget for a MarkItUp editor textarea.

    Takes two additional optional keyword arguments:

        URL path (absolute or relative to STATIC_URL) to MarkItUp
        button set directory.  Default: value of MARKITUP_SET setting.

        URL path (absolute or relative to STATIC_URL) to MarkItUp skin
        directory.  Default: value of MARKITUP_SKIN setting.

    def __init__(self, attrs=None,
        self.miu_set = absolute_url(markitup_set or settings.MARKITUP_SET)
        self.miu_skin = absolute_url(markitup_skin or settings.MARKITUP_SKIN)
        if auto_preview is None:
            auto_preview = settings.MARKITUP_AUTO_PREVIEW
        self.auto_preview = auto_preview
        super(MarkItUpWidget, self).__init__(attrs)

    def _media(self):
        return forms.Media(
            css= {'screen': (posixpath.join(self.miu_skin, 'style.css'),
                             posixpath.join(self.miu_set, 'style.css'))},
                posixpath.join(self.miu_set, 'set.js')))
    media = property(_media)

    def render(self, name, value, attrs=None):
        html = super(MarkItUpWidget, self).render(name, value, attrs)

        if self.auto_preview:
            auto_preview = "$('a[title=\"Preview\"]').trigger('mouseup');"
        else: auto_preview = ''

        html += ('<script type="text/javascript">'
                '(function($) { '
                 '$(document).ready(function() {'
                 '  $("#%(id)s").markItUp(mySettings);'
                 '  %(auto_preview)s '
                 '</script>' % {'id': attrs['id'],
                                'auto_preview': auto_preview })
        return mark_safe(html)

class AdminMarkItUpWidget(MarkItUpWidget, AdminTextareaWidget):
    Add vLargeTextarea class to MarkItUpWidget so it looks more
    similar to other admin textareas.