Customizing notifications
Batch allows you to customize your notifications adding specific keys to the payload or by setting some configuration in native code.
Advanced notification configuration is highly OS-specific and requires implementation at a lower level than Flutter.
Therefore, you might find what you want in the native documentations for each OS:
Small push notification icon
In order to make sure that users understand that your notifications come from your app, you need to setup a Small Icon and Notification Color. An icon can be generated using Android Studio's asset generator: as it will be tinted and masked by the system, only the alpha channel matters and will define the shape displayed. It should be of 24x24dp size. If your notifications shows up in the system statusbar in a white shape, this is what you need to configure.
This can be configured in the manifest as metadata in the application tag:
<!-- Assuming there is a push_icon.png in your res/drawable-{dpi} folder -->
<manifest ...>
<application ...>
<meta-data
android:name="com.batch.android.push.smallicon"
android:resource="@drawable/push_icon" />
<!-- Notification color. ARGB but the alpha value can only be FF -->
<meta-data
android:name="com.batch.android.push.color"
android:value="#FF00FF00" />
For more information, please see the android native documentation.
Disabling foreground notifications
By default, the Batch Flutter plugin will always show foreground notifications on both platforms.
The SDK exposes a method on BatchPush
to change this behaviour on iOS only:
BatchPush.instance.setShowForegroundNotificationsOniOS(true);
- This requires your app to use
BatchUNUserNotificationCenterDelegate
as described in the native integration. If you made your ownUNUserNotificationCenterDelegate
subclass, the Dart API will not do anything and you will have to implement this manually.- Disabling foreground notifications on iOS will automatically trigger mobile landings when attached to a push received while the App is in foreground. You can have the same behaviour on android by using the native API
Batch.Messaging.setShowForegroundLandings(true)
but the sdk will still display foreground notifications when no landing is attached.
Adding notification actions
Notification actions are supported but they integration differ greatly between iOS and Android. Please see the native documentations for more info:
Overriding the notification channel on Android
It is possible to override the default notification channel on Android either globally on a per notification basis.
As this is an operation that needs to be done by native code in the background when Flutter isn't running, please follow our native channels documentation.