Completed
Push — master ( c13142...c0435c )
by Tobias
02:34
created

src/Model/Customer/CustomerDeliveryAddress.php (1 issue)

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
3
namespace Billogram\Model\Customer;
4
5
use Billogram\Model\CreatableFromArray;
6
7
/**
8
 * @author Ibrahim Hizeoui <[email protected]>
9
 */
10 View Code Duplication
class CustomerDeliveryAddress implements CreatableFromArray
0 ignored issues
show
This class seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
11
{
12
    /**
13
     * @var string
14
     */
15
    private $name;
16
17
    /**
18
     * @var string
19
     */
20
    private $streetAddress;
21
22
    /**
23
     * @var string
24
     */
25
    private $careOf;
26
27
    /**
28
     * @var string
29
     */
30
    private $zipCode;
31
32
    /**
33
     * @var string
34
     */
35
    private $city;
36
37
    /**
38
     * @var string
39
     */
40
    private $country;
41
42 8
    public function __construct()
43
    {
44 8
    }
45
46
    /**
47
     * @return string
48
     */
49
    public function getName()
50
    {
51
        return $this->name;
52
    }
53
54
    /**
55
     * @param string $name
56
     *
57
     * @return CustomerDeliveryAddress
58
     */
59
    public function withName(string $name)
60
    {
61
        $new = clone $this;
62
        $new->name = $name;
63
64
        return $new;
65
    }
66
67
    /**
68
     * @return string
69
     */
70
    public function getStreetAddress()
71
    {
72
        return $this->streetAddress;
73
    }
74
75
    /**
76
     * @param string $streetAddress
77
     *
78
     * @return CustomerDeliveryAddress
79
     */
80
    public function withStreetAddress(string $streetAddress)
81
    {
82
        $new = clone $this;
83
        $new->streetAddress = $streetAddress;
84
85
        return $new;
86
    }
87
88
    /**
89
     * @return string
90
     */
91
    public function getCareOf()
92
    {
93
        return $this->careOf;
94
    }
95
96
    /**
97
     * @param string $careOf
98
     *
99
     * @return CustomerDeliveryAddress
100
     */
101
    public function withCareOf(string $careOf)
102
    {
103
        $new = clone $this;
104
        $new->zipCode = $careOf;
105
106
        return $new;
107
    }
108
109
    /**
110
     * @return string
111
     */
112
    public function getZipCode()
113
    {
114
        return $this->zipCode;
115
    }
116
117
    /**
118
     * @param string $zipCode
119
     *
120
     * @return CustomerDeliveryAddress
121
     */
122
    public function withZipCode(string $zipCode)
123
    {
124
        $new = clone $this;
125
        $new->zipCode = $zipCode;
126
127
        return $new;
128
    }
129
130
    /**
131
     * @return string
132
     */
133
    public function getCity()
134
    {
135
        return $this->city;
136
    }
137
138
    /**
139
     * @param string $city
140
     *
141
     * @return CustomerDeliveryAddress
142
     */
143
    public function withCity(string $city)
144
    {
145
        $new = clone $this;
146
        $new->city = $city;
147
148
        return $new;
149
    }
150
151
    /**
152
     * @return string
153
     */
154
    public function getCountry()
155
    {
156
        return $this->country;
157
    }
158
159
    /**
160
     * @param string $country
161
     *
162
     * @return CustomerDeliveryAddress
163
     */
164
    public function withCountry(string $country)
165
    {
166
        $new = clone $this;
167
        $new->country = $country;
168
169
        return $new;
170
    }
171
172 2
    public function toArray()
173
    {
174 2
        $data = [];
175 2
        if ($this->name !== null) {
176 2
            $data['name'] = $this->name;
177
        }
178 2
        if ($this->streetAddress !== null) {
179 2
            $data['street_address'] = $this->streetAddress;
180
        }
181 2
        if ($this->careOf !== null) {
182 2
            $data['careof'] = $this->careOf;
183
        }
184 2
        if ($this->zipCode !== null) {
185 2
            $data['zipcode'] = $this->zipCode;
186
        }
187 2
        if ($this->city !== null) {
188 2
            $data['city'] = $this->city;
189
        }
190 2
        if ($this->country !== null) {
191 2
            $data['country'] = $this->country;
192
        }
193
194 2
        return $data;
195
    }
196
197
    /**
198
     * Create an API response object from the HTTP response from the API server.
199
     *
200
     * @param array $data
201
     *
202
     * @return self
203
     */
204 8
    public static function createFromArray(array $data)
205
    {
206 8
        $customerDeliveryAddress = new self();
207 8
        $customerDeliveryAddress->name = $data['name'];
208 8
        $customerDeliveryAddress->streetAddress = $data['street_address'];
209 8
        $customerDeliveryAddress->careOf = $data['careof'];
210 8
        $customerDeliveryAddress->zipCode = $data['zipcode'];
211 8
        $customerDeliveryAddress->city = $data['city'];
212 8
        $customerDeliveryAddress->country = $data['country'];
213
214 8
        return $customerDeliveryAddress;
215
    }
216
}
217