Skip to content

Commit

Permalink
fix(Android): getChildDrawingOrder when using refreshcontrol (#2330)
Browse files Browse the repository at this point in the history
Fixes #2329

- Changes how we check if the child is a CircleImageView to be
minification safe

Build
`[this](https://github.com/BenIrving/refreshcontrolrepro/tree/main)`
repro using this changeset, observe no crash when navigating between
screens.

You can also check `Test640.tsx` test by going into the second screen
(by button), then try to manually refresh list by swiping down (until
the refresh control will show). During the refresh, try to go back to
the first screen - application shouldn't crash.

- [x] Ensured that CI passes

Co-authored-by: Ben Irving <[email protected]>
(cherry picked from commit d424e1a)
  • Loading branch information
BenIrving authored and kkafar committed Oct 25, 2024
1 parent eed1cb0 commit ee967a5
Showing 1 changed file with 3 additions and 1 deletion.
4 changes: 3 additions & 1 deletion android/src/main/java/com/swmansion/rnscreens/Screen.kt
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,10 @@ import android.view.View
import android.view.ViewGroup
import android.view.WindowManager
import android.webkit.WebView
import android.widget.ImageView
import androidx.core.view.children
import androidx.fragment.app.Fragment
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout
import com.facebook.react.bridge.GuardedRunnable
import com.facebook.react.bridge.ReactContext
import com.facebook.react.uimanager.UIManagerHelper
Expand Down Expand Up @@ -291,7 +293,7 @@ class Screen(
parent?.let {
for (i in 0 until it.childCount) {
val child = it.getChildAt(i)
if (child.javaClass.simpleName.equals("CircleImageView")) {
if (parent is SwipeRefreshLayout && child is ImageView) {
// SwipeRefreshLayout class which has CircleImageView as a child,
// does not handle `startViewTransition` properly.
// It has a custom `getChildDrawingOrder` method which returns
Expand Down

0 comments on commit ee967a5

Please sign in to comment.