- Aggiunto dark mode completo alla sidebar con classi Tailwind - Implementato sistema di salvataggio permanente delle impostazioni utente - Creata tabella user_settings per gestire preferenze personalizzate - Aggiunto model UserSetting con metodi helper get/set - Esteso controller impostazioni per supportare salvataggio e temi predefiniti - Applicato stesso tema anche al pannello amministratore - Aggiornate route per gestione temi in admin e superadmin - Integrato sistema impostazioni nel layout principale con variabili CSS - Aggiornato AppServiceProvider con helper userSetting() - Dark mode applicato a: sidebar, modali, footer, bottoni, hover states - Temi predefiniti: Default, Dark, Ocean con preview tempo reale - Compatibilità completa tra pannello admin e superadmin
71 lines
2.3 KiB
PHP
71 lines
2.3 KiB
PHP
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
// Import necessari
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Foundation\Auth\User as Authenticatable;
|
|
use Illuminate\Notifications\Notifiable;
|
|
use Illuminate\Database\Eloquent\Relations\HasOne;
|
|
use Lab404\Impersonate\Models\Impersonate; // Per la funzionalità di impersonificazione
|
|
use Spatie\Permission\Traits\HasRoles; // Per la gestione dei ruoli e permessi
|
|
use Laravel\Sanctum\HasApiTokens;
|
|
use Illuminate\Database\Eloquent\Relations\HasMany;
|
|
|
|
class User extends Authenticatable
|
|
{
|
|
// Aggiungi il trait Impersonate
|
|
use HasApiTokens, HasFactory, Notifiable, Impersonate, HasRoles; // Aggiungi HasRoles qui
|
|
|
|
|
|
protected $fillable = ['name', 'email', 'password', 'email_verified_at']; // Aggiunto email_verified_at
|
|
protected $hidden = ['password', 'remember_token'];
|
|
|
|
protected function casts(): array
|
|
{
|
|
return ['email_verified_at' => 'datetime', 'password' => 'hashed'];
|
|
}
|
|
|
|
/**
|
|
* Get the amministratore record associated with the user.
|
|
*/
|
|
public function amministratore(): HasOne
|
|
{
|
|
return $this->hasOne(Amministratore::class, 'user_id');
|
|
}
|
|
|
|
public function tickets(): HasMany { return $this->hasMany(Ticket::class, 'aperto_da_user_id'); }
|
|
|
|
/**
|
|
* Regola per il pacchetto: definisce se l'utente ATTUALE
|
|
* ha il permesso di impersonare altri.
|
|
*/
|
|
public function canImpersonate(): bool
|
|
|
|
{
|
|
// Solo il Super-Admin può farlo.
|
|
return $this->hasRole('super-admin');
|
|
}
|
|
|
|
/**
|
|
* Regola per il pacchetto: definisce se questo specifico
|
|
* utente PUÒ ESSERE impersonato.
|
|
*/
|
|
public function canBeImpersonated(): bool
|
|
{
|
|
// Solo gli utenti con ruolo 'admin' possono essere impersonati.
|
|
return $this->hasRole('admin');
|
|
}
|
|
|
|
// public function roles()
|
|
// {
|
|
// return $this->belongsToMany(\App\Models\Role::class, 'role_user')->withTimestamps();
|
|
// // Relazione legacy rimossa: ora i ruoli sono gestiti solo tramite Spatie/Permission
|
|
// }
|
|
// public function hasRole($role, $stabileId = null)
|
|
// {
|
|
// return $this->roles()->where('name', $role)
|
|
// ->when($stabileId, fn($q) => $q->wherePivot('stabile_id', $stabileId))
|
|
// ->exists();
|
|
// }
|
|
} |