X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/6d42bc478e3d1bd90eb294464748c21e4de0fc63..5abc88f0d2ad3036dd526fbff5f0241f1d6480e1:/src/funding/forms.py
diff --git a/src/funding/forms.py b/src/funding/forms.py
index 915e2aa09..e055faf93 100644
--- a/src/funding/forms.py
+++ b/src/funding/forms.py
@@ -4,14 +4,18 @@
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 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
+payment_method = PayU(app_settings.PAYU_POS)
+
+
class FundingForm(NewsletterForm):
required_css_class = 'required'
@@ -21,16 +25,18 @@ class FundingForm(NewsletterForm):
email = forms.EmailField(
label=_("Contact e-mail"),
help_text=mark_safe(_(
- "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).
"
+ "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
@@ -40,13 +46,13 @@ adres e-mail zostanie wykorzystany także w celu przesyÅania newslettera Wolnyc
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):
@@ -57,6 +63,9 @@ adres e-mail zostanie wykorzystany także w celu przesyÅania newslettera Wolnyc
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