mirror of
https://github.com/status-im/react-native.git
synced 2025-01-28 10:14:49 +00:00
Register ReactRootView into FabricUIManagerModule
Reviewed By: achen1 Differential Revision: D7043902 fbshipit-source-id: fecef5a019dadd3d2802baa20dd8a3711e566ed3
This commit is contained in:
parent
b57a78c3de
commit
d352c93487
@ -1,6 +1,6 @@
|
||||
load("//ReactNative:DEFS.bzl", "rn_android_library", "react_native_dep", "react_native_target")
|
||||
|
||||
android_library(
|
||||
rn_android_library(
|
||||
name = "fabric",
|
||||
srcs = glob(["*.java"]),
|
||||
provided_deps = [
|
||||
@ -13,10 +13,11 @@ android_library(
|
||||
deps = [
|
||||
react_native_dep("third-party/java/infer-annotations:infer-annotations"),
|
||||
react_native_dep("third-party/java/jsr-305:jsr-305"),
|
||||
react_native_target("java/com/facebook/react:reactAndroid"),
|
||||
react_native_target("java/com/facebook/react/bridge:bridgeAndroid"),
|
||||
react_native_target("java/com/facebook/react/uimanager:uimanagerAndroid"),
|
||||
react_native_target("java/com/facebook/react/uimanager/annotations:annotationsAndroid"),
|
||||
react_native_target("java/com/facebook/react/module/annotations:annotationsAndroid"),
|
||||
react_native_target("java/com/facebook/react:react"),
|
||||
react_native_target("java/com/facebook/react/bridge:bridge"),
|
||||
react_native_target("java/com/facebook/react/uimanager:uimanager"),
|
||||
react_native_target("java/com/facebook/react/uimanager/annotations:annotations"),
|
||||
react_native_target("java/com/facebook/react/module/annotations:annotations"),
|
||||
react_native_target("java/com/facebook/react/modules/i18nmanager:i18nmanager"),
|
||||
],
|
||||
)
|
||||
|
@ -4,12 +4,14 @@ package com.facebook.react.fabric;
|
||||
|
||||
import com.facebook.react.bridge.ReactApplicationContext;
|
||||
import com.facebook.react.bridge.ReadableMap;
|
||||
import com.facebook.react.modules.i18nmanager.I18nUtil;
|
||||
import com.facebook.react.uimanager.MeasureSpecProvider;
|
||||
import com.facebook.react.uimanager.NativeViewHierarchyOptimizer;
|
||||
import com.facebook.react.uimanager.ReactRootViewTagGenerator;
|
||||
import com.facebook.react.uimanager.ReactShadowNode;
|
||||
import com.facebook.react.uimanager.ReactShadowNodeImpl;
|
||||
import com.facebook.react.uimanager.ReactStylesDiffMap;
|
||||
import com.facebook.react.uimanager.SizeMonitoringFrameLayout;
|
||||
import com.facebook.react.uimanager.ThemedReactContext;
|
||||
import com.facebook.react.uimanager.UIModule;
|
||||
import com.facebook.react.uimanager.ViewManager;
|
||||
import com.facebook.react.uimanager.ViewManagerRegistry;
|
||||
@ -24,6 +26,7 @@ import javax.annotation.Nullable;
|
||||
@SuppressWarnings("unused") // used from JNI
|
||||
public class FabricUIManagerModule implements UIModule {
|
||||
|
||||
private final RootShadowNodeRegistry mRootShadowNodeRegistry = new RootShadowNodeRegistry();
|
||||
private final ReactApplicationContext mReactApplicationContext;
|
||||
private final ViewManagerRegistry mViewManagerRegistry;
|
||||
|
||||
@ -43,19 +46,23 @@ public class FabricUIManagerModule implements UIModule {
|
||||
ReadableMap props) {
|
||||
|
||||
ViewManager viewManager = mViewManagerRegistry.get(viewName);
|
||||
ReactShadowNode shadowNode = viewManager.createShadowNodeInstance(mReactApplicationContext);
|
||||
shadowNode.setRootTag(rootTag);
|
||||
shadowNode.setReactTag(reactTag);
|
||||
ReactStylesDiffMap styles = updateProps(props, shadowNode);
|
||||
ReactShadowNode node = viewManager.createShadowNodeInstance(mReactApplicationContext);
|
||||
node.setRootNode(getRootNode(rootTag));
|
||||
node.setReactTag(reactTag);
|
||||
ReactStylesDiffMap styles = updateProps(props, node);
|
||||
|
||||
return shadowNode;
|
||||
return node;
|
||||
}
|
||||
|
||||
private ReactStylesDiffMap updateProps(ReadableMap props, ReactShadowNode shadowNode) {
|
||||
private ReactShadowNode getRootNode(int rootTag) {
|
||||
return mRootShadowNodeRegistry.getNode(rootTag);
|
||||
}
|
||||
|
||||
private ReactStylesDiffMap updateProps(ReadableMap props, ReactShadowNode node) {
|
||||
ReactStylesDiffMap styles = null;
|
||||
if (props != null) {
|
||||
styles = new ReactStylesDiffMap(props);
|
||||
shadowNode.updateProperties(styles);
|
||||
node.updateProperties(styles);
|
||||
}
|
||||
return styles;
|
||||
}
|
||||
@ -134,15 +141,34 @@ public class FabricUIManagerModule implements UIModule {
|
||||
}
|
||||
|
||||
public void completeRoot(int rootTag, List<ReactShadowNode> childList) {
|
||||
// TODO Diffing old Tree with new Tree?
|
||||
// TODO Diffing old Tree with new Tree
|
||||
// Do we need to hold references to old and new tree?
|
||||
}
|
||||
|
||||
@Override
|
||||
public <T extends SizeMonitoringFrameLayout & MeasureSpecProvider> int addRootView(
|
||||
final T rootView) {
|
||||
// TODO: complete with actual implementation
|
||||
return ReactRootViewTagGenerator.getNextRootViewTag();
|
||||
int rootTag = ReactRootViewTagGenerator.getNextRootViewTag();
|
||||
ThemedReactContext themedRootContext = new ThemedReactContext(
|
||||
mReactApplicationContext,
|
||||
rootView.getContext());
|
||||
|
||||
mRootShadowNodeRegistry.addNode(createRootShadowNode(rootTag, themedRootContext));
|
||||
return rootTag;
|
||||
}
|
||||
|
||||
public void removeRootView(int rootTag) {
|
||||
mRootShadowNodeRegistry.removeNode(rootTag);
|
||||
}
|
||||
|
||||
private ReactShadowNode createRootShadowNode(int rootTag, ThemedReactContext themedReactContext) {
|
||||
ReactShadowNode rootNode = new ReactShadowNodeImpl();
|
||||
I18nUtil sharedI18nUtilInstance = I18nUtil.getInstance();
|
||||
// TODO: setLayoutDirection for the rootNode
|
||||
rootNode.setViewClassName("Root");
|
||||
rootNode.setReactTag(rootTag);
|
||||
rootNode.setThemedContext(themedReactContext);
|
||||
return rootNode;
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -0,0 +1,29 @@
|
||||
package com.facebook.react.fabric;
|
||||
|
||||
import android.util.SparseArray;
|
||||
import com.facebook.react.uimanager.ReactShadowNode;
|
||||
|
||||
/**
|
||||
* Simple container class to keep track of {@link ReactShadowNode}s that represents the Root
|
||||
* Shadow Nodes of a {@link FabricUIManagerModule}
|
||||
*/
|
||||
public class RootShadowNodeRegistry {
|
||||
|
||||
private final SparseArray<ReactShadowNode> mTagsToRootNodes;
|
||||
|
||||
public RootShadowNodeRegistry() {
|
||||
mTagsToRootNodes = new SparseArray<>();
|
||||
}
|
||||
|
||||
public void addNode(ReactShadowNode node) {
|
||||
mTagsToRootNodes.put(node.getReactTag(), node);
|
||||
}
|
||||
|
||||
public void removeNode(int tag) {
|
||||
mTagsToRootNodes.remove(tag);
|
||||
}
|
||||
|
||||
public ReactShadowNode getNode(int tag) {
|
||||
return mTagsToRootNodes.get(tag);
|
||||
}
|
||||
}
|
@ -132,11 +132,8 @@ public interface ReactShadowNode<T extends ReactShadowNode> {
|
||||
|
||||
T getRootNode();
|
||||
|
||||
@Deprecated() //Replaced by setRootTag method.
|
||||
void setRootNode(T rootNode);
|
||||
|
||||
void setRootTag(int rootTag);
|
||||
|
||||
void setViewClassName(String viewClassName);
|
||||
|
||||
@Nullable
|
||||
|
@ -410,11 +410,6 @@ public class ReactShadowNodeImpl implements ReactShadowNode<ReactShadowNodeImpl>
|
||||
mRootNode = rootNode;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setRootTag(int rootTag) {
|
||||
mRootTag = rootTag;
|
||||
}
|
||||
|
||||
@Override
|
||||
public final void setViewClassName(String viewClassName) {
|
||||
mViewClassName = viewClassName;
|
||||
|
@ -277,7 +277,6 @@ public class UIImplementation {
|
||||
cssNode.setReactTag(tag);
|
||||
cssNode.setViewClassName(className);
|
||||
cssNode.setRootNode(rootNode);
|
||||
if (rootNode != null) cssNode.setRootTag(rootNode.getReactTag());
|
||||
cssNode.setThemedContext(rootNode.getThemedContext());
|
||||
|
||||
mShadowNodeRegistry.addNode(cssNode);
|
||||
|
Loading…
x
Reference in New Issue
Block a user