TextFilter::apply()   A
last analyzed

Complexity

Conditions 6
Paths 17

Size

Total Lines 26
Code Lines 17

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 11
CRAP Score 7.0986

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 6
eloc 17
c 1
b 0
f 0
nc 17
nop 1
dl 0
loc 26
rs 9.0777
ccs 11
cts 16
cp 0.6875
crap 7.0986
1
<?php
2
3
namespace Yaro\Jarboe\Table\Filters;
4
5
class TextFilter extends AbstractFilter
6
{
7
    protected $like = [
8
        'left'  => true,
9
        'right' => true,
10
    ];
11
12 2
    public function like($left = true, $right = true)
13
    {
14 2
        $this->like = [
15 2
            'left'  => $left,
16 2
            'right' => $right,
17
        ];
18
19 2
        return $this;
20
    }
21
22 1
    public function render()
23
    {
24 1
        return view('jarboe::crud.filters.text', [
25 1
            'filter' => $this,
26
        ]);
27
    }
28
29 2
    public function apply($query)
30
    {
31 2
        $value = $this->value();
32 2
        if (is_null($value)) {
33 1
            return;
34
        }
35
36 1
        $leftPart  = $this->like['left'] ? '%' : '';
37 1
        $rightPart = $this->like['right'] ? '%' : '';
38 1
        $sign      = array_filter($this->like) ? 'like' : $this->sign;
39
40 1
        if ($this->field()->isRelationField()) {
41
            $query->whereHas($this->field()->getRelationMethod(), function ($query) use ($value, $sign, $leftPart, $rightPart) {
42
                $query->where(
43
                    $this->field()->getRelationTitleField(),
44
                    $sign,
45
                    $leftPart . $value . $rightPart
46
                );
47
            });
48
            return;
49
        }
50
51 1
        $query->where(
52 1
            $this->field->name(),
53
            $sign,
54 1
            $leftPart . $value . $rightPart
55
        );
56 1
    }
57
}
58