admin.py 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. from django.contrib import admin, messages
  2. from django.core.urlresolvers import reverse
  3. from django.utils.encoding import force_text
  4. from django.utils.safestring import mark_safe
  5. from .models import (
  6. Document, Cost, Good, CostUse, GoodUse, Service, ServiceUse)
  7. class GoodInline(admin.TabularInline):
  8. model = Good
  9. extra = 0
  10. exclude = ['description_html']
  11. class CostInline(admin.TabularInline):
  12. model = Cost
  13. extra = 0
  14. exclude = ['description_html']
  15. class ServiceInline(admin.TabularInline):
  16. model = Service
  17. fields = ('name', 'monthly_unit_cost', 'new_subscriber_cost')
  18. readonly_fields = ('name', 'monthly_unit_cost', 'new_subscriber_cost')
  19. show_change_link = True
  20. extra = 0
  21. def monthly_unit_cost(self, obj):
  22. return '{:.2f}€'.format(obj.get_prices()['unit_recurring_price'])
  23. monthly_unit_cost.short_description = "Coût de revient mensuel"
  24. def new_subscriber_cost(self, obj):
  25. return '{:.2f}€'.format(obj.get_prices()['total_goods_value_share'])
  26. new_subscriber_cost.short_description = "Coût nouv. abo"
  27. @admin.register(Document)
  28. class DocumentAdmin(admin.ModelAdmin):
  29. list_display = ('name', 'date', 'type')
  30. actions = ['copy']
  31. inlines = [ServiceInline, GoodInline, CostInline]
  32. save_on_top = True
  33. def copy(self, request, queryset):
  34. for i in queryset.all():
  35. new = i.copy()
  36. edit_url = reverse('admin:costs_document_change', args=(new.pk,))
  37. self.message_user(
  38. request, mark_safe(
  39. "{} copié, pensez à <a href=\"{}\">L'éditer</a>".format(
  40. new, edit_url)))
  41. copy.short_description = 'Copier'
  42. class AbstractUseInline(admin.TabularInline):
  43. """ An inline with some knowledge of the currently edited Document
  44. """
  45. def formfield_for_foreignkey(self, db_field, request, **kwargs):
  46. if db_field.name == "resource" and getattr(request, 'document', None):
  47. kwargs["queryset"] = db_field.related_model.objects.filter(
  48. document=request.document)
  49. return super().formfield_for_foreignkey(
  50. db_field, request, **kwargs)
  51. class GoodUseInline(AbstractUseInline):
  52. model = GoodUse
  53. extra = 1
  54. class CostUseInline(AbstractUseInline):
  55. model = CostUse
  56. extra = 1
  57. class ServiceUseInline(AbstractUseInline):
  58. model = ServiceUse
  59. extra = 1
  60. fk_name = 'service'
  61. class DirectDocumentFilter(admin.SimpleListFilter):
  62. title = 'Document'
  63. parameter_name = 'document'
  64. def queryset(self, request, queryset):
  65. document = self.value()
  66. if not document:
  67. return queryset.none()
  68. else:
  69. return queryset.filter(document=document)
  70. def lookups(self, request, model_admin):
  71. for i in Document.objects.all():
  72. yield i.pk, str(i)
  73. def choices(self, changelist):
  74. """ Same as base SimpleListFilter but do not display the "All" choice
  75. """
  76. for lookup, title in self.lookup_choices:
  77. yield {
  78. 'selected': self.value() == force_text(lookup),
  79. 'query_string': changelist.get_query_string(
  80. {self.parameter_name: lookup}, []),
  81. 'display': title,
  82. }
  83. @admin.register(Service)
  84. class ServiceAdmin(admin.ModelAdmin):
  85. list_display = (
  86. 'name', 'subscriptions_count', 'document',
  87. 'monthly_unit_cost', 'new_subscriber_cost')
  88. inlines = (CostUseInline, GoodUseInline, ServiceUseInline)
  89. list_filter = [DirectDocumentFilter]
  90. fieldsets = (
  91. (None, {
  92. 'fields': (
  93. ('name', 'document'), 'description', 'subscriptions_count'),
  94. }),
  95. ('Ré-utilisabilité', {
  96. 'fields': ('reusable',)
  97. })
  98. )
  99. save_on_top = True
  100. def get_form(self, request, obj=None, **kwargs):
  101. if obj:
  102. # anotate the request with some context
  103. request.document = obj.document
  104. else:
  105. doc_pk = request.GET.get('document')
  106. if doc_pk:
  107. request.document = Document.objects.get(pk=doc_pk)
  108. else:
  109. request.document = None
  110. if request.method == 'GET':
  111. self.message_user(
  112. request,
  113. 'Il est nécessaire de faire "Enregistrer et continuer"'
  114. ' pour ajouter des ressources au service',
  115. messages.WARNING)
  116. return super().get_form(request, obj, **kwargs)
  117. def get_inline_instances(self, request, obj=None):
  118. if getattr(request, 'document', None):
  119. return super().get_inline_instances(request, obj)
  120. else:
  121. return []
  122. def monthly_unit_cost(self, obj):
  123. return '{:.2f}€'.format(obj.get_prices()['unit_recurring_price'])
  124. def new_subscriber_cost(self, obj):
  125. return '{:.2f}€'.format(obj.get_prices()['total_goods_value_share'])