X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/6034428b14b634d1801e2d8279b1a0863b918a48..9fa9848eda1f2f714d0c65eee0ffc6b65e1de4cc:/src/club/forms.py?ds=inline diff --git a/src/club/forms.py b/src/club/forms.py index b818d1c12..8df778338 100644 --- a/src/club/forms.py +++ b/src/club/forms.py @@ -1,45 +1,27 @@ +# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later. +# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. +# from decimal import Decimal from django import forms from . import models -from .payment_methods import method_by_slug, methods from .payu.forms import CardTokenForm class ScheduleForm(forms.ModelForm): class Meta: model = models.Schedule - fields = ['plan', 'method', 'amount', 'email'] + fields = ['monthly', 'amount', 'email'] widgets = { - 'plan': forms.RadioSelect, - 'method': forms.RadioSelect, + 'amount': forms.HiddenInput, + 'monthly': forms.HiddenInput, } - def __init__(self, *args, request=None, **kwargs): - super(ScheduleForm, self).__init__(*args, **kwargs) - self.request = request - self.plans = models.Plan.objects.all() - self.payment_methods = methods - self.fields['amount'].required = False - - def clean(self): - cleaned_data = super(ScheduleForm, self).clean() - - if 'plan' in cleaned_data: - cleaned_data['amount'] = self.fields['amount'].clean( - self.request.POST['amount-{}'.format(cleaned_data['plan'].id)] - ) - - if cleaned_data['amount'] < cleaned_data['plan'].min_amount: - self.add_error( - 'amount', - 'Minimalna kwota dla tego planu to %d zł.' % cleaned_data['plan'].min_amount - ) - - if 'method' in cleaned_data: - method = method_by_slug[cleaned_data['method']] - if method not in cleaned_data['plan'].payment_methods(): - self.add_error('method', 'Wybrana metoda płatności nie jest dostępna dla tego planu.') - + def clean_amount(self): + value = self.cleaned_data['amount'] + club = models.Club.objects.first() + if club and value < club.min_amount: + raise forms.ValidationError('Minimalna kwota to %d zł.' % club.min_amount) + return value class PayUCardTokenForm(CardTokenForm):