Completed
Push — develop-3.0 ( bd5ff0...545efb )
by Mohamed
02:33
created

IssueScopes   A

Complexity

Total Complexity 21

Size/Duplication

Total Lines 186
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Importance

Changes 0
Metric Value
wmc 21
c 0
b 0
f 0
lcom 1
cbo 3
dl 0
loc 186
rs 10

12 Methods

Rating   Name   Duplication   Size   Complexity  
A scopeOpen() 0 4 1
A scopeClosed() 0 4 1
A scopeStatus() 0 4 1
A scopeAssignedTo() 0 4 1
A scopeCreatedBy() 0 4 1
A scopeForProject() 0 4 1
A scopeAssignedOrCreated() 0 8 3
A scopeLimitByCreatedForInternalProject() 0 8 4
A scopeNumber() 0 4 1
A whereIdEqual() 0 9 3
A scopeSearchContent() 0 11 2
A scopeWhereTags() 0 12 2
1
<?php
2
3
/*
4
 * This file is part of the Tinyissue package.
5
 *
6
 * (c) Mohamed Alsharaf <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace Tinyissue\Model\Project;
13
14
use Illuminate\Database\Eloquent;
15
use Illuminate\Database\Eloquent\Builder;
16
use Tinyissue\Model;
17
18
/**
19
 * IssueScopes is trait class containing the model scope methods.
20
 *
21
 * @author Mohamed Alsharaf <[email protected]>
22
 *
23
 * @property static $this
24
 */
25
trait IssueScopes
26
{
27
    /**
28
     * Filter status by open status.
29
     *
30
     * @param Builder $query
31
     *
32
     * @return Builder
33
     */
34
    public function scopeOpen(Builder $query)
35
    {
36
        return $this->scopeStatus($query, Issue::STATUS_OPEN);
37
    }
38
39
    /**
40
     * Filter status by closed status.
41
     *
42
     * @param Builder $query
43
     *
44
     * @return Builder
45
     */
46
    public function scopeClosed(Builder $query)
47
    {
48
        return $this->scopeStatus($query, Issue::STATUS_CLOSED);
49
    }
50
51
    /**
52
     * Filter status by a status.
53
     *
54
     * @param Builder $query
55
     * @param int     $status
56
     *
57
     * @return Builder
58
     */
59
    public function scopeStatus(Builder $query, $status = Issue::STATUS_OPEN)
60
    {
61
        return $query->where('status', '=', $status);
62
    }
63
64
    /**
65
     * Filter issue by created by or assigned to field based on user role.
66
     *
67
     * @param Builder   $query
68
     * @param Model\User|null $user
69
     *
70
     * @return Builder
71
     */
72
    public function scopeAssignedOrCreated(Builder $query, Model\User $user = null)
73
    {
74
        if ($user instanceof Model\User && $user->isUser()) {
75
            return $this->scopeCreatedBy($query, $user);
76
        }
77
78
        return $this->scopeAssignedTo($query, $user);
79
    }
80
81
    /**
82
     * Filter issue by assigned to.
83
     *
84
     * @param Builder         $query
85
     * @param null|Model\User $user
86
     *
87
     * @return Builder
88
     */
89
    public function scopeAssignedTo(Builder $query, $user = null)
90
    {
91
        return $this->whereIdEqual($query, 'assigned_to', $user);
92
    }
93
94
    /**
95
     * Filter issue by created by.
96
     *
97
     * @param Builder   $query
98
     * @param Model\User|null $user
99
     *
100
     * @return Builder
101
     */
102
    public function scopeCreatedBy(Builder $query, Model\User $user = null)
103
    {
104
        return $this->whereIdEqual($query, 'created_by', $user);
105
    }
106
107
    /**
108
     * Filter issue by created by if user logged in as User role adn current project is private internal.
109
     *
110
     * @param Builder       $query
111
     * @param Model\Project $project
112
     * @param Model\User|null     $user
113
     *
114
     * @return Builder
115
     */
116
    public function scopeLimitByCreatedForInternalProject(Builder $query, Model\Project $project, Model\User $user = null)
117
    {
118
        if ($user && $user->isUser() && $project->isPrivateInternal()) {
119
            $query = $this->scopeCreatedBy($query, $user);
120
        }
121
122
        return $query;
123
    }
124
125
    /**
126
     * Filter issue by project id.
127
     *
128
     * @param Builder $query
129
     * @param int     $projectId
130
     *
131
     * @return Builder
132
     */
133
    public function scopeForProject(Builder $query, $projectId)
134
    {
135
        return $this->whereIdEqual($query, 'project_id', $projectId);
136
    }
137
138
    /**
139
     * Filter issue by internal issue number.
140
     *
141
     * @param Builder $query
142
     * @param int     $number
143
     *
144
     * @return Builder
145
     */
146
    public function scopeNumber(Builder $query, $number)
147
    {
148
        return $this->whereIdEqual($query, 'issue_no', $number);
149
    }
150
151
    /**
152
     * Helper method to filter by a field and a value.
153
     *
154
     * @param Builder            $query
155
     * @param string             $field
156
     * @param int|Eloquent\Model|null $idOrObject
157
     *
158
     * @return $this|Builder
159
     */
160
    protected function whereIdEqual(Builder $query, $field, $idOrObject)
161
    {
162
        $id = $idOrObject instanceof Eloquent\Model ? $idOrObject->id : $idOrObject;
163
        if ($id > 0) {
164
            return $query->where($field, '=', $id);
165
        }
166
167
        return $query;
168
    }
169
170
    /**
171
     * Filter with like %% on issue string fields title/body.
172
     *
173
     * @param Builder $query
174
     * @param string  $keyword
175
     *
176
     * @return Builder
177
     */
178
    public function scopeSearchContent(Builder $query, $keyword)
179
    {
180
        if (!empty($keyword)) {
181
            return $query->where(function (Builder $query) use ($keyword) {
182
                $query->where('title', 'like', '%' . $keyword . '%');
183
                $query->orWhere('body', 'like', '%' . $keyword . '%');
184
            });
185
        }
186
187
        return $query;
188
    }
189
190
    /**
191
     * Filter issues by an array of tag ids.
192
     *
193
     * @param Builder $query
194
     * @param array   ...$tags
195
     *
196
     * @return Builder
197
     */
198
    public function scopeWhereTags(Builder $query, ...$tags)
199
    {
200
        $tags = array_filter($tags);
201
202
        if (!empty($tags)) {
203
            $query->whereHas('tags', function (Builder $query) use ($tags) {
204
                $query->whereIn('id', $tags);
205
            });
206
        }
207
208
        return $query;
209
    }
210
}
211