summaryrefslogtreecommitdiff
path: root/yaksh/views.py
diff options
context:
space:
mode:
authoradityacp2020-09-12 11:44:01 +0530
committeradityacp2020-09-12 11:44:01 +0530
commitb1d2b88746fc670d7362f9b4d175d5e570f3ac77 (patch)
tree7225713597b09645ce7b75ffe44271691e3e28b0 /yaksh/views.py
parentbee8d54d8ae094db5e3c9c04c5e28fb5b2abb1df (diff)
downloadonline_test-b1d2b88746fc670d7362f9b4d175d5e570f3ac77.tar.gz
online_test-b1d2b88746fc670d7362f9b4d175d5e570f3ac77.tar.bz2
online_test-b1d2b88746fc670d7362f9b4d175d5e570f3ac77.zip
Mulitple changes
- Remove all alerts and add toast messages - Accept user submissions for the lesson quiz and evaluate - Initial lesson statistics
Diffstat (limited to 'yaksh/views.py')
-rw-r--r--yaksh/views.py62
1 files changed, 46 insertions, 16 deletions
diff --git a/yaksh/views.py b/yaksh/views.py
index ff22a26..c817c51 100644
--- a/yaksh/views.py
+++ b/yaksh/views.py
@@ -38,7 +38,7 @@ from yaksh.models import (
StdIOBasedTestCase, StringTestCase, TestCase, User,
get_model_class, FIXTURES_DIR_PATH, MOD_GROUP_NAME, Lesson, LessonFile,
LearningUnit, LearningModule, CourseStatus, question_types, Post, Comment,
- Topic, TableOfContents, VideoQuizAnswer, MicroManager
+ Topic, TableOfContents, LessonQuizAnswer, MicroManager
)
from yaksh.forms import (
UserRegisterForm, UserLoginForm, QuizForm, QuestionForm,
@@ -3772,6 +3772,7 @@ def delete_toc(request, course_id, toc_id):
get_object_or_404(Topic, pk=toc.object_id).delete()
else:
get_object_or_404(Question, id=toc.object_id).delete()
+ messages.success(request, "Content deleted successfully")
return redirect(redirect_url)
@@ -3839,12 +3840,12 @@ def submit_marker_quiz(request, course_id, toc_id):
try:
user_answer = int(request.POST.get('answer'))
except ValueError:
- msg = "Please enter an Integer Value"
+ user_answer = None
elif current_question.type == 'float':
try:
user_answer = float(request.POST.get('answer'))
except ValueError:
- msg = "Please enter a Float Value"
+ user_answer = None
elif current_question.type == 'string':
user_answer = str(request.POST.get('answer'))
elif current_question.type == 'mcc':
@@ -3853,30 +3854,59 @@ def submit_marker_quiz(request, course_id, toc_id):
user_answer_ids = request.POST.get('answer').split(',')
user_answer = [int(ids) for ids in user_answer_ids]
- def is_valid_answer(user_answer):
- success = True
- if current_question.type == "mcc" and not user_answer:
- success = False
- elif not str(user_answer):
- success = False
- return success
+ def is_valid_answer(answer):
+ status = True
+ if ((current_question.type == "mcc" or
+ current_question.type == "arrange") and not answer):
+ status = False
+ elif answer is None or not str(answer):
+ status = False
+ return status
if is_valid_answer(user_answer):
- if not VideoQuizAnswer.objects.filter(
- toc_id=toc_id, student_id=user.id).exists():
+ success = True
+ # check if graded quiz and already attempted
+ has_attempts = LessonQuizAnswer.objects.filter(
+ toc_id=toc_id, student_id=user.id).exists()
+ if ((toc.content == 2 and not has_attempts) or
+ toc.content == 3 or toc.content == 4):
answer = Answer.objects.create(
question_id=current_question.id, answer=user_answer,
correct=False, error=json.dumps([])
)
- lesson_ans = VideoQuizAnswer.objects.create(
+ lesson_ans = LessonQuizAnswer.objects.create(
toc_id=toc_id, student=user, answer=answer
)
- if toc.content == 2:
- lesson_ans.check_answer(user_answer)
msg = "Answer saved successfully"
+ # call check answer only for graded quiz and exercise
+ if toc.content == 3 or toc.content == 2:
+ result = lesson_ans.check_answer(user_answer)
+ # if exercise then show custom message
+ if toc.content == 3:
+ if result.get("success"):
+ msg = "You answered the question correctly"
+ else:
+ success = False
+ msg = "You have answered the question incorrectly. "\
+ "Please refer the lesson again"
else:
msg = "You have already submitted the answer"
else:
+ success = False
msg = "Please submit a valid answer"
- context = {"success": True, "message": msg}
+ context = {"success": success, "message": msg}
return JsonResponse(context)
+
+
+@login_required
+@email_verified
+def lessson_statistics(request, course_id, lesson_id):
+ user = request.user
+ course = get_object_or_404(Course, pk=course_id)
+ if (not is_moderator(user) or
+ not course.is_creator(user) or not course.is_creator(user)):
+ raise Http404("You are not allowed to view this page")
+ toc = TableOfContents.objects.get_data(course_id, lesson_id)
+ return render(request, 'yaksh/show_lesson_statistics.html', {
+ 'data': toc,
+ })