X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/b0fadf2591f3af957c1c8e0307d0bcef9e9f8538..131ae407ca583a8a8086cf94c222c85fa3f5be63:/src/club/admin.py diff --git a/src/club/admin.py b/src/club/admin.py index 2ba842a81..442592803 100644 --- a/src/club/admin.py +++ b/src/club/admin.py @@ -1,5 +1,5 @@ -# 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 @@ -8,9 +8,9 @@ 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 +import annoy.models from wolnelektury.utils import YesNoFilter from . import models @@ -57,17 +57,23 @@ 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) @@ -81,7 +87,7 @@ class ScheduleForm(forms.ModelForm): class SourceFilter(admin.SimpleListFilter): - title = _('Source') # display title + title = 'Źródło' # display title parameter_name = 'source' template = "admin/long_filter.html" @@ -90,14 +96,35 @@ class SourceFilter(admin.SimpleListFilter): (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 CrisisFilter(admin.SimpleListFilter): + title = 'czas zbiórki kryzysowej' + parameter_name = 'crisis' + + def lookups(self, request, model_admin): + lookups = [ + (b.id, '%s — %s' % (b.since, b.until)) for b in + annoy.models.Banner.objects.filter(place='crisis') + ] + return lookups + + def queryset(self, request, queryset): + bid = self.value() + if not bid: + return + try: + b = annoy.models.Banner.objects.get(id=self.value()) + except annoy.models.Banner.DoesNotExist: + return + return queryset.filter( + started_at__gte=b.since, + started_at__lte=b.until + ) @@ -112,8 +139,8 @@ class ScheduleAdmin(admin.ModelAdmin): search_fields = ['email', 'source'] list_filter = [ 'is_cancelled', 'monthly', 'yearly', 'method', - PayedFilter, ExpiredFilter, - SourceFilter, + PayedFilter, ActiveFilter, ExpiredFilter, + SourceFilter, CrisisFilter ] filter_horizontal = ['consent'] date_hierarchy = 'started_at'