test - poprawki
[edumed.git] / edumed / contact_forms.py
index f667329..eb4f7c9 100644 (file)
@@ -1,8 +1,12 @@
 # -*- coding: utf-8 -*-
 # -*- coding: utf-8 -*-
+import re
+
 from django import forms
 from django.forms.formsets import BaseFormSet
 from django.utils.safestring import mark_safe
 from django import forms
 from django.forms.formsets import BaseFormSet
 from django.utils.safestring import mark_safe
+from markdown2 import Markdown
 
 
+from contact.fields import HeaderField
 from contact.forms import ContactForm
 from django.core.mail import send_mail
 from django.core.exceptions import ValidationError
 from contact.forms import ContactForm
 from django.core.mail import send_mail
 from django.core.exceptions import ValidationError
@@ -10,6 +14,14 @@ from django.core.validators import validate_email
 from django.template.loader import render_to_string
 from django.utils.translation import ugettext_lazy as _
 
 from django.template.loader import render_to_string
 from django.utils.translation import ugettext_lazy as _
 
+from edumed.contact_forms_test import TestForm, CollegiumTestForm
+
+LINK_PATTERNS = [
+    (re.compile(r'((http|ftp|https)://([\w_-]+(?:(?:\.[\w_-]+)+))([\w.,;@?^=%&:/~+#-]*[\w@?^=%&/~+#-])?)'),
+     r'\1')
+]
+
+markdown = Markdown(extras=["link-patterns", 'code-friendly'], link_patterns=LINK_PATTERNS)
 
 WOJEWODZTWA = (
     u'dolnośląskie',
 
 WOJEWODZTWA = (
     u'dolnośląskie',
@@ -33,10 +45,19 @@ WOJEWODZTWA = (
 WOJEWODZTWO_CHOICES = [(u'', u'(wybierz)')] + [(w, w) for w in WOJEWODZTWA]
 
 
 WOJEWODZTWO_CHOICES = [(u'', u'(wybierz)')] + [(w, w) for w in WOJEWODZTWA]
 
 
-class RegistrationForm(ContactForm):
+def make_data_processing(middle_text):
+    return mark_safe(u'''\
+Administratorem danych osobowych jest Fundacja Nowoczesna Polska (ul. Marszałkowska 84/92 lok. 125, 00-514 Warszawa). \
+Podanie danych osobowych jest dobrowolne. %s Osobom, których dane są zbierane, przysługuje prawo dostępu do treści \
+swoich danych oraz ich poprawiania. Więcej informacji w <a href="https://nowoczesnapolska.org.pl/prywatnosc/">\
+polityce prywatności</a>.''' % middle_text)
+
+
+class SuggestionForm(ContactForm):
     form_tag = 'sugestie'
     form_title = u"Zgłoś sugestię"
     admin_list = ['podpis', 'contact', 'temat']
     form_tag = 'sugestie'
     form_title = u"Zgłoś sugestię"
     admin_list = ['podpis', 'contact', 'temat']
+    data_processing = make_data_processing(u'Dane są przetwarzane w zakresie niezbędnym do obsługi zgłoszenia.')
 
     contact = forms.EmailField(label=u'E-mail', max_length=128, required=False)
     podpis = forms.CharField(label=u'Podpis', max_length=128, required=False)
 
     contact = forms.EmailField(label=u'E-mail', max_length=128, required=False)
     podpis = forms.CharField(label=u'Podpis', max_length=128, required=False)
@@ -47,37 +68,21 @@ class RegistrationForm(ContactForm):
 class CooperateForm(ContactForm):
     form_tag = 'wspolpraca'
     form_title = u"Bądź z nami w kontakcie"
 class CooperateForm(ContactForm):
     form_tag = 'wspolpraca'
     form_title = u"Bądź z nami w kontakcie"
-    admin_list = ['podpis', 'contact']
+    admin_list = ['contact']
+    mailing = True
+    data_processing = make_data_processing(
+        u'Dane są przetwarzane w zakresie niezbędnym do wysyłania newslettera odbiorcom.')
+    submit_label = u'Wyślij'
 
 
-    podpis = forms.CharField(label=u'Imię i nazwisko', max_length=128)
     contact = forms.EmailField(label=u'E-mail', max_length=128)
     contact = forms.EmailField(label=u'E-mail', max_length=128)
-    instytucja = forms.CharField(
-        label=u'Instytucja (nazwa, adres)', widget=forms.Textarea, max_length=1000, required=False)
-    uwagi = forms.CharField(label=u'Uwagi', widget=forms.Textarea, max_length=1800, required=False)
-        
-    zajecia_przedszkole = forms.BooleanField(label=u'Prowadzę zajęcia z dziećmi w wieku przedszkolnym', required=False)
-    zajecia_sp13 = forms.BooleanField(label=u'Prowadzę zajęcia z dziećmi z SP kl. 1-3', required=False)
-    zajecia_sp46 = forms.BooleanField(label=u'Prowadzę zajęcia z dziećmi z SP kl. 4-6', required=False)
-    zajecia_gimnazjum = forms.BooleanField(label=u'Prowadzę zajęcia z młodzieżą w wieku gimnazjalnym', required=False)
-    zajecia_ponadgimnazjalne = forms.BooleanField(
-        label=u'Prowadzę zajęcia z młodzieżą ze szkół ponadgimnazjalnych', required=False)
-    zajecia_wyzsze = forms.BooleanField(label=u'Prowadzę zajęcia w szkole wyższej', required=False)
-    zajecia_dorosli = forms.BooleanField(label=u'Prowadzę zajęcia dla dorosłych', required=False)
-    zajecia_seniorzy = forms.BooleanField(label=u'Prowadzę zajęcia dla seniorów', required=False)
-    zgoda_dane = forms.BooleanField(
-        label=u'Oświadczam, że wyrażam zgodę na przetwarzanie moich danych osobowych zawartych '
-              u'w niniejszym formularzu zgłoszeniowym przez Fundację Nowoczesna Polska '
-              u'(administratora danych) z siedzibą w Warszawie (00-514) przy ul. Marszałkowskiej 84/92 '
-              u'lok. 125 w celu otrzymywania newslettera Edukacja medialna. Jednocześnie oświadczam, '
-              u'ż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 '
-              u'do dokonania zgłoszenia.')
 
 
 class ContestForm(ContactForm):
 
 
 class ContestForm(ContactForm):
+    disabled = True
     form_tag = 'konkurs'
     form_title = u"Zgłoś się do konkursu"
     admin_list = ['nazwisko', 'instytucja', 'tytul']
     form_tag = 'konkurs'
     form_title = u"Zgłoś się do konkursu"
     admin_list = ['nazwisko', 'instytucja', 'tytul']
+    mailing_field = 'zgoda_informacje'
 
     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
     contact = forms.EmailField(label=u'Adres e-mail', max_length=128)
 
     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
     contact = forms.EmailField(label=u'Adres e-mail', max_length=128)
@@ -111,6 +116,7 @@ class ContestForm(ContactForm):
 
 
 class UdzialForm(ContactForm):
 
 
 class UdzialForm(ContactForm):
+    disabled = True
     form_tag = 'udzial'
     form_title = u"Udział"
     admin_list = ['nazwisko', 'miejscowosc', 'instytucja']
     form_tag = 'udzial'
     form_title = u"Udział"
     admin_list = ['nazwisko', 'miejscowosc', 'instytucja']
@@ -130,30 +136,30 @@ class WTEMStudentForm(forms.Form):
     form_tag = "student"
 
 
     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):
     """
     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:
         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):
     disabled = True
     disabled_template = 'wtem/disabled_contact_form.html'
     form_tag = "wtem"
 
 
 class WTEMForm(ContactForm):
     disabled = True
     disabled_template = 'wtem/disabled_contact_form.html'
     form_tag = "wtem"
+    old_form_tags = ["wtem2013", "wtem2014"]
     form_title = u"WTEM - rejestracja uczestników"
     submit_label = u"Wyślij zgłoszenie"
     admin_list = ['imie', 'nazwisko', 'institution']
     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),
+    }
+    mailing_field = 'zgoda_informacje'
 
     contact = forms.EmailField(label=u'Adres e-mail opiekuna/opiekunki', max_length=128)
     imie = forms.CharField(label=u'Imię', max_length=128)
 
     contact = forms.EmailField(label=u'Adres e-mail opiekuna/opiekunki', max_length=128)
     imie = forms.CharField(label=u'Imię', max_length=128)
@@ -235,7 +241,99 @@ class WTEMForm(ContactForm):
         return contact
 
 
         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 = True
+    disabled_template = 'wtem/disabled_contact_form.html'
+    form_tag = "olimpiada"
+    old_form_tags = ["olimpiada-2016"]
+    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()
+        if 'student' in fields:
+            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]
+        if 'student' in contact.body:
+            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):
 class MILForm(ContactForm):
+    disabled = True
     form_tag = 'mil'
     form_title = _('Share your thoughts on the "Media and information literacy competencies catalogue"')
     submit_label = _('Submit')
     form_tag = 'mil'
     form_title = _('Share your thoughts on the "Media and information literacy competencies catalogue"')
     submit_label = _('Submit')
@@ -273,9 +371,11 @@ class MILForm(ContactForm):
 
 
 class TEMForm(ContactForm):
 
 
 class TEMForm(ContactForm):
+    disabled = True
     form_tag = 'tem'
     form_title = u"TEM - szkolenie dla trenerów edukacji medialnej"
     admin_list = ['imie', 'nazwisko', 'instytucja', 'contact']
     form_tag = 'tem'
     form_title = u"TEM - szkolenie dla trenerów edukacji medialnej"
     admin_list = ['imie', 'nazwisko', 'instytucja', 'contact']
+    mailing_field = 'zgoda_informacje'
 
     imie = forms.CharField(label=u'Imię', max_length=128)
     nazwisko = forms.CharField(label=u'Nazwisko', max_length=128)
 
     imie = forms.CharField(label=u'Imię', max_length=128)
     nazwisko = forms.CharField(label=u'Nazwisko', max_length=128)
@@ -303,6 +403,7 @@ class TEMForm(ContactForm):
 
 
 class SuperwizjaForm(ContactForm):
 
 
 class SuperwizjaForm(ContactForm):
+    disabled = True
     form_tag = 'superwizja'
     form_title = u"Informacje o zajęciach"
     admin_list = ['nazwisko', 'contact', 'skype', 'temat']
     form_tag = 'superwizja'
     form_title = u"Informacje o zajęciach"
     admin_list = ['nazwisko', 'contact', 'skype', 'temat']
@@ -376,23 +477,30 @@ class SuperwizjaForm(ContactForm):
     uwagi = forms.CharField(label=u'Inne uwagi', widget=forms.Textarea, max_length=4096, required=False)
 
 
     uwagi = forms.CharField(label=u'Inne uwagi', widget=forms.Textarea, max_length=4096, required=False)
 
 
+def textarea_field(label, max_length=500):
+    return forms.CharField(
+        label=label, widget=forms.Textarea, max_length=max_length, help_text=u'(do %s znaków)' % max_length)
+
+
 class CybernauciForm(ContactForm):
     disabled = True
     disabled_template = 'contact/disabled_contact_form.html'
 class CybernauciForm(ContactForm):
     disabled = True
     disabled_template = 'contact/disabled_contact_form.html'
-    form_tag = 'trenerzy-cybernauci'
+    form_tag = 'trenerzy-cybernauci2017'
+    old_form_tags = ['trenerzy-cybernauci']
     form_title = u"Cybernauci – szkolenie dla trenerów"
     admin_list = ['nazwisko', 'instytucja', 'contact']
     submit_label = u'Wyślij'
     form_title = u"Cybernauci – szkolenie dla trenerów"
     admin_list = ['nazwisko', 'instytucja', 'contact']
     submit_label = u'Wyślij'
+    mailing_field = 'zgoda_newsletter'
 
     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=1024)
 
     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=1024)
-    contact = forms.CharField(label=u'E-mail kontaktowy')
-    telefon = forms.CharField(label=u'Telefon', max_length=32)
+    adres = forms.CharField(label=u'Adres zamieszkania')
     wojewodztwo = forms.ChoiceField(label=u'Województwo', choices=WOJEWODZTWO_CHOICES)
     wojewodztwo = forms.ChoiceField(label=u'Województwo', choices=WOJEWODZTWO_CHOICES)
-    dlaczego = forms.CharField(
-        label=u'Proszę opisać, dlaczego chce Pan/Pani zostać Emisariuszem Bezpiecznego Internetu.',
-        widget=forms.Textarea, max_length=4096)
+    contact = forms.CharField(label=u'Adres e-mail')
+    telefon = forms.CharField(label=u'Telefon kontaktowy', max_length=32)
+    dlaczego = textarea_field(
+        label=u'Proszę opisać, dlaczego chce Pan/Pani zostać Emisariuszem Bezpiecznego Internetu.')
     grupy = forms.MultipleChoiceField(
     grupy = forms.MultipleChoiceField(
-        label=u'Proszę wskazać, dla których grup realizował Pan/ realizowała Pani zajęcia warsztatowe',
+        label=u'Proszę wskazać, dla których grup realizował Pan/realizowała Pani zajęcia warsztatowe',
         widget=forms.CheckboxSelectMultiple,
         choices=[
             ('Uczniowie klas 1-3', 'Uczniowie klas 1-3'),
         widget=forms.CheckboxSelectMultiple,
         choices=[
             ('Uczniowie klas 1-3', 'Uczniowie klas 1-3'),
@@ -402,36 +510,34 @@ class CybernauciForm(ContactForm):
             ('Nauczyciele', 'Nauczyciele'),
             ('Rodzice', 'Rodzice'),
         ])
             ('Nauczyciele', 'Nauczyciele'),
             ('Rodzice', 'Rodzice'),
         ])
-    doswiadczenie_grupy = forms.CharField(
+    doswiadczenie_grupy = textarea_field(
         label=u'Proszę opisać swoje doświadczenie w pracy warsztatowej z grupami docelowymi Projektu '
               u'(dziećmi, młodzieżą, osobami dorosłymi: nauczycielami, rodzicami).',
         label=u'Proszę opisać swoje doświadczenie w pracy warsztatowej z grupami docelowymi Projektu '
               u'(dziećmi, młodzieżą, osobami dorosłymi: nauczycielami, rodzicami).',
-        widget=forms.Textarea, max_length=4096)
-    doswiadczenie_edumed = forms.CharField(
-        label=u'Jakie jest Pana/Pani doświadczenie w zakresie edukacji medialnej,'
-              u'zwłaszcza w zakresie bezpieczeństwa w Internecie i korzystania z TIK?'
-              u' Skąd czerpie Pan/Pani wiedzę w tym zakresie? W jakich projektach brał'
-              u' Pan/brała Pani udział dotychczas?',
-        widget=forms.Textarea, max_length=4096)
-    szkolenia = forms.CharField(
+        max_length=750)
+    doswiadczenie_edumed = textarea_field(
+        label=u'Jakie jest Pana/Pani doświadczenie w zakresie edukacji medialnej, '
+              u'zwłaszcza w zakresie bezpieczeństwa w Internecie i korzystania z TIK? '
+              u'Skąd czerpie Pan/Pani wiedzę w tym zakresie? W jakich projektach brał '
+              u'Pan/brała Pani udział dotychczas?',
+        max_length=750)
+    szkolenia = textarea_field(
         label=u'Proszę wymienić studia, szkolenia albo kursy (maks. 5 najważniejszych) '
               u'powiązane z tematyką Projektu, w których Pan/Pani uczestniczył/ła, '
               u'w tym dane na temat instytucji czy osoby prowadzącej (z JEDNOZDANIOWYM '
         label=u'Proszę wymienić studia, szkolenia albo kursy (maks. 5 najważniejszych) '
               u'powiązane z tematyką Projektu, w których Pan/Pani uczestniczył/ła, '
               u'w tym dane na temat instytucji czy osoby prowadzącej (z JEDNOZDANIOWYM '
-              u'omówieniem i terminami, w których się odbyły).',
-        widget=forms.Textarea, max_length=4096)
-    realizacje = forms.CharField(
+              u'omówieniem i terminami, w których się odbyły).')
+    realizacje = textarea_field(
         label=u'Proszę opisać swoje doświadczenie w zakresie realizacji działań w lokalnym środowisku '
         label=u'Proszę opisać swoje doświadczenie w zakresie realizacji działań w lokalnym środowisku '
-              u'szkolnym (np. na terenie gminy/powiatu/województwa).',
-        widget=forms.Textarea, max_length=4096)
-    cel = forms.CharField(
+              u'szkolnym (np. na terenie gminy/powiatu/województwa).')
+    cel = textarea_field(
         label=u'Proszę opisać, jaką wiedzę i umiejętności chce Pan/Pani zdobyć '
         label=u'Proszę opisać, jaką wiedzę i umiejętności chce Pan/Pani zdobyć '
-              u'lub doskonalić poprzez uczestnictwo w Szkoleniu trenerskim.',
-        widget=forms.Textarea, max_length=4096)
+              u'lub doskonalić poprzez uczestnictwo w Szkoleniu trenerskim.')
+    skad = forms.CharField(label=u'Skąd dowiedział/dowiedziała się Pan/Pani o projekcie „Cybernauci”?')
     zgoda_regulamin = forms.BooleanField(
         label=u'Oświadczam, że zapoznałem/zapoznałam się z Regulaminem Rekrutacji '
               u'i Uczestnictwa w Projekcie „Cybernauci – kompleksowy projekt '
               u'kształtowania bezpiecznych zachowań w sieci” i akceptuję jego warunki.',
     zgoda_regulamin = forms.BooleanField(
         label=u'Oświadczam, że zapoznałem/zapoznałam się z Regulaminem Rekrutacji '
               u'i Uczestnictwa w Projekcie „Cybernauci – kompleksowy projekt '
               u'kształtowania bezpiecznych zachowań w sieci” i akceptuję jego warunki.',
-        help_text=u'Zobacz <a href="http://cybernauci.edu.pl/wp-content/uploads/2016/04/'
-                  u'regulamin_Cybernauci_szkolenie_trenerskie.pdf">regulamin</a>.')
+        help_text=u'Zobacz <a href="https://cybernauci.edu.pl/wp-content/uploads/2017/04/'
+                  u'regulamin_Cybernauci_szkolenie_trenerskie_2017.pdf">regulamin</a>.')
     zgoda_dane = forms.BooleanField(
         label=u'Wyrażam zgodę na przetwarzanie moich danych osobowych zawartych '
               u'w niniejszym dokumencie dla potrzeb niezbędnych do realizacji Projektu '
     zgoda_dane = forms.BooleanField(
         label=u'Wyrażam zgodę na przetwarzanie moich danych osobowych zawartych '
               u'w niniejszym dokumencie dla potrzeb niezbędnych do realizacji Projektu '
@@ -441,16 +547,21 @@ class CybernauciForm(ContactForm):
     zgoda_niekaralnosc = forms.BooleanField(
         label=u'W przypadku zakwalifikowania się na kurs zobowiązuję się '
               u'do dostarczenia świadectwa o niekaralności – najpóźniej w dniu rozpoczęcia Szkolenia.')
     zgoda_niekaralnosc = forms.BooleanField(
         label=u'W przypadku zakwalifikowania się na kurs zobowiązuję się '
               u'do dostarczenia świadectwa o niekaralności – najpóźniej w dniu rozpoczęcia Szkolenia.')
+    zgoda_newsletter = forms.BooleanField(
+        required=False,
+        label=u'Chcę otrzymywać newsletter Edukacja Medialna.')
     cv = forms.FileField(
         label=u'Wgraj plik CV.',
         help_text=u'Prosimy o nazwanie pliku swoim imieniem i nazwiskiem. Preferowany format: PDF.')
 
 
 class WLEMForm(ContactForm):
     cv = forms.FileField(
         label=u'Wgraj plik CV.',
         help_text=u'Prosimy o nazwanie pliku swoim imieniem i nazwiskiem. Preferowany format: PDF.')
 
 
 class WLEMForm(ContactForm):
+    disabled = True
     form_tag = 'wlem'
     form_title = u"WLEM - szkolenie dla warszawskich liderów edukacji medialnej"
     admin_list = ['nazwisko', 'instytucja', 'contact']
     submit_label = u'Wyślij'
     form_tag = 'wlem'
     form_title = u"WLEM - szkolenie dla warszawskich liderów edukacji medialnej"
     admin_list = ['nazwisko', 'instytucja', 'contact']
     submit_label = u'Wyślij'
+    mailing_field = 'zgoda_newsletter'
 
     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
     contact = forms.CharField(label=u'Adres e-mail')
 
     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
     contact = forms.CharField(label=u'Adres e-mail')
@@ -485,14 +596,10 @@ class WLEMForm(ContactForm):
               u'związanych z edukacją medialną.')
 
 
               u'związanych z edukacją medialną.')
 
 
-def textarea_field(label, max_length=500):
-    return forms.CharField(label=label, widget=forms.Textarea, max_length=max_length)
-
-
 def ordered_textarea_field(start, pre_label=u'', label=u'', max_length=500):
     return textarea_field(
 def ordered_textarea_field(start, pre_label=u'', label=u'', max_length=500):
     return textarea_field(
-        mark_safe(u'%s<ol type="a" start="%s"><li>%s (max. %s znaków)</li></ol>' % (
-            pre_label, start, label, max_length)))
+        mark_safe(u'%s<ol type="a" start="%s"><li>%s</li></ol>' % (pre_label, start, label)),
+        max_length=max_length)
 
 
 def simple_choices(*choices):
 
 
 def simple_choices(*choices):
@@ -504,59 +611,222 @@ class CybernauciAnkietaForm(ContactForm):
         super(CybernauciAnkietaForm, self).__init__(*args, **kwargs)
         self.label_suffix = ''
 
         super(CybernauciAnkietaForm, self).__init__(*args, **kwargs)
         self.label_suffix = ''
 
-    form_tag = 'cybernauci-ankieta-trenera'
-    form_title = u"Cybernauci – kompleksowy projekt kształtowania bezpiecznych zachowań w sieci"
-    nazwisko = forms.CharField(label=u'Imię i nazwisko trenera', max_length=128)
+    disabled = True
+    form_tag = 'cybernauci-ankieta-trenera-2017'
+    old_form_tags = ['cybernauci-ankieta-trenera']
+    form_title = u"Cybernauci – ankieta trenerska"
+    nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
     contact = forms.CharField(label=u'Adres e-mail')
     pyt1a = ordered_textarea_field(
     contact = forms.CharField(label=u'Adres e-mail')
     pyt1a = ordered_textarea_field(
-        1, pre_label=u'W kontekście planowanego szkolenia jakie są Twoje oczekiwania w zakresie:',
+        1, pre_label=u'1. W kontekście planowanego szkolenia jakie są Twoje oczekiwania w zakresie:',
         label=u'przekazywanej wiedzy')
     pyt1b = ordered_textarea_field(2, label=u'tematyki szkoleń z bezpieczeństwa w sieci')
     pyt1c = ordered_textarea_field(3, label=u'materiałów dydaktycznych')
     pyt1d = ordered_textarea_field(4, label=u'organizacji  i prowadzenia szkoleń w projekcie')
     pyt1e = ordered_textarea_field(5, label=u'umiejętności trenerskich')
     pyt1f = ordered_textarea_field(6, label=u'inne, jakie?')
         label=u'przekazywanej wiedzy')
     pyt1b = ordered_textarea_field(2, label=u'tematyki szkoleń z bezpieczeństwa w sieci')
     pyt1c = ordered_textarea_field(3, label=u'materiałów dydaktycznych')
     pyt1d = ordered_textarea_field(4, label=u'organizacji  i prowadzenia szkoleń w projekcie')
     pyt1e = ordered_textarea_field(5, label=u'umiejętności trenerskich')
     pyt1f = ordered_textarea_field(6, label=u'inne, jakie?')
-    pyt2 = textarea_field(u'W których tematach z obszaru bezpieczeństwa w sieci czujesz się najpewniej? '
-                          u'Dlaczego? (max. 500 znaków)')
-    pyt3 = textarea_field(u'Które z tematów znasz słabej lub których nie znasz zupełnie? (max. 500 znaków)')
-    pyt4 = textarea_field(u'Jakie są Twoje mocne strony jako osoby prowadzącej warsztaty? (max. 500 znaków)')
-    pyt5 = textarea_field(u'Nad jakimi elementami pracy trenerskiej chciałbyś/chciałabyś popracować? (max. 500 znaków)')
-    pyt6 = textarea_field(u'Co jest dla Ciebie najważniejsze w pracy z grupą? '
-                          u'Na co zwracasz uwagę w tym obszarze jako osoba prowadząca warsztaty? (max. 500 znaków)')
-    pyt7 = textarea_field(u'Opisz najtrudniejszą Twoim zdaniem sytuację, której doświadczyłeś/doświadczyłaś '
-                          u'podczas prowadzenia zajęć w grupie z młodzieżą, rodzicami lub nauczycielami? '
-                          u'(max. 500 znaków)')
-    pyt8 = forms.ChoiceField(
-        label=u'W jaki sposób poradzisz sobie z niespodziewaną sytuacją skrócenia czasu zajęć? '
-              u'Na który z poniższych punktów przeznaczysz w takiej sytuacji najmniej czasu?',
-        widget=forms.RadioSelect,
-        choices=simple_choices(
-            u'Przedstawienie się prowadzących i uczestników',
-            u'Poznanie oczekiwań i dostosowanie do nich programu zajęć',
-            u'Integracja',
-            u'Poprowadzenie kolejnych elementów zajęć (teoria-ćwiczenia)',
-            u'Podsumowanie - sprawdzenie efektów warsztatu',
-            u'Zaplanowanie dalszych prac',
-            u'Ewaluacja'))
-    pyt8a = textarea_field(label=u'Dlaczego? (max. 1000 znaków)', max_length=1000)
+    pyt2 = textarea_field(u'2. W których tematach z obszaru bezpieczeństwa w sieci czujesz się najpewniej? '
+                          u'Dlaczego?')
+    pyt3 = textarea_field(u'3. Które z tematów znasz słabej lub których nie znasz zupełnie?')
+    pyt4 = textarea_field(u'4. Jakie są Twoje mocne strony jako osoby prowadzącej warsztaty?')
+    pyt5 = textarea_field(u'5. Nad jakimi elementami pracy trenerskiej chciałbyś/chciałabyś popracować?')
+    pyt6 = textarea_field(u'6. Co jest dla Ciebie najważniejsze w pracy z grupą? '
+                          u'Na co zwracasz uwagę w tym obszarze jako osoba prowadząca warsztaty?')
+    pyt7 = textarea_field(
+        u'7. Jakie są Twoje największe obawy wobec realizacji szkoleń w placówkach oświatowych?')
+    pyt8a = ordered_textarea_field(
+        1, pre_label=u'8. Opisz szczegółowo doświadczenie z różnymi grupami:', label=u'rodzice')
+    pyt8b = ordered_textarea_field(2, label=u'nauczyciele')
+    pyt8c = ordered_textarea_field(3, label=u'młodzież ponadgimnazjalna')
+    pyt8d = ordered_textarea_field(4, label=u'młodzież gimnazjalna')
+    pyt8e = ordered_textarea_field(5, label=u'dzieci i młodzież szkół podstawowych')
     pyt9 = textarea_field(
     pyt9 = textarea_field(
-        label=u'Jeden z uczestników przeszkadza podczas warsztatów: '
-              u'głośno żartuje, nie wykonuje zleconych zadań. Co robisz? (max. 500 znaków)')
+        u'9. Z jakimi grupami wiekowymi najlepiej Ci się współpracuje? '
+        u'Umiejętności w zakresie pracy z którą grupą najbardziej chciałabyś/chciałbyś zdobyć/doskonalić?')
     pyt10 = textarea_field(
     pyt10 = textarea_field(
-        u'Z całej grupy tylko trzy osoby odpowiadają na każde zadane przez Ciebie pytanie. '
-        u'Co robisz? (max. 500 znaków)')
-    pyt11 = textarea_field(
-        u'Jakie są Twoje największe obawy wobec realizacji szkoleń w placówkach oświatowych? (max. 500 znaków)')
-    pyt12a = ordered_textarea_field(
-        1, pre_label=u'Opisz szczegółowo doświadczenie z różnymi grupami:', label=u'rodzice')
-    pyt12b = ordered_textarea_field(2, label=u'nauczyciele')
-    pyt12c = ordered_textarea_field(3, label=u'młodzież ponadgimnazjalna')
-    pyt12d = ordered_textarea_field(4, label=u'młodzież gimnazjalna')
-    pyt12e = ordered_textarea_field(5, label=u'dzieci i młodzież szkół podstawowych')
-    pyt13 = textarea_field(
-        u'Z jakimi grupami wiekowymi najlepiej Ci się współpracuje?'
-        u'Umiejętności w zakresie pracy z którą grupą najbardziej chciałabyś/chciałbyś zdobyć/doskonalić? '
-        u'(max. 500 znaków)')
-    pyt14 = textarea_field(
-        u'W jaki sposób na co dzień dbasz o swój rozwój jako trenera,'
-        u'osoby prowadzącej warsztaty czy inne formy szkoleniowe? (max. 500 znaków)')
+        u'10. W jaki sposób na co dzień dbasz o swój rozwój jako trenera/trenerki, '
+        u'osoby prowadzącej warsztaty czy inne formy szkoleniowe?')
+    pyt11 = textarea_field(u'11. Jakie są Twoje potrzeby żywieniowe?')
+    pyt12 = forms.ChoiceField(
+        label=u'12. Jak przyjedziesz do Wilgi?',
+        widget=forms.RadioSelect,
+        choices=simple_choices(
+            u'publiczna komunikacja do/z Warszawy (i wesoły bus do/z Wilgi)',
+            u'publiczna komunikacja do/z Wilgi',
+            u'samochód prywatny'))
+
+
+class SciezkiKopernikaForm(ContactForm):
+    form_tag = 'sciezki-kopernika'
+    form_title = u'Formularz zgłoszeniowy na warsztaty'
+    disabled = True
+
+    nazwisko = forms.CharField(label=u'Imię i nazwisko uczestnika/uczestniczki', max_length=128)
+    rok_urodzenia = forms.IntegerField(label=u'Rok urodzenia')
+    adres_dom = forms.CharField(label=u'Adres zamieszkania – ulica i numer', max_length=128)
+    adres_poczta = forms.CharField(label=u'Adres zamieszkania – kod pocztowy i miejscowość', max_length=128)
+    contact = forms.EmailField(label=u'Adres e-mail')
+    szkola = forms.CharField(label=u'Nazwa szkoły', max_length=128)
+    adres_szkola = forms.CharField(label=u'Adres szkoły – ulica i numer', max_length=128)
+    poczta_szkola = forms.CharField(label=u'Adres szkoły – kod pocztowy i miejscowość', max_length=128)
+    opiekun = forms.CharField(label=u'Imię i nazwisko rodzica/opiekuna', max_length=128)
+    adres_opiekun = forms.CharField(label=u'Adres zamieszkania rodzica/opiekuna – ulica i numer', max_length=128)
+    poczta_opiekun = forms.CharField(
+        label=u'Adres zamieszkania rodzica/opiekuna – kod pocztowy i miejscowość', max_length=128)
+    telefon_opiekun = forms.CharField(label=u'Numer telefonu rodzica/opiekuna', max_length=32)
+    email_opiekun = forms.EmailField(label=u'Adres e-mail rodzica/opiekuna', max_length=32)
+    specjalne_potrzeby = forms.ChoiceField(
+        label=u'Czy uczestnik/uczestniczka ma specjalne potrzeby wynikające z niepełnosprawności', required=True,
+        choices=[('tak', 'tak'), ('nie', 'nie')], widget=forms.RadioSelect)
+    zgoda_regulamin = forms.BooleanField(
+        label=mark_safe(
+            u'Oświadczam, że zapoznałem/am się z <a href="/media/chunks/attachment/Regulamin.pdf" target="_blank">'
+            u'Regulaminem udziału w projekcie</a> '
+            u'i spełniam kryteria kwalifikowalności do udziału w projekcie.'))
+
+
+class CollegiumMlodychForm(ContactForm):
+    form_tag = 'collegium-mlodych'
+    form_title = u'Formularz zgłoszeniowy na warsztaty'
+
+    nazwisko = forms.CharField(label=u'Imię i nazwisko uczestnika/uczestniczki', max_length=128)
+    pesel = forms.CharField(label=u'PESEL', max_length=11)
+    adres_dom = forms.CharField(label=u'Adres zamieszkania – ulica i numer', max_length=128)
+    adres_poczta = forms.CharField(label=u'Adres zamieszkania – kod pocztowy i miejscowość', max_length=128)
+    contact = forms.EmailField(label=u'Adres e-mail')
+    szkola = forms.CharField(label=u'Nazwa szkoły', max_length=128)
+    adres_szkola = forms.CharField(label=u'Adres szkoły – ulica i numer', max_length=128)
+    poczta_szkola = forms.CharField(label=u'Adres szkoły – kod pocztowy i miejscowość', max_length=128)
+    opiekun = forms.CharField(label=u'Imię i nazwisko rodzica/opiekuna prawnego', max_length=128)
+    telefon_opiekun = forms.CharField(label=u'Numer telefonu rodzica/opiekuna prawnego', max_length=32)
+    email_opiekun = forms.EmailField(label=u'Adres e-mail rodzica/opiekuna prawnego', max_length=32)
+    specjalne_potrzeby = forms.ChoiceField(
+        label=u'Czy uczestnik/uczestniczka ma specjalne potrzeby wynikające z niepełnosprawności',
+        choices=[('tak', 'tak'), ('nie', 'nie')], widget=forms.RadioSelect)
+    zgoda_regulamin = forms.BooleanField(
+        label=mark_safe(
+            u'Oświadczam, że zapoznałem/am się z <a href="/media/chunks/attachment/Regulamin.pdf" target="_blank">'
+            u'Regulaminem udziału w projekcie</a> '
+            u'i spełniam kryteria kwalifikowalności do udziału w projekcie.'))
+
+
+class SciezkiKopernikaTestForm(TestForm):
+    def __init__(self, *args, **kwargs):
+        super(SciezkiKopernikaTestForm, self).__init__(*args, **kwargs)
+        self.label_suffix = ''
+
+    result_page = True
+    form_tag = 'sciezki-kopernika-test'
+    form_title = u'Test wiedzy w zakresie edukacji medialnej i cyfrowej'
+    submit_label = u'Wyślij'
+
+    contact = forms.EmailField(label=u'Adres e-mail, na który przyślemy informację o wynikach')
+    head1 = HeaderField(
+        label=u'Test powstał w ramach projektu "Collegium Młodych - media i technologie" realizowany w ramach '
+              u'III Osi priorytetowej: Szkolnictwo wyższe dla gospodarki i rozwoju, Działanie 3.1 Kompetencje '
+              u'w szkolnictwie wyższym Programu Operacyjnego Wiedza Edukacja Rozwój, współfinansowanego przez '
+              u'Unię Europejską w ramach Europejskiego Funduszu Społecznego. Nr umowy POWR.03.01.00-00-C078/16-00.')
+
+    @classmethod
+    def results(cls, contact):
+        fields = cls().fields
+
+        def get_idx(choices, answer):
+            return dict((score, i) for i, (score, text) in enumerate(choices))[answer]
+
+        def question_data(i):
+            field = 'pyt%s' % i
+            choices = fields[field].choices
+            score = contact.body[field]
+            chosen_idx = get_idx(choices, score)
+            correct_idx = get_idx(choices, 2)
+            return {
+                'score': score,
+                'chosen_idx': chosen_idx,
+                'correct_idx': correct_idx,
+                'chosen': 'abc'[chosen_idx],
+                'correct': 'abc'[correct_idx],
+                'label': fields[field].label,
+                'comment': mark_safe(markdown.convert(cls.ANSWER_COMMENTS[i-1][chosen_idx])),
+                'answers': [(text, a_score == score, a_score == 2) for a_score, text in choices],
+            }
+        question_count = 20
+        questions = [question_data(i) for i in xrange(1, question_count + 1)]
+        points = sum(question['score'] for question in questions)
+        return {'questions': questions, 'points': points/2., 'total': question_count}
+
+
+class CollegiumMlodychTestForm(CollegiumTestForm):
+    def __init__(self, *args, **kwargs):
+        super(CollegiumMlodychTestForm, self).__init__(*args, **kwargs)
+        self.label_suffix = ''
+
+    result_page = True
+    form_tag = 'collegium-mlodych-test'
+    form_title = u'Test wiedzy w zakresie edukacji medialnej i cyfrowej'
+    submit_label = u'Wyślij'
+
+    contact = forms.EmailField(label=u'Adres e-mail, na który przyślemy informację o wynikach')
+
+    @classmethod
+    def results(cls, contact):
+        fields = cls().fields
+
+        def question_data(i):
+            field = 'pyt%s' % i
+            choices = fields[field].choices
+            answers = contact.body[field]
+            answer_data = []
+            for answer in answers:
+                idx = answer // 10
+                answer_data.append(
+                    {
+                        'score': answer % 10,
+                        'index': idx,
+                        'letter': 'abcdef'[idx],
+                        'comment': mark_safe(markdown.convert(cls.ANSWER_COMMENTS[i-1][idx])),
+                    })
+            correct = [answer // 10 for answer, text in choices if answer % 10 == 1]
+            return {
+                'answer_data': answer_data,
+                'correct': correct,
+                'correct_letters': ['abcdef'[idx] for idx in correct],
+                'label': fields[field].label,
+                'answers': [(text, a_score in answers, a_score % 10 == 1) for a_score, text in choices],
+                'full_match': set(answer['index'] for answer in answer_data) == set(correct)
+            }
+        question_count = 20
+        questions = [question_data(i) for i in xrange(1, question_count + 1)]
+        points = sum(1 for question in questions if question['full_match'])
+        return {'questions': questions, 'points': points, 'total': question_count}
+
+
+class ESEMWarszawaForm(ContactForm):
+    form_tag = 'emels-warszawa'
+    form_title = u"Ja i młodzież w cyfrowym świecie"
+    admin_list = ['imie', 'nazwisko', 'instytucja', 'contact']
+    submit_label = u'Wyślij'
+    mailing_field = 'zgoda_newsletter'
+    disabled = True
+    disabled_template = 'contact/disabled_contact_form.html'
+
+    imie = forms.CharField(label=u'Imię', max_length=128)
+    nazwisko = forms.CharField(label=u'Nazwisko', max_length=128)
+    contact = forms.EmailField(
+        label=u'Adres e-mail', max_length=128, help_text=u'Wyślemy na niego informacje organizacyjne.')
+    telefon = forms.CharField(
+        label=u'Numer telefonu', max_length=20,
+        help_text=u'Liczba miejsc na warsztatach jest ograniczona, będziemy telefonicznie potwierdzać '
+                  u'obecność, a w przypadku rezygnacji chcielibyśmy móc udostępnić miejsce kolejnej '
+                  u'zainteresowanej osobie.')
+    motywacja = forms.CharField(
+        label=u'W jaki sposób wykorzystasz wiedzę zdobytą na warsztatach?', max_length=1000,
+        widget=forms.Textarea)
+    instytucja = forms.CharField(label=u'Organizacja/instytucja', max_length=255)
+    zgoda_newsletter = forms.BooleanField(
+        required=False,
+        label=u'Chcę otrzymywać newsletter Edukacja medialna.')
+
+
+class ESEMGdanskForm(ESEMWarszawaForm):
+    form_tag = 'emels-gdansk'