summaryrefslogtreecommitdiff
path: root/yaksh/views.py
diff options
context:
space:
mode:
authoradityacp2020-02-11 15:12:49 +0530
committeradityacp2020-02-11 15:12:49 +0530
commitd0c08efb57d0b83845ebccf67df09e798791c6e3 (patch)
tree79aefcfd39022647e0c7565ed24314a749885744 /yaksh/views.py
parent14486cfd74053ec5753b759bdd0d92a7ff101cc7 (diff)
downloadonline_test-d0c08efb57d0b83845ebccf67df09e798791c6e3.tar.gz
online_test-d0c08efb57d0b83845ebccf67df09e798791c6e3.tar.bz2
online_test-d0c08efb57d0b83845ebccf67df09e798791c6e3.zip
Change templates, urls, views
- Remove separate tab for allotted courses in moderator dashboard - Remove separate tab for enrolled courses in student dashboard - Increase pagination items for courses - Remove view function for allotted courses
Diffstat (limited to 'yaksh/views.py')
-rw-r--r--yaksh/views.py59
1 files changed, 21 insertions, 38 deletions
diff --git a/yaksh/views.py b/yaksh/views.py
index 6d70766..28515fd 100644
--- a/yaksh/views.py
+++ b/yaksh/views.py
@@ -175,15 +175,16 @@ def quizlist_user(request, enrolled=None, msg=None):
hidden_courses = Course.objects.get_hidden_courses(code=course_code)
courses = hidden_courses
title = 'Search'
- elif enrolled is not None:
- courses = user.students.filter(is_trial=False).order_by('-id')
- title = 'Enrolled Courses'
else:
- courses = Course.objects.filter(
- active=True, is_trial=False
+ courses = list(Course.objects.filter(
+ active=True, is_trial=False,
).exclude(
~Q(requests=user), ~Q(rejected=user), hidden=True
- ).order_by('-id')
+ ).order_by('-id'))
+ enrolled_course = list(
+ user.students.filter(is_trial=False).order_by('-id')
+ )
+ courses.extend(enrolled_course)
title = 'All Courses'
for course in courses:
@@ -198,9 +199,10 @@ def quizlist_user(request, enrolled=None, msg=None):
}
)
+ messages.info(request, msg)
context = {
'user': user, 'courses': courses_data,
- 'title': title, 'msg': msg
+ 'title': title
}
return my_render_to_response(request, "yaksh/quizzes_user.html", context)
@@ -405,8 +407,8 @@ def prof_manage(request, msg=None):
return my_redirect('/exam/')
courses = Course.objects.get_queryset().filter(
Q(creator=user) | Q(teachers=user),
- is_trial=False).distinct().order_by("-id")
- paginator = Paginator(courses, 10)
+ is_trial=False).distinct().order_by("-active")
+ paginator = Paginator(courses, 30)
page = request.GET.get('page')
try:
courses = paginator.page(page)
@@ -1041,8 +1043,9 @@ def courses(request):
if not is_moderator(user):
raise Http404('You are not allowed to view this page')
courses = Course.objects.filter(
- creator=user, is_trial=False).order_by('-id')
- paginator = Paginator(courses, 20)
+ Q(creator=user) | Q(teachers=user),
+ is_trial=False).order_by('-active').distinct()
+ paginator = Paginator(courses, 30)
page = request.GET.get('page')
try:
courses = paginator.page(page)
@@ -1058,28 +1061,6 @@ def courses(request):
@login_required
@email_verified
-def allotted_courses(request):
- user = request.user
- if not is_moderator(user):
- raise Http404('You are not allowed to view this page')
- allotted_courses = Course.objects.filter(
- teachers=user, is_trial=False).order_by('-id')
- paginator = Paginator(allotted_courses, 20)
- page = request.GET.get('page')
- try:
- allotted_courses = paginator.page(page)
- except PageNotAnInteger:
- # If page is not an integer, deliver first page.
- allotted_courses = paginator.page(1)
- except EmptyPage:
- # If page is out of range (e.g. 9999), deliver last page of results.
- allotted_courses = paginator.page(paginator.num_pages)
- context = {'allotted': True, "objects": allotted_courses}
- return my_render_to_response(request, 'yaksh/courses.html', context)
-
-
-@login_required
-@email_verified
def course_detail(request, course_id):
user = request.user
@@ -1256,7 +1237,7 @@ def monitor(request, quiz_id=None, course_id=None):
Q(creator=user) | Q(teachers=user),
is_trial=False
).order_by("-id").distinct()
- paginator = Paginator(courses, 20)
+ paginator = Paginator(courses, 30)
page = request.GET.get('page')
try:
courses = paginator.page(page)
@@ -1727,7 +1708,7 @@ def grade_user(request, quiz_id=None, user_id=None, attempt_number=None,
courses = Course.objects.filter(
Q(creator=current_user) | Q(teachers=current_user), is_trial=False
).order_by("-id").distinct()
- paginator = Paginator(courses, 20)
+ paginator = Paginator(courses, 30)
page = request.GET.get('page')
try:
courses = paginator.page(page)
@@ -1735,7 +1716,7 @@ def grade_user(request, quiz_id=None, user_id=None, attempt_number=None,
courses = paginator.page(1)
except EmptyPage:
courses = paginator.page(paginator.num_pages)
- context = {"objects": courses}
+ context = {"objects": courses, "msg": "grade"}
if quiz_id is not None:
questionpaper_id = QuestionPaper.objects.filter(
@@ -1758,7 +1739,8 @@ def grade_user(request, quiz_id=None, user_id=None, attempt_number=None,
"quiz_id": quiz_id,
"quiz": quiz,
"has_quiz_assignments": has_quiz_assignments,
- "course_id": course_id
+ "course_id": course_id,
+ "status": "grade"
}
if user_id is not None:
attempts = AnswerPaper.objects.get_user_all_attempts(
@@ -1785,7 +1767,8 @@ def grade_user(request, quiz_id=None, user_id=None, attempt_number=None,
"user_id": user_id,
"has_user_assignments": has_user_assignments,
"has_quiz_assignments": has_quiz_assignments,
- "course_id": course_id
+ "course_id": course_id,
+ "status": "grade"
}
if request.method == "POST":
papers = data['papers']