diff options
author | Prabhu Ramachandran | 2017-11-23 21:47:52 +0530 |
---|---|---|
committer | GitHub | 2017-11-23 21:47:52 +0530 |
commit | 63326f9519478f0d9bfb0b843e5dac8ab29428f4 (patch) | |
tree | 51b7146d13a6e01ac24778ae0926438e6ffbd571 /yaksh/views.py | |
parent | 8f9bc94eacb013649c427b9279b359e2a17b8869 (diff) | |
parent | 252449b7b96d73548f53ecd0c3256aa0e777d1dd (diff) | |
download | online_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.py | 22 |
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) |