SearchService.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. <?php
  2. namespace App\Services;
  3. use App\Models\Address;
  4. use App\Models\Client;
  5. use App\Models\Provider;
  6. use App\Rules\ScheduleBusinessRules;
  7. use Illuminate\Support\Facades\Auth;
  8. use Illuminate\Support\Facades\DB;
  9. class SearchService
  10. {
  11. public function __construct() {}
  12. public function buscaPrestadores(?string $name = null, ?string $date = null): array
  13. {
  14. $user = Auth::user();
  15. $cliente = Client::where('user_id', $user->id)->first();
  16. $blockedProviderIds = ScheduleBusinessRules::getBlockedProviderIdsForClient($cliente->id);
  17. $providersWithWorkingDays = ScheduleBusinessRules::getProviderIdsWithWorkingDays();
  18. $clientPrimaryAddress = Address::where('source', 'client')
  19. ->where('source_id', $cliente->id)
  20. ->orderBy('is_primary', 'desc')
  21. ->first();
  22. return Provider::leftJoin('users as provider_user', 'provider_user.id', '=', 'providers.user_id')
  23. ->leftJoin(DB::raw("
  24. (
  25. SELECT DISTINCT ON (source_id)
  26. *
  27. FROM addresses
  28. WHERE source = 'provider'
  29. ORDER BY source_id, is_primary DESC
  30. ) as provider_address
  31. "), 'provider_address.source_id', '=', 'providers.id')
  32. ->whereNotNull('provider_address.id')
  33. ->where('provider_address.city_id', $clientPrimaryAddress?->city_id)
  34. ->whereNotIn('providers.id', $blockedProviderIds)
  35. ->whereIn('providers.id', $providersWithWorkingDays)
  36. ->whereNotNull('providers.daily_price_8h')
  37. ->whereNotNull('providers.daily_price_6h')
  38. ->whereNotNull('providers.daily_price_4h')
  39. ->whereNotNull('providers.daily_price_2h')
  40. ->when($name, fn ($q) => $q->where('provider_user.name', 'ILIKE', "%{$name}%"))
  41. ->select(
  42. 'providers.id as provider_id',
  43. 'provider_user.name as provider_name',
  44. 'provider_address.district',
  45. 'providers.average_rating',
  46. 'providers.total_services',
  47. 'providers.daily_price_8h',
  48. 'providers.daily_price_6h',
  49. 'providers.daily_price_4h',
  50. 'providers.daily_price_2h',
  51. 'providers.created_at',
  52. DB::raw("(
  53. SELECT COUNT(*)
  54. FROM reviews
  55. LEFT JOIN schedules ON schedules.id = reviews.schedule_id
  56. WHERE reviews.origin = 'provider'
  57. AND schedules.provider_id = providers.id
  58. ) as total_reviews"),
  59. )
  60. ->orderBy('providers.average_rating', 'desc')
  61. ->get()
  62. ->when(
  63. $date,
  64. fn ($collection) => $collection->whereIn(
  65. 'provider_id',
  66. ScheduleBusinessRules::getAvailableProviderIdsForDate(
  67. $date,
  68. $collection->pluck('provider_id')
  69. )->toArray()
  70. )->values()
  71. )
  72. ->toArray();
  73. }
  74. }