django-orchestra-test/orchestra/apps/payments/admin.py

89 lines
3.2 KiB
Python
Raw Normal View History

2014-09-04 15:55:43 +00:00
from django import forms
2014-07-23 16:24:56 +00:00
from django.contrib import admin
2014-07-29 20:10:37 +00:00
from django.core.urlresolvers import reverse
from django.utils.translation import ugettext_lazy as _
2014-07-23 16:24:56 +00:00
2014-07-24 09:53:34 +00:00
from orchestra.admin.utils import admin_colored, admin_link
from orchestra.apps.accounts.admin import AccountAdminMixin
2014-07-24 09:53:34 +00:00
2014-07-29 20:10:37 +00:00
from .actions import process_transactions
2014-08-29 12:45:27 +00:00
from .methods import SEPADirectDebit
2014-07-29 20:10:37 +00:00
from .models import PaymentSource, Transaction, PaymentProcess
2014-07-23 16:24:56 +00:00
2014-07-24 09:53:34 +00:00
STATE_COLORS = {
Transaction.WAITTING_PROCESSING: 'darkorange',
2014-09-04 15:55:43 +00:00
Transaction.WAITTING_CONFIRMATION: 'purple',
2014-07-24 09:53:34 +00:00
Transaction.CONFIRMED: 'green',
Transaction.REJECTED: 'red',
Transaction.LOCKED: 'magenta',
Transaction.DISCARTED: 'blue',
}
2014-09-04 15:55:43 +00:00
class TransactionAdmin(AccountAdminMixin, admin.ModelAdmin):
2014-07-24 09:53:34 +00:00
list_display = (
2014-09-04 15:55:43 +00:00
'id', 'bill_link', 'account_link', 'source_link', 'display_state', 'amount'
2014-07-24 09:53:34 +00:00
)
list_filter = ('source__method', 'state')
2014-07-29 20:10:37 +00:00
actions = (process_transactions,)
2014-09-04 15:55:43 +00:00
filter_by_account_fields = ['source']
2014-07-24 09:53:34 +00:00
bill_link = admin_link('bill')
2014-09-04 15:55:43 +00:00
source_link = admin_link('source')
2014-07-24 09:53:34 +00:00
account_link = admin_link('bill__account')
display_state = admin_colored('state', colors=STATE_COLORS)
2014-08-19 18:59:23 +00:00
def get_queryset(self, request):
qs = super(TransactionAdmin, self).get_queryset(request)
return qs.select_related('source', 'bill__account__user')
2014-07-24 09:53:34 +00:00
class PaymentSourceAdmin(AccountAdminMixin, admin.ModelAdmin):
list_display = ('label', 'method', 'number', 'account_link', 'is_active')
list_filter = ('method', 'is_active')
2014-09-04 15:55:43 +00:00
def get_form(self, request, obj=None, **kwargs):
if obj:
self.form = obj.method_class().get_form()
else:
self.form = forms.ModelForm
return super(PaymentSourceAdmin, self).get_form(request, obj=obj, **kwargs)
2014-07-29 20:10:37 +00:00
class PaymentProcessAdmin(admin.ModelAdmin):
list_display = ('id', 'file_url', 'display_transactions', 'created_at')
fields = ('data', 'file_url', 'display_transactions', 'created_at')
readonly_fields = ('file_url', 'display_transactions', 'created_at')
def file_url(self, process):
if process.file:
return '<a href="%s">%s</a>' % (process.file.url, process.file.name)
file_url.allow_tags = True
file_url.admin_order_field = 'file'
def display_transactions(self, process):
ids = []
lines = []
counter = 0
2014-08-19 18:59:23 +00:00
# Because of values_list this query doesn't benefit from prefetch_related
tx_ids = process.transactions.values_list('id', flat=True)
for tx_id in tx_ids:
ids.append(str(tx_id))
counter += 1
if counter > 10:
counter = 0
lines.append(','.join(ids))
ids = []
lines.append(','.join(ids))
url = reverse('admin:payments_transaction_changelist')
url += '?processes=%i' % process.id
return '<a href="%s">%s</a>' % (url, '<br>'.join(lines))
2014-07-29 20:10:37 +00:00
display_transactions.short_description = _("Transactions")
display_transactions.allow_tags = True
admin.site.register(PaymentSource, PaymentSourceAdmin)
2014-07-24 09:53:34 +00:00
admin.site.register(Transaction, TransactionAdmin)
2014-07-29 20:10:37 +00:00
admin.site.register(PaymentProcess, PaymentProcessAdmin)