-
Notifications
You must be signed in to change notification settings - Fork 1k
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
fix(android): LocalNotification on
not working properly
#3307
Conversation
Ok, I tested up to monthly recurring events and everything seems to be working. My testing repro is available here. In case you want to try it out, you'd have to install Let me know if there's anything else I can do, if I should re-base on main or on v2.3.0. I have an app that's going into beta that will be using this feature branch for now, and when/if this gets merged/resolved I'll switch it back to the main repo again. Thanks! |
@carlpoole Care to take a look? @kheftel Yeah, please change the base branch to |
e855035
to
74213c0
Compare
I borked it with an accidental force push, changing it to a draft while i fix it, sorry! |
74213c0
to
2c9b5e1
Compare
ok, based it on 2.x branch, testing didn't seem to break anything, should be ready to look at now. |
I tested the changes and this appears to be working as expected. I went ahead and removed the test log and the commented out method for minor cleanup. Thanks for contributing! 🎉 👍 |
@jcesarmobile Here's a fix for 2.x. Good to go? |
thanks @carlpoole! Thanks for changing the logs to |
android/capacitor/src/main/java/com/getcapacitor/plugin/notification/DateMatch.java
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.
I've recommended a minor improvement, but changes look, can be merged as is. I'll let kheftel decide if my suggestion makes sense.
…cation/DateMatch.java Co-authored-by: jcesarmobile <[email protected]>
absolutely @jcesarmobile! Actually, I just pushed a new commit that zeroes out both second and millisecond, and does it in a slightly different place. |
Thanks, @kheftel! Great work 💪 |
I've read the contributing docs and I hope I'm doing this properly, please feel free to educate me on how to best approach this.
I needed to use the cron-like
on
notifications on a project of mine to make daily notifications happen at a certain time (like every day at 8:30 am) and noticed the Android implementation didn't work properly. On iOS, it all appears to be handled byDateComponents
, but on Android it's got a more complex custom implementation.It's a bit hard to find documentation, but after examining the native code, it appears that the
on
style notifications are supposed to let you:I could be wrong in my understanding, of course.
On the iOS side, Apple's documentation for
DateComponents
isn't very clear, tbh.Googling turned up some problems people were having (link, link), and I ran into my own issues as well. When trying to have a notification fire on the hour, it sometimes fired not on the hour, and if I passed hour and minute, I would sometimes get a notification that triggered at the next whole hour instead of the next day, and when I passed hour and omitted minute, I ended up with a notification that repeated ad infinitum as soon as I dismissed it, etc.
The existing logic appeared to be incomplete. It calculates the next time the notification should fire by first taking the current moment, setting the provided hour, minute etc, seeing if the resulting trigger time is in the past, and then bumping it by a certain amount. But it was only comparing to see if one unit was less than another (i.e. if hour < hour or if minute < minute), and sometimes it bumped by the wrong amount. Now it compares the timestamp of the two dates and explicitly remembers how much each iteration of the notification should be advanced by, according to the largest unit specified.
I've fixed it for my use case, i.e. I can pass hour and minute, and if device time is 2:15pm and I schedule it for 2:30pm, it goes off 15 min later, and if device time is 2:30 pm and I schedule it for 2:15pm, it schedules for the next day at 2:15pm. I left a logging statement commented out in the code for now that helped me test it and verify it's working - I expect to remove it before merge. The logic should be sound for the longer-repeating cases as well, though I haven't tested those on-device yet (I can certainly do that if I'm going about this right).
Please let me know how to proceed next, I am very impressed with this platform and am excited to be building my app on it, and if I can also contribute something back, so much the better. Thanks!