Notifications play an important role in targeting the right users at the right time. It helps in the following ways:-
- Increasing App Engagement
- Targeting the right user
- Enhancing the conversion rate
- Engaging user retention for a period of time
Libraries used: -
- Firebase Cloud Messaging: It is a cross-platform messaging solution that lets you reliably send messages at no cost.
- React Native MMKV (Optional): A library that allows you to easily use MMKV inside your React Native applications. We will need this if we want to store fcm token locally in a fast manner.
Let's divide the workflow in easy steps:-
- Setting up react native project.
- Installing Firebase libraries needed for FCM Token generation and notification.
- Integrating React native MMKV for fast storage. (Optional)
- Generating FCM token and storage
- Requesting user permission for the notification.
- Setting up notification Listener
- Testing
React CLI will generate the template for you to get started quickly.
npx react-native init SimpleReactNativeNotification
If you are new to React Native, then follow the React Native Official Docs to setup up the environment.
Firebase libraries provide various method to support the firestore, real-time database firebase, Cloud messaging, and so on.
# Using npm
npm install --save @react-native-firebase/app
# Using Yarn
yarn add @react-native-firebase/app
-
Android Visit Firebase console and start a new project.
Add a new Android application and enter your project details.
Download the google-services.json file and place it inside of your project at the following location:
/android/app/google-services.json
. -
I don't have a mac device💻. so you can follow here 😟
# Install the messaging module
yarn add @react-native-firebase/messaging
or
npm install --save @react-native-firebase/messaging
# If you're developing your app using iOS, run this command
cd ios/ && pod install
We don't need to generate the FCM token every time, as it is the same most of the time.
There are some exceptions, but we can handle them and reduce the number of calls to generate the token every time.
Validity of FCM Token
- The app deletes Instance ID
- The app is restored on a new device
- The user uninstalls/reinstalls the app
- The user clears app data.
yarn add react-native-mmkv
or
npm install --save react-native-mmkv
cd ios && pod install
Create a new file 'storage.js'
import { MMKV } from 'react-native-mmkv'
export const storage = new MMKV()
Hurray! Our mmkv storage is ready to use
Let's write a function to generate the FCM token.
Importing the messaging library which we installed earlier
import messaging from '@react-native-firebase/messaging';
creating a function getFcmToken - './notifications.js'
const getFcmToken = async () => {
try {
const newFcmToken = await messaging().getToken();
console.log(newFcmToken);
return newFcmToken;
} catch (error) {
console.error(error);
return null;
}
};
Let's make changes in App.js
import {getFcmToken} from './notifications';
const App = () => {
....
const [generatedToken, setGeneratedToken] = useState();
useEffect(() => {
const fetchToken = async () => {
const token = await getFcmToken();
if (token) {
setGeneratedToken(token);
}
};
void fetchToken();
}, []);
....
}
creating a function getFcmTokenFromLocalStorage - './notifications.js'
const getFcmTokenFromLocalStorage = async () => {
const fcmtoken = localStorage.getString('fcmtoken');
if (!fcmtoken) {
try {
const newFcmToken = await messaging().getToken();
localStorage.set('fcmtoken', newFcmToken);
} catch (error) {
console.error(error);
}
} else {
console.log('token found', fcmtoken);
}
};
Let's make changes in App.js
import {getFcmToken} from './notifications';
const App = () => {
....
const fcmToken = localStorage.getString('fcmtoken');
useEffect(() => {
const fetchTokenByLocal = async () => {
await getFcmTokenFromLocalStorage();
};
void fetchTokenByLocal();
}, []);
....
}
Use Hooks to see the tokens
useEffect(() => {
console.log('storage', fcmToken, 'newly generated', generatedToken);
}, [fcmToken, generatedToken]);
iOS prevent notification unless explicitly approved by the user.
On Android, you do not need to request user permission. This method can still be called on Android devices; however, and will always resolve successfully.
In Android, we don't need any special permission for notification, but this function can still be called and will resolve successfully
const requestUserPermission = async () => {
const authStatus = await messaging().requestPermission();
const enabled =
authStatus === messaging.AuthorizationStatus.AUTHORIZED ||
authStatus === messaging.AuthorizationStatus.PROVISIONAL;
if (enabled) {
console.log('Authorization status:', authStatus);
}
};
We can listen for real-time FCM messages on any device.
State | Description |
---|---|
Foreground | When the application is open and in view. |
Background | When the application is open, however, in the background (minimized). This typically occurs when the user has pressed the "home" button on the device or has switched to another app via the app switcher. |
Quit | When the device is locked or the application is not active or running. The user can quit an app by "swiping it away" via the app switcher UI on the device. |
You can read more about here.
Let's Handle these three cases: -
const notificationListener = () => {
messaging().onNotificationOpenedApp(remoteMessage => {
console.log(
'Notification caused app to open from background state:',
remoteMessage.notification,
);
});
// Quiet and Background State -> Check whether an initial notification is available
messaging()
.getInitialNotification()
.then(remoteMessage => {
if (remoteMessage) {
console.log(
'Notification caused app to open from quit state:',
remoteMessage.notification,
);
}
})
.catch(error => console.log('failed', error));
// Foreground State
messaging().onMessage(async remoteMessage => {
console.log('foreground', remoteMessage);
});
};
For handling the Background notification, we need to add a handler at the './index.js'
import messaging from '@react-native-firebase/messaging';
// Register background handler
messaging().setBackgroundMessageHandler(async remoteMessage => {
console.log('Message handled in the background!', remoteMessage);
});
First, grab the token from the terminal generated by console.log.
Visit TestFcm.com
We need the server keys to test. We can get this from the firebase console.
Open the project and get the server key by following the below steps:-
If your cloud messaging api is not enabled then
Resources : -
- Push Notification In React Native Using Firebase - Android & IOS Tutorial 2022
- React Native Firebase Official Docs
https://testfcm.com/ and make mock call