X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/b2d342589a7889a3b096e7192453d53bd28eed7d..4b2c05eedf0c6b3d213ce0b760d641c345e3c9b3:/src/funding/forms.py
diff --git a/src/funding/forms.py b/src/funding/forms.py
index 6feb104c9..e055faf93 100644
--- a/src/funding/forms.py
+++ b/src/funding/forms.py
@@ -1,16 +1,22 @@
-# -*- coding: utf-8 -*-
# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
#
from django import forms
from django.utils import formats
-from django.utils.translation import ugettext_lazy as _, ugettext, get_language
+from django.utils.safestring import mark_safe
+from django.utils.translation import gettext_lazy as _, gettext, get_language
+
+from newsletter.forms import NewsletterForm
+from club.payment_methods import PayU
from .models import Funding
from .widgets import PerksAmountWidget
from . import app_settings
-class FundingForm(forms.Form):
+payment_method = PayU(app_settings.PAYU_POS)
+
+
+class FundingForm(NewsletterForm):
required_css_class = 'required'
amount = forms.DecimalField(label=_("Amount"), decimal_places=2, widget=PerksAmountWidget())
@@ -18,13 +24,19 @@ class FundingForm(forms.Form):
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 details needed for your perks,
"
- "and to send you updates about your payment and the fundraiser status (which you can always turn off).
"
- "Your e-mail won't be publicised."), required=False)
+ help_text=mark_safe(_(
+ "We'll use it to "
+ "send you updates about your payment and the fundraiser status (which you can always turn off).
"
+ "Your e-mail won't be publicised.")), required=False)
+
+ data_processing_part2 = '''\
+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):
+ def __init__(self, request, offer, *args, **kwargs):
self.offer = offer
+ self.user = request.user if request.user.is_authenticated else None
+ self.client_ip = request.META['REMOTE_ADDR']
super(FundingForm, self).__init__(*args, **kwargs)
self.fields['amount'].widget.form_instance = self
@@ -34,22 +46,26 @@ class FundingForm(forms.Form):
if isinstance(min_amount, float):
min_amount = formats.number_format(min_amount, 2)
raise forms.ValidationError(
- ugettext("The minimum amount is %(amount)s PLN.") % {
+ gettext("The minimum amount is %(amount)s PLN.") % {
'amount': min_amount})
return self.cleaned_data['amount']
def clean(self):
if not self.offer.is_current():
- raise forms.ValidationError(ugettext("This offer is out of date."))
+ raise forms.ValidationError(gettext("This offer is out of date."))
return self.cleaned_data
def save(self):
+ super(FundingForm, self).save()
funding = Funding.objects.create(
offer=self.offer,
name=self.cleaned_data['name'],
email=self.cleaned_data['email'],
amount=self.cleaned_data['amount'],
language_code=get_language(),
+ user=self.user,
+ pos_id=payment_method.pos_id,
+ customer_ip=self.client_ip,
)
- funding.perks = funding.offer.get_perks(funding.amount)
+ funding.perks.set(funding.offer.get_perks(funding.amount))
return funding