# HG changeset patch # User Lennard de Rijk # Date 1246646323 -7200 # Node ID afae8791ad97a298f9446d3a3880e988806bc18f # Parent a3513142ae016d7c6effda027c69b422ca5eae11 Do not call takeGet when SurveyForm ValidationError occurs. Problems occured when a SurveyRecord was specified in the SurveyForm. The SurveyRecord data reset the erroneous POST data. Further code reduction might be possible soonish. diff -r a3513142ae01 -r afae8791ad97 app/soc/views/models/survey.py --- a/app/soc/views/models/survey.py Fri Jul 03 19:15:09 2009 +0200 +++ b/app/soc/views/models/survey.py Fri Jul 03 20:38:43 2009 +0200 @@ -535,14 +535,13 @@ return record_logic.getForFields(filter, unique=True) def takeGet(self, request, template, context, params, entity, record, - form_data=None, **kwargs): + **kwargs): """Handles the GET request for the Survey's take page. Args: template: the template used for this view entity: the Survey entity record: a SurveyRecord entity - form_data: dict with form data that will be used for validation rest: see base.View.public() """ @@ -550,18 +549,13 @@ survey_record=record, survey_logic=self._params['logic']) - # fetch field contents and pass request data, if any - survey_form.getFields(post_dict=form_data) + # fetch field contents + survey_form.getFields() # fill context with the survey and additional information context['survey_form'] = survey_form self.setHelpAndStatus(context, entity, record) - # validate request data - if form_data and not survey_form.is_valid(): - return self._constructResponse(request, entity=entity, context=context, - form=survey_form, params=params, template=template) - # call the hook method self._takeGet(request, template, context, params, entity, record, **kwargs) @@ -603,9 +597,13 @@ survey_form.getFields(post_dict=request.POST) if not survey_form.is_valid(): - # redirect to takeGet so we can handle errors - return self.takeGet(request, template, context, params, entity, record, - form_data=request.POST) + # fill context with the survey and additional information + context['survey_form'] = survey_form + self.setHelpAndStatus(context, entity, record) + # show the form errors + return self._constructResponse(request, entity=entity, context=context, + form=survey_form, params=params, + template=template) # retrieve the data from the form _, properties = forms_helper.collectCleanedFields(survey_form)