X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/97c8c6d7c7961976172bece182832d01c9c0fc4b..a844cd31e6a3053be61ce26a6bae5269c13bca62:/src/club/admin.py diff --git a/src/club/admin.py b/src/club/admin.py index e0beaeada..79b76cf21 100644 --- a/src/club/admin.py +++ b/src/club/admin.py @@ -3,9 +3,13 @@ # import json from django.contrib import admin +from django.db.models.functions import Now +from django.db.models import Q from django.utils.html import conditional_escape from django.utils.safestring import mark_safe +from django.utils.translation import gettext_lazy as _ from modeltranslation.admin import TranslationAdmin +from wolnelektury.utils import YesNoFilter from . import models @@ -37,10 +41,22 @@ class PayUCardTokenInline(admin.TabularInline): return False +class PayedFilter(YesNoFilter): + title = _('payment complete') + parameter_name = 'payed' + q = ~Q(payed_at=None) + + +class ExpiredFilter(YesNoFilter): + title = _('schedule expired') + parameter_name = 'expired' + q = Q(expires_at__isnull=False, expires_at__lt=Now()) + + class ScheduleAdmin(admin.ModelAdmin): list_display = ['email', 'started_at', 'payed_at', 'expires_at', 'amount', 'monthly', 'yearly', 'is_cancelled'] - list_search = ['email'] - list_filter = ['is_cancelled'] + search_fields = ['email'] + list_filter = ['is_cancelled', 'monthly', 'yearly', PayedFilter, ExpiredFilter] date_hierarchy = 'started_at' raw_id_fields = ['membership'] inlines = [PayUOrderInline, PayUCardTokenInline]