A library that provides an API to fetch push notification tokens and to present, schedule, receive and respond to notifications.
expo-notifications
provides an API to fetch push notification tokens and to present, schedule, receive and respond to notifications.
Do not miss our guides on how to set up, send, and handle push notifications.
Push notifications (remote notifications) functionality provided byexpo-notifications
will be unavailable in Expo Go from SDK 53. A development build will be required to use push notifications. Local notifications (in-app notifications) will remain available in Expo Go.
-
npx expo install expo-notifications
If you are installing this in an existing React Native app, start by installing expo
in your project. Then, follow the additional instructions as mentioned by the library's README under "Installation in bare React Native projects" section.
Check out the example Snack below to see Notifications in action, make sure to use a physical device to test it. Push notifications don't work on emulators/simulators.
import { useState, useEffect, useRef } from 'react';
import { Text, View, Button, Platform } from 'react-native';
import * as Device from 'expo-device';
import * as Notifications from 'expo-notifications';
import Constants from 'expo-constants';
Notifications.setNotificationHandler({
handleNotification: async () => ({
shouldShowAlert: true,
shouldPlaySound: false,
shouldSetBadge: false,
}),
});
export default function App() {
const [expoPushToken, setExpoPushToken] = useState('');
const [channels, setChannels] = useState<Notifications.NotificationChannel[]>([]);
const [notification, setNotification] = useState<Notifications.Notification | undefined>(
undefined
);
const notificationListener = useRef<Notifications.EventSubscription>();
const responseListener = useRef<Notifications.EventSubscription>();
useEffect(() => {
registerForPushNotificationsAsync().then(token => token && setExpoPushToken(token));
if (Platform.OS === 'android') {
Notifications.getNotificationChannelsAsync().then(value => setChannels(value ?? []));
}
notificationListener.current = Notifications.addNotificationReceivedListener(notification => {
setNotification(notification);
});
responseListener.current = Notifications.addNotificationResponseReceivedListener(response => {
console.log(response);
});
return () => {
notificationListener.current &&
Notifications.removeNotificationSubscription(notificationListener.current);
responseListener.current &&
Notifications.removeNotificationSubscription(responseListener.current);
};
}, []);
return (
<View
style={{
flex: 1,
alignItems: 'center',
justifyContent: 'space-around',
}}>
<Text>Your expo push token: {expoPushToken}</Text>
<Text>{`Channels: ${JSON.stringify(
channels.map(c => c.id),
null,
2
)}`}</Text>
<View style={{ alignItems: 'center', justifyContent: 'center' }}>
<Text>Title: {notification && notification.request.content.title} </Text>
<Text>Body: {notification && notification.request.content.body}</Text>
<Text>Data: {notification && JSON.stringify(notification.request.content.data)}</Text>
</View>
<Button
title="Press to schedule a notification"
onPress={async () => {
await schedulePushNotification();
}}
/>
</View>
);
}
async function schedulePushNotification() {
await Notifications.scheduleNotificationAsync({
content: {
title: "You've got mail! 📬",
body: 'Here is the notification body',
data: { data: 'goes here', test: { test1: 'more data' } },
},
trigger: {
type: SchedulableTriggerInputTypes.TIME_INTERVAL,
seconds: 2,
},
});
}
async function registerForPushNotificationsAsync() {
let token;
if (Platform.OS === 'android') {
await Notifications.setNotificationChannelAsync('myNotificationChannel', {
name: 'A channel is needed for the permissions prompt to appear',
importance: Notifications.AndroidImportance.MAX,
vibrationPattern: [0, 250, 250, 250],
lightColor: '#FF231F7C',
});
}
if (Device.isDevice) {
const { status: existingStatus } = await Notifications.getPermissionsAsync();
let finalStatus = existingStatus;
if (existingStatus !== 'granted') {
const { status } = await Notifications.requestPermissionsAsync();
finalStatus = status;
}
if (finalStatus !== 'granted') {
alert('Failed to get push token for push notification!');
return;
}
// Learn more about projectId:
// https://docs.expo.dev/push-notifications/push-notifications-setup/#configure-projectid
// EAS projectId is used here.
try {
const projectId =
Constants?.expoConfig?.extra?.eas?.projectId ?? Constants?.easConfig?.projectId;
if (!projectId) {
throw new Error('Project ID not found');
}
token = (
await Notifications.getExpoPushTokenAsync({
projectId,
})
).data;
console.log(token);
} catch (e) {
token = `${e}`;
}
} else {
alert('Must use physical device for Push Notifications');
}
return token;
}
import * as Notifications from 'expo-notifications';
// First, set the handler that will cause the notification
// to show the alert
Notifications.setNotificationHandler({
handleNotification: async () => ({
shouldShowAlert: true,
shouldPlaySound: false,
shouldSetBadge: false,
}),
});
// Second, call scheduleNotificationAsync()
Notifications.scheduleNotificationAsync({
content: {
title: 'Look at that notification',
body: "I'm so proud of myself!",
},
trigger: null,
});
If you'd like to deep link to a specific screen in your app when you receive a push notification, you can configure either of Expo's navigation systems to do that.
You can use Expo Router's built-in deep linking to handle incoming URLs from push notifications. Simply configure the root layout to listen for incoming and initial notification events.
import { useEffect } from 'react';
import * as Notifications from 'expo-notifications';
import { router } from 'expo-router';
function useNotificationObserver() {
useEffect(() => {
let isMounted = true;
function redirect(notification: Notifications.Notification) {
const url = notification.request.content.data?.url;
if (url) {
router.push(url);
}
}
Notifications.getLastNotificationResponseAsync()
.then(response => {
if (!isMounted || !response?.notification) {
return;
}
redirect(response?.notification);
});
const subscription = Notifications.addNotificationResponseReceivedListener(response => {
redirect(response.notification);
});
return () => {
isMounted = false;
subscription.remove();
};
}, []);
}
export default function Layout() {
useNotificationObserver();
return <Slot />;
}
React Navigation's manual linking configuration can be configured to handle incoming redirects from push notifications:
import React from 'react';
import { Linking } from 'react-native';
import * as Notifications from 'expo-notifications';
import { NavigationContainer } from '@react-navigation/native';
export default function App() {
return (
<NavigationContainer
linking={{
config: {
// Configuration for linking
},
async getInitialURL() {
// First, you may want to do the default deep link handling
// Check if app was opened from a deep link
const url = await Linking.getInitialURL();
if (url != null) {
return url;
}
// Handle URL from expo push notifications
const response = await Notifications.getLastNotificationResponseAsync();
return response?.notification.request.content.data.url;
},
subscribe(listener) {
const onReceiveURL = ({ url }: { url: string }) => listener(url);
// Listen to incoming links from deep linking
const eventListenerSubscription = Linking.addEventListener('url', onReceiveURL);
// Listen to expo push notifications
const subscription = Notifications.addNotificationResponseReceivedListener(response => {
const url = response.notification.request.content.data.url;
// Any custom logic to see whether the URL needs to be handled
//...
// Let React Navigation handle the URL
listener(url);
});
return () => {
// Clean up the event listeners
eventListenerSubscription.remove();
subscription.remove();
};
},
}}>
{/* Your app content */}
</NavigationContainer>
);
}
See more details on React Navigation documentation.
Firebase Cloud Messaging credentials are required for all Android apps to receive push notifications in your app (except when testing in Expo Go). For more information, see how to get FCM credentials for your app.
To register your iOS device and automatically enable push notifications for your EAS Build, see push notification setup.
To configure expo-notifications
, use the built-in config plugin in the app config (app.json or app.config.js) for EAS Build or with npx expo run:[android|ios]
. The plugin allows you to configure the following properties that cannot be set at runtime and require building a new app binary to take effect:
Name | Default | Description |
---|---|---|
icon | - | Only for: Android Local path to an image to use as the icon for push notifications. 96x96 all-white png with transparency. |
color | #ffffff | Only for: Android Tint color for the push notification image when it appears in the notification tray. |
defaultChannel | - | Only for: Android Default channel for FCMv1 notifications. |
sounds | - | Array of local paths to sound files (.wav recommended) that can be used as custom notification sounds. |
enableBackgroundRemoteNotifications | false | Only for: iOS Whether to enable background remote notifications, as described in Apple documentation. This updates the |
Here is an example of using the config plugin in the app config file:
{
"expo": {
"plugins": [
[
"expo-notifications",
{
"icon": "./local/assets/notification_icon.png",
"color": "#ffffff",
"defaultChannel": "default",
"sounds": [
"./local/assets/notification_sound.wav",
"./local/assets/notification_sound_other.wav"
],
"enableBackgroundRemoteNotifications": false
}
]
]
}
}
The iOS APNs entitlement is always set to 'development'. Xcode automatically changes this to 'production' during the archive. Learn more.
Learn how to configure the native projects in the installation instructions in the expo-notifications
repository.
On Android, this module requires permission to subscribe to the device boot. It's used to set up scheduled notifications when the device (re)starts.
The RECEIVE_BOOT_COMPLETED
permission is added automatically through the library AndroidManifest.xml.
Starting from Android 12 (API level 31), to schedule a notification that triggers at an exact time, you need to add
<uses-permission android:name="android.permission.SCHEDULE_EXACT_ALARM"/>
to AndroidManifest.xml.
Read more about the exact alarm permission.
On Android 13, app users must opt-in to receive notifications via a permissions prompt automatically triggered by the operating system.
This prompt will not appear until at least one notification channel is created. The setNotificationChannelAsync
must be called before
getDevicePushTokenAsync
or getExpoPushTokenAsync
to obtain a push token. You can read more about the new notification permission behavior for Android 13
in the official documentation.
Android Permission | Description |
---|---|
Allows an application to receive the Intent.ACTION_BOOT_COMPLETED that is broadcast after the system finishes booting.
| |
Allows applications to use exact alarm APIs. |
No usage description is required, see notification-related permissions.
On iOS, permissions for sending notifications are a little more granular than they are on Android. This is why you should rely on the NotificationPermissionsStatus
's ios.status
field, instead of the root status
field.
This value will be one of the following, accessible under Notifications.IosAuthorizationStatus
:
NOT_DETERMINED
: The user hasn't yet made a choice about whether the app is allowed to schedule notificationsDENIED
: The app isn't authorized to schedule or receive notificationsAUTHORIZED
: The app is authorized to schedule or receive notificationsPROVISIONAL
: The app is provisionally authorized to post noninterruptive user notificationsEPHEMERAL
: The app is authorized to schedule or receive notifications for a limited amount of timeNotification events include incoming notifications, interactions your users perform with notifications (this can be tapping on a notification, or interacting with it via notification categories), and rare occasions when your notifications may be dropped.
Several listeners are exposed and documented in the Push notification behaviors section.
See the definition of Headless Background Notifications in the What you need to know guide.
To handle notifications while the app is in the background or not running, you need to do the following:
expo-task-manager
package to your project.Then send a push notification which:
data
key (no title
, body
)_contentAvailable: true
set for iOS — see the Expo push notification service payload formatTo be able to use background push notifications on iOS, the remote-notification
value needs to be present in the UIBackgroundModes
array in your app's Info.plist file.
If you're using CNG, set the enableBackgroundRemoteNotifications
property of the config plugin to true, and the correct configuration will be applied automatically by prebuild.
If you're not using Continuous Native Generation (CNG) or you're using a native iOS project, then you'll need to add the following to your Expo.plist file:
<key>UIBackgroundModes</key>
<array>
<string>remote-notification</string>
</array>
</key>
To add custom push notification sounds to your app, add the expo-notifications
plugin to your app.json file and then under the sounds
key, provide an array of local paths to sound files that can be used as custom notification sounds. These local paths are local to your project.
{
"expo": {
"plugins": [
[
"expo-notifications",
{
"sounds": ["local/path/to/mySoundFile.wav"]
}
]
]
}
}
After building your app, the array of files will be available for use in both NotificationContentInput
and NotificationChannelInput
.
You only need to provide the base filename. Here's an example using the config above:
await Notifications.setNotificationChannelAsync('new_emails', {
name: 'E-mail notifications',
importance: Notifications.AndroidImportance.HIGH,
sound: 'mySoundFile.wav', // Provide ONLY the base filename
});
await Notifications.scheduleNotificationAsync({
content: {
title: "You've got mail! 📬",
sound: 'mySoundFile.wav', // Provide ONLY the base filename
},
trigger: {
seconds: 2,
channelId: 'new_emails',
},
});
You can also manually add notification files to your Android and iOS projects if you prefer:
On Androids 8.0+, playing a custom sound for a notification requires more than setting the sound
property on the NotificationContentInput
.
You will also need to configure the NotificationChannel
with the appropriate sound
, and use it when sending/scheduling the notification.
For the example below to work, you would place your email_sound.wav file in android/app/src/main/res/raw/.
// Prepare the notification channel
await Notifications.setNotificationChannelAsync('new_emails', {
name: 'E-mail notifications',
importance: Notifications.AndroidImportance.HIGH,
sound: 'email_sound.wav', // <- for Android 8.0+, see channelId property below
});
// Eg. schedule the notification
await Notifications.scheduleNotificationAsync({
content: {
title: "You've got mail! 📬",
body: 'Open the notification to read them all',
sound: 'email_sound.wav', // <- for Android below 8.0
},
trigger: {
seconds: 2,
channelId: 'new_emails', // <- for Android 8.0+, see definition above
},
});
On iOS, all that's needed is to place your sound file in your Xcode project (see the screenshot below),
and then specify the sound file in your NotificationContentInput
, like this:
await Notifications.scheduleNotificationAsync({
content: {
title: "You've got mail! 📬",
body: 'Open the notification to read them all',
sound: 'notification.wav',
},
trigger: {
// ...
},
});
Notification categories allow you to create interactive push notifications, so that a user can respond directly to the incoming notification
either via buttons or a text response. A category defines the set of actions a user can take, and then those actions are applied to a notification
by specifying the categoryIdentifier
in the NotificationContent
.
On iOS, notification categories also allow you to customize your notifications further. With each category, not only can you set interactive actions a user can take, but you can also configure things like the placeholder text to display when the user disables notification previews for your app.
Starting in Android 8.0 (API level 26), all notifications must be assigned to a channel. For each channel, you can set the visual and auditory behavior that is applied to all notifications in that channel. Then, users can change these settings and decide which notification channels from your app should be intrusive or visible at all, as Android developer docs states.
If you do not specify a notification channel, expo-notifications
will create a fallback channel for you, named Miscellaneous.
We encourage you to always ensure appropriate channels with informative names are set up for the application and to always send notifications to these channels.
Calling these methods is a no-op for platforms that do not support this feature (Android below version 8.0 (26) and iOS).
You can configure the notification.icon
and notification.color
keys
in the project's app.json if you are using Expo Prebuild or by using the expo-notifications
config plugin directly.
These are build-time settings, so you'll need to recompile your native Android app with eas build -p android
or npx expo run:android
to see the changes.
For your notification icon, make sure you follow Google's design guidelines (the icon must be all white with a transparent background) or else it may not be displayed as intended.
You can also set a custom notification color per-notification directly in your NotificationContentInput
under the color
attribute.
import * as Notifications from 'expo-notifications';
addPushTokenListener(listener)
Parameter | Type | Description |
---|---|---|
listener | PushTokenListener | A function accepting a push token as an argument, it will be called whenever the push token changes. |
In rare situations, a push token may be changed by the push notification service while the app is running. When a token is rolled, the old one becomes invalid and sending notifications to it will fail. A push token listener will let you handle this situation gracefully by registering the new token with your backend right away.
EventSubscription
An EventSubscription
object represents the subscription of the provided listener.
Example
import React from 'react';
import * as Notifications from 'expo-notifications';
import { registerDevicePushTokenAsync } from '../api';
export default function App() {
React.useEffect(() => {
const subscription = Notifications.addPushTokenListener(registerDevicePushTokenAsync);
return () => subscription.remove();
}, []);
return (
// Your app content
);
}
getDevicePushTokenAsync()
Returns a native FCM, APNs token or a PushSubscription
data
that can be used with another push notification service.
getExpoPushTokenAsync(options)
Parameter | Type | Description |
---|---|---|
options (optional) | ExpoPushTokenOptions | Object allowing you to pass in push notification configuration. Default: {} |
Returns an Expo token that can be used to send a push notification to the device using Expo's push notifications service.
This method makes requests to the Expo's servers. It can get rejected in cases where the request itself fails
(for example, due to the device being offline, experiencing a network timeout, or other HTTPS request failures).
To provide offline support to your users, you should try/catch
this method and implement retry logic to attempt
to get the push token later, once the device is back online.
For Expo's backend to be able to send notifications to your app, you will need to provide it with push notification keys. For more information, see credentials in the push notifications setup.
Returns a Promise
that resolves to an object representing acquired push token.
Example
import * as Notifications from 'expo-notifications';
export async function registerForPushNotificationsAsync(userId: string) {
const expoPushToken = await Notifications.getExpoPushTokenAsync({
projectId: 'your-project-id',
});
await fetch('https://example.com/', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
userId,
expoPushToken,
}),
});
}
removePushTokenSubscription(subscription)
Parameter | Type | Description |
---|---|---|
subscription | EventSubscription | A subscription returned by |
Removes a push token subscription returned by an addPushTokenListener
call.
void
addNotificationReceivedListener(listener)
Parameter | Type | Description |
---|---|---|
listener | (event: Notification) => void | A function accepting a notification ( |
Listeners registered by this method will be called whenever a notification is received while the app is running.
EventSubscription
An EventSubscription
object represents the subscription of the provided listener.
Example
import React from 'react';
import * as Notifications from 'expo-notifications';
export default function App() {
React.useEffect(() => {
const subscription = Notifications.addNotificationReceivedListener(notification => {
console.log(notification);
});
return () => subscription.remove();
}, []);
return (
// Your app content
);
}
addNotificationResponseReceivedListener(listener)
Parameter | Type | Description |
---|---|---|
listener | (event: NotificationResponse) => void | A function accepting notification response ( |
Listeners registered by this method will be called whenever a user interacts with a notification (for example, taps on it).
EventSubscription
An EventSubscription
object represents the subscription of the provided listener.
Example
import React from 'react';
import { Linking } from 'react-native';
import * as Notifications from 'expo-notifications';
export default function Container() {
React.useEffect(() => {
const subscription = Notifications.addNotificationResponseReceivedListener(response => {
const url = response.notification.request.content.data.url;
Linking.openURL(url);
});
return () => subscription.remove();
}, []);
return (
// Your app content
);
}
addNotificationsDroppedListener(listener)
Parameter | Type | Description |
---|---|---|
listener | () => void | A callback function. |
Listeners registered by this method will be called whenever some notifications have been dropped by the server.
Applicable only to Firebase Cloud Messaging which we use as a notifications service on Android. It corresponds to onDeletedMessages()
callback.
More information can be found in Firebase docs.
EventSubscription
An EventSubscription
object represents the subscription of the provided listener.
removeNotificationSubscription(subscription)
Parameter | Type | Description |
---|---|---|
subscription | EventSubscription | A subscription returned by |
Removes a notification subscription returned by an addNotificationListener
call.
void
useLastNotificationResponse()
A React hook which returns the notification response that was received most recently (a notification response designates an interaction with a notification, such as tapping on it).
To clear the last notification response, use clearLastNotificationResponseAsync()
.
If you don't want to use a hook, you can use
Notifications.getLastNotificationResponseAsync()
instead.
The hook may return one of these three types/values:
undefined
- until we're sure of what to return,null
- if no notification response has been received yet,NotificationResponse
object - if a notification response was received.Example
Responding to a notification tap by opening a URL that could be put into the notification's data
(opening the URL is your responsibility and is not a part of the expo-notifications
API):
import * as Notifications from 'expo-notifications';
import { Linking } from 'react-native';
export default function App() {
const lastNotificationResponse = Notifications.useLastNotificationResponse();
React.useEffect(() => {
if (
lastNotificationResponse &&
lastNotificationResponse.notification.request.content.data.url &&
lastNotificationResponse.actionIdentifier === Notifications.DEFAULT_ACTION_IDENTIFIER
) {
Linking.openURL(lastNotificationResponse.notification.request.content.data.url);
}
}, [lastNotificationResponse]);
return (
// Your app content
);
}
setNotificationHandler(handler)
Parameter | Type | Description |
---|---|---|
handler | null | NotificationHandler | A single parameter which should be either |
When a notification is received while the app is running, using this function you can set a callback that will decide whether the notification should be shown to the user or not.
When a notification is received, handleNotification
is called with the incoming notification as an argument.
The function should respond with a behavior object within 3 seconds, otherwise, the notification will be discarded.
If the notification is handled successfully, handleSuccess
is called with the identifier of the notification,
otherwise (or on timeout) handleError
will be called.
The default behavior when the handler is not set or does not respond in time is not to show the notification.
void
Example
import * as Notifications from 'expo-notifications';
Notifications.setNotificationHandler({
handleNotification: async () => ({
shouldShowAlert: true,
shouldPlaySound: false,
shouldSetBadge: false,
}),
});
registerTaskAsync(taskName)
Parameter | Type | Description |
---|---|---|
taskName | string | The string you passed to |
Call registerTaskAsync
to set a callback (task) that will run in response to when a notification is received while the app is in foreground, background, or terminated.
When app is terminated, only a data message (Android) / background notification (iOS) triggers the task execution.
However, the OS may decide not to deliver the notification to your app in some cases (e.g. when the device is in Doze mode on Android, or when you send too many notifications - Apple recommends to not "send more than two or three per hour").
Under the hood, this function is run using expo-task-manager
. You must define the task first, with TaskManager.defineTask
and register it with registerTaskAsync
.
Make sure you define and register the task in the module scope of a JS module which is required early by your app (e.g. in the index.js
file).
expo-task-manager
loads your app's JS bundle in the background and executes the task, as well as any side effects which may happen as a consequence of requiring any JS modules.
The callback function you define with TaskManager.defineTask
receives an object with the following fields:
data
: The remote payload delivered by either FCM (Android) or APNs (iOS). See PushNotificationTrigger
for details.error
: The error (if any) that occurred during execution of the task.executionInfo
: JSON object of additional info related to the task, including the taskName
.Promise<null>
Example
import * as TaskManager from 'expo-task-manager';
import * as Notifications from 'expo-notifications';
const BACKGROUND_NOTIFICATION_TASK = 'BACKGROUND-NOTIFICATION-TASK';
TaskManager.defineTask(BACKGROUND_NOTIFICATION_TASK, ({ data, error, executionInfo }) => {
console.log('Received a notification in the background!');
// Do something with the notification data
});
Notifications.registerTaskAsync(BACKGROUND_NOTIFICATION_TASK);
unregisterTaskAsync(taskName)
Parameter | Type | Description |
---|---|---|
taskName | string | The string you passed to |
Used to unregister tasks registered with registerTaskAsync
method.
Promise<null>
getPermissionsAsync()
Calling this function checks current permissions settings related to notifications. It lets you verify whether the app is currently allowed to display alerts, play sounds, etc. There is no user-facing effect of calling this.
It returns a Promise
resolving to an object represents permission settings (NotificationPermissionsStatus
).
On iOS, make sure you properly interpret the permissions response.
Example
import * as Notifications from 'expo-notifications';
export async function allowsNotificationsAsync() {
const settings = await Notifications.getPermissionsAsync();
return (
settings.granted || settings.ios?.status === Notifications.IosAuthorizationStatus.PROVISIONAL
);
}
requestPermissionsAsync(permissions)
Parameter | Type | Description |
---|---|---|
permissions (optional) | NotificationPermissionsRequest | An object representing configuration for the request scope. |
Prompts the user for notification permissions according to request. Request defaults to asking the user to allow displaying alerts, setting badge count and playing sounds.
It returns a Promise resolving to an object represents permission settings (NotificationPermissionsStatus
).
On iOS, make sure you properly interpret the permissions response.
Example
import * as Notifications from 'expo-notifications';
export function requestPermissionsAsync() {
return await Notifications.requestPermissionsAsync({
ios: {
allowAlert: true,
allowBadge: true,
allowSound: true,
},
});
}
getBadgeCountAsync()
Fetches the number currently set as the badge of the app icon on device's home screen. A 0
value means that the badge is not displayed.
Note: Not all Android launchers support application badges. If the launcher does not support icon badges, the method will always resolve to
0
.
Promise<number>
Returns a Promise resolving to a number that represents the current badge of the app icon.
setBadgeCountAsync(badgeCount, options)
Parameter | Type | Description |
---|---|---|
badgeCount | number | The count which should appear on the badge. A value of |
options (optional) | SetBadgeCountOptions | An object of options configuring behavior applied. |
Sets the badge of the app's icon to the specified number. Setting it to 0
clears the badge. On iOS, this method requires that you have requested
the user's permission for allowBadge
via requestPermissionsAsync
,
otherwise it will automatically return false
.
Note: Not all Android launchers support application badges. If the launcher does not support icon badges, the method will resolve to
false
.
Promise<boolean>
It returns a Promise resolving to a boolean representing whether the setting of the badge succeeded.
cancelAllScheduledNotificationsAsync()
Cancels all scheduled notifications.
Promise<void>
A Promise that resolves once all the scheduled notifications are successfully canceled, or if there are no scheduled notifications.
cancelScheduledNotificationAsync(identifier)
Parameter | Type | Description |
---|---|---|
identifier | string | The notification identifier with which |
Cancels a single scheduled notification. The scheduled notification of given ID will not trigger.
Promise<void>
A Promise resolves once the scheduled notification is successfully canceled or if there is no scheduled notification for a given identifier.
Example
import * as Notifications from 'expo-notifications';
async function scheduleAndCancel() {
const identifier = await Notifications.scheduleNotificationAsync({
content: {
title: 'Hey!',
},
trigger: { seconds: 60, repeats: true },
});
await Notifications.cancelScheduledNotificationAsync(identifier);
}
getAllScheduledNotificationsAsync()
Fetches information about all scheduled notifications.
Returns a Promise resolving to an array of objects conforming to the Notification
interface.
getNextTriggerDateAsync(trigger)
Parameter | Type | Description |
---|---|---|
trigger | SchedulableNotificationTriggerInput | The schedulable notification trigger you would like to check next trigger date for (of type |
Allows you to check what will be the next trigger date for given notification trigger input.
Promise<number | null>
If the return value is null
, the notification won't be triggered. Otherwise, the return value is the Unix timestamp in milliseconds
at which the notification will be triggered.
Example
import * as Notifications from 'expo-notifications';
async function logNextTriggerDate() {
try {
const nextTriggerDate = await Notifications.getNextTriggerDateAsync({
hour: 9,
minute: 0,
});
console.log(nextTriggerDate === null ? 'No next trigger date' : new Date(nextTriggerDate));
} catch (e) {
console.warn(`Couldn't have calculated next trigger date: ${e}`);
}
}
Deprecated This method has been deprecated in favor of using an explicit
NotificationHandler
and thescheduleNotificationAsync
method. More information can be found in our FYI document.
presentNotificationAsync(content, identifier)
Parameter | Type | Description |
---|---|---|
content | NotificationContentInput | An object representing the notification content. |
identifier (optional) | string | - |
Schedules a notification for immediate trigger.
Promise<string>
It returns a Promise resolving with the notification's identifier once the notification is successfully scheduled for immediate display.
scheduleNotificationAsync(request)
Parameter | Type | Description |
---|---|---|
request | NotificationRequestInput | An object describing the notification to be triggered. |
Schedules a notification to be triggered in the future.
Note: Please note that this does not mean that the notification will be presented when it is triggered. For the notification to be presented you have to set a notification handler with
setNotificationHandler
that will return an appropriate notification behavior. For more information see the example below.
Promise<string>
Returns a Promise resolving to a string which is a notification identifier you can later use to cancel the notification or to identify an incoming notification.
Example
import * as Notifications from 'expo-notifications';
Notifications.scheduleNotificationAsync({
content: {
title: "Time's up!",
body: 'Change sides!',
},
trigger: {
type: SchedulableTriggerInputTypes.TIME_INTERVAL,
seconds: 60,
},
});
import * as Notifications from 'expo-notifications';
Notifications.scheduleNotificationAsync({
content: {
title: 'Remember to drink water!',
},
trigger: {
type: SchedulableTriggerInputTypes.TIME_INTERVAL,
seconds: 60 * 20,
repeats: true,
},
});
import * as Notifications from 'expo-notifications';
const trigger = new Date(Date.now() + 60 * 60 * 1000);
trigger.setMinutes(0);
trigger.setSeconds(0);
Notifications.scheduleNotificationAsync({
content: {
title: 'Happy new hour!',
},
trigger,
});
dismissAllNotificationsAsync()
Removes all application's notifications displayed in the notification tray (Notification Center).
Promise<void>
A Promise which resolves once the request to dismiss the notifications is successfully dispatched to the notifications manager.
dismissNotificationAsync(notificationIdentifier)
Parameter | Type | Description |
---|---|---|
notificationIdentifier | string | The notification identifier, obtained either via |
Removes notification displayed in the notification tray (Notification Center).
Promise<void>
A Promise which resolves once the request to dismiss the notification is successfully dispatched to the notifications manager.
getPresentedNotificationsAsync()
Fetches information about all notifications present in the notification tray (Notification Center).
This method is not supported on Android below 6.0 (API level 23) – on these devices it will resolve to an empty array.
A Promise which resolves with a list of notifications (Notification
) currently present in the notification tray (Notification Center).
deleteNotificationChannelAsync(channelId)
Parameter | Type | Description |
---|---|---|
channelId | string | The channel identifier. |
Removes the notification channel.
Promise<void>
A Promise which resolving once the channel is removed (or if there was no channel for given identifier).
deleteNotificationChannelGroupAsync(groupId)
Parameter | Type | Description |
---|---|---|
groupId | string | The channel group identifier. |
Removes the notification channel group and all notification channels that belong to it.
Promise<void>
A Promise which resolves once the channel group is removed (or if there was no channel group for given identifier).
getNotificationChannelAsync(channelId)
Parameter | Type | Description |
---|---|---|
channelId | string | The channel's identifier. |
Fetches information about a single notification channel.
Promise<NotificationChannel | null>
A Promise which resolves to the channel object (of type NotificationChannel
) or to null
if there was no channel found for this identifier. On platforms that do not support notification channels, it will always resolve to null
.
getNotificationChannelGroupAsync(groupId)
Parameter | Type | Description |
---|---|---|
groupId | string | The channel group's identifier. |
Fetches information about a single notification channel group.
Promise<NotificationChannelGroup | null>
A Promise which resolves to the channel group object (of type NotificationChannelGroup
)
or to null
if there was no channel group found for this identifier. On platforms that do not support notification channels,
it will always resolve to null
.
getNotificationChannelGroupsAsync()
Fetches information about all known notification channel groups.
A Promise which resoles to an array of channel groups. On platforms that do not support notification channel groups, it will always resolve to an empty array.
getNotificationChannelsAsync()
Fetches information about all known notification channels.
A Promise which resolves to an array of channels. On platforms that do not support notification channels, it will always resolve to an empty array.
setNotificationChannelAsync(channelId, channel)
Parameter | Type | Description |
---|---|---|
channelId | string | The channel identifier. |
channel | NotificationChannelInput | Object representing the channel's configuration. |
Assigns the channel configuration to a channel of a specified name (creating it if need be). This method lets you assign given notification channel to a notification channel group.
Note: After a channel has been created, you can modify only its name and description. This limitation is imposed by the Android OS.
Note: For some settings to be applied on all Android versions, it may be necessary to duplicate the configuration across both a single notification and its respective notification channel.
For example, for a notification to play a custom sound on Android versions below 8.0,
the custom notification sound has to be set on the notification (through the NotificationContentInput
),
and for the custom sound to play on Android versions above 8.0, the relevant notification channel must have the custom sound configured
(through the NotificationChannelInput
). For more information,
see Set custom notification sounds on Android.
Promise<NotificationChannel | null>
A Promise which resolving to the object (of type NotificationChannel
) describing the modified channel
or to null
if the platform does not support notification channels.
setNotificationChannelGroupAsync(groupId, group)
Parameter | Type | Description |
---|---|---|
groupId | string | The channel group's identifier. |
group | NotificationChannelGroupInput | Object representing the channel group configuration. |
Assigns the channel group configuration to a channel group of a specified name (creating it if need be).
Promise<NotificationChannelGroup | null>
A Promise
resolving to the object (of type NotificationChannelGroup
)
describing the modified channel group or to null
if the platform does not support notification channels.
deleteNotificationCategoryAsync(identifier)
Parameter | Type | Description |
---|---|---|
identifier | string | Identifier initially provided to |
Deletes the category associated with the provided identifier.
Promise<boolean>
A Promise which resolves to true
if the category was successfully deleted, or false
if it was not.
An example of when this method would return false
is if you try to delete a category that doesn't exist.
getNotificationCategoriesAsync()
Fetches information about all known notification categories.
A Promise which resolves to an array of NotificationCategory
s. On platforms that do not support notification channels,
it will always resolve to an empty array.
setNotificationCategoryAsync(identifier, actions, options)
Parameter | Type | Description |
---|---|---|
identifier | string | A string to associate as the ID of this category. You will pass this string in as the
|
actions | NotificationAction[] | An array of |
options (optional) | NotificationCategoryOptions | An optional object of additional configuration options for your category. |
Sets the new notification category.
A Promise which resolves to the category you just have created.
Notifications.clearLastNotificationResponseAsync()
Clears the notification response that was received most recently. May be used when an app selects a route based on the notification response, and it is undesirable to continue selecting the route after the response has already been handled.
If a component is using the useLastNotificationResponse
hook,
this call will also clear the value returned by the hook.
Promise<void>
A promise that resolves if the native call was successful.
Notifications.getLastNotificationResponseAsync()
Gets the notification response that was received most recently (a notification response designates an interaction with a notification, such as tapping on it).
null
- if no notification response has been received yetNotificationResponse
object - if a notification response was receivedPromise<NotificationResponse | null>
AudioAttributes
AudioAttributes Properties
Name | Type | Description |
---|---|---|
contentType | AndroidAudioContentType | - |
flags | {
enforceAudibility: boolean,
requestHardwareAudioVideoSynchronization: boolean
} | - |
usage | AndroidAudioUsage | - |
BeaconRegion
Extends: Region
A region used to detect the presence of iBeacon devices. Based on Core Location CLBeaconRegion
class.
BeaconRegion Properties
Name | Type | Description |
---|---|---|
beaconIdentityConstraint (optional) | {
major: null | number,
minor: null | number,
uuid: string
} | The beacon identity constraint that defines the beacon region. |
major | null | number | The major value from the beacon identity constraint that defines the beacon region. |
minor | null | number | The minor value from the beacon identity constraint that defines the beacon region. |
notifyEntryStateOnDisplay | boolean | A Boolean value that indicates whether Core Location sends beacon notifications when the device’s display is on. |
type | 'beacon' | - |
uuid (optional) | string | The UUID value from the beacon identity constraint that defines the beacon region. |
CalendarNotificationTrigger
A trigger related to a UNCalendarNotificationTrigger
.
CalendarNotificationTrigger Properties
Name | Type | Description |
---|---|---|
dateComponents | {
calendar: string,
day: number,
era: number,
hour: number,
isLeapMonth: boolean,
minute: number,
month: number,
nanosecond: number,
quarter: number,
second: number,
timeZone: string,
weekday: number,
weekdayOrdinal: number,
weekOfMonth: number,
weekOfYear: number,
year: number,
yearForWeekOfYear: number
} | - |
repeats | boolean | - |
type | 'calendar' | - |
CircularRegion
Extends: Region
A circular geographic region, specified as a center point and radius. Based on Core Location CLCircularRegion
class.
CircularRegion Properties
Name | Type | Description |
---|---|---|
center | {
latitude: number,
longitude: number
} | The center point of the geographic area. |
radius | number | The radius (measured in meters) that defines the geographic area’s outer boundary. |
type | 'circular' | - |
DailyNotificationTrigger
A trigger related to a daily notification.
The same functionality will be achieved on iOS with a
CalendarNotificationTrigger
.
DailyNotificationTrigger Properties
Name | Type | Description |
---|---|---|
hour | number | - |
minute | number | - |
type | 'daily' | - |
ExpoPushToken
Object which contains the Expo push token in the data
field. Use the value from data
to send notifications via Expo Notifications service.
ExpoPushToken Properties
Name | Type | Description |
---|---|---|
data | string | The acquired push token. |
type | 'expo' | Always set to |
ExpoPushTokenOptions
ExpoPushTokenOptions Properties
Name | Type | Description |
---|---|---|
applicationId (optional) | string | The ID of the application to which the token should be attributed.
Defaults to |
baseUrl (optional) | string | Endpoint URL override. |
development (optional) | boolean | Only for: iOS On iOS, there are two push notification services: "sandbox" and "production".
This defines whether the push token is supposed to be used with the sandbox platform notification service.
Defaults to |
deviceId (optional) | string | - |
devicePushToken (optional) | DevicePushToken | The device push token with which to register at the backend.
Defaults to a token fetched with |
projectId (optional) | string | The ID of the project to which the token should be attributed.
Defaults to When using EAS Build, this value is automatically set. However, it is
recommended to set it manually. Once you have EAS Build configured, you can find
the value in app.json under |
type (optional) | string | Request body override. |
url (optional) | string | Request URL override. |
FirebaseRemoteMessage
A Firebase RemoteMessage
that caused the notification to be delivered to the app.
FirebaseRemoteMessage Properties
Name | Type | Description |
---|---|---|
collapseKey | null | string | - |
data | Record<string, string> | - |
from | null | string | - |
messageId | null | string | - |
messageType | null | string | - |
notification | null | FirebaseRemoteMessageNotification | - |
originalPriority | number | - |
priority | number | - |
sentTime | number | - |
to | null | string | - |
ttl | number | - |
FirebaseRemoteMessageNotification
FirebaseRemoteMessageNotification Properties
Name | Type | Description |
---|---|---|
body | null | string | - |
bodyLocalizationArgs | null | string[] | - |
bodyLocalizationKey | null | string | - |
channelId | null | string | - |
clickAction | null | string | - |
color | null | string | - |
eventTime | null | number | - |
icon | null | string | - |
imageUrl | null | string | - |
lightSettings | null | number[] | - |
link | null | string | - |
localOnly | boolean | - |
notificationCount | null | number | - |
notificationPriority | null | number | - |
sound | null | string | - |
sticky | boolean | - |
tag | null | string | - |
ticker | null | string | - |
title | null | string | - |
titleLocalizationArgs | null | string[] | - |
titleLocalizationKey | null | string | - |
usesDefaultLightSettings | boolean | - |
usesDefaultSound | boolean | - |
usesDefaultVibrateSettings | boolean | - |
vibrateTimings | null | number[] | - |
visibility | null | number | - |
IosNotificationPermissionsRequest
Available configuration for permission request on iOS platform.
See Apple documentation for UNAuthorizationOptions
to learn more.
IosNotificationPermissionsRequest Properties
Name | Type | Description |
---|---|---|
allowAlert (optional) | boolean | The ability to display alerts. |
allowBadge (optional) | boolean | The ability to update the app’s badge. |
allowCriticalAlerts (optional) | boolean | The ability to play sounds for critical alerts. |
allowDisplayInCarPlay (optional) | boolean | The ability to display notifications in a CarPlay environment. |
allowProvisional (optional) | boolean | The ability to post noninterrupting notifications provisionally to the Notification Center. |
allowSound (optional) | boolean | The ability to play sounds. |
provideAppNotificationSettings (optional) | boolean | An option indicating the system should display a button for in-app notification settings. |
LocationNotificationTrigger
A trigger related to a UNLocationNotificationTrigger
.
LocationNotificationTrigger Properties
Name | Type | Description |
---|---|---|
region | CircularRegion | BeaconRegion | - |
repeats | boolean | - |
type | 'location' | - |
MonthlyNotificationTrigger
A trigger related to a monthly notification.
The same functionality will be achieved on iOS with a
CalendarNotificationTrigger
.
MonthlyNotificationTrigger Properties
Name | Type | Description |
---|---|---|
day | number | - |
hour | number | - |
minute | number | - |
type | 'monthly' | - |
NativeDevicePushToken
NativeDevicePushToken Properties
Name | Type | Description |
---|---|---|
data | string | - |
type | 'ios' | 'android' | - |
Notification
An object which represents a single notification that has been triggered by some request (NotificationRequest
) at some point in time.
Notification Properties
Name | Type | Description |
---|---|---|
date | number | - |
request | NotificationRequest | - |
NotificationAction
NotificationAction Properties
Name | Type | Description |
---|---|---|
buttonTitle | string | The title of the button triggering this action. |
identifier | string | A unique string that identifies this action. If a user takes this action (for example, selects this button in the system's Notification UI),
your app will receive this |
options (optional) | {
isAuthenticationRequired: boolean,
isDestructive: boolean,
opensAppToForeground: boolean
} | Object representing the additional configuration options. |
textInput (optional) | {
placeholder: string,
submitButtonTitle: string
} | Object which, if provided, will result in a button that prompts the user for a text response. |
NotificationBehavior
An object which represents behavior that should be applied to the incoming notification.
On Android, setting
shouldPlaySound: false
will result in the drop-down notification alert not showing, no matter what the priority is. This setting will also override any channel-specific sounds you may have configured.
NotificationBehavior Properties
Name | Type | Description |
---|---|---|
priority (optional) | AndroidNotificationPriority | - |
shouldPlaySound | boolean | - |
shouldSetBadge | boolean | - |
shouldShowAlert | boolean | - |
NotificationCategory
NotificationCategory Properties
Name | Type | Description |
---|---|---|
actions | NotificationAction[] | - |
identifier | string | - |
options (optional) | NotificationCategoryOptions | - |
NotificationChannel
An object which represents a notification channel.
NotificationChannel Properties
Name | Type | Description |
---|---|---|
audioAttributes | AudioAttributes | - |
bypassDnd | boolean | - |
description | null | string | - |
enableLights | boolean | - |
enableVibrate | boolean | - |
groupId (optional) | null | string | - |
id | string | - |
importance | AndroidImportance | - |
lightColor | string | - |
lockscreenVisibility | AndroidNotificationVisibility | - |
name | null | string | - |
showBadge | boolean | - |
sound | null | 'default' | 'custom' | - |
vibrationPattern | null | number[] | - |
NotificationChannelGroup
An object which represents a notification channel group.
NotificationChannelGroup Properties
Name | Type | Description |
---|---|---|
channels | NotificationChannel[] | - |
description (optional) | null | string | - |
id | string | - |
isBlocked (optional) | boolean | - |
name | null | string | - |
NotificationChannelGroupInput
An object which represents a notification channel group to be set.
NotificationChannelGroupInput Properties
Name | Type | Description |
---|---|---|
description (optional) | null | string | - |
name | null | string | - |
NotificationChannelGroupManager
Extends: ProxyNativeModule
NotificationChannelGroupManager Properties
Name | Type | Description |
---|---|---|
deleteNotificationChannelGroupAsync (optional) | (groupId: string) => Promise<void> | - |
getNotificationChannelGroupAsync (optional) | (groupId: string) => Promise<null | NotificationChannelGroup> | - |
getNotificationChannelGroupsAsync (optional) | () => Promise<NotificationChannelGroup[]> | - |
setNotificationChannelGroupAsync (optional) | (groupId: string, group: NotificationChannelGroupInput) => Promise<null | NotificationChannelGroup> | - |
NotificationChannelManager
Extends: ProxyNativeModule
NotificationChannelManager Properties
Name | Type | Description |
---|---|---|
deleteNotificationChannelAsync (optional) | (channelId: string) => Promise<void> | - |
getNotificationChannelAsync (optional) | (channelId: string) => Promise<null | NotificationChannel> | - |
getNotificationChannelsAsync (optional) | () => Promise<null | NotificationChannel[]> | - |
setNotificationChannelAsync (optional) | (channelId: string, channelConfiguration: NotificationChannelInput) => Promise<null | NotificationChannel> | - |
NotificationHandler
NotificationHandler Properties
Name | Type | Description |
---|---|---|
handleError (optional) | (notificationId: string, error: NotificationHandlingError) => void | A function called whenever calling |
handleNotification | (notification: Notification) => Promise<NotificationBehavior> | A function accepting an incoming notification returning a |
handleSuccess (optional) | (notificationId: string) => void | A function called whenever an incoming notification is handled successfully. |
NotificationPermissionsRequest
An interface representing the permissions request scope configuration. Each option corresponds to a different native platform authorization option.
NotificationPermissionsRequest Properties
Name | Type | Description |
---|---|---|
android (optional) | object | On Android, all available permissions are granted by default, and if a user declines any permission, an app cannot prompt the user to change. |
ios (optional) | IosNotificationPermissionsRequest | Available configuration for permission request on iOS platform. |
NotificationPermissionsStatus
Extends: PermissionResponse
NotificationPermissionsStatus Properties
Name | Type | Description |
---|---|---|
android (optional) | {
importance: number,
interruptionFilter: number
} | - |
ios (optional) | {
alertStyle: IosAlertStyle,
allowsAlert: null | boolean,
allowsAnnouncements: null | boolean,
allowsBadge: null | boolean,
allowsCriticalAlerts: null | boolean,
allowsDisplayInCarPlay: null | boolean,
allowsDisplayInNotificationCenter: null | boolean,
allowsDisplayOnLockScreen: null | boolean,
allowsPreviews: IosAllowsPreviews,
allowsSound: null | boolean,
providesAppNotificationSettings: boolean,
status: IosAuthorizationStatus
} | - |
NotificationRequest
An object represents a request to present a notification. It has content — how it's being represented, and a trigger — what triggers the notification.
Many notifications (Notification
) may be triggered with the same request (for example, a repeating notification).
NotificationRequest Properties
Name | Type | Description |
---|---|---|
content | NotificationContent | - |
identifier | string | - |
trigger | NotificationTrigger | - |
NotificationRequestInput
An object which represents a notification request you can pass into scheduleNotificationAsync
.
NotificationRequestInput Properties
Name | Type | Description |
---|---|---|
content | NotificationContentInput | - |