X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/e7451b87d12c06755d6dc278e72b6650f8de8b4a..d5a5399ebf7c51aae90dd4df2a803faaa08807d9:/src/club/forms.py?ds=inline diff --git a/src/club/forms.py b/src/club/forms.py index ed18e2240..3a844dab4 100644 --- a/src/club/forms.py +++ b/src/club/forms.py @@ -5,19 +5,77 @@ from decimal import Decimal from django import forms from django.utils.translation import ugettext as _ from newsletter.forms import NewsletterForm -from . import models +from . import models, payment_methods from .payu.forms import CardTokenForm class ScheduleForm(forms.ModelForm, NewsletterForm): + data_processing = '''Informacja o przetwarzaniu danych osobowych + +<div class='more-expand'>Administratorem Twoich danych osobowych jest Fundacja Nowoczesna Polska z siedzibÄ w Warszawie, przy ul. MarszaÅkowskiej 84/92 lok.125, 00-514 Warszawa (dalej: Fundacja). + +Z FundacjÄ można siÄ kontaktowaÄ we wszystkich sprawach dotyczÄ cych przetwarzania danych osobowych oraz korzystania z praw zwiÄ zanych z przetwarzaniem danych, w szczególnoÅci w zakresie wycofania udzielonej zgody na przetwarzanie danych poprzez adres e-mail fundacja@nowoczesnapolska.org.pl, telefonicznie pod numerem +48 22 621 30 17 (w dni powszednie w godz. 9-17) lub listownie piszÄ c na adres siedziby Fundacji. +Podanie danych osobowych jest dobrowolne, jednak konieczne do przeprowadzenia pÅatnoÅci oraz realizacji innych celów wskazanych poniżej. + +Twoje dane bÄdÄ przetwarzane w celu: + ⢠rozliczeniowym, ksiÄgowym, i innych sprawach zwiÄ zanych z TwojÄ darowiznÄ na podstawie art. 6 ust. 1 lit. b i c RODO, + ⢠kontaktu telefonicznego, przez media elektroniczne oraz listownie, celem informowania o dziaÅalnoÅci oraz proÅby o wsparcie na podstawie art. 6 ust. 1 lit. a, + ⢠przesyÅania e-mailem newslettera: regularnej informacji o dziaÅalnoÅci fundacji oraz próÅb o wsparcie na podstawie art. 6 ust. 1 lit. a RODO, + ⢠ewentualnego ustalenia i dochodzenia roszczeÅ lub obrony przed nimi; zapewnienia bezpieczeÅstwa u Administratora oraz realizacji wewnÄtrznych celów administracyjnych, analitycznych i statystycznych na podstawie art. 6 ust. 1 lit. f RODO; uzasadnionym interesem Administratora jest możliwoÅÄ obrony przed ewentualnymi roszczeniami, zapewnienia bezpieczeÅstwa u Administratora oraz możliwoÅÄ realizacji wewnÄtrznych celów administracyjnych, analitycznych i statystycznych przez FundacjÄ. + +Fundacja nie udostÄpnia Twoich danych osobowych podmiotom trzecim. Fundacja może korzystaÄ z usÅug podwykonawców w celu realizacji kontaktu w ramach wyrażonej zgody. W szczególnoÅci Twoje dane mogÄ byÄ przekazywane podmiotom takim jak banki, firma obsÅugujÄ ca ksiÄgowoÅÄ i firmy wspóÅpracujÄ ce przy prowadzeniu akcji informacyjnych i edukacyjnych â przy czym takie podmioty przetwarzajÄ dane wyÅÄ cznie na podstawie umowy z administratorem, wyÅÄ cznie zgodnie z poleceniami administratora i wyÅÄ cznie zgodnie z zakresem udzielonej zgody. + +Twoje dane osobowe bÄdÄ przechowywane do momentu wycofania zgody, rozliczenia darowizn, a po tym okresie przez okres przedawnienia ewentualnych roszczeÅ lub przez okres, który wynika z przepisów prawa, w szczególnoÅci obowiÄ zku przechowywania dokumentów ksiÄgowych (rachunkowych). + +PrzysÅuguje Ci prawo dostÄpu do Twoich danych oraz prawo Å¼Ä dania ich sprostowania, ich usuniÄcia lub ograniczenia ich przetwarzania. W zakresie, w jakim podstawÄ przetwarzania Twoich danych osobowych jest przesÅanka prawnie uzasadnionego interesu administratora, przysÅuguje Ci prawo wniesienia sprzeciwu wobec przetwarzania Twoich danych osobowych. W zakresie, w jakim podstawÄ przetwarzania Twoich danych osobowych jest zgoda, masz prawo wycofania zgody. Wycofanie zgody nie ma wpÅywu na zgodnoÅÄ z prawem przetwarzania, którego dokonano na podstawie zgody przed jej wycofaniem. W celu skorzystania z powyższych praw należy skontaktowaÄ siÄ z fundacjÄ w dowolny wskazany powyżej sposób. + +Masz prawo do wniesienia skargi do organu nadzorczego, jeżeli uważasz, że Twoje dane osobowe sÄ przetwarzane w niewÅaÅciwy sposób. + +Twoje dane osobowe nie bÄdÄ profilowane, ani przesyÅane do paÅstw trzecich i organizacji miÄdzynarodowych. + +</div> +'''.replace('\n', '<br>') + class Meta: model = models.Schedule - fields = ['monthly', 'amount', 'email'] + fields = ['monthly', 'amount', + 'first_name', 'last_name', + 'email', 'phone', + 'postal', + 'postal_code', 'postal_town', 'postal_country', + 'method'] widgets = { 'amount': forms.HiddenInput, 'monthly': forms.HiddenInput, + 'method': forms.HiddenInput, + + 'first_name': forms.TextInput(attrs={"placeholder": _('first name')}), + 'last_name': forms.TextInput(attrs={"placeholder": _('last name')}), + + 'postal': forms.Textarea(attrs={"placeholder": _("street address")}), + 'postal_code': forms.TextInput(attrs={"placeholder": _('postal code')}), + 'postal_town': forms.TextInput(attrs={"placeholder": _('town')}), } + def __init__(self, referer=None, **kwargs): + self.referer = referer + super().__init__(**kwargs) + + self.fields['first_name'].required = True + self.fields['last_name'].required = True + self.fields['phone'].required = True + + self.consent = [] + for c in models.Consent.objects.filter(active=True).order_by('order'): + key = f'consent{c.id}' + self.fields[key] = forms.BooleanField( + label=c.text, + required=c.required + ) + self.consent.append(( + c, key, (lambda k: lambda: self[k])(key) + )) + def clean_amount(self): value = self.cleaned_data['amount'] club = models.Club.objects.first() @@ -29,9 +87,29 @@ class ScheduleForm(forms.ModelForm, NewsletterForm): ) return value + def clean_method(self): + value = self.cleaned_data['method'] + monthly = self.cleaned_data['monthly'] + for m in payment_methods.methods: + if m.slug == value: + if (monthly and m.is_recurring) or (not monthly and m.is_onetime): + return value + if monthly: + return payment_methods.recurring_payment_method.slug + else: + return payment_methods.single_payment_method.slug + def save(self, *args, **kwargs): NewsletterForm.save(self, *args, **kwargs) - return super().save(*args, **kwargs) + self.instance.source = self.referer or '' + instance = super().save(*args, **kwargs) + + consents = [] + for consent, key, consent_field in self.consent: + if self.cleaned_data[key]: + instance.consent.add(consent) + + return instance class PayUCardTokenForm(CardTokenForm):