A Convex component for managing push notifications with Expo.
npm install @convex-dev/expo-push-notifications
This is a Convex component that integrates with
Expo's push notification API
to allow sending mobile push notifications to users of your app. It will batch
calls to Expo's API and handle retrying delivery.
Demo GIF
!Demo of sending push notifications
Example usage:
``tsxHi from ${currentUser.name}
// App.tsx
onPress={() => {
void convex.mutation(api.example.sendPushNotification, {
to: otherUser,
title: ,`
});
}}
>
`typescript`
// convex/example.ts
export const sendPushNotification = mutation({
args: { title: v.string(), to: v.id("users") },
handler: async (ctx, args) => {
// Sending a notification
return pushNotifications.sendPushNotification(ctx, {
userId: args.to,
notification: {
title: args.title,
},
});
},
});
You'll need an existing Convex project to use the component. Convex is a hosted
backend platform, including a database, serverless functions, and a ton more you
can learn about here.
Run npm create convex or follow any of the
quickstarts to set one up.
Install the component package:
``
npm i @convex-dev/expo-push-notifications
Create a convex.config.ts file in your app's convex/ folder and install theuse
component by calling :
`ts
// convex/convex.config.ts
import { defineApp } from "convex/server";
import pushNotifications from "@convex-dev/expo-push-notifications/convex.config.js";
const app = defineApp();
app.use(pushNotifications);
// other components
export default app;
`
Instantiate the PushNotifications client in your Convex functions:
`ts
// convex/example.ts
import { PushNotifications } from "@convex-dev/expo-push-notifications";
const pushNotifications = new PushNotifications(components.pushNotifications);
`
It takes in an optional type parameter (defaulting to Id<"users">) for the
type to use as a unique identifier for push notification recipients:
`ts
import { PushNotifications } from "@convex-dev/expo-push-notifications";
export type Email = string & { __isEmail: true };
const pushNotifications = new PushNotifications
components.pushNotifications,
);
`
Get a user's push notification token following the Expo documentation
here,
and record it using a Convex mutation:
`ts`
// convex/example.ts
export const recordPushNotificationToken = mutation({
args: { token: v.string() },
handler: async (ctx, args) => {
const userId = await getAuthUserId(ctx);
await pushNotifications.recordToken(ctx, {
userId,
pushToken: args.token,
});
},
});
You can pause and resume push notification sending for a user using the
pausePushNotifications and resumePushNotifications methods.
To determine if a user has a token and their pause status, you can use
getStatusForUser.
`ts`
// convex/example.ts
export const sendPushNotification = mutation({
args: { title: v.string(), to: v.string() },
handler: async (ctx, args) => {
const pushId = await pushNotifications.sendPushNotification(ctx, {
userId: args.to,
notification: {
title: args.title,
},
});
},
});
You can use the ID returned from sendPushNotifications to query the status ofgetNotification
the notification using . Using this in a query allows you to
subscribe to the status of a notification.
You can also view all notifications for a user with getNotificationsForUser.
To add more logging, provide PushNotifications with a logLevel in the
constructor:
`ts`
const pushNotifications = new PushNotifications(components.pushNotifications, {
logLevel: "DEBUG",
});
The push notification sender can be shutdown gracefully, and then restarted
using the shutdown and restart` methods.