X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/3f527019946f993c9d1cadd41e80c2c7eac188ed..88eef14f0c0353b5b1c56bf8cf32c47a9e0fa1a0:/src/club/admin.py?ds=sidebyside diff --git a/src/club/admin.py b/src/club/admin.py index 1f3c837a7..2f07a4f41 100644 --- a/src/club/admin.py +++ b/src/club/admin.py @@ -1,3 +1,4 @@ + # This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later. # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # @@ -5,6 +6,7 @@ import json from django.contrib import admin from django.db.models.functions import Now from django.db.models import Q +from django import forms from django.utils.html import conditional_escape from django.utils.safestring import mark_safe from django.utils.translation import gettext_lazy as _ @@ -14,7 +16,20 @@ from wolnelektury.utils import YesNoFilter from . import models -admin.site.register(models.Club) +class SingleAmountInline(admin.TabularInline): + model = models.SingleAmount + + +class MonthlyAmountInline(admin.TabularInline): + model = models.MonthlyAmount + + +@admin.register(models.Club) +class ClubAdmin(admin.ModelAdmin): + inlines = [ + SingleAmountInline, + MonthlyAmountInline + ] class PayUOrderInline(admin.TabularInline): @@ -54,11 +69,26 @@ class ExpiredFilter(YesNoFilter): q = Q(expires_at__isnull=False, expires_at__lt=Now()) +class ScheduleForm(forms.ModelForm): + def __init__(self, *args, **kwargs): + super().__init__(*args, **kwargs) + self.fields['email'].required = False + self.fields['method'].required = False + self.fields['consent'].required = False + + class Meta: + model = models.Schedule + fields = '__all__' + + class ScheduleAdmin(admin.ModelAdmin): + form = ScheduleForm + list_display = [ 'email', 'started_at', 'payed_at', 'expires_at', 'amount', 'monthly', 'yearly', 'is_cancelled', 'method' ] + list_display_links = ['email', 'started_at'] search_fields = ['email'] list_filter = ['is_cancelled', 'monthly', 'yearly', 'method', PayedFilter, ExpiredFilter, 'source'] filter_horizontal = ['consent'] @@ -142,23 +172,6 @@ admin.site.register(models.PayUOrder, PayUOrderAdmin) admin.site.register(models.Ambassador) - -@admin.register(models.DirectDebit) -class DirectDebitAdmin(admin.ModelAdmin): - list_display = ['date', 'amount', 'first_name', 'last_name'] - fields = [ - ('first_name', 'sex', 'date_of_birth'), - 'last_name', - ('street', 'building'), - ('town', 'flat'), - ('postal_code', 'phone'), - 'email', - 'iban', - 'payment_id', - 'agree_newsletter', - 'date', - 'amount' - ] @admin.register(models.Consent)