fnp
/
wolnelektury.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add basic login.
[wolnelektury.git]
/
src
/
funding
/
forms.py
diff --git
a/src/funding/forms.py
b/src/funding/forms.py
index
ef79774
..
d910f57
100644
(file)
--- a/
src/funding/forms.py
+++ b/
src/funding/forms.py
@@
-1,36
+1,46
@@
-# This file is part of Wolne
l
ektury, licensed under GNU Affero GPLv3 or later.
-# Copyright © Fundacja
Nowoczesna Polska
. See NOTICE for more information.
+# This file is part of Wolne
L
ektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja
Wolne Lektury
. See NOTICE for more information.
#
from django import forms
from django.utils import formats
from django.utils.safestring import mark_safe
#
from django import forms
from django.utils import formats
from django.utils.safestring import mark_safe
-from django.utils.translation import
ugettext_lazy as _, u
gettext, get_language
+from django.utils.translation import
gettext_lazy as _,
gettext, get_language
from newsletter.forms import NewsletterForm
from newsletter.forms import NewsletterForm
+from club.payment_methods import PayU
from .models import Funding
from .widgets import PerksAmountWidget
from . import app_settings
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'
class FundingForm(NewsletterForm):
required_css_class = 'required'
- amount = forms.DecimalField(label=_("
Amount
"), decimal_places=2, widget=PerksAmountWidget())
+ amount = forms.DecimalField(label=_("
Kwota
"), decimal_places=2, widget=PerksAmountWidget())
name = forms.CharField(
name = forms.CharField(
- label=_("Name"), required=False, help_text=_("Optional name for public list of contributors"))
+ label=_("Imię i nazwisko na listę darczyńców"),
+ required=False,
+ help_text=_("Opcjonalnie imię i nazwisko lub pseudonim do publicznej listy darczyńców.")
+ )
email = forms.EmailField(
email = forms.EmailField(
- label=_("
Contact e-mail
"),
+ label=_("
E-mail kontaktowy
"),
help_text=mark_safe(_(
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).<br/>"
- "Your e-mail won't be publicised.")), required=False)
+ "Użyjemy go do informowania Cię o zmianach statusu płatności i zbiórki "
+ "(z czego zawsze możesz zrezygnować).<br/>"
+ "Twój adres e-mail nie będzie upubliczniony.")),
+ required=False)
- data_processing_part2 = '''\
+ data_processing_part2 =
_(
'''\
W przypadku podania danych zostaną one wykorzystane w sposób podany powyżej, a w przypadku wyrażenia dodatkowej zgody
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.'''
+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.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
super(FundingForm, self).__init__(*args, **kwargs)
self.fields['amount'].widget.form_instance = self
@@
-40,13
+50,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(
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("Minimalna kwota wpłaty to %(amount)s zł
.") % {
'amount': min_amount})
return self.cleaned_data['amount']
def clean(self):
if not self.offer.is_current():
'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("Ta zbiórka jest już nieaktywna
."))
return self.cleaned_data
def save(self):
return self.cleaned_data
def save(self):
@@
-57,6
+67,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(),
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.set(funding.offer.get_perks(funding.amount))
return funding
)
funding.perks.set(funding.offer.get_perks(funding.amount))
return funding