netgescon-master/app/Http/Controllers/Admin/DashboardController.php
Pikappa2 952c9b4e90 Fix: Risolte relazioni amministratore e chiavi database
 Correzioni:
- DashboardController: usa admin->id invece di admin->id_amministratore
- SidebarComposer: aggiornato per chiave modernizzata
- Amministratore model: rimossa primaryKey custom, usa 'id' standard
- TestSetupSeeder: corretto riferimento ID amministratore
- Aggiunta gestione sicura per utenti senza amministratore

�� Fix: Risolve errore 'Attempt to read property denominazione on null'
📊 Test: Creato stabile di test per verificare funzionamento
2025-07-07 18:09:32 +02:00

95 lines
3.6 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()
{
// Ottieni l'ID dell'amministratore in modo sicuro
$user = Auth::user();
$amministratore_id = null;
if ($user && $user->amministratore) {
$amministratore_id = $user->amministratore->id; // Usa 'id' invece di 'id_amministratore'
}
// Se l'utente non ha un amministratore associato, mostra vista vuota
if (!$amministratore_id) {
return view('admin.dashboard', [
'stats' => [
'stabili_gestiti' => 0,
'stabili_attivi' => 0,
'ticket_aperti' => 0,
'ticket_urgenti' => 0,
],
'ticketsAperti' => collect(),
'scadenzeImminenti' => collect(),
'ultimiDocumenti' => collect(),
'ultimiMovimenti' => collect(),
]);
}
// 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'
));
}
}