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

parseSearchAndRelationClosure()   A

Complexity

Conditions 4
Paths 1

Size

Total Lines 31
Code Lines 27

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 4
eloc 27
nc 1
nop 4
dl 0
loc 31
rs 9.488
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 ParseSearchAndRelationClosureTrait
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 parseSearchAndRelationClosure($value, $relation, $field, $condition)
33
    {
34
        $this->model =
35
            $this->model->whereHas($relation, function (Builder $query) use ($field, $condition, $value) {
36
                switch ($condition) {
37
                    case 'in':
38
                        $query->whereIn($field, $value);
39
                        break;
40
                    case 'between':
41
                        $query->whereBetween($field, $value);
42
                        break;
43
                    case 'cross':
44
                        $query->where(function (Builder $query) use ($field, $value) {
45
                            $query->where(function (Builder $query) use ($field, $value) {
46
                                $query->where("{$field}_min", '<=', $value[0])
47
                                      ->where("{$field}_max", '>=', $value[1]);
48
                            })->orWhere(function (Builder $query) use ($field, $value) {
49
                                $query->where("{$field}_min", '<=', $value[0])
50
                                      ->where("{$field}_max", '>=', $value[0]);
51
                            })->orWhere(function (Builder $query) use ($field, $value) {
52
                                $query->where("{$field}_min", '>=', $value[0])
53
                                      ->where("{$field}_max", '<=', $value[1]);
54
                            })->orWhere(function (Builder $query) use ($field, $value) {
55
                                $query->where("{$field}_min", '>=', $value[0])
56
                                      ->where("{$field}_max", '>=', $value[1])
57
                                      ->where("{$field}_min", '<=', $value[1]);
58
                            });
59
                        });
60
                        break;
61
                    default:
62
                        $query->where($field, $condition, $value);
63
                }
64
            });
65
    }
66
}