- Laravel 13.9 + PHP 8.5 + MySQL - Bootstrap 5.3 + jQuery 3.7 + Chart.js (replacing Alpine/Tailwind) - Packages: intervention/image, dompdf, simple-qrcode, league/csv, laravel/breeze, laravel/boost - 17 database migrations: users, programs, qr_codes, participants, attendances, certificates, questionnaires, email_logs, audit_logs - 13 Eloquent models with full relationships - Admin layout (Bootstrap 5 sidebar) + public layout (mobile-first) - Rate limiters: checkin (60/min), certificate (30/min) - Admin seeder: admin@mbip.gov.my - Storage directories + symlink configured Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
37 lines
1.2 KiB
PHP
37 lines
1.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\Attendance;
|
|
use App\Models\Certificate;
|
|
use App\Models\EmailLog;
|
|
use App\Models\Participant;
|
|
use App\Models\Program;
|
|
use App\Models\QuestionnaireResponse;
|
|
|
|
class DashboardController extends Controller
|
|
{
|
|
public function index()
|
|
{
|
|
$stats = [
|
|
'total_programs' => Program::count(),
|
|
'active_programs' => Program::where('status', 'published')->count(),
|
|
'total_participants' => Participant::count(),
|
|
'total_attendances' => Attendance::count(),
|
|
'total_certificates' => Certificate::count(),
|
|
'generated_certs' => Certificate::whereIn('status', ['generated', 'emailed', 'downloaded'])->count(),
|
|
'downloaded_certs' => Certificate::where('status', 'downloaded')->count(),
|
|
'total_responses' => QuestionnaireResponse::count(),
|
|
'pending_emails' => EmailLog::where('status', 'pending')->count(),
|
|
];
|
|
|
|
$recentPrograms = Program::with('creator')
|
|
->latest()
|
|
->limit(5)
|
|
->get();
|
|
|
|
return view('admin.dashboard', compact('stats', 'recentPrograms'));
|
|
}
|
|
}
|