Fundraising in PDF.
[wolnelektury.git] / src / club / admin.py
1 # This file is part of Wolne Lektury, licensed under GNU Affero GPLv3 or later.
2 # Copyright © Fundacja Wolne Lektury. 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 import forms
9 from django.utils.html import conditional_escape
10 from django.utils.safestring import mark_safe
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 = 'płatność zakończona'
60     parameter_name = 'payed'
61     q = ~Q(payed_at=None)
62
63
64 class ExpiredFilter(YesNoFilter):
65     title = 'harmonogram przedawniony'
66     parameter_name = 'expired'
67     q = Q(expires_at__isnull=False, expires_at__lt=Now())
68
69
70 class ScheduleForm(forms.ModelForm):
71     def __init__(self, *args, **kwargs):
72         super().__init__(*args, **kwargs)
73         self.fields['email'].required = False
74         self.fields['method'].required = False
75         self.fields['consent'].required = False
76
77     class Meta:
78         model = models.Schedule
79         fields = '__all__'
80
81
82 class SourceFilter(admin.SimpleListFilter):
83     title = 'Źródło' # display title
84     parameter_name = 'source'
85     template = "admin/long_filter.html"
86
87     def lookups(self, request, model_admin):
88         lookups = [
89             (m, m) for m in
90             model_admin.model.objects.exclude(source='').values_list('source', flat=True).distinct()[:10]
91         ]
92         print(lookups)
93         return lookups
94
95     def queryset(self, request, queryset):
96         return queryset
97     
98     #field_name = 'source' # name of the foreign key field
99
100
101
102
103 class ScheduleAdmin(admin.ModelAdmin):
104     form = ScheduleForm
105
106     list_display = [
107         'email', 'started_at', 'payed_at', 'expires_at', 'amount', 'monthly', 'yearly', 'is_cancelled',
108         'method'
109     ]
110     list_display_links = ['email', 'started_at']
111     search_fields = ['email', 'source']
112     list_filter = [
113         'is_cancelled', 'monthly', 'yearly', 'method',
114         PayedFilter, ExpiredFilter,
115         SourceFilter,
116     ]
117     filter_horizontal = ['consent']
118     date_hierarchy = 'started_at'
119     raw_id_fields = ['membership']
120     inlines = [PayUOrderInline, PayUCardTokenInline]
121     actions = [export_as_csv_action()]
122
123 admin.site.register(models.Schedule, ScheduleAdmin)
124
125
126 class ScheduleInline(admin.TabularInline):
127     model = models.Schedule
128     fields = ['email', 'amount', 'is_cancelled', 'started_at', 'payed_at', 'expires_at', 'email_sent']
129     readonly_fields = fields
130     extra = 0
131     show_change_link = True
132     can_delete = False
133
134     def has_add_permission(self, request, obj):
135         return False
136
137
138 class MembershipAdmin(admin.ModelAdmin):
139     list_display = ['user', 'manual', 'updated_at', 'notes']
140     list_filter = ['manual']
141     date_hierarchy = 'updated_at'
142     raw_id_fields = ['user']
143     search_fields = ['user__username', 'user__email', 'schedule__email', 'notes']
144     inlines = [ScheduleInline]
145
146 admin.site.register(models.Membership, MembershipAdmin)
147
148
149 admin.site.register(models.ReminderEmail, TranslationAdmin)
150
151
152 class PayUNotificationAdmin(admin.ModelAdmin):
153     list_display = ['received_at', 'order']
154     fields = ['received_at', 'order', 'body_']
155     readonly_fields = ['received_at', 'body_']
156     raw_id_fields = ['order']
157
158     def body_(self, obj):
159         return mark_safe(
160                 "<pre>" +
161                 conditional_escape(json.dumps(json.loads(obj.body), indent=4))
162                 + "</pre>")
163
164
165 admin.site.register(models.PayUNotification, PayUNotificationAdmin)
166
167
168 class PayUNotificationInline(admin.TabularInline):
169     model = models.PayUNotification
170     fields = ['received_at', 'body_']
171     readonly_fields = fields
172     extra = 0
173     show_change_link = True
174     can_delete = False
175
176     def body_(self, obj):
177         return mark_safe(
178                 "<pre>" +
179                 conditional_escape(json.dumps(json.loads(obj.body), indent=4))
180                 + "</pre>")
181
182     def has_add_permission(self, request, obj):
183         return False
184
185
186 class PayUOrderAdmin(admin.ModelAdmin):
187     list_display = ['schedule']
188     raw_id_fields = ['schedule']
189     inlines = [PayUNotificationInline]
190
191
192 admin.site.register(models.PayUOrder, PayUOrderAdmin)
193
194
195 admin.site.register(models.Ambassador)
196
197
198     
199
200 @admin.register(models.Consent)
201 class ConsentAdmin(admin.ModelAdmin):
202     list_display = ['text', 'order', 'active', 'required']
203
204     def get_readonly_fields(self, request, obj=None):
205         if obj:
206             return ['text']
207         else:
208             return []