71 lines
1.8 KiB
PHP
71 lines
1.8 KiB
PHP
<?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',
|
|
];
|
|
|
|
protected $hidden = [
|
|
'created_at',
|
|
'updated_at',
|
|
];
|
|
|
|
public static function find(int $room_id)
|
|
{
|
|
return self::where('room_id', $room_id)->first();
|
|
}
|
|
|
|
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');
|
|
}
|
|
|
|
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;
|
|
}
|
|
|
|
}
|