mirror of
https://github.com/django/django.git
synced 2025-10-28 10:40:18 +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:
parent
bf33d3eb1d
commit
fa0653cd1d
4 changed files with 72 additions and 18 deletions
|
|
@ -37,15 +37,17 @@ def set_language(request):
|
|||
|
||||
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',
|
||||
'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 = {}
|
||||
for module in [settings] + get_format_modules():
|
||||
for module in [settings] + get_format_modules(reverse=True):
|
||||
for attr in FORMAT_SETTINGS:
|
||||
try:
|
||||
result[attr] = getattr(module, attr)
|
||||
|
|
@ -141,7 +143,7 @@ def javascript_catalog(request, domain='djangojs', packages=None):
|
|||
activate(request.GET['language'])
|
||||
if packages is None:
|
||||
packages = ['django.conf']
|
||||
if type(packages) in (str, unicode):
|
||||
if isinstance(packages, basestring):
|
||||
packages = packages.split('+')
|
||||
packages = [p for p in packages if p == 'django.conf' or p in settings.INSTALLED_APPS]
|
||||
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():
|
||||
if k == '':
|
||||
continue
|
||||
if type(k) in (str, unicode):
|
||||
if isinstance(k, basestring):
|
||||
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:
|
||||
pdict[k[0]] = k[1]
|
||||
else:
|
||||
|
|
@ -209,7 +211,11 @@ def javascript_catalog(request, domain='djangojs', packages=None):
|
|||
for k, v in pdict.items():
|
||||
src.append("catalog['%s'] = [%s];\n" % (javascript_quote(k), ','.join(["''"]*(v+1))))
|
||||
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.append(LibFoot)
|
||||
src.append(InterPolate)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue