diff options
| author | Joseph Kocherhans <joseph@jkocherhans.com> | 2010-03-07 03:33:07 +0000 |
|---|---|---|
| committer | Joseph Kocherhans <joseph@jkocherhans.com> | 2010-03-07 03:33:07 +0000 |
| commit | 5beb5f73722f7807f2be4e95b2fbe4a0e5dcd232 (patch) | |
| tree | 7a1883997f66436db19d240c6e0db1ba8fb584e3 /django/forms | |
| parent | 686dac03b7d6086730234512425f5e81baee7cbd (diff) | |
Fixed #12858. DateTime related widgets now handle custom formats properly in _has_changed. Thanks for the initial patch, camillo.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12698 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'django/forms')
| -rw-r--r-- | django/forms/widgets.py | 30 |
1 files changed, 28 insertions, 2 deletions
diff --git a/django/forms/widgets.py b/django/forms/widgets.py index 81db2a24f3..482888da50 100644 --- a/django/forms/widgets.py +++ b/django/forms/widgets.py @@ -10,8 +10,10 @@ from django.utils.html import escape, conditional_escape from django.utils.translation import ugettext from django.utils.encoding import StrAndUnicode, force_unicode from django.utils.safestring import mark_safe -from django.utils import datetime_safe, formats -from datetime import time +from django.utils import formats +import time +import datetime +from django.utils.formats import get_format from util import flatatt from urlparse import urljoin @@ -313,6 +315,14 @@ class DateInput(Input): return super(DateInput, self).render(name, value, attrs) def _has_changed(self, initial, data): + # If our field has show_hidden_initial=True, initial will be a string + # formatted by HiddenInput using formats.localize_input, which is not + # necessarily the format used for this widget. Attempt to convert it. + try: + input_format = get_format('DATE_INPUT_FORMATS')[0] + initial = datetime.date(*time.strptime(initial, input_format)[:3]) + except (TypeError, ValueError): + pass return super(DateInput, self)._has_changed(self._format_value(initial), data) class DateTimeInput(Input): @@ -336,6 +346,14 @@ class DateTimeInput(Input): return super(DateTimeInput, self).render(name, value, attrs) def _has_changed(self, initial, data): + # If our field has show_hidden_initial=True, initial will be a string + # formatted by HiddenInput using formats.localize_input, which is not + # necessarily the format used for this widget. Attempt to convert it. + try: + input_format = get_format('DATETIME_INPUT_FORMATS')[0] + initial = datetime.datetime(*time.strptime(initial, input_format)[:6]) + except (TypeError, ValueError): + pass return super(DateTimeInput, self)._has_changed(self._format_value(initial), data) class TimeInput(Input): @@ -359,6 +377,14 @@ class TimeInput(Input): return super(TimeInput, self).render(name, value, attrs) def _has_changed(self, initial, data): + # If our field has show_hidden_initial=True, initial will be a string + # formatted by HiddenInput using formats.localize_input, which is not + # necessarily the format used for this widget. Attempt to convert it. + try: + input_format = get_format('TIME_INPUT_FORMATS')[0] + initial = datetime.time(*time.strptime(initial, input_format)[3:6]) + except (TypeError, ValueError): + pass return super(TimeInput, self)._has_changed(self._format_value(initial), data) class CheckboxInput(Widget): |
