Skip to content

Latest commit

 

History

History
172 lines (153 loc) · 9.11 KB

CHANGELOG.md

File metadata and controls

172 lines (153 loc) · 9.11 KB

ChangeLog

Version 0.10.0

  • Fixed Android 12 bug to make notifications clickable (@powobox) by replacing the action handler services with activities (avoid notification trampoline restrictions)
  • Merged forks of @timkellypa and @bhandaribhumin (cordova-plugin-local-notification-12) back into original fork
  • Android code clean-up and refactoring (@powobox, @fquirin)
  • Removed 'beta' from version name ... everything about Android/Cordova is 'beta' anyway ;-)

Important notice

If the app is in background, it must not be launched but put in foreground. To avoid launching the app in this case, add the following in your config.xml file: <preference name="AndroidLaunchMode" value="singleInstance"/>

Version 0.9.0-beta.5 (from cordova-plugin-local-notification-12 by @bhandaribhumin)

  • Fixed bugs 🐛
    • Added missing 'PendingIntent.FLAG_MUTABLE' and fixed gradle
    • Guard against webview crash
    • Add thread identifier property
    • Delete Alarms when intent is deleted
    • Not calling delegate events if nil or if we're consuming the notification
    • Android 13 POST_NOTIFICATIONS permission and runtime popup added
  • Enhancements (Android)
  • New interfaces to ask for / register permissions required to schedule local notifications
  • New method addded for android setDummyNotification()

