ClientFavoriteProviderService.php 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <?php
  2. namespace App\Services;
  3. use App\Http\Resources\ClientFavoriteProviderResource;
  4. use App\Models\ClientFavoriteProvider;
  5. use Illuminate\Database\Eloquent\Collection;
  6. class ClientFavoriteProviderService
  7. {
  8. public function getByClientId(int $clientId): Collection
  9. {
  10. return ClientFavoriteProvider::where('client_favorite_providers.client_id', $clientId)
  11. ->leftJoin('providers', 'providers.id', '=', 'client_favorite_providers.provider_id')
  12. ->leftJoin('users as provider_user', 'provider_user.id', '=', 'providers.user_id')
  13. ->leftJoin('addresses as provider_address', function ($join) {
  14. $join->on('provider_address.source_id', '=', 'providers.id')
  15. ->where('provider_address.source', 'provider')
  16. ->whereNull('provider_address.deleted_at');
  17. })
  18. ->leftJoin('cities', 'cities.id', '=', 'provider_address.city_id')
  19. ->select(
  20. 'client_favorite_providers.id',
  21. 'client_favorite_providers.client_id',
  22. 'client_favorite_providers.provider_id',
  23. 'client_favorite_providers.notes',
  24. 'client_favorite_providers.created_at',
  25. 'client_favorite_providers.updated_at',
  26. 'provider_user.name as provider_name',
  27. 'providers.average_rating',
  28. 'providers.daily_price_8h',
  29. 'providers.daily_price_6h',
  30. 'providers.daily_price_4h',
  31. 'providers.daily_price_2h',
  32. 'providers.total_services',
  33. 'cities.name as city_name',
  34. )
  35. ->orderBy('client_favorite_providers.created_at', 'desc')
  36. ->get();
  37. }
  38. public function getById(int $id): ClientFavoriteProviderResource
  39. {
  40. $favorite = ClientFavoriteProvider::with('provider')->findOrFail($id);
  41. return new ClientFavoriteProviderResource($favorite);
  42. }
  43. public function create(array $data): ClientFavoriteProviderResource
  44. {
  45. $favorite = ClientFavoriteProvider::create($data);
  46. $favorite->load('provider');
  47. return new ClientFavoriteProviderResource($favorite);
  48. }
  49. public function update(int $id, array $data): ClientFavoriteProviderResource
  50. {
  51. $favorite = ClientFavoriteProvider::findOrFail($id);
  52. $favorite->update($data);
  53. $favorite->load('provider');
  54. return new ClientFavoriteProviderResource($favorite);
  55. }
  56. public function delete(int $id): bool
  57. {
  58. $favorite = ClientFavoriteProvider::findOrFail($id);
  59. return $favorite->delete();
  60. }
  61. public function getFavoritedProviderIds(int $clientId): array
  62. {
  63. return ClientFavoriteProvider::where('client_id', $clientId)
  64. ->pluck('provider_id')
  65. ->toArray();
  66. }
  67. }