summaryrefslogtreecommitdiff
path: root/yaksh/views.py
diff options
context:
space:
mode:
authoradityacp2020-03-19 19:45:17 +0530
committeradityacp2020-03-19 19:45:17 +0530
commit36f43151ab26744cf9edc05d0df3f0fb901fcaaa (patch)
treec75b5d2730a74191f2c7e51a881e9404f5627c1d /yaksh/views.py
parent9933ec7861faf8abb38224e4b2f5f75fcf9e857a (diff)
parent1dbaec7dd8098701e11713faa0c9040a315e5fac (diff)
downloadonline_test-36f43151ab26744cf9edc05d0df3f0fb901fcaaa.tar.gz
online_test-36f43151ab26744cf9edc05d0df3f0fb901fcaaa.tar.bz2
online_test-36f43151ab26744cf9edc05d0df3f0fb901fcaaa.zip
Resolve conflicts in the courses view
Diffstat (limited to 'yaksh/views.py')
-rw-r--r--yaksh/views.py112
1 files changed, 107 insertions, 5 deletions
diff --git a/yaksh/views.py b/yaksh/views.py
index a75763a..b54461f 100644
--- a/yaksh/views.py
+++ b/yaksh/views.py
@@ -43,7 +43,8 @@ from yaksh.forms import (
UserRegisterForm, UserLoginForm, QuizForm, QuestionForm,
QuestionFilterForm, CourseForm, ProfileForm,
UploadFileForm, FileForm, QuestionPaperForm, LessonForm,
- LessonFileForm, LearningModuleForm, ExerciseForm, TestcaseForm
+ LessonFileForm, LearningModuleForm, ExerciseForm, TestcaseForm,
+ SearchFilterForm
)
from yaksh.settings import SERVER_POOL_PORT, SERVER_HOST_NAME
from .settings import URL_ROOT
@@ -1038,10 +1039,29 @@ def courses(request):
courses = Course.objects.filter(
Q(creator=user) | Q(teachers=user),
is_trial=False).order_by('-active').distinct()
+
+ form = SearchFilterForm()
+
+ if request.method == 'POST':
+ course_tags = request.POST.get('search_tags')
+ course_status = request.POST.get('search_status')
+
+ if course_status == 'select' :
+ courses = courses.filter(
+ name__contains=course_tags)
+ elif course_status == 'active' :
+ courses = courses.filter(
+ name__contains=course_tags, active=True)
+ elif course_status == 'closed':
+ courses = courses.filter(
+ name__contains=course_tags, active=False)
+
paginator = Paginator(courses, 30)
page = request.GET.get('page')
courses = paginator.get_page(page)
- context = {'objects': courses, 'created': True}
+ courses_found = courses.object_list.count()
+ context = {'objects': courses, 'created': True,
+ 'form': form, 'courses_found': courses_found}
return my_render_to_response(request, 'yaksh/courses.html', context)
@@ -2693,7 +2713,26 @@ def show_all_quizzes(request):
if not is_moderator(user):
raise Http404('You are not allowed to view this page!')
quizzes = Quiz.objects.filter(creator=user, is_trial=False)
- context = {"quizzes": quizzes}
+
+ form = SearchFilterForm()
+
+ if request.method == 'POST':
+ quiz_tags = request.POST.get('search_tags')
+ quiz_status = request.POST.get('search_status')
+
+ if quiz_status == 'select' :
+ quizzes = quizzes.filter(
+ description__contains=quiz_tags)
+ elif quiz_status == 'active' :
+ quizzes = quizzes.filter(
+ description__contains=quiz_tags, active=True)
+ elif quiz_status == 'closed':
+ quizzes = quizzes.filter(
+ description__contains=quiz_tags, active=False)
+ quizzes_found = quizzes.count()
+
+ context = {"quizzes": quizzes, "form": form,
+ "quizzes_found": quizzes_found}
return my_render_to_response(request, 'yaksh/quizzes.html', context)
@@ -2704,7 +2743,26 @@ def show_all_lessons(request):
if not is_moderator(user):
raise Http404('You are not allowed to view this page!')
lessons = Lesson.objects.filter(creator=user)
- context = {"lessons": lessons}
+
+ form = SearchFilterForm()
+
+ if request.method == 'POST':
+ lesson_tags = request.POST.get('search_tags')
+ lesson_status = request.POST.get('search_status')
+
+ if lesson_status == 'select' :
+ lessons = lessons.filter(
+ description__contains=lesson_tags)
+ elif lesson_status == 'active' :
+ lessons = lessons.filter(
+ description__contains=lesson_tags, active=True)
+ elif lesson_status == 'closed':
+ lessons = lessons.filter(
+ description__contains=lesson_tags, active=False)
+ lessons_found = lessons.count()
+
+ context = {"lessons": lessons, "form": form,
+ "lessons_found": lessons_found}
return my_render_to_response(request, 'yaksh/lessons.html', context)
@@ -2716,7 +2774,26 @@ def show_all_modules(request):
raise Http404('You are not allowed to view this page!')
learning_modules = LearningModule.objects.filter(
creator=user, is_trial=False)
- context = {"modules": learning_modules}
+
+ form = SearchFilterForm()
+
+ if request.method == 'POST':
+ module_tags = request.POST.get('search_tags')
+ module_status = request.POST.get('search_status')
+
+ if module_status == 'select' :
+ learning_modules = learning_modules.filter(
+ name__contains=module_tags)
+ elif module_status == 'active' :
+ learning_modules = learning_modules.filter(
+ name__contains=module_tags, active=True)
+ elif module_status == 'closed':
+ learning_modules = learning_modules.filter(
+ name__contains=module_tags, active=False)
+ learning_modules_found = learning_modules.count()
+
+ context = {"modules": learning_modules, "form": form,
+ "modules_found": learning_modules_found}
return my_render_to_response(
request, 'yaksh/modules.html', context
)
@@ -3135,3 +3212,28 @@ def get_course_modules(request, course_id):
modules = course.get_learning_modules()
context = {"modules": modules, "is_modules": True, "course": course}
return my_render_to_response(request, 'yaksh/course_detail.html', context)
+
+
+@login_required
+@email_verified
+def download_course_progress(request, course_id):
+ user = request.user
+ if not is_moderator(user):
+ raise Http404('You are not allowed to view this page!')
+ course = get_object_or_404(Course, pk=course_id)
+ if not course.is_creator(user) and not course.is_teacher(user):
+ raise Http404('This course does not belong to you')
+ students = course.students.order_by("-id")
+ stud_details = [(student.get_full_name(), course.get_grade(student),
+ course.get_completion_percent(student),
+ course.get_current_unit(student))
+ for student in students]
+ response = HttpResponse(content_type='text/csv')
+ response['Content-Disposition'] = 'attachment; filename="{0}.csv"'.format(
+ (course.name).lower().replace(' ', '_'))
+ header = ['Name', 'Grade', 'Completion Percent', 'Current Unit']
+ writer = csv.writer(response)
+ writer.writerow(header)
+ for student in stud_details:
+ writer.writerow(student)
+ return response