User.php 1.4KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace App\Models;
  3. use Illuminate\Database\Eloquent\Casts\Attribute;
  4. use Illuminate\Database\Eloquent\Factories\HasFactory;
  5. use Illuminate\Foundation\Auth\User as Authenticatable;
  6. use Illuminate\Notifications\Notifiable;
  7. use Laravel\Sanctum\HasApiTokens;
  8. class User extends Authenticatable
  9. {
  10. use HasApiTokens, HasFactory, Notifiable;
  11. /**
  12. * The attributes that are mass assignable.
  13. *
  14. * @var array<int, string>
  15. */
  16. protected $fillable = [
  17. 'name',
  18. 'username',
  19. 'status',
  20. 'password',
  21. 'role_id'
  22. ];
  23. /**
  24. * The attributes that should be hidden for serialization.
  25. *
  26. * @var array<int, string>
  27. */
  28. protected $hidden = [
  29. 'created_at',
  30. 'updated_at',
  31. 'password',
  32. 'remember_token'
  33. ];
  34. protected function status(): Attribute
  35. {
  36. return Attribute::make(
  37. get:fn($value) => $value ? __('words.active') : __('words.not_active'),
  38. );
  39. }
  40. public function role()
  41. {
  42. return $this->belongsTo(Role::class);
  43. }
  44. public function scopeFilter($query, array $filters)
  45. {
  46. $query->when($filters['search'] ?? null, function ($query, $search) {
  47. $query->where(function ($query) use ($search) {
  48. $query->where('name', 'like', '%' . $search . '%')
  49. ->orWhere('username', 'like', '%' . $search . '%');
  50. });
  51. });
  52. }
  53. }