I am new to Capacitor and ionic framework. I am trying to use FCM to trigger and deep link into my app. Following are the outputs:
Ios: App in background, foreground and killed state - when tap on push, pushNotificationActionPerformed listener is called properly.
Android: App in background and killed state - when tap on push, pushNotificationActionPerformed listener is called properly.
App in foreground- when tap on push, pushNotificationActionPerformed is never called, I can see pushNotificationReceived listener is called but I need to capture the tap from user to deep link them into certain page of my app. Basically, nothing happens when I try to tap on push.
Following is the code I have added till now: capacitor.config.json:
"PushNotifications": {
"presentationOptions": [
"badge",
"sound",
"alert"
]
}
AndroidManifest.xml:
<intent-filter>
<action android:name="MOBILE-PUSH-DEEP-LINK" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
Push payload:
{
"to": "FCM token",
"notification": {
"body": "test",
"title": "Dummy",
"click_action": "MOBILE-PUSH-DEEP-LINK"
},
"data": {
"data1": "test",
"data2": "12345",
}
}
Thanks in advance for your help!
Implemented the following solution till capacitor comes up with a proper update to deal with foreground push notifications.
private async fcmReceiver() {
await PushNotifications.addListener(
'pushNotificationReceived',
async (notification: PushNotificationSchema) => {
//only for android foreground push notification
//since capacitor has still not implemented tap on android //foreground notif
if (this.platformService.isNativeAndroid) {
await PushNotifications.getDeliveredNotifications().then((x) => {
PushNotifications.removeDeliveredNotifications(x);
});
this.foregrndLocalNotif(notification);
}
},
);
await PushNotifications.addListener('pushNotificationActionPerformed', (payload) => {
if (payload.actionId === 'tap') {
this.handlePushMessageAction(payload.notification.data);
}
});
await LocalNotifications.addListener(
'localNotificationActionPerformed',
(payload: ActionPerformed) => {
if (payload.actionId === 'tap') {
this.handlePushMessageAction(payload.notification.extra);
}
},
);
}
private foregrndLocalNotif(notification: any) {
LocalNotifications.schedule({
notifications: [
{
id: 1,
title: notification.title,
body: notification.body,
schedule: { at: new Date(Date.now() + 1000 * 1) },
extra: notification.data,
},
],
});
}