aboutsummaryrefslogtreecommitdiffstats
path: root/documentation/application/application-notifications.asciidoc
diff options
context:
space:
mode:
Diffstat (limited to 'documentation/application/application-notifications.asciidoc')
-rw-r--r--documentation/application/application-notifications.asciidoc177
1 files changed, 177 insertions, 0 deletions
diff --git a/documentation/application/application-notifications.asciidoc b/documentation/application/application-notifications.asciidoc
new file mode 100644
index 0000000000..d58bf7b59a
--- /dev/null
+++ b/documentation/application/application-notifications.asciidoc
@@ -0,0 +1,177 @@
+---
+title: Notifications
+order: 7
+layout: page
+---
+
+[[application.notifications]]
+= Notifications
+
+Notifications are error or information boxes that appear briefly, typically at
+the center of the screen. A notification box has a caption and an optional
+description and icon. The box stays on the screen either for a preset time or
+until the user clicks it. The notification type defines the default appearance
+and behaviour of a notification.
+
+There are two ways to create a notification. The easiest is to use a static
+shorthand [methodname]#Notification.show()# method, which takes the caption of
+the notification as a parameter, and an optional description and notification
+type, and displays it in the current page.
+
+
+[source, java]
+----
+Notification.show("This is the caption",
+ "This is the description",
+ Notification.Type.WARNING_MESSAGE);
+----
+
+[[figure.notification.example1]]
+.Notification
+image::img/notification-example2.png[]
+
+For more control, you can create a [classname]#Notification# object. Different
+constructors exist for taking just the caption, and optionally the description,
+notification type, and whether HTML is allowed or not. Notifications are shown
+in a [classname]#Page#, typically the current page.
+
+
+[source, java]
+----
+new Notification("This is a warning",
+ "<br/>This is the <i>last</i> warning",
+ Notification.TYPE_WARNING_MESSAGE, true)
+ .show(Page.getCurrent());
+----
+
+The caption and description are by default written on the same line. If you want
+to have a line break between them, use the HTML line break markup "
+[literal]#++<br/>++#" if HTML is enabled, or " [literal]#++\n++#" if not. HTML
+is disabled by default, but can be enabled with
+[methodname]#setHtmlContentAllowed(true)#. When enabled, you can use any HTML
+markup in the caption and description of a notification. If it is in any way
+possible to get the notification content from user input, you should either
+disallow HTML or sanitize the content carefully, as noted in
+<<dummy/../../../framework/advanced/advanced-security#advanced.security.sanitizing,"Sanitizing
+User Input to Prevent Cross-Site Scripting">>.
+
+[[figure.notification.example2]]
+.Notification with HTML Formatting
+image::img/notification-example3.png[]
+
+[[application.notifications.type]]
+== Notification Type
+
+The notification type defines the overall default style and behaviour of a
+notification. If no notification type is given, the "humanized" type is used as
+the default. The notification types, listed below, are defined in the
+[classname]#Notification.Type# class.
+
+[parameter]#TYPE_HUMANIZED_MESSAGE# image:[]:: A user-friendly message that does not annoy too much: it does not require
+confirmation by clicking and disappears quickly. It is centered and has a
+neutral gray color.
+
+[parameter]#TYPE_WARNING_MESSAGE# image:[]:: Warnings are messages of medium importance. They are displayed with colors that
+are neither neutral nor too distractive. A warning is displayed for 1.5 seconds,
+but the user can click the message box to dismiss it. The user can continue to
+interact with the application while the warning is displayed.
+
+[parameter]#TYPE_ERROR_MESSAGE# image:[]:: Error messages are notifications that require the highest user attention, with
+alert colors, and they require the user to click the message to dismiss it. The
+error message box does not itself include an instruction to click the message,
+although the close box in the upper right corner indicates it visually. Unlike
+with other notifications, the user can not interact with the application while
+the error message is displayed.
+
+[parameter]#TYPE_TRAY_NOTIFICATION# image:[]:: Tray notifications are displayed in the "system tray" area, that is, in the
+lower-right corner of the browser view. As they do not usually obscure any user
+interface, they are displayed longer than humanized or warning messages, 3
+seconds by default. The user can continue to interact with the application
+normally while the tray notification is displayed.
+
+
+
+
+ifdef::web[]
+[[application.notifications.customization]]
+== Customizing Notifications
+
+All of the features of specific notification types can be controlled with the
+[classname]#Notification# properties. Once configured, you need to show it in
+the current page.
+
+
+[source, java]
+----
+// Notification with default settings for a warning
+Notification notif = new Notification(
+ "Warning",
+ "<br/>Area of reindeer husbandry",
+ Notification.TYPE_WARNING_MESSAGE);
+
+// Customize it
+notif.setDelayMsec(20000);
+notif.setPosition(Position.BOTTOM_RIGHT);
+notif.setStyleName("mystyle");
+notif.setIcon(new ThemeResource("img/reindeer.png"));
+
+// Show it in the page
+notif.show(Page.getCurrent());
+----
+
+The [methodname]#setPosition()# method allows setting the positioning of the
+notification. The position can be specified by any of the constants defined in
+the [classname]#Position# enum.
+
+The [methodname]#setDelayMSec()# allows setting the time for how long the
+notification is displayed in milliseconds. Parameter value [literal]#++-1++#
+means that the message is displayed until the user clicks the message box. It
+also prevents interaction with other parts of the application window, which is
+the default behaviour for error notifications. It does not, however, add a close
+box that the error notification has.
+
+endif::web[]
+
+[[application.notifications.css]]
+== Styling with CSS
+
+
+[source, css]
+----
+.v-Notification {}
+ .popupContent {}
+ .gwt-HTML {}
+ h1 {}
+ p {}
+----
+
+The notification box is a floating [literal]#++div++# element under the
+[literal]#++body++# element of the page. It has an overall
+[literal]#++v-Notification++# style. The content is wrapped inside an element
+with [literal]#++popupContent++# style. The caption is enclosed within an
+[literal]#++h1++# element and the description in a [literal]#++p++# element.
+
+To customize it, add a style for the [classname]#Notification# object with
+[methodname]#setStyleName("mystyle")#, and make the settings in the theme, for
+example as follows:
+
+
+[source, css]
+----
+.v-Notification.mystyle {
+ background: #FFFF00;
+ border: 10px solid #C00000;
+ color: black;
+}
+----
+
+The result is shown, with the icon set earlier in the customization example, in
+<<figure.application.errors.notifications.css>>.
+
+[[figure.application.errors.notifications.css]]
+.A Styled Notification
+image::img/notification-customization.png[]
+
+
+
+