summaryrefslogtreecommitdiff
path: root/testapp/exam/views.py
diff options
context:
space:
mode:
authorhardythe12012-02-23 16:30:36 +0530
committerhardythe12012-02-23 16:30:36 +0530
commit9acff5f2cf9f9ae3d2fc097e1fcd84712d3199d0 (patch)
treecac2d9feddb2c5d45f24a806275d23635b528fe9 /testapp/exam/views.py
parentf2d65592affd34bc60cf4a3a2c72de1d84c934c0 (diff)
downloadonline_test-9acff5f2cf9f9ae3d2fc097e1fcd84712d3199d0.tar.gz
online_test-9acff5f2cf9f9ae3d2fc097e1fcd84712d3199d0.tar.bz2
online_test-9acff5f2cf9f9ae3d2fc097e1fcd84712d3199d0.zip
more changes to edit multiple questions at a time
Diffstat (limited to 'testapp/exam/views.py')
-rw-r--r--testapp/exam/views.py59
1 files changed, 57 insertions, 2 deletions
diff --git a/testapp/exam/views.py b/testapp/exam/views.py
index bc2290b..22151e7 100644
--- a/testapp/exam/views.py
+++ b/testapp/exam/views.py
@@ -92,6 +92,33 @@ def user_register(request):
{'form':form},
context_instance=RequestContext(request))
+def edit_question(request):
+ user = request.user
+ if not user.is_authenticated() or user.groups.filter(name='moderator').count() == 0 :
+ raise Http404('You are not allowed to view this page!')
+
+ summary = request.POST.getlist('summary')
+ description = request.POST.getlist('description')
+ points = request.POST.getlist('points')
+ test = request.POST.getlist('test')
+ options = request.POST.getlist('options')
+ type = request.POST.getlist('type')
+ active = request.POST.getlist('active')
+ j = 0
+ for i in editquestionlist:
+ question = Question.objects.get(id=i)
+ question.summary = summary[j]
+ question.description = description[j]
+ question.points = points[j]
+ question.test = test[j]
+ question.options = options[j]
+ question.type = type[j]
+ question.active = active[j]
+ question.save()
+ j += 1
+ return my_redirect("/exam/manage/questions")
+
+
def add_question(request,question_id=None):
"""To add a new question in the database. Create a new question and store it."""
user = request.user
@@ -478,7 +505,7 @@ def show_all_questions(request):
if not user.is_authenticated() or user.groups.filter(name='moderator').count() == 0 :
raise Http404("You are not allowed to view this page !")
- if request.method == 'POST':
+ if request.method == 'POST' and request.POST.get('delete')=='delete':
data = request.POST.getlist('question')
if data == None:
questions = Question.objects.all()
@@ -495,7 +522,35 @@ def show_all_questions(request):
'questions':questions}
return my_render_to_response('exam/showquestions.html', context,
context_instance=RequestContext(request))
-
+
+ elif request.method == 'POST' and request.POST.get('edit')=='edit':
+ data = request.POST.getlist('question')
+ global editquestionlist
+ editquestionlist = data
+ if data == None:
+ questions = Question.objects.all()
+ context = {'papers': [],
+ 'question': None,
+ 'questions':questions}
+ return my_render_to_response('exam/showquestions.html', context,
+ context_instance=RequestContext(request))
+
+ forms = []
+ for j in data:
+ d = Question.objects.get(id=j)
+ form = QuestionForm()
+ form.initial['summary']= d.summary
+ form.initial['description'] = d.description
+ form.initial['points']= d.points
+ form.initial['test'] = d.test
+ form.initial['options'] = d.options
+ form.initial['type'] = d.type
+ form.initial['active'] = d.active
+ forms.append(form)
+
+ return my_render_to_response('exam/edit_question.html',
+ {'forms':forms},
+ context_instance=RequestContext(request))
else:
questions = Question.objects.all()
context = {'papers': [],