Passed
Push — master ( 0c5836...7e4fb9 )
by Thierry
02:39
created

NotifyLibrary::getJs()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 0
dl 0
loc 3
rs 10
c 0
b 0
f 0
1
<?php
2
3
/**
4
 * DialogLibraryInterface.php - Adapter for the Notify library.
5
 *
6
 * @package jaxon-dialogs
7
 * @author Thierry Feuzeu <[email protected]>
8
 * @copyright 2016 Thierry Feuzeu <[email protected]>
9
 * @license https://opensource.org/licenses/BSD-3-Clause BSD 3-Clause License
10
 * @link https://github.com/jaxon-php/jaxon-dialogs
11
 */
12
13
namespace Jaxon\Dialogs\Library\Notify;
14
15
use Jaxon\Ui\Dialog\Library\AbstractDialogLibrary;
0 ignored issues
show
Bug introduced by
The type Jaxon\Ui\Dialog\Library\AbstractDialogLibrary 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...
16
use Jaxon\Ui\Dialog\MessageInterface;
0 ignored issues
show
Bug introduced by
The type Jaxon\Ui\Dialog\MessageInterface 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...
17
18
class NotifyLibrary extends AbstractDialogLibrary implements MessageInterface
19
{
20
    /**
21
     * @const The library name
22
     */
23
    const NAME = 'notify';
24
25
    /**
26
     * @inheritDoc
27
     */
28
    public function getName(): string
29
    {
30
        return self::NAME;
31
    }
32
33
    /**
34
     * @inheritDoc
35
     */
36
    public function getSubdir(): string
37
    {
38
        return 'notify';
39
    }
40
41
    /**
42
     * @inheritDoc
43
     */
44
    public function getVersion(): string
45
    {
46
        return '0.4.2';
47
    }
48
49
    /**
50
     * @inheritDoc
51
     */
52
    public function getJs(): string
53
    {
54
        return $this->xHelper->getJsCode('notify.js');
55
    }
56
57
    /**
58
     * @inheritDoc
59
     */
60
    public function getScript(): string
61
    {
62
        return $this->xHelper->render('notify/alert.js');
63
    }
64
65
    /**
66
     * @inheritDoc
67
     */
68
    public function getReadyScript(): string
69
    {
70
        return $this->xHelper->render('notify/ready.js.php');
71
    }
72
73
    /**
74
     * Print an alert message.
75
     *
76
     * @param string $sMessage The text of the message
77
     * @param string $sTitle The title of the message
78
     * @param string $sClass The type of the message
79
     *
80
     * @return string
81
     */
82
    protected function alert(string $sMessage, string $sTitle, string $sClass): string
83
    {
84
        if($this->returnCode())
85
        {
86
            return "$.notify(" . $sMessage . ", {className:'" . $sClass . "', position:'top center'})";
87
        }
88
        $aOptions = array('message' => $sMessage, 'className' => $sClass);
89
        // Show the alert
90
        $this->addCommand(array('cmd' => 'notify.alert'), $aOptions);
91
        return '';
92
    }
93
94
    /**
95
     * @inheritDoc
96
     */
97
    public function success(string $sMessage, string $sTitle = ''): string
98
    {
99
        return $this->alert($sMessage, $sTitle, 'success');
100
    }
101
102
    /**
103
     * @inheritDoc
104
     */
105
    public function info(string $sMessage, string $sTitle = ''): string
106
    {
107
        return $this->alert($sMessage, $sTitle, 'info');
108
    }
109
110
    /**
111
     * @inheritDoc
112
     */
113
    public function warning(string $sMessage, string $sTitle = ''): string
114
    {
115
        return $this->alert($sMessage, $sTitle, 'warn');
116
    }
117
118
    /**
119
     * @inheritDoc
120
     */
121
    public function error(string $sMessage, string $sTitle = ''): string
122
    {
123
        return $this->alert($sMessage, $sTitle, 'error');
124
    }
125
}
126