mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #17163 -- Added the NamedUrlWizardView.get_step_url() method. Thanks, Bradley Ayers.
				
					
				
			git-svn-id: http://code.djangoproject.com/svn/django/trunk@17235 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -591,6 +591,9 @@ class NamedUrlWizardView(WizardView): | |||||||
|             'step name "%s" is reserved for "done" view' % initkwargs['done_step_name'] |             'step name "%s" is reserved for "done" view' % initkwargs['done_step_name'] | ||||||
|         return initkwargs |         return initkwargs | ||||||
|  |  | ||||||
|  |     def get_step_url(self, step): | ||||||
|  |         return reverse(self.url_name, kwargs={'step': step}) | ||||||
|  |  | ||||||
|     def get(self, *args, **kwargs): |     def get(self, *args, **kwargs): | ||||||
|         """ |         """ | ||||||
|         This renders the form or, if needed, does the http redirects. |         This renders the form or, if needed, does the http redirects. | ||||||
| @@ -604,10 +607,8 @@ class NamedUrlWizardView(WizardView): | |||||||
|                 query_string = "?%s" % self.request.GET.urlencode() |                 query_string = "?%s" % self.request.GET.urlencode() | ||||||
|             else: |             else: | ||||||
|                 query_string = "" |                 query_string = "" | ||||||
|             next_step_url = reverse(self.url_name, kwargs={ |             return redirect(self.get_step_url(self.steps.current) | ||||||
|                 'step': self.steps.current, |                             + query_string) | ||||||
|             }) + query_string |  | ||||||
|             return redirect(next_step_url) |  | ||||||
|  |  | ||||||
|         # is the current step the "done" name/view? |         # is the current step the "done" name/view? | ||||||
|         elif step_url == self.done_step_name: |         elif step_url == self.done_step_name: | ||||||
| @@ -636,7 +637,7 @@ class NamedUrlWizardView(WizardView): | |||||||
|         # invalid step name, reset to first and redirect. |         # invalid step name, reset to first and redirect. | ||||||
|         else: |         else: | ||||||
|             self.storage.current_step = self.steps.first |             self.storage.current_step = self.steps.first | ||||||
|             return redirect(self.url_name, step=self.steps.first) |             return redirect(self.get_step_url(self.steps.first)) | ||||||
|  |  | ||||||
|     def post(self, *args, **kwargs): |     def post(self, *args, **kwargs): | ||||||
|         """ |         """ | ||||||
| @@ -646,7 +647,7 @@ class NamedUrlWizardView(WizardView): | |||||||
|         wizard_goto_step = self.request.POST.get('wizard_goto_step', None) |         wizard_goto_step = self.request.POST.get('wizard_goto_step', None) | ||||||
|         if wizard_goto_step and wizard_goto_step in self.get_form_list(): |         if wizard_goto_step and wizard_goto_step in self.get_form_list(): | ||||||
|             self.storage.current_step = wizard_goto_step |             self.storage.current_step = wizard_goto_step | ||||||
|             return redirect(self.url_name, step=wizard_goto_step) |             return redirect(self.get_step_url(wizard_goto_step)) | ||||||
|         return super(NamedUrlWizardView, self).post(*args, **kwargs) |         return super(NamedUrlWizardView, self).post(*args, **kwargs) | ||||||
|  |  | ||||||
|     def get_context_data(self, form, **kwargs): |     def get_context_data(self, form, **kwargs): | ||||||
| @@ -665,7 +666,7 @@ class NamedUrlWizardView(WizardView): | |||||||
|         """ |         """ | ||||||
|         next_step = self.get_next_step() |         next_step = self.get_next_step() | ||||||
|         self.storage.current_step = next_step |         self.storage.current_step = next_step | ||||||
|         return redirect(self.url_name, step=next_step) |         return redirect(self.get_step_url(next_step)) | ||||||
|  |  | ||||||
|     def render_revalidation_failure(self, failed_step, form, **kwargs): |     def render_revalidation_failure(self, failed_step, form, **kwargs): | ||||||
|         """ |         """ | ||||||
| @@ -673,7 +674,7 @@ class NamedUrlWizardView(WizardView): | |||||||
|         step. |         step. | ||||||
|         """ |         """ | ||||||
|         self.storage.current_step = failed_step |         self.storage.current_step = failed_step | ||||||
|         return redirect(self.url_name, step=failed_step) |         return redirect(self.get_step_url(failed_step)) | ||||||
|  |  | ||||||
|     def render_done(self, form, **kwargs): |     def render_done(self, form, **kwargs): | ||||||
|         """ |         """ | ||||||
| @@ -681,7 +682,7 @@ class NamedUrlWizardView(WizardView): | |||||||
|         name doesn't fit). |         name doesn't fit). | ||||||
|         """ |         """ | ||||||
|         if kwargs.get('step', None) != self.done_step_name: |         if kwargs.get('step', None) != self.done_step_name: | ||||||
|             return redirect(self.url_name, step=self.done_step_name) |             return redirect(self.get_step_url(self.done_step_name)) | ||||||
|         return super(NamedUrlWizardView, self).render_done(form, **kwargs) |         return super(NamedUrlWizardView, self).render_done(form, **kwargs) | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -557,8 +557,8 @@ an ``instance_dict`` argument that should contain instances of ``ModelForm`` and | |||||||
| ``ModelFormSet``.  Similarly to :attr:`~WizardView.initial_dict`, these | ``ModelFormSet``.  Similarly to :attr:`~WizardView.initial_dict`, these | ||||||
| dictionary key values should be equal to the step number in the form list. | dictionary key values should be equal to the step number in the form list. | ||||||
|  |  | ||||||
| Usage of NamedUrlWizardView | Usage of ``NamedUrlWizardView`` | ||||||
| =========================== | =============================== | ||||||
|  |  | ||||||
| .. class:: NamedUrlWizardView | .. class:: NamedUrlWizardView | ||||||
|  |  | ||||||
| @@ -595,3 +595,15 @@ Example code for the changed ``urls.py`` file:: | |||||||
|         url(r'^contact/(?P<step>.+)/$', contact_wizard, name='contact_step'), |         url(r'^contact/(?P<step>.+)/$', contact_wizard, name='contact_step'), | ||||||
|         url(r'^contact/$', contact_wizard, name='contact'), |         url(r'^contact/$', contact_wizard, name='contact'), | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|  | Advanced ``NamedUrlWizardView`` methods | ||||||
|  | ======================================= | ||||||
|  |  | ||||||
|  | .. method:: NamedUrlWizardView.get_step_url(step) | ||||||
|  |  | ||||||
|  |     This method returns the URL for a specific step. | ||||||
|  |  | ||||||
|  |     Default implementation:: | ||||||
|  |  | ||||||
|  |         def get_step_url(self, step): | ||||||
|  |             return reverse(self.url_name, kwargs={'step': step}) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user