X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/750d370ba7b4df0c5c8f775d1b1443883abd2bf9..2954f0e21a4c9adf96bb63c85339e7fa79d78e22:/src/club/admin.py?ds=sidebyside diff --git a/src/club/admin.py b/src/club/admin.py index d966ad64d..fc715e2cd 100644 --- a/src/club/admin.py +++ b/src/club/admin.py @@ -1,20 +1,33 @@ -# 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. # 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 _ from fnpdjango.actions import export_as_csv_action from modeltranslation.admin import TranslationAdmin 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): @@ -43,24 +56,70 @@ class PayUCardTokenInline(admin.TabularInline): class PayedFilter(YesNoFilter): - title = _('payment complete') + title = 'płatność zakończona' parameter_name = 'payed' q = ~Q(payed_at=None) class ExpiredFilter(YesNoFilter): - title = _('schedule expired') + title = 'harmonogram przedawniony' parameter_name = 'expired' q = Q(expires_at__isnull=False, expires_at__lt=Now()) +class ActiveFilter(YesNoFilter): + title = 'płatność aktualna' + parameter_name = 'active' + q = Q(expires_at__gt=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 SourceFilter(admin.SimpleListFilter): + title = 'Źródło' # display title + parameter_name = 'source' + template = "admin/long_filter.html" + + def lookups(self, request, model_admin): + lookups = [ + (m, m) for m in + model_admin.model.objects.exclude(source='').values_list('source', flat=True).distinct()[:10] + ] + print(lookups) + return lookups + + def queryset(self, request, queryset): + return queryset + + #field_name = 'source' # name of the foreign key field + + + + class ScheduleAdmin(admin.ModelAdmin): + form = ScheduleForm + list_display = [ 'email', 'started_at', 'payed_at', 'expires_at', 'amount', 'monthly', 'yearly', 'is_cancelled', 'method' ] - search_fields = ['email'] - list_filter = ['is_cancelled', 'monthly', 'yearly', 'method', PayedFilter, ExpiredFilter, 'source'] + list_display_links = ['email', 'started_at'] + search_fields = ['email', 'source'] + list_filter = [ + 'is_cancelled', 'monthly', 'yearly', 'method', + PayedFilter, ActiveFilter, ExpiredFilter, + SourceFilter, + ] filter_horizontal = ['consent'] date_hierarchy = 'started_at' raw_id_fields = ['membership']