|
@@ -136,7 +136,7 @@ def model_to_dict(instance, fields=None, exclude=None):
|
|
|
data[f.name] = f.value_from_object(instance)
|
|
|
return data
|
|
|
|
|
|
-def fields_for_model(model, fields=None, exclude=None, widgets=None, formfield_callback=None):
|
|
|
+def fields_for_model(model, fields=None, exclude=None, widgets=None, localized_fields=None, formfield_callback=None):
|
|
|
"""
|
|
|
Returns a ``SortedDict`` containing form fields for the given model.
|
|
|
|
|
@@ -162,10 +162,12 @@ def fields_for_model(model, fields=None, exclude=None, widgets=None, formfield_c
|
|
|
continue
|
|
|
if exclude and f.name in exclude:
|
|
|
continue
|
|
|
+
|
|
|
+ kwargs = {}
|
|
|
if widgets and f.name in widgets:
|
|
|
- kwargs = {'widget': widgets[f.name]}
|
|
|
- else:
|
|
|
- kwargs = {}
|
|
|
+ kwargs['widget'] = widgets[f.name]
|
|
|
+ if localized_fields == ALL_FIELDS or (localized_fields and f.name in localized_fields):
|
|
|
+ kwargs['localize'] = True
|
|
|
|
|
|
if formfield_callback is None:
|
|
|
formfield = f.formfield(**kwargs)
|
|
@@ -192,6 +194,7 @@ class ModelFormOptions(object):
|
|
|
self.fields = getattr(options, 'fields', None)
|
|
|
self.exclude = getattr(options, 'exclude', None)
|
|
|
self.widgets = getattr(options, 'widgets', None)
|
|
|
+ self.localized_fields = getattr(options, 'localized_fields', None)
|
|
|
|
|
|
|
|
|
class ModelFormMetaclass(type):
|
|
@@ -215,7 +218,7 @@ class ModelFormMetaclass(type):
|
|
|
# We check if a string was passed to `fields` or `exclude`,
|
|
|
# which is likely to be a mistake where the user typed ('foo') instead
|
|
|
# of ('foo',)
|
|
|
- for opt in ['fields', 'exclude']:
|
|
|
+ for opt in ['fields', 'exclude', 'localized_fields']:
|
|
|
value = getattr(opts, opt)
|
|
|
if isinstance(value, six.string_types) and value != ALL_FIELDS:
|
|
|
msg = ("%(model)s.Meta.%(opt)s cannot be a string. "
|
|
@@ -242,8 +245,9 @@ class ModelFormMetaclass(type):
|
|
|
# fields from the model"
|
|
|
opts.fields = None
|
|
|
|
|
|
- fields = fields_for_model(opts.model, opts.fields,
|
|
|
- opts.exclude, opts.widgets, formfield_callback)
|
|
|
+ fields = fields_for_model(opts.model, opts.fields, opts.exclude,
|
|
|
+ opts.widgets, opts.localized_fields, formfield_callback)
|
|
|
+
|
|
|
# make sure opts.fields doesn't specify an invalid field
|
|
|
none_model_fields = [k for k, v in six.iteritems(fields) if not v]
|
|
|
missing_fields = set(none_model_fields) - \
|
|
@@ -409,7 +413,7 @@ class ModelForm(six.with_metaclass(ModelFormMetaclass, BaseModelForm)):
|
|
|
pass
|
|
|
|
|
|
def modelform_factory(model, form=ModelForm, fields=None, exclude=None,
|
|
|
- formfield_callback=None, widgets=None):
|
|
|
+ localized_fields=None, widgets=None, formfield_callback=None):
|
|
|
"""
|
|
|
Returns a ModelForm containing form fields for the given model.
|
|
|
|
|
@@ -423,6 +427,8 @@ def modelform_factory(model, form=ModelForm, fields=None, exclude=None,
|
|
|
|
|
|
``widgets`` is a dictionary of model field names mapped to a widget.
|
|
|
|
|
|
+ ``localized_fields`` is a list of names of fields which should be localized.
|
|
|
+
|
|
|
``formfield_callback`` is a callable that takes a model field and returns
|
|
|
a form field.
|
|
|
"""
|
|
@@ -438,6 +444,8 @@ def modelform_factory(model, form=ModelForm, fields=None, exclude=None,
|
|
|
attrs['exclude'] = exclude
|
|
|
if widgets is not None:
|
|
|
attrs['widgets'] = widgets
|
|
|
+ if localized_fields is not None:
|
|
|
+ attrs['localized_fields'] = localized_fields
|
|
|
|
|
|
# If parent form class already has an inner Meta, the Meta we're
|
|
|
# creating needs to inherit from the parent's inner meta.
|
|
@@ -726,8 +734,8 @@ class BaseModelFormSet(BaseFormSet):
|
|
|
|
|
|
def modelformset_factory(model, form=ModelForm, formfield_callback=None,
|
|
|
formset=BaseModelFormSet, extra=1, can_delete=False,
|
|
|
- can_order=False, max_num=None, fields=None,
|
|
|
- exclude=None, widgets=None, validate_max=False):
|
|
|
+ can_order=False, max_num=None, fields=None, exclude=None,
|
|
|
+ widgets=None, validate_max=False, localized_fields=None):
|
|
|
"""
|
|
|
Returns a FormSet class for the given Django model class.
|
|
|
"""
|
|
@@ -748,7 +756,7 @@ def modelformset_factory(model, form=ModelForm, formfield_callback=None,
|
|
|
|
|
|
form = modelform_factory(model, form=form, fields=fields, exclude=exclude,
|
|
|
formfield_callback=formfield_callback,
|
|
|
- widgets=widgets)
|
|
|
+ widgets=widgets, localized_fields=localized_fields)
|
|
|
FormSet = formset_factory(form, formset, extra=extra, max_num=max_num,
|
|
|
can_order=can_order, can_delete=can_delete,
|
|
|
validate_max=validate_max)
|
|
@@ -885,9 +893,9 @@ def _get_foreign_key(parent_model, model, fk_name=None, can_fail=False):
|
|
|
|
|
|
def inlineformset_factory(parent_model, model, form=ModelForm,
|
|
|
formset=BaseInlineFormSet, fk_name=None,
|
|
|
- fields=None, exclude=None,
|
|
|
- extra=3, can_order=False, can_delete=True, max_num=None,
|
|
|
- formfield_callback=None, widgets=None, validate_max=False):
|
|
|
+ fields=None, exclude=None, extra=3, can_order=False,
|
|
|
+ can_delete=True, max_num=None, formfield_callback=None,
|
|
|
+ widgets=None, validate_max=False, localized_fields=None):
|
|
|
"""
|
|
|
Returns an ``InlineFormSet`` for the given kwargs.
|
|
|
|
|
@@ -910,6 +918,7 @@ def inlineformset_factory(parent_model, model, form=ModelForm,
|
|
|
'max_num': max_num,
|
|
|
'widgets': widgets,
|
|
|
'validate_max': validate_max,
|
|
|
+ 'localized_fields': localized_fields,
|
|
|
}
|
|
|
FormSet = modelformset_factory(model, **kwargs)
|
|
|
FormSet.fk = fk
|