ActivateViewHelper::render()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 15
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 7
c 1
b 0
f 0
nc 2
nop 0
dl 0
loc 15
rs 10
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\Definition\Tree\EventGroup\Event\EventDefinition;
21
use CuyZ\Notiz\Core\Notification\Activable;
22
use CuyZ\Notiz\Core\Notification\Notification;
23
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...
24
25
class ActivateViewHelper extends AbstractTagBasedViewHelper
26
{
27
    /**
28
     * @var string
29
     */
30
    protected $tagName = 'a';
31
32
    /**
33
     * @inheritdoc
34
     */
35
    public function initializeArguments()
36
    {
37
        parent::initializeArguments();
38
39
        $this->registerUniversalTagAttributes();
40
41
        $this->registerArgument(
42
            'notification',
43
            Notification::class,
44
            '',
45
            true
46
        );
47
48
        $this->registerArgument(
49
            'eventDefinition',
50
            EventDefinition::class,
51
            ''
52
        );
53
    }
54
55
    /**
56
     * @inheritdoc
57
     */
58
    public function render()
59
    {
60
        /** @var Notification $notification */
61
        $notification = $this->arguments['notification'];
62
63
        if (!$notification instanceof Activable) {
64
            return '';
65
        }
66
67
        $uri = $notification->getSwitchActivationUri($this->arguments['eventDefinition']);
68
69
        $this->tag->addAttribute('href', $uri);
70
        $this->tag->setContent($this->renderChildren());
71
72
        return $this->tag->render();
73
    }
74
}
75