-
-
Notifications
You must be signed in to change notification settings - Fork 632
iOS 13 TabBar position is invalid after resuming device from lock #373
Description
Describe the bug
First of all I would like to thank you again for this library, I use it in my apps and it makes the user experience much more pleasurable.
I've been updating my app for iOS 13 and I've noticed an invalid behaviour of the Scrolling NavBar, TabBar to be exact.
If the device is locked and the NavBar/TabBar is collapsed, then its position is invalid, when the device wakes back up. The problem can be seen in the gif I've attached.
The problem appears when also presenting other VCs onto the VC that has the ScollingNavBar, such as when presenting a SideMenu, in my case.
To Reproduce
Steps to reproduce the behavior:
- Make the TabBar collapse.
- Lock the device/simulator
- Unlock the device, the TabBar will be visible, but in the .collapsed state, so once you scroll up, the TabBar moves above its normal position.
(Tested on iPhone 11 Pro Max iOS 13 Simulator, which didn't seem to happen on iOS 12 and below after fixing The TabBar does not appear when resuming from a video inside a WKWebView #321 )
Expected behavior
The TabBar should either be collapsed when waking, or have the correct state so it does not go above its normal position
Screenshots
Here's the gif of the problem. gif
After taking a look at the source code, I believe that the scrollWithDelta function gets called before the didBecomeActive function, thus making the previousState param always .expanded before the didBecomeActive checks its value. All of these are in the ScrollingNavigationController class.
I'll do some more digging and report here if I find a fix, any ideas are appreciated