Better rendering and javascript initialization (@andybak / #2)

This commit is contained in:
Florent Lebreton
2014-11-26 18:35:33 +01:00
parent b29c5964af
commit 02e78b1a6c
7 changed files with 46 additions and 28 deletions

View File

@@ -1,15 +1,21 @@
$(document).ready(function() {
$(".jsign-container").each(function(){
var config = $(this).data('config');
var value = $(this).data('initial-value');
$(this).jSignature(config);
$(this).jSignature("setData", value, "native");
});
/* Each time user is done drawing a stroke, update value of hidden input */
$(document).delegate(".jsign-container", "change", function(e) {
$(".jsign-container").on("change", function(e) {
var jSignature_data = $(this).jSignature('getData', 'native');
var django_field_name = $(this).attr('id').split(/_(.+)/)[1];
$('#id_' + django_field_name).val(JSON.stringify(jSignature_data));
});
/* Bind clear button */
$(document).delegate(".jsign-wrapper input", "click", function(e) {
$(".jsign-wrapper input").on("click", function(e) {
$(this).siblings('.jsign-container').jSignature('reset');
});
})
});

View File

@@ -0,0 +1,8 @@
<div class='jsign-wrapper'>
{{ hidden }}
<div id='{{ jsign_id }}'
data-config='{{ config }}'
data-initial-value='{{ value }}'
class='jsign-container'></div>
<input type='button' value='{{ reset_btn_text }}' class="btn">
</div>

View File

@@ -1,4 +1,6 @@
import json
from pyquery import PyQuery as pq
from django.test import SimpleTestCase
from django.core.exceptions import ValidationError
@@ -59,6 +61,5 @@ class JSignatureWidgetTest(SimpleTestCase):
w = JSignatureWidget()
output = w.render(name='foo', value=None)
# Almost useless :/
self.assertIn('class="jsign-wrapper"', output)
self.assertIn('type="hidden"', output)
self.assertIn('type="text/javascript"', output)
self.assertEqual(1, len(pq('.jsign-wrapper', output)))
self.assertEqual(1, len(pq('[type=hidden]', output)))

View File

@@ -3,6 +3,8 @@
with jSignature jQuery plugin
"""
import json
from django.template.loader import render_to_string
from django.forms.widgets import HiddenInput
from django.core import validators
from django.core.exceptions import ValidationError
@@ -65,15 +67,13 @@ class JSignatureWidget(HiddenInput):
value = self.prep_value(value)
# Build output
hidden_input = super(JSignatureWidget, self).render(name, value, attrs)
div = u'<div id="%s" class="jsign-container"></div>' % jsign_id
clr = u'<input type="button" value="%s" class="btn">' % _('Reset')
js = u'$("#%s").jSignature(%s);' % (
jsign_id, json.dumps(jsignature_config))
js += u'$("#%s").jSignature("setData", %s,"native");' % (
jsign_id, value)
js = u'<script type="text/javascript">%s</script>' % js
out = u'<div class="jsign-wrapper">%s%s%s%s</div>' % (
hidden_input, div, clr, js)
context = {
'hidden': super(JSignatureWidget, self).render(name, value, attrs),
'jsign_id': jsign_id,
'reset_btn_text': _('Reset'),
'config': mark_safe(json.dumps(jsignature_config)),
'value': mark_safe(value),
}
out = render_to_string('jsignature/widget.html', context)
return mark_safe(out)