# HG changeset patch # User Sverre Rabbelier # Date 1234713218 0 # Node ID 1c5c6271f02ea0ddd5902912e9105c19f742e3a4 # Parent d94410538f8effb49f67e42cb4a347dfab23715f Fixed a bug in admin_form generation The edit_form was also being modified. Patch by: Sverre Rabbelier diff -r d94410538f8e -r 1c5c6271f02e app/soc/views/helper/params.py --- a/app/soc/views/helper/params.py Sun Feb 15 14:58:27 2009 +0000 +++ b/app/soc/views/helper/params.py Sun Feb 15 15:53:38 2009 +0000 @@ -22,6 +22,8 @@ ] +import copy + from django import forms from django.utils.translation import ugettext @@ -311,15 +313,15 @@ """Constructs a new AdminForm from base_form. """ - # extend to do a proper copy - admin_form = dynaform.extendDynaForm( - dynaform = base_form, - ) + # extend _and_ deepcopy the base_fields to do a proper copy + admin_form = dynaform.extendDynaForm(dynaform = base_form) + admin_form.base_fields = copy.deepcopy(admin_form.base_fields) # replace all widgets with PTW's for key, value in admin_form.base_fields.iteritems(): if not isinstance(value, forms.fields.Field): continue + value.widget = widgets.PlainTextWidget() return admin_form