From 5e83b79d260598fcdcc2014f99e6669c5b2a44f7 Mon Sep 17 00:00:00 2001
From: Jannis Leidel
Date: Sat, 9 Jan 2010 22:51:03 +0000
Subject: [PATCH] Fixed #12466 - Set HTML class attributes for each field
separately. Thanks for the patch, Bernd Schlapsi.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12153 bcc190cf-cafb-0310-a4f2-bffc1f526a37
---
django/forms/forms.py | 2 +-
tests/regressiontests/forms/forms.py | 13 +++++++++++++
2 files changed, 14 insertions(+), 1 deletion(-)
diff --git a/django/forms/forms.py b/django/forms/forms.py
index d484300a0d..c53a901e73 100644
--- a/django/forms/forms.py
+++ b/django/forms/forms.py
@@ -138,9 +138,9 @@ class BaseForm(StrAndUnicode):
"Helper function for outputting HTML. Used by as_table(), as_ul(), as_p()."
top_errors = self.non_field_errors() # Errors that should be displayed above all fields.
output, hidden_fields = [], []
- html_class_attr = ''
for name, field in self.fields.items():
+ html_class_attr = ''
bf = BoundField(self, field, name)
bf_errors = self.error_class([conditional_escape(error) for error in bf.errors]) # Escape and cache in local variable.
if bf.is_hidden:
diff --git a/tests/regressiontests/forms/forms.py b/tests/regressiontests/forms/forms.py
index 5f9f5dec5d..f9498c41e2 100644
--- a/tests/regressiontests/forms/forms.py
+++ b/tests/regressiontests/forms/forms.py
@@ -1816,6 +1816,12 @@ True
# The error_html_class and required_html_class attributes ####################
+>>> class Person(Form):
+... name = CharField()
+... is_cool = NullBooleanField()
+... email = EmailField(required=False)
+... age = IntegerField()
+
>>> p = Person({})
>>> p.error_css_class = 'error'
>>> p.required_css_class = 'required'
@@ -1827,6 +1833,8 @@ True
+
+
>>> print p.as_p()
@@ -1836,6 +1844,9 @@ True
+
+
+
>>> print p.as_table()
| |
@@ -1844,6 +1855,8 @@ True
+ | |
+ | |