Passed
Push — feature/optimize ( cf938e...7e8046 )
by Fu
03:43
created

parseSearchAndClosure()   A

Complexity

Conditions 4
Paths 4

Size

Total Lines 29
Code Lines 25

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 4
eloc 25
nc 4
nop 3
dl 0
loc 29
rs 9.52
c 0
b 0
f 0
1
<?php
2
3
4
namespace Modules\Core\Traits\Criteria;
5
6
7
use Illuminate\Database\Eloquent\Builder;
8
9
trait ParseSearchAndClosureTrait
10
{
11
    /** @var \Illuminate\Http\Request $request */
12
    protected $request;
13
    /** @var \Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Eloquent\Model|\Illuminate\Database\Query\Builder $model */
14
    protected $model;
15
    /** @var \Prettus\Repository\Contracts\RepositoryInterface $repository */
16
    protected $repository;
17
    protected $search;
18
    protected $searchData;
19
    protected $searchFields;
20
    protected $isFirstField;
21
    protected $modelForceAndWhere;
22
    protected $fieldsSearchable;
23
    protected $fields;
24
    protected $filter;
25
    protected $orderBy;
26
    protected $sortedBy;
27
    protected $with;
28
    protected $searchJoin;
29
    protected $acceptedConditions;
30
    protected $originalFields;
31
32
    protected function parseSearchAndClosure($value, $field, $condition)
33
    {
34
        switch ($condition) {
35
            case 'in':
36
                $this->model = $this->model->whereIn($field, $value);
37
                break;
38
            case 'between':
39
                $this->model = $this->model->whereBetween($field, $value);
40
                break;
41
            case 'cross':
42
                $this->model = $this->model->where(function (Builder $query) use ($field, $value) {
43
                    $query->where(function (Builder $query) use ($field, $value) {
44
                        $query->where("{$field}_min", '<=', $value[0])
45
                              ->where("{$field}_max", '>=', $value[1]);
46
                    })->orWhere(function (Builder $query) use ($field, $value) {
47
                        $query->where("{$field}_min", '<=', $value[0])
48
                              ->where("{$field}_max", '>=', $value[0]);
49
                    })->orWhere(function (Builder $query) use ($field, $value) {
50
                        $query->where("{$field}_min", '>=', $value[0])
51
                              ->where("{$field}_max", '<=', $value[1]);
52
                    })->orWhere(function (Builder $query) use ($field, $value) {
53
                        $query->where("{$field}_min", '>=', $value[0])
54
                              ->where("{$field}_max", '>=', $value[1])
55
                              ->where("{$field}_min", '<=', $value[1]);
56
                    });
57
                });
58
                break;
59
            default:
60
                $this->model = $this->model->where($field, $condition, $value);
61
        }
62
    }
63
}