summaryrefslogtreecommitdiff
path: root/yaksh/views.py
diff options
context:
space:
mode:
authorPrabhu Ramachandran2017-11-23 21:47:52 +0530
committerGitHub2017-11-23 21:47:52 +0530
commit63326f9519478f0d9bfb0b843e5dac8ab29428f4 (patch)
tree51b7146d13a6e01ac24778ae0926438e6ffbd571 /yaksh/views.py
parent8f9bc94eacb013649c427b9279b359e2a17b8869 (diff)
parent252449b7b96d73548f53ecd0c3256aa0e777d1dd (diff)
downloadonline_test-63326f9519478f0d9bfb0b843e5dac8ab29428f4.tar.gz
online_test-63326f9519478f0d9bfb0b843e5dac8ab29428f4.tar.bz2
online_test-63326f9519478f0d9bfb0b843e5dac8ab29428f4.zip
Merge pull request #400 from maheshgudi/ajax_questions
Display error output without page reloading
Diffstat (limited to 'yaksh/views.py')
-rw-r--r--yaksh/views.py22
1 files changed, 19 insertions, 3 deletions
diff --git a/yaksh/views.py b/yaksh/views.py
index bc03ca2..74d352b 100644
--- a/yaksh/views.py
+++ b/yaksh/views.py
@@ -8,7 +8,7 @@ from django.http import HttpResponse, JsonResponse
from django.core.urlresolvers import reverse
from django.contrib.auth import login, logout, authenticate
from django.shortcuts import render_to_response, get_object_or_404, redirect
-from django.template import RequestContext
+from django.template import RequestContext, Context, Template
from django.http import Http404
from django.db.models import Sum, Max, Q, F
from django.views.decorators.csrf import csrf_exempt
@@ -658,8 +658,24 @@ def get_result(request, uid):
result['status'] = result_state.get('status')
if result['status'] == 'done':
result = json.loads(result_state.get('result'))
- next_question, error_message, paper = _update_paper(request, uid, result)
- return show_question(request, next_question, paper, error_message)
+ template_path = os.path.join(*[os.path.dirname(__file__),
+ 'templates','yaksh',
+ 'error_template.html'
+ ]
+ )
+ next_question, error_message, paper = _update_paper(request,uid,
+ result
+ )
+ if result.get('success'):
+ return show_question(request, next_question, paper, error_message)
+ else:
+ with open(template_path) as f:
+ template_data = f.read()
+ template = Template(template_data)
+ context = Context({"error_message": result.get('error')})
+ render_error = template.render(context)
+ result["error"] = render_error
+
return JsonResponse(result)