django-contact-form / contact_form /

Full commit
View which can render and send email from a contact form.

from django.shortcuts import render_to_response, redirect
from django.template import RequestContext

from contact_form.forms import ContactForm

def contact_form(request, form_class=ContactForm,
                 success_url=None, extra_context=None,
    Render a contact form, validate its input and send an email
    from it.

    **Optional arguments:**

        A dictionary of variables to add to the template context. Any
        callable object in this dictionary will be called to produce
        the end result which appears in the context.

        If ``True``, errors when sending the email will be silently
        supressed (i.e., with no logging or reporting of any such
        errors. Default value is ``False``.

        The form to use. If not supplied, this will default to
        ``contact_form.forms.ContactForm``. If supplied, the form
        class must implement a method named ``save()`` which sends the
        email from the form; the form class must accept an
        ``HttpRequest`` as the keyword argument ``request`` to its
        constructor, and it must implement a method named ``save()``
        which sends the email and which accepts the keyword argument

        The URL to redirect to after a successful submission. If not
        supplied, this will default to the URL pointed to by the named
        URL pattern ``contact_form_sent``.

        The template to use for rendering the contact form. If not
        supplied, defaults to


        The form instance.

    The value of the ``template_name`` keyword argument, or

    # We set up success_url here, rather than as the default value for
    # the argument. Trying to do it as the argument's default would
    # mean evaluating the call to reverse() at the time this module is
    # first imported, which introduces a circular dependency: to
    # perform the reverse lookup we need access to contact_form/,
    # but contact_form/ in turn imports from this module.
    if request.method == 'POST':
        form = form_class(data=request.POST, files=request.FILES, request=request)
        if form.is_valid():
            if success_url is None:
                to, args, kwargs = form.get_success_redirect()
                return redirect(to, *args, **kwargs)
                return redirect(success_url)
        form = form_class(request=request)

    if extra_context is None:
        extra_context = {}
    context = RequestContext(request)
    for key, value in extra_context.items():
        context[key] = callable(value) and value() or value
    return render_to_response(template_name,
                              { 'form': form },