# HG changeset patch # User Sverre Rabbelier # Date 1236696194 0 # Node ID a456d120c90252784cdc1339430fd17d08d3cbed # Parent 501ffd646d1e52a8eff508bac690de8d967af5d2 Do not override fields in the model if they are already set Patch by: Sverre Rabbelier diff -r 501ffd646d1e -r a456d120c902 app/soc/views/helper/forms.py --- a/app/soc/views/helper/forms.py Tue Mar 10 12:31:25 2009 +0000 +++ b/app/soc/views/helper/forms.py Tue Mar 10 14:43:14 2009 +0000 @@ -59,31 +59,34 @@ Args: *args, **kwargs: passed through to parent __init__() constructor """ + super(djangoforms.ModelForm, self).__init__(*args, **kwargs) + renames = { + 'verbose_name': 'label', + 'help_text': 'help_text', + 'example_text': 'example_text', + 'group': 'group', + } + for field_name in self.fields.iterkeys(): + field = self.fields[field_name] + # Since fields can be added only to the ModelForm subclass, check to # see if the Model has a corresponding field first. if hasattr(self.Meta.model, field_name): model_prop = getattr(self.Meta.model, field_name) - if hasattr(model_prop, 'verbose_name'): - self.fields[field_name].label = model_prop.verbose_name - - if hasattr(model_prop, 'help_text'): - self.fields[field_name].help_text = model_prop.help_text - - if hasattr(model_prop, 'example_text'): - self.fields[field_name].example_text = model_prop.example_text - - if hasattr(model_prop, 'group'): - self.fields[field_name].group = model_prop.group + for old, new in renames.iteritems(): + value = getattr(model_prop, old, None) + if value and not getattr(field, new, None): + setattr(field, new, value) if isinstance(self.fields[field_name], forms.DateField): - self.fields[field_name].widget.attrs['class'] = 'date-pick' + field.widget.attrs['class'] = 'date-pick' if isinstance(self.fields[field_name], forms.DateTimeField): - self.fields[field_name].widget.attrs['class'] = 'datetime-pick' + field.widget.attrs['class'] = 'datetime-pick' class SelectQueryArgForm(forms.Form):