Spaces:
Running
Running
File size: 1,740 Bytes
0c117c4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 | <?php
namespace App\Models;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Spatie\Sluggable\HasSlug;
use Spatie\Sluggable\SlugOptions;
use App\Models\Traits\SearchableTraitExtend;
class Booking extends BaseModel
{
protected $hidden = ['pivot','laravel_through_key'];
protected $table = "bookings";
protected $fillable =[
'checkin_at',
'checkout_at',
'total_price',
'number_guests',
'status',
'customer_id',
'cancel_reason',
'created_by',
'updated_by',
'created_at',
'updated_at',
];
const TIME = [
'application_date',
'attendance_start_at',
'attendance_end_at',
'approved_at'
];
public static function boot()
{
parent::boot();
}
// public function getSlugOptions() : SlugOptions
// {
// return SlugOptions::create()
// ->generateSlugsFrom('comic_name')
// ->saveSlugsTo('slug');
// }
public function scopeStatus(Builder $query,$status): void
{
$query->where('status',$status);
}
public function roomBookings(){
return $this->hasMany(RoomBooking::class,'booking_id');
}
public function bookingStatus(){
return $this->belongsTo(BookingStatus::class,'status');
}
public function customer(){
return $this->belongsTo(User::class,'customer_id');
}
public function payments(){
return $this->hasMany(Payment::class,'booking_id');
}
public function rooms(){
return $this->belongsToMany(Room::class,'room_booking','booking_id','room_id');
}
}
|