Better experiments management.
[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 = [
59         'email', 'started_at', 'payed_at', 'expires_at', 'amount', 'monthly', 'yearly', 'is_cancelled',
60         'method'
61     ]
62     search_fields = ['email']
63     list_filter = ['is_cancelled', 'monthly', 'yearly', 'method', PayedFilter, ExpiredFilter, 'source']
64     filter_horizontal = ['consent']
65     date_hierarchy = 'started_at'
66     raw_id_fields = ['membership']
67     inlines = [PayUOrderInline, PayUCardTokenInline]
68     actions = [export_as_csv_action()]
69
70 admin.site.register(models.Schedule, ScheduleAdmin)
71
72
73 class ScheduleInline(admin.TabularInline):
74     model = models.Schedule
75     fields = ['email', 'amount', 'is_cancelled', 'started_at', 'payed_at', 'expires_at', 'email_sent']
76     readonly_fields = fields
77     extra = 0
78     show_change_link = True
79     can_delete = False
80
81     def has_add_permission(self, request, obj):
82         return False
83
84
85 class MembershipAdmin(admin.ModelAdmin):
86     list_display = ['user', 'manual', 'updated_at', 'notes']
87     list_filter = ['manual']
88     date_hierarchy = 'updated_at'
89     raw_id_fields = ['user']
90     search_fields = ['user__username', 'user__email', 'schedule__email', 'notes']
91     inlines = [ScheduleInline]
92
93 admin.site.register(models.Membership, MembershipAdmin)
94
95
96 admin.site.register(models.ReminderEmail, TranslationAdmin)
97
98
99 class PayUNotificationAdmin(admin.ModelAdmin):
100     list_display = ['received_at', 'order']
101     fields = ['received_at', 'order', 'body_']
102     readonly_fields = ['received_at', 'body_']
103     raw_id_fields = ['order']
104
105     def body_(self, obj):
106         return mark_safe(
107                 "<pre>" +
108                 conditional_escape(json.dumps(json.loads(obj.body), indent=4))
109                 + "</pre>")
110
111
112 admin.site.register(models.PayUNotification, PayUNotificationAdmin)
113
114
115 class PayUNotificationInline(admin.TabularInline):
116     model = models.PayUNotification
117     fields = ['received_at', 'body_']
118     readonly_fields = fields
119     extra = 0
120     show_change_link = True
121     can_delete = False
122
123     def body_(self, obj):
124         return mark_safe(
125                 "<pre>" +
126                 conditional_escape(json.dumps(json.loads(obj.body), indent=4))
127                 + "</pre>")
128
129     def has_add_permission(self, request, obj):
130         return False
131
132
133 class PayUOrderAdmin(admin.ModelAdmin):
134     list_display = ['schedule']
135     raw_id_fields = ['schedule']
136     inlines = [PayUNotificationInline]
137
138
139 admin.site.register(models.PayUOrder, PayUOrderAdmin)
140
141
142 admin.site.register(models.Ambassador)
143
144
145     
146
147 @admin.register(models.Consent)
148 class ConsentAdmin(admin.ModelAdmin):
149     list_display = ['text', 'order', 'active', 'required']
150
151     def get_readonly_fields(self, request, obj=None):
152         if obj:
153             return ['text']
154         else:
155             return []