Completed
Push — master ( 6ffea5...ef6d85 )
by Adam
104:53 queued 98:00
created

Room::scopeFreeRoomsForReservation()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 9
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
cc 1
eloc 6
nc 1
nop 4
dl 0
loc 9
ccs 0
cts 7
cp 0
crap 2
rs 9.6666
c 0
b 0
f 0
1
<?php
2
3
namespace App\Models;
4
5
use Illuminate\Database\Eloquent\Model;
6
7
/**
8
 * App\Models\Room.
9
 *
10
 * @property int $id
11
 * @property string $number
12
 * @property int $floor
13
 * @property int $capacity
14
 * @property float $price
15
 * @property string|null $comment
16
 * @property \Carbon\Carbon|null $created_at
17
 * @property \Carbon\Carbon|null $updated_at
18
 *
19
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Room whereCapacity($value)
20
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Room whereComment($value)
21
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Room whereCreatedAt($value)
22
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Room whereFloor($value)
23
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Room whereId($value)
24
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Room whereNumber($value)
25
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Room wherePrice($value)
26
 * @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Room whereUpdatedAt($value)
27
 * @mixin \Eloquent
28
 */
29
class Room extends Model
30
{
31
    protected $fillable = [
32
        'number', 'floor', 'capacity', 'price', 'comment',
33
    ];
34
35
    /**
36
     * @param \Illuminate\Database\Eloquent\Builder $query
37
     *
38
     * @return \Illuminate\Database\Eloquent\Builder
39
     */
40
    public function scopeFreeRoomsForReservation($query, $dateStart, $dateEnd, $people)
41
    {
42
        return $query->whereNotIn('id', function ($query) use ($dateStart, $dateEnd) {
43
            $query->select('room_id')->from('reservations')
44
                ->where('date_start', '<', $dateEnd)
45
                ->where('date_end', '>', $dateStart);
46
            })
47
            ->where('capacity', '>=', $people)
48
            ->orderBy('capacity');
49
    }
50
}
51