Lack of information is better that untrue information
[edumed.git] / contact / views.py
index d18598c..9fc9637 100644 (file)
@@ -12,25 +12,40 @@ def form(request, form_tag):
         form_class = contact_forms[form_tag]
     except KeyError:
         raise Http404
+    if getattr(form_class, 'disabled', False):
+        raise Http404
     if request.method == 'POST':
         form = form_class(request.POST, request.FILES)
-        if form.is_valid():
-            form.save(request)
+        formsets = []
+        valid = form.is_valid()
+        for formset in getattr(form, 'form_formsets', ()):
+            fset = formset(request.POST, request.FILES)
+            if not fset.is_valid():
+                valid = False
+            formsets.append(fset)
+        if valid:
+            form.save(request, formsets)
             return redirect('contact_thanks', form_tag)
     else:
         form = form_class(initial=request.GET)
+        formsets = []
+        for formset in getattr(form, 'form_formsets', ()):
+            formsets.append(formset())
     return render(request,
                 ['contact/%s/form.html' % form_tag, 'contact/form.html'],
-                {'form': form}
+                {'form': form, 'formsets': formsets}
             )
 
 
 def thanks(request, form_tag):
-    if form_tag not in contact_forms:
+    try:
+        form_class = contact_forms[form_tag]
+    except KeyError:
         raise Http404
 
     return render(request,
-                ['contact/%s/thanks.html' % form_tag, 'contact/thanks.html']
+                ['contact/%s/thanks.html' % form_tag, 'contact/thanks.html'],
+                dict(base_template = getattr(form_class, 'base_template', None))
             )