X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/6034428b14b634d1801e2d8279b1a0863b918a48..cafca91e28661f24abbcda91c733de7e77d16e86:/src/club/forms.py
diff --git a/src/club/forms.py b/src/club/forms.py
index b818d1c12..098a70edf 100644
--- a/src/club/forms.py
+++ b/src/club/forms.py
@@ -1,47 +1,203 @@
+# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
+#
from decimal import Decimal
from django import forms
-from . import models
-from .payment_methods import method_by_slug, methods
+from django.utils.translation import gettext as _
+from newsletter.forms import NewsletterForm
+from . import models, payment_methods
from .payu.forms import CardTokenForm
-class ScheduleForm(forms.ModelForm):
+class ScheduleForm(forms.ModelForm, NewsletterForm):
+ data_processing = '''Informacja o przetwarzaniu danych osobowych
+
+
Administratorem Twoich danych osobowych jest Fundacja Wolne Lektury 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.
+
+
+'''.replace('\n', '
')
+
class Meta:
model = models.Schedule
- fields = ['plan', 'method', 'amount', 'email']
+ fields = ['monthly', 'amount',
+ 'first_name', 'last_name',
+ 'email', 'phone',
+ 'postal',
+ 'postal_code', 'postal_town', 'postal_country',
+ 'method']
widgets = {
- 'plan': forms.RadioSelect,
- 'method': forms.RadioSelect,
+ '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, *args, request=None, **kwargs):
- super(ScheduleForm, self).__init__(*args, **kwargs)
- self.request = request
- self.plans = models.Plan.objects.all()
- self.payment_methods = methods
- self.fields['amount'].required = False
+ def __init__(self, referer=None, **kwargs):
+ self.referer = referer
+ super().__init__(**kwargs)
- def clean(self):
- cleaned_data = super(ScheduleForm, self).clean()
+ 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)
+ ))
- if 'plan' in cleaned_data:
- cleaned_data['amount'] = self.fields['amount'].clean(
- self.request.POST['amount-{}'.format(cleaned_data['plan'].id)]
+ def clean_amount(self):
+ value = self.cleaned_data['amount']
+ club = models.Club.objects.first()
+ if club and value < club.min_amount:
+ raise forms.ValidationError(
+ _('Minimal amount is %(amount)d PLN.') % {
+ 'amount': club.min_amount
+ }
)
+ return value
- if cleaned_data['amount'] < cleaned_data['plan'].min_amount:
- self.add_error(
- 'amount',
- 'Minimalna kwota dla tego planu to %d zÅ.' % cleaned_data['plan'].min_amount
- )
+ 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)
+ self.instance.source = self.referer or ''
+ instance = super().save(*args, **kwargs)
- if 'method' in cleaned_data:
- method = method_by_slug[cleaned_data['method']]
- if method not in cleaned_data['plan'].payment_methods():
- self.add_error('method', 'Wybrana metoda pÅatnoÅci nie jest dostÄpna dla tego planu.')
+ consents = []
+ for consent, key, consent_field in self.consent:
+ if self.cleaned_data[key]:
+ instance.consent.add(consent)
+ return instance
class PayUCardTokenForm(CardTokenForm):
def get_queryset(self, view):
return view.get_schedule().payucardtoken_set
+
+
+
+class DonationStep1Form(forms.ModelForm):
+ switch = forms.CharField()
+ single_amount = forms.IntegerField(required=False)
+ monthly_amount = forms.IntegerField(required=False)
+ single_amount_selected = forms.IntegerField(required=False)
+ monthly_amount_selected = forms.IntegerField(required=False)
+ custom_amount = forms.IntegerField(required=False)
+
+ amount = forms.IntegerField(required=False) # hidden
+
+ class Meta:
+ model = models.Schedule
+ fields = [
+ 'amount',
+ 'monthly'
+ ]
+
+ def __init__(self, *args, **kwargs):
+ super().__init__(*args, **kwargs)
+ club = models.Club.objects.first()
+ if club is not None:
+ self.fields['custom_amount'].widget.attrs['min'] = club.min_amount
+
+ def clean(self):
+ state = {}
+ state['monthly'] = self.cleaned_data['switch'] == 'monthly'
+ which = 'monthly' if state['monthly'] else 'single'
+ state['amount'] = \
+ self.cleaned_data[f'{which}_amount'] or \
+ self.cleaned_data['custom_amount'] or \
+ self.cleaned_data[f'{which}_amount_selected']
+
+ return state
+
+
+
+class DonationStep2Form(forms.ModelForm, NewsletterForm):
+ class Meta:
+ model = models.Schedule
+ fields = [
+ 'first_name', 'last_name',
+ 'email', 'phone',
+ 'postal',
+ 'postal_code', 'postal_town', 'postal_country',
+ ]
+ widgets = {
+ 'amount': forms.HiddenInput,
+ 'monthly': forms.HiddenInput,
+ }
+
+ 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 save(self, *args, **kwargs):
+ NewsletterForm.save(self, *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
+