fix contact admin?
[edumed.git] / wtem / views.py
index 33ac1e2..b5f7548 100644 (file)
@@ -1,11 +1,14 @@
 # -*- coding: utf-8 -*-
 # -*- coding: utf-8 -*-
+import json
+from copy import deepcopy
 
 from django.conf import settings
 from django.http import HttpResponseForbidden
 
 from django.conf import settings
 from django.http import HttpResponseForbidden
-from django.shortcuts import render
+from django.shortcuts import render, get_object_or_404
 from django.views.decorators.cache import never_cache
 from django.views.decorators.csrf import csrf_exempt
 
 from django.views.decorators.cache import never_cache
 from django.views.decorators.csrf import csrf_exempt
 
+from wtem.models import Confirmation
 from .forms import WTEMForm
 from .models import Submission, DEBUG_KEY, exercises
 
 from .forms import WTEMForm
 from .models import Submission, DEBUG_KEY, exercises
 
@@ -46,8 +49,19 @@ def form_during(request, key):
                 first_name='Debug', last_name='Debug', email='debug@debug.com', key=DEBUG_KEY)
         else:
             return render(request, 'wtem/key_not_found.html')
                 first_name='Debug', last_name='Debug', email='debug@debug.com', key=DEBUG_KEY)
         else:
             return render(request, 'wtem/key_not_found.html')
+    exercises_with_answers = deepcopy(exercises)
+    if submission.answers:
+        answers = json.loads(submission.answers)
+    else:
+        answers = {}
+    for exercise in exercises_with_answers:
+        exercise['saved_answer'] = answers.get(str(exercise['id']), '')
+        if exercise['type'] == 'open' and exercise.get('fields'):
+            field_answers = {field['id']: field['text'] for field in exercise['saved_answer']}
+            for field in exercise['fields']:
+                field['saved_answer'] = field_answers.get(field['id'], '')
     if request.method == 'GET':
     if request.method == 'GET':
-        return render(request, 'wtem/main.html', dict(exercises=exercises, end_time=submission.end_time))
+        return render(request, 'wtem/main.html', {'exercises': exercises_with_answers, 'end_time': submission.end_time})
     elif request.method == 'POST':
         form = WTEMForm(request.POST, request.FILES, instance=submission)
         if form.is_valid():
     elif request.method == 'POST':
         form = WTEMForm(request.POST, request.FILES, instance=submission)
         if form.is_valid():
@@ -55,3 +69,12 @@ def form_during(request, key):
             return render(request, 'wtem/thanks.html', dict(end_time=submission.end_time))
         else:
             raise Exception
             return render(request, 'wtem/thanks.html', dict(end_time=submission.end_time))
         else:
             raise Exception
+
+
+def confirmation(request, id, key):
+    conf = get_object_or_404(Confirmation, id=id, key=key)
+    was_confirmed = conf.confirmed
+    if not was_confirmed:
+        conf.confirmed = True
+        conf.save()
+    return render(request, 'wtem/confirmed.html', {'confirmation': conf, 'was_confirmed': was_confirmed})