-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Added support for active notifications on iOS #1391
Conversation
Thanks for the PR. Wanted to check, is the reason why you're saying it's a breaking change is because of the |
I changed the function name back to |
Thanks for making the change. Will try find some time to test this out before it's merged in. FYI I may change the target branch for this as there are some potentially breaking iOS/macOS changes I'm considering too. If I do, then I might create branch to combine these into a pre-release |
Just realised you raised a very good point about the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks I've reviewed the PR and give it a spin. Since I removed groupKey
you'll need to update your fork to resolve the conflicts, which should be a matter of keeping your changes instead. I've left some comments and found that the macOS implementation doesn't compile as it refers to a method that doesn't exist. Could you also change the target branch to the 10.0.0 branch that I've pushed up?
If you need some assistance then let me know
flutter_local_notifications/ios/Classes/FlutterLocalNotificationsPlugin.m
Outdated
Show resolved
Hide resolved
flutter_local_notifications_platform_interface/lib/src/types.dart
Outdated
Show resolved
Hide resolved
flutter_local_notifications_platform_interface/lib/src/types.dart
Outdated
Show resolved
Hide resolved
flutter_local_notifications/macos/Classes/FlutterLocalNotificationsPlugin.swift
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for making the changes. Left some comments. I'll try to retest the changes later in the week
...d/src/main/java/com/dexterous/flutterlocalnotifications/FlutterLocalNotificationsPlugin.java
Outdated
Show resolved
Hide resolved
flutter_local_notifications/ios/Classes/FlutterLocalNotificationsPlugin.m
Outdated
Show resolved
Hide resolved
Is this change included in the last version 9.3.2? I tried to call the implementation for iOS but I have a compilation error: The method 'getActiveNotifications' isn't defined for the type 'IOSFlutterLocalNotificationsPlugin'.
|
No it's in 10.0.0 prerelease. There were comments above that this would've been a breaking change so it wouldn't have been in a 9.x release |
Thanks @MaikuB, I'll try the 10.0.0 prerelease, and when do you estimate become 10.0.0 into a stable release? |
No estimate for it as it'll move to stable when it's ready and also relies on the community contributing. As this is open source you can fork, add the relevant bits you need and have your app point to the fork |
…ations on iOS and macOS, iOS and macOS refactoring and renamed Android error codes (#1406) * Added support for active notifications on iOS (#1391) * Added support for active notifications on iOS * bump platform interface to 6.0.0-dev.1 for prerelease Co-authored-by: Michael Bui <25263378+MaikuB@users.noreply.github.com> * Google Java Format * fix version of platform interface * Swift Format * update error codes for unsupported os version and existing error codes to lower case * Swift Format * update groupKey changelog details * Clang Format * bump platform interface dependency used by linux plugin * bump linux plugin for prerelease * use dependency overrides for example app * update text in example app for getActiveNotifications example around unsupported iOS version * bump main plugin for prerelease * bump cross-platform facing plugin's dependency on linux plugin * call apply method for shared preferences editor instead of committing in background via a thread * fix linux plugin pubspec * update example to use device_info_plus instead of device_info * Clang Format * address linter issues * refactored iOS and macOS classes * update readme based on iOS/macOS refactoring and tweaks to docs around actions * fix section around handling notifications when app is in the foreground for iOS * updates for pre-release * add changelog entry on breaking change for refactoring iOS and macOS classes * bump platform interface dependency * rename callback for selecting notification action * rename method invoked from macos when action is selected * bump linux dependency * [flutter_local_notifications_linux] Add actions support in Linux (#1442) * Add actions support in Linux * Update README * bump versions and changelog for another pre-release * add git clean script * add exported flag to ActionBroadcastReceiver * add keep annotation to NotificationAction * lookup callback handler after flutter engine is initialised * fix error where plugin was lookup to the notification action callback and failed to find it as it was doing before the Flutter engine was initialised * Google Java Format * remove ActionBroadcastReceiverTest as implementation logic depends on starting Flutter engine * apply appropriate mutability flag to intents for notification actions to * Google Java Format * bump to 10.0.0-dev.8 * bump linux plugin * avoid trying to process iOS notification responses for notifications not created by the plugin (#1509) * fix completionHandler being called for notifications created outside of the plugin * Clang Format * bump to 10.0.0-dev.9 Co-authored-by: runner <runner@Mac-1645938063170.local> * update requestPermissions on macOS to have non-nullable parameters * fix default param values on macOS for requestPermissions * update 10.0.0-dev.9 changelog entry for macOS requestPermissions change * [flutter_local_notifications] adding ios/macos time sensitive interruption level (#1501) * adding ios/macos time sensitive interruption level * adding ios/macos time sensitive interruption level * adding ios/macos time sensitive interruption level * darwin time sensitive notifications requested changes * darwin time sensitive notifications requested changes * fixing accidental revert of requrestPermission bool parameter defaults * fixing doc comment default value for `requestCriticalPermission` * Clang Format * change import used to get access to immutable annotation * update InterruptionLevel to use a class and be explicit on numeric values * bump to 10.0.0-dev.10 * fix api docs for InterruptionLevel * update example app to display groupKey of ActiveNotification * changelog and version bumps to prep for 10.0.0-dev.11 release * Reworked callbacks have separate callbacks to deal with foreground and background interactions (#1548) * updated notification callbacks * update ios plugin code to deal with foreground notification actions * update notification app launch to process notification responses on ios * refactor code for extracting notification response dictionary on ios * update launch notification to be saved as a dictionary * update app launch notification logic on macos * rename and refactor notification logic on macos and ios * revert making didNotificationLaunchApp parameter named * update android plugin to send foreground event for notification actions * bump plugin and update changelog * Google Java Format * Swift Format * formatted objective c with clang format Co-authored-by: github-actions <> Co-authored-by: runner <runner@Mac-1648977077650.local> * update logic on iOS and macOS to set notification categories without querying for existing categories (#1549) * update logic to set notification categories without querying for existing categories * Swift Format Co-authored-by: runner <runner@Mac-1648985481866.local> * add changelog entry on changes to setting notification categories * clarify notification actions support on Apple's platforms * updated readme to be more explicit around how to handle when is launched by a notification * remove reference to the word foreground from notification callback to avoid confusion (#1555) * remove reference to the word foreground from notification callback to avoid confusion * Clang Format * add changelog entry for platform interface * update changelog entries and bump linux plugin Co-authored-by: runner <runner@Mac-1649472035608.local> * fix linter issues in linux test class * bump linux plugin's dependency on platform interface * bump flutter_local_notifications dependencies on linux plugin and platform interface * suppress unchecked cast warnings in plugin * Google Java Format * bump to 10.0.0-dev.13 * bump to 10.0.0-dev.14 * fix merge issue * bump to 10.0.0-dev.15 * fix version which should be 10.0.0-dev.14 * fix progress in example app (#1600) * [flutter_local_notifications] removed dependency on ThreeTenBP and use desugaring (#1601) * remove ThreeTenBP and use Java desugaring * update example to app to use launchUrl instead of deprecated launch method * bump plugin and update changelog and readme on Gradle setup * add changelog entry for example app fix * add gradle setup to toc * fix version to 10.0.0-dev.14 * update changelog entry on version that it includes from stable release * remove extra bullet point in 10.0.0-dev.14 changelog entry * change linux plugin to now be a 1.0.0 pre-release instead * release 10.0.0-dev.15 * [flutter_local_notifications] add AndroidNotificationCategory to make Android categories more accessible (#1609) * replace Android notification category String to AndroidNotificationCategory class type * change AndroidNotificationCategory to make use of const properties instead of factory constructors * add API docs for each Android category * format categories file * changed linux notification categories to static const fields instead of factory constructors * release 10.0.0-dev.16 * fix example app with using the email arrived linux notification category * release flutter_local_notifications 10.0.0-dev.17 * fix show with actions unit test * [flutter_local_notifications] Fix #1654 (#1655) * fix #1654 * Google Java Format Co-authored-by: github-actions <> * add comment on why actionInputs has the nullable annotation * Google Java Format * release 10.0.0-dev.18 * release flutter_local_notification_linux 1.0.0-dev.3 * fix merge issue * bump for 10.0.0-dev.19 release * 10.0.0-dev.20 release * Google Java Format * fix unit test for notification actions to check for audioAttributesUsage * release flutter_local_notifications 10.0.0-dev.21 * bump minimum flutter sdk to 2.8 and minimum dart sdk to 2.15 * update changelog entry when mentioning dbus * [flutter_local_notification] update document #1684 (#1692) update IOS general setup document in flutter_local_notification/README.md * add annotation to solve tree-shaking issues when dealing with functions using background isolates * add more details on entry point annotation and wording tweaks to cavaets to using background isolates * update API docs for onDidReceiveBackgroundNotificationResponse to mention entry point annotation * remove references to IsolateNameServer APIs * update docs around callbacks * fix documentation on getActiveNotifications related code * update min flutter sdk version of flutter app to 2.8 * clean up example app * fix issues picked up by linter * add details on caveat on null notification payload * update versions for stable release * update changelog for stable release * add missing changelog entry for iOS and macOS on request critical notification permissions and specifying interruption level * add changelog entry on changes done to example app around notification IDs * remove url_launcher dependency as it's not longer used * add steps on setting up compile SDK version * remove excess blank line from changelog Co-authored-by: morvagergely <51244648+morvagergely@users.noreply.github.com> Co-authored-by: github-actions <> Co-authored-by: runner <runner@Mac-1638060363952.local> Co-authored-by: runner <runner@Mac-1638061424079.local> Co-authored-by: runner <runner@Mac-1638061878701.local> Co-authored-by: runner <runner@Mac-1641201145648.local> Co-authored-by: Yaroslav Pronin <proninyaroslav@gmail.com> Co-authored-by: runner <runner@Mac-1645938063170.local> Co-authored-by: maprohu <maprohu@gmail.com> Co-authored-by: runner <runner@Mac-1646129288136.local> Co-authored-by: runner <runner@Mac-1648977077650.local> Co-authored-by: runner <runner@Mac-1648985481866.local> Co-authored-by: runner <runner@Mac-1649472035608.local> Co-authored-by: Lucas Ribolli <42274899+lucasribolli@users.noreply.github.com> Co-authored-by: SungHyun <joooosan011@gmail.com>
I noticed that there were no support for active notifications on iOS, and I thought it could be useful. If the iOS version is older than 10, the
activeNotifications
will return an empty list. This however, is a breaking change.