Revert "[React Native] Add getInspectorDataForViewAtPoint (#18233)"
This reverts commit bf351089a0
.
This commit is contained in:
parent
dc7eedae3c
commit
a463fef31b
|
@ -34,10 +34,7 @@ import ReactVersion from 'shared/ReactVersion';
|
|||
import {UIManager} from 'react-native/Libraries/ReactPrivate/ReactNativePrivateInterface';
|
||||
|
||||
import {getClosestInstanceFromNode} from './ReactFabricComponentTree';
|
||||
import {
|
||||
getInspectorDataForViewAtPoint,
|
||||
getInspectorDataForViewTag,
|
||||
} from './ReactNativeFiberInspector';
|
||||
import {getInspectorDataForViewTag} from './ReactNativeFiberInspector';
|
||||
|
||||
import {LegacyRoot} from 'shared/ReactRootTags';
|
||||
import ReactSharedInternals from 'shared/ReactSharedInternals';
|
||||
|
@ -236,10 +233,6 @@ export {
|
|||
injectIntoDevTools({
|
||||
findFiberByHostInstance: getClosestInstanceFromNode,
|
||||
getInspectorDataForViewTag: getInspectorDataForViewTag,
|
||||
getInspectorDataForViewAtPoint: getInspectorDataForViewAtPoint.bind(
|
||||
null,
|
||||
findNodeHandle,
|
||||
),
|
||||
bundleType: __DEV__ ? 1 : 0,
|
||||
version: ReactVersion,
|
||||
rendererPackageName: 'react-native-renderer',
|
||||
|
|
|
@ -34,17 +34,11 @@ class ReactNativeFiberHostComponent {
|
|||
_children: Array<Instance | number>;
|
||||
_nativeTag: number;
|
||||
viewConfig: ReactNativeBaseComponentViewConfig<>;
|
||||
_internalFiberInstanceHandle: Object;
|
||||
|
||||
constructor(
|
||||
tag: number,
|
||||
viewConfig: ReactNativeBaseComponentViewConfig<>,
|
||||
internalInstanceHandle: Object,
|
||||
) {
|
||||
constructor(tag: number, viewConfig: ReactNativeBaseComponentViewConfig<>) {
|
||||
this._nativeTag = tag;
|
||||
this._children = [];
|
||||
this.viewConfig = viewConfig;
|
||||
this._internalFiberInstanceHandle = internalInstanceHandle;
|
||||
}
|
||||
|
||||
blur() {
|
||||
|
|
|
@ -8,7 +8,6 @@
|
|||
*/
|
||||
|
||||
import type {Fiber} from 'react-reconciler/src/ReactFiber';
|
||||
import type {TouchedViewDataAtPoint, InspectorData} from './ReactNativeTypes';
|
||||
|
||||
import {
|
||||
findCurrentHostFiber,
|
||||
|
@ -28,7 +27,6 @@ if (__DEV__) {
|
|||
}
|
||||
|
||||
let getInspectorDataForViewTag;
|
||||
let getInspectorDataForViewAtPoint;
|
||||
|
||||
if (__DEV__) {
|
||||
const traverseOwnerTreeUp = function(hierarchy, instance: any) {
|
||||
|
@ -82,68 +80,15 @@ if (__DEV__) {
|
|||
const createHierarchy = function(fiberHierarchy) {
|
||||
return fiberHierarchy.map(fiber => ({
|
||||
name: getComponentName(fiber.type),
|
||||
getInspectorData: findNodeHandle => {
|
||||
return {
|
||||
props: getHostProps(fiber),
|
||||
source: fiber._debugSource,
|
||||
measure: callback => {
|
||||
// If this is Fabric, we'll find a ShadowNode and use that to measure.
|
||||
const hostFiber = findCurrentHostFiber(fiber);
|
||||
const shadowNode =
|
||||
hostFiber != null &&
|
||||
hostFiber.stateNode !== null &&
|
||||
hostFiber.stateNode.node;
|
||||
|
||||
if (shadowNode) {
|
||||
nativeFabricUIManager.measure(shadowNode, function(
|
||||
x,
|
||||
y,
|
||||
width,
|
||||
height,
|
||||
pageX,
|
||||
pageY,
|
||||
) {
|
||||
callback(x, y, width, height, pageX, pageY);
|
||||
});
|
||||
} else {
|
||||
return UIManager.measure(
|
||||
getHostNode(fiber, findNodeHandle),
|
||||
callback,
|
||||
);
|
||||
}
|
||||
},
|
||||
};
|
||||
},
|
||||
getInspectorData: findNodeHandle => ({
|
||||
measure: callback =>
|
||||
UIManager.measure(getHostNode(fiber, findNodeHandle), callback),
|
||||
props: getHostProps(fiber),
|
||||
source: fiber._debugSource,
|
||||
}),
|
||||
}));
|
||||
};
|
||||
|
||||
const getInspectorDataForInstance = function(closestInstance): InspectorData {
|
||||
// Handle case where user clicks outside of ReactNative
|
||||
if (!closestInstance) {
|
||||
return {
|
||||
hierarchy: [],
|
||||
props: emptyObject,
|
||||
selection: null,
|
||||
source: null,
|
||||
};
|
||||
}
|
||||
|
||||
const fiber = findCurrentFiberUsingSlowPath(closestInstance);
|
||||
const fiberHierarchy = getOwnerHierarchy(fiber);
|
||||
const instance = lastNonHostInstance(fiberHierarchy);
|
||||
const hierarchy = createHierarchy(fiberHierarchy);
|
||||
const props = getHostProps(instance);
|
||||
const source = instance._debugSource;
|
||||
const selection = fiberHierarchy.indexOf(instance);
|
||||
|
||||
return {
|
||||
hierarchy,
|
||||
props,
|
||||
selection,
|
||||
source,
|
||||
};
|
||||
};
|
||||
|
||||
getInspectorDataForViewTag = function(viewTag: number): Object {
|
||||
const closestInstance = getClosestInstanceFromNode(viewTag);
|
||||
|
||||
|
@ -172,70 +117,6 @@ if (__DEV__) {
|
|||
source,
|
||||
};
|
||||
};
|
||||
|
||||
getInspectorDataForViewAtPoint = function(
|
||||
findNodeHandle: (componentOrHandle: any) => ?number,
|
||||
inspectedView: Object,
|
||||
locationX: number,
|
||||
locationY: number,
|
||||
callback: (viewData: TouchedViewDataAtPoint) => mixed,
|
||||
): void {
|
||||
let closestInstance = null;
|
||||
|
||||
if (inspectedView._internalInstanceHandle != null) {
|
||||
// For Fabric we can look up the instance handle directly and measure it.
|
||||
nativeFabricUIManager.findNodeAtPoint(
|
||||
inspectedView._internalInstanceHandle.stateNode.node,
|
||||
locationX,
|
||||
locationY,
|
||||
internalInstanceHandle => {
|
||||
if (internalInstanceHandle == null) {
|
||||
callback({
|
||||
pointerY: locationY,
|
||||
frame: {left: 0, top: 0, width: 0, height: 0},
|
||||
...getInspectorDataForInstance(closestInstance),
|
||||
});
|
||||
}
|
||||
|
||||
closestInstance =
|
||||
internalInstanceHandle.stateNode.canonical._internalInstanceHandle;
|
||||
nativeFabricUIManager.measure(
|
||||
internalInstanceHandle.stateNode.node,
|
||||
(x, y, width, height, pageX, pageY) => {
|
||||
callback({
|
||||
pointerY: locationY,
|
||||
frame: {left: pageX, top: pageY, width, height},
|
||||
...getInspectorDataForInstance(closestInstance),
|
||||
});
|
||||
},
|
||||
);
|
||||
},
|
||||
);
|
||||
} else if (inspectedView._internalFiberInstanceHandle != null) {
|
||||
// For Paper we fall back to the old strategy using the React tag.
|
||||
UIManager.findSubviewIn(
|
||||
findNodeHandle(inspectedView),
|
||||
[locationX, locationY],
|
||||
(nativeViewTag, left, top, width, height) => {
|
||||
const inspectorData = getInspectorDataForInstance(
|
||||
getClosestInstanceFromNode(nativeViewTag),
|
||||
);
|
||||
callback({
|
||||
...inspectorData,
|
||||
pointerY: locationY,
|
||||
frame: {left, top, width, height},
|
||||
touchedViewTag: nativeViewTag,
|
||||
});
|
||||
},
|
||||
);
|
||||
} else if (__DEV__) {
|
||||
console.error(
|
||||
'getInspectorDataForViewAtPoint expects to receieve a host component',
|
||||
);
|
||||
|
||||
return;
|
||||
}
|
||||
};
|
||||
} else {
|
||||
getInspectorDataForViewTag = () => {
|
||||
invariant(
|
||||
|
@ -243,19 +124,6 @@ if (__DEV__) {
|
|||
'getInspectorDataForViewTag() is not available in production',
|
||||
);
|
||||
};
|
||||
|
||||
getInspectorDataForViewAtPoint = (
|
||||
findNodeHandle: (componentOrHandle: any) => ?number,
|
||||
inspectedView: Object,
|
||||
locationX: number,
|
||||
locationY: number,
|
||||
callback: (viewData: TouchedViewDataAtPoint) => mixed,
|
||||
): void => {
|
||||
invariant(
|
||||
false,
|
||||
'getInspectorDataForViewAtPoint() is not available in production.',
|
||||
);
|
||||
};
|
||||
}
|
||||
|
||||
export {getInspectorDataForViewAtPoint, getInspectorDataForViewTag};
|
||||
export {getInspectorDataForViewTag};
|
||||
|
|
|
@ -112,11 +112,7 @@ export function createInstance(
|
|||
updatePayload, // props
|
||||
);
|
||||
|
||||
const component = new ReactNativeFiberHostComponent(
|
||||
tag,
|
||||
viewConfig,
|
||||
internalInstanceHandle,
|
||||
);
|
||||
const component = new ReactNativeFiberHostComponent(tag, viewConfig);
|
||||
|
||||
precacheFiberNode(internalInstanceHandle, tag);
|
||||
updateFiberProps(tag, props);
|
||||
|
|
|
@ -36,10 +36,7 @@ import ReactVersion from 'shared/ReactVersion';
|
|||
import {UIManager} from 'react-native/Libraries/ReactPrivate/ReactNativePrivateInterface';
|
||||
|
||||
import {getClosestInstanceFromNode} from './ReactNativeComponentTree';
|
||||
import {
|
||||
getInspectorDataForViewTag,
|
||||
getInspectorDataForViewAtPoint,
|
||||
} from './ReactNativeFiberInspector';
|
||||
import {getInspectorDataForViewTag} from './ReactNativeFiberInspector';
|
||||
|
||||
import {LegacyRoot} from 'shared/ReactRootTags';
|
||||
import ReactSharedInternals from 'shared/ReactSharedInternals';
|
||||
|
@ -250,10 +247,6 @@ export {
|
|||
injectIntoDevTools({
|
||||
findFiberByHostInstance: getClosestInstanceFromNode,
|
||||
getInspectorDataForViewTag: getInspectorDataForViewTag,
|
||||
getInspectorDataForViewAtPoint: getInspectorDataForViewAtPoint.bind(
|
||||
null,
|
||||
findNodeHandle,
|
||||
),
|
||||
bundleType: __DEV__ ? 1 : 0,
|
||||
version: ReactVersion,
|
||||
rendererPackageName: 'react-native-renderer',
|
||||
|
|
|
@ -100,46 +100,6 @@ type SecretInternalsType = {
|
|||
...
|
||||
};
|
||||
|
||||
type InspectorDataProps = $ReadOnly<{
|
||||
[propName: string]: string,
|
||||
...,
|
||||
}>;
|
||||
|
||||
type InspectorDataSource = $ReadOnly<{|
|
||||
fileName?: string,
|
||||
lineNumber?: number,
|
||||
|}>;
|
||||
|
||||
type InspectorDataGetter = (
|
||||
(componentOrHandle: any) => ?number,
|
||||
) => $ReadOnly<{|
|
||||
measure: Function,
|
||||
props: InspectorDataProps,
|
||||
source: InspectorDataSource,
|
||||
|}>;
|
||||
|
||||
export type InspectorData = $ReadOnly<{|
|
||||
hierarchy: Array<{|
|
||||
name: ?string,
|
||||
getInspectorData: InspectorDataGetter,
|
||||
|}>,
|
||||
selection: ?number,
|
||||
props: InspectorDataProps,
|
||||
source: ?InspectorDataSource,
|
||||
|}>;
|
||||
|
||||
export type TouchedViewDataAtPoint = $ReadOnly<{|
|
||||
pointerY: number,
|
||||
touchedViewTag?: number,
|
||||
frame: $ReadOnly<{|
|
||||
top: number,
|
||||
left: number,
|
||||
width: number,
|
||||
height: number,
|
||||
|}>,
|
||||
...InspectorData,
|
||||
|}>;
|
||||
|
||||
/**
|
||||
* Flat ReactNative renderer bundles are too big for Flow to parse efficiently.
|
||||
* Provide minimal Flow typing for the high-level RN API and call it a day.
|
||||
|
|
|
@ -10,7 +10,6 @@
|
|||
import type {Fiber} from './ReactFiber';
|
||||
import type {FiberRoot} from './ReactFiberRoot';
|
||||
import type {RootTag} from 'shared/ReactRootTags';
|
||||
import type {TouchedViewDataAtPoint} from 'react-native-renderer/src/ReactNativeTypes';
|
||||
import type {
|
||||
Instance,
|
||||
TextInstance,
|
||||
|
@ -110,13 +109,6 @@ type DevToolsConfig = {|
|
|||
// This API is unfortunately RN-specific.
|
||||
// TODO: Change it to accept Fiber instead and type it properly.
|
||||
getInspectorDataForViewTag?: (tag: number) => Object,
|
||||
// Used by RN in-app inspector.
|
||||
getInspectorDataForViewAtPoint?: (
|
||||
inspectedView: Object,
|
||||
locationX: number,
|
||||
locationY: number,
|
||||
callback: (viewData: TouchedViewDataAtPoint) => mixed,
|
||||
) => void,
|
||||
|};
|
||||
|
||||
let didWarnAboutNestedUpdates;
|
||||
|
|
|
@ -346,6 +346,5 @@
|
|||
"345": "Root did not complete. This is a bug in React.",
|
||||
"346": "An event responder context was used outside of an event cycle.",
|
||||
"347": "Maps are not valid as a React child (found: %s). Consider converting children to an array of keyed ReactElements instead.",
|
||||
"348": "ensureListeningTo(): received a container that was not an element node. This is likely a bug in React.",
|
||||
"349": "getInspectorDataForViewAtPoint() is not available in production."
|
||||
"348": "ensureListeningTo(): received a container that was not an element node. This is likely a bug in React."
|
||||
}
|
||||
|
|
|
@ -18,7 +18,6 @@ import type {
|
|||
} from 'react-native-renderer/src/ReactNativeTypes';
|
||||
import type {RNTopLevelEventType} from 'legacy-events/TopLevelEventTypes';
|
||||
import type {CapturedError} from 'react-reconciler/src/ReactCapturedValue';
|
||||
import type {Fiber} from 'react-reconciler/src/ReactFiber';
|
||||
|
||||
type DeepDifferOptions = {|+unsafelyIgnoreFunctions?: boolean|};
|
||||
|
||||
|
@ -97,17 +96,6 @@ declare module 'react-native/Libraries/ReactPrivate/ReactNativePrivateInterface'
|
|||
) => Promise<any>,
|
||||
setJSResponder: (reactTag: number, blockNativeResponder: boolean) => void,
|
||||
clearJSResponder: () => void,
|
||||
findSubviewIn: (
|
||||
reactTag: ?number,
|
||||
point: Array<number>,
|
||||
callback: (
|
||||
nativeViewTag: number,
|
||||
left: number,
|
||||
top: number,
|
||||
width: number,
|
||||
height: number,
|
||||
) => void,
|
||||
) => void,
|
||||
...
|
||||
};
|
||||
declare export var BatchedBridge: {
|
||||
|
@ -168,12 +156,6 @@ declare var nativeFabricUIManager: {
|
|||
onFail: () => void,
|
||||
onSuccess: MeasureLayoutOnSuccessCallback,
|
||||
) => void,
|
||||
findNodeAtPoint: (
|
||||
node: Node,
|
||||
locationX: number,
|
||||
locationY: number,
|
||||
callback: (Fiber) => void,
|
||||
) => void,
|
||||
...
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in New Issue