cineflex/app/Models/Room.php

72 lines
1.8 KiB
PHP
Raw Normal View History

2022-11-23 09:32:34 +01:00
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class Room extends Model
{
protected $table = 'rooms';
protected $primaryKey = 'room_id';
public $timestamps = false;
protected $fillable = [
'room_name',
'room_rows',
'room_columns',
'user_id', // who added the room?
'cinema_id',
2022-11-23 09:32:34 +01:00
];
protected $hidden = [
'created_at',
'updated_at',
];
public static function find(int $room_id)
{
return self::where('room_id', $room_id)->first();
}
2022-11-23 09:32:34 +01:00
public function showings()
{
return $this->hasMany(Showing::class, 'room_id', 'room_id');
}
public function seats()
{
return $this->hasMany(Seat::class, 'room_id', 'room_id');
}
public function cinema()
{
return $this->belongsTo(Cinema::class, 'cinema_id', 'cinema_id');
}
2022-11-23 09:32:34 +01:00
2023-01-01 20:13:11 +01:00
public function seatMatrix($showing_id = null)
{
$seats = $this->seats;
$matrix = [];
// first, create an empty matrix
for ($i = 0; $i < $this->room_rows-1; $i++) {
$matrix[$i] = [];
for ($j = 0; $j < $this->room_columns-1; $j++) {
$matrix[$i][$j] = null;
}
}
// then, fill it with the seats
foreach ($seats as $seat) {
$matrix[$seat->seat_row-1][$seat->seat_column-1] = [
'seat_id' => $seat->seat_id,
'seat_row' => $seat->seat_row,
'seat_column' => $seat->seat_column,
'seat_type' => $seat->seat_type,
'seat_linked_id' => $seat->seat_linked_id,
'reserved' => $showing_id ? $seat->isReserved($showing_id) : false,
];
}
return $matrix;
}
2022-11-23 09:32:34 +01:00
}