X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/149ca28f533a257ed8034f88a615c8d7abbc9f69..131ae407ca583a8a8086cf94c222c85fa3f5be63:/src/club/admin.py?ds=inline diff --git a/src/club/admin.py b/src/club/admin.py index 2f07a4f41..442592803 100644 --- a/src/club/admin.py +++ b/src/club/admin.py @@ -1,6 +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 @@ -9,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 @@ -58,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,6 +86,48 @@ class ScheduleForm(forms.ModelForm): 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] + ] + return lookups + + def queryset(self, request, queryset): + return queryset + + +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 + ) + + + class ScheduleAdmin(admin.ModelAdmin): form = ScheduleForm @@ -89,8 +136,12 @@ class ScheduleAdmin(admin.ModelAdmin): 'method' ] list_display_links = ['email', 'started_at'] - search_fields = ['email'] - list_filter = ['is_cancelled', 'monthly', 'yearly', 'method', PayedFilter, ExpiredFilter, 'source'] + search_fields = ['email', 'source'] + list_filter = [ + 'is_cancelled', 'monthly', 'yearly', 'method', + PayedFilter, ActiveFilter, ExpiredFilter, + SourceFilter, CrisisFilter + ] filter_horizontal = ['consent'] date_hierarchy = 'started_at' raw_id_fields = ['membership']