| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- <?php
- namespace App\Services;
- use App\Models\Client;
- use App\Models\Schedule;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Support\Facades\DB;
- use Illuminate\Support\Facades\Storage;
- class ClientCalendarService
- {
- public function __construct() {}
- public function getCalendar(): array
- {
- $user = Auth::user();
- $client = Client::where('user_id', $user->id)->first();
- $selectFields = [
- 'schedules.id',
- 'schedules.provider_id',
- 'schedules.date',
- 'schedules.start_time',
- 'schedules.end_time',
- 'schedules.total_amount',
- 'schedules.period_type',
- 'schedules.schedule_type',
- 'schedules.address_id',
- 'schedules.status',
- 'custom_schedules.offers_meal',
- 'provider_user.name as provider_name',
- 'providers.average_rating',
- 'providers.total_services',
- 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"),
- DB::raw("EXISTS(
- SELECT 1 FROM reviews
- WHERE reviews.schedule_id = schedules.id
- AND reviews.origin = 'client'
- AND reviews.origin_id = {$client->id}
- AND reviews.deleted_at IS NULL
- ) as client_reviewed"),
- DB::raw("(
- SELECT reviews.stars FROM reviews
- WHERE reviews.schedule_id = schedules.id
- AND reviews.origin = 'client'
- AND reviews.origin_id = {$client->id}
- AND reviews.deleted_at IS NULL
- LIMIT 1
- ) as client_stars"),
- ];
- $signPhoto = fn ($item) => tap($item, fn ($i) => $i->provider_photo = $i->provider_photo
- ? Storage::temporaryUrl($i->provider_photo, now()->addMinutes(60))
- : null);
- $upcomingSchedules = Schedule::with('address:district,address,number,source_id,source,id')
- ->where('schedules.client_id', $client->id)
- ->whereIn('schedules.status', ['pending', 'accepted', 'paid', 'started'])
- ->whereDate('schedules.date', '>=', now()->toDateString())
- ->leftJoin('providers', 'providers.id', '=', 'schedules.provider_id')
- ->leftJoin('users as provider_user', 'provider_user.id', '=', 'providers.user_id')
- ->leftJoin('custom_schedules', 'custom_schedules.schedule_id', '=', 'schedules.id')
- ->select($selectFields)
- ->orderBy('schedules.date', 'asc')
- ->orderBy('schedules.start_time', 'asc')
- ->get()
- ->map($signPhoto);
- $completedSchedules = Schedule::with('address:district,address,number,source_id,source,id')
- ->where('schedules.client_id', $client->id)
- ->whereIn('schedules.status', ['finished', 'cancelled'])
- ->leftJoin('providers', 'providers.id', '=', 'schedules.provider_id')
- ->leftJoin('users as provider_user', 'provider_user.id', '=', 'providers.user_id')
- ->leftJoin('custom_schedules', 'custom_schedules.schedule_id', '=', 'schedules.id')
- ->select($selectFields)
- ->orderBy('schedules.date', 'desc')
- ->orderBy('schedules.start_time', 'desc')
- ->get()
- ->map($signPhoto);
- return [
- 'upcomingSchedules' => $upcomingSchedules,
- 'completedSchedules' => $completedSchedules,
- ];
- }
- }
|