Native Push Plugin
The Native Push Plugin is a Flutter plugin that provides seamless integration of push notifications across different platforms including Android, iOS, macOS, and Web. This plugin allows your Flutter application to receive and handle remote notifications with ease.
Features
- Supports Firebase Cloud Messaging (FCM) for Android.
- Supports Apple Push Notification Service (APNs) for iOS and macOS.
- Supports Web Push for web applications.
- Handles push notifications while the app is in the foreground, background, or terminated.
- Provides methods to initialize the plugin, register for remote notifications, and retrieve the notification token.
- Supports various notification options like alert, badge, sound, and more.
Installation
Add the following dependency to your pubspec.yaml
file:
dependencies:
native_push: ^1.0.0
Then run flutter pub get
to install the plugin.
Usage
Import the Plugin
import 'package:native_push/native_push.dart';
Initialize the Plugin
Before using the plugin, you need to initialize it. This is typically done in the main.dart
file of your Flutter project.
void main() async {
WidgetsFlutterBinding.ensureInitialized();
// Initialize the native push plugin
await NativePush.instance.initialize(
firebaseOptions: {
'apiKey': 'YOUR_API_KEY',
'projectId': 'YOUR_PROJECT_ID',
'messagingSenderId': 'YOUR_MESSAGING_SENDER_ID',
'applicationId': 'YOUR_APP_ID',
},
useDefaultNotificationChannel: true,
);
runApp(MyApp());
}
The firebaseOptions can be omitted when not using fcm. You can use
the extract_fcm_options
script provided in the repository to
extract the information from the google-services.json
.
cat google-services.json | ./extract_fcm_options.sh <android-bundle-id>
Register for Remote Notifications
You need to register for remote notifications to get a notification token.
await NativePush.instance.registerForRemoteNotification(
options: [NotificationOption.alert, NotificationOption.sound],
vapidKey: 'YOUR_VAPID_KEY', // For web push, can be omitted otherwise
);
Handling Incoming Notifications
You can listen for incoming notifications using the notificationStream
.
NativePush.instance.notificationStream.listen((notification) {
// Handle the notification
print('Received notification: $notification');
});
Get Initial Notification
To handle the notification that opened the app, you can use initialNotification
.
final initialNotification = await NativePush.instance.initialNotification();
if (initialNotification != null) {
// Handle the initial notification
print('Initial notification: $initialNotification');
}
Retrieve the Notification Token
You can retrieve the current notification token with the following method:
final (service, token) = await NativePush.instance.notificationToken;
print('Notification Service: $service, Token: $token');
Platform Specifics
Android
For Android, ensure that you have add the following metadata to your application.
<meta-data
android:name="com.google.firebase.messaging.default_notification_channel_id"
android:value="native_push_notification_channel" />
<meta-data
android:name="com.google.firebase.messaging.default_notification_icon"
android:resource="@android:drawable/ic_input_add" />
You can only use native_push_notification_channel
if you set
useDefaultNotificationChannel
in initialize to true. Otherwise you have
to create and specify your own notification channel.
You also need to the following to your main activity intent filter:
<action android:name="com.opdehipt.native_push.PUSH"/>
iOS
You have to add the Push Notification
Capability.
If you want to support images in your notification, you also have to add
the Background Modes
Capability and check Remote Notifications
.
You also have to add Notification Service Extension
to your app and
replace the code with the following:
import NativePushNotificationService
final class NotificationService: NativePushNotificationService {}
The NativePushNotificationService
can be imported via the
Swift Package Manager
from
here.
MacOS
You only have to add the Push Notification
Capability.
Web
Please add the
native_push.min.js
to your web folder and it to
native_push.js
. You should also add one of
native_push_sw.min.js or
native_push_sw_non_localize.min.js
to your web folder and rename it to native_push_sw.js
. The normal
script should be used if you want to localize the notification on the
client side. Otherwise you should add the non_localize script. If you
add the localize script, you also have to add the
localization.js
and add your localization logic to the localization
function.
You don't have to import any of the javascript files in your index.html
.
Example
An example Flutter app demonstrating the usage of the Native Push Plugin can be found in the example
directory.
Contributing
Contributions are welcome! Please submit a pull request or create an issue if you find a bug or have a feature request.
License
This project is licensed under the BSD-3 License. See the LICENSE file for details.