diff options
-rwxr-xr-x | .gitignore | 5 | ||||
-rw-r--r-- | nccps2018/settings.py | 8 | ||||
-rw-r--r-- | static/website/templates/question_list.html | 1 | ||||
-rwxr-xr-x | website/forms.py | 13 | ||||
-rw-r--r-- | website/models.py | 16 | ||||
-rw-r--r-- | website/urls.py | 1 | ||||
-rw-r--r-- | website/views.py | 60 |
7 files changed, 87 insertions, 17 deletions
@@ -20,4 +20,7 @@ db.sqlite3 # Django Migration files #MAC OS specific -.DS_Store
\ No newline at end of file +.DS_Store + +#VScode +.vscode/ diff --git a/nccps2018/settings.py b/nccps2018/settings.py index f28ffa7..9ce4c32 100644 --- a/nccps2018/settings.py +++ b/nccps2018/settings.py @@ -81,10 +81,10 @@ WSGI_APPLICATION = 'nccps2018.wsgi.application' DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', - 'NAME': DB_NAME_DEFAULT, # Or path to database file if using sqlite3. - 'USER': DB_USER_DEFAULT, - 'PASSWORD': DB_PASS_DEFAULT, - 'HOST': DB_HOST_DEFAULT, + 'NAME': DB_NAME_DEFAULT, # Or path to database file if using sqlite3. + 'USER': DB_USER_DEFAULT, + 'PASSWORD': DB_PASS_DEFAULT, + 'HOST': DB_HOST_DEFAULT, } } diff --git a/static/website/templates/question_list.html b/static/website/templates/question_list.html index 65b571a..cc11098 100644 --- a/static/website/templates/question_list.html +++ b/static/website/templates/question_list.html @@ -13,6 +13,7 @@ <br> <a href="{% url 'website:add_questions' %}" ><button class="btn-default btn-warning"> Add Question </button></a> <a href="{% url 'website:leaderboard' %}" ><button class="btn-default btn-info"> LeaderBoard </button></a> + <br><br> </div> diff --git a/website/forms.py b/website/forms.py index 5b094e7..bee9ba9 100755 --- a/website/forms.py +++ b/website/forms.py @@ -1,7 +1,7 @@ from django import forms from django.forms import ModelForm, widgets - +import datetime from django.contrib.auth.forms import UserCreationForm from django.contrib.auth.models import User from django.core.validators import MinLengthValidator, MinValueValidator, \ @@ -396,4 +396,13 @@ class QuestionUploadForm(forms.ModelForm): widgets = { 'question_day': DateInput(), - }
\ No newline at end of file + } + + +#To upload model for each question +''' +class UploadModelForm(forms.ModelForm): + class Meta: + model = UploadModel + fields = ['model_file'] +''' diff --git a/website/models.py b/website/models.py index 2481177..e482453 100644 --- a/website/models.py +++ b/website/models.py @@ -34,7 +34,11 @@ def get_document_dir(instance, filename): fname, fext = os.path.splitext(filename) # print "----------------->",instance.user return '%s/attachment/%s/%s.%s' % (instance.user, instance.proposal_type, fname+'_'+str(instance.user), fext) - + + +def attachments(instance, filename): + return os.sep.join((instance.workshoptype_name.replace(" ", '_'), filename)) + class Proposal(models.Model): user = models.ForeignKey(User, on_delete=models.CASCADE,) @@ -123,4 +127,12 @@ class AnswerPaper(models.Model): participant = models.ForeignKey(Profile, on_delete=models.CASCADE) answered_q = models.ForeignKey(Question, on_delete=models.CASCADE) validate_ans = models.BooleanField() - date = models.DateTimeField(auto_now=True)
\ No newline at end of file + date = models.DateTimeField(auto_now=True) + + +#To upload model for each question +''' +class UploadModel(models.Model): + question = models.ForeignKey(Question, on_delete=models.CASCADE, blank=True, null=True) + model_file = models.FileField(upload_to=attachments) +'''
\ No newline at end of file diff --git a/website/urls.py b/website/urls.py index 7cf47c5..f0dbe60 100644 --- a/website/urls.py +++ b/website/urls.py @@ -20,6 +20,7 @@ urlpatterns = [ re_path(r'^cfp/$', views.cfp, name='cfp'), #re_path(r'^quiz/$', views.quiz_view, name='quiz_view'), re_path(r'^question_list/$', views.question_list, name='question_list'), + #re_path(r'^uploadmodel/$', views.uploadmodel, name='uploadmodel'), re_path(r'^add_questions/$', views.add_questions, name='add_questions'), re_path(r'^edit_question/(?P<qid>\d+)$', views.edit_question, name='edit_question'), re_path(r'^take_quiz/$', views.take_quiz, name='take_quiz'), diff --git a/website/views.py b/website/views.py index 35686e7..a330387 100644 --- a/website/views.py +++ b/website/views.py @@ -16,11 +16,12 @@ from website.models import (Proposal, Comments, Ratings, Question, AnswerPaper, Profile) from website.forms import (ProposalForm, UserRegisterForm, UserRegistrationForm, - UserLoginForm, WorkshopForm,QuestionUploadForm) # ,ContactForm + UserLoginForm, WorkshopForm,QuestionUploadForm + )# ,ContactForm from website.models import Proposal, Comments, Ratings from social.apps.django_app.default.models import UserSocialAuth from django.contrib.auth import authenticate, login, logout -from datetime import datetime +from datetime import datetime, date from django import template from django.core.mail import EmailMultiAlternatives import os @@ -1163,17 +1164,60 @@ def take_quiz(request): def leaderboard(request): profiles = Profile.objects.all() - leaderboard = {p:0 for p in profiles} - + marks = { + '5': [date(2018, 10, 29), date(2018, 11, 4)], + '10': [date(2018, 11, 5), date(2018, 11, 12)] + } answers = AnswerPaper.objects.all() for i in leaderboard: - profile_data = AnswerPaper.objects.filter(participant=i) - for pro in profile_data: - if pro.validate_ans==1: - leaderboard[i] +=1 + profiles = AnswerPaper.objects.filter(participant=i) + for p in profiles: + if p.validate_ans==1: + if marks['5'][0] <= p.answered_q.question_day <= marks['5'][1]: + leaderboard[i] +=5 + elif marks['10'][0] <= p.answered_q.question_day <= marks['10'][1]: + leaderboard[i] +=10 + else: + leaderboard[i] +=1 + sorted_leaderboard = sorted(leaderboard.items(), key=lambda kv: kv[1]) return render(request, "leaderboard.html", {'leaderboard': sorted_leaderboard[::-1]}) + +''' +@login_required +def uploadmodel(request): + if request.method == 'POST': + data = request.body.decode("utf-8").split('&') + date = data[1].replace("qdate=", "") + date = datetime.strptime(date, "%Y-%m-%d").date() + question_list = Question.objects.all() + try: + question_obj = Question.objects.get(question_day=date) + print(question_obj) + messages.info(request, 'Uploaded Successfully!') + except: + messages.error(request, 'No question uploaded for mentioned date') + + + form = UploadModelForm(request.POST) + if form.is_valid(): + uploadForm = form.save(commit=False) + try: + question_obj = Question.objects.get(question_day=date) + uploadForm.question = question_obj + uploadForm.model_file + uploadForm.save() + messages.info(request, 'Uploaded Successfully!') + except: + messages.error(request, 'No question uploaded for mentioned date') + print(question_obj) + else: + messages.error(request, 'Invalid Form') + + + return render(request, "uploadmodel.html", {"question_list":question_list})''' +
\ No newline at end of file |