summaryrefslogtreecommitdiff
path: root/yaksh/forms.py
diff options
context:
space:
mode:
authoradityacp2020-08-26 20:29:03 +0530
committeradityacp2020-08-26 20:29:03 +0530
commitd54b62c2803f0f0edb45348f47d6a541ca09e022 (patch)
tree67c5f3ee03d1a3702db00a5dab3d699be9692e9e /yaksh/forms.py
parent3999e744fe1a3a4c4fcb7d2763b36def9d7bb213 (diff)
downloadonline_test-d54b62c2803f0f0edb45348f47d6a541ca09e022.tar.gz
online_test-d54b62c2803f0f0edb45348f47d6a541ca09e022.tar.bz2
online_test-d54b62c2803f0f0edb45348f47d6a541ca09e022.zip
First cut for in video quizzes
Diffstat (limited to 'yaksh/forms.py')
-rw-r--r--yaksh/forms.py92
1 files changed, 91 insertions, 1 deletions
diff --git a/yaksh/forms.py b/yaksh/forms.py
index 3c4d664..797f54e 100644
--- a/yaksh/forms.py
+++ b/yaksh/forms.py
@@ -1,7 +1,8 @@
from django import forms
from yaksh.models import (
get_model_class, Profile, Quiz, Question, Course, QuestionPaper, Lesson,
- LearningModule, TestCase, languages, question_types, Post, Comment
+ LearningModule, TestCase, languages, question_types, Post, Comment,
+ Topic
)
from grades.models import GradingSystem
from django.contrib.auth import authenticate
@@ -15,6 +16,8 @@ except ImportError:
from string import ascii_letters as letters
from string import punctuation, digits
import pytz
+from ast import literal_eval
+
from .send_emails import generate_activation_key
languages = (("", "Select Language"),) + languages
@@ -520,6 +523,13 @@ class LessonForm(forms.ModelForm):
self.fields['description'].widget.attrs.update(
{'class': form_input_class, 'placeholder': des_msg}
)
+ self.fields['video_path'].widget.attrs.update(
+ {'class': form_input_class,
+ 'placeholder': dedent("""\
+ {'youtube': '', 'vimeo': '', 'others': ''}
+ """),
+ }
+ )
self.fields['video_file'].widget.attrs.update(
{'class': "custom-file-input"}
)
@@ -540,6 +550,26 @@ class LessonForm(forms.ModelForm):
)
return file
+ def clean_video_path(self):
+ path = self.cleaned_data.get("video_path")
+ if path:
+ try:
+ value = literal_eval(path)
+ if not isinstance(value, dict):
+ raise forms.ValidationError(
+ "Value must be dictionary as shown in sample"
+ )
+ else:
+ if len(value) > 1:
+ raise forms.ValidationError(
+ "Only one of the video name should be entered"
+ )
+ except ValueError:
+ raise forms.ValidationError(
+ "Value must be dictionary as shown in sample"
+ )
+ return path
+
class LessonFileForm(forms.Form):
Lesson_files = forms.FileField(
@@ -615,3 +645,63 @@ class CommentForm(forms.ModelForm):
}
)
}
+
+
+class TopicForm(forms.ModelForm):
+
+ timer = forms.CharField()
+ def __init__(self, *args, **kwargs):
+ super(TopicForm, self).__init__(*args, **kwargs)
+ self.fields['name'].widget.attrs.update(
+ {'class': form_input_class, 'placeholder': 'Topic Name'}
+ )
+ self.fields['timer'].widget.attrs.update(
+ {'class': form_input_class, 'placeholder': 'Topic Time'}
+ )
+
+ class Meta:
+ model = Topic
+ fields = "__all__"
+
+
+class VideoQuizForm(forms.ModelForm):
+
+ _types = dict(question_types)
+
+ type = forms.CharField()
+
+ timer = forms.CharField()
+
+ def __init__(self, *args, **kwargs):
+ if 'question_type' in kwargs:
+ question_type = kwargs.pop('question_type')
+ else:
+ question_type = "mcq"
+ super(VideoQuizForm, self).__init__(*args, **kwargs)
+ self.fields['summary'].widget.attrs.update(
+ {'class': form_input_class, 'placeholder': 'Summary'}
+ )
+ self.fields['language'].widget.attrs.update(
+ {'class': 'custom-select'}
+ )
+ self.fields['topic'].widget.attrs.update(
+ {'class': form_input_class, 'placeholder': 'Question topic name'}
+ )
+ self.fields['points'].widget.attrs.update(
+ {'class': form_input_class, 'placeholder': 'Points'}
+ )
+ self.fields['type'].widget.attrs.update(
+ {'class': form_input_class, 'readonly': True}
+ )
+ self.fields['type'].initial = self._types.get(question_type)
+ self.fields['description'].widget.attrs.update(
+ {'class': form_input_class, 'placeholder': 'Description'}
+ )
+ self.fields['timer'].widget.attrs.update(
+ {'class': form_input_class, 'placeholder': 'Quiz Time'}
+ )
+
+ class Meta:
+ model = Question
+ fields = ['summary', 'description', 'points',
+ 'language', 'type', 'topic']