mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Changed the default form presentation of datetime values to not include the
fractional second values (they usually aren't going to be needed). Based on patches from yi.codeplayer@gmail.com, andrews and Wiliam Alves de Souza. Fixed #4428, #4487 git-svn-id: http://code.djangoproject.com/svn/django/trunk@6578 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -11,7 +11,7 @@ from django.utils.translation import ugettext | |||||||
| from django.utils.encoding import StrAndUnicode, smart_unicode | from django.utils.encoding import StrAndUnicode, smart_unicode | ||||||
|  |  | ||||||
| from util import ErrorList, ValidationError | from util import ErrorList, ValidationError | ||||||
| from widgets import TextInput, PasswordInput, HiddenInput, MultipleHiddenInput, FileInput, CheckboxInput, Select, NullBooleanSelect, SelectMultiple | from widgets import TextInput, PasswordInput, HiddenInput, MultipleHiddenInput, FileInput, CheckboxInput, Select, NullBooleanSelect, SelectMultiple, DateTimeInput | ||||||
|  |  | ||||||
| try: | try: | ||||||
|     from decimal import Decimal, DecimalException |     from decimal import Decimal, DecimalException | ||||||
| @@ -284,6 +284,8 @@ DEFAULT_DATETIME_INPUT_FORMATS = ( | |||||||
| ) | ) | ||||||
|  |  | ||||||
| class DateTimeField(Field): | class DateTimeField(Field): | ||||||
|  |     widget = DateTimeInput | ||||||
|  |  | ||||||
|     def __init__(self, input_formats=None, *args, **kwargs): |     def __init__(self, input_formats=None, *args, **kwargs): | ||||||
|         super(DateTimeField, self).__init__(*args, **kwargs) |         super(DateTimeField, self).__init__(*args, **kwargs) | ||||||
|         self.input_formats = input_formats or DEFAULT_DATETIME_INPUT_FORMATS |         self.input_formats = input_formats or DEFAULT_DATETIME_INPUT_FORMATS | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ except NameError: | |||||||
|     from sets import Set as set   # Python 2.3 fallback |     from sets import Set as set   # Python 2.3 fallback | ||||||
|  |  | ||||||
| import copy | import copy | ||||||
|  | import datetime | ||||||
| from itertools import chain | from itertools import chain | ||||||
|  |  | ||||||
| from django.utils.datastructures import MultiValueDict | from django.utils.datastructures import MultiValueDict | ||||||
| @@ -19,7 +20,7 @@ from util import flatatt | |||||||
| __all__ = ( | __all__ = ( | ||||||
|     'Widget', 'TextInput', 'PasswordInput', |     'Widget', 'TextInput', 'PasswordInput', | ||||||
|     'HiddenInput', 'MultipleHiddenInput', |     'HiddenInput', 'MultipleHiddenInput', | ||||||
|     'FileInput', 'Textarea', 'CheckboxInput', |     'FileInput', 'DateTimeInput', 'Textarea', 'CheckboxInput', | ||||||
|     'Select', 'NullBooleanSelect', 'SelectMultiple', 'RadioSelect', |     'Select', 'NullBooleanSelect', 'SelectMultiple', 'RadioSelect', | ||||||
|     'CheckboxSelectMultiple', 'MultiWidget', 'SplitDateTimeWidget', |     'CheckboxSelectMultiple', 'MultiWidget', 'SplitDateTimeWidget', | ||||||
| ) | ) | ||||||
| @@ -133,7 +134,7 @@ class FileInput(Input): | |||||||
|  |  | ||||||
|     def render(self, name, value, attrs=None): |     def render(self, name, value, attrs=None): | ||||||
|         return super(FileInput, self).render(name, None, attrs=attrs) |         return super(FileInput, self).render(name, None, attrs=attrs) | ||||||
|          |  | ||||||
|     def value_from_datadict(self, data, files, name): |     def value_from_datadict(self, data, files, name): | ||||||
|         "File widgets take data from FILES, not POST" |         "File widgets take data from FILES, not POST" | ||||||
|         return files.get(name, None) |         return files.get(name, None) | ||||||
| @@ -151,6 +152,19 @@ class Textarea(Widget): | |||||||
|         final_attrs = self.build_attrs(attrs, name=name) |         final_attrs = self.build_attrs(attrs, name=name) | ||||||
|         return u'<textarea%s>%s</textarea>' % (flatatt(final_attrs), escape(value)) |         return u'<textarea%s>%s</textarea>' % (flatatt(final_attrs), escape(value)) | ||||||
|  |  | ||||||
|  | class DateTimeInput(Input): | ||||||
|  |     input_type = 'text' | ||||||
|  |     format = '%Y-%m-%d %H:%M:%S'     # '2006-10-25 14:30:59' | ||||||
|  |  | ||||||
|  |     def __init__(self, attrs=None, format=None): | ||||||
|  |         super(DateTimeInput, self).__init__(attrs) | ||||||
|  |         if format: | ||||||
|  |             self.format = format | ||||||
|  |  | ||||||
|  |     def render(self, name, value, attrs=None): | ||||||
|  |         return super(DateTimeInput, self).render(name, | ||||||
|  |                 value.strftime(self.format), attrs) | ||||||
|  |  | ||||||
| class CheckboxInput(Widget): | class CheckboxInput(Widget): | ||||||
|     def __init__(self, attrs=None, check_test=bool): |     def __init__(self, attrs=None, check_test=bool): | ||||||
|         super(CheckboxInput, self).__init__(attrs) |         super(CheckboxInput, self).__init__(attrs) | ||||||
| @@ -432,5 +446,5 @@ class SplitDateTimeWidget(MultiWidget): | |||||||
|  |  | ||||||
|     def decompress(self, value): |     def decompress(self, value): | ||||||
|         if value: |         if value: | ||||||
|             return [value.date(), value.time()] |             return [value.date(), value.time().replace(microsecond=0)] | ||||||
|         return [None, None] |         return [None, None] | ||||||
|   | |||||||
| @@ -1201,7 +1201,7 @@ If no ``input_formats`` argument is provided, the default input formats are:: | |||||||
| ``DateTimeField`` | ``DateTimeField`` | ||||||
| ~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|     * Default widget: ``TextInput`` |     * Default widget: ``DateTimeInput`` | ||||||
|     * Empty value: ``None`` |     * Empty value: ``None`` | ||||||
|     * Normalizes to: A Python ``datetime.datetime`` object. |     * Normalizes to: A Python ``datetime.datetime`` object. | ||||||
|     * Validates that the given value is either a ``datetime.datetime``, |     * Validates that the given value is either a ``datetime.datetime``, | ||||||
| @@ -1222,6 +1222,9 @@ If no ``input_formats`` argument is provided, the default input formats are:: | |||||||
|     '%m/%d/%y %H:%M',        # '10/25/06 14:30' |     '%m/%d/%y %H:%M',        # '10/25/06 14:30' | ||||||
|     '%m/%d/%y',              # '10/25/06' |     '%m/%d/%y',              # '10/25/06' | ||||||
|  |  | ||||||
|  | **New in Django development version:** The ``DateTimeField`` used to use a | ||||||
|  | ``TextInput`` widget by default. This has now changed. | ||||||
|  |  | ||||||
| ``DecimalField`` | ``DecimalField`` | ||||||
| ~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| @@ -1558,6 +1561,7 @@ commonly used groups of widgets: | |||||||
|     ``MultipleHiddenInput``       Multiple ``<input type='hidden' ...`` |     ``MultipleHiddenInput``       Multiple ``<input type='hidden' ...`` | ||||||
|                                   instances. |                                   instances. | ||||||
|     ``FileInput``                 ``<input type='file' ...`` |     ``FileInput``                 ``<input type='file' ...`` | ||||||
|  |     ``DateTimeInput``             ``<input type='text' ...`` | ||||||
|     ``Textarea``                  ``<textarea>...</textarea>`` |     ``Textarea``                  ``<textarea>...</textarea>`` | ||||||
|     ``CheckboxInput``             ``<input type='checkbox' ...`` |     ``CheckboxInput``             ``<input type='checkbox' ...`` | ||||||
|     ``Select``                    ``<select><option ...`` |     ``Select``                    ``<select><option ...`` | ||||||
| @@ -1571,6 +1575,9 @@ commonly used groups of widgets: | |||||||
|                                   one for the Date, and one for the Time. |                                   one for the Date, and one for the Time. | ||||||
|     ============================  =========================================== |     ============================  =========================================== | ||||||
|  |  | ||||||
|  | **New in Django development version:** The ``DateTimeInput`` has been added | ||||||
|  | since the last release. | ||||||
|  |  | ||||||
| Specifying widgets | Specifying widgets | ||||||
| ------------------ | ------------------ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -851,4 +851,19 @@ included on both widgets. | |||||||
| >>> w = SplitDateTimeWidget(attrs={'class': 'pretty'}) | >>> w = SplitDateTimeWidget(attrs={'class': 'pretty'}) | ||||||
| >>> w.render('date', datetime.datetime(2006, 1, 10, 7, 30)) | >>> w.render('date', datetime.datetime(2006, 1, 10, 7, 30)) | ||||||
| u'<input type="text" class="pretty" value="2006-01-10" name="date_0" /><input type="text" class="pretty" value="07:30:00" name="date_1" />' | u'<input type="text" class="pretty" value="2006-01-10" name="date_0" /><input type="text" class="pretty" value="07:30:00" name="date_1" />' | ||||||
|  |  | ||||||
|  | # DateTimeInput ############################################################### | ||||||
|  |  | ||||||
|  | >>> w = DateTimeInput() | ||||||
|  | >>> d = datetime.datetime(2007, 9, 17, 12, 51, 34, 482548) | ||||||
|  | >>> print d | ||||||
|  | 2007-09-17 12:51:34.482548 | ||||||
|  |  | ||||||
|  | The microseconds are trimmed on display, by default. | ||||||
|  | >>> w.render('date', d) | ||||||
|  | u'<input type="text" name="date" value="2007-09-17 12:51:34" />' | ||||||
|  | >>> w.render('date', datetime.datetime(2007, 9, 17, 12, 51, 34)) | ||||||
|  | u'<input type="text" name="date" value="2007-09-17 12:51:34" />' | ||||||
|  | >>> w.render('date', datetime.datetime(2007, 9, 17, 12, 51)) | ||||||
|  | u'<input type="text" name="date" value="2007-09-17 12:51:00" />' | ||||||
| """ | """ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user