PluginProbe ʕ •ᴥ•ʔ
Matomo Analytics – Powerful, Privacy-First Insights for WordPress / 5.2.2
Matomo Analytics – Powerful, Privacy-First Insights for WordPress v5.2.2
5.11.1 5.11.0 5.10.2 5.10.1 trunk 1.0.2 1.0.3 1.0.4 1.0.5 1.0.6 1.1.0 1.1.1 1.1.2 1.1.3 1.2.0 1.3.0 1.3.1 1.3.2 4.0.0 4.0.1 4.0.2 4.0.3 4.0.4 4.1.0 4.1.1 4.1.2 4.1.3 4.10.0 4.11.0 4.12.0 4.13.0 4.13.2 4.13.3 4.13.4 4.13.5 4.14.0 4.14.1 4.14.2 4.15.0 4.15.1 4.15.2 4.15.3 4.2.0 4.3.0 4.3.1 4.4.1 4.4.2 4.5.0 4.6.0 5.0.1 5.0.2 5.0.3 5.0.4 5.0.5 5.0.6 5.0.7 5.0.8 5.1.0 5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7 5.10.0 5.2.0 5.2.1 5.2.2 5.3.0 5.3.1 5.3.2 5.3.3 5.6.0 5.6.1 5.7.0 5.7.1 5.8.0 5.8.1 5.8.2
matomo / app / core / Notification.php
matomo / app / core Last commit date
API 1 year ago Access 1 year ago Application 1 year ago Archive 1 year ago ArchiveProcessor 1 year ago Archiver 2 years ago AssetManager 1 year ago Auth 1 year ago Category 2 years ago Changes 1 year ago CliMulti 1 year ago Columns 1 year ago Concurrency 1 year ago Config 1 year ago Container 1 year ago CronArchive 1 year ago DataAccess 1 year ago DataFiles 2 years ago DataTable 1 year ago Db 1 year ago DeviceDetector 1 year ago Email 2 years ago Exception 1 year ago Http 1 year ago Intl 1 year ago Log 2 years ago Mail 1 year ago Measurable 1 year ago Menu 1 year ago Metrics 1 year ago Notification 1 year ago Period 1 year ago Plugin 1 year ago ProfessionalServices 1 year ago Report 1 year ago ReportRenderer 1 year ago Scheduler 1 year ago Segment 1 year ago Session 1 year ago Settings 1 year ago Tracker 1 year ago Translation 1 year ago Twig 1 year ago UpdateCheck 1 year ago Updater 1 year ago Updates 1 year ago Validators 1 year ago View 1 year ago ViewDataTable 1 year ago Visualization 1 year ago Widget 1 year ago .htaccess 2 years ago Access.php 1 year ago Archive.php 1 year ago ArchiveProcessor.php 1 year ago AssetManager.php 1 year ago Auth.php 2 years ago AuthResult.php 2 years ago BaseFactory.php 2 years ago Cache.php 2 years ago CacheId.php 1 year ago CliMulti.php 1 year ago Common.php 1 year ago Config.php 1 year ago Console.php 1 year ago Context.php 2 years ago Cookie.php 1 year ago CronArchive.php 1 year ago DI.php 1 year ago DataArray.php 1 year ago DataTable.php 1 year ago Date.php 1 year ago Db.php 1 year ago DbHelper.php 1 year ago Development.php 1 year ago ErrorHandler.php 1 year ago EventDispatcher.php 1 year ago ExceptionHandler.php 1 year ago FileIntegrity.php 1 year ago Filechecks.php 1 year ago Filesystem.php 1 year ago FrontController.php 1 year ago Http.php 1 year ago IP.php 1 year ago Log.php 2 years ago LogDeleter.php 1 year ago Mail.php 1 year ago Metrics.php 1 year ago NoAccessException.php 2 years ago Nonce.php 1 year ago Notification.php 1 year ago NumberFormatter.php 1 year ago Option.php 1 year ago Period.php 1 year ago Piwik.php 1 year ago Plugin.php 1 year ago Process.php 1 year ago Profiler.php 1 year ago ProxyHeaders.php 2 years ago ProxyHttp.php 1 year ago QuickForm2.php 1 year ago RankingQuery.php 1 year ago ReportRenderer.php 1 year ago Request.php 1 year ago Segment.php 1 year ago Sequence.php 2 years ago Session.php 1 year ago SettingsPiwik.php 1 year ago SettingsServer.php 1 year ago Singleton.php 2 years ago Site.php 1 year ago SiteContentDetector.php 1 year ago SupportedBrowser.php 2 years ago TCPDF.php 1 year ago Theme.php 1 year ago Timer.php 2 years ago Tracker.php 1 year ago Twig.php 1 year ago Unzip.php 1 year ago UpdateCheck.php 1 year ago Updater.php 1 year ago UpdaterErrorException.php 2 years ago Updates.php 1 year ago Url.php 1 year ago UrlHelper.php 1 year ago Version.php 1 year ago View.php 1 year ago bootstrap.php 1 year ago dispatch.php 2 years ago testMinimumPhpVersion.php 2 years ago
Notification.php
188 lines
1 <?php
2
3 /**
4 * Matomo - free/libre analytics platform
5 *
6 * @link https://matomo.org
7 * @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
8 */
9 namespace Piwik;
10
11 /**
12 * Describes a UI notification.
13 *
14 * UI notifications are messages displayed to the user near the top of the screen.
15 * Notifications consist of a message, a context (the message type), a priority
16 * and a display type.
17 *
18 * **The context** affects the way the message looks, but not how it is displayed.
19 *
20 * **The display type** determines how the message is displayed.
21 *
22 * **The priority** determines where it is shown in the list of all displayed notifications.
23 *
24 * ### Examples
25 *
26 * **Display an error message**
27 *
28 * $notification = new Notification('My Error Message');
29 * $notification->context = Notification::CONTEXT_ERROR;
30 * Notification\Manager::notify('myUniqueNotificationId', $notification);
31 *
32 * **Display a temporary success message**
33 *
34 * $notification = new Notification('Success');
35 * $notification->context = Notification::CONTEXT_SUCCESS;
36 * $notification->type = Notification::TYPE_TOAST;
37 * Notification\Manager::notify('myUniqueNotificationId', $notification);
38 *
39 * **Display a message near the top of the screen**
40 *
41 * $notification = new Notification('Urgent: Your password has expired!');
42 * $notification->context = Notification::CONTEXT_INFO;
43 * $notification->type = Notification::TYPE_PERSISTENT;
44 * $notification->priority = Notification::PRIORITY_MAX;
45 *
46 * @api
47 */
48 class Notification
49 {
50 public const CONTEXT_SUCCESS = 'success';
51 public const CONTEXT_ERROR = 'error';
52 public const CONTEXT_INFO = 'info';
53 public const CONTEXT_WARNING = 'warning';
54 /**
55 * Lowest priority value.
56 */
57 public const PRIORITY_MIN = 1;
58 /**
59 * Lower priority value.
60 */
61 public const PRIORITY_LOW = 25;
62 /**
63 * Higher priority value.
64 */
65 public const PRIORITY_HIGH = 50;
66 /**
67 * Highest priority value.
68 */
69 public const PRIORITY_MAX = 100;
70 /**
71 * If this flag is applied, no close icon will be displayed. _Note: persistent notifications always have a close
72 * icon._
73 *
74 * See {@link $flags}.
75 */
76 public const FLAG_NO_CLEAR = 1;
77 /**
78 * If this flag is applied, a close icon will be displayed.
79 *
80 * See {@link $flags}.
81 */
82 public const FLAG_CLEAR = 0;
83 /**
84 * Notifications of this type will be displayed for a few seconds and then faded out.
85 */
86 public const TYPE_TOAST = 'toast';
87 /**
88 * Notifications of this type will be displayed until the new user explicitly closes the notification.
89 * The notifications will display even if the user reloads the page.
90 */
91 public const TYPE_PERSISTENT = 'persistent';
92 /**
93 * Notifications of this type will be displayed only once. They will disappear after a page reload or
94 * change.
95 */
96 public const TYPE_TRANSIENT = 'transient';
97 /**
98 * The notification title. The title is optional and is displayed directly before the message content.
99 *
100 * @var string
101 */
102 public $title;
103 /**
104 * The notification message. Must be set.
105 *
106 * @var string
107 */
108 public $message;
109 /**
110 * Contains extra display options.
111 *
112 * Usage: `$notification->flags = Notification::FLAG_BAR | Notification::FLAG_FOO`.
113 *
114 * @var int
115 */
116 public $flags = self::FLAG_NO_CLEAR;
117 /**
118 * The notification's display type. See `TYPE_*` constants in {@link Notification}.
119 *
120 * @var string
121 */
122 public $type = self::TYPE_TRANSIENT;
123 /**
124 * The notification's context (message type). See `CONTEXT_*` constants in {@link Notification}.
125 *
126 * A notification's context determines how it will be styled.
127 *
128 * @var string
129 */
130 public $context = self::CONTEXT_INFO;
131 /**
132 * The notification's priority. The higher the priority, the higher the order. See `PRIORITY_*`
133 * constants in {@link Notification} to see possible priority values.
134 *
135 * @var int
136 */
137 public $priority;
138 /**
139 * If true, the message will not be escaped before being outputted as HTML. If you set this to
140 * `true`, make sure you escape text yourself in order to avoid XSS vulnerabilities.
141 *
142 * @var bool
143 */
144 public $raw = \false;
145 /**
146 * Constructor.
147 *
148 * @param string $message The notification message.
149 * @throws \Exception If the message is empty.
150 */
151 public function __construct($message)
152 {
153 if (empty($message)) {
154 throw new \Exception('No notification message given');
155 }
156 $this->message = $message;
157 }
158 /**
159 * Returns `1` if the notification will be displayed without a close button, `0` if otherwise.
160 *
161 * @return int `1` or `0`.
162 */
163 public function hasNoClear()
164 {
165 if ($this->flags & self::FLAG_NO_CLEAR) {
166 return 1;
167 }
168 return 0;
169 }
170 /**
171 * Returns the notification's priority. If no priority has been set, a priority will be set based
172 * on the notification's context.
173 *
174 * @return int
175 */
176 public function getPriority()
177 {
178 if (!isset($this->priority)) {
179 $typeToPriority = array(static::CONTEXT_ERROR => static::PRIORITY_MAX, static::CONTEXT_WARNING => static::PRIORITY_HIGH, static::CONTEXT_SUCCESS => static::PRIORITY_MIN, static::CONTEXT_INFO => static::PRIORITY_LOW);
180 if (array_key_exists($this->context, $typeToPriority)) {
181 return $typeToPriority[$this->context];
182 }
183 return static::PRIORITY_LOW;
184 }
185 return $this->priority;
186 }
187 }
188