123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194 |
- # -*- 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
- @admin.register(Item)
- class ItemAdmin(admin.ModelAdmin):
- list_display = (
- 'designation', 'mac_address', 'serial', 'owner',
- 'buy_date', 'deployed', 'is_available', 'storage')
- list_filter = (
- AvailabilityFilter, 'type', 'storage',
- 'buy_date', 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__')
- 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)
|