Fix: state loss in SearchActivity and MediaDetailPagerFragment during screen rotation #6605
+41
−16
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description (required)
What changes did you make and why?
SearchActivity: added thaonSaveInstanceStateto track the current media position and updatedonCreateto restore the media detail view if a position was previously saved. This replaces the previous temporary fix inonResumewhich forced a back-press on rotation.MediaDetailPagerFragment: Updated the fragment to save and restore its internalViewPagercurrent item index.binding.root.postfor restoration, I ensured the UI is fully laid out before re-opening details, preventing crashes and ensuring the user stays on the same image they were viewing before rotating the device.onBackPressed()call fromonResume()which was an anti-pattern causing the fragment back-stack to increase incorrectly.Tests performed (required)
Tested ProdDebug on Redmi Note 13 Pro with API level 35.
isFeaturedImageandeditableflags are preserved after rotation, keeping menu items consistent.