EditViewHelper   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 42
Duplicated Lines 0 %

Importance

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

2 Methods

Rating   Name   Duplication   Size   Complexity  
A render() 0 15 3
A initializeArguments() 0 11 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\Editable;
21
use CuyZ\Notiz\Core\Notification\Notification;
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 EditViewHelper 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
48
    /**
49
     * @inheritdoc
50
     */
51
    public function render()
52
    {
53
        /** @var Notification $notification */
54
        $notification = $this->arguments['notification'];
55
56
        if (!$notification instanceof Editable
57
            || !$notification->isEditable()
58
        ) {
59
            return '';
60
        }
61
62
        $this->tag->addAttribute('href', $notification->getEditionUri());
63
        $this->tag->setContent($this->renderChildren());
64
65
        return $this->tag->render();
66
    }
67
}
68