Improve user and group admin

This commit is contained in:
ErikKalkoken
2020-02-05 17:48:06 +01:00
parent 564a25e578
commit 2b8bfbe544
2 changed files with 128 additions and 3 deletions

View File

@@ -1,11 +1,23 @@
from django.conf import settings
from django.contrib import admin
from django.contrib.auth.models import Group as BaseGroup
from django.db.models.signals import pre_save, post_save, pre_delete, post_delete, m2m_changed
from django.db.models import Count
from django.db.models.signals import pre_save, post_save, pre_delete, \
post_delete, m2m_changed
from django.dispatch import receiver
from .models import AuthGroup
from .models import GroupRequest
from . import signals
if 'allianceauth.eveonline.autogroups' in settings.INSTALLED_APPS:
_has_auto_groups = True
from allianceauth.eveonline.autogroups.models import *
else:
_has_auto_groups = False
class AuthGroupInlineAdmin(admin.StackedInline):
model = AuthGroup
filter_horizontal = ('group_leaders', 'group_leader_groups', 'states',)
@@ -23,10 +35,92 @@ class AuthGroupInlineAdmin(admin.StackedInline):
return request.user.has_perm('auth.change_group')
if _has_auto_groups:
class IsAutoGroupFilter(admin.SimpleListFilter):
title = 'auto group'
parameter_name = 'auto_group'
def lookups(self, request, model_admin):
return (
('Yes', 'Yes'),
('No', 'No'),
)
def queryset(self, request, queryset):
value = self.value()
if value == 'Yes':
return queryset.exclude(
managedalliancegroup__exact=None,
managedcorpgroup__exact=None
)
elif value == 'No':
return queryset.filter(managedalliancegroup__exact=None).filter(managedcorpgroup__exact=None)
else:
return queryset
class GroupAdmin(admin.ModelAdmin):
list_select_related = True
list_display = (
'name',
'description',
'member_count',
'has_leader',
'_attributes'
)
list_filter = (
'authgroup__internal',
'authgroup__hidden',
'authgroup__open',
'authgroup__public',
IsAutoGroupFilter
)
filter_horizontal = ('permissions',)
inlines = (AuthGroupInlineAdmin,)
def get_queryset(self, request):
queryset = super().get_queryset(request)
queryset = queryset.annotate(
_member_count=Count('user', distinct=True),
)
return queryset
def description(self, obj):
return obj.authgroup.description
def member_count(self, obj):
return obj._member_count
member_count.admin_order_field = '_member_count'
def has_leader(self, obj):
return obj.authgroup.group_leaders.exists()
has_leader.boolean = True
def _attributes(self, obj):
attributes = list()
if _has_auto_groups and (obj.managedalliancegroup_set.exists()
or obj.managedcorpgroup_set.exists()
):
attributes.append('Auto Group')
elif obj.authgroup.internal:
attributes.append('Internal')
else:
if obj.authgroup.hidden:
attributes.append('Hidden')
if obj.authgroup.open:
attributes.append('Open')
if obj.authgroup.public:
attributes.append('Public')
if not attributes:
attributes.append('Default')
return ', '.join(attributes)
_attributes.short_description = "Attributes"
class Group(BaseGroup):
class Meta: