netgescon-master/docs/team/project/app/Http/Controllers/Admin/DashboardController.php
Pikappa2 480e7eafbd 🎯 NETGESCON - Setup iniziale repository completo
📋 Commit iniziale con:
-  Documentazione unificata in docs/
-  Codice Laravel in netgescon-laravel/
-  Script automazione in scripts/
-  Configurazione sync rsync
-  Struttura organizzata e pulita

🔄 Versione: 2025.07.19-1644
🎯 Sistema pronto per Git distribuito
2025-07-19 16:44:47 +02:00

73 lines
2.8 KiB
PHP

<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Models\Stabile;
use App\Models\Ticket;
use App\Models\Rata;
use App\Models\Documento;
use App\Models\MovimentoContabile;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Carbon\Carbon;
class DashboardController extends Controller
{
public function index()
{
$amministratore_id = Auth::user()->amministratore->id_amministratore ?? null;
// Statistiche principali
$stats = [
'stabili_gestiti' => Stabile::where('amministratore_id', $amministratore_id)->count(),
'stabili_attivi' => Stabile::where('amministratore_id', $amministratore_id)->where('stato', 'attivo')->count(),
'ticket_aperti' => Ticket::whereHas('stabile', function($q) use ($amministratore_id) {
$q->where('amministratore_id', $amministratore_id);
})->whereIn('stato', ['Aperto', 'Preso in Carico', 'In Lavorazione'])->count(),
'ticket_urgenti' => Ticket::whereHas('stabile', function($q) use ($amministratore_id) {
$q->where('amministratore_id', $amministratore_id);
})->where('priorita', 'Urgente')->whereIn('stato', ['Aperto', 'Preso in Carico'])->count(),
];
// Ticket aperti da lavorare
$ticketsAperti = Ticket::with(['stabile', 'categoriaTicket'])
->whereHas('stabile', function($q) use ($amministratore_id) {
$q->where('amministratore_id', $amministratore_id);
})
->whereIn('stato', ['Aperto', 'Preso in Carico', 'In Lavorazione'])
->orderBy('priorita', 'desc')
->orderBy('created_at', 'desc')
->take(5)
->get();
// Scadenze imminenti (prossimi 30 giorni)
$scadenzeImminenti = collect(); // Placeholder per quando implementeremo le rate
// Ultimi documenti caricati
$ultimiDocumenti = Documento::with('documentable')
->whereHasMorph('documentable', [Stabile::class], function($q) use ($amministratore_id) {
$q->where('amministratore_id', $amministratore_id);
})
->orderBy('created_at', 'desc')
->take(5)
->get();
// Movimenti contabili recenti
$ultimiMovimenti = MovimentoContabile::with(['stabile', 'fornitore'])
->whereHas('stabile', function($q) use ($amministratore_id) {
$q->where('amministratore_id', $amministratore_id);
})
->orderBy('created_at', 'desc')
->take(5)
->get();
return view('admin.dashboard', compact(
'stats',
'ticketsAperti',
'scadenzeImminenti',
'ultimiDocumenti',
'ultimiMovimenti'
));
}
}