X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/86ece3be121fe57d58e76bffcd52713d413cacc1..9a0ea819fa5bfd8bce2e2500fbfc0cfcc75eff08:/src/funding/forms.py diff --git a/src/funding/forms.py b/src/funding/forms.py index 8f1c3be4b..d910f574f 100644 --- a/src/funding/forms.py +++ b/src/funding/forms.py @@ -1,32 +1,46 @@ -# -*- 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. +# This file is part of Wolne Lektury, 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.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 +payment_method = PayU(app_settings.PAYU_POS) + + 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( - 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( - 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) + label=_("E-mail kontaktowy"), + help_text=mark_safe(_( + "Użyjemy go do informowania Cię o zmianach statusu płatności i zbiórki " + "(z czego zawsze możesz zrezygnować).
" + "Twój adres e-mail nie będzie upubliczniony.")), + 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 @@ -36,13 +50,13 @@ class FundingForm(NewsletterForm): 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(): - 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): @@ -53,6 +67,9 @@ class FundingForm(NewsletterForm): 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