4. Advanced Notifications with Message Templates
Before we begin, please ensure the Notifications add-on is installed. If it is not currently installed, please install it before continuing.
In this section, you will:
-
Set up the Notifications add-on.
-
Create a
Plain text
template using the template editor. -
Add parameters to a template.
-
Create a notification that leverages this template, demonstrating its practical application.
Setting Up the Notifications Add-on
For a detailed example of configuring the Notifications add-on, please refer to the Configuration section. Here, we’ll provide a concise overview of the key steps.
Proceed with the following actions:
-
Create a set of
NotificationType
instances and register them viaNotificationTypesRepository
within your main application class:@Autowired private NotificationTypesRepository notificationTypesRepository; @EventListener public void onApplicationContextRefreshed(final ContextRefreshedEvent event) { notificationTypesRepository.registerTypes( new NotificationType("info", "INFO_CIRCLE"), new NotificationType("warn", "WARNING") ); }
-
Add a notification indicator component to the
main-view.xml
file:<mainView xmlns="http://jmix.io/schema/flowui/main-view" xmlns:ntf="http://jmix.io/schema/notifications/ui" title="msg://MainView.title"> <navigationBar> <header id="header" classNames="jmix-main-view-header"> <drawerToggle id="drawerToggle" classNames="jmix-main-view-drawer-toggle" themeNames="contrast" ariaLabel="msg://drawerToggle.ariaLabel"/> <h1 id="viewTitle" classNames="jmix-main-view-title"/> </header> <ntf:notificationsIndicator id="ntfIndicator" classNames="me-m"/> </navigationBar>
Creating Message Template
Launch the application. Navigate to the Message Templates view. Click the Create button to start creating a new template.
After clicking Create, the template designer will open. Configure the template as follows:
-
Name: Enter a user-friendly name for the template, such as
Booking Notification
. -
Code: Set the template code to
booking-notification
. -
Type: Select Plain text as the template type.
-
Content: Define the content of the template:
Hello ${booking.creator.firstName}! Thank you for booking your date and time for ${booking.title}. Your time starts at ${booking.startDate?datetime} and ends at ${booking.endDate?datetime} The booking took place ${today?date}. The penalty for false is ${penalty?string.currency}. Have a nice day, Developer team. Developer www.jmix.io
This template is formatted using placeholders with Apache FreeMarker Template Engine syntax.
data:image/s3,"s3://crabby-images/073d2/073d2901da4635c35d74a8b965d90c81b6179ced" alt="template notifications details"
Adding Template Parameters
Switch to the Parameters tab of template designer. Click the Create button. Provide the following parameter details:
-
Name: The name of the parameter as it will appear in the parameter input form:
Booking
. -
Alias: A unique identifier used to reference the parameter within the template:
booking
. -
Type: The data type of the parameter. Select the
Entity
type. -
Entity: Select the
Booking
entity to be used as the parameter.
data:image/s3,"s3://crabby-images/734c2/734c20514f10fc360dcfbc2700b0cb0452bf6a0a" alt="template parameter"
Click the OK button.
Create the Penalty parameter, ensuring it’s configured as a Number
type. Then, create the Today parameter and set its type to Date
:
data:image/s3,"s3://crabby-images/b8a8b/b8a8b3e58fae3e14883db3c13a886763420bc2c6" alt="template notifications params"
Once the template is configured, save it.
Creating a Notification
Navigate to the Notifications view. Click the Create notification button to begin creating a new notification. Configure the notification as follows:
-
Subject: the subject of the notification -
Booking information
. -
Type: select the notification type you created earlier in this section. Choose
Info
. -
Recipients: list of recipients of the notification. Start typing a username in the field, and select the appropriate users from the list.
-
Select the Use message template checkbox. A template selection field will appear below.
-
Click the … button in the Message template field.
-
The message template selection dialog will open. Choose the previously created template,
Booking Notification
, and click the Select button. -
After that, a dialog box will appear, prompting you to enter values for the parameters you previously defined for the template. Fill in the required fields with the appropriate values. Click OK.
-
After you click OK in the notification creation dialog, the notification will be saved and displayed to the specified user.
Viewing Notification
Log in as the Mari
user. Look for the notification indicator, located in the upper-right corner of the main view, and click it. The In-app notifications dialog window will appear, showing a list of unread or recent notifications:
data:image/s3,"s3://crabby-images/cfa5e/cfa5e1cae4bb2dd8dcd6008b9cff0197357cbb28" alt="in app notifications"
Double-click on a notification to view its full content:
data:image/s3,"s3://crabby-images/3d870/3d87017372bd96e3fdc2e95ff985b0d9482e2f44" alt="in app notification open"
You’ll notice that the parameter values you provided when creating the notification have been automatically inserted into the corresponding placeholders within the message template, personalizing the notification content.
Summary
In this section, you have successfully:
-
Configured the Notifications add-on.
-
Created a reusable
Plain Text
message template using the template editor. -
Defined parameters for the message template, enabling dynamic content.
-
Created and sent a notification that leverages the message template, demonstrating a practical application of advanced notification features.