Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aparajita/capacitor-ios-silent-notifications
Silent (AKA remote) notification support for Capacitor apps on iOS.
https://github.com/aparajita/capacitor-ios-silent-notifications
Last synced: about 2 months ago
JSON representation
Silent (AKA remote) notification support for Capacitor apps on iOS.
- Host: GitHub
- URL: https://github.com/aparajita/capacitor-ios-silent-notifications
- Owner: aparajita
- License: mit
- Created: 2024-03-08T01:55:01.000Z (10 months ago)
- Default Branch: main
- Last Pushed: 2024-07-17T20:25:55.000Z (6 months ago)
- Last Synced: 2024-11-02T05:47:48.763Z (2 months ago)
- Language: JavaScript
- Homepage:
- Size: 271 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-capacitorjs - @aparajita/capacitor-ios-silent-notifications
README
# capacitor-ios-silent-notifications
This plugin for [Capacitor 6+](https://capacitorjs.com) provides support for silent (data only) notifications on iOS.
## Installation
```sh
pnpm add @aparajita/capacitor-ios-silent-notifications # npm install, yarn add
```Not using [pnpm](https://pnpm.js.org/)? You owe it to yourself to give it a try. It’s faster, better with monorepos, and uses _way, way_ less disk space than the alternatives.
> This plugin assumes you have already [configured your app for push notifications](https://capacitorjs.com/docs/apis/push-notifications).
## Usage
There are two small steps to using this plugin:
### 1. Add a listener in your app
Add the following code during your app’s initialization:
```typescript
import { IosSilentNotifications } from '@aparajita/capacitor-ios-silent-notifications'// `const { remove }` is optional. If you are never going to remove the listener,
// you can omit it.
const { remove } = await IosSilentNotifications.addListener(
'onSilentNotification',
(notification: Notification) => {
// Do something with the notification
},
)
```Note that on Android, this plugin does nothing, since the same functionality is already provided by the `@capacitor/push-notifications` plugin. If you wish, you can skip the call to `addListener` on Android:
```typescript
if (Capacitor.getPlatform() === 'ios') {
await IosSilentNotifications.addListener(
'onSilentNotification',
(notification: Notification) => {
// Do something with the notification
},
)
}
```#### 2. Forward the notification to the plugin
In your app’s `AppDelegate.swift` file, add the following code to the `AppDelegate` class:
```swift
func application(_ application: UIApplication,
didReceiveRemoteNotification userInfo: [AnyHashable: Any],
fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
NotificationCenter.default.post(name:Notification.Name("silentNotification"), object: userInfo);
completionHandler(UIBackgroundFetchResult.newData)
}
```