-
Notifications
You must be signed in to change notification settings - Fork 24.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix legacy arch RTL horizontal ScrollView regression (#47282)
Summary: Pull Request resolved: #47282 D63318754 fixed a class of issues with RTL horizontal scrollviews by moving logic from native Android view layer to Fabric ShadowNode layer. I realized quite a bit later this is problematic for legacy arch, since it now never runs RTL translation code, and all our RTL screenshot tests are against new arch. It's tricky to port Fabric ShadowNode related code to Paper since its shadownodes are more coupled to Yoga nodes, and the existing solution for contextual layout direction didn't quite work, so I went with the original logic we had for this, where we use global layout direction to determine whether to offset, and disable removeClippedSubviews, and this is applied via onLayout. This is wrong in several ways, but not a regression compared to previous legacy arch behavior. The fully correct behavior will require new arch. Changelog: [Android][Fixed] - Fix legacy arch RTL horizontal ScrollView regression Reviewed By: rshest Differential Revision: D65139747 fbshipit-source-id: 5662c0744c3c402efe583e602b2272662b4d5476
- Loading branch information
1 parent
0df59d4
commit bfca7cf
Showing
3 changed files
with
76 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
46 changes: 46 additions & 0 deletions
46
...src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollContainerLegacyView.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
/* | ||
* Copyright (c) Meta Platforms, Inc. and affiliates. | ||
* | ||
* This source code is licensed under the MIT license found in the | ||
* LICENSE file in the root directory of this source tree. | ||
*/ | ||
|
||
package com.facebook.react.views.scroll | ||
|
||
import android.content.Context | ||
import com.facebook.react.modules.i18nmanager.I18nUtil | ||
import com.facebook.react.views.view.ReactViewGroup | ||
|
||
/** | ||
* Used by legacy/Paper renderer to perform offsetting of scroll content when the app-wide layout | ||
* direction is RTL. Contextually set layout direction is not respected by legacy renderer. | ||
*/ | ||
internal class ReactHorizontalScrollContainerLegacyView(context: Context) : | ||
ReactViewGroup(context) { | ||
private val isRTL: Boolean = I18nUtil.instance.isRTL(context) | ||
|
||
override fun setRemoveClippedSubviews(removeClippedSubviews: Boolean) { | ||
// removeClippedSubviews logic may read metrics before the offsetting we do in onLayout() and is | ||
// such unsafe | ||
if (isRTL) { | ||
super.setRemoveClippedSubviews(false) | ||
return | ||
} | ||
|
||
super.setRemoveClippedSubviews(removeClippedSubviews) | ||
} | ||
|
||
protected override fun onLayout(changed: Boolean, left: Int, top: Int, right: Int, bottom: Int) { | ||
if (isRTL) { | ||
// When the layout direction is RTL, we expect Yoga to give us a layout | ||
// that extends off the screen to the left so we re-center it with left=0 | ||
val newLeft = 0 | ||
val width = right - left | ||
val newRight = newLeft + width | ||
setLeft(newLeft) | ||
setTop(top) | ||
setRight(newRight) | ||
setBottom(bottom) | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters