mirror of
https://github.com/status-im/react-native.git
synced 2025-01-16 20:44:10 +00:00
RN: Revert D8666509
Summary: Reverts D8666509. Unfortunately, I misunderstood `setClipChildren` on Android. When set on a `ViewGroup`, `setClipChildren` configures whether its //children// — not itself — are clipped to their bounds. This is unlike `overflow` (as it behaves on iOS) which configures whether the view itself is clipped to its bounds. But they are definitely related. In theory, I think we could implement `overflow` using `setClipChildren` by: - Setting `setClipChildren(false)` by default. (This part, I got right.) - When `overflow` is set to `hidden` on a `View`, we create an extra `ViewGroup` (child) within the normal `ViewGroup` (parent). Then, we can set `setClipChildren(true)` on the parent `ViewGroup` which will cause the child `ViewGroup` to be clipped to its bounds. However, I think the tricky thing will be to create the child `ViewGroup` without incurring unintentional side effects. I need to decide whether or not this is worth trying. The alternative is to add a new `clipChildren` boolean prop that is Android-only, but I really hate further bifurcating the platform. But for now, I am reverting my mistake. Reviewed By: achen1 Differential Revision: D8690551 fbshipit-source-id: 1ba3bbcc5458ffbd5c475430ea0382b3fd0916b2
This commit is contained in:
parent
d9fa1d70dc
commit
f090840f45
@ -254,8 +254,8 @@ public class ViewProps {
|
|||||||
return map.isNull(BORDER_RIGHT_WIDTH) || map.getDouble(BORDER_RIGHT_WIDTH) == 0d;
|
return map.isNull(BORDER_RIGHT_WIDTH) || map.getDouble(BORDER_RIGHT_WIDTH) == 0d;
|
||||||
case BORDER_BOTTOM_WIDTH:
|
case BORDER_BOTTOM_WIDTH:
|
||||||
return map.isNull(BORDER_BOTTOM_WIDTH) || map.getDouble(BORDER_BOTTOM_WIDTH) == 0d;
|
return map.isNull(BORDER_BOTTOM_WIDTH) || map.getDouble(BORDER_BOTTOM_WIDTH) == 0d;
|
||||||
case OVERFLOW:
|
case OVERFLOW: // We do nothing with this right now.
|
||||||
return map.isNull(OVERFLOW) || map.getString(OVERFLOW) == "visible";
|
return true;
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -112,7 +112,6 @@ public class ReactViewGroup extends ViewGroup implements
|
|||||||
|
|
||||||
public ReactViewGroup(Context context) {
|
public ReactViewGroup(Context context) {
|
||||||
super(context);
|
super(context);
|
||||||
setClipChildren(false);
|
|
||||||
mDrawingOrderHelper = new ViewGroupDrawingOrderHelper(this);
|
mDrawingOrderHelper = new ViewGroupDrawingOrderHelper(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -639,7 +638,6 @@ public class ReactViewGroup extends ViewGroup implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void setOverflow(String overflow) {
|
public void setOverflow(String overflow) {
|
||||||
setClipChildren(mOverflow == "hidden");
|
|
||||||
mOverflow = overflow;
|
mOverflow = overflow;
|
||||||
invalidate();
|
invalidate();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user