mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #12454 - Added support for localized formats to admin date and time widgets.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12030 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -44,7 +44,7 @@ var DateTimeShortcuts = { | |||||||
|         var shortcuts_span = document.createElement('span'); |         var shortcuts_span = document.createElement('span'); | ||||||
|         inp.parentNode.insertBefore(shortcuts_span, inp.nextSibling); |         inp.parentNode.insertBefore(shortcuts_span, inp.nextSibling); | ||||||
|         var now_link = document.createElement('a'); |         var now_link = document.createElement('a'); | ||||||
|         now_link.setAttribute('href', "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", new Date().getHourMinuteSecond());"); |         now_link.setAttribute('href', "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", new Date().strftime('" + gettext('TIME_INPUT_FORMATS') + "'));"); | ||||||
|         now_link.appendChild(document.createTextNode(gettext('Now'))); |         now_link.appendChild(document.createTextNode(gettext('Now'))); | ||||||
|         var clock_link = document.createElement('a'); |         var clock_link = document.createElement('a'); | ||||||
|         clock_link.setAttribute('href', 'javascript:DateTimeShortcuts.openClock(' + num + ');'); |         clock_link.setAttribute('href', 'javascript:DateTimeShortcuts.openClock(' + num + ');'); | ||||||
| @@ -80,10 +80,10 @@ var DateTimeShortcuts = { | |||||||
|         quickElement('h2', clock_box, gettext('Choose a time')); |         quickElement('h2', clock_box, gettext('Choose a time')); | ||||||
|         time_list = quickElement('ul', clock_box, ''); |         time_list = quickElement('ul', clock_box, ''); | ||||||
|         time_list.className = 'timelist'; |         time_list.className = 'timelist'; | ||||||
|         quickElement("a", quickElement("li", time_list, ""), gettext("Now"), "href", "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", new Date().getHourMinuteSecond());") |         quickElement("a", quickElement("li", time_list, ""), gettext("Now"), "href", "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", new Date().strftime('" + gettext('TIME_INPUT_FORMATS') + "'));") | ||||||
|         quickElement("a", quickElement("li", time_list, ""), gettext("Midnight"), "href", "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", '00:00:00');") |         quickElement("a", quickElement("li", time_list, ""), gettext("Midnight"), "href", "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", new Date(1970,1,1,0,0,0,0).strftime('" + gettext('TIME_INPUT_FORMATS') + "'));") | ||||||
|         quickElement("a", quickElement("li", time_list, ""), gettext("6 a.m."), "href", "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", '06:00:00');") |         quickElement("a", quickElement("li", time_list, ""), gettext("6 a.m."), "href", "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", new Date(1970,1,1,6,0,0,0).strftime('" + gettext('TIME_INPUT_FORMATS') + "'));") | ||||||
|         quickElement("a", quickElement("li", time_list, ""), gettext("Noon"), "href", "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", '12:00:00');") |         quickElement("a", quickElement("li", time_list, ""), gettext("Noon"), "href", "javascript:DateTimeShortcuts.handleClockQuicklink(" + num + ", new Date(1970,1,1,12,0,0,0).strftime('" + gettext('TIME_INPUT_FORMATS') + "'));") | ||||||
|  |  | ||||||
|         cancel_p = quickElement('p', clock_box, ''); |         cancel_p = quickElement('p', clock_box, ''); | ||||||
|         cancel_p.className = 'calendar-cancel'; |         cancel_p.className = 'calendar-cancel'; | ||||||
| @@ -237,12 +237,19 @@ var DateTimeShortcuts = { | |||||||
|         DateTimeShortcuts.calendars[num].drawNextMonth(); |         DateTimeShortcuts.calendars[num].drawNextMonth(); | ||||||
|     }, |     }, | ||||||
|     handleCalendarCallback: function(num) { |     handleCalendarCallback: function(num) { | ||||||
|         return "function(y, m, d) { DateTimeShortcuts.calendarInputs["+num+"].value = y+'-'+(m<10?'0':'')+m+'-'+(d<10?'0':'')+d; document.getElementById(DateTimeShortcuts.calendarDivName1+"+num+").style.display='none';}"; |         format = gettext('DATE_INPUT_FORMATS'); | ||||||
|  |         // the format needs to be escaped a little | ||||||
|  |         format = format.replace('\\', '\\\\'); | ||||||
|  |         format = format.replace('\r', '\\r'); | ||||||
|  |         format = format.replace('\n', '\\n'); | ||||||
|  |         format = format.replace('\t', '\\t'); | ||||||
|  |         format = format.replace("'", "\\'"); | ||||||
|  |         return "function(y, m, d) { DateTimeShortcuts.calendarInputs["+num+"].value = new Date(y, m-1, d).strftime('"+format+"');document.getElementById(DateTimeShortcuts.calendarDivName1+"+num+").style.display='none';}" | ||||||
|     }, |     }, | ||||||
|     handleCalendarQuickLink: function(num, offset) { |     handleCalendarQuickLink: function(num, offset) { | ||||||
|        var d = new Date(); |        var d = new Date(); | ||||||
|        d.setDate(d.getDate() + offset) |        d.setDate(d.getDate() + offset) | ||||||
|        DateTimeShortcuts.calendarInputs[num].value = d.getISODate(); |        DateTimeShortcuts.calendarInputs[num].value = d.strftime(gettext('DATE_INPUT_FORMATS')); | ||||||
|        DateTimeShortcuts.dismissCalendar(num); |        DateTimeShortcuts.dismissCalendar(num); | ||||||
|     }, |     }, | ||||||
|     cancelEventPropagation: function(e) { |     cancelEventPropagation: function(e) { | ||||||
|   | |||||||
| @@ -115,6 +115,10 @@ Date.prototype.getCorrectYear = function() { | |||||||
|     return (y < 38) ? y + 2000 : y + 1900; |     return (y < 38) ? y + 2000 : y + 1900; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | Date.prototype.getTwelveHours = function() { | ||||||
|  |     return (this.getHours() <= 12) ? this.getHours() : 24 - this.getHours(); | ||||||
|  | } | ||||||
|  |  | ||||||
| Date.prototype.getTwoDigitMonth = function() { | Date.prototype.getTwoDigitMonth = function() { | ||||||
|     return (this.getMonth() < 9) ? '0' + (this.getMonth()+1) : (this.getMonth()+1); |     return (this.getMonth() < 9) ? '0' + (this.getMonth()+1) : (this.getMonth()+1); | ||||||
| } | } | ||||||
| @@ -123,6 +127,10 @@ Date.prototype.getTwoDigitDate = function() { | |||||||
|     return (this.getDate() < 10) ? '0' + this.getDate() : this.getDate(); |     return (this.getDate() < 10) ? '0' + this.getDate() : this.getDate(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | Date.prototype.getTwoDigitTwelveHour = function() { | ||||||
|  |     return (this.getTwelveHours() < 10) ? '0' + this.getTwelveHours() : this.getTwelveHours(); | ||||||
|  | } | ||||||
|  |  | ||||||
| Date.prototype.getTwoDigitHour = function() { | Date.prototype.getTwoDigitHour = function() { | ||||||
|     return (this.getHours() < 10) ? '0' + this.getHours() : this.getHours(); |     return (this.getHours() < 10) ? '0' + this.getHours() : this.getHours(); | ||||||
| } | } | ||||||
| @@ -147,6 +155,37 @@ Date.prototype.getHourMinuteSecond = function() { | |||||||
|     return this.getTwoDigitHour() + ':' + this.getTwoDigitMinute() + ':' + this.getTwoDigitSecond(); |     return this.getTwoDigitHour() + ':' + this.getTwoDigitMinute() + ':' + this.getTwoDigitSecond(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | Date.prototype.strftime = function(format) { | ||||||
|  |     var fields = { | ||||||
|  |         c: this.toString(), | ||||||
|  |         d: this.getTwoDigitDate(), | ||||||
|  |         H: this.getTwoDigitHour(), | ||||||
|  |         I: this.getTwoDigitTwelveHour(), | ||||||
|  |         m: this.getTwoDigitMonth(), | ||||||
|  |         M: this.getTwoDigitMinute(), | ||||||
|  |         p: (this.getHours() >= 12) ? 'PM' : 'AM', | ||||||
|  |         S: this.getTwoDigitSecond(), | ||||||
|  |         w: '0' + this.getDay(), | ||||||
|  |         x: this.toLocaleDateString(), | ||||||
|  |         X: this.toLocaleTimeString(), | ||||||
|  |         y: ('' + this.getFullYear()).substr(2, 4), | ||||||
|  |         Y: '' + this.getFullYear(), | ||||||
|  |         '%' : '%' | ||||||
|  |     }; | ||||||
|  |     var result = '', i = 0; | ||||||
|  |     while (i < format.length) { | ||||||
|  |         if (format[i] === '%') { | ||||||
|  |             result = result + fields[format[i + 1]]; | ||||||
|  |             ++i; | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             result = result + format[i]; | ||||||
|  |         } | ||||||
|  |         ++i; | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
| // ---------------------------------------------------------------------------- | // ---------------------------------------------------------------------------- | ||||||
| // String object extensions | // String object extensions | ||||||
| // ---------------------------------------------------------------------------- | // ---------------------------------------------------------------------------- | ||||||
|   | |||||||
| @@ -7,12 +7,12 @@ from django.utils.importlib import import_module | |||||||
| from django.utils.encoding import smart_str | from django.utils.encoding import smart_str | ||||||
| from django.utils import dateformat, numberformat, datetime_safe | from django.utils import dateformat, numberformat, datetime_safe | ||||||
|  |  | ||||||
| def get_format_modules(): | def get_format_modules(reverse=False): | ||||||
|     """ |     """ | ||||||
|     Returns an iterator over the format modules found in the project and Django |     Returns an iterator over the format modules found in the project and Django | ||||||
|     """ |     """ | ||||||
|     modules = [] |     modules = [] | ||||||
|     if not check_for_language(get_language()): |     if not check_for_language(get_language()) or not settings.USE_L10N: | ||||||
|         return modules |         return modules | ||||||
|     locale = to_locale(get_language()) |     locale = to_locale(get_language()) | ||||||
|     if settings.FORMAT_MODULE_PATH: |     if settings.FORMAT_MODULE_PATH: | ||||||
| @@ -30,6 +30,8 @@ def get_format_modules(): | |||||||
|                 # Don't return duplicates |                 # Don't return duplicates | ||||||
|                 if mod not in modules: |                 if mod not in modules: | ||||||
|                     modules.append(mod) |                     modules.append(mod) | ||||||
|  |     if reverse: | ||||||
|  |         modules.reverse() | ||||||
|     return modules |     return modules | ||||||
|  |  | ||||||
| def get_format(format_type): | def get_format(format_type): | ||||||
|   | |||||||
| @@ -37,15 +37,17 @@ def set_language(request): | |||||||
|  |  | ||||||
| def get_formats(): | def get_formats(): | ||||||
|     """ |     """ | ||||||
|     Returns an iterator over all formats in formats file |     Returns all formats strings required for i18n to work | ||||||
|     """ |     """ | ||||||
|     FORMAT_SETTINGS = ('DATE_FORMAT', 'DATETIME_FORMAT', 'TIME_FORMAT', |     FORMAT_SETTINGS = ( | ||||||
|  |         'DATE_FORMAT', 'DATETIME_FORMAT', 'TIME_FORMAT', | ||||||
|         'YEAR_MONTH_FORMAT', 'MONTH_DAY_FORMAT', 'SHORT_DATE_FORMAT', |         'YEAR_MONTH_FORMAT', 'MONTH_DAY_FORMAT', 'SHORT_DATE_FORMAT', | ||||||
|         'SHORT_DATETIME_FORMAT', 'FIRST_DAY_OF_WEEK', 'DECIMAL_SEPARATOR', |         'SHORT_DATETIME_FORMAT', 'FIRST_DAY_OF_WEEK', 'DECIMAL_SEPARATOR', | ||||||
|         'THOUSAND_SEPARATOR', 'NUMBER_GROUPING') |         'THOUSAND_SEPARATOR', 'NUMBER_GROUPING', | ||||||
|  |         'DATE_INPUT_FORMATS', 'TIME_INPUT_FORMATS', 'DATETIME_INPUT_FORMATS' | ||||||
|  |     ) | ||||||
|     result = {} |     result = {} | ||||||
|     for module in [settings] + get_format_modules(): |     for module in [settings] + get_format_modules(reverse=True): | ||||||
|         for attr in FORMAT_SETTINGS: |         for attr in FORMAT_SETTINGS: | ||||||
|             try: |             try: | ||||||
|                 result[attr] = getattr(module, attr) |                 result[attr] = getattr(module, attr) | ||||||
| @@ -141,7 +143,7 @@ def javascript_catalog(request, domain='djangojs', packages=None): | |||||||
|                 activate(request.GET['language']) |                 activate(request.GET['language']) | ||||||
|     if packages is None: |     if packages is None: | ||||||
|         packages = ['django.conf'] |         packages = ['django.conf'] | ||||||
|     if type(packages) in (str, unicode): |     if isinstance(packages, basestring): | ||||||
|         packages = packages.split('+') |         packages = packages.split('+') | ||||||
|     packages = [p for p in packages if p == 'django.conf' or p in settings.INSTALLED_APPS] |     packages = [p for p in packages if p == 'django.conf' or p in settings.INSTALLED_APPS] | ||||||
|     default_locale = to_locale(settings.LANGUAGE_CODE) |     default_locale = to_locale(settings.LANGUAGE_CODE) | ||||||
| @@ -195,9 +197,9 @@ def javascript_catalog(request, domain='djangojs', packages=None): | |||||||
|     for k, v in t.items(): |     for k, v in t.items(): | ||||||
|         if k == '': |         if k == '': | ||||||
|             continue |             continue | ||||||
|         if type(k) in (str, unicode): |         if isinstance(k, basestring): | ||||||
|             csrc.append("catalog['%s'] = '%s';\n" % (javascript_quote(k), javascript_quote(v))) |             csrc.append("catalog['%s'] = '%s';\n" % (javascript_quote(k), javascript_quote(v))) | ||||||
|         elif type(k) == tuple: |         elif isinstance(k, tuple): | ||||||
|             if k[0] not in pdict: |             if k[0] not in pdict: | ||||||
|                 pdict[k[0]] = k[1] |                 pdict[k[0]] = k[1] | ||||||
|             else: |             else: | ||||||
| @@ -209,7 +211,11 @@ def javascript_catalog(request, domain='djangojs', packages=None): | |||||||
|     for k, v in pdict.items(): |     for k, v in pdict.items(): | ||||||
|         src.append("catalog['%s'] = [%s];\n" % (javascript_quote(k), ','.join(["''"]*(v+1)))) |         src.append("catalog['%s'] = [%s];\n" % (javascript_quote(k), ','.join(["''"]*(v+1)))) | ||||||
|     for k, v in get_formats().items(): |     for k, v in get_formats().items(): | ||||||
|         src.append("catalog['%s'] = '%s';\n" % (javascript_quote(k), javascript_quote(smart_unicode(v)))) |         if isinstance(v, (basestring, int)): | ||||||
|  |             src.append("catalog['%s'] = '%s';\n" % (javascript_quote(k), javascript_quote(smart_unicode(v)))) | ||||||
|  |         elif isinstance(v, (tuple, list)): | ||||||
|  |             v = [javascript_quote(smart_unicode(value)) for value in v] | ||||||
|  |             src.append("catalog['%s'] = ['%s'];\n" % (javascript_quote(k), "', '".join(v))) | ||||||
|     src.extend(csrc) |     src.extend(csrc) | ||||||
|     src.append(LibFoot) |     src.append(LibFoot) | ||||||
|     src.append(InterPolate) |     src.append(InterPolate) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user