hook mailchimp to contact forms
[edumed.git] / edumed / contact_forms.py
1 # -*- coding: utf-8 -*-
2 import re
3
4 from django import forms
5 from django.forms.formsets import BaseFormSet
6 from django.utils.safestring import mark_safe
7 from markdown2 import Markdown
8
9 from contact.fields import HeaderField
10 from contact.forms import ContactForm
11 from django.core.mail import send_mail
12 from django.core.exceptions import ValidationError
13 from django.core.validators import validate_email
14 from django.template.loader import render_to_string
15 from django.utils.translation import ugettext_lazy as _
16
17 from edumed.contact_forms_test import TestForm
18
19 LINK_PATTERNS = [
20     (re.compile(r'((http|ftp|https)://([\w_-]+(?:(?:\.[\w_-]+)+))([\w.,;@?^=%&:/~+#-]*[\w@?^=%&/~+#-])?)'),
21      r'\1')
22 ]
23
24 markdown = Markdown(extras=["link-patterns", 'code-friendly'], link_patterns=LINK_PATTERNS)
25
26 WOJEWODZTWA = (
27     u'dolnośląskie',
28     u'kujawsko-pomorskie',
29     u'lubelskie',
30     u'lubuskie',
31     u'łódzkie',
32     u'małopolskie',
33     u'mazowieckie',
34     u'opolskie',
35     u'podkarpackie',
36     u'podlaskie',
37     u'pomorskie',
38     u'śląskie',
39     u'świętokrzyskie',
40     u'warmińsko-mazurskie',
41     u'wielkopolskie',
42     u'zachodniopomorskie',
43 )
44
45 WOJEWODZTWO_CHOICES = [(u'', u'(wybierz)')] + [(w, w) for w in WOJEWODZTWA]
46
47
48 class RegistrationForm(ContactForm):
49     form_tag = 'sugestie'
50     form_title = u"Zgłoś sugestię"
51     admin_list = ['podpis', 'contact', 'temat']
52
53     contact = forms.EmailField(label=u'E-mail', max_length=128, required=False)
54     podpis = forms.CharField(label=u'Podpis', max_length=128, required=False)
55     temat = forms.CharField(label=u'Temat zgłoszenia', max_length=255)
56     tresc = forms.CharField(label=u'Treść', widget=forms.Textarea, max_length=1800)
57
58
59 class CooperateForm(ContactForm):
60     form_tag = 'wspolpraca'
61     form_title = u"Bądź z nami w kontakcie"
62     admin_list = ['podpis', 'contact']
63     mailing_field = 'zgoda_dane'
64
65     podpis = forms.CharField(label=u'Imię i nazwisko', max_length=128)
66     contact = forms.EmailField(label=u'E-mail', max_length=128)
67     instytucja = forms.CharField(
68         label=u'Instytucja (nazwa, adres)', widget=forms.Textarea, max_length=1000, required=False)
69     uwagi = forms.CharField(label=u'Uwagi', widget=forms.Textarea, max_length=1800, required=False)
70         
71     zajecia_przedszkole = forms.BooleanField(label=u'Prowadzę zajęcia z dziećmi w wieku przedszkolnym', required=False)
72     zajecia_sp13 = forms.BooleanField(label=u'Prowadzę zajęcia z dziećmi z SP kl. 1-3', required=False)
73     zajecia_sp46 = forms.BooleanField(label=u'Prowadzę zajęcia z dziećmi z SP kl. 4-6', required=False)
74     zajecia_gimnazjum = forms.BooleanField(label=u'Prowadzę zajęcia z młodzieżą w wieku gimnazjalnym', required=False)
75     zajecia_ponadgimnazjalne = forms.BooleanField(
76         label=u'Prowadzę zajęcia z młodzieżą ze szkół ponadgimnazjalnych', required=False)
77     zajecia_wyzsze = forms.BooleanField(label=u'Prowadzę zajęcia w szkole wyższej', required=False)
78     zajecia_dorosli = forms.BooleanField(label=u'Prowadzę zajęcia dla dorosłych', required=False)
79     zajecia_seniorzy = forms.BooleanField(label=u'Prowadzę zajęcia dla seniorów', required=False)
80     zgoda_dane = forms.BooleanField(
81         label=u'Oświadczam, że wyrażam zgodę na przetwarzanie moich danych osobowych zawartych '
82               u'w niniejszym formularzu zgłoszeniowym przez Fundację Nowoczesna Polska '
83               u'(administratora danych) z siedzibą w Warszawie (00-514) przy ul. Marszałkowskiej 84/92 '
84               u'lok. 125 w celu otrzymywania newslettera Edukacja medialna. Jednocześnie oświadczam, '
85               u'że zostałam/em poinformowana/y o tym, że mam prawo wglądu w treść swoich danych '
86               u'i możliwość ich poprawiania oraz że ich podanie jest dobrowolne, ale niezbędne '
87               u'do dokonania zgłoszenia.')
88
89
90 class ContestForm(ContactForm):
91     form_tag = 'konkurs'
92     form_title = u"Zgłoś się do konkursu"
93     admin_list = ['nazwisko', 'instytucja', 'tytul']
94     mailing_field = 'zgoda_informacje'
95
96     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
97     contact = forms.EmailField(label=u'Adres e-mail', max_length=128)
98     instytucja = forms.CharField(label=u'Instytucja (nazwa, adres)', widget=forms.Textarea, max_length=1000)
99     tytul = forms.CharField(
100         label=u'Tytuł przeprowadzonej lekcji',
101         help_text=u'proszę wymienić wszystkie, jeśli zostały przeprowadzone więcej niż jedne zajęcia',
102         widget=forms.Textarea, max_length=1000)
103     uczestnicy = forms.CharField(label=u'Liczba uczestników', max_length=64)
104     trudnosci = forms.CharField(
105         label=u'Czy w trakcie zajęć pojawiły się jakieś trudności? Jeśli tak, to jakie?',
106         widget=forms.Textarea, max_length=2000)
107     pomocne = forms.CharField(
108         label=u'Co w materiałach okazało się najbardziej pomocne w przygotowaniu i prowadzeniu lekcji?',
109         widget=forms.Textarea, max_length=2000)
110     nieprzydatne = forms.CharField(
111         label=u'Co w materiałach okazało się nieprzydatne w przygotowaniu i prowadzeniu lekcji?',
112         widget=forms.Textarea, max_length=2000)
113     poprawic = forms.CharField(
114         label=u'Jak możemy poprawić serwis edukacjamedialna.edu.pl?',
115         widget=forms.Textarea, max_length=2000, required=False)
116     inne = forms.CharField(label=u'Inne uwagi i komentarze', widget=forms.Textarea, max_length=2000, required=False)
117     zgoda_regulamin = forms.BooleanField(
118         label=u'Znam i akceptuję regulamin konkursu Medialog.',
119         help_text=u'Zobacz <a href="/media/chunks/attachment/Regulamin_konkursu_MediaLog_1.pdf">'
120                   u'regulamin konkursu MediaLog</a>.')
121     zgoda_informacje = forms.BooleanField(
122         label=u'Wyrażam zgodę na otrzymywanie informacji od Fundacji Nowoczesna Polska związanych z edukacją medialną.',
123         required=False
124     )
125
126
127 class UdzialForm(ContactForm):
128     form_tag = 'udzial'
129     form_title = u"Udział"
130     admin_list = ['nazwisko', 'miejscowosc', 'instytucja']
131
132     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
133     miejscowosc = forms.CharField(label=u'Miejscowość', max_length=128)
134     instytucja = forms.CharField(label=u'Nazwa organizacji/instytucji', max_length=128)
135     contact = forms.EmailField(label=u'Adres e-mail', max_length=128)
136     telefon = forms.CharField(label=u'Telefon', max_length=32)
137     uczestnicy = forms.IntegerField(label=u'Przewidywana liczba uczestników zajęć')
138
139
140 class WTEMStudentForm(forms.Form):
141     first_name = forms.CharField(label=u'Imię', max_length=128)
142     last_name = forms.CharField(label=u'Nazwisko', max_length=128)
143     email = forms.EmailField(label=u'Adres e-mail', max_length=128)
144     form_tag = "student"
145
146
147 class NonEmptyBaseFormSet(BaseFormSet):
148     """
149     Won't allow formset_factory to be submitted with no forms
150     """
151     def clean(self):
152         for form in self.forms:
153             if form.cleaned_data:
154                 return
155         forms.ValidationError(u"Proszę podać dane przynajmniej jednej osoby.")
156
157
158 class WTEMForm(ContactForm):
159     disabled = True
160     disabled_template = 'wtem/disabled_contact_form.html'
161     form_tag = "wtem"
162     old_form_tags = ["wtem2013", "wtem2014"]
163     form_title = u"WTEM - rejestracja uczestników"
164     submit_label = u"Wyślij zgłoszenie"
165     admin_list = ['imie', 'nazwisko', 'institution']
166     form_formsets = {
167         'student': forms.formsets.formset_factory(
168             WTEMStudentForm, formset=NonEmptyBaseFormSet, max_num=5, validate_max=True, extra=5),
169     }
170     mailing_field = 'zgoda_informacje'
171
172     contact = forms.EmailField(label=u'Adres e-mail opiekuna/opiekunki', max_length=128)
173     imie = forms.CharField(label=u'Imię', max_length=128)
174     nazwisko = forms.CharField(label=u'Nazwisko', max_length=128)
175     function = forms.CharField(label=u'Pełniona funkcja', max_length=255)
176     institution = forms.CharField(label=u'Nazwa instytucji', max_length=255)
177     institution_address = forms.CharField(label=u'Adres instytucji', widget=forms.Textarea, max_length=1000)
178     institution_email = forms.EmailField(label=u'Adres e-mail instytucji', max_length=128)
179     institution_phone = forms.CharField(label=u'Telefon do instytucji', max_length=32)
180     institution_www = forms.URLField(label=u'Strona WWW instytucji', max_length=255, required=False)
181
182     zgoda_regulamin = forms.BooleanField(
183         label=u'Znam i akceptuję regulamin Wielkiego Turnieju Edukacji Medialnej.',
184         help_text=u'Zobacz <a href="/media/chunks/attachment/regulamin_III_edycja.pdf">'
185                   u'regulamin Wielkiego Turnieju Edukacji Medialnej</a>.'
186     )
187     zgoda_dane = forms.BooleanField(
188         label=u'Wyrażam zgodę na przetwarzanie moich danych osobowych oraz danych osobowych moich podopiecznych.',
189         # help_text=u'Zobacz <a href="/media/chunks/attachment/Oswiadczenie_o_danych_osobowych.pdf">'
190         # 'pełną treść oświadczenia</a>.'
191     )
192
193     potw_uczniowie = forms.BooleanField(
194         label=u'Potwierdzam, że zgłoszeni Uczestnicy/Uczestniczki w chwili rejestracji są '
195               u'uczniami/uczennicami szkoły ponadgimnazjalnej.',
196     )
197     zgoda_informacje = forms.BooleanField(
198         label=u'Wyrażam zgodę na otrzymywanie informacji od Fundacji Nowoczesna Polska '
199               u'związanych z edukacją medialną.',
200         required=False
201     )
202
203     extract_types = (dict(slug='extended', label=_('extended')),)
204
205     @staticmethod
206     def get_extract_fields(contact, extract_type_slug):
207         fields = contact.body.keys()
208         fields.pop(fields.index('student'))
209         fields.extend(['contact', 'student_first_name', 'student_last_name', 'student_email'])
210         return fields
211
212     @staticmethod
213     def get_extract_records(keys, contact, extract_type_slug):
214         toret = [dict()]
215         for field_name in keys:
216             if field_name.startswith('student_'):
217                 continue
218             if field_name == 'contact':
219                 val = contact.contact
220             else:
221                 val = contact.body[field_name]
222             toret[0][field_name] = val
223         
224         current = toret[0]
225         for student in contact.body['student']:
226             for attr in ('first_name', 'last_name', 'email'):
227                 current['student_' + attr] = student[attr]
228             if current not in toret:
229                 toret.append(current)
230             current = dict()
231         return toret
232
233     def save(self, request, formsets=None):
234         contact = super(WTEMForm, self).save(request, formsets)
235
236         mail_subject = render_to_string('contact/wtem/student_mail_subject.html').strip()
237         mail_body = render_to_string('contact/wtem/student_mail_body.html')
238         for formset in formsets or []:
239             for f in formset.forms:
240                 email = f.cleaned_data.get('email', None)
241                 try:
242                     validate_email(email)
243                 except ValidationError:
244                     pass
245                 else:
246                     send_mail(mail_subject, mail_body, 'edukacjamedialna@nowoczesnapolska.org.pl', [email],
247                               fail_silently=True)
248
249         return contact
250
251
252 class CommissionForm(forms.Form):
253     name = forms.CharField(label=u'Imię i nazwisko Członka Komisji', max_length=128)
254     form_tag = "commission"
255
256
257 class OlimpiadaForm(ContactForm):
258     disabled = True
259     disabled_template = 'wtem/disabled_contact_form.html'
260     form_tag = "olimpiada"
261     old_form_tags = ["olimpiada-2016"]
262     form_title = u"Olimpiada Cyfrowa - Elektroniczny System Zgłoszeń"
263     submit_label = u"Wyślij zgłoszenie"
264     admin_list = ['nazwisko', 'school']
265     form_formsets = {
266         'student': forms.formsets.formset_factory(WTEMStudentForm, formset=NonEmptyBaseFormSet),
267         'commission': forms.formsets.formset_factory(CommissionForm, formset=BaseFormSet),
268     }
269
270     contact = forms.EmailField(label=u'Adres e-mail Przewodniczącego/Przewodniczącej', max_length=128)
271     przewodniczacy = forms.CharField(label=u'Imię i nazwisko Przewodniczącego/Przewodniczącej', max_length=128)
272     school = forms.CharField(label=u'Nazwa szkoły', max_length=255)
273     school_address = forms.CharField(label=u'Adres szkoły', widget=forms.Textarea, max_length=1000)
274     school_email = forms.EmailField(label=u'Adres e-mail szkoły', max_length=128)
275     school_phone = forms.CharField(label=u'Numer telefonu szkoły', max_length=32)
276     school_www = forms.URLField(label=u'Strona WWW szkoły', max_length=255, required=False)
277
278     zgoda_regulamin = forms.BooleanField(
279         label=u'Znam i akceptuję Regulamin Olimpiady Cyfrowej.',
280         help_text=u'Zobacz <a href="https://olimpiadacyfrowa.pl/regulamin/" target="_blank">'
281                   u'regulamin Olimpiady Cyfrowej</a>.'
282     )
283     zgoda_dane = forms.BooleanField(
284         label=u'Oświadczam, że wyrażam zgodę na przetwarzanie danych osobowych zawartych w niniejszym formularzu '
285               u'zgłoszeniowym przez Fundację Nowoczesna Polska (administratora danych) z siedzibą w Warszawie (00-514) '
286               u'przy ul. Marszałkowskiej 84/92 lok. 125 na potrzeby organizacji Olimpiady Cyfrowej. Jednocześnie '
287               u'oświadczam, że zostałam/em poinformowana/y o tym, że mam prawo wglądu w treść swoich danych '
288               u'i możliwość ich poprawiania oraz że ich podanie jest dobrowolne, ale niezbędne do dokonania '
289               u'zgłoszenia.')
290
291     extract_types = (dict(slug='extended', label=_('extended')),)
292
293     @staticmethod
294     def get_extract_fields(contact, extract_type_slug):
295         fields = contact.body.keys()
296         if 'student' in fields:
297             fields.remove('student')
298         fields.extend(['contact', 'student_first_name', 'student_last_name', 'student_email'])
299         return fields
300
301     @staticmethod
302     def get_extract_records(keys, contact, extract_type_slug):
303         toret = [{}]
304         for field_name in keys:
305             if field_name.startswith('student_'):
306                 continue
307             if field_name == 'contact':
308                 val = contact.contact
309             else:
310                 val = contact.body[field_name]
311             toret[0][field_name] = val
312
313         current = toret[0]
314         if 'student' in contact.body:
315             for student in contact.body['student']:
316                 for attr in ('first_name', 'last_name', 'email'):
317                     current['student_' + attr] = student[attr]
318                 if current not in toret:
319                     toret.append(current)
320                 current = {}
321         return toret
322
323     def save(self, request, formsets=None):
324         contact = super(OlimpiadaForm, self).save(request, formsets)
325
326         mail_subject = render_to_string('contact/olimpiada/student_mail_subject.html').strip()
327         mail_body = render_to_string('contact/olimpiada/student_mail_body.html')
328         for formset in formsets or []:
329             if formset.prefix == 'student':
330                 for f in formset.forms:
331                     email = f.cleaned_data.get('email', None)
332                     try:
333                         validate_email(email)
334                     except ValidationError:
335                         pass
336                     else:
337                         send_mail(mail_subject, mail_body, 'edukacjamedialna@nowoczesnapolska.org.pl', [email],
338                                   fail_silently=True)
339
340         return contact
341
342
343 class MILForm(ContactForm):
344     form_tag = 'mil'
345     form_title = _('Share your thoughts on the "Media and information literacy competencies catalogue"')
346     submit_label = _('Submit')
347     base_template = 'base_mil.html'
348     site_name = site_domain = 'katalog.nowoczesnapolska.org.pl'
349
350     name = forms.CharField(label=_('Name and Surname'), max_length=255)
351     contact = forms.EmailField(label=_('E-mail'), max_length=255)
352
353     institution = forms.CharField(label=_('Institution'), widget=forms.Textarea, max_length=8192)
354
355     question_stages = forms.CharField(
356         label=_('What do you think about the proposed educational stages classification?'),
357         widget=forms.Textarea,
358         max_length=255,
359         required=False)
360
361     question_fields = forms.CharField(
362         label=_('What do you think about the proposed thematic fields?'),
363         widget=forms.Textarea,
364         max_length=255,
365         required=False)
366
367     question_left_out = forms.CharField(
368         label=_('What important areas of media and information literacy have been left out?'),
369         widget=forms.Textarea,
370         max_length=255,
371         required=False)
372
373     other = forms.CharField(
374         label=_('Other suggestions and comments'),
375         widget=forms.Textarea,
376         max_length=255,
377         required=False)
378
379
380 class TEMForm(ContactForm):
381     form_tag = 'tem'
382     form_title = u"TEM - szkolenie dla trenerów edukacji medialnej"
383     admin_list = ['imie', 'nazwisko', 'instytucja', 'contact']
384     mailing_field = 'zgoda_informacje'
385
386     imie = forms.CharField(label=u'Imię', max_length=128)
387     nazwisko = forms.CharField(label=u'Nazwisko', max_length=128)
388     contact = forms.EmailField(label=u'E-mail', max_length=128)
389     telefon = forms.CharField(label=u'Tel. kontaktowy', max_length=128)
390     instytucja = forms.CharField(label=u'Instytucja', max_length=256)
391     adres = forms.CharField(label=u'Adres', widget=forms.Textarea, max_length=1000)
392     stanowisko = forms.CharField(label=u'Stanowisko', max_length=256)
393     doswiadczenie = forms.CharField(
394         label=u'Jakie jest Pani/Pana doświadczenie w zakresie edukacji medialnej?',
395         widget=forms.Textarea, max_length=500, help_text=u'(max 500 znaków)')
396     dlaczego = forms.CharField(
397         label=u'Dlaczego chce Pani/Pan wziąć udział w szkoleniu?',
398         widget=forms.Textarea, max_length=500, help_text=u'(max 500 znaków)')
399     jak_wykorzystac = forms.CharField(
400         label=u'Jak zamierza Pan/Pani wykorzystać wiedzę zdobytą w czasie szkolenia?',
401         widget=forms.Textarea, max_length=500, help_text=u'(max 500 znaków)')
402
403     zajecia = forms.BooleanField(
404         label=u'W okresie wrzesień-październik 2015 r. przeprowadzę min. 2 godziny zajęć edukacji medialnej '
405               u'z wybraną grupą dzieci lub młodzieży.', required=True)
406     zgoda_informacje = forms.BooleanField(
407         label=u'Wyrażam zgodę na otrzymywanie informacji od Fundacji Nowoczesna Polska '
408               u'związanych z edukacją medialną.', required=False)
409
410
411 class SuperwizjaForm(ContactForm):
412     form_tag = 'superwizja'
413     form_title = u"Informacje o zajęciach"
414     admin_list = ['nazwisko', 'contact', 'skype', 'temat']
415     submit_label = u'Wyślij'
416
417     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=1024)
418     contact = forms.CharField(label=u'E-mail kontaktowy', required=False)
419     skype = forms.CharField(label=u'Nazwa użytkownika Skype', max_length=255)
420     temat = forms.CharField(label=u'Temat zajęć', max_length=1024)
421     termin = forms.CharField(label=u'Termin zajęć', max_length=1024)
422     czas_trwania = forms.CharField(label=u'Czas trwania zajęć', max_length=1024)
423     miejsce = forms.CharField(label=u'Miejsce prowadzenia zajęć', max_length=1024)
424     rodzaj = forms.ChoiceField(
425         label=u'Rodzaj zajęć', widget=forms.RadioSelect,
426         choices=[('jednorazowe', 'jednorazowe'), ('w ramach cyklu', 'w ramach cyklu')])
427     cykl = forms.CharField(label=u'Jeśli w ramach cyklu, to podaj jego temat i czas trwania', required=False)
428     sposob = forms.ChoiceField(
429         label=u'Sposób prowadzenia zajęć', widget=forms.RadioSelect,
430         choices=[('samodzielnie', 'samodzielnie'), (u'z drugą osobą', 'z drugą osobą')])
431     wrazenia = forms.CharField(
432         label=u'Opisz Twoje ogólne wrażenia po warsztacie.', widget=forms.Textarea, max_length=4096)
433     opiekun = forms.CharField(
434         label=u'Czy opiekun grupy był obecny podczas zajęć? Jeśli tak, opisz krótko jego rolę.',
435         widget=forms.Textarea, max_length=4096)
436     grupa = forms.CharField(
437         label=u'Opisz krótko grupę uczestników zajęć (wiek, liczba osób, czy to pierwszy kontakt z grupą).',
438         widget=forms.Textarea, max_length=4096)
439     cel = forms.CharField(
440         label=u'Jaki był założony cel zajęć? Dlaczego wybrałaś/eś taki cel?', widget=forms.Textarea, max_length=4096)
441     ewaluacja = forms.CharField(
442         label=u'W jaki sposób sprawdziłeś/aś, czy cel zajęć został zrealizowany? Opisz krótko efekty zajęć.',
443         widget=forms.Textarea, max_length=4096)
444     # header
445     przygotowania = forms.CharField(
446         label=u'Opisz w punktach proces przygotowania się do zajęć.', widget=forms.Textarea, max_length=4096)
447     przygotowania_trudnosci = forms.CharField(
448         label=u'Co na etapie przygotowań sprawiło Ci największą trudność?', widget=forms.Textarea, max_length=4096)
449     przygotowania_pomoc = forms.CharField(
450         label=u'Co było pomocne w przygotowaniu zajęć? '
451               u'(Czy korzystałaś/eś z materiałów z serwisu edukacjamedialna.edu.pl? Jeśli tak, to jakich?)',
452         widget=forms.Textarea, max_length=4096)
453     narzedzia = forms.CharField(
454         label=u'Jakie narzędzie/a planowałaś/eś wykorzystać, a jakie wykorzystałaś/eś?',
455         widget=forms.Textarea, max_length=4096)
456     struktura = forms.CharField(
457         label=u'Opisz w punktach strukturę zajęć. '
458               u'Zaznacz ile czasu planowałaś/eś na każdą część, a ile czasu faktycznie Ci to zajęło.',
459         widget=forms.Textarea, max_length=4096)
460     prowadzenie_trudnosci = forms.CharField(
461         label=u'Co sprawiało Ci trudność w prowadzeniu zajęć?', widget=forms.Textarea, max_length=4096)
462     prowadzenie_pomoc = forms.CharField(
463         label=u'Co było pomocne w prowadzeniu zajęć?', widget=forms.Textarea, max_length=4096)
464     kontrakt = forms.CharField(
465         label=u'W jakiej formie został zawarty kontrakt z uczestnikami? Jakie zasady zostały przyjęte? '
466               u'Czy w trakcie zajęć Ty bądź uczestnicy odwoływaliście się do kontraktu?',
467         widget=forms.Textarea, max_length=4096)
468     trudne_sytuacje = forms.CharField(
469         label=u'Czy podczas zajęć miały miejsce tzw. „trudne sytuacje”. '
470               u'Jak na nie zareagowałaś/eś? Czy potrzebowałabyś/łbyś czegoś w związku z nimi?',
471         widget=forms.Textarea, max_length=4096)
472     informacje_zwrotne = forms.CharField(
473         label=u'Czy zbierałaś/eś informacje zwrotne od uczestników? Jeśli tak, na co zwrócili uwagę? '
474               u'W jaki sposób zbierałaś/eś informacje zwrotne?', widget=forms.Textarea, max_length=4096)
475
476     mocne_strony = forms.CharField(
477         label=u'Opisz w punktach mocne strony przeprowadzonych zajęć.', widget=forms.Textarea, max_length=4096)
478     zmiany = forms.CharField(
479         label=u'Opisz w punktach, co byś zmienił(a) na przyszłość.', widget=forms.Textarea, max_length=4096)
480     potrzeby = forms.CharField(
481         label=u'Czy potrzebowałbyś/łbyś czegoś przed następnymi zajęciami?', widget=forms.Textarea, max_length=4096)
482     uwagi = forms.CharField(label=u'Inne uwagi', widget=forms.Textarea, max_length=4096, required=False)
483
484
485 def textarea_field(label, max_length=500):
486     return forms.CharField(
487         label=label, widget=forms.Textarea, max_length=max_length, help_text=u'(do %s znaków)' % max_length)
488
489
490 class CybernauciForm(ContactForm):
491     disabled = True
492     disabled_template = 'contact/disabled_contact_form.html'
493     form_tag = 'trenerzy-cybernauci2017'
494     old_form_tags = ['trenerzy-cybernauci']
495     form_title = u"Cybernauci – szkolenie dla trenerów"
496     admin_list = ['nazwisko', 'instytucja', 'contact']
497     submit_label = u'Wyślij'
498     mailing_field = 'zgoda_newsletter'
499
500     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=1024)
501     adres = forms.CharField(label=u'Adres zamieszkania')
502     wojewodztwo = forms.ChoiceField(label=u'Województwo', choices=WOJEWODZTWO_CHOICES)
503     contact = forms.CharField(label=u'Adres e-mail')
504     telefon = forms.CharField(label=u'Telefon kontaktowy', max_length=32)
505     dlaczego = textarea_field(
506         label=u'Proszę opisać, dlaczego chce Pan/Pani zostać Emisariuszem Bezpiecznego Internetu.')
507     grupy = forms.MultipleChoiceField(
508         label=u'Proszę wskazać, dla których grup realizował Pan/realizowała Pani zajęcia warsztatowe',
509         widget=forms.CheckboxSelectMultiple,
510         choices=[
511             ('Uczniowie klas 1-3', 'Uczniowie klas 1-3'),
512             ('Uczniowie klas 4-6', 'Uczniowie klas 4-6'),
513             ('Uczniowie szkół gimnazjalnych', 'Uczniowie szkół gimnazjalnych'),
514             ('Uczniowie szkół ponadgimnazjalnych', 'Uczniowie szkół ponadgimnazjalnych'),
515             ('Nauczyciele', 'Nauczyciele'),
516             ('Rodzice', 'Rodzice'),
517         ])
518     doswiadczenie_grupy = textarea_field(
519         label=u'Proszę opisać swoje doświadczenie w pracy warsztatowej z grupami docelowymi Projektu '
520               u'(dziećmi, młodzieżą, osobami dorosłymi: nauczycielami, rodzicami).',
521         max_length=750)
522     doswiadczenie_edumed = textarea_field(
523         label=u'Jakie jest Pana/Pani doświadczenie w zakresie edukacji medialnej, '
524               u'zwłaszcza w zakresie bezpieczeństwa w Internecie i korzystania z TIK? '
525               u'Skąd czerpie Pan/Pani wiedzę w tym zakresie? W jakich projektach brał '
526               u'Pan/brała Pani udział dotychczas?',
527         max_length=750)
528     szkolenia = textarea_field(
529         label=u'Proszę wymienić studia, szkolenia albo kursy (maks. 5 najważniejszych) '
530               u'powiązane z tematyką Projektu, w których Pan/Pani uczestniczył/ła, '
531               u'w tym dane na temat instytucji czy osoby prowadzącej (z JEDNOZDANIOWYM '
532               u'omówieniem i terminami, w których się odbyły).')
533     realizacje = textarea_field(
534         label=u'Proszę opisać swoje doświadczenie w zakresie realizacji działań w lokalnym środowisku '
535               u'szkolnym (np. na terenie gminy/powiatu/województwa).')
536     cel = textarea_field(
537         label=u'Proszę opisać, jaką wiedzę i umiejętności chce Pan/Pani zdobyć '
538               u'lub doskonalić poprzez uczestnictwo w Szkoleniu trenerskim.')
539     skad = forms.CharField(label=u'Skąd dowiedział/dowiedziała się Pan/Pani o projekcie „Cybernauci”?')
540     zgoda_regulamin = forms.BooleanField(
541         label=u'Oświadczam, że zapoznałem/zapoznałam się z Regulaminem Rekrutacji '
542               u'i Uczestnictwa w Projekcie „Cybernauci – kompleksowy projekt '
543               u'kształtowania bezpiecznych zachowań w sieci” i akceptuję jego warunki.',
544         help_text=u'Zobacz <a href="https://cybernauci.edu.pl/wp-content/uploads/2017/04/'
545                   u'regulamin_Cybernauci_szkolenie_trenerskie_2017.pdf">regulamin</a>.')
546     zgoda_dane = forms.BooleanField(
547         label=u'Wyrażam zgodę na przetwarzanie moich danych osobowych zawartych '
548               u'w niniejszym dokumencie dla potrzeb niezbędnych do realizacji Projektu '
549               u'„Cybernauci – kompleksowy projekt kształtowania bezpiecznych zachowań '
550               u'w sieci”  zgodnie z ustawą z dnia 29.08.1997 roku o Ochronie Danych '
551               u'Osobowych (Dz. U. z 2002 r. Nr 101, poz. 926 z późniejszymi zmianami).')
552     zgoda_niekaralnosc = forms.BooleanField(
553         label=u'W przypadku zakwalifikowania się na kurs zobowiązuję się '
554               u'do dostarczenia świadectwa o niekaralności – najpóźniej w dniu rozpoczęcia Szkolenia.')
555     zgoda_newsletter = forms.BooleanField(
556         required=False,
557         label=u'Chcę otrzymywać newsletter Edukacja Medialna.')
558     cv = forms.FileField(
559         label=u'Wgraj plik CV.',
560         help_text=u'Prosimy o nazwanie pliku swoim imieniem i nazwiskiem. Preferowany format: PDF.')
561
562
563 class WLEMForm(ContactForm):
564     disabled = True
565     form_tag = 'wlem'
566     form_title = u"WLEM - szkolenie dla warszawskich liderów edukacji medialnej"
567     admin_list = ['nazwisko', 'instytucja', 'contact']
568     submit_label = u'Wyślij'
569     mailing_field = 'zgoda_newsletter'
570
571     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
572     contact = forms.CharField(label=u'Adres e-mail')
573     telefon = forms.CharField(label=u'Tel. kontaktowy', max_length=32)
574     instytucja = forms.CharField(label=u'Instytucja', max_length=128)
575     instytucja_adres = forms.CharField(label=u'Adres (instytucji)', max_length=1024)
576     stanowisko = forms.CharField(label=u'Stanowisko', max_length=256)
577     doswiadczenie = forms.CharField(
578         label=u'Jakie jest Pani/Pana doświadczenie w zakresie edukacji medialnej?',
579         widget=forms.Textarea, max_length=4096)
580     dlaczego = forms.CharField(
581         label=u'Dlaczego chce Pani/Pan wziąć udział w szkoleniu?',
582         widget=forms.Textarea, max_length=4096)
583     cel = forms.CharField(
584         label=u'Jaką wiedzę i umiejętności chce Pan/Pani zdobyć lub doskonalić poprzez uczestnictwo w szkoleniu?',
585         widget=forms.Textarea, max_length=4096)
586     jak_wykorzystac = forms.CharField(
587         label=u'Jak zamierza Pan/Pani wykorzystać wiedzę i umiejętności zdobyte w czasie szkolenia?',
588         widget=forms.Textarea, max_length=4096)
589     zgoda_zajecia = forms.BooleanField(
590         label=u'W okresie lipiec-październik 2016 r. przeprowadzę min. 2 godziny zajęć '
591               u'edukacji medialnej z grupą warszawiaków.')
592     zgoda_dane = forms.BooleanField(
593         label=u'Wyrażam zgodę na przetwarzanie moich danych osobowych zawartych '
594               u'w niniejszym dokumencie dla potrzeb niezbędnych do realizacji Projektu '
595               u'„Warszawscy Liderzy Edukacji Medialnej” zgodnie z ustawą z dnia 29.08.1997 '
596               u'roku o Ochronie Danych Osobowych (Dz. U. z 2002 r. Nr 101, poz. 926 '
597               u'z późniejszymi zmianami).')
598     zgoda_newsletter = forms.BooleanField(
599         required=False,
600         label=u'Wyrażam zgodę na otrzymywanie informacji od Fundacji Nowoczesna Polska '
601               u'związanych z edukacją medialną.')
602
603
604 def ordered_textarea_field(start, pre_label=u'', label=u'', max_length=500):
605     return textarea_field(
606         mark_safe(u'%s<ol type="a" start="%s"><li>%s</li></ol>' % (pre_label, start, label)),
607         max_length=max_length)
608
609
610 def simple_choices(*choices):
611     return tuple((choice, choice) for choice in choices)
612
613
614 class CybernauciAnkietaForm(ContactForm):
615     def __init__(self, *args, **kwargs):
616         super(CybernauciAnkietaForm, self).__init__(*args, **kwargs)
617         self.label_suffix = ''
618
619     form_tag = 'cybernauci-ankieta-trenera-2017'
620     old_form_tags = ['cybernauci-ankieta-trenera']
621     form_title = u"Cybernauci – ankieta trenerska"
622     nazwisko = forms.CharField(label=u'Imię i nazwisko', max_length=128)
623     contact = forms.CharField(label=u'Adres e-mail')
624     pyt1a = ordered_textarea_field(
625         1, pre_label=u'1. W kontekście planowanego szkolenia jakie są Twoje oczekiwania w zakresie:',
626         label=u'przekazywanej wiedzy')
627     pyt1b = ordered_textarea_field(2, label=u'tematyki szkoleń z bezpieczeństwa w sieci')
628     pyt1c = ordered_textarea_field(3, label=u'materiałów dydaktycznych')
629     pyt1d = ordered_textarea_field(4, label=u'organizacji  i prowadzenia szkoleń w projekcie')
630     pyt1e = ordered_textarea_field(5, label=u'umiejętności trenerskich')
631     pyt1f = ordered_textarea_field(6, label=u'inne, jakie?')
632     pyt2 = textarea_field(u'2. W których tematach z obszaru bezpieczeństwa w sieci czujesz się najpewniej? '
633                           u'Dlaczego?')
634     pyt3 = textarea_field(u'3. Które z tematów znasz słabej lub których nie znasz zupełnie?')
635     pyt4 = textarea_field(u'4. Jakie są Twoje mocne strony jako osoby prowadzącej warsztaty?')
636     pyt5 = textarea_field(u'5. Nad jakimi elementami pracy trenerskiej chciałbyś/chciałabyś popracować?')
637     pyt6 = textarea_field(u'6. Co jest dla Ciebie najważniejsze w pracy z grupą? '
638                           u'Na co zwracasz uwagę w tym obszarze jako osoba prowadząca warsztaty?')
639     pyt7 = textarea_field(
640         u'7. Jakie są Twoje największe obawy wobec realizacji szkoleń w placówkach oświatowych?')
641     pyt8a = ordered_textarea_field(
642         1, pre_label=u'8. Opisz szczegółowo doświadczenie z różnymi grupami:', label=u'rodzice')
643     pyt8b = ordered_textarea_field(2, label=u'nauczyciele')
644     pyt8c = ordered_textarea_field(3, label=u'młodzież ponadgimnazjalna')
645     pyt8d = ordered_textarea_field(4, label=u'młodzież gimnazjalna')
646     pyt8e = ordered_textarea_field(5, label=u'dzieci i młodzież szkół podstawowych')
647     pyt9 = textarea_field(
648         u'9. Z jakimi grupami wiekowymi najlepiej Ci się współpracuje? '
649         u'Umiejętności w zakresie pracy z którą grupą najbardziej chciałabyś/chciałbyś zdobyć/doskonalić?')
650     pyt10 = textarea_field(
651         u'10. W jaki sposób na co dzień dbasz o swój rozwój jako trenera/trenerki, '
652         u'osoby prowadzącej warsztaty czy inne formy szkoleniowe?')
653     pyt11 = textarea_field(u'11. Jakie są Twoje potrzeby żywieniowe?')
654     pyt12 = forms.ChoiceField(
655         label=u'12. Jak przyjedziesz do Wilgi?',
656         widget=forms.RadioSelect,
657         choices=simple_choices(
658             u'publiczna komunikacja do/z Warszawy (i wesoły bus do/z Wilgi)',
659             u'publiczna komunikacja do/z Wilgi',
660             u'samochód prywatny'))
661
662
663 class SciezkiKopernikaForm(ContactForm):
664     form_tag = 'sciezki-kopernika'
665     form_title = u'Formularz zgłoszeniowy na warsztaty'
666     disabled = True
667
668     nazwisko = forms.CharField(label=u'Imię i nazwisko uczestnika/uczestniczki', max_length=128)
669     rok_urodzenia = forms.IntegerField(label=u'Rok urodzenia')
670     adres_dom = forms.CharField(label=u'Adres zamieszkania – ulica i numer', max_length=128)
671     adres_poczta = forms.CharField(label=u'Adres zamieszkania – kod pocztowy i miejscowość', max_length=128)
672     contact = forms.EmailField(label=u'Adres e-mail')
673     szkola = forms.CharField(label=u'Nazwa szkoły', max_length=128)
674     adres_szkola = forms.CharField(label=u'Adres szkoły – ulica i numer', max_length=128)
675     poczta_szkola = forms.CharField(label=u'Adres szkoły – kod pocztowy i miejscowość', max_length=128)
676     opiekun = forms.CharField(label=u'Imię i nazwisko rodzica/opiekuna', max_length=128)
677     adres_opiekun = forms.CharField(label=u'Adres zamieszkania rodzica/opiekuna – ulica i numer', max_length=128)
678     poczta_opiekun = forms.CharField(
679         label=u'Adres zamieszkania rodzica/opiekuna – kod pocztowy i miejscowość', max_length=128)
680     telefon_opiekun = forms.CharField(label=u'Numer telefonu rodzica/opiekuna', max_length=32)
681     email_opiekun = forms.EmailField(label=u'Adres e-mail rodzica/opiekuna', max_length=32)
682     specjalne_potrzeby = forms.ChoiceField(
683         label=u'Czy uczestnik/uczestniczka ma specjalne potrzeby wynikające z niepełnosprawności', required=True,
684         choices=[('tak', 'tak'), ('nie', 'nie')], widget=forms.RadioSelect)
685     zgoda_regulamin = forms.BooleanField(
686         label=mark_safe(
687             u'Oświadczam, że zapoznałem/am się z <a href="/media/chunks/attachment/Regulamin.pdf" target="_blank">'
688             u'Regulaminem udziału w projekcie</a> '
689             u'i spełniam kryteria kwalifikowalności do udziału w projekcie.'))
690
691
692 ODMOWA_CHOICES = [
693     ('nie', u'Nie'),
694     ('tak', u'Tak'),
695     ('odmowa', u'Odmowa odpowiedzi'),
696 ]
697
698 YESNO_CHOICES = [
699     ('nie', u'Nie'),
700     ('tak', u'Tak'),
701 ]
702
703
704 class SciezkiKopernikaTestForm(TestForm):
705     def __init__(self, *args, **kwargs):
706         super(SciezkiKopernikaTestForm, self).__init__(*args, **kwargs)
707         self.label_suffix = ''
708
709     result_page = True
710     form_tag = 'sciezki-kopernika-test'
711     form_title = u'Test wiedzy w zakresie edukacji medialnej i cyfrowej'
712     submit_label = u'Wyślij'
713
714     contact = forms.EmailField(label=u'Adres e-mail, na który przyślemy informację o wynikach')
715     head1 = HeaderField(
716         label=u'Test powstał w ramach projektu "Collegium Młodych - media i technologie" realizowany w ramach '
717               u'III Osi priorytetowej: Szkolnictwo wyższe dla gospodarki i rozwoju, Działanie 3.1 Kompetencje '
718               u'w szkolnictwie wyższym Programu Operacyjnego Wiedza Edukacja Rozwój, współfinansowanego przez '
719               u'Unię Europejską w ramach Europejskiego Funduszu Społecznego. Nr umowy POWR.03.01.00-00-C078/16-00.')
720     head2 = HeaderField(
721         label=u'Dane zbierane są wyłącznie na potrzeby realizacji projektu „Collegium Młodych – media i technologie”,'
722               u' w szczególności potwierdzenia kwalifikowalności wydatków, udzielenia wsparcia, monitoringu, '
723               u'ewaluacji, kontroli, audytu i sprawozdawczości oraz działań informacyjno-promocyjnych w ramach '
724               u'PO WER.')
725     imie = forms.CharField(label=u'Imię')
726     nazwisko = forms.CharField(label=u'Nazwisko')
727     PESEL = forms.CharField(label=u'PESEL', required=False, help_text=u'zostawić pusty w przypadku braku')
728     plec = forms.ChoiceField(
729         label=u'Płeć', widget=forms.RadioSelect,
730         choices=[('k', u'kobieta'), ('m', u'mężczyzna')])
731     wiek = forms.IntegerField(label='Wiek')
732     wyksztalcenie = forms.ChoiceField(
733         label=u'Wykształcenie',
734         choices=[
735             (u'Niższe niż podstawowe', u'Niższe niż podstawowe'),
736             (u'Podstawowe', u'Podstawowe'),
737             (u'Gimnazjalne', u'Gimnazjalne'),
738             (u'Ponadgimnazjalne', u'Ponadgimnazjalne'),
739             (u'Policealne', u'Policealne'),
740             (u'Wyższe', u'Wyższe'),
741         ])
742     wojewodztwo = forms.ChoiceField(label=u'Województwo', choices=WOJEWODZTWO_CHOICES)
743     powiat = forms.CharField(label=u'Powiat')
744     gmina = forms.CharField(label=u'Gmina')
745     miejscowosc = forms.CharField(label=u'Miejscowość')
746     ulica = forms.CharField(label=u'Ulica', required=False)
747     numer = forms.CharField(label=u'Nr budynku')
748     lokal = forms.CharField(label=u'Nr lokalu', required=False)
749     kod = forms.CharField(label=u'Kod pocztowy')
750     telefon = forms.CharField(label=u'Telefon kontaktowy')
751     status = forms.ChoiceField(
752         label=u'Status na rynku pracy',
753         choices=[
754             (u'uczeń', u'osoba bierna zawodowo ucząca się'),
755             (u'nieuczeń', u'osoba bierna zawodowo nieuczestnicząca w kształceniu'),
756             (u'bezrobotna-up', u'Osoba bezrobotna zarejestrowana w ewidencji UP'),
757             (u'bezrobotna-nie-up', u'Osoba bezrobotna nie zarejestrowana w ewidencji UP'),
758             (u'pracująca', u'Osoba pracująca'),
759             (u'inne', u'inne'),
760         ])
761     typ_szkoly = forms.CharField(label=u'Typ szkoły (ponadgimnazjalna; inna, jaka?)', required=False)
762     mniejszosc = forms.ChoiceField(
763         label=u'Osoba należąca do mniejszości narodowej lub etnicznej, migrant, osoba obcego pochodzenia',
764         choices=ODMOWA_CHOICES)
765     bezdomna = forms.ChoiceField(
766         label=u'Osoba bezdomna lub dotknięta wykluczeniem z dostępu do mieszkań', choices=YESNO_CHOICES)
767     niepelnosprawna = forms.ChoiceField(
768         label=u'Osoba z niepełnosprawnościami',
769         choices=ODMOWA_CHOICES)
770     pytanie4 = forms.ChoiceField(
771         label=u'Osoba przebywająca w gospodarstwie domowym bez osób pracujących',
772         choices=YESNO_CHOICES)
773     pytanie5 = forms.ChoiceField(
774         label=u'Osoba przebywająca w gospodarstwie domowym z dziećmi pozostającymi na utrzymaniu',
775         choices=YESNO_CHOICES)
776     pytanie6 = forms.ChoiceField(
777         label=u'Osoba żyjąca w gospodarstwie składającym się z jednej osoby dorosłej i dzieci '
778               u'pozostających na utrzymaniu',
779         choices=YESNO_CHOICES)
780     pytanie7 = forms.ChoiceField(
781         label=u'Osoba żyjąca w innej niekorzystnej sytuacji społecznej (inne niż wymienione powyżej)',
782         choices=ODMOWA_CHOICES)
783
784     @classmethod
785     def results(cls, contact):
786         fields = cls().fields
787
788         def get_idx(choices, answer):
789             return dict((score, i) for i, (score, text) in enumerate(choices))[answer]
790
791         def question_data(i):
792             field = 'pyt%s' % i
793             choices = fields[field].choices
794             score = contact.body[field]
795             chosen_idx = get_idx(choices, score)
796             correct_idx = get_idx(choices, 2)
797             return {
798                 'score': score,
799                 'chosen_idx': chosen_idx,
800                 'correct_idx': correct_idx,
801                 'chosen': 'abc'[chosen_idx],
802                 'correct': 'abc'[correct_idx],
803                 'label': fields[field].label,
804                 'comment': mark_safe(markdown.convert(cls.ANSWER_COMMENTS[i-1][chosen_idx])),
805                 'answers': [(text, a_score == score, a_score == 2) for a_score, text in choices],
806             }
807         question_count = 20
808         questions = [question_data(i) for i in xrange(1, question_count + 1)]
809         points = sum(question['score'] for question in questions)
810         return {'questions': questions, 'points': points/2., 'total': question_count}