OK I *think* I see what is wrong: You are returning the redirect from within the 'process_form' function, but not assigning it to anything or further processing it. SO, the process form returns a redirect, which is promptly and efficiently ignored, then returns a render_to_response from the view.
Move: return HttpResponseRedirect('/articles-and-books/thanks/') back to the views and get rid of the render_to_response. On 6/20/08, Brandon Taylor <[EMAIL PROTECTED]> wrote: > > > Hi Richard, > > Thanks for taking the tie to address my question. Here's my current > views.py file. As you can see there's quite a bit of duplication. I > guess what's throwing me for a loop is that I can abstract processing > the form out, checking to see if the request is a post, etc, but the > redirect doesn't work. > > The current file: > > from django.shortcuts import render_to_response, get_object_or_404 > from django.newforms import form_for_model > from django.core.mail import send_mail > from django.http import HttpResponseRedirect > from lua.references.models import * > from lua.references.forms import SuggestionForm > > reference_groups = > ReferenceGroup.objects.all().order_by('order').select_related() > > def list_references(request): > > form = create_form(request) > > if request.method == 'POST': > if form.is_valid(): > first_name = form.cleaned_data['first_name'] > last_name = form.cleaned_data['last_name'] > email = form.cleaned_data['email'] > reference_name = form.cleaned_data['reference_name'] > url = form.cleaned_data['url'] > > subject = 'Your suggestion to Hawaiian Lua.com has been > received.' > message = "Thank you for suggesting %s to us. We'll review > your suggestion and get back to you as quickly as possible." % > (reference_name) > > #send_mail(subject, message, email, > '[EMAIL PROTECTED]') > request.session['first_name'] = first_name > return HttpResponseRedirect('/articles-and-books/thanks/') > > return render_to_response('references.html', {'reference_groups' : > reference_groups, 'form' : form}) > > > def get_reference(request, slug): > reference = get_object_or_404(Reference, slug=slug) > > form = create_form(request) > > if request.is_ajax(): > template = '_content.html' > elif request.method == 'POST': > if form.is_valid(): > first_name = form.cleaned_data['first_name'] > last_name = form.cleaned_data['last_name'] > email = form.cleaned_data['email'] > reference_name = form.cleaned_data['reference_name'] > url = form.cleaned_data['url'] > > subject = 'Your suggestion to Hawaiian Lua.com has been > received.' > message = "Thank you for suggesting %s to us. We'll review > your suggestion and get back to you as quickly as possible." % > (reference_name) > > #send_mail(subject, message, email, > '[EMAIL PROTECTED]') > request.session['first_name'] = first_name > return HttpResponseRedirect('/articles-and-books/thanks/') > else: > template = 'reference_content.html' > > return render_to_response(template, {'reference' : reference, > 'form' : form}) > > > def thanks(request): > form = create_form(request) > > if request.method == 'POST': > if form.is_valid(): > first_name = form.cleaned_data['first_name'] > last_name = form.cleaned_data['last_name'] > email = form.cleaned_data['email'] > reference_name = form.cleaned_data['reference_name'] > url = form.cleaned_data['url'] > > subject = 'Your suggestion to Hawaiian Lua.com has been > received.' > message = "Thank you for suggesting %s to us. We'll review > your suggestion and get back to you as quickly as possible." % > (reference_name) > > #send_mail(subject, message, email, > '[EMAIL PROTECTED]') > request.session['first_name'] = first_name > return HttpResponseRedirect('/articles-and-books/thanks/') > > first_name = request.session['first_name'] > return render_to_response('thanks.html', {'reference_groups' : > reference_groups,'form' : form, 'first_name' : first_name}) > > > def create_form(request): > if request.method == 'POST': > form = SuggestionForm(request.POST) > else: > form = SuggestionForm() > > return form > > > This works, but is just hideous. I've tried doing this: > > def process_form(request, form): > if request.method == 'POST': > if form.is_valid(): > first_name = form.cleaned_data['first_name'] > last_name = form.cleaned_data['last_name'] > email = form.cleaned_data['email'] > reference_name = form.cleaned_data['reference_name'] > url = form.cleaned_data['url'] > > subject = 'Your suggestion to Hawaiian Lua.com has been > received.' > message = "Thank you for suggesting %s to us. We'll review > your suggestion and get back to you as quickly as possible." % > (reference_name) > > send_mail(subject, message, email, > '[EMAIL PROTECTED]') > request.session['first_name'] = first_name > return HttpResponseRedirect('/articles-and-books/thanks/') > > > def list_references(request): > form = create_form(request) > process_form(request, form) > return render_to_response('references.html', {'reference_groups' : > reference_groups, 'form' : form}) > > > But this doesn't work. The validation will fire, but the redirect will > not. > > Thoughts? > > On Jun 20, 2:06 pm, "Richard Dahl" <[EMAIL PROTECTED]> wrote: > > put all of the otherwise duplicative code into its own function within > > another module. then import that function into your views.py, i.e: > > > > at the top of views.py: > > from formprocessing.py import formprocessor > > > > then within formproccessor.py > > > > def processemail(email, reference_name): > > subject = 'Your suggestion has been received.' > > message = "Thank you for suggesting %s to us. We'll review > > your suggestion and get back to you as quickly as possible." % > > (reference_name) > > > > send_mail(subject, message, email, > > '[EMAIL PROTECTED]') > > > > and of course in the view: > > if form.is_valid(): > > first_name = form.cleaned_data['first_name'] > > last_name = form.cleaned_data['last_name'] > > email = form.cleaned_data['email'] > > reference_name = form.cleaned_data['reference_name'] > > url = form.cleaned_data['url'] > > > > processemail(email, reference_name): > > > > request.session['first_name'] = first_name > > return HttpResponseRedirect('/articles-and-books/thanks/') > > > > you could have it do all of the form processing if you need it too, just > > depends on what you need. > > -richard > > > > On 6/20/08, Brandon Taylor <[EMAIL PROTECTED]> wrote: > > > > > > > > > Hi everyone, > > > > > I have a feedback form which needs to be functional across 3 different > > > actions within the same view... > > > > > My actions are: > > > references_list > > > reference_detail > > > thanks > > > > > Here's my current form processing code: > > > > > if request.method == 'POST': > > > form = SuggestionForm(request.POST) > > > > > if form.is_valid(): > > > first_name = form.cleaned_data['first_name'] > > > last_name = form.cleaned_data['last_name'] > > > email = form.cleaned_data['email'] > > > reference_name = form.cleaned_data['reference_name'] > > > url = form.cleaned_data['url'] > > > > > subject = 'Your suggestion has been received.' > > > message = "Thank you for suggesting %s to us. We'll review > > > your suggestion and get back to you as quickly as possible." % > > > (reference_name) > > > > > send_mail(subject, message, email, > > > '[EMAIL PROTECTED]') > > > request.session['first_name'] = first_name > > > return HttpResponseRedirect('/articles-and-books/thanks/') > > > else: > > > form = SuggestionForm() > > > > > How can I structure this such that I don't have to repeat myself in > > > each action of the view? > > > > > TIA, > > > Brandon > > > --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-users@googlegroups.com To unsubscribe from this group, send email to [EMAIL PROTECTED] For more options, visit this group at http://groups.google.com/group/django-users?hl=en -~----------~----~----~----~------~----~------~--~---