ShowViewHelper   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 50
Duplicated Lines 0 %

Importance

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

2 Methods

Rating   Name   Duplication   Size   Complexity  
A render() 0 17 3
A initializeArguments() 0 17 1
1
<?php
2
declare(strict_types=1);
3
4
/*
5
 * Copyright (C)
6
 * Nathan Boiron <[email protected]>
7
 * Romain Canon <[email protected]>
8
 *
9
 * This file is part of the TYPO3 NotiZ project.
10
 * It is free software; you can redistribute it and/or modify it
11
 * under the terms of the GNU General Public License, either
12
 * version 3 of the License, or any later version.
13
 *
14
 * For the full copyright and license information, see:
15
 * http://www.gnu.org/licenses/gpl-3.0.html
16
 */
17
18
namespace CuyZ\Notiz\ViewHelpers\Notification\Link;
19
20
use CuyZ\Notiz\Core\Notification\Notification;
21
use CuyZ\Notiz\Core\Notification\Viewable;
22
use TYPO3\CMS\Fluid\Core\ViewHelper\AbstractTagBasedViewHelper;
0 ignored issues
show
Bug introduced by
The type TYPO3\CMS\Fluid\Core\Vie...tractTagBasedViewHelper was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
23
24
class ShowViewHelper extends AbstractTagBasedViewHelper
25
{
26
    /**
27
     * @var string
28
     */
29
    protected $tagName = 'a';
30
31
    /**
32
     * @inheritdoc
33
     */
34
    public function initializeArguments()
35
    {
36
        parent::initializeArguments();
37
38
        $this->registerUniversalTagAttributes();
39
40
        $this->registerArgument(
41
            'notification',
42
            Notification::class,
43
            '',
44
            true
45
        );
46
47
        $this->registerArgument(
48
            'graceful',
49
            'bool',
50
            'If the link can not be generated, the content will still be displayed without the link.'
51
        );
52
    }
53
54
    /**
55
     * @inheritdoc
56
     */
57
    public function render()
58
    {
59
        /** @var Notification $notification */
60
        $notification = $this->arguments['notification'];
61
62
        if (!$notification instanceof Viewable) {
63
            if ($this->arguments['graceful']) {
64
                return $this->renderChildren();
65
            }
66
67
            return '';
68
        }
69
70
        $this->tag->addAttribute('href', $notification->getViewUri());
71
        $this->tag->setContent($this->renderChildren());
72
73
        return $this->tag->render();
74
    }
75
}
76