PluginProbe ʕ •ᴥ•ʔ
Matomo Analytics – Powerful, Privacy-First Insights for WordPress / trunk
Matomo Analytics – Powerful, Privacy-First Insights for WordPress vtrunk
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 month ago Access 3 months ago Application 1 month ago Archive 1 month ago ArchiveProcessor 1 month ago Archiver 2 years ago AssetManager 1 month ago Auth 6 months ago Category 6 months ago Changes 1 month ago CliMulti 1 year ago Columns 1 month ago Concurrency 1 month ago Config 1 month ago Container 1 month ago CronArchive 3 months ago DataAccess 1 month ago DataFiles 2 years ago DataTable 2 weeks ago Db 2 weeks ago DeviceDetector 1 year ago Email 2 years ago Exception 4 months ago Http 4 months ago Intl 3 months ago Log 2 years ago Mail 1 year ago Measurable 6 months ago Menu 1 month ago Metrics 3 months ago Notification 6 months ago Period 1 month ago Plugin 2 weeks ago Policy 1 month ago ProfessionalServices 1 year ago Report 1 year ago ReportRenderer 3 months ago Request 3 months ago Scheduler 1 month ago Segment 1 month ago Session 2 weeks ago Settings 1 month ago Tracker 2 weeks ago Translation 1 month ago Twig 1 year ago UpdateCheck 3 months ago Updater 1 month ago Updates 2 days ago Validators 1 year ago View 1 month ago ViewDataTable 2 weeks ago Visualization 1 year ago Widget 1 month ago .htaccess 2 years ago Access.php 1 month ago Archive.php 1 month ago ArchiveProcessor.php 1 month ago AssetManager.php 1 month ago Auth.php 6 months ago AuthResult.php 6 months ago BaseFactory.php 2 years ago Cache.php 2 years ago CacheId.php 4 months ago CliMulti.php 1 month ago Common.php 2 weeks ago Config.php 1 month ago Console.php 3 months ago Context.php 2 years ago Cookie.php 1 year ago CronArchive.php 1 month ago DI.php 3 months ago DataArray.php 1 month ago DataTable.php 1 month ago Date.php 1 month ago Db.php 1 month ago DbHelper.php 1 month ago Development.php 1 year ago ErrorHandler.php 6 months ago EventDispatcher.php 1 month ago ExceptionHandler.php 4 months ago FileIntegrity.php 1 month ago Filechecks.php 1 year ago Filesystem.php 1 month ago FrontController.php 4 months ago Http.php 1 month ago IP.php 1 year ago Log.php 3 months ago LogDeleter.php 1 year ago Mail.php 1 year ago Metrics.php 1 month ago NoAccessException.php 2 years ago Nonce.php 6 months ago Notification.php 1 month ago NumberFormatter.php 5 months ago Option.php 5 months ago Period.php 1 month ago Piwik.php 1 month ago Plugin.php 1 month ago Process.php 1 month ago Profiler.php 6 months ago ProxyHeaders.php 4 months ago ProxyHttp.php 5 months ago QuickForm2.php 3 months ago RankingQuery.php 1 month ago ReportRenderer.php 1 month ago Request.php 1 month ago Segment.php 1 month ago Sequence.php 6 months ago Session.php 2 weeks ago SettingsPiwik.php 1 month ago SettingsServer.php 1 year ago Singleton.php 2 years ago Site.php 1 month ago SiteContentDetector.php 1 month ago SupportedBrowser.php 2 years ago TCPDF.php 1 year ago Theme.php 1 year ago Timer.php 1 month ago Tracker.php 1 month ago Twig.php 1 month ago Unzip.php 1 year ago UpdateCheck.php 1 month ago Updater.php 1 month ago UpdaterErrorException.php 2 years ago Updates.php 3 months ago Url.php 3 months ago UrlHelper.php 1 month ago Version.php 2 days ago View.php 1 month ago bootstrap.php 1 year ago dispatch.php 2 years ago testMinimumPhpVersion.php 6 months ago
Notification.php
186 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 * @param string $message The notification message.
147 * @throws \Exception If the message is empty.
148 */
149 public function __construct($message)
150 {
151 if (empty($message)) {
152 throw new \Exception('No notification message given');
153 }
154 $this->message = $message;
155 }
156 /**
157 * Returns `1` if the notification will be displayed without a close button, `0` if otherwise.
158 *
159 * @return int `1` or `0`.
160 */
161 public function hasNoClear()
162 {
163 if ($this->flags & self::FLAG_NO_CLEAR) {
164 return 1;
165 }
166 return 0;
167 }
168 /**
169 * Returns the notification's priority. If no priority has been set, a priority will be set based
170 * on the notification's context.
171 *
172 * @return int
173 */
174 public function getPriority()
175 {
176 if (!isset($this->priority)) {
177 $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);
178 if (array_key_exists($this->context, $typeToPriority)) {
179 return $typeToPriority[$this->context];
180 }
181 return static::PRIORITY_LOW;
182 }
183 return $this->priority;
184 }
185 }
186