X-Git-Url: https://git.mdrn.pl/edumed.git/blobdiff_plain/30343946f333b9b63113bdda185c30924bab0337..d29e7ec36ee9d49763dfe72e52275f3a2709e1c2:/edumed/contact_forms.py diff --git a/edumed/contact_forms.py b/edumed/contact_forms.py index 1884d0d..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,23 +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): disabled = True disabled_template = 'contact/disabled_contact_form.html' - form_tag = 'trenerzy-cybernauci' + 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'), @@ -400,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 ' @@ -439,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'] @@ -481,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
  1. %s
' % (pre_label, start, label)), + max_length=max_length) + + +def simple_choices(*choices): + return tuple((choice, choice) for choice in choices) + + +class CybernauciAnkietaForm(ContactForm): + def __init__(self, *args, **kwargs): + super(CybernauciAnkietaForm, self).__init__(*args, **kwargs) + self.label_suffix = '' + + form_tag = '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( + 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?') + 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. 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?') + pyt8 = forms.MultipleChoiceField( + label=u'8. W jaki sposób poradzisz sobie z niespodziewaną sytuacją skrócenia czasu zajęć? ' + u'Na które z poniższych punktów przeznaczysz w takiej sytuacji najmniej czasu?', + widget=forms.CheckboxSelectMultiple, + 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_length=1000) + pyt9 = textarea_field( + label=u'9. Jeden z uczestników przeszkadza podczas warsztatów: ' + u'głośno żartuje, nie wykonuje zleconych zadań. Co robisz?') + pyt10 = textarea_field( + u'10. Z całej grupy tylko trzy osoby odpowiadają na każde zadane przez Ciebie pytanie. ' + u'Co robisz?') + pyt11 = textarea_field( + u'11. Jakie są Twoje największe obawy wobec realizacji szkoleń w placówkach oświatowych?') + pyt12a = ordered_textarea_field( + 1, pre_label=u'12. 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'13. 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ć?') + pyt14 = textarea_field( + u'14. 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?') + + +def quiz_question(label, choices): + return forms.TypedChoiceField(label=label, choices=choices, coerce=int, widget=forms.RadioSelect) + + +def make_link(text, url): + return u'%s' % (url, text) + + +class SciezkiKopernikaTestForm(ContactForm): + 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' + submit_label = u'Wyślij' + + contact = forms.EmailField(label=u'Adres e-mail, na który przyślemy informację o wynikach') + pyt1 = quiz_question( + label=u'1) Na stronie portalu internetowego opublikowano wpis o treści ' + u'„Nie wszyscy muzułmanie to terroryści, ale wszyscy terroryści to muzułmanie”. ' + u'Komentarz podlega moderacji i powinien:', + choices=[ + (1, u'zostać zachowany, ponieważ jest prywatną opinią korzystającą z wolności słowa,'), + (0, u'zostać zachowany, ponieważ informuje o fakcie,'), + (2, u'zostać usunięty, ponieważ jest wprowadzającą w błąd interpretacją faktów.'), + ]) + pyt2 = quiz_question( + label=u'2) Aby przygotować podcast, należy posiadać przynajmniej:', + choices=[ + (0, u'półprofesjonalny mikrofon radiowy, z wbudowanym interfejsem dźwiękowym, ' + u'komercyjne oprogramowanie typu DAW, średnio-zaawansowane umiejętności cyfrowej obróbki dźwięku,'), + (1, u'urządzenie do nagrywania dźwięku, laptop, oprogramowanie dedykowane do tworzenia podcastów,'), + (2, u'urządzenie do nagrywania dźwięku, podstawowe oprogramowanie do edycji dźwięku, ' + u'podstawowe umiejętności cyfrowej obróbki dźwięku.')]) + pyt3 = quiz_question( + label=u'3) Muzeum cyfrowe chce udostępnić skan XIV-wiecznego kodeksu. ' + u'Zgodnym z ideą domeny publicznej sposobem jego udostępnienia będzie:', + choices=[ + (0, u'udostępnienie go na licencji Creative Commons,'), + (2, u'udostępnienie go bez licencji z czytelnym wskazaniem praw do dowolnego wykorzystania,'), + (1, u'udostępnienie go w pliku jakości produkcyjnej.')]) + pyt4 = quiz_question( + label=u'4) Aby uniknąć możliwości podejrzenia przez niepowołane osoby, jakie strony internetowe ' + u'odwiedzałeś ostatnio, powinieneś/powinnaś:', + choices=[ + (0, u'ustawić opcję otwierania nowej sesji przeglądarki bez wyświetlania ostatnio używanych kart ' + u'oraz regularnie czyścić historię wyszukiwania,'), + (2, u'wylogowywać się lub blokować ekran za każdym razem, kiedy odchodzisz od komputera, tabletu ' + u'lub odkładasz gdzieś telefon, regularnie czyścić dane zgromadzone przez przeglądarkę internetową,'), + (1, u'wylogowywać się lub blokować ekran za każdym razem, kiedy odchodzisz od komputera, tabletu ' + u'lub odkładasz gdzieś telefon, regularnie czyścić historię przeglądanych stron.')]) + pyt5 = quiz_question( + label=u'5) Komentarz opublikowany w internecie ma taką samą wartość bez względu na to, ' + u'czy jest anonimowy czy podpisany imieniem i nazwiskiem:', + choices=[ + (0, u'tak, ze względu na zasadę wolności słowa,'), + (2, u'to zależy od jego treści i kontekstu, w którym go opublikowano,'), + (1, u'tak, z punktu widzenia odpowiedzialności prawnej. [poprawna]')]) + pyt6 = quiz_question( + label=u'6) Wraz z grupą osób zamierzasz przygotować cyfrową opowieść (narrację) na temat współczesnych ' + u'nastolatków i ich stosunku do szkoły. Żeby praca była efektywna, a jej rezultat efektowny, warto ' + u'zorganizować wspólną pracę w następujących krokach:', + choices=[ + (2, u'przeprowadzić wspólną dyskusję odnośnie tematu opowieści, wybrać jeden, ustalić, co należy zrobić, ' + u'podzielić zadania w grupie i przygotować scenariusz narracji (opisać poszczególne sceny, co się ' + u'w nich znajdzie, co będzie potrzebne do ich przygotowania),'), + (0, u'zgromadzić jak najwięcej materiałów wideo i zdjęć, wybrać oprogramowanie do obróbki wideo i wspólnie ' + u'decydować o kolejności scen i zawartości opowieści,'), + (1, u'wybrać temat opowieści, zgromadzić jak najwięcej filmików i zdjęć, podzielić się zadaniami w grupie, ' + u'zmontować narrację z części przygotowanych przez uczestników zespołu.')]) + pyt7 = quiz_question( + label=u'7) Firma telekomunikacyjna wykorzystuje boty do automatycznego odpowiadania na pytania klientów ' + u'zadawane przez Facebooka. Boty zwracają się do wszystkich po imieniu. Kiedy użytkownik, który nie ' + u'życzy sobie tego nie życzy, wyraża swoje niezadowolenie z takiej formy rozmowy, firma:', + choices=[ + (2, u'przeprosić użytkownika, szanując preferowane przez niego reguły komunikacji,'), + (0, u'zignorować użytkownika odwołując się do zasad netykiety,'), + (1, u'zareagować zgodnie z wypracowanymi wewnętrznie zasadami komunikacji.')]) + pyt8 = quiz_question( + label=u'8) Jesteś członkiem/członkinią grupy, która przygotowuje aplikację, mającą ułatwić osobom ' + u'niepełnosprawnym poruszanie się po Twojej miejscowości. Oprogramowanie będzie m.in. informować, ' + u'czy przy określonej instytucji, firmie, sklepie, znajdują się miejsca parkingowe ' + u'dla niepełnosprawnych i ile ich jest. Aby aplikacja działała prawidłowo, powinieneś/powinnaś:', + choices=[ + (1, u'przygotować listę najważniejszych obiektów w Twoim mieście i skontaktować się z ich administracją, ' + u'pytając o liczbę miejsc parkingowych,'), + (0, u'poszukać informacji o dostępnych miejscach parkingowych na stronach instytucji, firm i sklepów,'), + (2, u'skontaktować się z administracją obiektów, o których będzie informować aplikacja, udać się również ' + u'do tych obiektów, aby potwierdzić ilość dostępnych miejsc, spróbować zgromadzić informacje o tym, ' + u'jak często miejsca parkingowe są zajmowane przez ludzi pełnosprawnych.')]) + pyt9 = quiz_question( + label=u'9) Pojęcie „niewidzialnej pracy” może dotyczyć:', + choices=[ + (2, u'moderatorów mediów społecznościowych zatrudnianych w krajach o niskich kosztach pracy, [najlepsze]'), + (1, u'użytkowników serwisów społecznościowych publikujących codziennie i bez wynagrodzenia własne ' + u'materiały w tym serwisie, [dobre]'), + (0, u'informatyków budujących rozwiązania IT dla firm. [złe]')]) + + pyt10 = quiz_question( + label=u'10) Możesz uważać, że informacje, do których docierasz, są wiarygodne, ponieważ:', + choices=[ + (1, u'pojawiają się w wielu telewizyjnych serwisach informacyjnych, na profilach społecznościowych ' + u'moich znajomych i w różnorodnych internetowych serwisach informacyjnych, wszędzie przedstawiane ' + u'są w podobny sposób,'), + (2, u'pojawiają się w wielu serwisach informacyjnych, na profilach moich znajomych, zawierają odnośniki ' + u'do oryginalnych źródeł, do których można dotrzeć,'), + (0, u'pojawiają się na profilach wielu moich znajomych w serwisach społecznościowych i ' + u'w kilku internetowych serwisach informacyjnych.')]) + pyt11 = quiz_question( + label=u'11) W pewnym mieście prokuratura bada umowy z wykonawcami projektów budżetu obywatelskiego. ' + u'Nikomu, jak dotąd, nie postawiono zarzutów. Która postać tytułu newsa opublikowanego ' + u'na lokalnym portalu internetowym będzie najbardziej zgodna z zasadami etyki dziennikarskiej?', + choices=[ + (1, u'„Budżet obywatelski: niejasne umowy z wykonawcami?”,'), + (2, u'„Prokuratura zbada umowy z wykonawcami projektów budżetu obywatelskiego.”,'), + (0, u'„Zobacz, które firmy mogły obłowić się na projektach budżetu obywatelskiego!”.')]) + pyt12 = quiz_question( + label=u'12) Dołączyłeś/-aś do grupy, która zbiera informacje o problemach dotyczących młodych ludzi ' + u'w Twojej okolicy. Zamierzacie zaprezentować zgromadzone informacje w interesujący sposób, ' + u'tak by zainteresować lokalne media, służby miejskie, zwykłych obywateli i waszych rówieśników. ' + u'Grupa nie ma możliwości regularnego spotykania się, dlatego wybraliście pracę wyłącznie ' + u'przez internet. Który zestaw narzędzi pozwoli wam na jak najlepszą, wspólną pracę?', + choices=[ + (0, u'mail grupowy, komunikator tekstowy (np. Messenger), oprogramowanie do tworzenia podcastów, ' + u'stacjonarne narzędzie do tworzenia prezentacji (np. Power Point),'), + (1, u'mail grupowy, komunikator tekstowy zespołu (np. Slack), narzędzie do kolektywnego tworzenia ' + u'map myśli (np. Coggle), blog redagowany przez wszystkich uczestników projektu, aplikacja do ' + u'synchronizowania plików w chmurze (np. Dropbox), narzędzie do grupowej komunikacji za pomocą wideo ' + u'(dyskusyjna) (np. Skype),'), + (2, u'aplikacja do zarządzania zadaniami zespołu i terminami do wykonania (np. Wunderlist), ' + u'narzędzie do tworzenia kolektywnych notatek (np. OneNote) lub wspólnej pracy z tekstem ' + u'(np. EtherPad, Google Dokumenty), grupa w serwisie społecznościowym lub tekstowy komunikator ' + u'zespołu (np. Messenger lub Slack), narzędzia do gromadzenia lub prezentowania materiałów ' + u'(np. wspólny blog, kanał w serwisie społecznościowym).')]) + pyt13 = quiz_question( + label=u'13) Poniżej podano wybrane cechy hasła opublikowanego w Wikipedii. ' + u'Która z nich jest najbardziej pomocna przy analizie jakości hasła?', + choices=[ + (0, u'liczba edycji hasła,'), + (1, u'długość i struktura hasła,'), + (2, u'obecność i jakość przypisów.')]) + pyt14 = quiz_question( + label=u'14) Na przeglądanej stronie internetowej znalazłeś/-aś interesującą grafikę, którą chciał(a)byś ' + u'wykorzystać przygotowywanej cyfrowej narracji. Nie jest ona jednak podpisana. Co robisz?', + choices=[ + (0, u'podpisuję grafikę adresem strony, na której ją znalazłem/-am,'), + (1, u'korzystam z opcji wyszukiwania obrazem w wyszukiwarce grafiki, chcąc znaleźć inne strony, ' + u'gdzie pojawiła się grafika,'), + (2, u'korzystam z opcji wyszukiwania obrazem, a jeśli to się nie powiedzie, skontaktuję się ' + u'z administratorem strony, na której znalazłem/-am grafikę, pytając o autora; przeglądam także ' + u'informacje o stronie, szukając ewentualnych informacji o zasadach publikacji treści; być może ' + u'autor informuje, że wszystkie grafiki są jego autorstwa.')]) + pyt15 = quiz_question( + label=mark_safe( + u'15) W nieistniejącym języku programowania TEST dana jest funkcja zapisana w następujący sposób:' + u'

funkcja f(a) { wyświetl a + b;
' + u'}

' + u'Przeczytaj uważnie kod i zastanów się, jak działa ta funkcja.' + u'Główną wadą tego kodu jest przetwarzanie brakującego argumentu:'), + choices=[ + (2, u'b,'), + (1, u'b będącego dowolną liczbą,'), + (0, u'f.')]) + pyt16 = quiz_question( + label=u'16) Przygotowujesz teledysk do utworu nagranego przez twój zespół. Efekt swojej pracy opublikujesz ' + u'na kanale zespołu na YouTube. Teledysk nie może łamać praw autorskich, w przeciwnym razie zostanie ' + u'usunięty z serwisu. W teledysku możesz wykorzystać zdjęcia, ikony, fragmenty filmów:', + choices=[ + (1, mark_safe( + u'znalezionych w wyszukiwarce serwisu Flickr na licencji %s, przygotowanych przez ciebie, ' + u'ściągniętych z serwisu %s,' % ( + make_link(u'CC BY-SA', 'https://www.flickr.com/creativecommons/by-sa-2.0/'), + make_link(u'The Noun Project', 'https://thenounproject.com')))), + (2, mark_safe( + u'znalezionych w wyszukiwarce serwisu Flickr na licencji %s, przygotowanych przez ciebie, ' + u'ściągniętych z %s,' % ( + make_link(u'CC-BY', 'https://www.flickr.com/creativecommons/by-2.0/'), + make_link(u'serwisu ze zdjęciami NASA', + 'https://www.nasa.gov/multimedia/imagegallery/index.html')))), + (0, mark_safe( + u'znalezionych w wyszukiwarce serwisu Flickr na licencji %s, przygotowanych przez ciebie, ' + u'ściągniętych z wyszukiwarki grafiki Google.' % + make_link('CC-BY-NC', 'https://www.flickr.com/creativecommons/by-nc-2.0/')))]) + pyt17 = quiz_question( + label=mark_safe( + u'17) Muzeum cyfrowe udostępniło skan druku propagandowego z pierwszej połowy XVII w. ' + u'w humorystyczny sposób przedstawiający strony angielskiej wojny domowej (trwającej z przerwami ' + u'między 1642-1651 rokiem):' + u'

' + u'

' + 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}