X-Git-Url: https://git.mdrn.pl/edumed.git/blobdiff_plain/fe1c0b8004de74f89acb68b48ccdc8d6705d5064..b1e1600ec1a45327a4bb2e0a1104a17ec5f9a187:/edumed/contact_forms.py?ds=sidebyside diff --git a/edumed/contact_forms.py b/edumed/contact_forms.py index e5124b8..29f25b4 100644 --- a/edumed/contact_forms.py +++ b/edumed/contact_forms.py @@ -1,6 +1,8 @@ # -*- coding: utf-8 -*- from django import forms from django.forms.formsets import BaseFormSet +from django.utils.safestring import mark_safe + from contact.forms import ContactForm from django.core.mail import send_mail from django.core.exceptions import ValidationError @@ -128,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): @@ -150,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) @@ -233,6 +233,96 @@ 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 = True + disabled_template = 'wtem/disabled_contact_form.html' + form_tag = "olimpiada" + form_title = u"Olimpiada Cyfrowa - Elektroniczny System ZgÅoszeÅ" + submit_label = u"WyÅlij zgÅoszenie" + admin_list = ['nazwisko', 'school'] + form_formsets = { + 'student': forms.formsets.formset_factory(WTEMStudentForm, formset=NonEmptyBaseFormSet), + 'commission': forms.formsets.formset_factory(CommissionForm, formset=BaseFormSet), + } + + contact = forms.EmailField(label=u'Adres e-mail PrzewodniczÄ cego/PrzewodniczÄ cej', max_length=128) + przewodniczacy = forms.CharField(label=u'ImiÄ i nazwisko PrzewodniczÄ cego/PrzewodniczÄ cej', max_length=128) + school = forms.CharField(label=u'Nazwa szkoÅy', max_length=255) + school_address = forms.CharField(label=u'Adres szkoÅy', widget=forms.Textarea, max_length=1000) + school_email = forms.EmailField(label=u'Adres e-mail szkoÅy', max_length=128) + school_phone = forms.CharField(label=u'Numer telefonu szkoÅy', max_length=32) + school_www = forms.URLField(label=u'Strona WWW szkoÅy', max_length=255, required=False) + + zgoda_regulamin = forms.BooleanField( + label=u'Znam i akceptujÄ Regulamin Olimpiady Cyfrowej.', + help_text=u'Zobacz ' + u'regulamin Olimpiady Cyfrowej.' + ) + zgoda_dane = forms.BooleanField( + label=u'OÅwiadczam, że wyrażam zgodÄ na przetwarzanie danych osobowych zawartych w niniejszym formularzu ' + u'zgÅoszeniowym przez FundacjÄ Nowoczesna Polska (administratora danych) z siedzibÄ w Warszawie (00-514) ' + u'przy ul. MarszaÅkowskiej 84/92 lok. 125 na potrzeby organizacji Olimpiady Cyfrowej. JednoczeÅnie ' + u'oÅwiadczam, że zostaÅam/em poinformowana/y o tym, że mam prawo wglÄ du w treÅÄ swoich danych ' + u'i możliwoÅÄ ich poprawiania oraz że ich podanie jest dobrowolne, ale niezbÄdne do dokonania ' + u'zgÅoszenia.') + + extract_types = (dict(slug='extended', label=_('extended')),) + + @staticmethod + def get_extract_fields(contact, extract_type_slug): + fields = contact.body.keys() + 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): form_tag = 'mil' form_title = _('Share your thoughts on the "Media and information literacy competencies catalogue"') @@ -374,21 +464,28 @@ class SuperwizjaForm(ContactForm): 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): - form_tag = 'trenerzy-cybernauci' + disabled = True + disabled_template = 'contact/disabled_contact_form.html' + form_tag = 'trenerzy-cybernauci2017' form_title = u"Cybernauci â szkolenie dla trenerów" admin_list = ['nazwisko', 'instytucja', 'contact'] submit_label = u'WyÅlij' 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) - 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( - 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'), @@ -398,36 +495,34 @@ class CybernauciForm(ContactForm): ('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).', - 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 ' - 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 ' - 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Ä ' - 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.', - help_text=u'Zobacz regulamin.') + help_text=u'Zobacz regulamin.') 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 ' @@ -437,12 +532,16 @@ 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_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): + disabled = True form_tag = 'wlem' form_title = u"WLEM - szkolenie dla warszawskich liderów edukacji medialnej" admin_list = ['nazwisko', 'instytucja', 'contact'] @@ -464,7 +563,7 @@ class WLEMForm(ContactForm): label=u'JakÄ wiedzÄ i umiejÄtnoÅci chce Pan/Pani zdobyÄ lub doskonaliÄ poprzez uczestnictwo w szkoleniu?', widget=forms.Textarea, max_length=4096) jak_wykorzystac = forms.CharField( - label=u'Jak zamierza Pan/Pani wykorzystaÄ wiedzÄ zdobytÄ w czasie szkolenia?', + label=u'Jak zamierza Pan/Pani wykorzystaÄ wiedzÄ i umiejÄtnoÅci zdobyte w czasie szkolenia?', widget=forms.Textarea, max_length=4096) zgoda_zajecia = forms.BooleanField( label=u'W okresie lipiec-październik 2016 r. przeprowadzÄ min. 2 godziny zajÄÄ ' @@ -479,3 +578,363 @@ class WLEMForm(ContactForm): required=False, label=u'Wyrażam zgodÄ na otrzymywanie informacji od Fundacji Nowoczesna Polska ' u'zwiÄ zanych z edukacjÄ medialnÄ .') + + +def ordered_textarea_field(start, pre_label=u'', label=u'', max_length=500): + return textarea_field( + mark_safe(u'%s
funkcja f(a) { wyÅwietl a + b;
'
+ u'}
' + u'https://commons.wikimedia.org/wiki/File:Engl-Bürgerkrieg.JPG
' + u'Najbardziej użytecznym dla użytkowników przeszukujÄ cych stronÄ zestawem sÅów kluczowych ' + u'opisujÄ cych ten obiekt bÄdzie:'), + choices=[ + (2, u'Anglia, wojna domowa, karykatura, propaganda,'), + (0, u'komiks, Åmiech, Anglicy, Wielka Brytania, psy,'), + (1, u'Angielska Wojna Domowa 1642-1651, propaganda.')]) + pyt18 = quiz_question( + label=u'18) Podczas wycieczki szkolnej zrobiÅeÅ sporo zdjÄÄ znajomym, w różnych sytuacjach. ' + u'Masz również dostÄp do wielu fotografii, które przygotowali twoi koledzy i koleżanki. ' + u'Zamierzasz niektóre z nich zamieÅciÄ na swoim kanale w serwisie spoÅecznoÅciowym. Możesz opublikowaÄ:', + choices=[ + (0, u'zdjÄcia prezentujÄ ce selfie (o ile nie przedstawiajÄ wiÄcej niż dwóch osób), ' + u'zdjÄcia grupy podczas zwiedzania, zdjÄcia, które ktoÅ zrobiÅ tobie na tle zwiedzanych obiektów, ' + u'zdjÄcia, na których ludzie siÄ uÅmiechajÄ i cieszÄ , że robisz im zdjÄcie,'), + (1, u'zdjÄcia prezentujÄ ce selfie (ale tylko twoje), zdjÄcia pokazujÄ ce w oddali grupÄ na tle ' + u'zwiedzanych obiektów, zdjÄcia, zdjÄcia na których widaÄ tylko ciebie, na tle zwiedzanych obiektów,'), + (2, u'zdjÄcia prezentujÄ ce selfie (na których jesteÅ ty, ale również inne osoby, które potwierdziÅy, ' + u'że możesz opublikowaÄ fotografie), zdjÄcia na których widaÄ tylko ciebie ' + u'i masz zgodÄ na ich publikacjÄ od osoby, która wykonaÅa fotografiÄ, ' + u'wykonane przez ciebie zdjÄcia zwiedzanych obiektów.')]) + pyt19 = quiz_question( + label=u'19) KorzystajÄ c z sieci, natrafiamy na różne interesujÄ ce informacje. ' + u'PojawiajÄ siÄ w wielu serwisach informacyjnych, spoÅecznoÅciowych, w postaci reklam ' + u'doÅÄ czanych do materiaÅów wideo, reklam zamieszczonych w tekstach itp. ' + u'Na co warto zwracaÄ uwagÄ, podczas codziennego korzystania z mediów, ' + u'żeby efektywnie wykorzystaÄ czas spÄdzony w internecie?', + choices=[ + (1, u'zaplanowaÄ czas spÄdzany na korzystaniu z mediów i staraÄ siÄ trzymaÄ swojego planu, ' + u'nie unikasz jednak nagÅych rozmów przez komunikator, oglÄ dania postów, ' + u'zdjÄÄ i filmików dodawanych przez znajomych,'), + (0, u'zaplanowaÄ, co bÄdziesz robiÅ(a), ale traktujesz to jako ramÄ dziaÅania, wiesz, ' + u'że po drodze pojawi siÄ wiele interesujÄ cych informacji, z których skorzystasz,'), + (2, u'zaplanowaÄ czas spÄdzany na korzystaniu z mediów i rejestrowaÄ, co, ' + u'kiedy i przez ile czasu robisz, np. instalujÄ c aplikacjÄ do mierzenia czasu spÄdzanego w sieci. ' + u'NastÄpnie analizujesz zebrane informacje i starasz siÄ okreÅliÄ, co robisz zbyt czÄsto ' + u'i jakie rzeczy odciÄ gajÄ TwojÄ uwagÄ od tych zaplanowanych.')]) + pyt20 = quiz_question( + label=u'20) BlokujÄ ca reklamy wtyczka do przeglÄ darki dziaÅa w nastÄpujÄ cy sposób:', + choices=[ + (0, u'analizuje treÅÄ tekstów oraz obrazków i blokuje te, które zawierajÄ reklamy,'), + (1, u'blokuje wyÅwietlanie plików reklam zanim wyÅwietli je przeglÄ darka,'), + (2, u'blokuje komunikacjÄ przeglÄ darki z serwerami publikujÄ cymi reklamy.')]) + + ANSWER_COMMENTS = [ + (u'dobrze', u'źle', u'najlepiej'), + (u'Årednio', u'gÅupio', u'super'), + (u'sÅabo', u'beznadziejnie', u'ujdzie'), + (u'trója', u'paÅa', u'szóstka'), + (u'dobrze', u'źle', u'najlepiej'), + (u'Årednio', u'gÅupio', u'super'), + (u'sÅabo', u'beznadziejnie', u'ujdzie'), + (u'trója', u'paÅa', u'szóstka'), + (u'dobrze', u'źle', u'najlepiej'), + (u'Årednio', u'gÅupio', u'super'), + (u'sÅabo', u'beznadziejnie', u'ujdzie'), + (u'trója', u'paÅa', u'szóstka'), + (u'dobrze', u'źle', u'najlepiej'), + (u'Årednio', u'gÅupio', u'super'), + (u'sÅabo', u'beznadziejnie', u'ujdzie'), + (u'trója', u'paÅa', u'szóstka'), + (u'dobrze', u'źle', u'najlepiej'), + (u'Årednio', u'gÅupio', u'super'), + (u'sÅabo', u'beznadziejnie', u'ujdzie'), + (u'trója', u'paÅa', u'szóstka'), + ] + + @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': cls.ANSWER_COMMENTS[i-1][chosen_idx], + 'answers': [(text, a_score == score, a_score == 2) for a_score, text in choices], + } + question_count = len(fields) - 1 + 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}