Python 3
[wolnelektury.git] / src / funding / forms.py
index 6ed9076..1c85135 100644 (file)
@@ -4,23 +4,31 @@
 #
 from django import forms
 from django.utils import formats
+from django.utils.safestring import mark_safe
 from django.utils.translation import ugettext_lazy as _, ugettext, get_language
+
+from newsletter.forms import NewsletterForm
 from .models import Funding
 from .widgets import PerksAmountWidget
 from . import app_settings
 
 
-class FundingForm(forms.Form):
+class FundingForm(NewsletterForm):
     required_css_class = 'required'
 
-    amount = forms.DecimalField(label=_("Amount"), decimal_places=2,
-        widget=PerksAmountWidget())
-    name = forms.CharField(label=_("Name"), required=False,
-        help_text=_("Optional name for public list of contributors"))
-    email = forms.EmailField(label=_("Contact e-mail"),
-        help_text=_("We'll use it to contact you about the <strong>details needed for your perks</strong>,<br/>"
+    amount = forms.DecimalField(label=_("Amount"), decimal_places=2, widget=PerksAmountWidget())
+    name = forms.CharField(
+        label=_("Name"), required=False, help_text=_("Optional name for public list of contributors"))
+    email = forms.EmailField(
+        label=_("Contact e-mail"),
+        help_text=mark_safe(_(
+            "We'll use it to contact you about the <strong>details needed for your perks</strong>,<br/>"
             "and to send you updates about your payment and the fundraiser status (which you can always turn off).<br/>"
-            "Your e-mail won't be publicised."), required=False)
+            "Your e-mail won't be publicised.")), required=False)
+
+    data_processing_part2 = u'''\
+W przypadku podania danych zostaną one wykorzystane w sposób podany powyżej, a w przypadku wyrażenia dodatkowej zgody 
+adres e-mail zostanie wykorzystany także w celu przesyłania newslettera Wolnych Lektur.'''
 
     def __init__(self, offer, *args, **kwargs):
         self.offer = offer
@@ -43,6 +51,7 @@ class FundingForm(forms.Form):
         return self.cleaned_data
 
     def save(self):
+        super(FundingForm, self).save()
         funding = Funding.objects.create(
             offer=self.offer,
             name=self.cleaned_data['name'],
@@ -52,4 +61,3 @@ class FundingForm(forms.Form):
         )
         funding.perks = funding.offer.get_perks(funding.amount)
         return funding
-