UserService.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <?php
  2. namespace App\Services;
  3. use App\Enums\UserStatusEnum;
  4. use App\Enums\UserTypeEnum;
  5. use App\Models\User;
  6. use Illuminate\Database\Eloquent\Collection;
  7. use Illuminate\Support\Facades\Auth;
  8. class UserService
  9. {
  10. public function authUser(): ?User
  11. {
  12. $user = Auth::user();
  13. return $user?->load(['position', 'sector'])
  14. ->loadCount(['notificationSends as unread_notifications_count' => fn($q) => $q->where('read', false)]);
  15. }
  16. public function getAll(): Collection
  17. {
  18. return User::with(['position', 'sector'])->orderBy("created_at", "desc")->get();
  19. }
  20. public function getAllPaginated(array $filters = [], int $perPage = 10): \Illuminate\Pagination\LengthAwarePaginator
  21. {
  22. $query = User::with(['position', 'sector'])->orderBy('name', 'asc');
  23. if (!empty($filters['type'])) {
  24. $query->where('type', $filters['type']);
  25. }
  26. if (!empty($filters['status'])) {
  27. $query->where('status', $filters['status']);
  28. }
  29. if (!empty($filters['search'])) {
  30. $term = '%' . mb_strtolower($filters['search']) . '%';
  31. $query->where(function ($q) use ($term) {
  32. $q->whereRaw('UNACCENT(LOWER(name)) LIKE UNACCENT(?)', [$term])
  33. ->orWhereRaw('UNACCENT(LOWER(email)) LIKE UNACCENT(?)', [$term])
  34. ->orWhereRaw('UNACCENT(LOWER(COALESCE(cpf, \'\'))) LIKE UNACCENT(?)', [$term])
  35. ->orWhereRaw('UNACCENT(LOWER(COALESCE(registration, \'\'))) LIKE UNACCENT(?)', [$term]);
  36. });
  37. }
  38. return $query->paginate($perPage);
  39. }
  40. public function findById(int $id): ?User
  41. {
  42. return User::find($id);
  43. }
  44. public function create(array $data): User
  45. {
  46. return User::create($data);
  47. }
  48. public function update(int $id, array $data): ?User
  49. {
  50. $model = $this->findById($id);
  51. if (!$model) {
  52. return null;
  53. }
  54. if (isset($data['status'])) {
  55. $newStatus = $data['status'] instanceof UserStatusEnum
  56. ? $data['status']
  57. : UserStatusEnum::from($data['status']);
  58. if ($newStatus === UserStatusEnum::INACTIVE && $model->status !== UserStatusEnum::INACTIVE) {
  59. $data['excluded_at'] = now();
  60. } elseif ($newStatus !== UserStatusEnum::INACTIVE) {
  61. $data['excluded_at'] = null;
  62. }
  63. }
  64. $model->update($data);
  65. return $model->fresh();
  66. }
  67. public function delete(int $id): bool
  68. {
  69. $model = $this->findById($id);
  70. if (!$model) {
  71. return false;
  72. }
  73. return $model->delete();
  74. }
  75. public function getUserTypes(): array
  76. {
  77. return UserTypeEnum::toArray();
  78. }
  79. }