HasAddress   A
last analyzed

Complexity

Total Complexity 2

Size/Duplication

Total Lines 22
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 4
c 1
b 0
f 0
dl 0
loc 22
rs 10
wmc 2

2 Methods

Rating   Name   Duplication   Size   Complexity  
A address() 0 3 1
A bootHasAddress() 0 4 1
1
<?php
2
3
namespace Signifly\Addresses\Traits;
4
5
use Illuminate\Database\Eloquent\Relations\MorphOne;
6
7
trait HasAddress
8
{
9
    /**
10
     * Boot the `HasAddress` trait for the model.
11
     *
12
     * @return void
13
     */
14
    public static function bootHasAddress()
15
    {
16
        static::deleting(function ($model) {
17
            $model->address()->delete();
18
        });
19
    }
20
21
    /**
22
     * The associated address relation.
23
     *
24
     * @return \Illuminate\Database\Eloquent\Relations\MorphOne
25
     */
26
    public function address(): MorphOne
27
    {
28
        return $this->morphOne(config('addresses.address_model'), 'addressable');
0 ignored issues
show
Bug introduced by
It seems like morphOne() 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

28
        return $this->/** @scrutinizer ignore-call */ morphOne(config('addresses.address_model'), 'addressable');
Loading history...
29
    }
30
}
31