Experiments page.
[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 class SingleAmountInline(admin.TabularInline):
18     model = models.SingleAmount
19
20
21 class MonthlyAmountInline(admin.TabularInline):
22     model = models.MonthlyAmount
23
24
25 @admin.register(models.Club)
26 class ClubAdmin(admin.ModelAdmin):
27     inlines = [
28         SingleAmountInline,
29         MonthlyAmountInline
30     ]
31
32
33 class PayUOrderInline(admin.TabularInline):
34     model = models.PayUOrder
35     fields = ['order_id', 'status', 'customer_ip']
36     readonly_fields = fields
37     extra = 0
38     show_change_link = True
39     can_delete = False
40
41     def has_add_permission(self, request, obj):
42         return False
43
44
45 class PayUCardTokenInline(admin.TabularInline):
46     model = models.PayUCardToken
47     fields = ['created_at', 'disposable_token', 'reusable_token']
48     readonly_fields = fields
49     extra = 0
50     show_change_link = True
51     can_delete = False
52     show_change_link = True
53
54     def has_add_permission(self, request, obj):
55         return False
56
57
58 class PayedFilter(YesNoFilter):
59     title = _('payment complete')
60     parameter_name = 'payed'
61     q = ~Q(payed_at=None)
62
63
64 class ExpiredFilter(YesNoFilter):
65     title = _('schedule expired')
66     parameter_name = 'expired'
67     q = Q(expires_at__isnull=False, expires_at__lt=Now())
68
69
70 class ScheduleAdmin(admin.ModelAdmin):
71     list_display = [
72         'email', 'started_at', 'payed_at', 'expires_at', 'amount', 'monthly', 'yearly', 'is_cancelled',
73         'method'
74     ]
75     search_fields = ['email']
76     list_filter = ['is_cancelled', 'monthly', 'yearly', 'method', PayedFilter, ExpiredFilter, 'source']
77     filter_horizontal = ['consent']
78     date_hierarchy = 'started_at'
79     raw_id_fields = ['membership']
80     inlines = [PayUOrderInline, PayUCardTokenInline]
81     actions = [export_as_csv_action()]
82
83 admin.site.register(models.Schedule, ScheduleAdmin)
84
85
86 class ScheduleInline(admin.TabularInline):
87     model = models.Schedule
88     fields = ['email', 'amount', 'is_cancelled', 'started_at', 'payed_at', 'expires_at', 'email_sent']
89     readonly_fields = fields
90     extra = 0
91     show_change_link = True
92     can_delete = False
93
94     def has_add_permission(self, request, obj):
95         return False
96
97
98 class MembershipAdmin(admin.ModelAdmin):
99     list_display = ['user', 'manual', 'updated_at', 'notes']
100     list_filter = ['manual']
101     date_hierarchy = 'updated_at'
102     raw_id_fields = ['user']
103     search_fields = ['user__username', 'user__email', 'schedule__email', 'notes']
104     inlines = [ScheduleInline]
105
106 admin.site.register(models.Membership, MembershipAdmin)
107
108
109 admin.site.register(models.ReminderEmail, TranslationAdmin)
110
111
112 class PayUNotificationAdmin(admin.ModelAdmin):
113     list_display = ['received_at', 'order']
114     fields = ['received_at', 'order', 'body_']
115     readonly_fields = ['received_at', 'body_']
116     raw_id_fields = ['order']
117
118     def body_(self, obj):
119         return mark_safe(
120                 "<pre>" +
121                 conditional_escape(json.dumps(json.loads(obj.body), indent=4))
122                 + "</pre>")
123
124
125 admin.site.register(models.PayUNotification, PayUNotificationAdmin)
126
127
128 class PayUNotificationInline(admin.TabularInline):
129     model = models.PayUNotification
130     fields = ['received_at', 'body_']
131     readonly_fields = fields
132     extra = 0
133     show_change_link = True
134     can_delete = False
135
136     def body_(self, obj):
137         return mark_safe(
138                 "<pre>" +
139                 conditional_escape(json.dumps(json.loads(obj.body), indent=4))
140                 + "</pre>")
141
142     def has_add_permission(self, request, obj):
143         return False
144
145
146 class PayUOrderAdmin(admin.ModelAdmin):
147     list_display = ['schedule']
148     raw_id_fields = ['schedule']
149     inlines = [PayUNotificationInline]
150
151
152 admin.site.register(models.PayUOrder, PayUOrderAdmin)
153
154
155 admin.site.register(models.Ambassador)
156
157
158     
159
160 @admin.register(models.Consent)
161 class ConsentAdmin(admin.ModelAdmin):
162     list_display = ['text', 'order', 'active', 'required']
163
164     def get_readonly_fields(self, request, obj=None):
165         if obj:
166             return ['text']
167         else:
168             return []