Creating Notifications
You can create notifications via administration UI or programmatically in code.
Administration UI
After the add-on is added to your application, the main menu contains the Notifications item. The Notifications browser provides a list of created notifications and buttons for managing them.
data:image/s3,"s3://crabby-images/77b39/77b396d544a70c629cf7602ed2642d73682b452e" alt="ntf list"
The notification editor appears after clicking the Create new notification button.
data:image/s3,"s3://crabby-images/08d64/08d64dca8a5b4f1f111a76cb1284a11b4cec600e" alt="ntf editor"
The dialog provides the following fields to fill in:
-
Subject – a subject of the notification.
-
Type – a type of notification. There are no default notification types. See the configuration section to create types.
-
Recipients – list of recipients of the notification. Start typing a username in the field, and select the appropriate users from the list.
-
Channels – a channel used for notification.
-
In-app channel – a user will receive the notification in the application UI.
-
Email channel – a user will receive an email with the notification. (available with Email add-on.)
-
-
Body – body of the notification.
Programmatic Creation
The NotificationManager service provides methods to send notifications to users.
In the example below, a notification is sent to the user every time a new order is created.
data:image/s3,"s3://crabby-images/b39ab/b39abc74458b94aa6623d8d502f3544a70bfc7e2" alt="ntf programmatic"
private boolean justCreated;
@ViewComponent
private TypedTextField<Integer> numberField;
@Autowired
protected NotificationManager notificationManager;
@Subscribe
public void onInitEntity(InitEntityEvent<Order> event) {
justCreated = true;
}
@Subscribe(target = Target.DATA_CONTEXT)
public void onPostSave(final DataContext.PostSaveEvent event) { (1)
if (justCreated) { (2)
notificationManager.createNotification() (3)
.withSubject("New order")(4)
.withRecipientUsernames("admin") (5)
.toChannelsByNames("in-app") (6)
.withContentType(ContentType.PLAIN) (7)
.withBody("A new order with number " + numberField.getValue()+ " is created.") (8)
.send(); (9)
}
}
1 | This method is invoked after saving changes. |
2 | Checks if this entity is newly created. |
3 | Initiates NotificationRequestBuilder that creates a new NotificationRequest object. |
4 | Defines the subject of the notification. |
5 | Sets the recipient by the provided username. |
6 | Sets notification channels by provided names. The in-app and email are available. |
7 | Set notification body content type. |
8 | Sets notification body. |
9 | Creates and sends the notification request. |