Skip to content

Commit

Permalink
Fixed #6230: Fixed the addition of id values to the select widgets in
Browse files Browse the repository at this point in the history
SelectDateWidget. Thanks, Matt McClanahan.


git-svn-id: http://code.djangoproject.com/svn/django/trunk@7291 bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information
malcolmt committed Mar 18, 2008
1 parent 4b9497c commit ec0bbc1
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 9 deletions.
18 changes: 15 additions & 3 deletions django/newforms/extras/widgets.py
Expand Up @@ -39,21 +39,33 @@ def render(self, name, value, attrs=None):


output = [] output = []


if 'id' in self.attrs:
id_ = self.attrs['id']
else:
id_ = 'id_%s' % name

month_choices = MONTHS.items() month_choices = MONTHS.items()
month_choices.sort() month_choices.sort()
select_html = Select(choices=month_choices).render(self.month_field % name, month_val) local_attrs = self.build_attrs(id=self.month_field % id_)
select_html = Select(choices=month_choices).render(self.month_field % name, month_val, local_attrs)
output.append(select_html) output.append(select_html)


day_choices = [(i, i) for i in range(1, 32)] day_choices = [(i, i) for i in range(1, 32)]
select_html = Select(choices=day_choices).render(self.day_field % name, day_val) local_attrs['id'] = self.day_field % id_
select_html = Select(choices=day_choices).render(self.day_field % name, day_val, local_attrs)
output.append(select_html) output.append(select_html)


year_choices = [(i, i) for i in self.years] year_choices = [(i, i) for i in self.years]
select_html = Select(choices=year_choices).render(self.year_field % name, year_val) local_attrs['id'] = self.year_field % id_
select_html = Select(choices=year_choices).render(self.year_field % name, year_val, local_attrs)
output.append(select_html) output.append(select_html)


return mark_safe(u'\n'.join(output)) return mark_safe(u'\n'.join(output))


def id_for_label(self, id_):
return '%s_month' % id_
id_for_label = classmethod(id_for_label)

def value_from_datadict(self, data, files, name): def value_from_datadict(self, data, files, name):
y, m, d = data.get(self.year_field % name), data.get(self.month_field % name), data.get(self.day_field % name) y, m, d = data.get(self.year_field % name), data.get(self.month_field % name), data.get(self.day_field % name)
if y and m and d: if y and m and d:
Expand Down
12 changes: 6 additions & 6 deletions tests/regressiontests/forms/extra.py
Expand Up @@ -22,7 +22,7 @@
>>> from django.newforms.extras import SelectDateWidget >>> from django.newforms.extras import SelectDateWidget
>>> w = SelectDateWidget(years=('2007','2008','2009','2010','2011','2012','2013','2014','2015','2016')) >>> w = SelectDateWidget(years=('2007','2008','2009','2010','2011','2012','2013','2014','2015','2016'))
>>> print w.render('mydate', '') >>> print w.render('mydate', '')
<select name="mydate_month"> <select name="mydate_month" id="id_mydate_month">
<option value="1">January</option> <option value="1">January</option>
<option value="2">February</option> <option value="2">February</option>
<option value="3">March</option> <option value="3">March</option>
Expand All @@ -36,7 +36,7 @@
<option value="11">November</option> <option value="11">November</option>
<option value="12">December</option> <option value="12">December</option>
</select> </select>
<select name="mydate_day"> <select name="mydate_day" id="id_mydate_day">
<option value="1">1</option> <option value="1">1</option>
<option value="2">2</option> <option value="2">2</option>
<option value="3">3</option> <option value="3">3</option>
Expand Down Expand Up @@ -69,7 +69,7 @@
<option value="30">30</option> <option value="30">30</option>
<option value="31">31</option> <option value="31">31</option>
</select> </select>
<select name="mydate_year"> <select name="mydate_year" id="id_mydate_year">
<option value="2007">2007</option> <option value="2007">2007</option>
<option value="2008">2008</option> <option value="2008">2008</option>
<option value="2009">2009</option> <option value="2009">2009</option>
Expand All @@ -84,7 +84,7 @@
>>> w.render('mydate', None) == w.render('mydate', '') >>> w.render('mydate', None) == w.render('mydate', '')
True True
>>> print w.render('mydate', '2010-04-15') >>> print w.render('mydate', '2010-04-15')
<select name="mydate_month"> <select name="mydate_month" id="id_mydate_month">
<option value="1">January</option> <option value="1">January</option>
<option value="2">February</option> <option value="2">February</option>
<option value="3">March</option> <option value="3">March</option>
Expand All @@ -98,7 +98,7 @@
<option value="11">November</option> <option value="11">November</option>
<option value="12">December</option> <option value="12">December</option>
</select> </select>
<select name="mydate_day"> <select name="mydate_day" id="id_mydate_day">
<option value="1">1</option> <option value="1">1</option>
<option value="2">2</option> <option value="2">2</option>
<option value="3">3</option> <option value="3">3</option>
Expand Down Expand Up @@ -131,7 +131,7 @@
<option value="30">30</option> <option value="30">30</option>
<option value="31">31</option> <option value="31">31</option>
</select> </select>
<select name="mydate_year"> <select name="mydate_year" id="id_mydate_year">
<option value="2007">2007</option> <option value="2007">2007</option>
<option value="2008">2008</option> <option value="2008">2008</option>
<option value="2009">2009</option> <option value="2009">2009</option>
Expand Down

0 comments on commit ec0bbc1

Please sign in to comment.