ClientCalendarService.php 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <?php
  2. namespace App\Services;
  3. use App\Models\Client;
  4. use App\Models\Schedule;
  5. use Illuminate\Support\Facades\Auth;
  6. use Illuminate\Support\Facades\DB;
  7. use Illuminate\Support\Facades\Storage;
  8. class ClientCalendarService
  9. {
  10. public function __construct() {}
  11. public function getCalendar(): array
  12. {
  13. $user = Auth::user();
  14. $client = Client::where('user_id', $user->id)->first();
  15. $selectFields = [
  16. 'schedules.id',
  17. 'schedules.provider_id',
  18. 'schedules.date',
  19. 'schedules.start_time',
  20. 'schedules.end_time',
  21. 'schedules.total_amount',
  22. 'schedules.period_type',
  23. 'schedules.schedule_type',
  24. 'schedules.address_id',
  25. 'schedules.status',
  26. 'custom_schedules.offers_meal',
  27. 'provider_user.name as provider_name',
  28. 'providers.average_rating',
  29. 'providers.total_services',
  30. DB::raw("(SELECT media.path FROM media WHERE media.source_id = providers.id AND media.source = 'provider' AND media.deleted_at IS NULL LIMIT 1) as provider_photo"),
  31. DB::raw("EXISTS(
  32. SELECT 1 FROM reviews
  33. WHERE reviews.schedule_id = schedules.id
  34. AND reviews.origin = 'client'
  35. AND reviews.origin_id = {$client->id}
  36. AND reviews.deleted_at IS NULL
  37. ) as client_reviewed"),
  38. DB::raw("(
  39. SELECT reviews.stars FROM reviews
  40. WHERE reviews.schedule_id = schedules.id
  41. AND reviews.origin = 'client'
  42. AND reviews.origin_id = {$client->id}
  43. AND reviews.deleted_at IS NULL
  44. LIMIT 1
  45. ) as client_stars"),
  46. ];
  47. $signPhoto = fn ($item) => tap($item, fn ($i) => $i->provider_photo = $i->provider_photo
  48. ? Storage::temporaryUrl($i->provider_photo, now()->addMinutes(60))
  49. : null);
  50. $upcomingSchedules = Schedule::with('address:district,address,number,source_id,source,id')
  51. ->where('schedules.client_id', $client->id)
  52. ->whereIn('schedules.status', ['pending', 'accepted', 'paid', 'started'])
  53. ->whereDate('schedules.date', '>=', now()->toDateString())
  54. ->leftJoin('providers', 'providers.id', '=', 'schedules.provider_id')
  55. ->leftJoin('users as provider_user', 'provider_user.id', '=', 'providers.user_id')
  56. ->leftJoin('custom_schedules', 'custom_schedules.schedule_id', '=', 'schedules.id')
  57. ->select($selectFields)
  58. ->orderBy('schedules.date', 'asc')
  59. ->orderBy('schedules.start_time', 'asc')
  60. ->get()
  61. ->map($signPhoto);
  62. $completedSchedules = Schedule::with('address:district,address,number,source_id,source,id')
  63. ->where('schedules.client_id', $client->id)
  64. ->whereIn('schedules.status', ['finished', 'cancelled'])
  65. ->leftJoin('providers', 'providers.id', '=', 'schedules.provider_id')
  66. ->leftJoin('users as provider_user', 'provider_user.id', '=', 'providers.user_id')
  67. ->leftJoin('custom_schedules', 'custom_schedules.schedule_id', '=', 'schedules.id')
  68. ->select($selectFields)
  69. ->orderBy('schedules.date', 'desc')
  70. ->orderBy('schedules.start_time', 'desc')
  71. ->get()
  72. ->map($signPhoto);
  73. return [
  74. 'upcomingSchedules' => $upcomingSchedules,
  75. 'completedSchedules' => $completedSchedules,
  76. ];
  77. }
  78. }