direct debits
[wolnelektury.git] / src / club / admin.py
1 # This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
2 # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
3 #
4 import json
5 from django.contrib import admin
6 from django.db.models.functions import Now
7 from django.db.models import Q
8 from django.utils.html import conditional_escape
9 from django.utils.safestring import mark_safe
10 from django.utils.translation import gettext_lazy as _
11 from fnpdjango.actions import export_as_csv_action
12 from modeltranslation.admin import TranslationAdmin
13 from wolnelektury.utils import YesNoFilter
14 from . import models
15
16
17 admin.site.register(models.Club)
18
19
20 class PayUOrderInline(admin.TabularInline):
21     model = models.PayUOrder
22     fields = ['order_id', 'status', 'customer_ip']
23     readonly_fields = fields
24     extra = 0
25     show_change_link = True
26     can_delete = False
27
28     def has_add_permission(self, request, obj):
29         return False
30
31
32 class PayUCardTokenInline(admin.TabularInline):
33     model = models.PayUCardToken
34     fields = ['created_at', 'disposable_token', 'reusable_token']
35     readonly_fields = fields
36     extra = 0
37     show_change_link = True
38     can_delete = False
39     show_change_link = True
40
41     def has_add_permission(self, request, obj):
42         return False
43
44
45 class PayedFilter(YesNoFilter):
46     title = _('payment complete')
47     parameter_name = 'payed'
48     q = ~Q(payed_at=None)
49
50
51 class ExpiredFilter(YesNoFilter):
52     title = _('schedule expired')
53     parameter_name = 'expired'
54     q = Q(expires_at__isnull=False, expires_at__lt=Now())
55
56
57 class ScheduleAdmin(admin.ModelAdmin):
58     list_display = ['email', 'started_at', 'payed_at', 'expires_at', 'amount', 'monthly', 'yearly', 'is_cancelled']
59     search_fields = ['email']
60     list_filter = ['is_cancelled', 'monthly', 'yearly', PayedFilter, ExpiredFilter, 'source']
61     date_hierarchy = 'started_at'
62     raw_id_fields = ['membership']
63     inlines = [PayUOrderInline, PayUCardTokenInline]
64     actions = [export_as_csv_action()]
65
66 admin.site.register(models.Schedule, ScheduleAdmin)
67
68
69 class ScheduleInline(admin.TabularInline):
70     model = models.Schedule
71     fields = ['email', 'amount', 'is_cancelled', 'started_at', 'payed_at', 'expires_at', 'email_sent']
72     readonly_fields = fields
73     extra = 0
74     show_change_link = True
75     can_delete = False
76
77     def has_add_permission(self, request, obj):
78         return False
79
80
81 class MembershipAdmin(admin.ModelAdmin):
82     list_display = ['user', 'manual', 'updated_at', 'notes']
83     list_filter = ['manual']
84     date_hierarchy = 'updated_at'
85     raw_id_fields = ['user']
86     search_fields = ['user__username', 'user__email', 'schedule__email', 'notes']
87     inlines = [ScheduleInline]
88
89 admin.site.register(models.Membership, MembershipAdmin)
90
91
92 admin.site.register(models.ReminderEmail, TranslationAdmin)
93
94
95 class PayUNotificationAdmin(admin.ModelAdmin):
96     list_display = ['received_at', 'order']
97     fields = ['received_at', 'order', 'body_']
98     readonly_fields = ['received_at', 'body_']
99     raw_id_fields = ['order']
100
101     def body_(self, obj):
102         return mark_safe(
103                 "<pre>" +
104                 conditional_escape(json.dumps(json.loads(obj.body), indent=4))
105                 + "</pre>")
106
107
108 admin.site.register(models.PayUNotification, PayUNotificationAdmin)
109
110
111 class PayUNotificationInline(admin.TabularInline):
112     model = models.PayUNotification
113     fields = ['received_at', 'body_']
114     readonly_fields = fields
115     extra = 0
116     show_change_link = True
117     can_delete = False
118
119     def body_(self, obj):
120         return mark_safe(
121                 "<pre>" +
122                 conditional_escape(json.dumps(json.loads(obj.body), indent=4))
123                 + "</pre>")
124
125     def has_add_permission(self, request, obj):
126         return False
127
128
129 class PayUOrderAdmin(admin.ModelAdmin):
130     list_display = ['schedule']
131     raw_id_fields = ['schedule']
132     inlines = [PayUNotificationInline]
133
134
135 admin.site.register(models.PayUOrder, PayUOrderAdmin)
136
137
138 admin.site.register(models.Ambassador)
139
140
141
142 @admin.register(models.DirectDebit)
143 class DirectDebitAdmin(admin.ModelAdmin):
144     list_display = ['date', 'amount', 'first_name', 'last_name']
145     fields = [
146         ('first_name', 'sex', 'date_of_birth'),
147         'last_name',
148         ('street', 'building'),
149         ('town', 'flat'),
150         ('postal_code', 'phone'),
151         'email',
152         'iban',
153         'payment_id',
154         'agree_newsletter',
155         'date',
156         'amount'
157     ]
158