Source code for evennia.web.utils.adminsite
"""
Custom Evennia admin-site, for better customization of the admin-site
as a whole.
This must be located outside of the admin/ folder because it must be imported
before any of the app-data (which in turn must be imported in the `__init__.py`
of that folder for Django to find them).
"""
from django.conf import settings
from django.contrib import admin
from django.contrib.admin import apps
[docs]class EvenniaAdminApp(apps.AdminConfig):
"""
This is imported in INSTALLED_APPS instead of django.contrib.admin.
"""
default_site = "evennia.web.utils.adminsite.EvenniaAdminSite"
[docs]class EvenniaAdminSite(admin.AdminSite):
"""
The main admin site root (replacing the default from Django). When doing
admin.register in the admin/ folder, this is what is being registered to.
"""
site_header = "Evennia web admin"
[docs] def get_app_list(self, request, app_label=None):
app_list = super().get_app_list(request, app_label=app_label)
app_mapping = {app["app_label"]: app for app in app_list}
out = [
app_mapping.pop(app_label)
for app_label in settings.DJANGO_ADMIN_APP_ORDER
if app_label in app_mapping
]
for app in settings.DJANGO_ADMIN_APP_EXCLUDE:
app_mapping.pop(app, None)
out += app_mapping.values()
return out