Server IP : 66.29.132.124 / Your IP : 3.145.44.46 Web Server : LiteSpeed System : Linux business141.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : wavevlvu ( 1524) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/wavevlvu/book24.ng/modules/Hotel/Models/ |
Upload File : |
<?php namespace Modules\Hotel\Models; use ICal\ICal; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Cache; use Illuminate\Support\Facades\Validator; use Illuminate\Http\Request; use Modules\Booking\Models\Bookable; use Modules\Booking\Models\Booking; use Modules\Core\Models\SEO; use Modules\Media\Helpers\FileHelper; use Modules\Review\Models\Review; use Illuminate\Database\Eloquent\SoftDeletes; use Modules\Hotel\Models\HotelTranslation; use Modules\User\Models\UserWishList; class HotelRoom extends Bookable { use SoftDeletes; protected $table = 'bravo_hotel_rooms'; public $type = 'hotel_room'; public $availabilityClass = HotelRoomDate::class; protected $fillable = [ 'title', 'content', 'status', ]; protected $seo_type = 'hotel_room'; protected $bookingClass; protected $roomDateClass; protected $hotelRoomTermClass; protected $roomBookingClass; public function __construct(array $attributes = []) { parent::__construct($attributes); $this->bookingClass = Booking::class; $this->roomDateClass = HotelRoomDate::class; $this->hotelRoomTermClass = HotelRoomTerm::class; $this->roomBookingClass = HotelRoomBooking::class; } public static function getModelName() { return __("Hotel Room"); } public static function getTableName() { return with(new static)->table; } public function terms(){ return $this->hasMany($this->hotelRoomTermClass, "target_id"); } public function isAvailableAt($filters = []){ if(empty($filters['start_date']) or empty($filters['end_date'])) return true; $filters['end_date'] = date("Y-m-d", strtotime($filters['end_date']." -1day")); $roomDates = $this->getDatesInRange($filters['start_date'],$filters['end_date']); $allDates = []; $tmp_price = 0; $tmp_night = 0; $period = periodDate($filters['start_date'],$filters['end_date'],true); foreach ($period as $dt){ $allDates[$dt->format('Y-m-d')] = [ 'number'=>$this->number, 'price'=>$this->price ]; $tmp_night++; } if(!empty($roomDates)) { foreach ($roomDates as $row) { if(!$row->active or !$row->number or !$row->price) return false; if(!array_key_exists(date('Y-m-d',strtotime($row->start_date)),$allDates)) continue; $allDates[date('Y-m-d',strtotime($row->start_date))] = [ 'number'=>$row->number, 'price'=>$row->price ]; } } $roomBookings = $this->getBookingsInRange($filters['start_date'],$filters['end_date']); if(!empty($roomBookings)){ foreach ($roomBookings as $roomBooking){ $period = periodDate($roomBooking->start_date,$roomBooking->end_date,false); foreach ($period as $dt){ $date = $dt->format('Y-m-d'); if(!array_key_exists($date,$allDates)) continue; $allDates[$date]['number'] -= $roomBooking->number; if($allDates[$date]['number'] <= 0){ return false; } } } } if(!empty($this->ical_import_url)){ $startDate = $filters['start_date']; $endDate = $filters['end_date']; $timezone = setting_item('site_timezone',config('app.timezone')); try { $icalevents = new Ical($this->ical_import_url,[ 'defaultTimeZone'=>$timezone ]); $eventRange = $icalevents->eventsFromRange($startDate,$endDate); if(!empty($eventRange)){ foreach ($eventRange as $item=>$value){ if(!empty($date = $value->dtstart_array[2])){ $allDates[date('Y-m-d',$date)]['number'] -= 1; if($allDates[date('Y-m-d',$date)]['number'] <= 0){ return false; } } } } }catch (\Exception $exception){ return $this->sendError($exception->getMessage()); } } $this->tmp_number = !empty($allDates) ? (int) min(array_column($allDates,'number')) : 0; if(empty($this->tmp_number)) return false; //Adult - Children if( !empty($filters['adults']) and $this->adults * $this->tmp_number < $filters['adults'] ){ return false; } if( !empty($filters['children']) and $this->children * $this->tmp_number < $filters['children'] ){ return false; } $this->tmp_price = array_sum(array_column($allDates,'price')); $this->tmp_dates = $allDates; $this->tmp_nights = $tmp_night; return true; } public function getDatesInRange($start_date,$end_date) { $query = $this->roomDateClass::query(); $query->where('target_id',$this->id); $query->where('start_date','>=',date('Y-m-d H:i:s',strtotime($start_date))); $query->where('end_date','<=',date('Y-m-d H:i:s',strtotime($end_date))); return $query->take(100)->get(); } public function getBookingsInRange($from, $to) { return $this->roomBookingClass::query() ->where('bravo_hotel_room_bookings.room_id',$this->id) ->active() ->inRange($from,$to) ->get(['bravo_hotel_room_bookings.*']); } public function getGallery($featuredIncluded = false) { if (empty($this->gallery)) return $this->gallery; $list_item = []; if ($featuredIncluded and $this->image_id) { $list_item[] = [ 'large' => FileHelper::url($this->image_id, 'full'), 'thumb' => FileHelper::url($this->image_id, 'thumb') ]; } $items = explode(",", $this->gallery); foreach ($items as $k => $item) { $large = FileHelper::url($item, 'full'); $thumb = FileHelper::url($item, 'thumb'); if(!$thumb) continue; $list_item[] = [ 'large' => $large, 'thumb' => $thumb ]; } return $list_item; } }