- Support to AGP 8: Added new proguard rules to allow SQLite database, used to capture notification events and schedules, to work with AGP 8.
- Example app updated to support Flutter 3.19: The flutter example was updated to fully support Flutter 3.24 with new Gradle Java Standards.
- Firebase dependencies updated: All Firebase dependencies was updated to support Firebase core 3.0.0.
- Intervals changed to Duration type: The inteval value was changed from int (sec) to Duration, allowing a better understanding of time reading the code.
- Documentation Updated: Documentation updated to also include AndroidManifest instructions to recreate schedules when the device is restarted.
- MediaPlayer Album Art Resolution Fix: Addressed an issue where album art was displaying at reduced resolution on Android 14 devices. Album artwork now renders clearly and crisply, improving the visual quality of the media player.
- Gson Library Removal: Removed the Gson library due to compatibility issues with Android's latest releases and the R8 minification process. Transitioned to a more robust serialization framework that better supports obfuscation and modern Android versions.
- Minimal supported Android version increased to 23: The minimal android supported is now 23 (Android 6), since some encryption and security features rely on this minimal version.
- Minimum iOS Deployment Target Increased to 12: The minimum iOS deployment target has been increased to iOS 12 to leverage newer API capabilities and enhance app security and performance.
- Necessity to Manually Add Permissions in AndroidManifest.xml: Projects will now need to manually declare the following permissions in their AndroidManifest.xml in case needed:
android.permission.VIBRATE
android.permission.SCHEDULE_EXACT_ALARM
android.permission.USE_FULL_SCREEN_INTENT
android.permission.WAKE_LOCK
android.permission.FOREGROUND_SERVICE
android.permission.RECEIVE_BOOT_COMPLETED
- weekOfMonth parameter is deprecated and scheduled for removal in a future release due to unimplemented dependencies expected in versions beyond 1.0.0. It may be reconsidered for inclusion in later versions.
- GitHub Issues Closure: Effective immediately, GitHub issues will no longer be open for new support requests. Existing issues will remain accessible as an archive and resource.
- Discord Community Support: All support for Awesome Notifications has transitioned to our Discord community. This move aims to provide a more dynamic, interactive, and efficient support experience.
- Reasons for Change:
- Community Rules Respect: Numerous issues posted on GitHub have not adhered to our community guidelines, impacting heavily on support efficiency and effectiveness.
- Efficiency and Effectiveness: Managing support through GitHub has become exceedingly time-consuming, particularly when posts omit critical information or disregard guidelines.
- Quality of Support: Our Discord community allows for real-time engagement, resource sharing, and a closer-knit user and developer interaction, which wasn't true for GitHub.
- Next Steps for Users: We encourage all users to join our Discord community https://discord.awesome-notifications.carda.me/ for ongoing support, updates, and to connect with fellow users and the development team.
- Double Check in Lost Events Manager: Implemented a double-check for
createdDate
anddisplayedDate
fields to enhance the stability of the Awesome Notifications framework. - Image Support for iOS Notifications: Expanded image support to all notification layouts on the iOS platform, enabling a richer user experience.
- Upgrade to Flutter 3.19 Standards: Migrated Android configuration and dependency management to comply with Flutter 3.19 standards.
- Project and Android Core Dependencies Updated: Upgraded all project dependencies, including Android core dependencies to version 0.9.3, to their latest versions.
- Notification Builder Flexibility: Adjusted notification builder to eliminate the need for setting a summary in the Messaging layout, addressing the exception "User must be valid and have a name."
- SimpleButton Widget Update: Updated the
SimpleButton
widget in the example app to use non-deprecated properties, ensuring compatibility with the latest Flutter versions.
- Progress Property Type Change: The
progress
property inNotificationContent
has been altered fromint
todouble
for improved precision in notification progress indication.
- iOS Core Version Bumped to 0.9.3: Updated the iOS core version to 0.9.3 to align with the latest enhancements and fixes.
- Android Core Dependencies Updated to 0.9.3: The Android core dependencies have been updated to reflect the latest improvements, security patches, and new features.
- Cancel schedule for iOS: The feature
cancelSchedule
was added to iOS platform. - Example app updated: The example app was updated to reflect the last changes.
- Progress Property Now Double: The
progress
property inNotificationContent
has been changed fromint
todouble
. This modification enhances the precision of progress values in notifications.
- Enhanced Documentation: Updated the README documentation to include details on the new media player properties and the updated
progress
property type. - Refined Test Cases: Revised test cases to cover the new
double
type forprogress
and related numerical conversions, ensuring robustness and accuracy.
- Default Values for MediaPlayer Properties: Introduced default values for new media player properties like
duration
,playState
, andplaySpeed
. This change aims to eliminate null exceptions and improve reliability.
- Pod modifications: Now it's necessary to also add Awesome Notifications pod modification inside
PodFile
at iOS folder. - Receive port and send port: The methods
sendPort.send()
andreceivePort!.listen()
now only accept serialized data, not objects. Convert your data to a map format and reconstruct it later from this format. - License Key (Year 2): Starting the year 2 support of awesome suite. In case your license was generated for Year 1 and you're still under the 1-year purchase support you just need to reply to the license email requesting the free update.
- Translation keys and Args: Implemented support for dynamic localization in notifications. Translation keys (
titleLocKey
,bodyLocKey
) and their respective arguments (titleLocArgs
,bodyLocArgs
) can now be used to localize notification content dynamically based on the user's language preference. - Authentication required action: New action property that requires user authentication to proceed.
- Extended Support: We're excited to announce the commencement of our "Year 2 Support Season." This includes ongoing maintenance, regular updates, and dedicated support.
- Flutter 3.16.5 Compatibility: The plugin is now fully compatible with Flutter 3.16.5.
- Enhanced Event Handling on Android: We've modified event handlers on Android to support negative values. This enhancement ensures more robust and reliable event management.
- Resolved Silent Callback Issue: Fixed a previously encountered issue where silent callbacks were missing for silent background actions.
- New media player features (Playback state, speed and duration) for media player notifications
- Support for Flutter 3.16.0 and the new methods exclusive for Main targets on iOS
- Dependencies updated
- Unit tests updated
- Documentation updated
- iOS awesome_notifications library updated to version 0.8.1
- Swift libraries updated to utilize a shared reference from the new Logger class.
- Updated library versions to 0.8.0 to ensure that project lock files are updated.
- Enhanced versioning of iOS core libraries to better support DevOps, ensuring greater flexibility for future updates.
- Integration with awesome_notifications_core to automatically manage versions
- Support for Android 14
- Documentation updated
- Full support for Flutter 3.13
- Support for iOS 17
- Compatibility with AGP 8
- Automated tests for Dart code in master, with over 90% coverage
- New image provider for native resource media
- Project dependencies upgraded to the latest version available
- Documentation updated
- Chronometer indicator for Android notifications
- Default app small icon fixed on Android
- New field timeoutAfter exposed on NotificationContentModel constructor
- Notification events changed to fire also for negative address
- Filters to separate meta data from payload on iOS pushes changed to ignore local notifications
- Order of recreation notification events changed on iOS to preserve expired lost events
- iOS minimal deployment target decreased to 11
- TimeoutAfter modified to use Duration, instead of integer values to represent seconds
- Android core dependencies moved to new repository
- Added new native module switcher to avoid the folder copy at example/android folder.
- Added new test cases for actionType property
- Replaces local references from development repositories to online versions
- Updates and improves documentation due new pub.dev requirements
- Added translation feature to notifications based on app configurations or custom configurations
- Added "AwnAppGroupName" property to "Info.plist" to support custom App Group names on iOS
- Added support for inexact schedules, allowing notifications to be scheduled at approximate times rather than exact times
- Added "delayTolerance" parameter to schedules to provide a tolerance for delayed notifications (in seconds)
- Added methods to API to list all active notification IDs and check if a notification ID is * * currently active
- Achieved 97.7% test coverage with new test cases for all relevant classes
- SQLite database to replace SharedPreferences on Android
- Ability for displayed notification events to fire in the exact amount that they had displayed to the user, even with the same ID
- Example app with ReceivePort and SendPort
- schedule map conversions for interval notifications with repeat option on Android
- onCreated and onDisplayed calling events for Notification Target Extensions on iOS
- Updates Discord markdown links on pub.dev
- Adds single page example on pub.dev
- Fixes background action definition labels for iOS
- Fixes getInitialNotificationAction for larger projects with intense initial loading
- Ensures notifications with reply buttons do not close the status bar after sending text messages
- Updates and improves documentation
- Adds badge parameter into notification's content to set the app badge value through notifications
- Adds deep merge method into MapUtils to allow notification content combinations
- Increases Flutter minimal version to 2.14 due to DecoderCallback deprecation
- Updates and improves documentation
- Upgrades Media Style dependencies
- Decreases Flutter SDK dependency from 2.18 to 2.12 to support old Flutter applications
- Adds switch imports for Dart:io and Dart:html to improve web support
- Updates Awesome web portal URLs
- Updates iOS core dependency to version 0.7.1 to match FCM add-on plugin
- Initial release of Awesome Notifications version 0.7.0
- Updates Android core dependency to 0.7.0-alpha.7+6
- Adds getInitialNotificationAction method
- Updates Android core dependency to 0.7.0-alpha.7+6
- Runs dart format over Lib to increase pub.dev score
- Decreases Dart support to support version 2.18.0.
- Replaces DecoderCallback with DecoderBufferCallback due to Flutter deprecation for resource images
- Makes modifications according to lint warnings to increase pub.dev score
- Fixes to change the plugin domain name
- Adds new Flutter plugin architecture to make it compatible with all available platforms
- Extracts Android and iOS core to be reused in remote repositories and other languages
- Includes the Donate with PayPal section
- Fixes out-of-sync definition values between Flutter, Android, and iOS
- Extends coverage to Android 13 (SDK 33), without the new request dialog (temporary)
- Fixes zero being saved instead of the actual handles for silent background actions
- Adds getLifeCycle function to return the current life cycle state of awesome notifications
- Adds optional value for payload data
- iOS notification actions improved to gain more performance and ensure the fast first opening
- iOS notification builder refactored to ensure the ios category creation before the notification being displayed
- iOS notification builder refactored to ensure the completion handle order for push notifications
- Fixes displayOnForeground e displayOnBackground for iOS
- Fixes empty title and body for messaging layout
- Removed Java cast warnings for cases where's a previous type checking.
- Fixes NotificationCalendar's inverted error "The time conditions are invalid"
- Documentation improved with new imports and observations with common found issues during beta phase
- Dart source code cleaned to improve pub points
- Coverage extended to Android 12L (SDK 32)
- All exceptions have been standardized with distinct exception codes to improve native error handling via PlatformException
- New exception catcher implemented to handle all native exceptions and provide better integration with Firebase Analytics.
- StopForeground method by id was Fixes on Android
- Message layout grouping Fixes (#466)
- Background actions improved on iOS to hold long tasks
- Background actions improved on iOS to increase UI performance through background threads
- Adds console performance measures for iOS
- Adds warning messages for non implemented layouts on iOS
- Notification's payload attribute changed to support null values
- awesome_notifications_core package renamed to core to reduce import's path length
- Documentation improved
- AsyncTask replaced by Handler/Looper due deprecation in Android 12
- FULL_WAKE_LOCK replaced by SCREEN_BRIGHT_WAKE_LOCK to improve battery life in Android
- Implemented research by Android alarm intents to optimize the reschedule process
- Adds id helpers to improve the performance of ScheduleManger's cancellations process in almost 100 times
- Adds dart isolates to allow receiving background notifications without bring the app to foreground
- Adds silentBackground, silentBackgroundAction, disableAction and dismissAction action types for notifications and buttons
- InputField type deprecated, as now is possible to combine input buttons with all other action types. Now, to use InputField, please use the property requireInputText
- Internal architecture rewrote to decrease O.S. interventions, allowing to increase the performance while create and schedules notifications in almost 10 times
- Date objects replaced by Calendar type to enable real time zone operations in native layer
- Adds test unit cases to increase test coverage (55% coverage)
- Network images for foreground services are reactivated
- Upgraded external dependencies to become compatible with Flutter 2.10
- Adds customSound feature for Android (only applicable for versions older than Android 8 (Oreo))
- Type parameter T removed from AwesomeAssertUtils to allows it to be compatible with Flutter web parser.
- Adds rounded images for large icon and big picture
- Adds bool value extraction for Map objects in dart
- Fixes immutable error for input buttons in Android 12
- Network images for foreground services are temporarily disabled (https://github.com/rafaelsetragni/awesome_notifications/issues/369)
- Adds sound extension for notifications with categories Alarm and Call
- Adds call notification behavior (stay floating on screen and keep playing the sound in loop) for Call category
- Adds CancellationManager to reorganize all dismiss and cancellation methods in a single place
- Created StatusBarManager to manage which notifications are currently active, improving performance and extending support to Android 5.0 Lollipop (SDK 21)
- Notification layouts BigPicture, Messaging and MessagingGroup improved to be more performative and to reuses network connection data
- Adds history box to notification's reply buttons on Android 8.0 to 12.0
- iOS swift completion handlers modified to allow display notifications from another plugins
- Update readme file and PermissionManager to be compatible with Android 12 and Java 7
- Java lambda expressions removed to turn Android source compatible with old Java 7
- Adds Channel's Group feature for Android
- Adds notification's category feature for Android
- Adds fullScreenIntent permission and content option to allow to show notifications in full screen mode.
- Adds PreciseAlarms permission and schedule option to allow to show scheduled notifications with more precision.
- Adds showPage methods to provide shortcuts to channel permissions page and alarm permission page.
- Adds shouldShowRationale method for android to check if the requested permissions require user intervention to be enable.
- Adds request permissions methods to demand the users permissions considered dangerous by the system.
- Permission's request methods refactored to enable a more modular and scalable evolution to comport future permissions for Android
- Documentation has been improved with the new permissions methods, channel's group, notification categories, fullScreenIntent and PreciseAlarms permissions
- Adds wakeUpScreen option in notification content to wake up screen when a notification is displayed (Requires to add WAKE_LOCK permission into AndroidManifest.xml).
- Adds custom permissions for method requestPermissionToSendNotifications (has no effect on Android).
- Documentation has been improved with wakeUpScreen option
- Media button receiver removed from AndroidManifest.xml due incompatibility with some Galaxy models and another plugins (#81 and #320)
- Documentation on scheduling notifications has been improved
- PushNotification class deprecated, as all push features are being moved to the new companion plugin. Instead, use NotificationModel.
- Adds isDangerousOption for action buttons, to color the text in red to indicate a dangerous option for the user.
- Adds color option for action buttons, to color the text in Android 8.0 Oreo and beyond (has no effect on iOS).
- Fixes for issue #321, when a new notification is erroneously created when the user taps on notification action button.
- Adds validation to prevent scheduling with repeating intervals smaller than 60 seconds (iOS restriction)
- Adds crontab schedule to allow complex schedules based on initial and expiration date, a list of precise dates, or a crontab expression, and all four options can be combined together (only for Android)
- Defined the final standard to replace negative IDs by random values
- Minimum Android requirements increased to SDK 23 (Android 6.0 Marshmallow) due to new cancellation methods with unsecure procedures on API prior 23
- Adds messaging layout and messaging group layout
- Adds method showNotificationPage to programmatically redirect the user to O.S. notifications permission page
- Minimum Android requirements increased to SDK 21 (Android 5.0 Lollipop) due to new cancellation methods
- Adds new cancellation methods (dismiss, cancel schedules and cancel all (dismiss and schedules at same time))) based on group key or channel key
- Property "autoCancel" changed to "autoDismissable", to match the new cancellation methods naming principles
- Adds internal group key based on ID, to prevent Android auto grouping with 4+ notification from same channel when group key was not specified
- Android channels refactored to keep the original channel key at maximum as possible, maximizing the compatibility with another plugins.
- Models refactored to follow the native standards and transformations from map data
- Calendar millisecond precision has been deprecated, due devices do not provide or ignore such precision.
- Adds error handling for image assets (iOS)
- Adds video tutorial into README file
- Version numbering has changed to better translate the stage of development for future releases.
- Adds showInCompactView property for MediaPlayer buttons
- Adds support to multiple subscriptions on created, displayed, action and dismissed stream
- Removed channel key from Android Badge methods, because the segregation in channel keys was never used (now is all global)
- Adds increment and decrement badge methods (more performative)
- Fix Android reschedules on startup process (issue #285)
- Improved Android channels to manage another package channels and convert then to the new standard, using channelKey as hashKey produced from digest channel content
- Adds foreground services for Android
- Fixes android reference for guava package
- Fixes null reference for main class inside NotificationBuilder.java
- Fixes null reference for main class
- Improves documentation
- Updates push notifications in the example app
- Adds time zones for scheduled notifications
- Adds foreground behavior for input button
- Adds dismiss methods to dismiss the notifications without cancel their respective schedules
- Adds behavior of bringing action buttons to foreground on iOS
- Adds debug option on initialize method to lower debug verbosity if not necessary
- Improves error messages and error handling for iOS and Android platforms
- Adds native firebase handling for will present notification method
- Adds fixedDate to getNextDate on iOS
- Adds .aiff example files with more quality
- Adjust weekday to work with ISO 8601
- Fixes Android canceling for a grouped notification set as summary behaviour
- Adds color hexadecimal representation for json content
- Fixes Android first grouped message as summary behaviour.
- Flutter version Fixes, according to pub.dev warnings
- Plugin upgraded to support dart Null Safety
- FCM service native support removed for iOS and Android.
- iOS awesome extensions removed.
- Schedule feature downgraded due to iOS official developer's incapacity and SO limitations (could be reactivated manually).
- Adds an example to how to integrate awesome_notification with firebase_messaging plugin.
- Documentation improved
- FCM service with comments removed for iOS.
- Adds removeChannel method for iOS and error messages for Android removeChannel method.
- ios project and example project recovered.
- Releasing of final version with push notifications enabled.
- Adds forceUpdate option on setChannel method, to allows to full update an channel on Android Oreo and above without need to reinstall the app, with the downside to close all current notifications.
- Flutter version updated to 3.0, with null safety support.
- Fixes privacy bugs
- Fixes grouping functionality and Adds sort option (sort only works for Android)
- Fixes media button errors for Android 10 and above
- Fixes media path errors for iOS
- Adds default sound options for Ringtone, Alarm and Notifications.
- Documentation improved
- Adds the link to allows the community to remove or not the push notification functionality from Awesome Notifications plugin.
- Adds the icon field inside notification content package to allow to change the small icon without need to use another channel
- Included the example for locked notifications for Android and improved the locked priority behaviour
- Adds importance level for notifications (Android 8 and above)
- Documentation improved
- Internal firebase packages updated to the last Android and iOS version
- Fixes auto cancel off for schedule notifications (Android)
- Fixes action buttons for push notifications (iOS)
- Solution for DateUtils class conflict with the new Material "DateUtils" included on documentation
- Documentation improved
- Included emojis to be used on local and push notifications
- Documentation improved
- Included canceling capability to notification push service in cases of invalid notification
- iOS documentation improved
- Finished FCM push messages for iOS 10 or higher
- Decreased the implementation complexity to use NotificationServiceExtension and NotificationContentExtension targets (iOS)
- Adds two app examples on documentation as tutorials
- Improved the native resource decoder to work outside of main thread (Android)
- Included protect mode to native resources against obfuscation (Android)
- Improved object storage to work correctly with minification
- Documentation on README file updated
- Improved error messages for notifications disabled in Android Devices
- Fixing bug found at Android channel checking process (https://github.com/rafaelsetragni/awesome_notifications/issues/28)
- Cleared log messages to decrease visual pollution.
- Replaced the native Java Log package by the Flutter's one.
- Fixes wrong "Invalid push notification content", wrongly showed when notification is successfully created.
- Simplifying the iOS setup process for the developer (it's still a bit complex)
- Fixes complex schedules for iOS apps running on Foreground
- Included Global Badge indicators for iOS and some Android distributions
- Included request permission and check permission methods
- Included Firebase support to send push notifications on iOS (work in progress)
- Fixes Shader's render problems on iOS devices
- Fixes UTC Dates on iOS devices
- Adjusting the plugin content to pub.dev patterns
- Documentation updated
- Included DismissedStream to capture dismissed notifications by the user
- Included iOS notification source code to enable send local notifications on iOS devices (still in development)
- Updated asset's load file method inside the java native code, due to flutter's 1.22 deprecation on "FlutterLoader.getInstance()"
- Extracted Bitmap class from bitmap package, due to buildGradle incompatibilities while running the project on release mode (Java)
- Documentation updated
- Adds precise schedules option to schedule a notification multiple times with precisely date and time
- Documenting the code
- Adjusting the plugin content to pub.dev patterns
- Initial release.