dsffdsdsf
This commit is contained in:
@@ -1,14 +1,13 @@
|
||||
"""
|
||||
Custom Admin Dashboard with Key Metrics
|
||||
"""
|
||||
from django.contrib.admin.views.decorators import staff_member_required
|
||||
from django.contrib import admin
|
||||
from django.shortcuts import render
|
||||
from django.db.models import Count, Sum, Q
|
||||
from django.utils import timezone
|
||||
from datetime import timedelta
|
||||
|
||||
|
||||
@staff_member_required
|
||||
def admin_dashboard(request):
|
||||
"""Custom admin dashboard with operational metrics"""
|
||||
|
||||
@@ -182,4 +181,9 @@ def admin_dashboard(request):
|
||||
'alerts': alerts,
|
||||
}
|
||||
|
||||
# Merge with admin context to get sidebar and header
|
||||
from igny8_core.admin.site import admin_site
|
||||
admin_context = admin_site.each_context(request)
|
||||
context.update(admin_context)
|
||||
|
||||
return render(request, 'admin/dashboard.html', context)
|
||||
|
||||
@@ -21,16 +21,15 @@ class Igny8AdminSite(UnfoldAdminSite):
|
||||
index_title = 'IGNY8 Administration'
|
||||
|
||||
def get_urls(self):
|
||||
"""Get admin URLs - dashboard available at /admin/dashboard/ but not default"""
|
||||
"""Get admin URLs with dashboard available at /admin/dashboard/"""
|
||||
from django.urls import path
|
||||
from .dashboard import admin_dashboard
|
||||
|
||||
urls = super().get_urls()
|
||||
# Dashboard is available at /admin/dashboard/ if needed, but not redirecting by default
|
||||
# from django.urls import path
|
||||
# from .dashboard import admin_dashboard
|
||||
# custom_urls = [
|
||||
# path('dashboard/', self.admin_view(admin_dashboard), name='dashboard'),
|
||||
# ]
|
||||
# return custom_urls + urls
|
||||
return urls
|
||||
custom_urls = [
|
||||
path('dashboard/', self.admin_view(admin_dashboard), name='dashboard'),
|
||||
]
|
||||
return custom_urls + urls
|
||||
|
||||
def each_context(self, request):
|
||||
"""
|
||||
@@ -184,6 +183,15 @@ class Igny8AdminSite(UnfoldAdminSite):
|
||||
# regardless of app_label parameter (for consistent sidebar on all pages)
|
||||
organized_apps = []
|
||||
|
||||
# Add Dashboard link as first item
|
||||
organized_apps.append({
|
||||
'name': '📊 Dashboard',
|
||||
'app_label': '_dashboard',
|
||||
'app_url': '/admin/dashboard/',
|
||||
'has_module_perms': True,
|
||||
'models': [],
|
||||
})
|
||||
|
||||
for group_name, group_config in custom_groups.items():
|
||||
group_models = []
|
||||
|
||||
|
||||
@@ -652,7 +652,7 @@ UNFOLD = {
|
||||
},
|
||||
"SIDEBAR": {
|
||||
"show_search": True,
|
||||
"show_all_applications": False, # Use custom app_list from Igny8AdminSite
|
||||
"show_all_applications": True, # Let Unfold show our custom app_list
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user