CanView::recentViews()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 1
eloc 1
c 1
b 0
f 1
nc 1
nop 0
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
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