HasVocabularies::vocabularies()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 3
rs 10
c 0
b 0
f 0
cc 1
eloc 1
nc 1
nop 0
1
<?php
2
3
/** Created by PhpStorm,  User: jonphipps,  Date: 2017-05-22,  Time: 11:44 AM */
4
5
namespace App\Models\Traits;
6
7
use App\Models\Project;
8
use App\Models\Vocabulary;
9
use Illuminate\Database\Eloquent\Relations\HasMany;
10
11
trait HasVocabularies
12
{
13
    /**
14
     * @return string
15
     */
16
    public function getVocabColumn()
17
    {
18
        $count = $this->vocabularies()->count();
19
20
        return $count ?
21
            '<a href="' .
22
            url('projects/' . $this->id . '/vocabularies') .
23
            '">' .
24
            Project::badge($count) : '&nbsp;';
25
    }
26
27
    public function vocabularies(): ?HasMany
28
    {
29
        return $this->hasMany(Vocabulary::class, 'agent_id', 'id');
0 ignored issues
show
Bug introduced by
It seems like hasMany() must be provided by classes using this trait. How about adding it as abstract method to this trait? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

29
        return $this->/** @scrutinizer ignore-call */ hasMany(Vocabulary::class, 'agent_id', 'id');
Loading history...
30
    }
31
}
32