Version 0.9.0-beta.4

  • Platform enhancements
  • Enhancements (Android)
    • Adjusted high priority notifications to fire at more exact time.
      • use setAlarmClock() rather than setExactAndAllowWhileIdle().
    • New autoLaunch attribute.
      • Notification launches application if closed (Android <= 9).
      • App has the option to run some logic and schedule (or not schedule) an immediate alarm.
      • Note, this will be overridden if fullScreenIntent is true. Doing that will use the fullScreenIntent behavior and not always autoLaunch.
      • Also note, this feature can cause alarms to not always fire on time.
    • New alarmVolume attribute. Can force application to increase device notification volume prior to playing sound.
    • New resetDelay attribute. Delay to reset alarmVolume on the device back to its original settings
    • New wakeLockTimeout attribute. Can be used to extend the wakelock to keep the device awake longer (in case an autoLaunch application trigger takes a while).
    • New triggerInApp attribute.
      • If set to true, notification will not fire. Instead it will fire a trigger event that can be listened to in the app.

      • This allows you to evaluate the notification in the application, and if you decide to fire it, you can remove the trigger, remove triggerInApp, and schedule it. (It should fire immediately).

      • This was previously coupled with autoLaunch, but I split it out for more flexibility.

      • Listening to the event can be done as follows:

        window.cordova.plugins.notification.local.on('trigger', (notification) => { // do something with notification });

      • Note: this functionality will be skipped (alarms will fire immediately with no trigger method) if any of the following are true:

        • Android 8+ is asleep and the app is not running (even if autoLaunch is true). As a timely execution of the app code can't be guaranteed in this state, the notification will fire immediately.
        • The app is not running and autoLaunch is false (any Android version). If the app is not running, we can't execute its code, so fire immediately.
    • New fullScreenIntent attribute.
      • If set to true, will use fullScreenIntent in AlarmManager to launch application.
      • Setting this to true will negate autoLaunch, and is the only way to automatically launch the app on Android 10+.
      • Note: OS/manufacturer has some options for how to deal with this configuration. It will not always launch the activity, but typically will launch it if the device is asleep and show a heads-up notification if it is not.
  • Android Channel Support
  • New channelName attribute for the name of the notification channel to use
  • New channelId attribute. If passed in, a notification channel will be created (using volume and vibration settings to determine importance)
  • Android: Support for excluding an application from battery optimization settings.
  • Android: Support for allowing an application permissions to override Do Not Disturb.
  • iOS: No longer remove notification from notification bar when alarms are rescheduled. Call cancel() explicitly to retain this behavior.

Please also read the Upgrade Guide for more information.

Version 0.8.5 (22.05.2017)

  • iOS 10

Version 0.8.4 (04.01.2016)

  • Bug fixes
  • SyntaxError: missing ) after argument list

Version 0.8.3 (03.01.2016)

  • Platform enhancements
  • Support for the Crosswalk Engine
  • Support for cordova-ios@4 and the WKWebView Engine
  • Support for cordova-windows@4 and Windows 10 without using hooks
  • Enhancements
  • New color attribute for Android (Thanks to @Eusebius1920)
  • New quarter intervall for iOS & Android
  • smallIcon is optional (Android)
  • update checks for permission like schedule
  • Decreased time-frame for trigger event (iOS)
  • Force every: to be a string on iOS
  • Bug fixes
  • Fixed #634 option to skip permission check
  • Fixed #588 crash when basename & extension can't be extracted (Android)
  • Fixed #732 loop between update and trigger (Android)
  • Fixed #710 crash due to >500 notifications (Android)
  • Fixed #682 crash while resuming app from notification (Android 6)
  • Fixed #612 cannot update icon or sound (Android)
  • Fixed crashing get(ID) if notification doesn't exist
  • Fixed #569 getScheduled returns two items per notification
  • Fixed #700 notifications appears on bootup

Version 0.8.2 (08.11.2015)

  • Submitted to npm
  • Initial support for the windows platform
  • Re-add autoCancel option on Android
  • Warn about unknown properties
  • Fix crash on iOS 9
  • Fixed webView-Problems with cordova-android 4.0
  • Fix get* with single id
  • Fix issue when passing data in milliseconds
  • Update device plugin id
  • Several other fixes

Version 0.8.1 (08.03.2015)

  • Fix incompatibility with cordova version 3.5-3.0
  • Fire clear instead of cancel event when clicked on repeating notifications
  • Do not fire clear or cancel event when clicked on persistent notifications

Version 0.8.0 (05.03.2015)

  • Support for iOS 8, Android 2 (SDK >= 7) and Android 5
  • Windows Phone 8.1 will be added soon
  • New interfaces to ask for / register permissions required to schedule local notifications
  • hasPermission() and registerPermission()
  • schedule() will register the permission automatically and schedule the notification if granted.
  • New interface to update already scheduled|triggered local notifications
  • update()
  • New interfaces to clear the notification center
  • clear() and clearAll()
  • New interfaces to query for local notifications, their properties, their IDs and their existence depend on their state
  • isPresent(), isScheduled(), isTriggered()
  • getIds(), getAllIds(), getScheduledIds(), getTriggeredIds()
  • get(), getAll(), getScheduled(), getTriggered()
  • Schedule multiple local notifications at once
  • schedule( [{...},{...}] )
  • Update multiple local notifications at once
  • update( [{...},{...}] )
  • Clear multiple local notifications at once
  • clear( [1, 2] )
  • Cancel multiple local notifications at once
  • cancel( [1, 2] )
  • New URI format to specify sound and image resources
  • http(s): for remote resources (Android)
  • file: for local resources relative to the www folder
  • res: for native resources
  • New events
  • schedule, update, clear, clearall and cancelall
  • Enhanced event informations
  • Listener will get called with the local notification object instead of only the ID
  • Multiple listener for one event
  • on(event, callback, scope)
  • Unregister event listener
  • un(event, callback)
  • New Android specific properties
  • led properties
  • sound and image accepts remote resources
  • Callback function and scope for all interface methods
  • schedule( notification, callback, scope )
  • Renamed add() to schedule()
  • autoCancel property has been removed
  • Use ongoing: true for persistent local notifications on Android
  • Renamed repeat intervals
  • second, minute, hour, day, week, month and year
  • Renamed some local notification properties
  • date, json, message and repeat
  • Scheduling local notifications with the deprecated properties is still possible
  • Kitchen Sink sample app
  • Wiki

Version 0.8.0 (05.03.2015)

Added condition to get view from view or engine PR