123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286 |
- # -*- coding: utf-8 -*-
- from __future__ import unicode_literals
- from django.contrib import admin
- from django.contrib.auth import get_user_model
- from django.forms import ModelChoiceField
- import autocomplete_light
- from .models import ItemType, Item, Loan, Storage
- import coin.members.admin
- User = get_user_model()
- admin.site.register(ItemType)
- class OwnerFilter(admin.SimpleListFilter):
- title = "Propriétaire"
- parameter_name = 'owner'
- def lookups(self, request, model_admin):
- owners = [
- (i.pk, i) for i in User.objects.filter(items__isnull=False)]
- return [(None, "L'association")] + owners
- def queryset(self, request, queryset):
- if self.value():
- return queryset.filter(owner__pk=self.value())
- else:
- return queryset
- class AvailabilityFilter(admin.SimpleListFilter):
- title = "Disponibilité"
- parameter_name = 'availability'
- def lookups(self, request, model_admin):
- return [
- ('available', 'Disponible'),
- ('borrowed', 'Emprunté'),
- ('deployed', 'Déployé'),
- ]
- def queryset(self, request, queryset):
- if self.value() == 'available':
- return queryset.available()
- elif self.value() == 'borrowed':
- return queryset.borrowed()
- elif self.value() == 'deployed':
- return queryset.deployed()
- else:
- return queryset
- class CurrentLoanInline(admin.TabularInline):
- model = Loan
- extra = 0
- fields = ('user', 'item', 'short_date', 'notes')
- readonly_fields = ('user', 'item', 'short_date', 'notes')
- verbose_name_plural = "Emprunt en cours"
- show_change_link = True
- def get_queryset(self, request):
- qs = super(CurrentLoanInline, self).get_queryset(request)
- return qs.running()
- def has_add_permission(self, request, obj=None):
- return False
- def has_delete_permission(self, request, obj=None):
- return False
- class LoanHistoryInline(admin.TabularInline):
- model = Loan
- extra = 0
- fields = ('user', 'item', 'short_date', 'short_date_end', 'notes')
- readonly_fields = ('user', 'item', 'short_date', 'short_date_end', 'notes')
- ordering = ['-loan_date_end']
- verbose_name_plural = "Historique de prêt de cet objet"
- show_change_link = True
- classes = ['collapse'] # Django >= 1.10-ready
- def get_queryset(self, request):
- qs = super(LoanHistoryInline, self).get_queryset(request)
- return qs.finished()
- def has_add_permission(self, request, obj=None):
- return False
- def has_delete_permission(self, request, obj=None):
- return False
- class AddLoanInline(admin.StackedInline):
- model = Loan
- extra = 1
- max_num = 1
- fields = ('user', 'item', 'loan_date', 'notes')
- verbose_name_plural = "Déclarer le prêt de cet objet"
- classes = ['collapse'] # Django >= 1.10-ready
- form = autocomplete_light.modelform_factory(Loan, fields='__all__')
- def get_queryset(self, request):
- qs = super(AddLoanInline, self).get_queryset(request)
- return qs.none()
- def has_delete_permission(self, request, obj=None):
- return False
- class BorrowerFilter(admin.SimpleListFilter):
- title = 'Adhérent emprunteur'
- parameter_name = 'user'
- def _filter_loans(self, items_queryset, user_pk=None):
- qs = Loan.objects.running().filter(item__in=items_queryset)
- if user_pk is not None:
- qs.filter(user=user_pk)
- return qs
- def lookups(self, request, model_admin):
- # Get relevant (and authorized) users only
- relevant_items = model_admin.get_queryset(request)
- users = set()
- for loan in self._filter_loans(relevant_items):
- users.add((loan.user.pk, loan.user))
- return users
- def queryset(self, request, queryset):
- if self.value():
- loans_qs = self._filter_loans(queryset).filter(
- user__pk=self.value(),
- )
- return queryset.filter(loans__in=loans_qs)
- else:
- return queryset
- @admin.register(Item)
- class ItemAdmin(admin.ModelAdmin):
- list_display = (
- 'designation',
- 'current_borrower',
- 'get_mac_and_serial',
- 'deployed', 'is_available', 'storage',
- 'buy_date', 'owner',
- )
- list_filter = (
- AvailabilityFilter, 'type', 'storage',
- 'buy_date', BorrowerFilter, OwnerFilter)
- search_fields = (
- 'designation', 'mac_address', 'serial',
- 'owner__email', 'owner__nickname',
- 'owner__first_name', 'owner__last_name')
- save_as = True
- actions = ['give_back']
- form = autocomplete_light.modelform_factory(Loan, fields='__all__')
- inlines = [AddLoanInline, CurrentLoanInline, LoanHistoryInline]
- def give_back(self, request, queryset):
- for item in queryset.filter(loans__loan_date_end=None):
- item.give_back()
- give_back.short_description = 'Rendre le matériel'
- class StatusFilter(admin.SimpleListFilter):
- title = 'Statut'
- parameter_name = 'status'
- def lookups(self, request, model_admin):
- return [
- ('all', 'Tout'),
- (None, 'En cours'),
- ('finished', 'Passés'),
- ]
- def choices(self, cl):
- for lookup, title in self.lookup_choices:
- yield {
- 'selected': self.value() == lookup,
- 'query_string': cl.get_query_string({
- self.parameter_name: lookup,
- }, []),
- 'display': title,
- }
- def queryset(self, request, queryset):
- v = self.value()
- if v in (None, 'running'):
- return queryset.running()
- elif v == 'finished':
- return queryset.finished()
- else:
- return queryset
- class BorrowerFilter(admin.SimpleListFilter):
- title = 'Adhérent emprunteur'
- parameter_name = 'user'
- def lookups(self, request, model_admin):
- users = set()
- for loan in model_admin.get_queryset(request):
- users.add((loan.user.pk, loan.user))
- return users
- def queryset(self, request, queryset):
- if self.value():
- return queryset.filter(user=self.value())
- else:
- return queryset
- class ItemChoiceField(ModelChoiceField):
- # On surcharge cette méthode pour afficher mac et n° de série dans le menu
- # déroulant de sélection d'un objet dans la création d'un prêt.
- def label_from_instance(self, obj):
- return obj.designation + ' ' + obj.get_mac_and_serial()
- @admin.register(Loan)
- class LoanAdmin(admin.ModelAdmin):
- list_display = ('item', 'get_mac_and_serial', 'user', 'loan_date', 'loan_date_end')
- list_filter = (StatusFilter, BorrowerFilter, 'item__designation')
- search_fields = (
- 'item__designation',
- 'user__nickname', 'user__username',
- 'user__first_name', 'user__last_name', )
- actions = ['end_loan']
- def end_loan(self, request, queryset):
- queryset.filter(loan_date_end=None).update(
- loan_date_end=datetime.now())
- end_loan.short_description = 'Mettre fin au prêt'
- form = autocomplete_light.modelform_factory(Loan, fields='__all__')
- def formfield_for_foreignkey(self, db_field, request, **kwargs):
- if db_field.name == 'item':
- kwargs['queryset'] = Item.objects.all()
- return ItemChoiceField(**kwargs)
- else:
- return super(LoanAdmin, self).formfield_for_foreignkey(db_field, request, **kwargs)
- @admin.register(Storage)
- class StorageAdmin(admin.ModelAdmin):
- list_display = ('name', 'truncated_notes', 'items_count')
- def truncated_notes(self, obj):
- if len(obj.notes) > 50:
- return '{}…'.format(obj.notes[:50])
- else:
- return obj.notes
- truncated_notes.short_description = 'notes'
- class LoanInline(admin.TabularInline):
- model = Loan
- extra = 0
- exclude = ('notes',)
- readonly_fields = ('item', 'get_mac_and_serial', 'loan_date', 'loan_date_end', 'is_running')
- show_change_link = True
- def get_queryset(self, request):
- qs = super(LoanInline, self).get_queryset(request)
- return qs.order_by('-loan_date_end')
- def has_add_permission(self, request, obj=None):
- return False
- def has_delete_permission(self, request, obj=None):
- return False
- class MemberAdmin(coin.members.admin.MemberAdmin):
- inlines = coin.members.admin.MemberAdmin.inlines + [LoanInline]
- admin.site.unregister(coin.members.admin.Member)
- admin.site.register(coin.members.admin.Member, MemberAdmin)
|