from contact.forms import ContactForm
from django.utils.translation import ugettext_lazy as _
+from wtem.models import TeacherConfirmation, Confirmation
+
WOJEWODZTWA = (
u'dolnośląskie',
u'kujawsko-pomorskie',
email = forms.EmailField(label=u'Adres e-mail', max_length=128)
form_tag = "student"
+ def clean_email(self):
+ email = self.cleaned_data['email']
+ if Confirmation.objects.filter(email=email):
+ raise forms.ValidationError(u'Uczeń z tym adresem już został zgłoszony.')
+ return email
+
class NonEmptyBaseFormSet(BaseFormSet):
"""
forms.ValidationError(u"Proszę podać dane przynajmniej jednej osoby.")
+class StudentFormset(forms.formsets.formset_factory(WTEMStudentForm, formset=NonEmptyBaseFormSet)):
+ def clean(self):
+ from django.forms.util import ErrorList
+ super(StudentFormset, self).clean()
+
+ emails = set()
+ for form in self.forms:
+ if not form.is_valid():
+ continue
+ if form.cleaned_data:
+ email = form.cleaned_data['email']
+ if email in emails:
+ errors = form._errors.setdefault('email', ErrorList())
+ errors.append(u'Każdy zgłoszony uczeń powinien mieć własny adres email')
+ else:
+ emails.add(email)
+
+
class CommissionForm(forms.Form):
name = forms.CharField(label=u'Imię i nazwisko Członka Komisji', max_length=128)
form_tag = "commission"
class OlimpiadaForm(ContactForm):
- ends_on = (2017, 11, 17, 0, 5)
+ ends_on = (2018, 11, 17, 0, 5)
disabled_template = 'wtem/disabled_contact_form.html'
form_tag = "olimpiada"
old_form_tags = ["olimpiada-2016"]
submit_label = u"Wyślij zgłoszenie"
admin_list = ['nazwisko', 'school']
form_formsets = {
- 'student': forms.formsets.formset_factory(WTEMStudentForm, formset=NonEmptyBaseFormSet),
+ 'student': StudentFormset,
'commission': forms.formsets.formset_factory(CommissionForm),
}
mailing_field = 'zgoda_newsletter'
contact = forms.EmailField(label=u'Adres e-mail Przewodniczącego/Przewodniczącej', max_length=128)
przewodniczacy = forms.CharField(label=u'Imię i nazwisko Przewodniczącego/Przewodniczącej', max_length=128)
+ przewodniczacy_phone = forms.CharField(
+ label=u'Numer telefonu Przewodniczącego/Przewodniczącej', max_length=128, required=False,
+ help_text=u'Zadzwonimy tylko w przypadku problemów ze zgłoszeniem.')
school = forms.CharField(label=u'Nazwa szkoły', max_length=255)
school_address = forms.CharField(label=u'Adres szkoły', widget=forms.Textarea, max_length=1000)
school_wojewodztwo = forms.ChoiceField(label=u'Województwo', choices=WOJEWODZTWO_CHOICES)
current = {}
return toret
+ def get_dictionary(self, contact):
+ dictionary = super(OlimpiadaForm, self).get_dictionary(contact)
+ conf = TeacherConfirmation.objects.filter(contact=contact)
+ if conf:
+ confirmation = conf.get()
+ else:
+ confirmation = TeacherConfirmation.create(contact=contact)
+ dictionary['confirmation'] = confirmation
+ return dictionary
+
def save(self, request, formsets=None):
from wtem.models import Confirmation
contact = super(OlimpiadaForm, self).save(request, formsets)
--- /dev/null
+# -*- coding: utf-8 -*-
+from south.utils import datetime_utils as datetime
+from south.db import db
+from south.v2 import SchemaMigration
+from django.db import models
+
+
+class Migration(SchemaMigration):
+
+ def forwards(self, orm):
+ # Adding model 'TeacherConfirmation'
+ db.create_table(u'wtem_teacherconfirmation', (
+ (u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+ ('contact', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['contact.Contact'], null=True)),
+ ('key', self.gf('django.db.models.fields.CharField')(max_length=30)),
+ ('confirmed', self.gf('django.db.models.fields.BooleanField')(default=False)),
+ ))
+ db.send_create_signal(u'wtem', ['TeacherConfirmation'])
+
+
+ def backwards(self, orm):
+ # Deleting model 'TeacherConfirmation'
+ db.delete_table(u'wtem_teacherconfirmation')
+
+
+ models = {
+ u'auth.group': {
+ 'Meta': {'object_name': 'Group'},
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
+ 'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
+ },
+ u'auth.permission': {
+ 'Meta': {'ordering': "(u'content_type__app_label', u'content_type__model', u'codename')", 'unique_together': "((u'content_type', u'codename'),)", 'object_name': 'Permission'},
+ 'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+ 'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['contenttypes.ContentType']"}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
+ },
+ u'auth.user': {
+ 'Meta': {'object_name': 'User'},
+ 'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+ 'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+ 'groups': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "u'user_set'", 'blank': 'True', 'to': u"orm['auth.Group']"}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
+ 'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+ 'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+ 'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+ 'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+ 'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+ 'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "u'user_set'", 'blank': 'True', 'to': u"orm['auth.Permission']"}),
+ 'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+ },
+ u'contact.contact': {
+ 'Meta': {'ordering': "('-created_at',)", 'object_name': 'Contact'},
+ 'body': ('jsonfield.fields.JSONField', [], {}),
+ 'contact': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+ 'created_at': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+ 'form_tag': ('django.db.models.fields.CharField', [], {'max_length': '32', 'db_index': 'True'}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'ip': ('django.db.models.fields.IPAddressField', [], {'max_length': '15'})
+ },
+ u'contenttypes.contenttype': {
+ 'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
+ 'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+ },
+ u'wtem.assignment': {
+ 'Meta': {'object_name': 'Assignment'},
+ 'exercises': ('jsonfield.fields.JSONField', [], {}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'user': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['auth.User']", 'unique': 'True'})
+ },
+ u'wtem.attachment': {
+ 'Meta': {'object_name': 'Attachment'},
+ 'exercise_id': ('django.db.models.fields.IntegerField', [], {}),
+ 'file': ('django.db.models.fields.files.FileField', [], {'max_length': '100'}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'submission': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['wtem.Submission']"}),
+ 'tag': ('django.db.models.fields.CharField', [], {'max_length': '128', 'null': 'True', 'blank': 'True'})
+ },
+ u'wtem.competitionstate': {
+ 'Meta': {'object_name': 'CompetitionState'},
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'state': ('django.db.models.fields.CharField', [], {'max_length': '16'})
+ },
+ u'wtem.confirmation': {
+ 'Meta': {'ordering': "['contact__contact']", 'object_name': 'Confirmation'},
+ 'confirmed': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+ 'contact': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['contact.Contact']", 'null': 'True'}),
+ 'email': ('django.db.models.fields.EmailField', [], {'unique': 'True', 'max_length': '100'}),
+ 'first_name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'key': ('django.db.models.fields.CharField', [], {'max_length': '30'}),
+ 'last_name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+ },
+ u'wtem.submission': {
+ 'Meta': {'object_name': 'Submission'},
+ 'answers': ('django.db.models.fields.CharField', [], {'max_length': '65536', 'null': 'True', 'blank': 'True'}),
+ 'contact': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['contact.Contact']", 'null': 'True'}),
+ 'email': ('django.db.models.fields.EmailField', [], {'unique': 'True', 'max_length': '100'}),
+ 'end_time': ('django.db.models.fields.CharField', [], {'max_length': '5', 'null': 'True', 'blank': 'True'}),
+ 'examiners': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': u"orm['auth.User']", 'null': 'True', 'blank': 'True'}),
+ 'first_name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'key': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'}),
+ 'key_sent': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+ 'last_name': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+ 'marks': ('jsonfield.fields.JSONField', [], {'default': '{}'}),
+ 'opened_link': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+ 'random_seed': ('django.db.models.fields.IntegerField', [], {})
+ },
+ u'wtem.teacherconfirmation': {
+ 'Meta': {'ordering': "['contact__contact']", 'object_name': 'TeacherConfirmation'},
+ 'confirmed': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+ 'contact': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['contact.Contact']", 'null': 'True'}),
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+ 'key': ('django.db.models.fields.CharField', [], {'max_length': '30'})
+ }
+ }
+
+ complete_apps = ['wtem']
\ No newline at end of file
return self.user.username + ': ' + ','.join(map(str, self.exercises))
-class Confirmation(models.Model):
- first_name = models.CharField(max_length=100)
- last_name = models.CharField(max_length=100)
- email = models.EmailField(max_length=100, unique=True)
+class AbstractConfirmation(models.Model):
contact = models.ForeignKey(Contact, null=True)
key = models.CharField(max_length=30)
confirmed = models.BooleanField(default=False)
+ class Meta:
+ abstract = True
+
+ def readable_contact(self):
+ return '%s <%s>' % (self.contact.body.get('przewodniczacy'), self.contact.contact)
+
+ def school_phone(self):
+ return '%s, tel. %s' % (self.contact.body.get('school'), self.contact.body.get('school_phone'))
+
+ def age(self):
+ return timezone.now() - self.contact.created_at
+
+ def readable_age(self):
+ td = self.age()
+ return '%s dni, %s godzin' % (td.days, td.seconds/3600)
+
+
+class Confirmation(AbstractConfirmation):
+ first_name = models.CharField(max_length=100)
+ last_name = models.CharField(max_length=100)
+ email = models.EmailField(max_length=100, unique=True)
+
class Meta:
ordering = ['contact__contact']
def absolute_url(self):
return reverse('student_confirmation', args=(self.id, self.key))
- def readable_contact(self):
- return '%s <%s>' % (self.contact.body.get('przewodniczacy'), self.contact.contact)
-
- def school_phone(self):
- return '%s, tel. %s' % (self.contact.body.get('school'), self.contact.body.get('school_phone'))
-
- def age(self):
- return timezone.now() - self.contact.created_at
-
- def readable_age(self):
- td = self.age()
- return '%s dni, %s godzin' % (td.days, td.seconds/3600)
-
def send_mail(self):
mail_subject = render_to_string('contact/olimpiada/student_mail_subject.html').strip()
mail_body = render_to_string(
fail_silently=True)
+class TeacherConfirmation(AbstractConfirmation):
+
+ class Meta:
+ ordering = ['contact__contact']
+
+ @classmethod
+ def create(cls, contact=None, key=None):
+ confirmation = cls(
+ contact=contact,
+ key=key if key else make_key(30),
+ )
+ confirmation.save()
+ return confirmation
+
+ def absolute_url(self):
+ return reverse('teacher_confirmation', args=(self.id, self.key))
+
+
def exercise_checked_manually(exercise):
return (exercise['type'] in ('open', 'file_upload')) or 'open_part' in exercise