diff options
| author | Adrian Holovaty <adrian@holovaty.com> | 2007-01-09 05:12:25 +0000 |
|---|---|---|
| committer | Adrian Holovaty <adrian@holovaty.com> | 2007-01-09 05:12:25 +0000 |
| commit | fb60a6ff0acc84417ced061e83bb170fff351b59 (patch) | |
| tree | 3b7bf5cf6373a50430276bc3d479c32054e6c0ea /django/newforms | |
| parent | 2e148d70647bfab640ab395fc98ba9492d061dad (diff) | |
Fixed #3193 -- newforms: Modified as_hidden() to handle MultipleChoiceField correctly. Thanks for the report, Honza Kral
git-svn-id: http://code.djangoproject.com/svn/django/trunk@4298 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'django/newforms')
| -rw-r--r-- | django/newforms/fields.py | 5 | ||||
| -rw-r--r-- | django/newforms/forms.py | 4 | ||||
| -rw-r--r-- | django/newforms/widgets.py | 14 |
3 files changed, 18 insertions, 5 deletions
diff --git a/django/newforms/fields.py b/django/newforms/fields.py index 408c90df45..e3c1cee87a 100644 --- a/django/newforms/fields.py +++ b/django/newforms/fields.py @@ -4,7 +4,7 @@ Field classes from django.utils.translation import gettext from util import ValidationError, smart_unicode -from widgets import TextInput, PasswordInput, CheckboxInput, Select, SelectMultiple +from widgets import TextInput, PasswordInput, HiddenInput, MultipleHiddenInput, CheckboxInput, Select, SelectMultiple import datetime import re import time @@ -29,6 +29,7 @@ except NameError: class Field(object): widget = TextInput # Default widget to use when rendering this type of Field. + hidden_widget = HiddenInput # Default widget to use when rendering this as "hidden". # Tracks each time a Field instance is created. Used to retain order. creation_counter = 0 @@ -336,6 +337,8 @@ class ChoiceField(Field): return value class MultipleChoiceField(ChoiceField): + hidden_widget = MultipleHiddenInput + def __init__(self, choices=(), required=True, widget=SelectMultiple, label=None, initial=None): ChoiceField.__init__(self, choices, required, widget, label, initial) diff --git a/django/newforms/forms.py b/django/newforms/forms.py index e1cc566b3b..21c9722990 100644 --- a/django/newforms/forms.py +++ b/django/newforms/forms.py @@ -5,7 +5,7 @@ Form classes from django.utils.datastructures import SortedDict, MultiValueDict from django.utils.html import escape from fields import Field -from widgets import TextInput, Textarea, HiddenInput +from widgets import TextInput, Textarea, HiddenInput, MultipleHiddenInput from util import StrAndUnicode, ErrorDict, ErrorList, ValidationError __all__ = ('BaseForm', 'Form') @@ -238,7 +238,7 @@ class BoundField(StrAndUnicode): """ Returns a string of HTML for representing this as an <input type="hidden">. """ - return self.as_widget(HiddenInput(), attrs) + return self.as_widget(self.field.hidden_widget(), attrs) def _data(self): """ diff --git a/django/newforms/widgets.py b/django/newforms/widgets.py index 996e353775..df8bb19c4f 100644 --- a/django/newforms/widgets.py +++ b/django/newforms/widgets.py @@ -3,8 +3,8 @@ HTML Widget classes """ __all__ = ( - 'Widget', 'TextInput', 'PasswordInput', 'HiddenInput', 'FileInput', - 'Textarea', 'CheckboxInput', + 'Widget', 'TextInput', 'PasswordInput', 'HiddenInput', 'MultipleHiddenInput', + 'FileInput', 'Textarea', 'CheckboxInput', 'Select', 'SelectMultiple', 'RadioSelect', 'CheckboxSelectMultiple', ) @@ -87,6 +87,16 @@ class HiddenInput(Input): input_type = 'hidden' is_hidden = True +class MultipleHiddenInput(HiddenInput): + """ + A widget that handles <input type="hidden"> for fields that have a list + of values. + """ + def render(self, name, value, attrs=None): + if value is None: value = [] + final_attrs = self.build_attrs(attrs, type=self.input_type, name=name) + return u'\n'.join([(u'<input%s />' % flatatt(dict(value=smart_unicode(v), **final_attrs))) for v in value]) + class FileInput(Input): input_type = 'file' |
