CanView::getRecentViews()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 8
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 2
eloc 4
c 1
b 0
f 1
nc 2
nop 1
dl 0
loc 8
ccs 5
cts 5
cp 1
crap 2
rs 10
1
<?php
2
3
namespace RecentlyViewed\Models\Traits;
4
5
use Illuminate\Database\Eloquent\Model;
6
use Illuminate\Database\Eloquent\Relations\MorphMany;
7
use Illuminate\Support\Collection;
8
use RecentlyViewed\PersistManager;
9
10
trait CanView
11
{
12 4
    public function deleteRecentViews(array|string|null $types = null)
13
    {
14 4
        if (is_null($types)) {
15 2
            return $this->recentViews()->delete();
16
        }
17
18 2
        return $this->recentViews()->whereIn('type', (array) $types)->delete();
19
    }
20
21 5
    public function getRecentViews(array|string|null $types = null): Collection
22
    {
23 5
        $query = $this->recentViews();
24 5
        if (!is_null($types)) {
25 4
            $query->whereIn('type', (array) $types);
26
        }
27
28 5
        return $query->get()->pluck('views', 'type')->map(fn ($views) => json_decode($views, true));
29
    }
30
31 6
    public function syncRecentViews(string $type, array $data = []): Model
32
    {
33 6
        $data = array_filter($data, fn ($i) => !empty($i) && (is_string($i) || is_integer($i)));
34
35 6
        return $this->recentViews()->updateOrCreate(['type' => $type], ['views' => json_encode($data)]);
36
    }
37
38 7
    public function recentViews(): MorphMany
39
    {
40 7
        return $this->morphMany(PersistManager::$model, 'viewer');
0 ignored issues
show
Bug introduced by
It seems like morphMany() 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

40
        return $this->/** @scrutinizer ignore-call */ morphMany(PersistManager::$model, 'viewer');
Loading history...
41
    }
42
}
43