Fix a bug with comment box positioning.
Summary: We do want to only apply updates when a view previously wasn't mounted and didn't have a backing view created. Previously we were applying updates to the view regardless of the mount state, which resulted in positioning bugs. Rather than revert, I cleaned up the code Ahmed fixed, since didUpdate || ensureBackingViewIsCreated() was both a bug and obscure, as the two should have a swapped order. Reviewed By: sriramramani Differential Revision: D3538734
This commit is contained in:
parent
7562f9d6f5
commit
e674185ea1
|
@ -224,10 +224,14 @@ public class FlatUIImplementation extends UIImplementation {
|
||||||
callback);
|
callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ensureMountsToViewAndBackingViewIsCreated(int reactTag) {
|
private boolean ensureMountsToViewAndBackingViewIsCreated(int reactTag) {
|
||||||
FlatShadowNode node = (FlatShadowNode) resolveShadowNode(reactTag);
|
FlatShadowNode node = (FlatShadowNode) resolveShadowNode(reactTag);
|
||||||
|
if (node.isBackingViewCreated()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
node.forceMountToView();
|
node.forceMountToView();
|
||||||
mStateBuilder.ensureBackingViewIsCreated(node);
|
mStateBuilder.ensureBackingViewIsCreated(node);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -249,8 +253,15 @@ public class FlatUIImplementation extends UIImplementation {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void dispatchViewManagerCommand(int reactTag, int commandId, ReadableArray commandArgs) {
|
public void dispatchViewManagerCommand(int reactTag, int commandId, ReadableArray commandArgs) {
|
||||||
ensureMountsToViewAndBackingViewIsCreated(reactTag);
|
if (ensureMountsToViewAndBackingViewIsCreated(reactTag)) {
|
||||||
|
// need to make sure any ui operations (UpdateViewGroup, for example, etc) have already
|
||||||
|
// happened before we actually dispatch the view manager command (since otherwise, the command
|
||||||
|
// may go to an empty shell parent without its children, which is against the specs). note
|
||||||
|
// that we only want to applyUpdates if the view has not yet been created so that it does
|
||||||
|
// get created (otherwise, we may end up changing the View's position when we're not supposed
|
||||||
|
// to, for example).
|
||||||
mStateBuilder.applyUpdates((FlatShadowNode) resolveShadowNode(reactTag));
|
mStateBuilder.applyUpdates((FlatShadowNode) resolveShadowNode(reactTag));
|
||||||
|
}
|
||||||
super.dispatchViewManagerCommand(reactTag, commandId, commandArgs);
|
super.dispatchViewManagerCommand(reactTag, commandId, commandArgs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -164,8 +164,6 @@ import com.facebook.react.views.view.ReactClippingViewGroupHelper;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void dispatchDraw(Canvas canvas) {
|
public void dispatchDraw(Canvas canvas) {
|
||||||
super.dispatchDraw(canvas);
|
|
||||||
|
|
||||||
if (mRemoveClippedSubviews) {
|
if (mRemoveClippedSubviews) {
|
||||||
for (DrawCommand drawCommand : mDrawCommands) {
|
for (DrawCommand drawCommand : mDrawCommands) {
|
||||||
if (drawCommand instanceof DrawView) {
|
if (drawCommand instanceof DrawView) {
|
||||||
|
|
Loading…
Reference in New Issue