Completed
Push — master ( abd274...070f80 )
by ARCANEDEV
10s
created

SeoHelper::setImage()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 7
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 4
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 7
c 0
b 0
f 0
cc 1
eloc 4
nc 1
nop 1
ccs 4
cts 4
cp 1
crap 1
rs 9.4285
1
<?php namespace Arcanedev\SeoHelper;
2
3
use Arcanedev\SeoHelper\Contracts\SeoHelper as SeoHelperContract;
4
use Arcanedev\SeoHelper\Contracts\SeoMeta as SeoMetaContract;
5
use Arcanedev\SeoHelper\Contracts\SeoOpenGraph as SeoOpenGraphContract;
6
use Arcanedev\SeoHelper\Contracts\SeoTwitter as SeoTwitterContract;
7
8
/**
9
 * Class     SeoHelper
10
 *
11
 * @package  Arcanedev\SeoHelper
12
 * @author   ARCANEDEV <[email protected]>
13
 */
14
class SeoHelper implements SeoHelperContract
15
{
16
    /* -----------------------------------------------------------------
17
     |  Properties
18
     | -----------------------------------------------------------------
19
     */
20
    /**
21
     * The SeoMeta instance.
22
     *
23
     * @var \Arcanedev\SeoHelper\Contracts\SeoMeta
24
     */
25
    private $seoMeta;
26
27
    /**
28
     * The SeoOpenGraph instance.
29
     *
30
     * @var \Arcanedev\SeoHelper\Contracts\SeoOpenGraph
31
     */
32
    private $seoOpenGraph;
33
34
    /**
35
     * The SeoTwitter instance.
36
     *
37
     * @var \Arcanedev\SeoHelper\Contracts\SeoTwitter
38
     */
39
    private $seoTwitter;
40
41
    /* -----------------------------------------------------------------
42
     |  Constructor
43
     | -----------------------------------------------------------------
44
     */
45
    /**
46
     * Make SeoHelper instance.
47
     *
48
     * @param  \Arcanedev\SeoHelper\Contracts\SeoMeta       $seoMeta
49
     * @param  \Arcanedev\SeoHelper\Contracts\SeoOpenGraph  $seoOpenGraph
50
     * @param  \Arcanedev\SeoHelper\Contracts\SeoTwitter    $seoTwitter
51
     */
52 60
    public function __construct(
53
        SeoMetaContract      $seoMeta,
54
        SeoOpenGraphContract $seoOpenGraph,
55
        SeoTwitterContract   $seoTwitter
56
    ) {
57 60
        $this->setSeoMeta($seoMeta);
58 60
        $this->setSeoOpenGraph($seoOpenGraph);
59 60
        $this->setSeoTwitter($seoTwitter);
60 60
    }
61
62
    /* -----------------------------------------------------------------
63
     |  Getters & Setters
64
     | -----------------------------------------------------------------
65
     */
66
    /**
67
     * Get SeoMeta instance.
68
     *
69
     * @return \Arcanedev\SeoHelper\Contracts\SeoMeta
70
     */
71 42
    public function meta()
72
    {
73 42
        return $this->seoMeta;
74
    }
75
76
    /**
77
     * Set SeoMeta instance.
78
     *
79
     * @param  \Arcanedev\SeoHelper\Contracts\SeoMeta  $seoMeta
80
     *
81
     * @return \Arcanedev\SeoHelper\SeoHelper
82
     */
83 60
    public function setSeoMeta(SeoMetaContract $seoMeta)
84
    {
85 60
        $this->seoMeta = $seoMeta;
86
87 60
        return $this;
88
    }
89
90
    /**
91
     * Get SeoOpenGraph instance.
92
     *
93
     * @return \Arcanedev\SeoHelper\Contracts\SeoOpenGraph
94
     */
95 42
    public function openGraph()
96
    {
97 42
        return $this->seoOpenGraph;
98
    }
99
100
    /**
101
     * Get SeoOpenGraph instance (alias).
102
     *
103
     * @see openGraph()
104
     *
105
     * @return \Arcanedev\SeoHelper\Contracts\SeoOpenGraph
106
     */
107 3
    public function og()
108
    {
109 3
        return $this->openGraph();
110
    }
111
112
    /**
113
     * Get SeoOpenGraph instance.
114
     *
115
     * @param  \Arcanedev\SeoHelper\Contracts\SeoOpenGraph  $seoOpenGraph
116
     *
117
     * @return \Arcanedev\SeoHelper\SeoHelper
118
     */
119 60
    public function setSeoOpenGraph(SeoOpenGraphContract $seoOpenGraph)
120
    {
121 60
        $this->seoOpenGraph = $seoOpenGraph;
122
123 60
        return $this;
124
    }
125
126
    /**
127
     * Get SeoTwitter instance.
128
     *
129
     * @return \Arcanedev\SeoHelper\Contracts\SeoTwitter
130
     */
131 39
    public function twitter()
132
    {
133 39
        return $this->seoTwitter;
134
    }
135
136
    /**
137
     * Set SeoTwitter instance.
138
     *
139
     * @param  \Arcanedev\SeoHelper\Contracts\SeoTwitter  $seoTwitter
140
     *
141
     * @return \Arcanedev\SeoHelper\SeoHelper
142
     */
143 60
    public function setSeoTwitter(SeoTwitterContract $seoTwitter)
144
    {
145 60
        $this->seoTwitter = $seoTwitter;
146
147 60
        return $this;
148
    }
149
150
    /**
151
     * Set title.
152
     *
153
     * @param  string       $title
154
     * @param  string|null  $siteName
155
     * @param  string|null  $separator
156
     *
157
     * @return \Arcanedev\SeoHelper\SeoHelper
158
     */
159 9
    public function setTitle($title, $siteName = null, $separator = null)
160
    {
161 9
        $this->meta()->setTitle($title, null, $separator);
162 9
        $this->openGraph()->setTitle($title);
163 9
        $this->twitter()->setTitle($title);
164
165 9
        return $this->setSiteName($siteName);
166
    }
167
168
    /**
169
     * Set the site name.
170
     *
171
     * @param  string  $siteName
172
     *
173
     * @return self
174
     */
175 9
    public function setSiteName($siteName)
176
    {
177 9
        $this->meta()->setSiteName($siteName);
178 9
        $this->openGraph()->setSiteName($siteName);
179
180 9
        return $this;
181
    }
182
183
    /**
184
     * Set description.
185
     *
186
     * @param  string  $description
187
     *
188
     * @return \Arcanedev\SeoHelper\Contracts\SeoHelper
189
     */
190 6
    public function setDescription($description)
191
    {
192 6
        $this->meta()->setDescription($description);
193 6
        $this->openGraph()->setDescription($description);
194 6
        $this->twitter()->setDescription($description);
195
196 6
        return $this;
197
    }
198
199
    /**
200
     * Set keywords.
201
     *
202
     * @param  array|string  $keywords
203
     *
204
     * @return \Arcanedev\SeoHelper\SeoHelper
205
     */
206 6
    public function setKeywords($keywords)
207
    {
208 6
        $this->meta()->setKeywords($keywords);
209
210 6
        return $this;
211
    }
212
213
    /**
214
     * Set Image.
215
     *
216
     * @param  string  $imageUrl
217
     *
218
     * @return \Arcanedev\SeoHelper\SeoHelper
219
     */
220 3
    public function setImage($imageUrl)
221
    {
222 3
        $this->openGraph()->setImage($imageUrl);
223 3
        $this->twitter()->addImage($imageUrl);
224
225 3
        return $this;
226
    }
227
228
    /* -----------------------------------------------------------------
229
     |  Main Methods
230
     | -----------------------------------------------------------------
231
     */
232
    /**
233
     * Render all seo tags.
234
     *
235
     * @return string
236
     */
237 36
    public function render()
238
    {
239 36
        return implode(PHP_EOL, array_filter([
240 36
            $this->meta()->render(),
241 36
            $this->openGraph()->render(),
242 36
            $this->twitter()->render(),
243 12
        ]));
244
    }
245
246
    /**
247
     * Render all seo tags with HtmlString object.
248
     *
249
     * @return \Illuminate\Support\HtmlString
250
     */
251 3
    public function renderHtml()
252
    {
253 3
        return new \Illuminate\Support\HtmlString(
254 3
            $this->render()
255 1
        );
256
    }
257
258
    /**
259
     * Render the tag.
260
     *
261
     * @return string
262
     */
263 21
    public function __toString()
264
    {
265 21
        return $this->render();
266
    }
267
268
    /**
269
     * Enable the OpenGraph.
270
     *
271
     * @return \Arcanedev\SeoHelper\SeoHelper
272
     */
273 3
    public function enableOpenGraph()
274
    {
275 3
        $this->openGraph()->enable();
276
277 3
        return $this;
278
    }
279
280
    /**
281
     * Disable the OpenGraph.
282
     *
283
     * @return \Arcanedev\SeoHelper\SeoHelper
284
     */
285 3
    public function disableOpenGraph()
286
    {
287 3
        $this->openGraph()->disable();
288
289 3
        return $this;
290
    }
291
292
    /**
293
     * Enable the Twitter Card.
294
     *
295
     * @return \Arcanedev\SeoHelper\SeoHelper
296
     */
297 3
    public function enableTwitter()
298
    {
299 3
        $this->twitter()->enable();
300
301 3
        return $this;
302
    }
303
304
    /**
305
     * Disable the Twitter Card.
306
     *
307
     * @return \Arcanedev\SeoHelper\SeoHelper
308
     */
309 3
    public function disableTwitter()
310
    {
311 3
        $this->twitter()->disable();
312
313 3
        return $this;
314
    }
315
}
316