From: Jan Szejko <janek37@gmail.com> Date: Thu, 1 Sep 2016 13:44:02 +0000 (+0200) Subject: OC registration form X-Git-Url: https://git.mdrn.pl/edumed.git/commitdiff_plain/1c6b6f643fb3a9f50fe2752b3b2ee3390b321d78?ds=sidebyside;hp=1a94f90243f87a850db25293698b7b48b8854509 OC registration form --- 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 <a href="https://olimpiadacyfrowa.pl/regulamin/" target="_blank">' + u'regulamin Olimpiady Cyfrowej</a>.' + ) + 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 %} + + + + + + + <h1>{% block contact_form_title %}{{ form.form_title }}{% endblock %}</h1> + + <div class="form-info"> + {% block contact_form_description %} + {% chunk "contact_form__"|add:form.form_tag %} + {% endblock %} + </div> + + <form method="POST" action="." enctype="multipart/form-data" class="submit-form"> + {% csrf_token %} + {% render_honeypot_field %} + <h3>Dane PrzewodniczÄ cego i szkoÅy zgÅaszajÄ cej Uczestników:</h3> + <table> + {{ form.as_table }} + </table> + + {% with formsets.commission as formset %} + + <h3>Dane czÅonków Komisji Szkolnej:</h3> + + {{ formset.management_form }} + + <ul class="errorlist"> + {% for err in formset.non_form_errors %} + <li>{{ err }}</li> + {% endfor %} + </ul> + + {% for form in formset.forms %} + <table> + {{ form.as_table }} + </table> + {% endfor %} + + <div id="formstub-{{ formset.prefix }}" style="display:none"> + <table> + {{ formset.empty_form.as_table }} + </table> + </div> + + <input type="button" value="+ Dodaj kolejnÄ osobÄ" class="add_more" data-selector="#formstub-{{formset.prefix}}" data-prefix="{{formset.prefix}}"> + {% endwith %} + + + {% with formsets.student as formset %} + <h3>Dane Uczestników:</h3> + + {{ formset.management_form }} + + <ul class="errorlist"> + {% for err in formset.non_form_errors %} + <li>{{ err }}</li> + {% endfor %} + </ul> + + {% for form in formset.forms %} + <h4>Uczestnik/Uczestniczka:</h4> + + <table> + {{ form.as_table }} + </table> + {% endfor %} + + <div id="formstub-{{ formset.prefix }}" style="display:none"> + <h4>Uczestnik/Uczestniczka:</h4> + <table> + {{ formset.empty_form.as_table }} + </table> + </div> + + <input type="button" value="+ Dodaj kolejnÄ osobÄ" class="add_more" data-selector="#formstub-{{formset.prefix}}" data-prefix="{{formset.prefix}}"> + {% endwith %} + + <p> + <button style="font-size:1.5em;">{% block contact_form_submit %}{{ form.submit_label }}{% endblock %}</button> + </p> + </form> + + +{% 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 %} +<p>DziÄkujemy za rejestracjÄ w Olimpiadzie Cyfrowej.</p> + +<p>Na adres adres e-mail PrzewodniczÄ cego/PrzewodniczÄ cej zostaÅa wysÅana wiadomoÅÄ potwierdzajÄ ca +rejestracjÄ.</p> + +<p>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. </p> + +<p>ZespóŠOlimpiady Cyfrowej<br> +fundacja Nowoczesna Polska</p> +{% endblock %}