From 1c6b6f643fb3a9f50fe2752b3b2ee3390b321d78 Mon Sep 17 00:00:00 2001 From: Jan Szejko Date: Thu, 1 Sep 2016 15:44:02 +0200 Subject: [PATCH] OC registration form --- contact/views.py | 24 ++-- edumed/contact_forms.py | 104 ++++++++++++++++-- edumed/templates/contact/olimpiada/form.html | 93 ++++++++++++++++ .../templates/contact/olimpiada/mail_body.txt | 19 ++++ .../contact/olimpiada/mail_subject.txt | 1 + .../contact/olimpiada/student_mail_body.html | 17 +++ .../olimpiada/student_mail_subject.html | 1 + .../templates/contact/olimpiada/thanks.html | 17 +++ 8 files changed, 254 insertions(+), 22 deletions(-) create mode 100755 edumed/templates/contact/olimpiada/form.html create mode 100755 edumed/templates/contact/olimpiada/mail_body.txt create mode 100755 edumed/templates/contact/olimpiada/mail_subject.txt create mode 100644 edumed/templates/contact/olimpiada/student_mail_body.html create mode 100644 edumed/templates/contact/olimpiada/student_mail_subject.html create mode 100755 edumed/templates/contact/olimpiada/thanks.html diff --git a/contact/views.py b/contact/views.py index b9a411f..5a2f2ae 100644 --- a/contact/views.py +++ b/contact/views.py @@ -25,21 +25,19 @@ def form(request, form_tag, force_enabled=False): raise Http404 if request.method == 'POST': form = form_class(request.POST, request.FILES) - formsets = [] - valid = form.is_valid() - for formset in getattr(form, 'form_formsets', ()): - fset = formset(request.POST, request.FILES) - if not fset.is_valid(): - valid = False - formsets.append(fset) - if valid: - form.save(request, formsets) - return redirect('contact_thanks', form_tag) else: form = form_class(initial=request.GET) - formsets = [] - for formset in getattr(form, 'form_formsets', ()): - formsets.append(formset()) + formset_classes = getattr(form, 'form_formsets', {}) + if request.method == 'POST': + formsets = { + prefix: formset_class(request.POST, request.FILES, prefix=prefix) + for prefix, formset_class in formset_classes.iteritems()} + if form.is_valid() and all(formset.is_valid() for formset in formsets.itervalues()): + form.save(request, formsets.values()) + return redirect('contact_thanks', form_tag) + else: + formsets = {prefix: formset_class(prefix=prefix) for prefix, formset_class in formset_classes.iteritems()} + return render( request, ['contact/%s/form.html' % form_tag, 'contact/form.html'], {'form': form, 'formsets': formsets} diff --git a/edumed/contact_forms.py b/edumed/contact_forms.py index 7f71143..87fc591 100644 --- a/edumed/contact_forms.py +++ b/edumed/contact_forms.py @@ -130,19 +130,15 @@ class WTEMStudentForm(forms.Form): form_tag = "student" -# FIXME: doesn't do what is says anymore. -class NoEmptyFormsAllowedBaseFormSet(BaseFormSet): +class NonEmptyBaseFormSet(BaseFormSet): """ Won't allow formset_factory to be submitted with no forms """ def clean(self): - needed = 3 for form in self.forms: if form.cleaned_data: - needed -= 1 - # return - if needed > 0: - raise forms.ValidationError(u"Proszę podać dane przynajmniej trzech osób.") + return + forms.ValidationError(u"Proszę podać dane przynajmniej jednej osoby.") class WTEMForm(ContactForm): @@ -152,8 +148,10 @@ class WTEMForm(ContactForm): form_title = u"WTEM - rejestracja uczestników" submit_label = u"Wyślij zgłoszenie" admin_list = ['imie', 'nazwisko', 'institution'] - form_formsets = (forms.formsets.formset_factory( - WTEMStudentForm, formset=NoEmptyFormsAllowedBaseFormSet, max_num=5, validate_max=True, extra=5),) + form_formsets = { + 'student': forms.formsets.formset_factory( + WTEMStudentForm, formset=NonEmptyBaseFormSet, max_num=5, validate_max=True, extra=5), + } contact = forms.EmailField(label=u'Adres e-mail opiekuna/opiekunki', max_length=128) imie = forms.CharField(label=u'Imię', max_length=128) @@ -235,6 +233,94 @@ class WTEMForm(ContactForm): return contact +class CommissionForm(forms.Form): + name = forms.CharField(label=u'Imię i nazwisko Członka Komisji', max_length=128) + form_tag = "commission" + + +class OlimpiadaForm(ContactForm): + disabled = False + disabled_template = 'wtem/disabled_contact_form.html' + form_tag = "olimpiada" + form_title = u"Olimpiada Cyfrowa - Elektroniczny System Zgłoszeń" + submit_label = u"Wyślij zgłoszenie" + admin_list = ['nazwisko', 'school'] + form_formsets = { + 'student': forms.formsets.formset_factory(WTEMStudentForm, formset=NonEmptyBaseFormSet), + 'commission': forms.formsets.formset_factory(CommissionForm, formset=BaseFormSet), + } + + 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) + 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_email = forms.EmailField(label=u'Adres e-mail szkoły', max_length=128) + school_phone = forms.CharField(label=u'Numer telefonu szkoły', max_length=32) + school_www = forms.URLField(label=u'Strona WWW szkoły', max_length=255, required=False) + + zgoda_regulamin = forms.BooleanField( + label=u'Znam i akceptuję Regulamin Olimpiady Cyfrowej.', + help_text=u'Zobacz ' + u'regulamin Olimpiady Cyfrowej.' + ) + zgoda_dane = forms.BooleanField( + label=u'Oświadczam, że wyrażam zgodę na przetwarzanie danych osobowych zawartych w niniejszym formularzu ' + u'zgłoszeniowym przez Fundację Nowoczesna Polska (administratora danych) z siedzibą w Warszawie (00-514) ' + u'przy ul. Marszałkowskiej 84/92 lok. 125 na potrzeby organizacji Olimpiady Cyfrowej. Jednocześnie ' + u'oświadczam, że zostałam/em poinformowana/y o tym, że mam prawo wglądu w treść swoich danych ' + u'i możliwość ich poprawiania oraz że ich podanie jest dobrowolne, ale niezbędne do dokonania ' + u'zgłoszenia.') + + extract_types = (dict(slug='extended', label=_('extended')),) + + @staticmethod + def get_extract_fields(contact, extract_type_slug): + fields = contact.body.keys() + fields.remove('student') + fields.extend(['contact', 'student_first_name', 'student_last_name', 'student_email']) + return fields + + @staticmethod + def get_extract_records(keys, contact, extract_type_slug): + toret = [{}] + for field_name in keys: + if field_name.startswith('student_'): + continue + if field_name == 'contact': + val = contact.contact + else: + val = contact.body[field_name] + toret[0][field_name] = val + + current = toret[0] + for student in contact.body['student']: + for attr in ('first_name', 'last_name', 'email'): + current['student_' + attr] = student[attr] + if current not in toret: + toret.append(current) + current = {} + return toret + + def save(self, request, formsets=None): + contact = super(OlimpiadaForm, self).save(request, formsets) + + mail_subject = render_to_string('contact/olimpiada/student_mail_subject.html').strip() + mail_body = render_to_string('contact/olimpiada/student_mail_body.html') + for formset in formsets or []: + if formset.prefix == 'student': + for f in formset.forms: + email = f.cleaned_data.get('email', None) + try: + validate_email(email) + except ValidationError: + pass + else: + send_mail(mail_subject, mail_body, 'edukacjamedialna@nowoczesnapolska.org.pl', [email], + fail_silently=True) + + return contact + + class MILForm(ContactForm): form_tag = 'mil' form_title = _('Share your thoughts on the "Media and information literacy competencies catalogue"') diff --git a/edumed/templates/contact/olimpiada/form.html b/edumed/templates/contact/olimpiada/form.html new file mode 100755 index 0000000..c28925a --- /dev/null +++ b/edumed/templates/contact/olimpiada/form.html @@ -0,0 +1,93 @@ +{% extends "base.html" %} +{% load chunks %} +{% load honeypot %} + +{% block title %}{{ form.form_title }}{% endblock %} + +{% block body %} + + + + + + +

{% block contact_form_title %}{{ form.form_title }}{% endblock %}

+ +
+ {% block contact_form_description %} + {% chunk "contact_form__"|add:form.form_tag %} + {% endblock %} +
+ +
+ {% csrf_token %} + {% render_honeypot_field %} +

Dane Przewodniczącego i szkoły zgłaszającej Uczestników:

+ + {{ form.as_table }} +
+ + {% with formsets.commission as formset %} + +

Dane członków Komisji Szkolnej:

+ + {{ formset.management_form }} + + + + {% for form in formset.forms %} + + {{ form.as_table }} +
+ {% endfor %} + + + + + {% endwith %} + + + {% with formsets.student as formset %} +

Dane Uczestników:

+ + {{ formset.management_form }} + + + + {% for form in formset.forms %} +

Uczestnik/Uczestniczka:

+ + + {{ form.as_table }} +
+ {% endfor %} + + + + + {% endwith %} + +

+ +

+
+ + +{% endblock %} diff --git a/edumed/templates/contact/olimpiada/mail_body.txt b/edumed/templates/contact/olimpiada/mail_body.txt new file mode 100755 index 0000000..0a63f92 --- /dev/null +++ b/edumed/templates/contact/olimpiada/mail_body.txt @@ -0,0 +1,19 @@ +Dziękujemy za rejestrację w Olimpiadzie Cyfrowej. +Do udziału zostały zgłoszone następujące osoby: +{% for student in contact.body.student %}* {{ student.first_name }} {{ student.last_name }}{% endfor %} + +Każdy zgłoszony uczeń powinien otrzymać wiadomość z potwierdzeniem +rejestracji. Prosimy upewnić się, czy potwierdzenie dotarło do każdego +ze zgłoszonych uczniów. W ten sposób zweryfikujemy, czy podane adresy +są prawidłowe. + +Pierwszy etap Olimpiady (test on-line) odbędzie się +15 listopada 2016 r. o godz. 10:00 i potrwa 90 minut. + +Wszystkie ogłoszenia związane z Turniejem będą publikowane na stronie https://olimpiadacyfrowa.pl. +W razie pytań lub wątpliwości można kontaktować się z nami, pisząc na adres: olimpiada@nowoczesnapolska.org.pl. + +Z pozdrowieniami, + +Zespół Olimpiady Cyfrowej +Fundacja Nowoczesna Polska \ No newline at end of file diff --git a/edumed/templates/contact/olimpiada/mail_subject.txt b/edumed/templates/contact/olimpiada/mail_subject.txt new file mode 100755 index 0000000..b40c079 --- /dev/null +++ b/edumed/templates/contact/olimpiada/mail_subject.txt @@ -0,0 +1 @@ +Potwierdzenie zgłoszenia uczniów do Olimpiady Cyfrowej \ No newline at end of file diff --git a/edumed/templates/contact/olimpiada/student_mail_body.html b/edumed/templates/contact/olimpiada/student_mail_body.html new file mode 100644 index 0000000..eb3df3e --- /dev/null +++ b/edumed/templates/contact/olimpiada/student_mail_body.html @@ -0,0 +1,17 @@ +Witaj, + +Przewodniczący Komisji Szkolnej właśnie zgłosił Cię do Olimpiady Cyfrowej. +Cieszymy się, że chcesz wziąć w niej udział. + +Pierwszy etap Olimpiady (test on-line) odbędzie się 15 listopada 2016 r. +o godz. 10:00 i potrwa 90 minut. + +Szczegółowe informacje na temat pierwszego etapu Olimpiady oraz wszystkie +ogłoszenia z nią związane będą publikowane na stronie https://olimpiadacyfrowa.pl. +W razie pytań lub wątpliwości możesz kontaktować się z nami, pisząc na adres +olimpiada@nowoczesnapolska.org.pl. + +Z pozdrowieniami, + +Zespół Olimpiady Cyfrowej +Fundacja Nowoczesna Polska diff --git a/edumed/templates/contact/olimpiada/student_mail_subject.html b/edumed/templates/contact/olimpiada/student_mail_subject.html new file mode 100644 index 0000000..4910d3f --- /dev/null +++ b/edumed/templates/contact/olimpiada/student_mail_subject.html @@ -0,0 +1 @@ +Potwierdzenie zgłoszenia do Olimpiady Cyfrowej \ No newline at end of file diff --git a/edumed/templates/contact/olimpiada/thanks.html b/edumed/templates/contact/olimpiada/thanks.html new file mode 100755 index 0000000..6252026 --- /dev/null +++ b/edumed/templates/contact/olimpiada/thanks.html @@ -0,0 +1,17 @@ +{% extends "contact/thanks.html" %} + +{% block contact_form_description %} +

Dziękujemy za rejestrację w Olimpiadzie Cyfrowej.

+ +

Na adres adres e-mail Przewodniczącego/Przewodniczącej została wysłana wiadomość potwierdzająca +rejestrację.

+ +

Każdy zgłoszony uczeń powinien otrzymać wiadomość z potwierdzeniem +rejestracji. +Prosimy upewnić się, że potwierdzenie dotarło do każdego ze +zgłoszonych uczniów. +W ten sposób zweryfikujemy, czy podane adresy są prawidłowe.

+ +

Zespół Olimpiady Cyfrowej
+fundacja Nowoczesna Polska

+{% endblock %} -- 2.20.1